我的目标是对几种指令集架构进行比较研究。对于每种指令集体系结构,我如何找到最常用的指令?
这是我正在考虑的步骤:
[这是有关x86机器代码统计的很好的研究:https://www.strchr.com/x86_machine_code_statistics
我已经尝试在下面的命令中进行拆卸,但是似乎无法正确拆卸。反汇编的代码显示了一些das
指令,这些指令在实际代码中不应出现。
ndisasm -b32 -a $(which which)
您可以尝试这样做,以从.text部分收集助记符:
objdump --no-show-raw-insn \
-M intel \
-sDj .text $(which *program name*) | # <-- disassemble .text section
sed -n '/<\.text>/, $ p' | # <-- skip raw hex
awk '{$1 = ""; print}' | # <-- remove offsets
sed '1d' # <-- delete annoying <.text> in first line
此后,您只能获得助记符名称,并附加awk '{print $1}'
到上一个命令,或以某种方式更改数据。
全部完成后,将sort | uniq -c
添加到前面的步骤中。所以我产生的命令看起来像:
objdump --no-show-raw-insn \
-M intel \
-sDj .text $(which *program name*) |
sed -n '/<\.text>/, $ p' |
awk '{$1 = ""; print}' |
sed '1d' |
awk '{print $1}' | sort | uniq -c
从程序的文本部分打印出每个助记符的频率