summaryrefslogtreecommitdiff
path: root/asm/int_clock_handler.asm
blob: dd0de96cf3c294c9d30bfd24e8a29254e126521b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
global int_clock_handler
[extern task_switch_next]

CLOCK_COUNTER:
    db 0x00

[bits 32]
int_clock_handler:
 
 ;Notice there is no IRQ number or error code - we don't need them

 inc byte [CLOCK_COUNTER]
 
 cmp byte  [CLOCK_COUNTER], 0x10

 jne skip_clock

 mov byte [CLOCK_COUNTER], 0x00

 pusha          ;Push all standard registers

 push esp       ;Push pointer to all the stuff we just pushed

 call task_switch_next ;Call C code
 
 mov esp, eax   ;Replace the stack with what the C code gave us

 popa           ;Put the standard registers back
 
 skip_clock:

 mov al, 0x20   ;Port number AND command number to Acknowledge IRQ
 out 0x20, al     ;Acknowledge IRQ, so we keep getting interrupts

 ;We didn't push an error code or IRQ number, so we don't have to edit esp now
 
 iret           ;Interrupt-Return