我正在尝试从assemler调用printf函数打印浮点值 . 它适用于字符串和整数值,但无法打印浮点数 . 以下是工作代码的示例:
global main
extern printf
section .data
message: db "String is: %d %x %s", 10, 0
end_message: db ".. end of string", 0
section .text
main:
mov eax, 0xff
mov edi, message
movsxd rsi, eax
mov rdx, 0xff
mov rcx, end_message
xor rax, rax
call printf
ret
字符串是:255 ff ..字符串的结尾
因此,参数通过寄存器传递:edi包含格式化字符串的地址,rsi和rdx包含以十进制和十六进制样式打印的相同数字,rcx包含字符串的结尾,rax包含0,因为我们没有浮点数打印 . 这段代码工作正常,但在尝试打印float时有些变化:
global main
extern printf
section .data
val: dq 123.456
msg: db "Result is: %fl",10, 0
section .text
main:
mov rdi,msg
movsd xmm0,[val]
mov eax,1
call printf
mov rax, 0
ret
可以编译此代码剪切但返回正在执行的分段错误 . 似乎问题是xmm0的错误值,但试图将 movsd xmm0,[val] 更改为 movsd xmm0,val 给出了
错误:操作码和操作数的无效组合
信息 . 编译器是在openSuSe 12.3上运行的NASM
更新 . 我试图制作一个c程序并生成一个.S程序集 . 它提供了一个非常奇怪的解决方案:
main:
.LFB2:
.cfi_startproc
pushq %rbp
.cfi_def_cfa_offset 16
.cfi_offset 6, -16
movq %rsp, %rbp
.cfi_def_cfa_register 6
subq $32, %rsp
movl %edi, -4(%rbp)
movq %rsi, -16(%rbp)
movq val(%rip), %rax
movq %rax, -24(%rbp)
movsd -24(%rbp), %xmm0
movl $.LC0, %edi
movl $1, %eax
call printf
movl $0, %eax
leave
.cfi_def_cfa 7, 8
ret
是否可以编写一个简单的printf示例?
1 回答
对于汇编程序问题:您需要在主程序启动之前对齐堆栈 .
插入
主要之后:
然后在ret之前再次添加它: