-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathkeyboard_decoder.v
98 lines (94 loc) · 2.4 KB
/
keyboard_decoder.v
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
module keyboard_decoder(CLOCK_50, PS2_CLK, PS2_DAT, key_pressed, keycode);
input CLOCK_50;
inout PS2_CLK, PS2_DAT;
output reg key_pressed = 0;
output reg [7:0] keycode = 0;
wire[7:0] received_data;
wire received_data_en;
reg [7:0] data = 0;
reg ignore = 0, key_change = 0;
PS2_Controller myController(
.CLOCK_50(CLOCK_50),
.PS2_CLK(PS2_CLK),
.PS2_DAT(PS2_DAT),
.received_data(received_data),
.received_data_en(received_data_en));
always@(posedge CLOCK_50) begin
if(received_data_en) begin
if(!ignore) begin
if(received_data != 8'hE0) begin
if(received_data == 8'hF0) begin
ignore <= 1;
key_change <= 0;
end
else begin
data <= received_data;
key_change <= 1;
end
end
end
else begin
key_change <= 0;
ignore <= 0;
end
end
else begin
key_change <= 0;
end
end
always@(posedge CLOCK_50) begin
if (key_change) begin
key_pressed <= 1;
case(data)
8'h45: keycode <= 8'd0;
8'h16: keycode <= 8'd1;
8'h1E: keycode <= 8'd2;
8'h26: keycode <= 8'd3;
8'h25: keycode <= 8'd4;
8'h2E: keycode <= 8'd5;
8'h36: keycode <= 8'd6;
8'h3D: keycode <= 8'd7;
8'h3E: keycode <= 8'd8;
8'h46: keycode <= 8'd9;
8'h1C: keycode <= 8'd10; // A
8'h32: keycode <= 8'd11;
8'h21: keycode <= 8'd12;
8'h23: keycode <= 8'd13;
8'h24: keycode <= 8'd14;
8'h2B: keycode <= 8'd15;
8'h34: keycode <= 8'd16;
8'h33: keycode <= 8'd17;
8'h43: keycode <= 8'd18;
8'h3B: keycode <= 8'd19;
8'h42: keycode <= 8'd20;
8'h4B: keycode <= 8'd21;
8'h3A: keycode <= 8'd22;
8'h31: keycode <= 8'd23;
8'h44: keycode <= 8'd24;
8'h4D: keycode <= 8'd25;
8'h15: keycode <= 8'd26;
8'h2D: keycode <= 8'd27;
8'h1B: keycode <= 8'd28; // S
8'h2C: keycode <= 8'd29;
8'h3C: keycode <= 8'd30;
8'h2A: keycode <= 8'd31;
8'h1D: keycode <= 8'd32;
8'h22: keycode <= 8'd33;
8'h35: keycode <= 8'd34;
8'h1A: keycode <= 8'd35; // Z
8'h29: keycode <= 8'd36; // space
8'h66: keycode <= 8'd37; // delete
8'h49: keycode <= 8'd38; // period
8'h76: keycode <= 8'd39; // esc
8'h5A: keycode <= 8'd98; // enter
8'h72: keycode <= 8'd99; //key down
8'h75: keycode <= 8'd100; //key up
8'h6B: keycode <= 8'd101; //key left
8'h74: keycode <= 8'd102; //key right
default: keycode <= 8'd255;
endcase
end
else
key_pressed <= 0;
end
endmodule