我在汇编中有一些代码有点奇怪。我有一个C extern函数,它使用.asm文件中的 asm 调用另一个函数。这个C函数将我的函数从.asm文件中使用的三个地址放在堆栈上。一切顺利,直到出现:
; Let's say we take from the stack first parameter from my C function.
; This parameter is a string of bytes that respect this format:
; - first 4 bytes are the sign representation of a big number
; - second 4 bytes are the length representation of a big number
; - following bytes are the actual big number
section .data
operand1 dd 0
section .text
global main
main:
push ebp
mov ebp, esp
mov eax, [ebp + 8] ; Here eax will contain the address where my big number begins.
lea eax, [eax + 8] ; Here eax will contain the address where
; my actual big number begins.
mov [operand1], eax
PRINT_STRING "[eax] is: "
PRINT_HEX 1, [eax] ; a SASM macro which prints a byte as HEX
NEWLINE
PRINT_STRING "[operand1] is: "
PRINT_HEX 1, [operand1]
NEWLINE
leave
ret
运行此代码时,我在终端输入正确的[eax]输出,而对于[operand1],它会保持打印一个数字,如果我修改了我的C函数的第一个参数,这个数字不会改变。我在这里做错了什么?
答案 0 :(得分:0)
我犯了一个可以理解的错误。在做的时候:
mov [operand1], eax
PRINT_STRING "[operand1] is: "
PRINT_HEX 1, [operand1]
NEWLINE
此代码打印包含在此局部变量(operand1)所在地址的内容的第一个字节(,即我的实际大数字开始的地址)。为了获得驻留在[operand1]的实际值,我必须这样做:
mov ebx, [operand1]
PRINT_STRING "[operand1] is: "
PRINT_HEX 1, [ebx]
NEWLINE