DirectoryInode.cpp 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. /*
  2. * Copyright (c) 2021, Liav A. <liavalb@hotmail.co.il>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include <AK/StringView.h>
  7. #include <Kernel/FileSystem/SysFS/DirectoryInode.h>
  8. #include <Kernel/Sections.h>
  9. #include <Kernel/Time/TimeManagement.h>
  10. namespace Kernel {
  11. ErrorOr<NonnullLockRefPtr<SysFSDirectoryInode>> SysFSDirectoryInode::try_create(SysFS const& sysfs, SysFSComponent const& component)
  12. {
  13. return adopt_nonnull_lock_ref_or_enomem(new (nothrow) SysFSDirectoryInode(sysfs, component));
  14. }
  15. SysFSDirectoryInode::SysFSDirectoryInode(SysFS const& fs, SysFSComponent const& component)
  16. : SysFSInode(fs, component)
  17. {
  18. }
  19. SysFSDirectoryInode::~SysFSDirectoryInode() = default;
  20. InodeMetadata SysFSDirectoryInode::metadata() const
  21. {
  22. // NOTE: No locking required as m_associated_component or its component index will never change during our lifetime.
  23. InodeMetadata metadata;
  24. metadata.inode = { fsid(), m_associated_component->component_index() };
  25. metadata.mode = S_IFDIR | S_IRUSR | S_IRGRP | S_IROTH | S_IXOTH;
  26. metadata.uid = 0;
  27. metadata.gid = 0;
  28. metadata.size = 0;
  29. metadata.mtime = TimeManagement::boot_time();
  30. return metadata;
  31. }
  32. ErrorOr<void> SysFSDirectoryInode::traverse_as_directory(Function<ErrorOr<void>(FileSystem::DirectoryEntryView const&)> callback) const
  33. {
  34. MutexLocker locker(fs().m_lock);
  35. return m_associated_component->traverse_as_directory(fs().fsid(), move(callback));
  36. }
  37. ErrorOr<NonnullLockRefPtr<Inode>> SysFSDirectoryInode::lookup(StringView name)
  38. {
  39. MutexLocker locker(fs().m_lock);
  40. auto component = m_associated_component->lookup(name);
  41. if (!component)
  42. return ENOENT;
  43. return TRY(component->to_inode(fs()));
  44. }
  45. }