どういうわけか、cからのこの呼び出しアセンブリ関数に関連しています
私はその関数にintと長さの配列を渡します:
do_stuff_in_asm (array, len);
組立部品はこんな感じ
...................
movl 8(%ebp), %eax
movl 12(%ebp), %ecx
movl $0, %edi
...................
movl (%eax,%edi,4), %edx
pushl %edx
pushl $printtext
call printf
addl $8, $esp
..................
len引数12(%ebp)を出力できますが、配列の最初の要素である%edxで同じことを試みるたびに、セグメンテーション違反が発生します。
int *array, n, i;
printf ("Give array size: ");
scanf("%d",&n);
array = malloc (n * sizeof(int));
次に、データでいっぱいになります。