1
0
mirror of https://github.com/cfenollosa/os-tutorial.git synced 2024-10-27 20:34:19 +00:00

bootsector print hello

This commit is contained in:
Carlos Fenollosa 2014-09-29 11:43:20 +02:00
parent 48d8e35912
commit 80ec5420e4
7 changed files with 69 additions and 4 deletions
01-bootsector-barebones
02-boot-sector-interrupts
02-bootsector-print
03-bootsector-memory

View File

@ -1,4 +0,0 @@
We will improve a bit on our infinite-loop boot sector and print
something on the screen. We will raise an interrupt for this.

View File

@ -0,0 +1,50 @@
*Concepts you may want to Google beforehand: interrupts, CPU
registers*
We will improve a bit on our infinite-loop boot sector and print
something on the screen. We will raise an interrupt for this.
On this example we are going to write each character of the "Hello"
word into the register `al` (lower part of `ax`), the bytes `0x0e`
into `ah` (the higher part of `ax`) and raise interrupt `0x10` which
tells the machine to print on screen the contents of `ax`.
`0x0e` on `ah` is necessary to indicate tty mode.
We will set tty mode only once though in the real world we
cannot be sure that the contents of `ah` are constant. Some other
process may run on the CPU while we are sleeping, not clean
up properly and leave garbage data on `ah`.
For this example we don't need to take care of that since we are
the only thing running on the CPU.
Our new boot sector looks like this:
```nasm
mov ah, 0x0e ; tty mode
mov al, 'H'
int 0x10
mov al, 'e'
int 0x10
mov al, 'l'
int 0x10
int 0x10 ; 'l' is still on al, remember?
mov al, 'o'
int 0x10
jmp $ ; jump to current address = infinite loop
; padding and magic number
times 510 - ($-$$) db 0
dw 0xaa55
```
You can examine the binary data with `xxd file.bin`
Anyway, you know the drill:
`nasm -fbin boot_sect_hello.asm -o boot_sect_hello.bin`
`qemu boot_sect_hello.bin`
Your boot sector will say 'Hello' and hang on an infinite loop

View File

@ -0,0 +1,16 @@
mov ah, 0x0e ; tty mode
mov al, 'H'
int 0x10
mov al, 'e'
int 0x10
mov al, 'l'
int 0x10
int 0x10 ; 'l' is still on al, remember?
mov al, 'o'
int 0x10
jmp $ ; jump to current address = infinite loop
; padding and magic number
times 510 - ($-$$) db 0
dw 0xaa55

View File

@ -0,0 +1,3 @@
TBD
Our new boot sector will refer to memory addresses and labels