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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
|
#define FOOLOS_MODULE_NAME "keyboard"
#include "kernel.h"
#include "x86.h"
#include "console.h"
#include "../lib/logger/log.h" // logger facilities
/// keyboard driver ////
void keyboard_handle(uint8_t in)
{
uint8_t make_codes[]={
0x1e, // A
0x30, // B
0x2e, // C
0x20, // D
0x12, // E
0x21, // F
0x22, // G
0x23, // H
0x17, // I
0x24, // J
0x25, // K
0x26, // L
0x32, // M
0x31, // N
0x18, // O
0x19, // P
0x10, // Q
0x13, // R
0x1F, // S
0x14, // T
0x16, // U
0x2F, // V
0x11, // W
0x2D, // X
0x15, // Y
0x2c, // Z
};
uint8_t break_alpha[]={
0x9e, // A
0xb0, // B
0xae, // C
0xa0, // D
0x92, // E
0xa1, // F
0xa2, // G
0xa3, // H
0x97, // I
0xa4, // J
0xa5, // K
0xa6, // L
0xb2, // M
0xb1, // N
0x98, // O
0x99, // P
0x90, // Q
0x93, // R
0x9F, // S
0x94, // T
0x96, // U
0xaF, // V
0x91, // W
0xaD, // X
0x95, // Y
0xac, // Z
};
uint8_t break_key_enter=0x9c;
uint8_t break_key_space=0xb9;
uint8_t break_key_backspace=0x8e;
char ascii;
// optimize this!
if(break_key_space==in)ascii=' ';
else if(break_key_backspace==in)ascii='x';
else if(break_key_enter==in)ascii='\n';
else for(int i=0;i<26;i++)
{
if(break_alpha[i]==in)
{
ascii=('A'+i);
break;
}
if(i==25)
{
return;
}
}
PutConsoleChar(ascii,0b1111100000011111);
if(!ringbuffer_put(ascii))
log(FOOLOS_MODULE_NAME,FOOLOS_LOG_INFO,"ringbuffer full..");
}
void int_kb_handler()
{
X86_IRQ_BEGIN
static uint8_t kb_in;
__asm__("in $0x60, %al");
__asm__("mov %%al, %0"::"m" (kb_in));
//log(FOOLOS_MODULE_NAME,FOOLOS_LOG_INFO,"scancode 0x%x",kb_in);
keyboard_handle(kb_in);
X86_IRQ_END
}
|