Título: Problema al cargar segundo sector del floppy Publicado por: armizh en 18 Diciembre 2011, 00:14 am 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. Código: ;boot.asm Título: Re: Problema al cargar segundo sector del floppy Publicado por: Eternal Idol en 18 Diciembre 2011, 02:18 am 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 ... Título: Re: Problema al cargar segundo sector del floppy Publicado por: armizh en 18 Diciembre 2011, 02:44 am 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.
Código: load_kernel: Título: Re: Problema al cargar segundo sector del floppy Publicado por: 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 ... Título: Re: Problema al cargar segundo sector del floppy Publicado por: armizh en 18 Diciembre 2011, 14:46 pm Bueno, no se notaba en el codigo y tenes exactamente el mismo problema en print_hello (escribe basura). Osea que el problema esta en el programa y no en el boot?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 ... Título: Re: Problema al cargar segundo sector del floppy Publicado por: Eternal Idol en 18 Diciembre 2011, 14:48 pm 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 ...
Título: Re: Problema al cargar segundo sector del floppy Publicado por: armizh en 18 Diciembre 2011, 15:29 pm Bueno, se que el boot se carga correctamente, pero el app no.
Para enviar el app al segundo sector escribo en la terminal: Código: dd if=app.bin of='floppy' bs=512 seek=1 Título: Re: Problema al cargar segundo sector del floppy Publicado por: 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. Título: Re: Problema al cargar segundo sector del floppy Publicado por: armizh en 18 Diciembre 2011, 16:45 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. 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.Usar imagenes y maquinas virtuales no deberia ser ningun problema. Código: [BITS 16] 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. Título: Re: Problema al cargar segundo sector del floppy Publicado por: 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: Código
Título: Re: Problema al cargar segundo sector del floppy Publicado por: armizh en 18 Diciembre 2011, 17:33 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 ... 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 masLeyendo una tecla despues de escribir en pantalla y antes de cargar el codigo del seugndo sector se nota mas como funciona: Código
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? Título: Re: Problema al cargar segundo sector del floppy Publicado por: Eternal Idol en 18 Diciembre 2011, 18:26 pm 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. Título: Re: Problema al cargar segundo sector del floppy Publicado por: armizh en 18 Diciembre 2011, 18:53 pm Bueno gracias por la ayuda y especialmente por las molestias :D A pesar de que no logro hacer funcionar el bootloader :(
Título: Re: Problema al cargar segundo sector del floppy Publicado por: Eternal Idol en 18 Diciembre 2011, 19:27 pm De nada, segui probando, tiene que funcionar.
|