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