Custody.h 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. /*
  2. * Copyright (c) 2018-2022, Andreas Kling <kling@serenityos.org>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #pragma once
  7. #include <AK/Error.h>
  8. #include <AK/IntrusiveList.h>
  9. #include <AK/RefPtr.h>
  10. #include <Kernel/Forward.h>
  11. #include <Kernel/KString.h>
  12. #include <Kernel/Library/ListedRefCounted.h>
  13. #include <Kernel/Locking/SpinlockProtected.h>
  14. namespace Kernel {
  15. class Custody final : public ListedRefCounted<Custody, LockType::Spinlock> {
  16. public:
  17. static ErrorOr<NonnullRefPtr<Custody>> try_create(Custody* parent, StringView name, Inode&, int mount_flags);
  18. ~Custody();
  19. RefPtr<Custody> parent() { return m_parent; }
  20. RefPtr<Custody const> parent() const { return m_parent; }
  21. Inode& inode() { return *m_inode; }
  22. Inode const& inode() const { return *m_inode; }
  23. StringView name() const { return m_name->view(); }
  24. ErrorOr<NonnullOwnPtr<KString>> try_serialize_absolute_path() const;
  25. int mount_flags() const { return m_mount_flags; }
  26. bool is_readonly() const;
  27. private:
  28. Custody(Custody* parent, NonnullOwnPtr<KString> name, Inode&, int mount_flags);
  29. RefPtr<Custody> m_parent;
  30. NonnullOwnPtr<KString> m_name;
  31. NonnullLockRefPtr<Inode> m_inode;
  32. int m_mount_flags { 0 };
  33. mutable IntrusiveListNode<Custody> m_all_custodies_list_node;
  34. public:
  35. using AllCustodiesList = IntrusiveList<&Custody::m_all_custodies_list_node>;
  36. static SpinlockProtected<Custody::AllCustodiesList, LockRank::None>& all_instances();
  37. };
  38. }