diff options
author | Pankaj Raghav <pankydev8@gmail.com> | 2021-12-16 20:35:51 +0530 |
---|---|---|
committer | Andreas Kling <kling@serenityos.org> | 2022-01-01 14:55:58 +0100 |
commit | 602b35aa62586f5d75ea329ebc29e49cdb470932 (patch) | |
tree | 6293f410a0a4b09d505f097cf3bc0e54995e1981 | |
parent | 8489388e753faa7d0cba2c834c2b5154337490ce (diff) | |
download | serenity-602b35aa62586f5d75ea329ebc29e49cdb470932.zip |
Kernel: Add DMA allocate functions that are TRY-able
Add DMA allocate buffer helper functions in MemoryManager.
-rw-r--r-- | Kernel/Memory/MemoryManager.cpp | 19 | ||||
-rw-r--r-- | Kernel/Memory/MemoryManager.h | 2 |
2 files changed, 21 insertions, 0 deletions
diff --git a/Kernel/Memory/MemoryManager.cpp b/Kernel/Memory/MemoryManager.cpp index 4e1185e5cb..ae7950a9b2 100644 --- a/Kernel/Memory/MemoryManager.cpp +++ b/Kernel/Memory/MemoryManager.cpp @@ -733,6 +733,25 @@ ErrorOr<NonnullOwnPtr<Region>> MemoryManager::allocate_contiguous_kernel_region( return allocate_kernel_region_with_vmobject(range, move(vmobject), name, access, cacheable); } +ErrorOr<NonnullOwnPtr<Memory::Region>> MemoryManager::allocate_dma_buffer_page(StringView name, Memory::Region::Access access, RefPtr<Memory::PhysicalPage>& dma_buffer_page) +{ + dma_buffer_page = allocate_supervisor_physical_page(); + if (dma_buffer_page.is_null()) + return ENOMEM; + auto region_or_error = allocate_kernel_region(dma_buffer_page->paddr(), PAGE_SIZE, name, access); + return region_or_error; +} + +ErrorOr<NonnullOwnPtr<Memory::Region>> MemoryManager::allocate_dma_buffer_pages(size_t size, StringView name, Memory::Region::Access access, NonnullRefPtrVector<Memory::PhysicalPage>& dma_buffer_pages) +{ + VERIFY(!(size % PAGE_SIZE)); + dma_buffer_pages = allocate_contiguous_supervisor_physical_pages(size); + if (dma_buffer_pages.is_empty()) + return ENOMEM; + auto region_or_error = allocate_kernel_region(dma_buffer_pages.first().paddr(), size, name, access); + return region_or_error; +} + ErrorOr<NonnullOwnPtr<Region>> MemoryManager::allocate_kernel_region(size_t size, StringView name, Region::Access access, AllocationStrategy strategy, Region::Cacheable cacheable) { VERIFY(!(size % PAGE_SIZE)); diff --git a/Kernel/Memory/MemoryManager.h b/Kernel/Memory/MemoryManager.h index 6e25460d3a..fcd70e462e 100644 --- a/Kernel/Memory/MemoryManager.h +++ b/Kernel/Memory/MemoryManager.h @@ -175,6 +175,8 @@ public: void deallocate_physical_page(PhysicalAddress); ErrorOr<NonnullOwnPtr<Region>> allocate_contiguous_kernel_region(size_t, StringView name, Region::Access access, Region::Cacheable = Region::Cacheable::Yes); + ErrorOr<NonnullOwnPtr<Memory::Region>> allocate_dma_buffer_page(StringView name, Memory::Region::Access access, RefPtr<Memory::PhysicalPage>& dma_buffer_page); + ErrorOr<NonnullOwnPtr<Memory::Region>> allocate_dma_buffer_pages(size_t size, StringView name, Memory::Region::Access access, NonnullRefPtrVector<Memory::PhysicalPage>& dma_buffer_pages); ErrorOr<NonnullOwnPtr<Region>> allocate_kernel_region(size_t, StringView name, Region::Access access, AllocationStrategy strategy = AllocationStrategy::Reserve, Region::Cacheable = Region::Cacheable::Yes); ErrorOr<NonnullOwnPtr<Region>> allocate_kernel_region(PhysicalAddress, size_t, StringView name, Region::Access access, Region::Cacheable = Region::Cacheable::Yes); ErrorOr<NonnullOwnPtr<Region>> allocate_kernel_region_with_vmobject(VMObject&, size_t, StringView name, Region::Access access, Region::Cacheable = Region::Cacheable::Yes); |