DirectoryInode.cpp 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  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<NonnullRefPtr<SysFSDirectoryInode>> SysFSDirectoryInode::try_create(SysFS const& sysfs, SysFSComponent const& component)
  12. {
  13. return adopt_nonnull_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. return m_associated_component->traverse_as_directory(fs().fsid(), move(callback));
  35. }
  36. ErrorOr<NonnullRefPtr<Inode>> SysFSDirectoryInode::lookup(StringView name)
  37. {
  38. auto component = m_associated_component->lookup(name);
  39. if (!component)
  40. return ENOENT;
  41. return TRY(component->to_inode(fs()));
  42. }
  43. }