用objdump只反汇编想要的函数

 github:https://github.com/pacepi/tool/

 

今天在网上看到有人在反汇编vmlinux时考虑到反汇编速度太慢,而且生成的文件有很大,所以写了一个只反汇编想要的函数的脚本 objdump-function.sh:

#!/bin/bash

vmlinux=$1 
symbol=$2 
 
if [ -z "$vmlinux" ]; then 
    echo "usage : $0 vmlinux symbol"
    exit 
fi 
 
startaddress=$(nm -n $vmlinux | grep "\w\s$symbol" | awk '{print "0x"$1;exit}') 
endaddress=$(nm -n $vmlinux | grep -A1 "\w\s$symbol" | awk '{getline; print "0x"$1;exit}') 
  
if [ -z "$symbol" ]; then 
    echo "dump all symbol"
    objdump -d $vmlinux 
else 
    echo "start-address: $startaddress, end-address: $endaddress" 
    objdump -d $vmlinux --start-address=$startaddress --stop-address=$endaddress
fi

示例:

objdump-function.sh vmlinux codec_list_seq_show

 

完。

posted @ 2018-01-19 23:30  摩斯电码  阅读(4861)  评论(1编辑  收藏  举报