繁体   English   中英

将数组从C传递到nasm时出现分段错误

[英]Segmentation fault when passing arrays from C to nasm

我有一个C程序,该程序调用在nasm中实现的函数。 C电话:

    extern void calc(float *, float *, float *, float *);
    //...
    float *data1, *data2, *results1, *results2;
    data1 = (float *)malloc(MAXLINES * sizeof(float));
    //...
    calc(data1, data2, results1, results2);
    /...
    for(i=0;i<linesread;i++) {
        printf ("Zeile %u: result1 = %f,\tresult2 = %f\n", i, results1[i], results2[i]); //Segmentation fault
    }

nasm:

segment .data

constAir:   dq 1.11330e-10
constOil:   dq 2.33656e-10
pi:     dq 3.1415
four:       dq 4

SEGMENT .text

GLOBAL calc

calc:

PUSH EBP
PUSH EAX
PUSH EBX
PUSH ECX
PUSH EDX
MOV EBP, ESP
ADD EBP, 20
MOV EAX, [EBP]      ; data1
MOV EBX, [EBP + 4]  ; data2
MOV ECX, [EBP + 8]  ; results1
MOV EDX, [EBP + 12] ; results2

; results1/2 = data1 / (4 * PI * constAir/Oil * data2 * data2)

FLD QWORD [four]
FMUL QWORD [pi]
FMUL QWORD [constAir]
FMUL QWORD [EBX]
FMUL QWORD [EBX]
FST ST1
FLD QWORD [EAX]
FDIV ST1
FST QWORD [ECX]

FLD QWORD [four]
FMUL QWORD [pi]
FMUL QWORD [constOil]
FMUL QWORD [EBX]
FMUL QWORD [EBX]
FST ST1
FLD QWORD [EAX]
FDIV ST1
FST QWORD [EDX]

POP EDX
POP ECX
POP EBX
POP EAX
POP EBP
RET

我在C代码的printf函数中遇到分段错误。 在我看来,调用nasm过程后,数组无法以某种方式填充。

最好的问候,并有一个愉快的周末!

您忘记了将返回地址存储在堆栈中。

当前代码:

MOV EAX, [EBP]      ; data1
MOV EBX, [EBP + 4]  ; data2
MOV ECX, [EBP + 8]  ; results1
MOV EDX, [EBP + 12] ; results2

更正的代码:

MOV EAX, [EBP + 4]  ; data1
MOV EBX, [EBP + 8]  ; data2
MOV ECX, [EBP + 12] ; results1
MOV EDX, [EBP + 16] ; results2

另外,您使用的是浮点数,在您的体系结构上可能是32位,但是您在使用QWORD(64位)来操纵它们。 并将4声明为4而不是4.0

暂无
暂无

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

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