How to debug memory leakage in media server in Android

取消
显示结果 
显示  仅  | 搜索替代 
您的意思是: 

How to debug memory leakage in media server in Android

How to debug memory leakage in media server in Android

  • Check memory leakage in media server.
    • Set libc debug level. So libc will record back trace for all memory allocate.
      • setprop libc.debug.malloc 1
    • Kill mediaserver to let the libc debug take effect. Android will restart mediaserver.
      • busybox killall -HUP mediaserver
  • you will see below log if you setting right.
  • I/libc    ( 3074): /system/bin/mediaserver using MALLOC_DEBUG = 1 (leak checker)
  • Dump all used memory of mediaserver.
    • dumpsys media.player -m
    • Allocation count 297
    • Total memory 1483423
    • size   262144, dup    1, 0x401f4c18, 0x400b6152, 0x401a6568, 0x4061a95c, 0x40146cfa, 0x4019639c, 0x40146ec2, 0x4014a1ec, 0x4014a3ca, 0x00008a98, 0x400b67aa
    • size   178192, dup    1, 0x401f4c18, 0x400b6152, 0x4280adae, 0x427ffcee, 0x4280ae6c, 0x427ec75a, 0x427f7e22, 0x42807648, 0x428082ea, 0x415144f0, 0x4151334a, 0x413381d0, 0x401dcbc, 0x401d438c, 0x4014d996, 0x405c3c46, 0x405c7516, 0x405c6ad4, 0x412c02ca, 0x412c0584, 0x4108c64c, 0x4107d622, 0x4107fbf2, 0x4107c19a, 0x400b2eac, 0x400b2a00
  • Diff two times of memory dump to check if there is any memory leakage. You can playback one video file between the dump.
    • diff 1.txt 2.txt > diff.txt
    • Get maps file of mediaserver.
      • adb pull proc/<pid of mediaserver>/maps .
    • Use attached script to map back trace to function symbols and file line.
      • ./addr2func.py --root-dir=../../ --maps-file=./maps --product=sabresd_6dq diff.txt
  • Notes: should use eng build for the debug.


附件
评论

Great!!

%3CLINGO-SUB%20id%3D%22lingo-sub-1102257%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%E5%A6%82%E4%BD%95%E8%B0%83%E8%AF%95Android%E5%AA%92%E4%BD%93%E6%9C%8D%E5%8A%A1%E5%99%A8%E7%9A%84%E5%86%85%E5%AD%98%E6%B3%84%E6%BC%8F%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-1102257%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%26lt%3Bmeta%20http-equiv%3D%22Content-Type%22%20content%3D%22text%2Fhtml%3B%20charset%3Dutf-8%22%20%2F%26gt%3B%0A%3CUL%3E%3CLI%3E%E6%A3%80%E6%9F%A5%E5%AA%92%E4%BD%93%E6%9C%8D%E5%8A%A1%E5%99%A8%E4%B8%AD%E7%9A%84%E5%86%85%E5%AD%98%E6%B3%84%E6%BC%8F%E3%80%82%20%3CUL%3E%3CLI%3E%E8%AE%BE%E7%BD%AE%20libc%20%E8%B0%83%E8%AF%95%E7%BA%A7%E5%88%AB%E3%80%82%E5%9B%A0%E6%AD%A4%20libc%20%E5%B0%86%E8%AE%B0%E5%BD%95%E6%89%80%E6%9C%89%E5%86%85%E5%AD%98%E5%88%86%E9%85%8D%E7%9A%84%E5%9B%9E%E6%BA%AF%E3%80%82%20%3CUL%3E%3CLI%3Esetprop%20libc.debug.malloc%201%3C%2FLI%3E%3C%2FUL%3E%3C%2FLI%3E%3CLI%3E%E7%BB%88%E6%AD%A2%20mediaserver%20%E4%BB%A5%E4%BD%BF%20libc%20%E8%B0%83%E8%AF%95%E7%94%9F%E6%95%88%E3%80%82Android%20%E5%B0%86%E9%87%8D%E6%96%B0%E5%90%AF%E5%8A%A8%E5%AA%92%E4%BD%93%E6%9C%8D%E5%8A%A1%E5%99%A8%E3%80%82%20%3CUL%3E%3CLI%3Ebusybox%20killall%20-HUP%20mediaserver%3C%2FLI%3E%3C%2FUL%3E%3C%2FLI%3E%3C%2FUL%3E%3C%2FLI%3E%3CLI%3E%E5%A6%82%E6%9E%9C%E8%AE%BE%E7%BD%AE%E6%AD%A3%E7%A1%AE%EF%BC%8C%E6%82%A8%E5%B0%86%E7%9C%8B%E5%88%B0%E4%B8%8B%E9%9D%A2%E7%9A%84%E6%97%A5%E5%BF%97%E3%80%82%3C%2FLI%3E%3CLI%3EI%2Flibc%20(3074)%EF%BC%9A%2Fsystem%2Fbin%2Fmediaserver%20%E4%BD%BF%E7%94%A8%20MALLOC_DEBUG%20%3D%201%EF%BC%88%E6%B3%84%E6%BC%8F%E6%A3%80%E6%9F%A5%E5%99%A8%EF%BC%89%3C%2FLI%3E%3CLI%3E%E8%BD%AC%E5%82%A8%E5%AA%92%E4%BD%93%E6%9C%8D%E5%8A%A1%E5%99%A8%E7%9A%84%E6%89%80%E6%9C%89%E5%B7%B2%E7%94%A8%E5%86%85%E5%AD%98%E3%80%82%20%3CUL%3E%3CLI%3Edumpsys%20media.player-m%3C%2FLI%3E%3CLI%3E%E5%88%86%E9%85%8D%E8%AE%A1%E6%95%B0%20297%3C%2FLI%3E%3CLI%3E%E6%80%BB%E5%86%85%E5%AD%98%201483423%3C%2FLI%3E%3CLI%3Esize%26nbsp%3B%26nbsp%3B%20262144%2C%20dup%26nbsp%3B%26nbsp%3B%26nbsp%3B%201%2C%200x401f4c18%2C%200x400b6152%2C%200x401a6568%2C%200x4061a95c%2C%200x40146cfa%2C%200x4019639c%2C%200x40146ec2%2C%200x4014a1ec%2C%200x4014a3ca%2C%200x00008a98%2C%200x400b67aa%3C%2FLI%3E%3CLI%3Esize%26nbsp%3B%26nbsp%3B%20178192%2C%20dup%26nbsp%3B%26nbsp%3B%26nbsp%3B%201%2C%200x401f4c18%2C%200x400b6152%2C%200x4280adae%2C%200x427ffcee%2C%200x4280ae6c%2C%200x427ec75a%2C%200x427f7e22%2C%200x42807648%2C%200x428082ea%2C%200x415144f0%2C%200x4151334a%2C%200x413381d0%2C%200x401dcbc%2C%200x401d438c%2C%200x4014d996%2C%200x405c3c46%2C%200x405c7516%2C%200x405c6ad4%2C%200x412c02ca%2C%200x412c0584%2C%200x4108c64c%2C%200x4107d622%2C%200x4107fbf2%2C%200x4107c19a%2C%200x400b2eac%2C%200x400b2a00%3C%2FLI%3E%3C%2FUL%3E%3C%2FLI%3E%3CLI%3E%E6%AF%94%E8%BE%83%E4%B8%A4%E6%AC%A1%E5%86%85%E5%AD%98%E8%BD%AC%E5%82%A8%E6%9D%A5%E6%A3%80%E6%9F%A5%E6%98%AF%E5%90%A6%E5%AD%98%E5%9C%A8%E5%86%85%E5%AD%98%E6%B3%84%E6%BC%8F%E3%80%82%E6%82%A8%E5%8F%AF%E4%BB%A5%E5%9C%A8%E8%BD%AC%E5%82%A8%E4%B9%8B%E9%97%B4%E6%92%AD%E6%94%BE%E4%B8%80%E4%B8%AA%E8%A7%86%E9%A2%91%E6%96%87%E4%BB%B6%E3%80%82%20%3CUL%3E%3CLI%3E%E5%B7%AE%E5%BC%82%201.txt%202.txt%20%26gt%3B%20%E5%B7%AE%E5%BC%82.txt%3C%2FLI%3E%3CLI%3E%E8%8E%B7%E5%8F%96%E5%AA%92%E4%BD%93%E6%9C%8D%E5%8A%A1%E5%99%A8%E7%9A%84%E5%9C%B0%E5%9B%BE%E6%96%87%E4%BB%B6%E3%80%82%20%3CUL%3E%3CLI%3Eadb%20pull%20proc%2F%3CPID%20of%3D%22%22%20mediaserver%3D%22%22%3E%20%2Fmaps%20%E3%80%82%3C%2FPID%3E%3C%2FLI%3E%3C%2FUL%3E%3C%2FLI%3E%3CLI%3E%E4%BD%BF%E7%94%A8%E9%99%84%E5%8A%A0%E8%84%9A%E6%9C%AC%E5%B0%86%E5%9B%9E%E6%BA%AF%E6%98%A0%E5%B0%84%E5%88%B0%E5%87%BD%E6%95%B0%E7%AC%A6%E5%8F%B7%E5%92%8C%E6%96%87%E4%BB%B6%E8%A1%8C%E3%80%82%20%3CUL%3E%3CLI%3E.%2Faddr2func.py%20--root-dir%3D..%2F..%2F%20--maps-file%3D.%2Fmaps--%E4%BA%A7%E5%93%81%3Dsabresd_6dq%20diff.txt%3C%2FLI%3E%3C%2FUL%3E%3C%2FLI%3E%3C%2FUL%3E%3C%2FLI%3E%3CLI%3E%3CSTRONG%3E%E6%B3%A8%E6%84%8F%3C%2FSTRONG%3E%EF%BC%9A%E5%BA%94%E4%BD%BF%E7%94%A8%20eng%20build%20%E8%BF%9B%E8%A1%8C%E8%B0%83%E8%AF%95%E3%80%82%3C%2FLI%3E%3C%2FUL%3E%3CP%3E%3CSPAN%20class%3D%22mce_paste_marker%22%3E%3CBR%20%2F%3E%3C%2FSPAN%3E%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-1102258%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%E5%9B%9E%E5%A4%8D%EF%BC%9A%E5%A6%82%E4%BD%95%E8%B0%83%E8%AF%95Android%E5%AA%92%E4%BD%93%E6%9C%8D%E5%8A%A1%E5%99%A8%E4%B8%AD%E7%9A%84%E5%86%85%E5%AD%98%E6%B3%84%E6%BC%8F%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-1102258%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%26lt%3Bmeta%20http-equiv%3D%22Content-Type%22%20content%3D%22text%2Fhtml%3B%20charset%3Dutf-8%22%20%2F%26gt%3B%0A%3CP%3E%E4%BC%9F%E5%A4%A7%E7%9A%84%EF%BC%81%EF%BC%81%3C%2FP%3E%3C%2FLINGO-BODY%3E
无评分
版本历史
最后更新:
‎09-12-2012 10:27 PM
更新人: