Я заканчиваю программу сборки, которая заменяет символы в строке с заданным символом замены. Код сборки вызывает функции C, а сама программа сборки вызывается из main в моем .c файле. Однако, пытаясь закончить и вернуть окончательное значение int из программы сборки TO C, я получаю segfaults. Мой файл .asm выглядит следующим образом:Сборка Возврат int к функции C segfaults
; File: strrepl.asm
; Implements a C function with the prototype:
;
; int strrepl(char *str, int c, int (* isinsubset) (int c)) ;
;
;
; Result: chars in string are replaced with the replacement character and string is returned.
SECTION .text
global strrepl
_strrepl: nop
strrepl:
push ebp ; set up stack frame
mov ebp, esp
push esi ; save registers
push ebx
xor eax, eax
mov ecx, [ebp + 8] ;load string (char array) into ecx
jecxz end ;jump if [ecx] is zero
mov al, [ebp + 12] ;move the replacement character into esi
mov edx, [ebp + 16] ;move function pointer into edx
firstLoop:
xor eax, eax
mov edi, [ecx]
cmp edi, 0
jz end
mov edi, ecx ; save array
movzx eax, byte [ecx] ;load single byte into eax
push eax ; parameter for (*isinsubset)
mov edx, [ebp + 16]
call edx ; execute (*isinsubset)
mov ecx, edi ; restore array
cmp eax, 0
jne secondLoop
add esp, 4 ; "pop off" the parameter
mov ebx, eax ; store return value
add ecx, 1
jmp firstLoop
secondLoop:
mov eax, [ebp+12]
mov [ecx], al
mov edx, [ebp+16]
add esp, 4
mov ebx, eax
add ecx, 1
jmp firstLoop
end:
pop ebx ; restore registers
pop esi
mov esp, ebp ; take down stack frame
pop ebp
mov eax, 9
push eax ;test
ret
и мой файл с:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
//display *((char *) $edi)
// These functions will be implemented in assembly:
//
int strrepl(char *str, int c, int (* isinsubset) (int c)) ;
int isvowel (int c) {
if (c == 'a' || c == 'e' || c == 'i' || c == 'o' || c == 'u')
return 1 ;
if (c == 'A' || c == 'E' || c == 'I' || c == 'O' || c == 'U')
return 1 ;
return 0 ;
}
int main(){
char *str1;
int r;
str1 = strdup("ABC 123 779 Hello World") ;
r = strrepl(str1, '#', &isdigit) ;
printf("str1 = \"%s\"\n", str1) ;
printf("%d chararcters were replaced\n", r) ;
free(str1) ;
return 0;
}
В моей сборке кода, вы можете увидеть в конце
mov eax, 9
push eax
Я просто пытаюсь верните значение 9 в значение «r», которое является int в файле C. Это просто тест, чтобы проверить, могу ли я вернуть int обратно в r в файле c. В конце концов я вернусь к числу символов, которые были заменены на r. Тем не менее, мне нужно выяснить, почему следующий код выше является segfault. Есть идеи?
я вижу. Исправьте меня, если я ошибаюсь, но если бы я хотел вернуть значение FROM assembly TO c, я бы сохранил его в регистре EAX, нет? – user2357446
Нет, не «нет» :-) Я имею в виду, да, обычно вы просто вставляете его в eax и возвращаетесь. – paxdiablo