如何使用GCC将源代码行与汇编输出内联?

时间:2010-03-09 21:46:09

标签: c macos gcc assembly

我想让C源代码行与汇编输出内联,以查看正在生成的代码。

我尝试过GCC选项,例如-S -Wa,-ahlms(甚至是-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:

3 个答案:

答案 0 :(得分:11)

也许调试+后处理步骤?

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()

答案 1 :(得分:5)

这不完全是您所要求的,但您可能会发现-S -fverbose-asm有帮助。

答案 2 :(得分:2)

你可以通过macports获得objdump。只需输入“binutils”包,然后使用“gobjdump”