Autor
|
Tema: [FASM]strlen en ASM (Leído 6,004 veces)
|
0xDani
Desconectado
Mensajes: 1.077
|
He encontrado una implementacion de strlen en ASM, podriais ayudarme a entenderla? ; Will return the length of a null-terminated string ; The result will be written to ECX ; ; Usage: ; hello_tmp db "test",0 ; ... ; ccall strlen, hello_tmp proc strlen, strInput mov ecx,-1 mov al,0 mov edi,[strInput] cld repne scasb not ecx dec ecx ret endp
Enlace: http://www.betamaster.us/blog/?p=471Saludos.
|
|
|
En línea
|
I keep searching for something that I never seem to find, but maybe I won't, because I left it all behind!
I code for $$$ Hago trabajos en C/C++ Contactar por PM
|
|
|
_Enko
|
fijate que hacen las instrucciones "cld", "repne" y "scasb" y con eso debe quedar claro. Me atrevería a decir que está mucho mejor la implementecion de la c runtime de microsoft en mvcrt.dll _strelen. (son mas lineas de codigo, pero funciona mas rapido) Ya que si mal no recuerdo, no lo hacia de a byte a byte sino de dwrod.
|
|
|
En línea
|
|
|
|
0xDani
Desconectado
Mensajes: 1.077
|
La instruccion cld limpia la flag de direccion pero el repne con el scasb que hacen? No lo pillo
|
|
|
En línea
|
I keep searching for something that I never seem to find, but maybe I won't, because I left it all behind!
I code for $$$ Hago trabajos en C/C++ Contactar por PM
|
|
|
avesudra
Desconectado
Mensajes: 724
Intentando ser mejor cada día :)
|
Hola 0xDani, REPNE repite un bucle y decrementa ECX mientras que la bandera zero no esté activada. SCASB lo que hace es mirar si el byte de AL coincide con el byte que apunta EDI. Básicamente la instrucción SCASB sería similar a esto: CMP AL,[EDI] INC EDI
Siguiendo con el problema que planteas el código es fácil de entender, el ciclo de REPNE termina cuando SCASB encuentra el final de la cadena. Lo más complicado de entender viene después. Que se le hace un NOT a ECX y lo disminuye en 1. Esto tiene una explicación y es que para pasar un número de positivo a negativo, se realiza el complemento a dos. Que consiste en: -Aplicar el NOT -Sumar 1 al resultado obtenido. Ejemplo(negativo a positivo): -1 en binario es 1111 NOT 1111 = 0000 0000 + 1 = 0001 Ejemplo(positivo a negativo): 1 en binario es 0001 NOT 0001 = 1110 1110 + 1 = 1111
Una vez dicho esto, para pasar de un numero positivo a negativo sería exactamente igual. Pero en el caso de esta rutina, REPNE disminuye ECX también cuando encuentra el final de cadena, y además ECX ya tenía un -1 , así que el resultado si le aplicásemos el complemento a dos directamente estaría 2 por encima del correcto. Para corregir esto , una vez aplicado el NOT , en vez de sumarle un 1 , se le resta , provocando así que de el resultado correcto.
|
|
|
En línea
|
Regístrate en
|
|
|
0xDani
Desconectado
Mensajes: 1.077
|
Gracias por la explicacion avesudra, pero todavia hay una cosa que no entiendo. Si SCASB compara AL con el byte al que apunta EDI, porque al principio hace: mov edi,[strInput]
Asi EDI contiene el primer byte de la cadena, no su direccion no? A mi pobre entender deberia ser: mov edi,strInput
Saludos y gracias por la ayuda!
|
|
|
En línea
|
I keep searching for something that I never seem to find, but maybe I won't, because I left it all behind!
I code for $$$ Hago trabajos en C/C++ Contactar por PM
|
|
|
avesudra
Desconectado
Mensajes: 724
Intentando ser mejor cada día :)
|
Porque será un puntero y strInput lo que contiene es otra dirección
|
|
|
En línea
|
Regístrate en
|
|
|
0xDani
Desconectado
Mensajes: 1.077
|
Que raro hubiera sido mas facil hacerlo como yo he dicho no? ¬¬' Pero bueno ya lo he comprendido gracias a los dos Saludos.
|
|
|
En línea
|
I keep searching for something that I never seem to find, but maybe I won't, because I left it all behind!
I code for $$$ Hago trabajos en C/C++ Contactar por PM
|
|
|
avesudra
Desconectado
Mensajes: 724
Intentando ser mejor cada día :)
|
Jajajaja hombre más fácil es pero lo que obtendrías en edi haciendo esto: mov edi,strInput
Sería la dirección de memoria de la variable strInput(que es un puntero), no la de la dirección a la que apunta ese puntero, que es su contenido. Es un poco lioso .Lo que puedes hacer para entenderlo mejor es compilar algún programilla y depurarlo con OllyDBG
|
|
« Última modificación: 28 Diciembre 2012, 14:33 pm por avesudra »
|
En línea
|
Regístrate en
|
|
|
|
Mensajes similares |
|
Asunto |
Iniciado por |
Respuestas |
Vistas |
Último mensaje |
|
|
[ANSI C] Split(), strlen(), mid(), Instr(), strcpy().
« 1 2 »
Programación C/C++
|
BlackZeroX
|
11
|
10,457
|
14 Enero 2011, 02:35 am
por Littlehorse
|
|
|
Duda con strlen [Solucionado]
Programación C/C++
|
Dark00
|
9
|
5,870
|
11 Noviembre 2012, 19:17 pm
por Dark00
|
|
|
[Micro-rutina] strlen - ANSI
« 1 2 »
ASM
|
Karcrack
|
13
|
8,175
|
4 Abril 2013, 02:14 am
por mr.blood
|
|
|
strlen() y .length()
Programación C/C++
|
erest0r
|
4
|
4,590
|
17 Septiembre 2013, 08:25 am
por erest0r
|
|
|
Duda con programa - funcion strlen?
Programación C/C++
|
welchu
|
9
|
4,820
|
18 Febrero 2014, 03:11 am
por NOB2014
|
|