diff options
author | Sergey Bugaev <bugaevc@gmail.com> | 2019-08-18 14:48:15 +0300 |
---|---|---|
committer | Andreas Kling <awesomekling@gmail.com> | 2019-08-18 15:59:59 +0200 |
commit | acccf9ccda13e134c3fb75b78d26c9465aa23510 (patch) | |
tree | f6bbeba0e552e246cf4620aee4f50cfe39aa7349 /Kernel/FileSystem | |
parent | d5352b87b749609837bfc5387d65baa81806b22e (diff) | |
download | serenity-acccf9ccda13e134c3fb75b78d26c9465aa23510.zip |
Kernel: Move device lookup to Device class itself
Previously, VFS stored a list of all devices, and devices had to
register and unregister themselves with it. This cleans up things
a bit.
Diffstat (limited to 'Kernel/FileSystem')
-rw-r--r-- | Kernel/FileSystem/DevPtsFS.cpp | 2 | ||||
-rw-r--r-- | Kernel/FileSystem/VirtualFileSystem.cpp | 23 | ||||
-rw-r--r-- | Kernel/FileSystem/VirtualFileSystem.h | 6 |
3 files changed, 4 insertions, 27 deletions
diff --git a/Kernel/FileSystem/DevPtsFS.cpp b/Kernel/FileSystem/DevPtsFS.cpp index cb7203d83b..73d2113e51 100644 --- a/Kernel/FileSystem/DevPtsFS.cpp +++ b/Kernel/FileSystem/DevPtsFS.cpp @@ -69,7 +69,7 @@ RefPtr<Inode> DevPtsFS::get_inode(InodeIdentifier inode_id) const return m_root_inode; unsigned pty_index = inode_index_to_pty_index(inode_id.index()); - auto* device = VFS::the().get_device(11, pty_index); + auto* device = Device::get_device(11, pty_index); ASSERT(device); auto inode = adopt(*new DevPtsFSInode(const_cast<DevPtsFS&>(*this), inode_id.index())); diff --git a/Kernel/FileSystem/VirtualFileSystem.cpp b/Kernel/FileSystem/VirtualFileSystem.cpp index 3b2b9c5274..459753221c 100644 --- a/Kernel/FileSystem/VirtualFileSystem.cpp +++ b/Kernel/FileSystem/VirtualFileSystem.cpp @@ -216,11 +216,11 @@ KResultOr<NonnullRefPtr<FileDescription>> VFS::open(StringView path, int options } if (metadata.is_device()) { - auto it = m_devices.find(encoded_device(metadata.major_device, metadata.minor_device)); - if (it == m_devices.end()) { + auto device = Device::get_device(metadata.major_device, metadata.minor_device); + if (device == nullptr) { return KResult(-ENODEV); } - auto descriptor_or_error = (*it).value->open(options); + auto descriptor_or_error = device->open(options); if (descriptor_or_error.is_error()) return descriptor_or_error.error(); descriptor_or_error.value()->set_original_inode({}, inode); @@ -615,23 +615,6 @@ InodeIdentifier VFS::Mount::host() const return m_host_custody->inode().identifier(); } -void VFS::register_device(Badge<Device>, Device& device) -{ - m_devices.set(encoded_device(device.major(), device.minor()), &device); -} - -void VFS::unregister_device(Badge<Device>, Device& device) -{ - m_devices.remove(encoded_device(device.major(), device.minor())); -} - -Device* VFS::get_device(unsigned major, unsigned minor) -{ - auto it = m_devices.find(encoded_device(major, minor)); - if (it == m_devices.end()) - return nullptr; - return (*it).value; -} void VFS::for_each_mount(Function<void(const Mount&)> callback) const { diff --git a/Kernel/FileSystem/VirtualFileSystem.h b/Kernel/FileSystem/VirtualFileSystem.h index dcce762312..f439d675c1 100644 --- a/Kernel/FileSystem/VirtualFileSystem.h +++ b/Kernel/FileSystem/VirtualFileSystem.h @@ -79,9 +79,6 @@ public: KResult mknod(StringView path, mode_t, dev_t, Custody& base); KResultOr<NonnullRefPtr<Custody>> open_directory(StringView path, Custody& base); - void register_device(Badge<Device>, Device&); - void unregister_device(Badge<Device>, Device&); - size_t mount_count() const { return m_mounts.size(); } void for_each_mount(Function<void(const Mount&)>) const; @@ -89,8 +86,6 @@ public: void sync(); - Device* get_device(unsigned major, unsigned minor); - Custody& root_custody(); KResultOr<NonnullRefPtr<Custody>> resolve_path(StringView path, Custody& base, RefPtr<Custody>* parent = nullptr, int options = 0); @@ -110,7 +105,6 @@ private: RefPtr<Inode> m_root_inode; NonnullOwnPtrVector<Mount> m_mounts; - HashMap<u32, Device*> m_devices; RefPtr<Custody> m_root_custody; }; |