我在debian wheezy上编译下面的汇编程序,但它不会运行给我错误:
-bash:./ power:无法执行二进制文件
.section data
.section text
.global _start
_start:
# do first calc and save the answer
pushl $3
pushl $2
call power
addl $8, %esp
pushl %eax
# do second calc
pushl $2
pushl $5
call power
addl $8, %esp
# add both together
popl %ebx
addl %eax, %ebx
# exit with answer as return status
movl $1, %eax
int $0x80
.type power, @function
power:
# ?
pushl %ebp
movl %esp, %ebp
subl $4, %esp
# load params
movl 8(%ebp), %ebx
movl 12(%ebp), %ecx
movl %ebx, -4(%ebp)
power_loop_start:
# have we looped down to 1?
cmpl $1, %ecx
je end_power
# multiply prev result by base and store
movl -4(%ebp), %eax
imull %ebx, %eax
movl %eax, -4(%ebp)
# go again
decl %ecx
jmp power_loop_start
end_power:
movl -4(%ebp), %eax
movl %ebp, %esp
popl %ebp
ret
我跑步:
as power.s -o power.o
ld power.o -o power
./power
uname -m
和arch
都给我 i686 ,二进制文件在objdump -x
上输出:
$ objdump -x power
power: file format elf32-i386
power
architecture: i386, flags 0x00000012:
EXEC_P, HAS_SYMS
start address 0x00000000
Sections:
Idx Name Size VMA LMA File off Algn
0 text 0000004a 00000000 00000000 00000034 2**0
CONTENTS, READONLY
SYMBOL TABLE:
00000000 l d text 00000000 text
00000023 l F text 00000000 power
00000032 l text 00000000 power_loop_start
00000043 l text 00000000 end_power
00000000 g text 00000000 _start
08049034 g *ABS* 00000000 __bss_start
08049034 g *ABS* 00000000 _edata
08049034 g *ABS* 00000000 _end
不确定我做错了什么。
这个例子来自书"从头开始编程"。我尝试使用Red Hat x86_64 计算机,as
标记--32
和ld
标记-m elf_i386
,它们编译得很好就像在x86机器,但执行时会出现相同的错误。
答案 0 :(得分:4)
你有一个拼写错误:$numWords
应为.section text
(注意点)或.section .text
虽然这个问题是由一个错字引起的,但我觉得值得一些解释,特别是因为你很好地提供了所有细节:)
虽然您可以根据自己的喜好命名您的部分(这就是工具没有抱怨的原因),但每个部分都有一些标记。在这种情况下,您可以在objdump输出中看到:.text
。这意味着该部分不可执行,实际上它甚至没有加载。 (可以说错误信息可能更准确一些。)
好的,为什么它不可执行?汇编程序识别一些常见的节名称并正确设置标志。对于自定义名称,您必须手动执行此操作,例如通过执行设置CONTENTS, READONLY
和.section text, "ax"
的{{1}}。另请参阅.section
directive in the manual和this answer about the various flags。