summaryrefslogtreecommitdiffhomepage
path: root/Kernel/KernelKit/KernelHeap.hpp
blob: 95412761772c23da76e5ba3ff66a1b01c7aef6a8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
/* -------------------------------------------

	Copyright ZKA Technologies

------------------------------------------- */

#pragma once

// last-rev 30/01/24
// file: KernelHeap.hpp
// description: heap allocation for the kernel.

#include <NewKit/Defines.hpp>

namespace Kernel
{
	/// @brief Declare pointer as free.
	/// @param allocatedPtr the pointer.
	/// @return
	Int32 ke_delete_ke_heap(voidPtr allocatedPtr);

	/// @brief Declare a new size for allocatedPtr.
	/// @param allocatedPtr the pointer.
	/// @return
	voidPtr ke_realloc_ke_heap(voidPtr allocatedPtr, SizeT newSz);

	/// @brief Check if pointer is a valid kernel pointer.
	/// @param allocatedPtr the pointer
	/// @return if it exists.
	Boolean ke_is_valid_heap(VoidPtr allocatedPtr);

	/// @brief allocate chunk of memory.
	/// @param sz size of pointer
	/// @param rw read write (true to enable it)
	/// @param user is it accesible by user processes?
	/// @return the pointer
	voidPtr ke_new_ke_heap(const SizeT sz, const Bool rw, const Bool user);

	/// @brief Protect the heap with a CRC value.
	/// @param allocatedPtr pointer.
	/// @return if it valid: point has crc now., otherwise fail.
	Boolean ke_protect_ke_heap(VoidPtr allocatedPtr);

	/// @brief Makes a kernel heap page.
	/// @param allocatedPtr the page pointer.
	/// @return
	Int32 ke_make_ke_page(VoidPtr allocatedPtr);
} // namespace Kernel