From 8bf248a046fcf18b0d96f65b4dc1054bb7185ea2 Mon Sep 17 00:00:00 2001 From: Andreas Kling Date: Sun, 19 Feb 2023 23:01:04 +0100 Subject: [PATCH] Kernel: Make NNRP possible This wasn't possible before as ref() and unref() were non-const. --- Kernel/Memory/PhysicalPage.cpp | 2 +- Kernel/Memory/PhysicalPage.h | 8 ++++---- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/Kernel/Memory/PhysicalPage.cpp b/Kernel/Memory/PhysicalPage.cpp index b4890b5c4a3..2f5ceb5b9a2 100644 --- a/Kernel/Memory/PhysicalPage.cpp +++ b/Kernel/Memory/PhysicalPage.cpp @@ -26,7 +26,7 @@ PhysicalAddress PhysicalPage::paddr() const return MM.get_physical_address(*this); } -void PhysicalPage::free_this() +void PhysicalPage::free_this() const { auto paddr = MM.get_physical_address(*this); if (m_may_return_to_freelist == MayReturnToFreeList::Yes) { diff --git a/Kernel/Memory/PhysicalPage.h b/Kernel/Memory/PhysicalPage.h index 724eb6d5c44..c0869ffb000 100644 --- a/Kernel/Memory/PhysicalPage.h +++ b/Kernel/Memory/PhysicalPage.h @@ -25,12 +25,12 @@ class PhysicalPage { public: PhysicalAddress paddr() const; - void ref() + void ref() const { m_ref_count.fetch_add(1, AK::memory_order_relaxed); } - void unref() + void unref() const { if (m_ref_count.fetch_sub(1, AK::memory_order_acq_rel) == 1) free_this(); @@ -47,9 +47,9 @@ private: explicit PhysicalPage(MayReturnToFreeList may_return_to_freelist); ~PhysicalPage() = default; - void free_this(); + void free_this() const; - Atomic m_ref_count { 1 }; + mutable Atomic m_ref_count { 1 }; MayReturnToFreeList m_may_return_to_freelist { MayReturnToFreeList::Yes }; };