Foro de elhacker.net

Programación => ASM => Mensaje iniciado por: .:UND3R:. en 29 Noviembre 2011, 20:40 pm



Título: [Ayuda!]Problema con procedimientos Irvine
Publicado por: .:UND3R:. en 29 Noviembre 2011, 20:40 pm
Hola a todos tengo el siguiente código que quiero lograr hacerlo funcionar, pero no hay caso, lo único que quiero es que me muestre en consola el mensaje hola a todos utilizando el archivo de inclusión Irvine32.inc (Aun no prefiero utilizar las APIS de MS-Windows), al internarlo iniciar solo se cierra y no muestra nada.

Código
  1. TITLE Pruebas
  2. INCLUDE c:\masm32\include\Irvine32.inc
  3. INCLUDELIB c:\masm32\lib\kernel32.lib
  4. INCLUDELIB c:\masm32\lib\Irvine32.lib
  5. INCLUDELIB c:\masm32\lib\User32.lib
  6.  
  7. .data
  8. TEXT1  BYTE "Hola a todos",0
  9. .code
  10. main PROC
  11.     mov edx,OFFSET TEXT1
  12.     call WriteString
  13. exit
  14. main ENDP
  15. END main

Aclaro que el procedimiento WriteString se encarga de escribir una cadena en consola, requiere un solo parámetro que es el OFFSET de la cadena a mostrar.

Debuggeando he notado que que el error aparece retornando de la call y en last error me muestra lo siguiente: ERROR_INVALID_HANDLE

Por lo que deduzco que el manejador de la consola (lugar en donde se mostrará la cadena) es invalido, creo que retorna 0, mi duda es como solucionar esto ya que el mismo error ocurre cuando llamo al procedimiento DumpRegs (también perteneciente a la biblioteca de enlace de Irvine32.lib

Como soluciono esto?


Saludos

PD: he intentado iniciarlo desde la consola y con doble clic pero ninguno me muestra el mensaje

EDIT: he notado que por lo general cuando depuro programas que utilizan la consola para mostrar información o pedirla (E/S) estos estando detenidos en el EP ya me muestra la consola pero sin ningún contenido en OllyDBG pero en este caso con el programa que he ensamblado y posteriormente enlazado no me carga estando detenido en el EP


Título: Re: Problema con procedimientos Irvine
Publicado por: _Enko en 29 Noviembre 2011, 20:42 pm
Cual es la ventaja de agregar a este tal "Kip Irvine" a tus programas?
(http://kipirvine.com/asm/images/Irvine3.jpg)

digo, porque muy lindo no es :silbar: ;-)



Ese tal Irvine.inc de seguro que utiliza la Api de Consola de Windows, que no es nada complicada:

http://msdn.microsoft.com/en-us/library/windows/desktop/ms682073(v=vs.85).aspx


Y si no quieres usar la api de windows directamente, siempre tienes la opcion de usar la C Runtime.
Código:
invoke printf, szFormat, szStr

y antes haces los includes
msvcrt.inc o parecidos

Saludos.


Título: Re: Problema con procedimientos Irvine
Publicado por: .:UND3R:. en 29 Noviembre 2011, 20:44 pm
Te pido paciencia yo también deseo utilizar las apis de windows directamente pero voy siguiendo al pie de la letra el libro, pero mi problema es ese. podrías decirme como solucionarlo.

Muchas gracias

PD: no hes muy atractivo que digamos pero sabe algo de programación  :silbar:


Título: Re: Problema con procedimientos Irvine
Publicado por: _Enko en 29 Noviembre 2011, 21:20 pm
La libreria irvine es stdcall o fastcall?

mucho no te puedo ayudar, no lei el libro...

Si sigues el libro  a pie de letra, es cuestion de hacer buen copy past.
La unica alternativa que se me ocurre es no seguir el libro a pie de letras. Tomalo como una prueba anti copy past.



Título: Re: Problema con procedimientos Irvine
Publicado por: .:UND3R:. en 29 Noviembre 2011, 21:46 pm
La libreria irvine es stdcall o fastcall?

mucho no te puedo ayudar, no lei el libro...

Si sigues el libro  a pie de letra, es cuestion de hacer buen copy past.
La unica alternativa que se me ocurre es no seguir el libro a pie de letras. Tomalo como una prueba anti copy past.



Eso es chino para mi, de todas formas te adjunto un autoextraible:

http://kipirvine.com/asm/examples/index.htm (http://kipirvine.com/asm/examples/index.htm)

Example programs and link library source code for Visual Studio 2005

a ver si le puedes hechar una mirada por favor, quiero avanzar

Saludos


Título: Re: Problema con procedimientos Irvine
Publicado por: _Enko en 29 Noviembre 2011, 22:22 pm
por lo que veo, usa "irvinecall"  o como se le ha cantado.
Pasas el unico parametro que lleva en EDX que es lo que estas haciendo, y por lo que pude ver deberia funcionar.

no  te recomiendo enroscarte mucho con esa libreria... es un asco, la convencion de llamada es ridicula....
No se como  pretende enseñar usar luego la winapi (98% stdcall) con su libreria riducula 50% "irvinecall".
Código:

.data
caption db "Dialog Title", 0
HelloMsg BYTE "This is a pop-up message box.", 0dh,0ah
   BYTE "Click OK to continue...", 0
.code
main PROC
mov ebx,OFFSET caption ; caption
mov edx,OFFSET HelloMsg ; contents
call MsgBox
exit
main ENDP
END main
Y su codigo de ejemplo tambien le falla, "caption" con minuscula, pero "HelloMsg" con mayuscula... onda, elige un estilo y respetalo.


Título: Re: Problema con procedimientos Irvine
Publicado por: x64core en 29 Noviembre 2011, 22:44 pm
@_Enko mira yo tengo una pregunta :P
msgbox es una funcion de la libreria irvine32 no :P entonces revise el archivo irvine32.inc entonces
ahi aparecia:
MsgBox PROTO
pero se supone que es una funcion... y el codigo que hace que muestre ese msgbox? :P

no me digais que esta en el irvine32.lib ? :P


Título: Re: Problema con procedimientos Irvine
Publicado por: _Enko en 29 Noviembre 2011, 23:06 pm
archivos lib los usa el linker para enlazar tu ejecutable con las funciones. Son librerias estaticas.

los inc, son los prototipos de las funciones que tiene esa libreria para que el ensamblador sepa que es lo que estas usando y derive el trabajo al linker.

MsgBox  seria una META funcion, funcion de segundo grado... llamala como quieras.

La funcion original es MessageBoxA/W de user32, lo que hace MsgBox es llamar a la funcion de la winapi original. (de seguro que lugo hay uno que otro nivel mas, pero dejemoslo ahi)



Saludos.









Título: Re: Problema con procedimientos Irvine
Publicado por: x64core en 29 Noviembre 2011, 23:32 pm
oh ya ;D entendi pero para eso uso de una vez la de winapi :xD que señor.... :P


Título: Re: Problema con procedimientos Irvine
Publicado por: .:UND3R:. en 29 Noviembre 2011, 23:51 pm
por lo que veo, usa "irvinecall"  o como se le ha cantado.
Pasas el unico parametro que lleva en EDX que es lo que estas haciendo, y por lo que pude ver deberia funcionar.

no  te recomiendo enroscarte mucho con esa libreria... es un asco, la convencion de llamada es ridicula....
No se como  pretende enseñar usar luego la winapi (98% stdcall) con su libreria riducula 50% "irvinecall".
Código:

.data
caption db "Dialog Title", 0
HelloMsg BYTE "This is a pop-up message box.", 0dh,0ah
   BYTE "Click OK to continue...", 0
.code
main PROC
mov ebx,OFFSET caption ; caption
mov edx,OFFSET HelloMsg ; contents
call MsgBox
exit
main ENDP
END main
Y su codigo de ejemplo tambien le falla, "caption" con minuscula, pero "HelloMsg" con mayuscula... onda, elige un estilo y respetalo.


Hola _Enko gracias por la info, en cuanto a MsgBox no tengo problemas el problema se debe a cuando intento llamar a DumpRegs o a WriteString, WriteDecimal

bueno DumpRegs se encarga de devolver los registros de propósito general de 32 bits en la salida (Consola) mientras que WriteString se encarga de devolver en la consola una cadena de texto, si pudieras ayudarme te lo agradecería mucho, pues pretendo continuar, muchísimas gracias :D


Título: Re: [Ayuda!]Problema con procedimientos Irvine
Publicado por: _Enko en 1 Diciembre 2011, 02:24 am
Hola, en el enlace que pasaste:
http://kipirvine.com/asm/examples/index.htm

los include de la libreria irvine no se si realmente son compatibles con masm.

Con visual cpp fue tan facil como:
Código
  1.  
  2. unsigned int __stdcall WriteString();
  3. int main()
  4. {
  5. char *hello = "hola mundo";
  6. __asm{
  7. mov edx, hello
  8. }
  9. WriteString();
  10. system("pause");
  11. return 0;
  12. }
  13.  
solamente hubo que agregar en la opcion del linker irvine32.lib para que pueda resolver el simbolo WriteString. Y funciona bien.

primero, que en masm no he podido hacer el include de irvine32.inc, se supone que es para masm, pero a mi me ha creado conflicto SmallWin.inc que resolvi haciendo el prototipo manualmente.

Código
  1. .386
  2. .model flat, stdcall
  3. option casemap :none
  4.  
  5.  
  6. include \masm32\include\windows.inc
  7. include \masm32\include\kernel32.inc
  8. include \masm32\include\msvcrt.inc
  9.  
  10. WriteString PROTO
  11.  
  12.  
  13. includelib \masm32\lib\kernel32.lib
  14. includelib \masm32\lib\msvcrt.lib
  15. includelib Irvine32.lib
  16. .data
  17. szMsg db "Hola a todos",0
  18. .code
  19.  
  20. start:
  21.     mov edx, offset szMsg
  22.     call WriteString
  23.     invoke ExitProcess, 0
  24. end start
  25.  
Igual no funciona,  por alguna extraña razon no tiene un handle valido a la consola.

No uso masm, no se si tendra alguna vuelta mas, pero en si, tal cual esta deberia funcionar.


Título: Re: [Ayuda!]Problema con procedimientos Irvine
Publicado por: .:UND3R:. en 1 Diciembre 2011, 04:54 am
Hola, en el enlace que pasaste:
http://kipirvine.com/asm/examples/index.htm

los include de la libreria irvine no se si realmente son compatibles con masm.

Con visual cpp fue tan facil como:
Código
  1.  
  2. unsigned int __stdcall WriteString();
  3. int main()
  4. {
  5. char *hello = "hola mundo";
  6. __asm{
  7. mov edx, hello
  8. }
  9. WriteString();
  10. system("pause");
  11. return 0;
  12. }
  13.  
solamente hubo que agregar en la opcion del linker irvine32.lib para que pueda resolver el simbolo WriteString. Y funciona bien.

primero, que en masm no he podido hacer el include de irvine32.inc, se supone que es para masm, pero a mi me ha creado conflicto SmallWin.inc que resolvi haciendo el prototipo manualmente.

Código
  1. .386
  2. .model flat, stdcall
  3. option casemap :none
  4.  
  5.  
  6. include \masm32\include\windows.inc
  7. include \masm32\include\kernel32.inc
  8. include \masm32\include\msvcrt.inc
  9.  
  10. WriteString PROTO
  11.  
  12.  
  13. includelib \masm32\lib\kernel32.lib
  14. includelib \masm32\lib\msvcrt.lib
  15. includelib Irvine32.lib
  16. .data
  17. szMsg db "Hola a todos",0
  18. .code
  19.  
  20. start:
  21.     mov edx, offset szMsg
  22.     call WriteString
  23.     invoke ExitProcess, 0
  24. end start
  25.  
Igual no funciona,  por alguna extraña razon no tiene un handle valido a la consola.

No uso masm, no se si tendra alguna vuelta mas, pero en si, tal cual esta deberia funcionar.

Que extraño, se supone que está orientado a MASM incluso hablan de que los ejemplos son realizados bajo MASM. Te comento tengo: la desventaja que no sé como hacerlo a través de las API'S de Windows pero algo me ayuda el arte de Ingeniería inversa traceando noté en donde se genera el error:


00401F1E  |.  6A 00         PUSH 0                                        ; /pReserved = NULL
00401F20  |.  68 98484000   PUSH serial.00404898                          ; |pWritten = serial.00404898
00401F25  |.  50            PUSH EAX                                      ; |CharsToWrite
00401F26  |.  52            PUSH EDX                                      ; |Buffer
00401F27  |.  FF35 94484000 PUSH DWORD PTR DS:[404894]                    ; |hConsole = NULL
00401F2D  |.  E8 34010000   CALL <JMP.&kernel32.WriteConsoleA>            ; \WriteConsoleA


A mi criterio debería ser pusheado el handle de la consola, es por eso que no puede escribir ya que la call WriteString utiliza la API de windows WriteConsoleA, pero desconozco como se realizaría todo en código de fuente ASM ya que eso estoy estudiando (y de eso trama el libro), se podría sacar algo de provecho con lo comentado?

Saludos y muchas gracias _Enko por tomarte tu tiempo, muchísimas gracias, a ver si te hago la competencia en los crackmes en algunos años luz, Saludos


Título: Re: [Ayuda!]Problema con procedimientos Irvine
Publicado por: _Enko en 1 Diciembre 2011, 06:26 am
Es lo que te habia comentado, no le pasa un handle valido a consola.
Lo que me extraña a mi, es que importando la libreria a visual studio si funciona.
Trata reinstalando masm, y mejor aun, reinstala exactamente la misma version que viene con el libro.

pd: no es "arte ingenieria inversa" sino que se llama "depurar mi propio programa"


Saludos.


Título: Re: [Ayuda!]Problema con procedimientos Irvine
Publicado por: .:UND3R:. en 1 Diciembre 2011, 07:08 am
Es lo que te habia comentado, no le pasa un handle valido a consola.
Lo que me extraña a mi, es que importando la libreria a visual studio si funciona.
Trata reinstalando masm, y mejor aun, reinstala exactamente la misma version que viene con el libro.

pd: no es "arte ingenieria inversa" sino que se llama "depurar mi propio programa"


Saludos.

Para mi es entretenido nunca había depurado algo que era mio, siempre depuré lo ajeno

Puede ser útil lo siguiente?

http://kipirvine.com/asm/5th/gettingStarted/index.htm#batch (http://kipirvine.com/asm/5th/gettingStarted/index.htm#batch)


Título: Re: [Ayuda!]Problema con procedimientos Irvine
Publicado por: _Enko en 1 Diciembre 2011, 19:08 pm
acabo de probar el codigo del primer post y funciona ok si:

en QEDIT de masm32, pones:
Project>>Console BuildAll

y ahi ya funciona bien.

casualmetne era el mismo error que estaba teniendo al querer usar la msvcrt con masm.


Título: Re: [Ayuda!]Problema con procedimientos Irvine
Publicado por: .:UND3R:. en 1 Diciembre 2011, 20:32 pm
acabo de probar el codigo del primer post y funciona ok si:

en QEDIT de masm32, pones:
Project>>Console BuildAll

y ahi ya funciona bien.

casualmetne era el mismo error que estaba teniendo al querer usar la msvcrt con masm.

Nada más que decir, excelente gracias a ti podré seguir el libro al pie de la letra sin ningún problema, de verdad muchísimas gracias, ya veía que mientras me lo leía no iba a poder ejercitarme con los ejercicios que me iban a salir, Muchísimas gracias _Enko :D


Título: Re: [Ayuda!]Problema con procedimientos Irvine
Publicado por: x64core en 1 Diciembre 2011, 20:49 pm
yo por eso cuando llege a esa parte lo hare con otra libreria :P
ya solo me faltan 20 pag para el capitulo 5 :D