簡體   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