Rev 1392 | Rev 1474 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed
Rev | Author | Line No. | Line |
---|---|---|---|
1 | ha | 1 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
2 | ;; |
||
1273 | Lrz | 3 | ;; Copyright (C) KolibriOS team 2004-2009. All rights reserved. |
431 | serge | 4 | ;; PROGRAMMING: |
5 | ;; Ivan Poddubny |
||
6 | ;; Marat Zakiyanov (Mario79) |
||
7 | ;; VaStaNi |
||
8 | ;; Trans |
||
9 | ;; Mihail Semenyako (mike.dld) |
||
10 | ;; Sergey Kuzmin (Wildwest) |
||
11 | ;; Andrey Halyavin (halyavin) |
||
12 | ;; Mihail Lisovin (Mihasik) |
||
13 | ;; Andrey Ignatiev (andrew_programmer) |
||
14 | ;; NoName |
||
15 | ;; Evgeny Grechnikov (Diamond) |
||
16 | ;; Iliya Mihailov (Ghost) |
||
17 | ;; Sergey Semyonov (Serge) |
||
18 | ;; Johnny_B |
||
543 | spraid | 19 | ;; SPraid (simba) |
1043 | hidnplayr | 20 | ;; Hidnplayr |
1273 | Lrz | 21 | ;; Alexey Teplov ( |
1 | ha | 22 | ;; |
431 | serge | 23 | ;; Data in this file was originally part of MenuetOS project which is |
24 | ;; distributed under the terms of GNU GPL. It is modified and redistributed as |
||
25 | ;; part of KolibriOS project under the terms of GNU GPL. |
||
1 | ha | 26 | ;; |
431 | serge | 27 | ;; Copyright (C) MenuetOS 2000-2004 Ville Mikael Turjanmaa |
28 | ;; PROGRAMMING: |
||
1 | ha | 29 | ;; |
431 | serge | 30 | ;; Ville Mikael Turjanmaa, villemt@itu.jyu.fi |
31 | ;; - main os coding/design |
||
32 | ;; Jan-Michael Brummer, BUZZ2@gmx.de |
||
33 | ;; Felix Kaiser, info@felix-kaiser.de |
||
34 | ;; Paolo Minazzi, paolo.minazzi@inwind.it |
||
35 | ;; quickcode@mail.ru |
||
36 | ;; Alexey, kgaz@crosswinds.net |
||
37 | ;; Juan M. Caravaca, bitrider@wanadoo.es |
||
38 | ;; kristol@nic.fi |
||
39 | ;; Mike Hibbett, mikeh@oceanfree.net |
||
40 | ;; Lasse Kuusijarvi, kuusijar@lut.fi |
||
41 | ;; Jarek Pelczar, jarekp3@wp.pl |
||
1 | ha | 42 | ;; |
431 | serge | 43 | ;; KolibriOS is distributed in the hope that it will be useful, but WITHOUT ANY |
44 | ;; WARRANTY. No author or distributor accepts responsibility to anyone for the |
||
45 | ;; consequences of using it or for whether it serves any particular purpose or |
||
46 | ;; works at all, unless he says so in writing. Refer to the GNU General Public |
||
47 | ;; License (the "GPL") for full details. |
||
48 | ; |
||
49 | ;; Everyone is granted permission to copy, modify and redistribute KolibriOS, |
||
50 | ;; but only under the conditions described in the GPL. A copy of this license |
||
51 | ;; is supposed to have been given to you along with KolibriOS so you can know |
||
52 | ;; your rights and responsibilities. It should be in a file named COPYING. |
||
53 | ;; Among other things, the copyright notice and this notice must be preserved |
||
54 | ;; on all copies. |
||
55 | ;; |
||
1 | ha | 56 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
426 | mikedld | 57 | |
58 | include 'macros.inc' |
||
59 | |||
425 | victor | 60 | $Revision: 1447 $ |
426 | mikedld | 61 | |
593 | mikedld | 62 | |
1055 | Galkov | 63 | USE_COM_IRQ equ 1 ; make irq 3 and irq 4 available for PCI devices |
566 | serge | 64 | |
1043 | hidnplayr | 65 | ; Enabling the next line will enable serial output console |
66 | ;debug_com_base equ 0x3f8 ; 0x3f8 is com1, 0x2f8 is com2, 0x3e8 is com3, 0x2e8 is com4, no irq's are used |
||
67 | |||
164 | serge | 68 | include "proc32.inc" |
7 | me_root | 69 | include "kglobals.inc" |
1 | ha | 70 | include "lang.inc" |
71 | |||
164 | serge | 72 | include "const.inc" |
1055 | Galkov | 73 | max_processes equ 255 |
74 | tss_step equ (128+8192) ; tss & i/o - 65535 ports, * 256=557056*4 |
||
1 | ha | 75 | |
164 | serge | 76 | |
1055 | Galkov | 77 | os_stack equ (os_data_l-gdts) ; GDTs |
465 | serge | 78 | os_code equ (os_code_l-gdts) |
79 | graph_data equ (3+graph_data_l-gdts) |
||
1055 | Galkov | 80 | tss0 equ (tss0_l-gdts) |
465 | serge | 81 | app_code equ (3+app_code_l-gdts) |
82 | app_data equ (3+app_data_l-gdts) |
||
1220 | serge | 83 | app_tls equ (3+tls_data_l-gdts) |
586 | serge | 84 | pci_code_sel equ (pci_code_32-gdts) |
85 | pci_data_sel equ (pci_data_32-gdts) |
||
1 | ha | 86 | |
87 | |||
88 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
||
89 | ;; |
||
90 | ;; Included files: |
||
91 | ;; |
||
92 | ;; Kernel16.inc |
||
93 | ;; - Booteng.inc English text for bootup |
||
94 | ;; - Bootcode.inc Hardware setup |
||
95 | ;; - Pci16.inc PCI functions |
||
96 | ;; |
||
97 | ;; Kernel32.inc |
||
98 | ;; - Sys32.inc Process management |
||
99 | ;; - Shutdown.inc Shutdown and restart |
||
100 | ;; - Fat32.inc Read / write hd |
||
101 | ;; - Vesa12.inc Vesa 1.2 driver |
||
102 | ;; - Vesa20.inc Vesa 2.0 driver |
||
103 | ;; - Vga.inc VGA driver |
||
104 | ;; - Stack.inc Network interface |
||
105 | ;; - Mouse.inc Mouse pointer |
||
106 | ;; - Scincode.inc Window skinning |
||
107 | ;; - Pci32.inc PCI functions |
||
108 | ;; |
||
109 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
||
110 | |||
111 | |||
112 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
||
113 | ;; ;; |
||
114 | ;; 16 BIT ENTRY FROM BOOTSECTOR ;; |
||
115 | ;; ;; |
||
116 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
||
117 | |||
118 | use16 |
||
1055 | Galkov | 119 | org 0x0 |
120 | jmp start_of_code |
||
1 | ha | 121 | |
1324 | Lrz | 122 | version db 'Kolibri OS version 0.7.7.0+ ',13,10,13,10,0 |
1 | ha | 123 | |
465 | serge | 124 | include "boot/bootstr.inc" ; language-independent boot messages |
1 | ha | 125 | include "boot/preboot.inc" |
126 | |||
465 | serge | 127 | if lang eq en |
128 | include "boot/booteng.inc" ; english system boot messages |
||
129 | else if lang eq ru |
||
130 | include "boot/bootru.inc" ; russian system boot messages |
||
1055 | Galkov | 131 | include "boot/ru.inc" ; Russian font |
465 | serge | 132 | else if lang eq et |
133 | include "boot/bootet.inc" ; estonian system boot messages |
||
1055 | Galkov | 134 | include "boot/et.inc" ; Estonian font |
465 | serge | 135 | else |
136 | include "boot/bootge.inc" ; german system boot messages |
||
137 | end if |
||
1 | ha | 138 | |
465 | serge | 139 | include "boot/bootcode.inc" ; 16 bit system boot code |
140 | include "bus/pci/pci16.inc" |
||
709 | diamond | 141 | include "detect/biosdisk.inc" |
1 | ha | 142 | |
143 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
||
144 | ;; ;; |
||
145 | ;; SWITCH TO 32 BIT PROTECTED MODE ;; |
||
146 | ;; ;; |
||
147 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
||
148 | |||
149 | |||
150 | ; CR0 Flags - Protected mode and Paging |
||
151 | |||
1055 | Galkov | 152 | mov ecx, CR0_PE |
1 | ha | 153 | |
154 | ; Enabling 32 bit protected mode |
||
155 | |||
1055 | Galkov | 156 | sidt [cs:old_ints_h] |
1 | ha | 157 | |
1055 | Galkov | 158 | cli ; disable all irqs |
159 | cld |
||
160 | mov al,255 ; mask all irqs |
||
161 | out 0xa1,al |
||
162 | out 0x21,al |
||
163 | l.5: in al, 0x64 ; Enable A20 |
||
164 | test al, 2 |
||
165 | jnz l.5 |
||
166 | mov al, 0xD1 |
||
167 | out 0x64, al |
||
168 | l.6: in al, 0x64 |
||
169 | test al, 2 |
||
170 | jnz l.6 |
||
171 | mov al, 0xDF |
||
172 | out 0x60, al |
||
173 | l.7: in al, 0x64 |
||
174 | test al, 2 |
||
175 | jnz l.7 |
||
176 | mov al, 0xFF |
||
177 | out 0x64, al |
||
465 | serge | 178 | |
1055 | Galkov | 179 | lgdt [cs:tmp_gdt] ; Load GDT |
180 | mov eax, cr0 ; protected mode |
||
181 | or eax, ecx |
||
182 | and eax, 10011111b *65536*256 + 0xffffff ; caching enabled |
||
183 | mov cr0, eax |
||
184 | jmp pword os_code:B32 ; jmp to enable 32 bit mode |
||
1 | ha | 185 | |
465 | serge | 186 | align 8 |
187 | tmp_gdt: |
||
1 | ha | 188 | |
1055 | Galkov | 189 | dw 23 |
190 | dd tmp_gdt+0x10000 |
||
191 | dw 0 |
||
183 | diamond | 192 | |
1055 | Galkov | 193 | dw 0xffff |
194 | dw 0x0000 |
||
195 | db 0x00 |
||
196 | dw 11011111b *256 +10011010b |
||
197 | db 0x00 |
||
375 | Ghost | 198 | |
1055 | Galkov | 199 | dw 0xffff |
200 | dw 0x0000 |
||
201 | db 0x00 |
||
202 | dw 11011111b *256 +10010010b |
||
203 | db 0x00 |
||
1 | ha | 204 | |
465 | serge | 205 | include "data16.inc" |
1 | ha | 206 | |
465 | serge | 207 | use32 |
208 | org $+0x10000 |
||
1 | ha | 209 | |
465 | serge | 210 | align 4 |
211 | B32: |
||
1055 | Galkov | 212 | mov ax,os_stack ; Selector for os |
213 | mov ds,ax |
||
214 | mov es,ax |
||
215 | mo |