summaryrefslogtreecommitdiff
path: root/kernel/keyboard.c
blob: 083e5536a5123abafa51b4676917ebe0becab87a (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
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

}