底层内存裁剪的一些思路:
主要思路是针对功能需求,裁剪冗余或无用的功能项,可以从以下几个方面下手:
1、kernel config的逐个排查,去掉冗余的项
结合功能需求去掉无用的功能模块,非必要的调试选项,比如安全/加密部分,USB的多余外设支持,FS的多余支持
2、缩减reserved的内存占用
从dts中声明 reserved 或代码中申请reserved的部分下手
3、缩减未进入内存管理的内存占用
找出 物理内存 - MemTotal(/proc/meminfo中第一行) 被哪些地方使用, 看能否裁剪一些
4、从占用较大的内存块下手,找到谁在使用, 看能否裁剪一些
/proc/vmallocinfo 中较大的部分
/proc/slabinfo 中较大的部分
5.从多余的native进程下手
从adb shell ps -A中排查非必要的进程和服务,进行裁剪
如何查看kernel占用的内存:
1、未进入内存管理的内存
即是 物理内存 - MemTotal(/proc/meminfo中第一行) 的部分。
2、kernel reserved内存
kernel reserved的内存,即是kernel log中Memory:的 reserved部分的大小
举例如下:
//代码占用 = kernel code + rwdata + rodata + init + bss
//reserved = reserved + cma-reserved
//关系:reserved_pages(63776K) = physpages(2045952K) - totalram_pages(1982176K) - totalcma_pages(0K)
[ 0.000000] -(0)[0:swapper]Memory: 1982176K/2045952K available (12924K kernel code, 1384K rwdata, 4392K rodata, 960K init, 5936K bss, 63776K reserved, 0K cma-reserved)
3、kernel运行中分配的内存
对应dumpsys meminfo 中 Used RAM: 中 kernel部分的大小
这里kernel的占用是从 /proc/meminfo 和 /proc/vmallocinfo 中统计而来,具体上:
kernel used = Shmem + SUnreclaim + VmallocUsed + PageTables + KernelStack
Shmem,SUnreclaim,PageTables,KernelStack对应 /proc/meminfo 中的具体字段
VmallocUsed 是统计/proc/vmallocinfo中除ioremap,map_lowmem,vm_map_ram之外的和
举例如下:
Total RAM: 1,983,136K (status critical)
Free RAM: 1,116,972K ( 0K cached pss + 203,672K cached kernel + 913,300K free)
Used RAM: 873,491K ( 629,723K used pss + 243,768K kernel)
Lost RAM: -7,331K
ZRAM: 4K physical used for 0K in swap (1,048,572K total swap)
Tuning: 128 (large 256), oom 322,560K, restore limit 107,520K (high-end-gfx)