Hola a todos, estoy programando un bootloader y un programa, ambos en ASM, el boot inicia la computadora, muestra uno mensaje y luego deberia cargar el programa, y este ultimo muestra un mensaje, llama al modo protegido y estoy trabajando en un arcaico sistema de E/S. Cabe destacar que inicialmente era un solo programa, que funcionaba perfectamente, pero separe lo que era el sector de booteo y el programa en si, ya que el programa iba creciendo en tamaño. El problema es que no carga el programa que se encuentra en el segundo sector, ¿que es lo que esta sucediendo? ¿que error estoy cometiendo? ¿que se puede hacer para que funcione correctamente?
Ademas tengo una duda, ¿es necesario iniciar el modo protegido para llamar al programa que se encuentra en el segundo sector del floppy? Porque solo he encontrado informacion para modo real, y he usado la Int 13h ya que no encuentro informacion sobre cargar sectores de discos en modo protegido, porque no se pueden usar las interrupciones en el modo protegido. He buscado informacion en muchisimas paginas, en google, en osdev.org y nada. De antemano, gracias.
;boot.asm
[BITS 16]
[ORG 7C00h]
jmp main
mesg db 'Cargando el programa... espere... ',0Ah,0Dh,0
init:
cli
sti
ret
clrscr :
mov ax,0600h
mov cx,0000h
mov dx,174Fh
mov bh,0
int 10h
ret
print_hello:
mov ah,13h
mov al,01h
mov bx,0007h
mov cx,21h
mov dx,0000h
mov bl,07h
mov bp,mesg
int 10h
ret
reset_floppy:
mov ah,00h
mov dl,00h
int 13h
ret
load_app:
mov ah,02h
mov al,13
mov ch,02
mov cl,02
mov dh,01
mov dl,00h
int 13h
jmp 0800h:0000h
main:
call init
call clrscr
call print_hello
call reset_floppy
call load_app
times 510-($-$$) db 0
db 0x55
db 0xAA
http://www.ctyme.com/intr/rb-0607.htm
AH = 02h
AL = number of sectors to read (must be nonzero)
CH = low eight bits of cylinder number
CL = sector number 1-63 (bits 0-5)
high two bits of cylinder (bits 6-7, hard disk only)
DH = head number
DL = drive number (bit 7 set for hard disk)
ES:BX -> data buffer
CH y DH deberian ser 0.
http://en.wikipedia.org/wiki/Cylinder_%28disk_drive%29
http://en.wikipedia.org/wiki/Cylinder-head-sector
¿De donde sale la idea de saltar a 0800h:0000h? ES deberia ser 0800h y BX 0 para que eso funcionara ...
Gracias por el comentario, la verdad es que me habia percatado de eso y pues bien, si es=0800h y bx=0 para que funcione, el código deberia ser así, no? ya que no se puede escribir directamente sobre es.
load_kernel:
mov ah,02h
mov al,10
mov ch,00
mov cl,02
mov dl,00h
mov dh,00
mov bx,0800h
mov es,bx
mov bx,0
int 13h
jmp 0800h:0000h
Sin embargo no funciona, busco y busco y sigue sin funcionar. En una página encontre que debe cargarse el segmento sobre la memoria, ¿es cierto eso? si es así ¿como se hace? Las explicaciones que dan no son del todo claras o simplemente estan equivocadas. Gracias.
Bueno, no se notaba en el codigo y tenes exactamente el mismo problema en print_hello (escribe basura).
En realidad funciona perfectamente ese codigo para cargar el sector en memoria y saltar (ya lo probe con un viejo codigo que tenia, paso a modo protegido, escribio en pantalla y hizo un beep, funciona). El problema ahora lo tenes en otro lado, o escribis incorrectamente en el diskette o lo que escribis tiene otro problema ...
Cita de: Eternal Idol en 18 Diciembre 2011, 14:20 PM
Bueno, no se notaba en el codigo y tenes exactamente el mismo problema en print_hello (escribe basura).
En realidad funciona perfectamente ese codigo para cargar el sector en memoria y saltar (ya lo probe con un viejo codigo que tenia, paso a modo protegido, escribio en pantalla y hizo un beep, funciona). El problema ahora lo tenes en otro lado, o escribis incorrectamente en el diskette o lo que escribis tiene otro problema ...
Osea que el problema esta en el programa y no en el boot?
El problema esta en el segundo sector, este se carga correctamente y si hay codigo valido lo ejecuta sin problemas. Tenes que fijate si es que hay codigo en el segundo sector y si este es valido ...
Bueno, se que el boot se carga correctamente, pero el app no.
Para enviar el app al segundo sector escribo en la terminal:
dd if=app.bin of='floppy' bs=512 seek=1
¿Es correcto esto? Por cierto, lo envio todo a una imagen de floppy y lo cargo con qemu ¿influye en los resultados?
Parece que si pero esto no es assembly sino un programa de *NIX. Comproba que los bytes coincidan en la imagen y el binario ... si lo hacen comproba el codigo que ahi debe estar el problema.
Usar imagenes y maquinas virtuales no deberia ser ningun problema.
Cita de: Eternal Idol en 18 Diciembre 2011, 15:56 PM
Parece que si pero esto no es assembly sino un programa de *NIX. Comproba que los bytes coincidan en la imagen y el binario ... si lo hacen comproba el codigo que ahi debe estar el problema.
Usar imagenes y maquinas virtuales no deberia ser ningun problema.
He revisado la correspondencia entre bytes y es correcta, aproveche de comprobar con el comando od si se grababa exactamente igual en el floppy, y bien la respuesta es si. El código de pruebas del app solo borra la pantalla.
[BITS 16]
jmp main
clrscr :
mov ax,0x0600
mov cx,0x0000
mov dx,0x174f
mov bh,0
int 0x10
ret
main:
call clrscr
jmp main
Por cierto, en algunos lugares en internet decian que habia que ubicarnos en 0800h con org en el app y en otros lo hacian sin la ubicacion, ¿influye eso? Ademas, si a ese código lo transformo en booteable con AAh 55h funciona de maravillas.
¿Y cuando arranca la maquina virtual que pasa exactamente? Si uso eso no alcanzo a ver el mensaje siquiera, simplemente queda la pantalla limpia ...
Leyendo una tecla despues de escribir en pantalla y antes de cargar el codigo del seugndo sector se nota mas como funciona:
xor ah, ah
int 16h
Cita de: Eternal Idol en 18 Diciembre 2011, 16:58 PM
¿Y cuando arranca la maquina virtual que pasa exactamente? Si uso eso no alcanzo a ver el mensaje siquiera, simplemente queda la pantalla limpia ...
Leyendo una tecla despues de escribir en pantalla y antes de cargar el codigo del seugndo sector se nota mas como funciona:
xor ah, ah
int 16h
Claaro, no se nota el mensaje si uso el codigo del principio, pero ahora estoy trabajando sobre una versión reducida del boot que solo posee la funcion reset_floppy y load_app solo para testear la carga del segundo sector, y se supone que en caso de cargar el app borra toda la pantalla, incluso los mensajes de la BIOS. Pero al darle launch en el qemu launcher no borra la pantalla, solo muestra que cargo el boot y nada mas
Exactamente dice:
Starting SeaBIOS (version pre-0.6.1-20100702_143500-palmer)
Booting from Floppy...
_
Sin embargo hace unos minutos, luego de haber mostrado ese mensaje por alrededor de minuto y medio, se limpio la pantalla. Vuelvo a intentarlo y vuelve a pasar.
Ahora pruebo con mostrar un mensaje desde el app, pero solo limpia la pantalla ¿que es lo que sucede?
No tenemos poder de adivinacion como para saber que estas haciendo, si cambias el codigo y no lo decis nadie se entera. Y no, no se que sucede en tu maquina ya que a mi me funciona bien pero no uso *NIX, ni dd, ni QEMU.
PD. Proba sin usar ni en el boot ni en el programa clrscr.
Bueno gracias por la ayuda y especialmente por las molestias :D A pesar de que no logro hacer funcionar el bootloader :(
De nada, segui probando, tiene que funcionar.