Escribir 'A' en mi primer programa : ¿No funciona?

Iniciado por Garfield07, 31 Diciembre 2010, 17:41 PM

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

Garfield07

Bueno, tengo un code sencillo, sencillamente escribe una A en la terminal... Por algo se empieza  :P
La cosa es que no escribe nada...
Código (asm) [Seleccionar]

global _start

section .code
_start:
mov eax, 0x4   ; write (1, "A", 1);
mov ebx, 0x1
mov ecx, 0x42
mov edx, 0x2
int 80H

mov eax, 1 // return 0;
xor ebx, ebx
int 80H

Citar
nano code.s
nasm -f elf -o code.o code.s
ld -m elf_i386 -o code code.o
chmod 777 *
./code

Bueno, donde esta el fallo? Recuerden que es mi primer code xD...
Alguna idea en algo tan simple?

Pd: De paso, ahora mismito me voy a leer un libro de ASM, a ver si descubro algo  :P


* Quiero cambiar el mundo, pero estoy seguro de que no me darían el código fuente.
* No estoy tratando de destruir a Microsoft. Ese será tan solo un efecto colateral no intencionado.
* Si compila esta bien, si arranca es perfecto.

¡Wiki elhacker.net!
Un saludo

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

Garfield07

Entonces como lo hago para escribir una sola A? Y para poner la cadena sin usar data?


* Quiero cambiar el mundo, pero estoy seguro de que no me darían el código fuente.
* No estoy tratando de destruir a Microsoft. Ese será tan solo un efecto colateral no intencionado.
* Si compila esta bien, si arranca es perfecto.

¡Wiki elhacker.net!
Un saludo

Eternal Idol

Con pasar una direccion de memoria donde haya una 'A' (0x41) y que count (edx) sea 1 es suficiente. Para no usar .data podrias usar la pila ... proba ... no uso *NIX y encima es 31 de Diciembre  :silbar:
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

Garfield07

Pero como paso una direccion, algo asi como un puntero? le meto la A en la pila y le paso el ESP?
Código (asm) [Seleccionar]

push 0x42
pop ebx


Feliz nochevieja y gracias ! Ahora modifico !


* Quiero cambiar el mundo, pero estoy seguro de que no me darían el código fuente.
* No estoy tratando de destruir a Microsoft. Ese será tan solo un efecto colateral no intencionado.
* Si compila esta bien, si arranca es perfecto.

¡Wiki elhacker.net!
Un saludo

Eternal Idol

#5
Como te dije no uso *NIX asi que lo vas a tener que probar vos el codigo:

Código (asm) [Seleccionar]

push ecx ;no importa lo que haya, despues ponemos la 'A'
;no sera una cadena terminada correctamente
;pero como especificamos el tamaño en count no importa
mov byte ptr [esp], 041h ;sintaxis MASM
mov eax, 0x4   ; write (1, "A", 1);
mov ebx, 0x1 ;fd <<
mov ecx, esp ;buffer <<
mov edx, 0x1 ;count <<
int 80H
pop ecx



Feliz año nuevo.
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

Garfield07

#6
Bueno, muchisimas gracias por el code de nuevo xD... pero no me va... juntando codes:
Código (asm) [Seleccionar]
global _start

section .code
_start:
push ecx
mov byte ptr [esp], 041h
mov eax, 0x4
mov ebx, 0x1
mov ecx, esp
mov edx, 0x1
int 80H
pop ecx


mov eax, 1
xor ebx, ebx
int 80H

La cosa es que me da fallo de segmentación. Con la compilacion de antes...
Como es? (perdooooona)

Esto de ASM es buscar nuevas formas de hacer las cosas. En C la cosa no es tan dificil, pero ASM me resulta muchisimo mas entretenido ...
Bueno, poco a poco se agranda el expediente !!!

PD1: Feliz año nuevo otra vez!
PD2: Ahora que lo pienso, muchisimas gracias ... Ahora que me doy cuenta tu me has ayudado a empezar tanto en ASM como en C. Jaja cuando desaparezcas como Rojodos dire que fuistes tu quien me enseño lo que era un programa xD....


* Quiero cambiar el mundo, pero estoy seguro de que no me darían el código fuente.
* No estoy tratando de destruir a Microsoft. Ese será tan solo un efecto colateral no intencionado.
* Si compila esta bien, si arranca es perfecto.

¡Wiki elhacker.net!
Un saludo

08l00D

Código (asm) [Seleccionar]

global _start

section .code
_start:
push ecx
mov byte [esp], 041h
mov eax, 0x4
mov ebx, 0x1
mov ecx, esp
mov edx, 0x1
int 80H
pop ecx


mov eax, 1
xor ebx, ebx
int 80H

La sintaxis  no es igual en masm y nasm ... la linea que te puso eternal idol para copiar la letra a la pila es para masm, incluso lo puso como comentario en el codigo... en nasm para especificar el tamaño del dato a apuntar es con la palabra byte sola (en el caso de un byte obviamente)...
PD: Un buen libro que podes leer es Professional Assembly Language... es muy completo y de lectura facil y comprensible..

Saludos y feliz año nuevo

Garfield07

Feliz año nuevo y muchas gracias xD!!!
Pd: Me confundi al leer el comentario crei que ponia nasm fallo mio xD..


* Quiero cambiar el mundo, pero estoy seguro de que no me darían el código fuente.
* No estoy tratando de destruir a Microsoft. Ese será tan solo un efecto colateral no intencionado.
* Si compila esta bien, si arranca es perfecto.

¡Wiki elhacker.net!
Un saludo

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