aboutsummaryrefslogtreecommitdiff
path: root/arch/x86_64/src/memory/heap
diff options
context:
space:
mode:
authorMatteo Gmür <matteo.gmuer1@ost.ch>2024-12-02 13:51:58 +0000
committerMatteo Gmür <matteo.gmuer1@ost.ch>2024-12-02 13:51:58 +0000
commitdcd83b71c833e86c7e00e2b8f75ab6208b5d360d (patch)
tree9d35296dfa4fc45de2347942abce3ccec8676fe7 /arch/x86_64/src/memory/heap
parentf7abde02150deacbc2ad1957e6165769cc2fea0b (diff)
downloadteachos-dcd83b71c833e86c7e00e2b8f75ab6208b5d360d.tar.xz
teachos-dcd83b71c833e86c7e00e2b8f75ab6208b5d360d.zip
WIP thread safe linked list
Diffstat (limited to 'arch/x86_64/src/memory/heap')
-rw-r--r--arch/x86_64/src/memory/heap/linked_list_allocator.cpp8
1 files changed, 4 insertions, 4 deletions
diff --git a/arch/x86_64/src/memory/heap/linked_list_allocator.cpp b/arch/x86_64/src/memory/heap/linked_list_allocator.cpp
index f596f27..22b5757 100644
--- a/arch/x86_64/src/memory/heap/linked_list_allocator.cpp
+++ b/arch/x86_64/src/memory/heap/linked_list_allocator.cpp
@@ -28,7 +28,7 @@ namespace teachos::arch::memory::heap
"[Linked List Allocator] Allocated memory cannot be smaller than 16 bytes");
memory_block * previous = nullptr;
- auto current = first;
+ auto current = first.load(std::memory_order::relaxed);
while (current != nullptr)
{
@@ -52,7 +52,7 @@ namespace teachos::arch::memory::heap
auto const end_address = start_address + size;
memory_block * previous = nullptr;
- auto current = first;
+ auto current = first.load(std::memory_order::relaxed);
while (current != nullptr)
{
@@ -81,11 +81,11 @@ namespace teachos::arch::memory::heap
// free block (nullptr). Therefore we have to overwrite the first block instead of overwriting its next value.
if (previous_block == nullptr)
{
- first = new_block;
+ first.compare_exchange_weak(previous_block, new_block, std::memory_order::relaxed);
}
else
{
- previous_block->next = new_block;
+ previous_block->next.compare_exchange_weak(current_block, new_block, std::memory_order::relaxed);
}
clear_memory_block_header(current_block);
return reinterpret_cast<void *>(start_address);