Component.h 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. /*
  2. * Copyright (c) 2021, Liav A. <liavalb@hotmail.co.il>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #pragma once
  7. #include <AK/AtomicRefCounted.h>
  8. #include <AK/Error.h>
  9. #include <AK/Function.h>
  10. #include <AK/StringView.h>
  11. #include <AK/Types.h>
  12. #include <Kernel/FileSystem/File.h>
  13. #include <Kernel/FileSystem/FileSystem.h>
  14. #include <Kernel/FileSystem/OpenFileDescription.h>
  15. #include <Kernel/Forward.h>
  16. #include <Kernel/Library/LockRefPtr.h>
  17. namespace Kernel {
  18. struct SysFSInodeData : public OpenFileDescriptionData {
  19. OwnPtr<KBuffer> buffer;
  20. };
  21. class SysFSDirectory;
  22. class SysFSComponent : public AtomicRefCounted<SysFSComponent> {
  23. friend class SysFSDirectory;
  24. public:
  25. virtual StringView name() const = 0;
  26. virtual ErrorOr<size_t> read_bytes(off_t, size_t, UserOrKernelBuffer&, OpenFileDescription*) const { return Error::from_errno(ENOTIMPL); }
  27. virtual ErrorOr<void> traverse_as_directory(FileSystemID, Function<ErrorOr<void>(FileSystem::DirectoryEntryView const&)>) const { VERIFY_NOT_REACHED(); }
  28. virtual LockRefPtr<SysFSComponent> lookup(StringView) { VERIFY_NOT_REACHED(); };
  29. virtual mode_t permissions() const;
  30. virtual ErrorOr<void> truncate(u64) { return EPERM; }
  31. virtual size_t size() const { return 0; }
  32. virtual ErrorOr<size_t> write_bytes(off_t, size_t, UserOrKernelBuffer const&, OpenFileDescription*) { return EROFS; }
  33. virtual ErrorOr<void> refresh_data(OpenFileDescription&) const { return {}; }
  34. virtual ErrorOr<NonnullLockRefPtr<SysFSInode>> to_inode(SysFS const&) const;
  35. InodeIndex component_index() const { return m_component_index; };
  36. virtual ~SysFSComponent() = default;
  37. ErrorOr<NonnullOwnPtr<KString>> relative_path(NonnullOwnPtr<KString>, size_t current_hop = 0) const;
  38. ErrorOr<size_t> relative_path_hops_count_from_mountpoint(size_t current_hop = 0) const;
  39. protected:
  40. explicit SysFSComponent(SysFSDirectory const& parent_directory);
  41. SysFSComponent();
  42. LockRefPtr<SysFSDirectory> m_parent_directory;
  43. IntrusiveListNode<SysFSComponent, NonnullLockRefPtr<SysFSComponent>> m_list_node;
  44. private:
  45. InodeIndex m_component_index {};
  46. };
  47. class SysFSSymbolicLink : public SysFSComponent {
  48. public:
  49. virtual ErrorOr<size_t> read_bytes(off_t, size_t, UserOrKernelBuffer&, OpenFileDescription*) const override final;
  50. virtual ErrorOr<NonnullLockRefPtr<SysFSInode>> to_inode(SysFS const& sysfs_instance) const override final;
  51. protected:
  52. ErrorOr<NonnullOwnPtr<KString>> try_generate_return_path_to_mount_point() const;
  53. ErrorOr<NonnullOwnPtr<KBuffer>> try_to_generate_buffer() const;
  54. explicit SysFSSymbolicLink(SysFSDirectory const& parent_directory, SysFSComponent const& pointed_component);
  55. LockRefPtr<SysFSComponent> m_pointed_component;
  56. };
  57. class SysFSDirectory : public SysFSComponent {
  58. public:
  59. virtual ErrorOr<void> traverse_as_directory(FileSystemID, Function<ErrorOr<void>(FileSystem::DirectoryEntryView const&)>) const override final;
  60. virtual LockRefPtr<SysFSComponent> lookup(StringView name) override final;
  61. virtual ErrorOr<NonnullLockRefPtr<SysFSInode>> to_inode(SysFS const& sysfs_instance) const override final;
  62. using ChildList = SpinlockProtected<IntrusiveList<&SysFSComponent::m_list_node>, LockRank::None>;
  63. protected:
  64. virtual bool is_root_directory() const { return false; }
  65. SysFSDirectory() {};
  66. explicit SysFSDirectory(SysFSDirectory const& parent_directory);
  67. ChildList m_child_components {};
  68. };
  69. }