转载注明出处:http://www.cnblogs.com/lucasysfeng/p/4847662.html
上一讲地址:http://www.cnblogs.com/lucasysfeng/p/5059767.html
项目地址:https://github.com/lucasysfeng/lucasOS
上一讲我们获取到了物理内存,本讲我们来看如何分配物理内存。为简化问题,我们不使用伙伴内存分配算法,而是把可用内存按页存入栈中,每次分配从栈中取就可以了。
本讲的主要代码在lib/pmm.c中,下面给出部分代码。本讲内容不多,读者看代码即可。
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
|
void
init_pmm()
{
mmap_entry_t *mmap_start_addr = (mmap_entry_t *) glb_mboot_ptr->mmap_addr;
mmap_entry_t *mmap_end_addr = (mmap_entry_t *) glb_mboot_ptr->mmap_addr
+ glb_mboot_ptr->mmap_length;
mmap_entry_t *map_entry;
for
(map_entry = mmap_start_addr; map_entry < mmap_end_addr; map_entry++)
{
// type为1表示可用内存,其它指保留区域,参考上一讲的multiboot_t结构
if
(map_entry->type == 1 && map_entry->base_addr_low == 0x100000)
{
// 可用内存要减去内核本身占用的内存
uint32_t page_addr = map_entry->base_addr_low
+ (uint32_t) (kern_end - kern_start);
uint32_t length = map_entry->base_addr_low + map_entry->length_low;
while
(page_addr < length && page_addr <= PMM_MAX_SIZE)
{
pmm_free_page(page_addr);
page_addr += PMM_PAGE_SIZE;
phy_page_count++;
}
}
}
}
|
1
2
3
4
5
|
void
pmm_free_page(uint32_t p)
{
assert
(pmm_stack_top != PAGE_MAX_SIZE,
"out of pmm_stack stack\n"
);
pmm_stack[++pmm_stack_top] = p;
}
|
代码获取
本系列GitHub地址 https://github.com/lucasysfeng/lucasOS,本讲的代码是code/chapter5.