VirtualBox

source: vbox/trunk/src/VBox/Devices/PC/BIOS-new/orgs.asm@ 41084

Last change on this file since 41084 was 41084, checked in by vboxsync, 13 years ago

Put together a kBuild makefile for the new BIOS code. No idea if the output works.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 35.7 KB
Line 
1;;
2;; Copyright (C) 2006-2011 Oracle Corporation
3;;
4;; This file is part of VirtualBox Open Source Edition (OSE), as
5;; available from http://www.virtualbox.org. This file is free software;
6;; you can redistribute it and/or modify it under the terms of the GNU
7;; General Public License (GPL) as published by the Free Software
8;; Foundation, in version 2 as it comes in the "COPYING" file of the
9;; VirtualBox OSE distribution. VirtualBox OSE is distributed in the
10;; hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
11;; --------------------------------------------------------------------
12;;
13;; This code is based on:
14;;
15;; ROM BIOS for use with Bochs/Plex86/QEMU emulation environment
16;;
17;; Copyright (C) 2002 MandrakeSoft S.A.
18;;
19;; MandrakeSoft S.A.
20;; 43, rue d'Aboukir
21;; 75002 Paris - France
22;; http://www.linux-mandrake.com/
23;; http://www.mandrakesoft.com/
24;;
25;; This library is free software; you can redistribute it and/or
26;; modify it under the terms of the GNU Lesser General Public
27;; License as published by the Free Software Foundation; either
28;; version 2 of the License, or (at your option) any later version.
29;;
30;; This library is distributed in the hope that it will be useful,
31;; but WITHOUT ANY WARRANTY; without even the implied warranty of
32;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
33;; Lesser General Public License for more details.
34;;
35;; You should have received a copy of the GNU Lesser General Public
36;; License along with this library; if not, write to the Free Software
37;; Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
38;;
39;;
40
41
42EBDA_SEG equ 09FC0h ; starts at 639K
43EBDA_SIZE equ 1 ; 1K
44BASE_MEM_IN_K equ (640 - EBDA_SIZE)
45
46CMOS_ADDR equ 070h
47CMOS_DATA equ 071h
48
49
50PIC_CMD_EOI equ 020h
51PIC_MASTER equ 020h
52PIC_SLAVE equ 0A0h
53
54BIOS_FIX_BASE equ 0E000h
55
56SYS_MODEL_ID equ 0FCh ; PC/AT
57SYS_SUBMODEL_ID equ 0
58BIOS_REVISION equ 1
59
60BIOS_BUILD_DATE equ '06/23/99'
61BIOS_COPYRIGHT equ 'Oracle VM VirtualBox BIOS'
62
63;BX_PCIBIOS equ 1 ; defined in pcicfg.inc
64BX_ROMBIOS32 equ 0
65BX_CALL_INT15_4F equ 1
66
67;; Set a fixed BIOS location, with a marker for verification
68BIOSORG macro addr
69 org addr - BIOS_FIX_BASE - 2
70 db 'XM'
71 endm
72
73;; Set an interrupt vector (not very efficient if multiple vectors are
74;; programmed in one go)
75SET_INT_VECTOR macro vec, segm, offs
76 mov ax, offs
77 mov ds:[vec*4], ax
78 mov ax, segm
79 mov ds:[vec*4+2], ax
80endm
81
82; Set up an environment C code expects. DS must point to the BIOS segment
83; and the direction flag must be cleared(!)
84C_SETUP macro
85 push cs
86 pop ds
87 cld
88endm
89
90;; External function in separate modules
91extrn _dummy_isr_function:near
92extrn _log_bios_start:near
93extrn _nmi_handler_msg:near
94extrn _int18_panic_msg:near
95extrn _int09_function:near
96extrn _int13_diskette_function:near
97extrn _int13_eltorito:near
98extrn _int13_cdemu:near
99extrn _int13_cdrom:near
100extrn _cdemu_isactive:near
101extrn _cdemu_emulated_drive:near
102extrn _int13_harddisk:near
103extrn _int13_harddisk_ext:near
104extrn _int14_function:near
105extrn _int15_function:near
106extrn _int15_function_mouse:near
107extrn _int15_function32:near
108extrn _int16_function:near
109extrn _int17_function:near
110extrn _int19_function:near
111extrn _int1a_function:near
112extrn _int1a_function_pci:near
113extrn _int70_function:near
114extrn _int74_function:near
115extrn _ata_init:near
116extrn _ahci_init:near
117extrn _scsi_init:near
118extrn _ata_detect:near
119extrn _cdemu_init:near
120extrn _keyboard_init:near
121extrn _print_bios_banner:near
122
123
124;; Symbols referenced from C code
125public _diskette_param_table
126public _pmode_IDT
127public _rmode_IDT
128public post
129public eoi_both_pics
130public rtc_post
131
132;; Additional publics for easier disassembly and debugging
133ifndef DEBUG
134 DEBUG equ 1
135endif
136ifdef DEBUG
137
138public int08_handler
139public int0e_handler
140public int11_handler
141public int12_handler
142public int13_handler
143public int13_relocated
144public int15_handler
145public int17_handler
146public int19_handler
147public int19_relocated
148public dummy_iret
149public nmi
150public rom_fdpt
151public cpu_reset
152public normal_post
153public eoi_jmp_post
154public eoi_master_pic
155public ebda_post
156public hard_drive_post
157public int13_legacy
158public int70_handler
159public int75_handler
160public int15_handler32
161public int15_handler_mouse
162public iret_modify_cf
163public rom_scan
164public rom_checksum
165public init_pic
166public floppy_post
167public int13_out
168public int13_disk
169public int13_notfloppy
170public int13_legacy
171public int13_noeltorito
172public int1c_handler
173public int10_handler
174public int74_handler
175public int76_handler
176public detect_parport
177public detect_serial
178public font8x8
179
180endif
181
182;; NOTE: The last 8K of the ROM BIOS are peppered with fixed locations which
183;; must be retained for compatibility. As a consequence, some of the space is
184;; going to be wasted, but the gaps should be filled with miscellaneous code
185;; and data when possible.
186
187.286p
188
189BIOSSEG segment 'CODE'
190 assume cs:BIOSSEG
191
192;;
193;; Start of fixed code - eoi_jmp_post is kept here to allow short jumps.
194;;
195 BIOSORG 0E030h
196eoi_jmp_post:
197 call eoi_both_pics
198 xor ax, ax
199 mov ds, ax
200 jmp dword ptr ds:[0467h]
201
202eoi_both_pics:
203 mov al, PIC_CMD_EOI
204 out PIC_SLAVE, al
205eoi_master_pic:
206 mov al, PIC_CMD_EOI
207 out PIC_MASTER, al
208 ret
209
210;; --------------------------------------------------------
211;; POST entry point
212;; --------------------------------------------------------
213 BIOSORG 0E05Bh
214post:
215 xor ax, ax
216
217 ;; reset the DMA controllers
218 out 00Dh, al
219 out 0DAh, al
220
221 ;; then initialize the DMA controllers
222 mov al, 0C0h
223 out 0D6h, al ; enable channel 4 cascade
224 mov al, 0
225 out 0D4h, al ; unmask channel 4
226
227 ;; read the CMOS shutdown status
228 mov al, 0Fh
229 out CMOS_ADDR, al
230 in al, CMOS_DATA
231
232 ;; save status
233 mov bl, al
234
235 ;; reset the shutdown status in CMOS
236 mov al, 0Fh
237 out CMOS_ADDR, al
238 mov al, 0
239 out CMOS_DATA, al
240
241 ;; examine the shutdown status code
242 mov al, bl
243 cmp al, 0
244 jz normal_post
245 cmp al, 0Dh
246 jae normal_post
247 cmp al, 9
248 je normal_post ;; TODO: really?!
249
250 ;; 05h = EOI + jump through 40:67
251 cmp al, 5
252 je eoi_jmp_post
253
254 ;; any other shutdown status values are ignored
255 ;; OpenSolaris sets the status to 0Ah in some cases?
256; jmp normal_post
257
258normal_post:
259 ;; shutdown code 0: normal startup
260 cli
261 ;; Set up the stack top at 0:7800h. The stack should not be
262 ;; located above 0:7C00h; that conflicts with PXE, which
263 ;; considers anything above that address to be fair game.
264 ;; The traditional locations are 30:100 (PC) or 0:400 (PC/AT).
265 mov ax, 7800h
266 mov sp, ax
267 xor ax, ax
268 mov ds, ax
269 mov ss, ax
270
271 ;; clear the bottom of memory except for the word at 40:72
272 ;; TODO: Why not clear all of it? What's the point?
273 mov es, ax
274 xor di, di
275 cld
276 mov cx, 0472h / 2
277 rep stosw
278 inc di
279 inc di
280 mov cx, (1000h - 0472h - 2) / 2
281 rep stosw
282
283 ;; clear the remaining base memory except for the top
284 ;; of the EBDA (the MP table is planted there)
285 xor bx, bx
286memory_zero_loop:
287 add bx, 1000h
288 cmp bx, 9000h
289 jae memory_cleared
290 mov es, bx
291 xor di, di
292 mov cx, 8000h ; 32K words
293 rep stosw
294 jmp memory_zero_loop
295memory_cleared:
296 mov es, bx
297 xor di, di
298 mov cx, 7E00h ; all but the last 1K
299 rep stosw
300 xor bx, bx
301
302
303 C_SETUP
304 call _log_bios_start
305
306 call pmode_setup
307
308 ;; set all interrupts to default handler
309 xor bx, bx
310 mov ds, bx
311 mov cx, 78h ; leave the rest as zeros
312 mov ax, dummy_iret
313 mov dx, BIOSSEG
314
315post_default_ints:
316 mov [bx], ax
317 mov [bx+2], dx
318 add bx, 4
319 loop post_default_ints
320
321 ;; set vector 79h to zero
322 ;; this is used by 'guardian angel' protection system
323 ;; TODO: Really? Why?
324
325 ;; base memory in K to 40:13
326 mov ax, BASE_MEM_IN_K
327 mov ds:[413h], ax
328
329 ;; manufacturing test at 40:12
330 ;; zeroed out above
331
332 ;; set up various service vectors
333 ;; TODO: This should use the table at FEF3h instead
334 SET_INT_VECTOR 11h, BIOSSEG, int11_handler
335 SET_INT_VECTOR 12h, BIOSSEG, int12_handler
336 SET_INT_VECTOR 15h, BIOSSEG, int15_handler
337 SET_INT_VECTOR 17h, BIOSSEG, int17_handler
338 SET_INT_VECTOR 18h, BIOSSEG, int18_handler
339 SET_INT_VECTOR 19h, BIOSSEG, int19_handler
340 SET_INT_VECTOR 1Ch, BIOSSEG, int1c_handler
341
342 call ebda_post
343
344 ;; PIT setup
345 SET_INT_VECTOR 08h, BIOSSEG, int08_handler
346 mov al, 34h ; timer 0, binary, 16-bit, mode 2
347 out 43h, al
348 mov al, 0 ; max count -> ~18.2 Hz
349 out 40h, al
350 out 40h, al
351
352 ;; keyboard setup
353 SET_INT_VECTOR 09h, BIOSSEG, int09_handler
354 SET_INT_VECTOR 16h, BIOSSEG, int16_handler
355
356 xor ax, ax
357 mov ds, ax
358 ;; TODO: What's the point? The BDA is zeroed already?!
359 mov ds:[417h], al ; keyboard shift flags, set 1
360 mov ds:[418h], al ; keyboard shift flags, set 2
361 mov ds:[419h], al ; keyboard Alt-numpad work area
362 mov ds:[471h], al ; keyboard Ctrl-Break flag
363 mov ds:[497h], al ; keyboard status flags 4
364 mov al, 10h
365 mov ds:[496h], al ; keyboard status flags 3
366
367 mov bx, 1Eh
368 mov ds:[41Ah], bx ; keyboard buffer head
369 mov ds:[41Ch], bx ; keyboard buffer tail
370 mov ds:[480h], bx ; keyboard buffer start
371 mov bx, 3Eh
372 mov ds:[482h], bx ; keyboard buffer end
373
374 push ds
375 C_SETUP
376 call _keyboard_init
377 pop ds
378
379
380 ;; store CMOS equipment byte in BDA
381 mov al, 14h
382 out CMOS_ADDR, al
383 in al, CMOS_DATA
384 mov ds:[410h], al
385
386 ;; parallel setup
387 SET_INT_VECTOR 0Fh, BIOSSEG, dummy_iret
388 xor ax, ax
389 mov ds, ax
390 xor bx, bx
391 mov cl, 14h ; timeout value
392 mov dx, 378h ; parallel port 1
393 call detect_parport
394 mov dx, 278h ; parallel port 2
395 call detect_parport
396 shl bx, 0Eh
397 mov ax, ds:[410h] ; equipment word
398 and ax, 3FFFh
399 or ax, bx ; set number of parallel ports
400 mov ds:[410h], ax ; store in BDA
401
402 ;; Serial setup
403 SET_INT_VECTOR 0Bh, BIOSSEG, dummy_isr
404 SET_INT_VECTOR 0Ch, BIOSSEG, dummy_isr
405 SET_INT_VECTOR 14h, BIOSSEG, int14_handler
406 xor bx, bx
407 mov cl, 0Ah ; timeout value
408 mov dx, 3F8h ; first serial address
409 call detect_serial
410 mov dx, 2F8h ; second serial address
411 call detect_serial
412 mov dx, 3E8h ; third serial address
413 call detect_serial
414 mov dx, 2E8h ; fourth serial address
415 call detect_serial
416 shl bx, 9
417 mov ax, ds:[410h] ; equipment word
418 and ax, 0F1FFh ; bits 9-11 determine serial ports
419 or ax, bx
420 mov ds:[410h], ax
421
422 ;; CMOS RTC
423 SET_INT_VECTOR 1Ah, BIOSSEG, int1a_handler
424 SET_INT_VECTOR 4Ah, BIOSSEG, dummy_iret ; TODO: redundant?
425 SET_INT_VECTOR 70h, BIOSSEG, int70_handler
426 ;; BIOS DATA AREA 4CEh ???
427 call rtc_post
428
429 ;; PS/2 mouse setup
430 SET_INT_VECTOR 74h, BIOSSEG, int74_handler
431
432 ;; IRQ 13h (FPU exception) setup
433 SET_INT_VECTOR 75h, BIOSSEG, int75_handler
434
435 ;; Video setup
436 SET_INT_VECTOR 10h, BIOSSEG, int10_handler
437
438 call init_pic
439
440 call pcibios_init_iomem_bases
441 call pcibios_init_irqs
442
443 call rom_scan
444
445 C_SETUP
446 ;; ATA/ATAPI driver setup
447 call _ata_init
448 call _ata_detect
449
450ifdef VBOX_WITH_SCSI
451 ; SCSI driver setup
452 call _scsi_init
453endif
454
455ifdef VBOX_WITH_AHCI
456 ; AHCI driver setup
457 call _ahci_init
458endif
459
460 ;; floppy setup
461 call floppy_post
462
463 ;; hard drive setup
464 call hard_drive_post
465
466 C_SETUP ; in case assembly code changed things
467 call _print_bios_banner
468
469 ;; El Torito floppy/hard disk emulation
470 call _cdemu_init
471
472 ; TODO: what's the point of enabling interrupts here??
473 sti ; enable interrupts
474 int 19h
475 ;; does not return here
476 sti
477wait_forever:
478 hlt
479 jmp wait_forever
480 cli
481 hlt
482
483
484;; --------------------------------------------------------
485;; NMI handler
486;; --------------------------------------------------------
487 BIOSORG 0E2C3h
488nmi:
489 C_SETUP
490 call _nmi_handler_msg
491 iret
492
493int75_handler:
494 out 0F0h, al ; clear IRQ13
495 call eoi_both_pics
496 int 2 ; emulate legacy NMI
497 iret
498
499
500hard_drive_post proc near
501
502 ;; TODO Why? And what about secondary controllers?
503 mov al, 0Ah ; disable IRQ 14
504 mov dx, 03F6h
505 out dx, al
506
507 xor ax, ax
508 mov ds, ax
509 ;; TODO: Didn't we just clear the entire EBDA?
510 mov ds:[474h], al ; last HD operation status
511 mov ds:[477h], al ; HD port offset (XT only???)
512 mov ds:[48Ch], al ; HD status register
513 mov ds:[48Dh], al ; HD error register
514 mov ds:[48Eh], al ; HD task complete flag
515 mov al, 0C0h
516 mov ds:[476h], al ; HD control byte
517 ;; set up hard disk interrupt vectors
518 SET_INT_VECTOR 13h, BIOSSEG, int13_handler
519 SET_INT_VECTOR 76h, BIOSSEG, int76_handler
520 ;; INT 41h/46h: hard disk 0/1 dpt
521 ; TODO: This should be done from the code which
522 ; builds the DPTs?
523 SET_INT_VECTOR 41h, EBDA_SEG, 3Dh
524 SET_INT_VECTOR 46h, EBDA_SEG, 4Dh
525 ret
526
527hard_drive_post endp
528
529
530;; --------------------------------------------------------
531;; INT 13h handler - Disk services
532;; --------------------------------------------------------
533 BIOSORG 0E3FEh
534
535int13_handler:
536 jmp int13_relocated
537
538
539;; --------------------------------------------------------
540;; Fixed Disk Parameter Table
541;; --------------------------------------------------------
542;; BIOSORG 0E401h - fixed wrt preceding
543
544rom_fdpt:
545
546;; --------------------------------------------------------
547;; INT 19h handler - Boot load service
548;; --------------------------------------------------------
549 BIOSORG 0E6F2h
550
551int19_handler:
552 jmp int19_relocated
553
554
555
556;; --------------------------------------------------------
557;; System BIOS Configuration Table
558;; --------------------------------------------------------
559;; BIOSORG 0E6F5h - fixed wrt preceding
560; must match BIOS_CONFIG_TABLE
561bios_cfg_table:
562 dw 9 ; table size in bytes
563 db SYS_MODEL_ID
564 db SYS_SUBMODEL_ID
565 db BIOS_REVISION
566 ; Feature byte 1
567 ; b7: 1=DMA channel 3 used by hard disk
568 ; b6: 1=2 interrupt controllers present
569 ; b5: 1=RTC present
570 ; b4: 1=BIOS calls int 15h/4Fh for every key
571 ; b3: 1=wait for extern event supported (Int 15h/41h)
572 ; b2: 1=extended BIOS data area used
573 ; b1: 0=AT or ESDI bus, 1=MicroChannel
574 ; b0: 1=Dual bus (MicroChannel + ISA)
575ifdef BX_CALL_INT15_4F
576 db 74h; or USE_EBDA
577else
578 db 64h; or USE_EBDA
579endif
580 ; Feature byte 2
581 ; b7: 1=32-bit DMA supported
582 ; b6: 1=int16h, function 9 supported
583 ; b5: 1=int15h/C6h (get POS data) supported
584 ; b4: 1=int15h/C7h (get mem map info) supported
585 ; b3: 1=int15h/C8h (en/dis CPU) supported
586 ; b2: 1=non-8042 kb controller
587 ; b1: 1=data streaming supported
588 ; b0: reserved
589 db 40h
590 ; Feature byte 3
591 ; b7: not used
592 ; b6: reserved
593 ; b5: reserved
594 ; b4: POST supports ROM-to-RAM enable/disable
595 ; b3: SCSI on system board
596 ; b2: info panel installed
597 ; b1: Initial Machine Load (IML) system - BIOS on disk
598 ; b0: SCSI supported in IML
599 db 0
600 ; Feature byte 4
601 ; b7: IBM private
602 ; b6: EEPROM present
603 ; b5-3: ABIOS presence (011 = not supported)
604 ; b2: private
605 ; b1: memory split above 16Mb supported
606 ; b0: POSTEXT directly supported by POST
607 db 0
608 ; Feature byte 5 (IBM)
609 ; b1: enhanced mouse
610 ; b0: flash EPROM
611 db 0
612
613
614;; --------------------------------------------------------
615;; Baud Rate Generator Table
616;; --------------------------------------------------------
617 BIOSORG 0E729h
618
619
620;; --------------------------------------------------------
621;; INT 14h handler - Serial Communication Service
622;; --------------------------------------------------------
623 BIOSORG 0E739h
624int14_handler:
625 push ds
626 push es
627 pusha
628 C_SETUP
629 call _int14_function
630 popa
631 pop es
632 pop ds
633 iret
634
635
636
637;;
638;; Handler for unexpected hardware interrupts
639;;
640dummy_isr:
641 push ds
642 push es
643 pusha
644 C_SETUP
645 call _dummy_isr_function
646 popa
647 pop es
648 pop ds
649 iret
650
651
652rom_checksum proc near
653 push ax
654ifdef CHECKSUM_ROMS
655 push bx
656 push cx
657 xor ax, ax
658 xor bx, bx
659 xor cx, cx
660 mov ch, ds:[2]
661 shl cx, 1
662checksum_loop:
663 add al, [bx]
664 inc bx
665 loop checksum_loop
666 and al, 0FFh ; set flags
667 pop cx
668 pop bx
669else
670 xor al, al
671endif
672 pop ax
673 ret
674rom_checksum endp
675
676
677;;
678;; ROM scan - scan for valid ROMs and initialize them
679;;
680rom_scan:
681 mov cx, 0C000h ; start at C000
682rom_scan_loop:
683 mov ds, cx
684 mov ax, 4 ; scan in 2K increments
685 cmp word ptr ds:[0], 0AA55h ; look for signature
686 jne rom_scan_increment
687
688 call rom_checksum
689 jnz rom_scan_increment
690
691 mov al, ds:[2] ; set increment to ROM length
692 test al, 3
693 jz block_count_rounded
694
695 and al, 0FCh ; round up
696 add al, 4 ; to nearest 2K
697block_count_rounded:
698 xor bx, bx
699 mov ds, bx
700 push ax
701 push cx ; push segment...
702 push 3 ; ...and offset of ROM entry
703 mov bp, sp
704 call dword ptr [bp] ; call ROM init routine
705 cli ; in case ROM enabled interrupts
706 add sp, 2 ; get rid of offset
707 pop cx ; restore registers
708 pop ax
709rom_scan_increment:
710 shl ax, 5 ; convert to 16-byte increments
711 add cx, ax
712 cmp cx, 0E800h ; must encompass VBOX_LANBOOT_SEG!
713 jbe rom_scan_loop
714
715 xor ax, ax ; DS back to zero
716 mov ds, ax
717 ret
718
719init_pic proc near
720
721 mov al, 11h ; send init commands
722 out PIC_MASTER, al
723 out PIC_SLAVE, al
724 mov al, 08h ; base 08h
725 out PIC_MASTER+1, al
726 mov al, 70h ; base 70h
727 out PIC_SLAVE+1, al
728 mov al, 04h ; master PIC
729 out PIC_MASTER+1, al
730 mov al, 02h ; slave PIC
731 out PIC_SLAVE+1, al
732 mov al, 01h
733 out PIC_MASTER+1, al
734 out PIC_SLAVE+1, al
735 mov al, 0B8h ; unmask IRQs 0/1/2/6
736 out PIC_MASTER+1, al
737 mov al, 08Fh
738 out PIC_SLAVE+1, al ; unmask IRQs 12/13/14
739 ret
740
741init_pic endp
742
743ebda_post proc near
744
745 SET_INT_VECTOR 0Dh, BIOSSEG, dummy_isr ; IRQ 5
746 SET_INT_VECTOR 0Fh, BIOSSEG, dummy_isr ; IRQ 7
747 SET_INT_VECTOR 72h, BIOSSEG, dummy_isr ; IRQ 11
748 SET_INT_VECTOR 77h, BIOSSEG, dummy_isr ; IRQ 15
749
750 mov ax, EBDA_SEG
751 mov ds, ax
752 mov byte ptr ds:[0], EBDA_SIZE
753 ;; store EBDA seg in 40:0E
754 xor ax, ax
755 mov ds, ax
756 mov word ptr ds:[40Eh], EBDA_SEG
757 ret
758
759ebda_post endp
760
761
762
763;; --------------------------------------------------------
764;; INT 16h handler - Keyboard service
765;; --------------------------------------------------------
766 BIOSORG 0E82Eh
767int16_handler:
768 sti
769 push es
770 push ds
771 pusha
772
773 cmp ah, 0
774 je int16_F00
775
776 cmp ah, 10h
777 je int16_F00
778
779 C_SETUP
780 call _int16_function
781 popa
782 pop ds
783 pop es
784 iret
785
786int16_F00:
787 mov bx, 40h ; TODO: why 40h here and 0 elsewhere?
788 mov ds, bx
789int16_wait_for_key:
790 cli
791 mov bx, ds:[1Ah]
792 cmp bx, ds:[1Ch]
793 jne int16_key_found
794 sti
795 nop
796; TODO: review/enable?
797if 0
798 push ax
799 mov ax, 9002h
800 int 15h
801 pop ax
802endif
803 jmp int16_wait_for_key
804
805int16_key_found:
806 C_SETUP
807 call _int16_function
808 popa
809 pop ds
810 pop es
811; TODO: review/enable? If so, flags should be restored here?
812if 0
813 push ax
814 mov ax, 9202h
815 int 15h
816 pop ax
817endif
818 iret
819
820
821;; Quick and dirty protected mode entry/exit routines
822include pmode.inc
823
824;; Initialization code which needs to run in protected mode (LAPIC etc.)
825include pmsetup.inc
826
827
828KBDC_DISABLE EQU 0ADh
829KBDC_ENABLE EQU 0AEh
830KBC_CMD EQU 64h
831KBC_DATA EQU 60h
832
833;; --------------------------------------------------------
834;; INT 09h handler - Keyboard ISR (IRQ 1)
835;; --------------------------------------------------------
836 BIOSORG 0E987h
837int09_handler:
838 cli ; TODO: why? they're off already!
839 push ax
840 mov al, KBDC_DISABLE
841 out KBC_CMD, al
842
843 mov al, 0Bh
844 out PIC_MASTER, al
845 in al, PIC_MASTER
846 and al, 2
847 jz int09_finish
848
849 in al, KBC_DATA
850 push ds
851 pusha
852 cld ; Before INT 15h (and any C code)
853ifdef BX_CALL_INT15_4F
854 mov ah, 4Fh
855 stc
856 int 15h ; keyboard intercept
857 jnc int09_done
858endif
859 sti ; Only after calling INT 15h
860
861 ;; check for extended key
862 cmp al, 0E0h
863 jne int09_check_pause
864 xor ax, ax
865 mov ds, ax
866 mov al, ds:[496h] ; mf2_state |= 0x02
867 or al, 2 ; TODO: why not RMW?
868 mov ds:[496h], al
869 jmp int09_done
870
871int09_check_pause:
872 cmp al, 0E1h ; pause key?
873 jne int09_process_key
874 xor ax, ax
875 mov ds, ax ; TODO: haven't we just done that??
876 mov al, ds:[496h]
877 or al, 1
878 mov ds:[496h], al ; TODO: why not RMW?
879 jmp int09_done
880
881int09_process_key:
882 push es
883 C_SETUP
884 call _int09_function
885 pop es
886
887int09_done:
888 popa
889 pop ds
890 cli
891 call eoi_master_pic
892
893int09_finish:
894 mov al, KBDC_ENABLE
895 out KBC_CMD, al
896 pop ax
897 iret
898
899
900;; --------------------------------------------------------
901;; INT 13h handler - Diskette service
902;; --------------------------------------------------------
903 BIOSORG 0EC59h
904int13_diskette:
905 jmp int13_noeltorito
906
907
908
909;; --------------------------------------------------------
910;; INT 13h handler - Disk service
911;; --------------------------------------------------------
912int13_relocated:
913 ;; check for an El-Torito function
914 cmp ah, 4Ah
915 jb int13_not_eltorito
916
917 cmp ah, 4Dh
918 ja int13_not_eltorito
919
920 pusha
921 push es
922 push ds
923 C_SETUP ; TODO: setup C envrionment only once?
924 push int13_out ; simulate a call
925 jmp _int13_eltorito ; ELDX not used
926
927int13_not_eltorito:
928 push es
929 push ax ; TODO: better register save/restore
930 push bx
931 push cx
932 push dx
933
934 ;; check if emulation is active
935 call _cdemu_isactive
936 cmp al, 0
937 je int13_cdemu_inactive
938
939 ;; check if access to the emulated drive
940 call _cdemu_emulated_drive
941 pop dx ; recover dx (destroyed by C code)
942 push dx
943 cmp al, dl ; INT 13h on emulated drive
944 jne int13_nocdemu
945
946 pop dx
947 pop cx
948 pop bx
949 pop ax
950 pop es
951
952 pusha
953 push es
954 push ds
955 C_SETUP ; TODO: setup environment only once?
956
957 push int13_out ; simulate a call
958 jmp _int13_cdemu ; ELDX not used
959
960int13_nocdemu:
961 and dl, 0E0h ; mask to get device class
962 cmp al, dl
963 jne int13_cdemu_inactive
964
965 pop dx
966 pop cx
967 pop bx
968 pop ax
969 pop es
970
971 push ax
972 push cx
973 push dx
974 push bx
975
976 dec dl ; real drive is dl - 1
977 jmp int13_legacy
978
979int13_cdemu_inactive:
980 pop dx
981 pop cx
982 pop bx
983 pop ax
984 pop es
985
986int13_noeltorito:
987 push ax
988 push cx
989 push dx
990 push bx
991int13_legacy:
992 push dx ; push eltorito dx in place of sp
993 push bp
994 push si
995 push di
996 push es
997 push ds
998 C_SETUP ; TODO: setup environment only once?
999
1000 ;; now the registers can be restored with
1001 ;; pop ds; pop es; popa; iret
1002 test dl, 80h ; non-removable?
1003 jnz int13_notfloppy
1004
1005 push int13_out ; simulate a near call
1006 jmp _int13_diskette_function
1007
1008int13_notfloppy:
1009 cmp dl, 0E0h
1010 jb int13_notcdrom
1011
1012 ;; ebx may be modified, save here
1013 ;; TODO: check/review 32-bit register use
1014 .386
1015 shr ebx, 16
1016 push bx
1017 call _int13_cdrom
1018 pop bx
1019 shl ebx, 16
1020 .286
1021
1022 jmp int13_out
1023
1024int13_notcdrom:
1025int13_disk:
1026 cmp ah,40h
1027 ja int13x
1028 call _int13_harddisk
1029 jmp int13_out
1030
1031int13x:
1032 call _int13_harddisk_ext
1033
1034int13_out:
1035 pop ds
1036 pop es
1037 popa
1038 iret
1039
1040
1041
1042; parallel port detection: port in dx, index in bx, timeout in cl
1043detect_parport proc near
1044
1045 push dx
1046 inc dx
1047 inc dx
1048 in al, dx
1049 and al, 0DFh ; clear input mode
1050 out dx, al
1051 pop dx
1052 mov al, 0AAh
1053 out dx, al
1054 in al, dx
1055 cmp al, 0AAh
1056 jne no_parport
1057
1058 push bx
1059 shl bx, 1
1060 mov [bx+408h], dx ; parallel I/O address
1061 pop bx
1062 mov [bx+478h], cl ; parallel printer timeout
1063 inc bx
1064no_parport:
1065 ret
1066
1067detect_parport endp
1068
1069; setial port detection: port in dx, index in bx, timeout in cl
1070detect_serial proc near
1071
1072 push dx
1073 inc dx
1074 mov al, 2
1075 out dx, al
1076 in al, dx
1077 cmp al, 2
1078 jne no_serial
1079
1080 inc dx
1081 in al, dx
1082 cmp al, 2
1083 jne no_serial
1084
1085 dec dx
1086 xor al, al
1087 pop dx
1088 push bx
1089 shl bx, 1
1090 mov [bx+400h], dx ; serial I/O address
1091 pop bx
1092 mov [bx+47Ch], cl ; serial timeout
1093 inc bx
1094 ret
1095
1096no_serial:
1097 pop dx
1098 ret
1099
1100detect_serial endp
1101
1102
1103;;
1104;; POST: Floppy drive
1105;;
1106floppy_post proc near
1107
1108 xor ax, ax
1109 mov ds, ax
1110
1111 ;; TODO: This code is really stupid. Zeroing the BDA byte
1112 ;; by byte is dumb, and it's been already zeroed elsewhere!
1113 mov al, 0
1114 mov ds:[43Eh], al ; drive 0/1 uncalibrated, no IRQ
1115 mov ds:[43Fh], al ; motor status
1116 mov ds:[440h], al ; motor timeout counter
1117 mov ds:[441h], al ; controller status return code
1118 mov ds:[442h], al ; hd/floppy ctlr status register
1119 mov ds:[443h], al ; controller status register 1
1120 mov ds:[444h], al ; controller status register 2
1121 mov ds:[445h], al ; cylinder number
1122 mov ds:[446h], al ; head number
1123 mov ds:[447h], al ; sector number
1124 mov ds:[448h], al ; bytes written
1125
1126 mov ds:[48Bh], al ; configuration data
1127
1128 mov al, 10h ; floppy drive type
1129 out CMOS_ADDR, al
1130 in al, CMOS_DATA
1131 mov ah, al ; save drive type byte
1132
1133look_drive0:
1134 ; TODO: pre-init bl to reduce jumps
1135 shr al, 4 ; drive 0 in high nibble
1136 jz f0_missing ; jump if no drive
1137 mov bl, 7 ; drv0 determined, multi-rate, chgline
1138 jmp look_drive1
1139
1140f0_missing:
1141 mov bl, 0 ; no drive 0
1142
1143look_drive1:
1144 mov al, ah ; restore CMOS data
1145 and al, 0Fh ; drive 1 in low nibble
1146 jz f1_missing
1147 or bl, 70h ; drv1 determined, multi-rate, chgline
1148f1_missing:
1149 mov ds:[48Fh], bl ; store in BDA
1150
1151 ;; TODO: See above. Dumb *and* redundant!
1152 mov al, 0
1153 mov ds:[490h], al ; drv0 media state
1154 mov ds:[491h], al ; drv1 media state
1155 mov ds:[492h], al ; drv0 operational state
1156 mov ds:[493h], al ; drv1 operational state
1157 mov ds:[494h], al ; drv0 current cylinder
1158 mov ds:[495h], al ; drv1 current cylinder
1159
1160 mov al, 2
1161 out 0Ah, al ; unmask DMA channel 2
1162
1163 SET_INT_VECTOR 1Eh, BIOSSEG, _diskette_param_table
1164 SET_INT_VECTOR 40h, BIOSSEG, int13_diskette
1165 SET_INT_VECTOR 0Eh, BIOSSEG, int0e_handler ; IRQ 6
1166
1167 ret
1168
1169floppy_post endp
1170
1171
1172bcd_to_bin proc near
1173
1174 ;; in : AL in packed BCD format
1175 ;; out: AL in binary, AH always 0
1176 shl ax, 4
1177 shr al, 4
1178 aad
1179 ret
1180
1181bcd_to_bin endp
1182
1183rtc_post proc near
1184
1185 .386
1186 ;; get RTC seconds
1187 xor eax, eax
1188 mov al, 0
1189 out CMOS_ADDR, al
1190 in al, CMOS_DATA ; RTC seconds, in BCD
1191 call bcd_to_bin ; eax now has seconds in binary
1192 mov edx, 18206507
1193 mul edx
1194 mov ebx, 1000000
1195 xor edx, edx
1196 div ebx
1197 mov ecx, eax ; total ticks in ecx
1198
1199 ;; get RTC minutes
1200 xor eax, eax
1201 mov al, 2
1202 out CMOS_ADDR, al
1203 in al, CMOS_DATA ; RTC minutes, in BCD
1204 call bcd_to_bin ; eax now has minutes in binary
1205 mov edx, 10923904
1206 mul edx
1207 mov ebx, 10000
1208 xor edx, edx
1209 div ebx
1210 add ecx, eax ; add to total ticks
1211
1212 ;; get RTC hours
1213 xor eax, eax
1214 mov al, 4
1215 out CMOS_ADDR, al
1216 in al, CMOS_DATA ; RTC hours, in BCD
1217 call bcd_to_bin ; eax now has hours in binary
1218 mov edx, 65543427
1219 mul edx
1220 mov ebx, 1000
1221 xor edx, edx
1222 div ebx
1223 add ecx, eax ; add to total ticks
1224
1225 mov ds:[46Ch], ecx ; timer tick count
1226 xor al, al ; TODO: redundant?
1227 mov ds:[470h], al ; rollover flag
1228 .286
1229 ret
1230
1231rtc_post endp
1232
1233
1234
1235;; --------------------------------------------------------
1236;; INT 0Eh handler - Diskette IRQ 6 ISR
1237;; --------------------------------------------------------
1238 BIOSORG 0EF57h
1239int0e_handler:
1240 push ax
1241 push dx
1242 mov dx, 3F4h
1243 in al, dx
1244 and al, 0C0h
1245 cmp al, 0C0h
1246 je int0e_normal
1247 mov dx, 3F5h
1248 mov al, 08h ; sense interrupt
1249 out dx, al
1250int0e_loop1:
1251 mov dx, 3F4h ; TODO: move out of the loop?
1252 in al, dx
1253 and al, 0C0h
1254 cmp al, 0C0h
1255 jne int0e_loop1
1256
1257int0e_loop2:
1258 mov dx, 3F5h ; TODO: inc/dec dx instead
1259 in al, dx
1260 mov dx, 3F4h
1261 in al, dx
1262 and al, 0C0h
1263 cmp al, 0C0h
1264 je int0e_loop2
1265
1266int0e_normal:
1267 push ds
1268 xor ax, ax
1269 mov ds, ax
1270 call eoi_master_pic
1271 ; indicate that an interrupt occurred
1272 or byte ptr ds:[43Eh], 80h
1273 pop ds
1274 pop dx
1275 pop ax
1276 iret
1277
1278
1279;; --------------------------------------------------------
1280;; Diskette Parameter Table
1281;; --------------------------------------------------------
1282 BIOSORG 0EFC7h
1283_diskette_param_table:
1284 db 0AFh
1285 db 2 ; HLT=1, DMA mode
1286 db 025h
1287 db 2
1288 db 18 ; SPT (good for 1.44MB media)
1289 db 01Bh
1290 db 0FFh
1291 db 06Ch
1292 db 0F6h ; format filler
1293 db 15
1294 db 8
1295
1296
1297
1298;; --------------------------------------------------------
1299;; INT 17h handler - Printer service
1300;; --------------------------------------------------------
1301;; BIOSORG 0EFD2h - fixed WRT preceding code
1302int17_handler:
1303 push ds
1304 push es
1305 pusha
1306 C_SETUP
1307 call _int17_function
1308 popa
1309 pop es
1310 pop ds
1311 iret
1312
1313
1314
1315;; Protected mode IDT descriptor
1316;;
1317;; The limit is 0 to cause a shutdown if an exception occurs
1318;; in protected mode. TODO: Is that what we really want?
1319;;
1320;; Set base to F0000 to correspond to beginning of BIOS,
1321;; in case an IDT is defined later.
1322
1323_pmode_IDT:
1324 dw 0 ; limit 15:0
1325 dw 0 ; base 15:0
1326 dw 0Fh ; base 23:16
1327
1328
1329;; Real mode IDT descriptor
1330;;
1331;; Set to typical real-mode values.
1332;; base = 000000
1333;; limit = 03ff
1334
1335_rmode_IDT:
1336 dw 3FFh ; limit 15:00
1337 dw 0 ; base 15:00
1338 dw 0 ; base 23:16
1339
1340
1341;;
1342;; INT 1Ch
1343;;
1344;; TODO: Why does this need a special handler?
1345int1c_handler: ;; user timer tick
1346 iret
1347
1348
1349
1350;; --------------------------------------------------------
1351;; INT 10h functions 0-Fh entry point
1352;; --------------------------------------------------------
1353 BIOSORG 0F045h
1354i10f0f_entry:
1355 iret
1356
1357
1358;; --------------------------------------------------------
1359;; INT 10h handler - MDA/CGA video
1360;; --------------------------------------------------------
1361 BIOSORG 0F065h
1362int10_handler:
1363 ;; do nothing - assumes VGA
1364 iret
1365
1366
1367;; --------------------------------------------------------
1368;; MDA/CGA Video Parameter Table (INT 1Dh)
1369;; --------------------------------------------------------
1370 BIOSORG 0F0A4h
1371mdacga_vpt:
1372
1373
1374;;
1375;; INT 18h - boot failure
1376;;
1377int18_handler:
1378 C_SETUP
1379 call _int18_panic_msg
1380 ;; TODO: handle failure better?
1381 hlt
1382 iret
1383
1384;;
1385;; INT 19h - boot service - relocated
1386;;
1387int19_relocated:
1388; If an already booted OS calls int 0x19 to reboot, it is not sufficient
1389; just to try booting from the configured drives. All BIOS variables and
1390; interrupt vectors need to be reset, otherwise strange things may happen.
1391; The approach used is faking a warm reboot (which just skips showing the
1392; logo), which is a bit more than what we need, but hey, it's fast.
1393 mov bp, sp
1394 mov ax, [bp+2] ; TODO: redundant? address via sp?
1395 cmp ax, BIOSSEG ; check caller's segment
1396 jz bios_initiated_boot
1397
1398 xor ax, ax
1399 mov ds, ax
1400 mov ax, 1234h
1401 mov ds:[472], ax
1402 jmp post
1403
1404bios_initiated_boot:
1405 ;; The C worker function returns the boot drive in bl and
1406 ;; the boot segment in ax. In case of failure, the boot
1407 ;; segment will be zero.
1408 C_SETUP ; TODO: Here? Now?
1409 push bp
1410 mov bp, sp
1411
1412 ;; 1st boot device
1413 mov ax, 1
1414 push ax
1415 call _int19_function
1416 inc sp
1417 inc sp
1418 test ax, ax ; if 0, try next device
1419 jnz boot_setup
1420
1421 ;; 2nd boot device
1422 mov ax, 2
1423 push ax
1424 call _int19_function
1425 inc sp
1426 inc sp
1427 test ax, ax ; if 0, try next device
1428 jnz boot_setup
1429
1430 ; 3rd boot device
1431 mov ax, 3
1432 push 3
1433 call _int19_function
1434 inc sp
1435 inc sp
1436 test ax, ax ; if 0, try next device
1437 jnz boot_setup
1438
1439 ; 4th boot device
1440 mov ax, 4
1441 push ax
1442 call _int19_function
1443 inc sp
1444 inc sp
1445 test ax, ax ; if 0, invoke INT 18h
1446 jz int18_handler
1447
1448boot_setup:
1449; TODO: the drive should be in dl already??
1450;; mov dl, bl ; tell guest OS what boot drive is
1451 .386 ; NB: We're getting garbage into high eax bits
1452 shl eax, 4 ; convert seg to ip
1453 mov [bp+2], ax ; set ip
1454
1455 shr eax, 4 ; get cs back
1456 .286
1457 and ax, BIOSSEG ; remove what went in ip
1458 mov [bp+4], ax ; set cs
1459 xor ax, ax
1460 mov ds, ax
1461 mov es, ax
1462 mov [bp], ax ; TODO: what's this?!
1463 mov ax, 0AA55h ; set ok flag ; TODO: and this?
1464
1465 pop bp ; TODO: why'd we just zero it??
1466 iret ; beam me up scotty
1467
1468;; PCI BIOS
1469
1470include pcibios.inc
1471include pirq.inc
1472
1473
1474;; --------------------------------------------------------
1475;; INT 12h handler - Memory size
1476;; --------------------------------------------------------
1477 BIOSORG 0F841h
1478int12_handler:
1479 ;; Don't touch - fixed size!
1480 sti
1481 push ds
1482 mov ax, 40h
1483 mov ds, ax
1484 mov ax, ds:[13h]
1485 pop ds
1486 iret
1487
1488
1489;; --------------------------------------------------------
1490;; INT 11h handler - Equipment list service
1491;; --------------------------------------------------------
1492;; BIOSORG 0F84Dh - fixed wrt preceding code
1493int11_handler:
1494 ;; Don't touch - fixed size!
1495 sti
1496 push ds
1497 mov ax, 40h
1498 mov ds, ax
1499 mov ax, ds:[10h]
1500 pop ds
1501 iret
1502
1503
1504;; --------------------------------------------------------
1505;; INT 15h handler - System services
1506;; --------------------------------------------------------
1507;; BIOSORG 0F859h - fixed wrt preceding code
1508int15_handler:
1509 pushf
1510 cmp ah, 53h ; APM function?
1511 je apm_call
1512 push ds
1513 push es
1514 C_SETUP
1515 cmp ah, 86h
1516 je int15_handler32
1517 cmp ah, 0E8h
1518 je int15_handler32
1519 pusha
1520 cmp ah, 0C2h
1521 je int15_handler_mouse
1522
1523 call _int15_function
1524int15_handler_mouse_ret:
1525 popa
1526int15_handler32_ret:
1527 pop es
1528 pop ds
1529 popf
1530 jmp iret_modify_cf
1531
1532apm_call:
1533; TODO!!
1534 popf
1535 stc
1536 jmp iret_modify_cf
1537; jmp apmreal_entry
1538
1539int15_handler_mouse:
1540 call _int15_function_mouse
1541 jmp int15_handler_mouse_ret
1542
1543int15_handler32:
1544 ;; need to save/restore 32-bit registers
1545 .386
1546 pushad
1547 call _int15_function32
1548 popad
1549 .286
1550 jmp int15_handler32_ret
1551
1552;;
1553;; Perform an IRET but retain the current carry flag value
1554;;
1555iret_modify_cf:
1556 jc carry_set
1557 push bp
1558 mov bp, sp
1559 and byte ptr [bp + 6], 0FEh
1560 pop bp
1561 iret
1562carry_set:
1563 push bp
1564 mov bp, sp
1565 or byte ptr [bp + 6], 1
1566 pop bp
1567 iret
1568
1569;;
1570;; INT 74h handler - PS/2 mouse (IRQ 12)
1571;;
1572int74_handler proc
1573
1574 sti
1575 pusha
1576 push es
1577 push ds
1578 push 0 ; placeholder for status
1579 push 0 ; placeholder for X
1580 push 0 ; placeholder for Y
1581 push 0 ; placeholder for Z
1582 push 0 ; placeholder for make_far_call bool
1583 C_SETUP
1584 call _int74_function
1585 pop cx ; pop make_far_call flag
1586 jcxz int74_done
1587
1588 ;; make far call to EBDA:0022
1589 push 0
1590 pop ds
1591 push ds:[40Eh]
1592 pop ds
1593 call far ptr ds:[22h]
1594int74_done:
1595 cli
1596 call eoi_both_pics
1597 add sp, 8 ; remove status, X, Y, Z
1598 pop ds
1599 pop es
1600 popa
1601 iret
1602
1603int74_handler endp
1604
1605int76_handler proc
1606
1607 ;; record completion in BIOS task complete flag
1608 push ax
1609 push ds
1610 mov ax, 40h
1611 mov ds, ax
1612 mov byte ptr ds:[8Eh], 0FFh
1613 call eoi_both_pics
1614 pop ds
1615 pop ax
1616 iret
1617
1618int76_handler endp
1619
1620;; --------------------------------------------------------
1621;; 8x8 font (first 128 characters)
1622;; --------------------------------------------------------
1623 BIOSORG 0FA6Eh
1624include font8x8.inc
1625
1626
1627;; --------------------------------------------------------
1628;; INT 1Ah handler - Time of the day + PCI BIOS
1629;; --------------------------------------------------------
1630;; BIOSORG 0FE6Eh - fixed wrt preceding table
1631int1a_handler:
1632 cmp ah, 0B1h
1633 jne int1a_normal
1634
1635 call pcibios_real
1636 jc pcibios_error
1637
1638 jmp iret_modify_cf ; don't trash caller's flags!
1639
1640pcibios_error:
1641; mov bl, ah
1642; mov ah, 0B1h
1643 pusha
1644; mov ax, ss ; set readable descriptor to DS for calling
1645; mov ds, ax ; PCI BIOS from 16-bit protected mode
1646 ; TODO: C environment?!
1647 call _int1a_function_pci
1648 popa
1649 iret
1650
1651int1a_normal:
1652 push es
1653 push ds
1654 pusha
1655 C_SETUP
1656int1a_callfunction:
1657 call _int1a_function
1658 popa
1659 pop ds
1660 pop es
1661 iret
1662
1663
1664;;
1665;; IRQ 8 handler (RTC)
1666;;
1667int70_handler:
1668 push es
1669 push ds
1670 pusha
1671 C_SETUP
1672 call _int70_function
1673 popa
1674 pop ds
1675 pop es
1676 iret
1677
1678
1679;; --------------------------------------------------------
1680;; Timer tick - IRQ 0 handler
1681;; --------------------------------------------------------
1682 BIOSORG 0FEA5h
1683int08_handler:
1684 .386
1685 sti
1686 push eax
1687 push ds
1688 xor ax, ax
1689 mov ds, ax
1690
1691 ;; time to turn off floppy driv motor(s)?
1692 mov al, ds:[440h]
1693 or al, al
1694 jz int08_floppy_off
1695 ;; turn motor(s) off
1696 push dx
1697 mov dx, 03F2h
1698 in al, dx
1699 and al, 0CFh
1700 out dx, al
1701 pop dx
1702
1703int08_floppy_off:
1704 mov eax, ds:[46Ch] ; get ticks dword
1705 inc eax
1706
1707 ;; compare eax to one day's worth of ticks (at 18.2 Hz)
1708 cmp eax, 1800B0h
1709 jb int08_store_ticks
1710 ;; there has been a midnight rollover
1711 xor eax, eax
1712 inc byte ptr ds:[470h] ; increment rollover flag
1713
1714int08_store_ticks:
1715 mov ds:[46Ch], eax
1716 int 1Ch ; call the user timer handler
1717 cli
1718 call eoi_master_pic
1719 pop ds
1720 pop eax
1721 .286
1722 iret
1723
1724
1725;; --------------------------------------------------------
1726;; Initial interrupt vector offsets for POST
1727;; --------------------------------------------------------
1728 BIOSORG 0FEF3h
1729vector_table:
1730
1731
1732
1733;; --------------------------------------------------------
1734;; BIOS copyright string
1735;; --------------------------------------------------------
1736 BIOSORG 0FF00h
1737bios_string:
1738 db BIOS_COPYRIGHT
1739
1740
1741;; --------------------------------------------------------
1742;; IRET - default interrupt handler
1743;; --------------------------------------------------------
1744 BIOSORG 0FF53h
1745
1746dummy_iret:
1747 iret
1748
1749
1750;; --------------------------------------------------------
1751;; INT 05h - Print Screen service
1752;; --------------------------------------------------------
1753;; BIOSORG 0FF54h - fixed wrt preceding
1754int05_handler:
1755 ;; Not implemented
1756 iret
1757
1758include smidmi.inc
1759
1760;; --------------------------------------------------------
1761;; Processor reset entry point
1762;; --------------------------------------------------------
1763 BIOSORG 0FFF0h
1764cpu_reset:
1765 ;; This is where the CPU starts executing after a reset
1766 jmp far ptr post
1767
1768 ;; BIOS build date
1769 db BIOS_BUILD_DATE
1770 db 0 ; padding
1771 ;; System model ID
1772 db SYS_MODEL_ID
1773 ;; Checksum byte
1774 db 0FFh
1775
1776
1777BIOSSEG ends
1778
1779 end
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette