2014-10-05 10:06:14 +00:00
|
|
|
mov ah, 0x0e ; tty mode
|
2014-10-05 10:03:44 +00:00
|
|
|
|
|
|
|
mov bp, 0x8000 ; this is an address far away from 0x7c00 so that we don't get overwritten
|
2014-10-05 10:06:14 +00:00
|
|
|
mov sp, bp ; if the stack is empty then sp points to bp
|
2014-10-05 10:03:44 +00:00
|
|
|
|
|
|
|
push 'A'
|
|
|
|
push 'B'
|
|
|
|
push 'C'
|
|
|
|
|
|
|
|
; to show how the stack grows downwards
|
|
|
|
mov al, [0x7ffe] ; 0x8000 - 2
|
2019-07-26 14:38:16 +00:00
|
|
|
int 0x10 ; prints A
|
|
|
|
|
|
|
|
mov al, [0x7ffc] ; 0x8000 - 4
|
|
|
|
int 0x10 ; prints B
|
|
|
|
|
|
|
|
mov al, [0x7ffa] ; 0x8000 - 6
|
|
|
|
int 0x10 ; prints C
|
2014-10-05 10:03:44 +00:00
|
|
|
|
|
|
|
; however, don't try to access [0x8000] now, because it won't work
|
2019-07-26 14:38:16 +00:00
|
|
|
; 0x8000 is just the base address and doesn't contain anything
|
2014-10-05 10:03:44 +00:00
|
|
|
mov al, [0x8000]
|
|
|
|
int 0x10
|
|
|
|
|
|
|
|
|
|
|
|
; recover our characters using the standard procedure: 'pop'
|
|
|
|
; We can only pop full words so we need an auxiliary register to manipulate
|
|
|
|
; the lower byte
|
|
|
|
pop bx
|
|
|
|
mov al, bl
|
|
|
|
int 0x10 ; prints C
|
|
|
|
|
|
|
|
pop bx
|
|
|
|
mov al, bl
|
|
|
|
int 0x10 ; prints B
|
|
|
|
|
|
|
|
pop bx
|
|
|
|
mov al, bl
|
|
|
|
int 0x10 ; prints A
|
|
|
|
|
|
|
|
|
|
|
|
jmp $
|
|
|
|
times 510-($-$$) db 0
|
|
|
|
dw 0xaa55
|