summaryrefslogtreecommitdiff
path: root/Kernel/VM/ContiguousVMObject.cpp
diff options
context:
space:
mode:
authorTom <tomut@yahoo.com>2020-09-04 21:12:25 -0600
committerAndreas Kling <kling@serenityos.org>2021-01-01 23:43:44 +0100
commitb2a52f62089e4799336cf0bf32eb307b077d2e72 (patch)
treed0e3763a1a452357c76b5fe68fa3ab1b6bc83147 /Kernel/VM/ContiguousVMObject.cpp
parente21cc4cff63c36917d83730871dfff1a9f0eb927 (diff)
downloadserenity-b2a52f62089e4799336cf0bf32eb307b077d2e72.zip
Kernel: Implement lazy committed page allocation
By designating a committed page pool we can guarantee to have physical pages available for lazy allocation in mappings. However, when forking we will overcommit. The assumption is that worst-case it's better for the fork to die due to insufficient physical memory on COW access than the parent that created the region. If a fork wants to ensure that all memory is available (trigger a commit) then it can use madvise. This also means that fork now can gracefully fail if we don't have enough physical pages available.
Diffstat (limited to 'Kernel/VM/ContiguousVMObject.cpp')
-rw-r--r--Kernel/VM/ContiguousVMObject.cpp2
1 files changed, 1 insertions, 1 deletions
diff --git a/Kernel/VM/ContiguousVMObject.cpp b/Kernel/VM/ContiguousVMObject.cpp
index 41a188f553..13238a6041 100644
--- a/Kernel/VM/ContiguousVMObject.cpp
+++ b/Kernel/VM/ContiguousVMObject.cpp
@@ -58,7 +58,7 @@ ContiguousVMObject::~ContiguousVMObject()
{
}
-NonnullRefPtr<VMObject> ContiguousVMObject::clone()
+RefPtr<VMObject> ContiguousVMObject::clone()
{
ASSERT_NOT_REACHED();
}