1 ; AcessOS Microkernel Version
11 GDT_SIZE equ (1+2*2+1+MAX_CPUS)*8
19 dd 0x00000000, 0x00000000 ; 00 NULL Entry
20 dd 0x0000FFFF, 0x00CF9A00 ; 08 PL0 Code
21 dd 0x0000FFFF, 0x00CF9200 ; 10 PL0 Data
22 dd 0x0000FFFF, 0x00CFFA00 ; 18 PL3 Code
23 dd 0x0000FFFF, 0x00CFF200 ; 20 PL3 Data
24 dd 26*4-1, 0x00408900 ; 28 Double Fault TSS
25 times MAX_CPUS dd 26*4-1, 0x00408900 ; 30+ TSSes
34 ; CS = 0x08, Type = 32-bit Interrupt (0xE = 1 110)
35 times 256 dd 0x00080000,0x00000E00
38 dw 256 * 16 - 1 ; Limit
43 [global Desctab_Install]
47 mov ax, 0x10 ; PL0 Data
58 ; - Set an IDT entry to an ISR
61 mov WORD [gIDT + %1*8], ax
63 mov WORD [gIDT + %1*8+6], ax
65 mov ax, WORD [gIDT + %1*8 + 4]
67 mov WORD [gIDT + %1*8 + 4], ax
69 ; Enable user calling of an ISR
71 or WORD [gIDT + %1*8 + 4], 0x6000
73 ; Set an ISR as a trap (leaves interrupts enabled when invoked)
75 or WORD [gIDT + %1*8 + 4], 0x0100
88 SET_TRAP 0xAC ; Interruptable
92 SETISR 0xEE ; 0xEE Timer
93 SETISR 0xEF ; 0xEF Spurious Interrupt
110 out dx, al ; Init Command
113 out dx, al ; Offset (Start of IDT Range)
115 out dx, al ; IRQ connected to Slave (00000100b) = IRQ2
117 out dx, al ; Set Mode
119 out dx, al ; Set Mode
123 out dx, al ; Init Command
126 out dx, al ; Offset (Start of IDT Range)
128 out dx, al ; IRQ Line connected to master
130 out dx, al ; Set Mode
132 out dx, al ; Set Mode
173 ISR_NOERR 0; 0: Divide By Zero Exception
174 ISR_NOERR 1; 1: Debug Exception
175 ISR_NOERR 2; 2: Non Maskable Interrupt Exception
176 ISR_NOERR 3; 3: Int 3 Exception
177 ISR_NOERR 4; 4: INTO Exception
178 ISR_NOERR 5; 5: Out of Bounds Exception
179 ISR_NOERR 6; 6: Invalid Opcode Exception
180 ISR_NOERR 7; 7: Coprocessor Not Available Exception
181 ISR_ERRNO 8; 8: Double Fault Exception (With Error Code!)
182 ISR_NOERR 9; 9: Coprocessor Segment Overrun Exception
183 ISR_ERRNO 10; 10: Bad TSS Exception (With Error Code!)
184 ISR_ERRNO 11; 11: Segment Not Present Exception (With Error Code!)
185 ISR_ERRNO 12; 12: Stack Fault Exception (With Error Code!)
186 ISR_ERRNO 13; 13: General Protection Fault Exception (With Error Code!)
187 ISR_ERRNO 14; 14: Page Fault Exception (With Error Code!)
188 ISR_NOERR 15; 15: Reserved Exception
189 ISR_NOERR 16; 16: Floating Point Exception
190 ISR_NOERR 17; 17: Alignment Check Exception
191 ISR_NOERR 18; 18: Machine Check Exception
192 ISR_NOERR 19; 19: Reserved
193 ISR_NOERR 20; 20: Reserved
194 ISR_NOERR 21; 21: Reserved
195 ISR_NOERR 22; 22: Reserved
196 ISR_NOERR 23; 23: Reserved
197 ISR_NOERR 24; 24: Reserved
198 ISR_NOERR 25; 25: Reserved
199 ISR_NOERR 26; 26: Reserved
200 ISR_NOERR 27; 27: Reserved
201 ISR_NOERR 28; 28: Reserved
202 ISR_NOERR 29; 29: Reserved
203 ISR_NOERR 30; 30: Reserved
204 ISR_NOERR 31; 31: Reserved
206 DEF_SYSCALL 0xAC ; Acess System Call
210 [extern SchedulerBase]
211 ; AP's Timer Interrupt
213 push 0 ; Line up with interrupt number
214 xchg bx, bx ; MAGIC BREAK
219 xchg bx, bx ; MAGIC BREAK
227 [extern SchedulerBase]
228 [extern SetAPICTimerCount]
230 push 0 ; Line up with Argument in errors
232 ;xchg bx, bx ; MAGIC BREAK
235 jmp SetAPICTimerCount ; This is reset once the bus speed has been calculated
246 ; ---------------------
247 ; Common error handling
248 ; ---------------------
249 [extern ErrorHandler]
251 ;xchg bx, bx ; MAGIC BREAK
261 ; and WORD [esp], 0xFEFF
279 add esp, 8 ; Error Code and ID
282 ; --------------------------
283 ; Common System Call Handler
284 ; --------------------------
285 [extern SyscallHandler]
297 ; Pass changes to TF on to the user
298 ; EFLAGS is stored at ESP[4+8+2+2]
299 ; 4 Segment Registers
301 ; 2 Error Code / Interrupt ID
305 and eax, 0x100 ; 0x100 = Trace Flag
306 and WORD [esp+(4+8+2+2)*4], ~0x100 ; Clear
307 or DWORD [esp+(4+8+2+2)*4], eax ; Set for user
314 add esp, 8 ; Error Code and ID
322 [global IRQCommon_handled]
323 IRQCommon_handled equ IRQCommon.handled
347 add esp, 8 ; Error Code and ID