底層內(nèi)存裁剪的一些思路:
主要思路是針對功能需求,裁剪冗余或無用的功能項(xiàng),可以從以下幾個(gè)方面下手:
1、kernel config的逐個(gè)排查,去掉冗余的項(xiàng)
結(jié)合功能需求去掉無用的功能模塊,非必要的調(diào)試選項(xiàng),比如安全/加密部分,USB的多余外設(shè)支持,FS的多余支持
2、縮減reserved的內(nèi)存占用
從dts中聲明 reserved 或代碼中申請reserved的部分下手
3、縮減未進(jìn)入內(nèi)存管理的內(nèi)存占用
找出 物理內(nèi)存 - MemTotal(/proc/meminfo中第一行) 被哪些地方使用, 看能否裁剪一些
4、從占用較大的內(nèi)存塊下手,找到誰在使用, 看能否裁剪一些
- /proc/vmallocinfo 中較大的部分
- /proc/slabinfo 中較大的部分
5.從多余的native進(jìn)程下手
從adb shell ps -A中排查非必要的進(jìn)程和服務(wù),進(jìn)行裁剪
如何查看kernel占用的內(nèi)存:
1、未進(jìn)入內(nèi)存管理的內(nèi)存
即是 物理內(nèi)存 - MemTotal(/proc/meminfo中第一行) 的部分。
2、kernel reserved內(nèi)存
kernel reserved的內(nèi)存,即是kernel log中Memory:的 reserved部分的大小
舉例如下:
//代碼占用 = kernel code + rwdata + rodata + init + bss
//reserved = reserved + cma-reserved
//關(guān)系: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運(yùn)行中分配的內(nèi)存
對應(yīng)dumpsys meminfo 中 Used RAM: 中 kernel部分的大小
這里kernel的占用是從 /proc/meminfo 和 /proc/vmallocinfo 中統(tǒng)計(jì)而來,具體上:
kernel used = Shmem + SUnreclaim + VmallocUsed + PageTables + KernelStack
- Shmem,SUnreclaim,PageTables,KernelStack對應(yīng)
/proc/meminfo中的具體字段- VmallocUsed 是統(tǒng)計(jì)
/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)