[英]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.