Llamadas a ASM desde C

Iniciado por fary, 10 Marzo 2013, 17:22 PM

0 Miembros y 1 Visitante están viendo este tema.

fary

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í:

typedef (WINAPI * DLLCargada) (DWORD sock);
DLLCargada ShellDLLCargada;
ShellDLLCargada = (DLLCargada)GetProcAddress(Shell,"DLLCargada");
ShellDLLCargada(sock);


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

Código (asm) [Seleccionar]
DLLCargada:    ; parametro sock
             ; informamos que la DLL esta cargada correctamente.
             push ebp
             mov ebp,esp
             mov eax,dword[esp+8]

             invoke send,eax,CargadaOk,20,0

             leave
             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!
Un byte a la izquierda.

Eternal Idol

La economía nunca ha sido libre: o la controla el Estado en beneficio del Pueblo o lo hacen los grandes consorcios en perjuicio de éste.
Juan Domingo Perón

fary

#2
Hola EI, gracias por responder.

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

Código (asm) [Seleccionar]
DLLCargada:    ; parametro sock
            ; informamos que la DLL esta cargada correctamente.
            push ebp
            mov ebp,esp


            invoke LoadLibraryA,mKernel32       ; cargamos las librerias
            mov [Kernel32],eax

            invoke LoadLibraryA,mWinsock
            mov [Winsock],eax


            stdcall mGetProc,[Winsock],hsend
            ; EAX = send@winsock

            mov edx,dword[esp+8]
            stdcall eax,edx,CargadaOk,20,0  ;invoke send,edx,CargadaOk,20,0

            leave
            ret 4  


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

Eternal Idol

#3
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 ...
La economía nunca ha sido libre: o la controla el Estado en beneficio del Pueblo o lo hacen los grandes consorcios en perjuicio de éste.
Juan Domingo Perón

fary

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

Un byte a la izquierda.

Eternal Idol

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.
La economía nunca ha sido libre: o la controla el Estado en beneficio del Pueblo o lo hacen los grandes consorcios en perjuicio de éste.
Juan Domingo Perón

Arkangel_0x7C5

con el primer codigo si eliminas el winapi de la declaracion tiene que solucionarse el error de la convencion de llamadas

Saludos

fary

Ya solucione el problema, era porque rompia registros que no podia tocar con la convencion de llamada stdcall. Gracias EI jaja  ;)




Un byte a la izquierda.

Eternal Idol

La economía nunca ha sido libre: o la controla el Estado en beneficio del Pueblo o lo hacen los grandes consorcios en perjuicio de éste.
Juan Domingo Perón