[英]How can I get the source lines inline with the assembly output using GCC?
我想讓C源代碼行與匯編輸出內聯,以查看正在生成的代碼。
我嘗試過像-S
-Wa,-ahlms
這樣的GCC選項(甚至-Wa,--gstabs
因為我在某處讀過它)。
哦! 順便說一句,我在Mac上,所以我沒有objdump
。
(對不起,這很簡短,我得下車!)
輸出gcc pc-clisp.c -S -g -fverbose-asm -fnested-functions
.globl _getBool
_getBool:
LFB32:
LM21:
pushl %ebp #
LCFI30:
movl %esp, %ebp #,
LCFI31:
subl $8, %esp #,
LCFI32:
LM22:
movzbl 8(%ebp), %eax # atom.pred, D.4112
movzbl %al, %eax # D.4112, D.4113
andl $-16, %eax #, D.4114
sarl $4, %eax #, D.4115
testl %eax, %eax # D.4115
setne %al #, tmp64
movzbl %al, %eax # tmp64, D.4111
leave
ret
LFE32:
也許調試+后處理步驟?
gcc <source.c> -S -g -fverbose-asm
找到.file 1 "1.c"
告訴你文件名到文件名的映射。 然后在.loc 1 8 0
行之后添加源。 我不確定如何使用單個shell命令來執行此操作,但是短腳本應該能夠執行此操作:
#!/usr/bin/env python
import re
import sys
filename = sys.argv[1]
f = open(filename)
lines = f.readlines()
f.close()
FILE_RE=re.compile(r"\s+\.file (\d+) \"(.*)\"")
LOC_RE =re.compile(r"\s+\.loc (\d+) (\d+)")
output = []
files = {}
for line in lines:
output.append(line)
mo = FILE_RE.match(line)
if mo is not None:
files[mo.group(1)] = open(mo.group(2)).readlines()
print mo.group(1),"=",mo.group(2)
continue
mo = LOC_RE.match(line)
if mo is not None:
print mo.group(1),"=",mo.group(2)
source = files[mo.group(1)][int(mo.group(2))-1]
output.append("\t#"+source)
f = open(filename+".2","w")
f.writelines(output)
f.close()
這不完全是你所要求的,但你可能會發現-S -fverbose-asm
很有幫助。
你可以通過macports獲得objdump。 只需安裝“binutils”包,然后使用“gobjdump”
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.