org 7c00h
bits 16
-data_start equ 7e00h
-nticks equ data_start
-tmoffs equ nticks + 4
-muscur equ tmoffs + 4
-spkstat equ muscur + 4
-vol equ spkstat + 4
-data_end equ vol + 4
-
-OSC_FREQ equ 1193182
-PIT_DATA0 equ 40h
-PIT_CMD equ 43h
-PIT_CMD_CHAN0 equ 00h
-PIT_CMD_HILO equ 30h
-PIT_CMD_SQWAVE equ 06h
-KB_CTRL equ 61h
-
-%define DIV_ROUND(a, b) ((a) / (b) + ((a) % (b)) / ((b) / 2))
-
-%macro setcursor 2
- mov dl, %1
- mov dh, %2
+nticks equ 7e00h
+tmoffs equ 7e04h
+muscur equ 7e08h
+
+%macro setcur 2
+ mov dx, %1 | (%2 << 8)
xor bx, bx
mov ah, 2
int 10h
%endmacro
%macro spkon 0
- in al, KB_CTRL
+ in al, 61h
or al, 3
- out KB_CTRL, al
+ out 61h, al
%endmacro
%macro spkoff 0
- in al, KB_CTRL
+ in al, 61h
and al, 0fch
- out KB_CTRL, al
+ out 61h, al
%endmacro
-%macro settimer 2
- mov al, (PIT_CMD_CHAN0 + (%1 << 6)) | PIT_CMD_HILO | PIT_CMD_SQWAVE
- out PIT_CMD, al
+%macro stimer 2
+ mov al, (%1 << 6) | 36h
+ out 43h, al
mov ax, %2
- out PIT_DATA0 + %1, al
+ out 40h + %1, al
mov al, ah
- out PIT_DATA0 + %1, al
+ out 40h + %1, al
%endmacro
- xor eax, eax
+start: xor ax, ax
mov ds, ax
mov es, ax
mov ss, ax
mov sp, 7c00h
- mov di, data_start
- mov cx, (data_end - data_start) / 2
+ mov di, nticks
+ mov cx, 6
rep stosw
- ;mov word [vol], 04h
- mov word [32], timer_intr
- mov word [34], 0
+ mov word [32], tintr
+ mov [34], ax
- settimer 0, DIV_ROUND(OSC_FREQ, 100)
+ stimer 0, 5966
mov ax, 13h
int 10h
- mov ax, 0a000h
- mov es, ax
+ push 1000h
+ pop es
- mov ax, 0303h
- mov cx, 32000
+ sti
+
+mainloop:
+ call drawbg
+
+ push ds
+ push es
+ push es
+ pop ds
+ push 0a000h
+ pop es
xor di, di
- rep stosw
+ xor si, si
+ mov cx, 32000
+
+ mov dx, 3dah
+.invb: in al, dx
+ and al, 8
+ jnz .invb
+.novb: in al, dx
+ and al, 8
+ jz .novb
- setcursor 10, 12
+ rep movsw
+ pop es
+ pop ds
+
+ setcur 10, 0
mov si, str1
call textout
- setcursor 12, 13
+ setcur 12, 1
mov si, str2
call textout
- sti
+ jmp mainloop
+
+drawbg:
+ mov bx, 200
+ mov di, 5120
+.fillgrad:
+ mov ax, bx
+ mov ah, al
+ mov cx, 2400 ; 15 lines
+ rep stosw
+ inc bx
+ cmp bx, 208
+ jnz .fillgrad
+
+ ; mountains
+ mov cx, 320
+ mov bp, sp
+.mnt: mov [bp - 2], cx
+ fild word [bp - 2]
+ fidiv word [w30]
+ fsincos
+ fiadd word [w5]
+ fimul word [w5]
+ fistp word [bp - 2]
+ fstp st0
+ mov bx, [bp - 2]
+ add bx, 100
+ imul bx, bx, 320
+ add bx, cx
+.mntcol:
+ mov byte [es:bx], 0
+ add bx, 320
+ cmp bx, 64000
+ jb .mntcol
+
+ dec cx
+ jnz .mnt
+
+ ret
-infloop:
- hlt
- jmp infloop
textout:
mov al, [si]
and al, al
jz .done
mov ah, 0eh
- mov bx, 0fh
+ mov bx, 82
int 10h
inc si
jmp textout
.done: ret
-timer_intr:
+tintr:
pusha
+ push ds
+ push word 0
+ pop ds
mov ax, [nticks]
inc ax
mov [nticks], ax
sub ax, [tmoffs]
.pmus: mov bx, [muscur]
shl bx, 2
- mov cx, [music + bx] ; event time
+ mov cx, [music + bx]
cmp cx, 0ffffh
jz .loop
cmp ax, cx
- jb .dopwm
+ jb .eoi
- inc dword [muscur]
- mov ax, [music + 2 + bx] ; event counter reload
+ inc word [muscur]
+ mov ax, [music + 2 + bx]
test ax, ax
jz .off
mov bx, ax
- settimer 2, bx
+ stimer 2, bx
spkon
- mov word [spkstat], 1
- jmp .dopwm
-
-.off: spkoff
- mov word [spkstat], 0
jmp .eoi
- ; PWM for volume control
-.dopwm: jmp .eoi
- spkoff
- mov ax, [spkstat]
- test ax, ax
- jz .eoi
- mov ax, [nticks]
- and ax, 0fh
- cmp ax, [vol]
- jae .pwmoff
- spkon
- jmp .eoi
-.pwmoff:
- spkoff
+.off: spkoff
.eoi: mov al, 20h
- out 20h, al ; EOI
+ out 20h, al
+ pop ds
popa
iret
jmp .pmus
-str1: db 'message message blah',0
-str2: db 'Michael & Athina',0
-
-G1 equ 24351
-C2 equ 18243
-D2 equ 16252
-B1 equ 19328
-F2 equ 13666
-E2 equ 14479
-
-%define TM(x) (40 + (x) * 2)
-
-music: dw 0, 0
- dw TM(0), G1
- dw TM(40), C2
- dw TM(70), C2
-
- dw TM(80), C2
- dw TM(140), 0
-
- dw TM(160), G1
- dw TM(200), D2
- dw TM(230), B1
-
- dw TM(240), C2
- dw TM(300), 0
-
- dw TM(320), G1
- dw TM(360), C2
- dw TM(390), F2
-
- dw TM(400), F2
- dw TM(440), E2
- dw TM(470), D2
-
- dw TM(480), C2
- dw TM(520), B1
- dw TM(550), C2
-
- dw TM(560), D2
- dw TM(640), 0
-
- dw TM(680), 0
- dw 0ffffh, 0
+str1: db 'message blah',0
+str2: db 'Michael & Athena',0
+
+G2 equ 12175
+C3 equ 9121
+D3 equ 8126
+B2 equ 9664
+F3 equ 6833
+E3 equ 7239
+
+music: dw 0, 0
+ dw 40, G2
+ dw 200, C3
+ dw 320, C3
+ dw 360, C3
+ dw 600, 0
+ dw 680, G2
+ dw 840, D3
+ dw 960, B2
+ dw 1000, C3
+ dw 1240, 0
+ dw 1320, G2
+ dw 1480, C3
+ dw 1600, F3
+ dw 1640, F3
+ dw 1800, E3
+ dw 1920, D3
+ dw 1960, C3
+ dw 2120, B2
+ dw 2240, C3
+ dw 2280, D3
+ dw 2600, 0
+ dw 2760, 0
+ dw 0ffffh, 0
+
+w5: dw 5
+w30: dw 30
times 446-($-$$) db 0
dd 00212080h
dd 0820280ch
dd 00000800h
dd 0001f800h
+
times 510-($-$$) db 0
dw 0aa55h