Android计算开机完成之后kernel所消耗的总的内存(不可回收)

1. 开机后各可用内存和实际物理内存之间的关系

要计算开机之后剩余的总内存,首先必须弄清楚kernel在开机之后出现的几个可用内存变量之间的关系,今天以一个项目的log来分析开机之后memory的计算方式和各可用内存和总的实际内存之间的关系:

我们在开机之后kernel会有一句log如下:

[    0.000000] <0>-(0)[0:swapper]Memory: 3919424K/4027408K available (12244K kernel code, 1856K rwdata, 5636K rodata, 1056K init, 13278K bss, 107984K reserved)

内存初始化信息的解读如下:

absent:表示不可用的物理内存大小。譬如有一些物理内存被BIOS保留、对kernel是不可用的,这部分物理内存被计入”absent”之中,这里没有出现。

107984k reserved:包括【initrd】和【内核代码及数据】等,其中内核代码和部分数据包含在下列统计值中:

12244k kernel code :表示kernel的代码,属于reserved memory;

1856k rwdata和5636K rodata :表示kernel的可读可写的数据和只读数据大小,属于reserved memory;

1056k init :表示init code和init data,属于reserved memory,但引导完成之后会释放给free memory;

13278k bss:表示kernel bss段的大小;

它们之间的关系如下:

reserved 包括 kernel code, data 和 init,由于它还包括initrd和其它更多的内容,所以reserved远远大于 kernel code + data + init 之和;

此时会有以下几个疑惑:

1. 这里的4027408K是从哪里计算出来的,他与实际总内存4G之间差值包含了哪些内容?

2. 3919424K又是如何计算出来的?

经过查看kernel code可以回答上面的两个问题:

void __init mem_init_print_info(const char *str)
{
	unsigned long physpages, codesize, datasize, rosize, bss_size;
	unsigned long init_code_size, init_data_size;

	physpages = get_num_physpages();
	codesize = _etext - _stext;
	datasize = _edata - _sdata;
	rosize = __end_rodata - __start_rodata;
	bss_size = __bss_stop - __bss_start;
	init_data_size = __init_end - __init_begin;
	init_code_size = _einittext - _sinittext;
……
printk("Memory: %luK/%luK available "
	       "(%luK kernel code, %luK rwdata, %luK rodata, "
	       "%luK init, %luK bss, %luK reserved"
#ifdef	CONFIG_HIGHMEM
	       ", %luK highmem"
#endif
	       "%s%s)\n",
	       nr_free_pages() << (PAGE_SHIFT-10), physpages << (PAGE_SHIFT-10),
codesize >> 10, datasize >> 10, rosize 
  • 4
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要对Android开机时的内存进行分析,可以使用以下方法[^1]: 1. 首先,通过adb shell命令获取系统当前内存状态。可以使用以下命令: ``` adb shell cat /proc/meminfo ``` 该命令可以输出系统的内存信息,包括总内存、空闲内存、缓存等。 2. 如果机器在运行的过程中MemAvailable持续减小,就可以怀疑系统中存在内存泄漏。但是并不是MemAvailable减小就一定存在内存泄漏,还要进一步分析减少的内存被什么占用了。可以使用以下命令获取内存占用信息: ``` adb shell cat /proc/meminfo | grep "Active(anon)\|Inactive(anon)\|SUnreclaim" ``` 该命令可以输出Active(anon)、Inactive(anon)和SUnreclaim所占用的内存情况。其中,Active(anon)+Inactive(anon)所占用的内存增加,说明用户进程占用的内存增加。如果SUnreclaim所占用的内存增加,说明kernel占用的内存增加。 3. 知道了减少的内存是被用户进程还是kernel占用之后,要分析是哪个用户进程或内核哪部分占用了内存。可以使用以下命令: ``` adb shell dumpsys meminfo ``` 该命令可以输出每个进程的内存占用情况,包括Native Heap、Dalvik Heap等。 4. 如果需要进一步分析某个进程的内存占用情况,可以使用以下命令: ``` adb shell dumpsys meminfo <pid> ``` 其中,<pid>为进程的ID号。 另外,如果需要分析slab占用情况,可以使用以下命令: ``` adb shell cat /proc/slabinfo ``` 该命令可以输出所有slab的信息,包括名称、对象大小、分配情况等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值