flat assembler
Message board for the users of flat assembler.
  
|  Index
      > OS Construction > BootLoader help Goto page 1, 2 Next | 
| Author | 
 | 
| SheldonCompton 07 Feb 2015, 16:12 I've been trying to write a usb bootloader in fasm for the last week or so.  It boots, but for some reason it doesn't seem to want to load and jump to the kernel.  No flags seem to be set.  Any suggestions will gratefully be suggested. 
 
 | |||||||||||||||||||||
|  07 Feb 2015, 16:12 | 
 | 
| SheldonCompton 07 Feb 2015, 23:55 Unfortunately that wasn't the problem.  Currently it displays 1 and then nothing after.
 This is the build script I've been using. ----------------------------------------------------------------------------------------------------------------------------------- #!/bin/bash cd /home/sheldon/Desktop/fasm ./fasm ../Git/ProgrammingClubGame/BootLoader0.03.asm ./fasm ../Git/ProgrammingClubGame/Kernel0.01.asm cd /home/sheldon/Desktop/Git/ProgrammingClubGame dd if=/home/sheldon/Desktop/Git/ProgrammingClubGame/BootLoader0.03.bin of=/dev/sdb bs=512 count=1 dd if=/home/sheldon/Desktop/Git/ProgrammingClubGame/Kernel0.01.bin of=/dev/sdb seek=2 bs=512 count=1 rm /home/sheldon/Desktop/Git/ProgrammingClubGame/BootLoader0.03.bin rm /home/sheldon/Desktop/Git/ProgrammingClubGame/Kernel0.01.bin ------------------------------------------------------------------------------------------------------------------------------------------------------------- Any suggestions will gratefully be excepted. | |||
|  07 Feb 2015, 23:55 | 
 | 
| SheldonCompton 08 Feb 2015, 00:03 Sorry, wrong version of the build script. Here is the one I'm really using.
 -------------------------------------------------------------------------------------------------------------- #!/bin/bash cd /home/sheldon/Desktop/fasm ./fasm ../Git/ProgrammingClubGame/BootLoader0.03.asm ./fasm ../Git/ProgrammingClubGame/Kernel0.01.asm cd /home/sheldon/Desktop/Git/ProgrammingClubGame dd if=/home/sheldon/Desktop/Git/ProgrammingClubGame/BootLoader0.03.bin of=/dev/sdb bs=512 count=1 dd if=/home/sheldon/Desktop/Git/ProgrammingClubGame/Kernel0.01.bin of=/dev/sdb obs=512 seek=1 bs=512 count=1 rm /home/sheldon/Desktop/Git/ProgrammingClubGame/BootLoader0.03.bin rm /home/sheldon/Desktop/Git/ProgrammingClubGame/Kernel0.01.bin ------------------------------------------------------------------------------------------------------------------------------------------------------------- | |||
|  08 Feb 2015, 00:03 | 
 | 
| smiddy 08 Feb 2015, 12:43 Yeah, I have no idea what those scripts are...I'm assuming that's Linux.
 The drive you are placing it on should get on the very first sector the binary BootLoader0.03.bin, then the second sector on the disk should get the kernel binary. Although, I'm looking at your INT 13h, and that should be: Code: MOV DL,[BootDriveNumber] ; DL from BOOT ; you are placing a 1 here, don't, remove your DL, it is already set at boot. MOV AH,42h ; Read from drive function MOV SI,DiskAddressPacket ; Load SI with address of the DAP INT 13h ; Call read sector from drive JC Failure ; Nope, hosed, get out At least in theory, I haven't tried a USB drive with these. This does work with a CD-ROM however, which I've tested it on, and assuming that the USB emulates through BIOS INT 13h, should be the very same. | |||
|  08 Feb 2015, 12:43 | 
 | 
| SheldonCompton 08 Feb 2015, 16:20 I tried this, but now I'm getting an error. 
 | |||||||||||
|  08 Feb 2015, 16:20 | 
 | 
| smiddy 09 Feb 2015, 06:34 Now you have 
 Code: mov dl,0 | |||
|  09 Feb 2015, 06:34 | 
 | 
| SheldonCompton 09 Feb 2015, 12:57 This is where I am right now.  It displays 1 then nothing.
 Code: org 7C00h ;;;;;;;;;;;;;;;;;; ;DO NOT MODIFY DL; ;;;;;;;;;;;;;;;;;; jmp start start: cli mov ax, 0x0200 ;start the stack after the bootloader mov ss, ax mov ax, 0xC00 ;make the stack 3k big later this will need to be changed and hardware detection added mov ax, sp ;but for now this will work. mov ax, ds sti mov ah, 0x0e mov al, '1' int 0x10 mov ah, 0x42 mov si, DiskAddressPacket int 0x13 jc error jmp 0xA00:0x0200 error: mov ah, 0x0e mov al, 'E' int 0x10 DiskAddressPacket: db 0x10 ;size of packet db 0x0 ;reserved dw 0x1 ;number of blocks to transfer dw 0x200 ;offset dw 0xA00 ;where in memory to write to dq 0x1 ;starting block to read dd 0x0 times 510-($-$$) db 0 ;Fill rest of sector up with 0s to make this 512B (a sector) dw 0xAA55 ;Let BIOS know this is an OS The kernel hasn't changed. | |||
|  09 Feb 2015, 12:57 | 
 | 
| smiddy 09 Feb 2015, 14:34 I'll see if I can modify a thumb drive tonight and try it, when I get a chance after getting home from work. The only other thing I would consider, is that the block may be wrong, I cannot recall if it starts at 0, or 1. I suspect since you are only getting one '1' on the screen, that it is loading it and jumping to the correct locale. Let do a quick look at your kernel code...based on the code, it should fill the screen up with 2s. I found this note:     http://wiki.osdev.org/ATA_in_x86_RealMode_%28BIOS%29 wrote: Note: Always remember that Sector is 1-based, and not 0-based ... this detail causes many problems. | |||
|  09 Feb 2015, 14:34 | 
 | 
| SheldonCompton 09 Feb 2015, 18:00 I changed the sector it's reading to 2, but got the same result.
 Code: DiskAddressPacket: db 0x10 ;size of packet db 0x0 ;reserved dw 0x1 ;number of blocks to transfer dw 0xA00 ;where in memory to write to dw 0x200 ;offset dq 0x2 ;starting block to read dd 0x0 | |||
|  09 Feb 2015, 18:00 | 
 | 
| smiddy 09 Feb 2015, 23:22 Yep, I loaded it on a 1 GB flash drive and on my machine it stopped after showing a 1 with the cursor just after. However, when I created a HDD with VirtualBox of the USB drive, and loaded it in VirtualBox it worked, showed 2s across the screen. So, in theory it works and as to why on the USB drive on a real machine is beyond me at the moment. There must be something perculaiar to an USB drive boot. | |||
|  09 Feb 2015, 23:22 | 
 | 
| smiddy 10 Feb 2015, 01:10 I don't have time right now to look at this further, but you might have to create a partition table the tells BIOS that you are emulating a HDD, because I suspect that the BIOS is floppy emulating the drive, also may need a BIOS Parameter Block too, in the book sector of the partition to load. In other words, talking absolute sectors, 1 = code to start, which holds a Master Boot Record (MBR), in the first MBR entry place it to point to absolute sector 2, where Bootloader goes, and in absolute sector 3, place the kernel code. Try that and see what happens. | |||
|  10 Feb 2015, 01:10 | 
 | 
| SheldonCompton 10 Feb 2015, 01:26 I'll have to try that.  As of right now though I put it on a spare hard drive, booted without using a vm, and I got '1E1E'. | |||
|  10 Feb 2015, 01:26 | 
 | 
| SheldonCompton 10 Feb 2015, 02:52 I got it to work booting from a usb without a vm.  I had to format it to fat16 first then write to it.  I'm not exactly sure why this works, but it does. | |||
|  10 Feb 2015, 02:52 | 
 | 
| SheldonCompton 10 Feb 2015, 12:52 I should probably give credit and say I found this information here: http://forum.osdev.org/viewtopic.php?f=13&t=19357 | |||
|  10 Feb 2015, 12:52 | 
 | 
| smiddy 10 Feb 2015, 15:19 Kewl! So, which emulation is being used? So, I have seen other boot sectors that they say have worked. In those I did notice that they will test for BIOS EDD, and if you don't have EDD, then you may need to use the standard disk read function under INT 13h (whatever it is). I use EDD for my CD-ROM bootable CD, although I also test it first. Too, what is in your DL? This will give you a clue as to your emulation. I will check mine later this evening once I get home from work. I need a flash drive boot sector so this is a good exercise for me. Although I will be using FAT 32 though, and loading an DOS MZ EXE as my OS kernel. I've done a FAT 12 FDD and CDFS, now it is time for flash (ala HDD style).
 Can you post your final code? | |||
|  10 Feb 2015, 15:19 | 
 | 
| SheldonCompton 11 Feb 2015, 01:35 Final Code:
 Code: org 7C00h ;;;;;;;;;;;;;;;;;; ;DO NOT MODIFY DL; ;;;;;;;;;;;;;;;;;; jmp start start: cli mov ax, 0x0200 ;start the stack after the bootloader mov ss, ax mov ax, 0xC00 ;make the stack 3k big later this will need to be changed and hardware detection added mov ax, sp ;but for now this will work. mov ax, ds sti mov ah, 0x0e mov al, '1' int 0x10 mov ah, 0x42 mov si, DiskAddressPacket int 0x13 jc error jmp 0xA00:0x0200 error: mov ah, 0x0e mov al, 'E' int 0x10 DiskAddressPacket: db 0x10 ;size of packet db 0x0 ;reserved dw 0x1 ;number of blocks to transfer dw 0xA00 ;where in memory to write to dw 0x200 ;offset dq 0x2 ;starting block to read dd 0x0 times 510-($-$$) db 0 ;Fill rest of sector up with 0s to make this 512B (a sector) dw 0xAA55 ;Let BIOS know this is an OS Kernel Code: jmp main main: cli mov ax, 0x9000 ;Set up stack mov ss, ax ;Tell processor where stack is mov sp, 0xFB00 ;Set stack offset sti mov al, '2' mov ah, 0x0e int 0x10 jmp main times 512-($-$$) db 0 Build script Code: cd /home/sheldon/Desktop/fasm ./fasm ../Git/ProgrammingClubGame/BootLoader0.03.asm ./fasm ../Git/ProgrammingClubGame/Kernel0.01.asm cd /home/sheldon/Desktop/Git/ProgrammingClubGame dd if=/home/sheldon/Desktop/Git/ProgrammingClubGame/BootLoader0.03.bin of=/dev/sdc obs=512 bs=512 count=1 dd if=/home/sheldon/Desktop/Git/ProgrammingClubGame/Kernel0.01.bin of=/dev/sdc obs=512 bs=512 count=1 rm /home/sheldon/Desktop/Git/ProgrammingClubGame/BootLoader0.03.bin rm /home/sheldon/Desktop/Git/ProgrammingClubGame/Kernel0.01.bin It's using HDD emulation, but soon I will have to write one for FDD since different bioses (Not sure what the plural of bios is) see usb drives differently. I believe that it won't work with FAT 32. I was using FAT 32 when it wasn't working and when I formated it to FAT 16 it did. | |||
|  11 Feb 2015, 01:35 | 
 | 
| smiddy 11 Feb 2015, 01:54 Thanks man, I'm swamped right now, but once I get the opportunity I'll put it to the test. | |||
|  11 Feb 2015, 01:54 | 
 | 
| SheldonCompton 12 Feb 2015, 04:22 Shamefully I have to admit I made a mistake.  The bootloader never worked.  I accidentally wrote the kernel to the MBR which I perceived as working. | |||
|  12 Feb 2015, 04:22 | 
 | 
| smiddy 12 Feb 2015, 14:11 So, we know that it loads absolute sector 1, but after that is a mystery.   | |||
|  12 Feb 2015, 14:11 | 
 | 
| Goto page 1, 2  Next < Last Thread | Next Thread > | 
| Forum Rules: 
 | 
Copyright © 1999-2025, Tomasz Grysztar. Also on GitHub, YouTube.
Website powered by rwasa.