-
Notifications
You must be signed in to change notification settings - Fork 19
/
top.v
75 lines (63 loc) · 2.05 KB
/
top.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
//
// Example using the usb_hid_host core, for Machdyne Riegel
// based on the icesugar-pro example by nand2mario, 8/2023
//
module top (
input sys_clk,
// input sys_resetn,
// input s1,
// UART
input UART_RXD,
output UART_TXD,
// LEDs
output led,
// USB
inout usbdm,
inout usbdp
);
always @(posedge clk_24) begin
clk_usb <= !clk_usb;
end
wire sys_resetn;
reg clk_usb;
wire clk_24;
wire [1:0] usb_type;
wire [7:0] key_modifiers, key1, key2, key3, key4;
wire [7:0] mouse_btn;
wire signed [7:0] mouse_dx, mouse_dy;
wire [63:0] hid_report;
wire usb_report, usb_conerr, game_l, game_r, game_u, game_d, game_a, game_b, game_x, game_y;
wire game_sel, game_sta;
wire [13:0] dbg_pc;
wire [3:0] dbg_inst;
clock clock(
.clkin(sys_clk),
.clk24(clk_24),
.locked(sys_resetn)
);
usb_hid_host usb (
.usbclk(clk_usb), .usbrst_n(sys_resetn),
.usb_dm(usbdm), .usb_dp(usbdp),
.typ(usb_type), .report(usb_report),
.key_modifiers(key_modifiers), .key1(key1), .key2(key2), .key3(key3), .key4(key4),
.mouse_btn(mouse_btn), .mouse_dx(mouse_dx), .mouse_dy(mouse_dy),
.game_l(game_l), .game_r(game_r), .game_u(game_u), .game_d(game_d),
.game_a(game_a), .game_b(game_b), .game_x(game_x), .game_y(game_y),
.game_sel(game_sel), .game_sta(game_sta),
.conerr(usb_conerr), .dbg_hid_report(hid_report)
);
hid_printer prt (
.clk(clk_usb), .resetn(sys_resetn),
.uart_tx(UART_TXD), .usb_type(usb_type), .usb_report(usb_report),
.key_modifiers(key_modifiers), .key1(key1), .key2(key2), .key3(key3), .key4(key4),
.mouse_btn(mouse_btn), .mouse_dx(mouse_dx), .mouse_dy(mouse_dy),
.game_l(game_l), .game_r(game_r), .game_u(game_u), .game_d(game_d),
.game_a(game_a), .game_b(game_b), .game_x(game_x), .game_y(game_y),
.game_sel(game_sel), .game_sta(game_sta)
);
reg report_toggle; // blinks whenever there's a report
always @(posedge clk_usb) if (usb_report) report_toggle <= ~report_toggle;
assign led = report_toggle;
//assign leds[7:0] = ~{6'b0, usb_type};
//assign leds[15:8] = ~8'b0;
endmodule