转载注明出处:http://www.cnblogs.com/lucasysfeng/p/4847662.html
上一讲地址:http://www.cnblogs.com/lucasysfeng/p/5059767.html
项目地址:https://github.com/lucasysfeng/lucasOS
上一讲我们获取到了物理内存,本讲我们来看如何分配物理内存。为简化问题,我们不使用伙伴内存分配算法,而是把可用内存按页存入栈中,每次分配从栈中取就可以了。
本讲的主要代码在lib/pmm.c中,下面给出部分代码。本讲内容不多,读者看代码即可。
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++; } } } }
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.
时间: 2024-10-24 08:29:24