summaryrefslogtreecommitdiffstats
path: root/mem/phys.c
blob: bf56b7765502bea9e81642c09fbab6fac3b8e16a (plain) (blame)
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
#include "memory.h"
#include "zone.h"
#include "lib/jove.h"

void
mem_phys_reserve(physptr_t start, physptr_t end)
{
    size_t zone = mem_zone_for(start);
    size_t limit = mem_zone_bound_upper(zone);

    if(end > limit) {
        mem_phys_reserve(limit, end);
        end = limit;
    }
    mem_zone_resv(MEM_ZONE_STANDARD, start, end);
}

void 
mem_phys_release(physptr_t start, physptr_t end)
{
    size_t zone = mem_zone_for(start);
    size_t limit = mem_zone_bound_upper(zone);

    if(end > limit) {
        mem_phys_release(limit, end);
        end = limit;
    }
    mem_zone_free(MEM_ZONE_STANDARD, start, end);
}

physptr_t
mem_phys_alloc(size_t pages)
{
    if(mem_zone_pages_free(MEM_ZONE_HIGHER) >= pages)
        return mem_zone_alloc(MEM_ZONE_HIGHER, pages);
    if(mem_zone_pages_free(MEM_ZONE_STANDARD) >= pages)
        return mem_zone_alloc(MEM_ZONE_STANDARD, pages);
    kpanic("Kernel ran out of physical memory!\n");
}