繁体   English   中英

如何从 x64 程序集中的堆栈中获取参数?

[英]How to get an argument from stack in x64 assembly?

我正在尝试在 x64 程序集中编写一个过程。

我在用 C++ 编写的主程序中调用它。 我正在传递几个参数。 我知道前 4 个将在特定寄存器中,其余的(应该)在堆栈中。 更重要的是,我在从堆栈中取出第 5 个参数之前读到,我应该从 RSP 中减去 40。 一开始它奏效了。 后来我需要检查某事的地址,所以我通过:cout和&来完成。 但是,从堆栈中取出第 5 个参数不起作用,我不知道我该怎么办。

C++代码片段:

std::cout << xOld << '\t' << &xOld << std::endl;
std::cout << xOld[0] << '\t' << &xOld[0] << std::endl;

SthInAsm(A, B, alfa, beta, n, xOld, xNew, lowerBound, upperBound, condition, isReady, precision, maxIterations);

Asm 代码片段:

.data
    Aaddr DQ 0
    Baddr DQ 0
    alfa DQ 0
    beta DQ 0
    n DQ 0
    xOld DQ 0
.
.
.

.code

SthInAsm PROC   
    MOV Aaddr, RCX
    MOV Baddr, RDX
    MOV alfa, R8
    MOV beta, R9

    SUB RSP, 40

    XOR RAX, RAX
    POP n
    MOV RAX, n
.
.
.

在 'MOV RAX, n' RAX 之后不包含 n 的值。 当我在调用此函数之前没有通过 cout 检查地址时,它起作用了。

有谁知道这里有什么问题?

感谢 Jester,我知道我的代码有什么问题。 当我阅读有关 x64 程序集的内容时,我一定误解了某事。 从 RSP 中减去 - 我不应该这样做。

取而代之的是,当我写:MOV RAX、QWORD PTR [RSP+40] MOV RAX、QWORD PTR [RSP+48] 等时,从堆栈中获取参数是有效的。

再次感谢小丑!

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM