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