linux 内核bootmem分配器(一)

本文详细介绍了Linux内核启动期间使用的bootmem分配器,用于在内存管理初始化前分配内存。通过`bootmem_init`函数,解析了如何确定最小和最大可用页帧号,并通过`add_active_range`和`free_bootmem`等函数管理内存区域。此外,还讨论了内存区域的预留和释放过程。
摘要由CSDN通过智能技术生成
linux 内核bootmem分配器


   内核在启动期间,内存管理还没有初始化,bootmem内存分配器在启动期间分配内存


static void __init bootmem_init(void)
{
	unsigned long reserved_end;
	unsigned long mapstart = ~0UL;
	unsigned long bootmap_size;
	int i;
  /* 全局变量reserved_end记录保留区后第一个空闲页的pfn 
  __end 是内核内核映像的最后的位置。具体的值可以参考System.map
  在我的1b开发板中_end 为0x808567c0
 	__pa_symbol 为获取物理地址。     
  __pa_symbol(&_end) 为0x8567c0,其实就是x808567c0最高位清零 在mips体系中
  地址0x80000000 ~ 0xA0000000地址,只要将最高位清空就会得到物理地址
  Reserved_end 为 0x857
  PFN_UP  的意思就是获取物理页帧号 UP 就是四舍五入的意思,在我1b开发板中页	的大小4KB=4*1024B = (1 << 12);而PFN_UP就是将地址左移12位,reserved_end 
  就是将 0x8567c0  << 12*/
	reserved_end = max(init_initrd(),
			   (unsigned long) PFN_UP(__pa_symbol(&_end)));
  /* 全局变量min_low_pfn和max_low_pfn为可用低端内存的最小、最大pfn */
	min_low_pfn = ~0UL;
	max_low_pfn = 0;
 
	for (i = 0; i < boot_mem_map.nr_map; i++) {
		unsigned long start, end;
  		/* 不是可用的内存区域,跳过 */
		if (boot_mem_map.map[i].type != BOOT_MEM_RAM)
			continue;
  		/* 获得这块内存区起止页面的pfn */
		start = PFN_UP(boot_mem_map.map[i].addr);
		end = PFN_DOWN(boot_mem_map.map[i].addr
				+ boot_mem_map.map[i].size);
  /*进入kdb可以查看boot_mem_map的值
  kdb> md boot_mem_map
  0x807c5110 00000
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值