Foro de elhacker.net

Programación => ASM => Mensaje iniciado por: fary en 10 Marzo 2013, 17:22 pm



Título: Llamadas a ASM desde C
Publicado por: fary en 10 Marzo 2013, 17:22 pm
Hola a todos,

Tengo una DLL creada en FASM y llamo a las funciones desde C pero me devuelve un error 0xC0000005 mi aplicacion y se cierra.

Para llamarla desde C lo ago así:

Código
  1. typedef (WINAPI * DLLCargada) (DWORD sock);
  2. DLLCargada ShellDLLCargada;
  3. ShellDLLCargada = (DLLCargada)GetProcAddress(Shell,"DLLCargada");
  4. ShellDLLCargada(sock);

y las funciones en la DLL están hechas así:

Código
  1. DLLCargada:    ; parametro sock
  2.             ; informamos que la DLL esta cargada correctamente.
  3.             push ebp
  4.             mov ebp,esp
  5.             mov eax,dword[esp+8]
  6.  
  7.             invoke send,eax,CargadaOk,20,0
  8.  
  9.             leave
  10.             ret    

La aplicación me peta y nose porque creo que es por la pila que no la arreglo bien o algo  desde el ASM :-\ ayuda  :P

un saludo!


Título: Re: Llamadas a ASM desde C
Publicado por: Eternal Idol en 10 Marzo 2013, 19:04 pm
Código
  1. ret 4


Título: Re: Llamadas a ASM desde C
Publicado por: fary en 10 Marzo 2013, 19:28 pm
Hola EI, gracias por responder.

La aplicación sigue dando el mismo error...

Código
  1. DLLCargada:    ; parametro sock
  2.             ; informamos que la DLL esta cargada correctamente.
  3.             push ebp
  4.             mov ebp,esp
  5.  
  6.  
  7.             invoke LoadLibraryA,mKernel32       ; cargamos las librerias
  8.             mov [Kernel32],eax
  9.  
  10.             invoke LoadLibraryA,mWinsock
  11.             mov [Winsock],eax
  12.  
  13.  
  14.             stdcall mGetProc,[Winsock],hsend
  15.             ; EAX = send@winsock
  16.  
  17.             mov edx,dword[esp+8]
  18.             stdcall eax,edx,CargadaOk,20,0  ;invoke send,edx,CargadaOk,20,0
  19.  
  20.             leave
  21.             ret 4  

En la función mGetProc hago ret 8 tambien y nada... estoy ya un poco desesperado  :xD


Título: Re: Llamadas a ASM desde C
Publicado por: Eternal Idol en 10 Marzo 2013, 19:59 pm
Bueno ese codigo ya es bastante diferente, depuralo linea por linea ya que ahora no hay forma de que lo haga yo sin tener que esforzarme (no se bien que hace mGetProc y sinceramente no tengo ganas de crear todo el codigo necesario en FASM).

EDITO: llamando a GetProcAddress funciona bien, siempre que hsend sea una cadena con send como texto claro ...


Título: Re: Llamadas a ASM desde C
Publicado por: fary en 10 Marzo 2013, 20:27 pm
mGetProc retorna la dirección de una API pasandole la librería y un hash de la cadena de la funcion.

Solo explota cuando lo lamo desde C si genero un exe con el mismo código ASM y llamo a las funciones no explota, creo que es por las convenciones de llamada o algo pero no acabo de atinar  :-X



Título: Re: Llamadas a ASM desde C
Publicado por: Eternal Idol en 10 Marzo 2013, 21:10 pm
Depuralo con WinDbg (en teoria estas usando stdcall en ambos lados), asi sabras exactamente cual es el problema, siempre es mas rapido para resolver un problema conocerlo.


Título: Re: Llamadas a ASM desde C
Publicado por: Arkangel_0x7C5 en 12 Marzo 2013, 16:30 pm
con el primer codigo si eliminas el winapi de la declaracion tiene que solucionarse el error de la convencion de llamadas

Saludos


Título: Re: Llamadas a ASM desde C
Publicado por: fary en 13 Marzo 2013, 12:05 pm
Ya solucione el problema, era porque rompia registros que no podia tocar con la convencion de llamada stdcall. Gracias EI jaja  ;)






Título: Re: Llamadas a ASM desde C
Publicado por: Eternal Idol en 13 Marzo 2013, 13:50 pm
De nadas  ::)