annotate cos/kernel/klib.c @ 31:88590c42320f

Changed interrupt handler
author windel
date Tue, 10 Jan 2012 20:40:35 +0100
parents 7e3bdcb391dc
children 3a6a9b929db0
rev   line source
24
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
1 #include "kernel.h"
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
2
29
7e3bdcb391dc Added get_page function to mm
windel
parents: 28
diff changeset
3 void magicBochsBreak()
7e3bdcb391dc Added get_page function to mm
windel
parents: 28
diff changeset
4 {
7e3bdcb391dc Added get_page function to mm
windel
parents: 28
diff changeset
5 asm volatile("xchg %bx, %bx");
7e3bdcb391dc Added get_page function to mm
windel
parents: 28
diff changeset
6 }
7e3bdcb391dc Added get_page function to mm
windel
parents: 28
diff changeset
7
24
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
8 void panic(char *msg)
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
9 {
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
10 printf("Kernel panic: ");
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
11 printf(msg);
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
12 magicBochsBreak();
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
13 halt();
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
14 }
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
15
26
dcce92b1efbc Added mm.c
windel
parents: 24
diff changeset
16 void reboot()
dcce92b1efbc Added mm.c
windel
parents: 24
diff changeset
17 {
dcce92b1efbc Added mm.c
windel
parents: 24
diff changeset
18 while ( (inb(0x64) & 0x02) == 0x02)
dcce92b1efbc Added mm.c
windel
parents: 24
diff changeset
19 {
dcce92b1efbc Added mm.c
windel
parents: 24
diff changeset
20 ;
dcce92b1efbc Added mm.c
windel
parents: 24
diff changeset
21 }
dcce92b1efbc Added mm.c
windel
parents: 24
diff changeset
22 outb(0x64, 0xFE);
dcce92b1efbc Added mm.c
windel
parents: 24
diff changeset
23 }
dcce92b1efbc Added mm.c
windel
parents: 24
diff changeset
24
28
47b7df514243 Moved Makefiles
windel
parents: 26
diff changeset
25 void halt()
47b7df514243 Moved Makefiles
windel
parents: 26
diff changeset
26 {
47b7df514243 Moved Makefiles
windel
parents: 26
diff changeset
27 asm volatile("cli");
47b7df514243 Moved Makefiles
windel
parents: 26
diff changeset
28 asm volatile("hlt");
47b7df514243 Moved Makefiles
windel
parents: 26
diff changeset
29 }
47b7df514243 Moved Makefiles
windel
parents: 26
diff changeset
30
24
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
31 // IO port helpers:
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
32 void outb(uint16_t port, uint8_t value)
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
33 {
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
34 asm volatile ("outb %1, %0" : : "dN" (port), "a" (value));
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
35 }
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
36
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
37 uint8_t inb(uint16_t port)
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
38 {
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
39 uint8_t ret;
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
40 asm volatile ("inb %1, %0" : "=a" (ret) : "dN" (port));
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
41 return ret;
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
42 }
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
43
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
44 uint16_t inw(uint16_t port)
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
45 {
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
46 uint16_t ret;
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
47 asm volatile ("inw %1, %0" : "=a" (ret) : "dN" (port));
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
48 return ret;
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
49 }
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
50
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
51 // string functions:
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
52 int strncmp(const char* s1, const char* s2, int size)
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
53 {
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
54 int i;
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
55 for (i=0; i<size; i++)
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
56 {
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
57 if (s1[i] != s2[i]) return 0;
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
58 }
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
59 return 1;
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
60 }
d8627924d40d Split up in more files and reboot command
windel
parents:
diff changeset
61
28
47b7df514243 Moved Makefiles
windel
parents: 26
diff changeset
62 // mem functions:
47b7df514243 Moved Makefiles
windel
parents: 26
diff changeset
63 void memset(void* data, uint8_t value, uint64_t size)
47b7df514243 Moved Makefiles
windel
parents: 26
diff changeset
64 {
47b7df514243 Moved Makefiles
windel
parents: 26
diff changeset
65 uint64_t i;
47b7df514243 Moved Makefiles
windel
parents: 26
diff changeset
66 uint8_t *data2 = (uint8_t*)data;
47b7df514243 Moved Makefiles
windel
parents: 26
diff changeset
67 for (i = 0; i < size; i++)
47b7df514243 Moved Makefiles
windel
parents: 26
diff changeset
68 {
47b7df514243 Moved Makefiles
windel
parents: 26
diff changeset
69 data2[i] = value;
47b7df514243 Moved Makefiles
windel
parents: 26
diff changeset
70 }
47b7df514243 Moved Makefiles
windel
parents: 26
diff changeset
71 }
47b7df514243 Moved Makefiles
windel
parents: 26
diff changeset
72