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

phi*_*urn 14 c macos assembly gcc

我想让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:
Run Code Online (Sandbox Code Playgroud)

Dou*_*der 12

也许调试+后处理步骤?

gcc <source.c> -S -g -fverbose-asm
Run Code Online (Sandbox Code Playgroud)

查找.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()
Run Code Online (Sandbox Code Playgroud)


Ste*_*non 5

这不完全是你所要求的,但你可能会觉得-S -fverbose-asm有帮助.