正常的vm命令输出:
crash_new> vm PID: 2380 TASK: ffffff88414bddc0 CPU: 5 COMMAND: "xxx" MM PGD RSS TOTAL_VM ffffff880a997c00 ffffff8825747000 16565804k 44535380k VMA START END FLAGS FILE ffffff8801f09258 5eef950000 5eef97b000 71 /vendor/bin/bdo ffffff8801f09e10 5eef97b000 5eef9d9000 75 /vendor/bin/bdo ffffff8801f09bb8 5eef9d9000 5eef9df000 100071 /vendor/bin/bdo ffffff8801f09320 5eef9df000 5eef9e0000 100073 /vendor/bin/bdo ffffff881552eed8 5eefa40000 5eefa43000 100073 /vendor/bin/bdo ffffff8a7bc51bb8 74df600000 7e65e00000 100073 ffffff8a8f24abb8 7e65f08000 7ee3b08000 100073 ffffff8a82ec3578 7ee3b08000 7eea008000 100073 ffffff8024f17898 7eea008000 7eeab92000 70 ffffff8829eb5708 7eeab92000 7eeab94000 100073 ffffff8024f17a28 7eeab94000 7eeb296000 70 ffffff8801e5c4b0 7eeb296000 7eeb298000 100073 ffffff8829eb5898 7eeb298000 7eec132000 70 ffffff8826be2708 7eec132000 7eec134000 100073 ffffff8801e5c000 7eec134000 7eed612000 70 ffffff882575ca28 7eed612000 7eed614000 100073 ffffff881e308898 7eed614000 7eee57a000 70 ffffff882575c960 7eee57a000 7eee57c000 100073 ffffff881df37e10 7eee57c000 7eef008000 70 ffffff8801e5c190 7eef008000 7eef009000 200070 ffffff8801e5ce10 7eef009000 7eef105000 200073 ffffff8801e5cbb8 7eef105000 7eef107000 200070 ffffff882592b3e8 7eef107000 7eef203000 200073 ffffff8801e5c708 7eef203000 7eef205000 200070 ffffff882592b0c8 7eef205000 7eef301000 200073 ffffff882592b000 7eef301000 7eef303000 200070 ffffff880a27d7d0 7eef303000 7eef3ff000 200073 ffffff882592b578 7eef3ff000 7eef400000 200070 ffffff88299e13e8 7eef400000 7eefe00000 100073 ffffff882654f708 7eefe08000 7eefe09000 200070 ...
有个需求,我想统计覆盖的虚拟地址最大的几个vma。
可以参考下面的命令:
vm | awk 'NR>=5 {vmas[$1]=strtonum("0x"$3)-strtonum("0x"$2)} END {for (vma in vmas) {printf "%s %x MB\n", vma, vmas[vma]/1024/1024}}' | sort -n -k 2
这里用到的awk工具,其中由于vm列出的地址范围是按16进制输出的,所以需要使用strtonum先转换为10进制,然后再做减法。
当找到范围最大的vma后,可以使用下面的方法来统计这个vma实际消耗的物理页:
vm -P ffffff8a7bc51bb8 | awk 'NR>=5' | grep -v "SWAP" | grep -v "mapped" | wc -l
正常来说,每一行对应的物理页,知道了行数,也就可以很容易得到占用的物理内存大小。