-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtop.v
161 lines (142 loc) · 3.77 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
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
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
`timescale 1ns / 1ps
//////////////////////////////////////////////////////////////////////////////////
// Company:
// Engineer:
//
// Create Date: 12:21:23 12/20/2017
// Design Name:
// Module Name: Top
// Project Name:
// Target Devices:
// Tool versions:
// Description:
//
// Dependencies:
//
// Revision:
// Revision 0.01 - File Created
// Additional Comments:
//
//////////////////////////////////////////////////////////////////////////////////
`include "vga_scan_param_h.v"
module top(
input clk,
input rst,// active low
input PS2C,
input PS2D,
input [3:0] BTN,
input [6:0] SW,
output hs,
output vs,
output [3:0] r,
output [3:0] g,
output [3:0] b,
output buzzer
// runtime test
,
output [7:0] LED
);
// clkdiv //
reg [31:0] clkdiv = 0;
always@( posedge clk) begin
clkdiv <= clkdiv + 1'b1;
end
// deactivate buzzer
assign buzzer = 1'b1;
wire RST_OK;
// assign RST_OK = rst;
AntiJitter #(4) anti(.clk(clkdiv[15]), .I(rst), .O(RST_OK));
wire [6:0] SW_ok;
// assign SW_ok = SW;
AntiJitter #(4) anti1[6:0](.clk(clkdiv[15]), .I(SW), .O(SW_ok)) ;
wire [3:0] BTN_OK;
// assign BTN_OK = BTN;
AntiJitter #(4) anti2[3:0](.clk(clkdiv[15]), .I(BTN), .O(BTN_OK)) ;
// Input: keyboard //
// keyboard routine >
// wire [7:0] ascii;
// keyboard kbd0(
// .clk(clk),.PS2C(PS2C),.PS2D(PS2D),.ascii(ascii)
// );
// to Player Control //
wire [3:0] collision;
wire [1:0] rotate_sig;
wire [1:0] move_sig;
control_host control_host0(
.clk(clk),
.rst(RST_OK),
.key(BTN_OK),
.en_left(collision[3]),
.en_right(collision[2]),
.en_forward(collision[1]),
.en_backward(collision[0]),
.rotate_sig(rotate_sig),
.move_sig(move_sig)
);
// to Object Ram //
// io addr >>
// write: tracer
wire [`ROW_WIDTH+`COL_WIDTH-1:0] tracer_write_addr;
// read: vga
wire [`ROW_WIDTH+`COL_WIDTH-1:0] vga_read_addr;
// composite
wire [`ROW_WIDTH-1:0] write_row_addr;
wire [`COL_WIDTH-1:0] write_col_addr;
wire [`ROW_WIDTH-1:0] read_row_addr;// 60 8*8 pixel block
wire [`COL_WIDTH-1:0] read_col_addr;// 80 8*8 pixel block
assign tracer_write_addr = {write_col_addr,write_row_addr};
assign vga_read_addr = {read_col_addr,read_row_addr};
// io data >>
// write: from tracer
wire [11:0] tracer_dout;
// read: to vga api
wire [11:0] vga_din;
dual_port_ram #(.WIDTH(`ROW_WIDTH+`COL_WIDTH),.LENGTH(12)) pixelRAM(
.clk(clk),
.rst(RST_OK),
.write_addr(tracer_write_addr),
.read_addr(vga_read_addr),
.din(tracer_dout),
.dout(vga_din)
);
// ip core ram //
// ip_ram pixel_ram(
// .clka(clk),
// .wea(1'b1),
// .addra(tracer_write_addr),
// .dina(tracer_dout),
// .clkb(clk),
// .addrb(vga_read_addr),
// .doutb(vga_din)
// );
// which link to Tracer //
wire [179:0] object_ram_bus;
ray_tracer_host ray_tracer_host0(
.clk(clkdiv[1]),
.rst(RST_OK),
.in_bus(object_ram_bus),
.col_addr(write_col_addr),
.row_addr(write_row_addr),
.dout(tracer_dout),
.collision_sig(collision)
);
// and VGA //
vga vga0(
.vga_clk(clkdiv[1]),
.rst(RST_OK),
.din(vga_din),
.col_addr(read_col_addr),
.row_addr(read_row_addr),
.hs(hs),.vs(vs),
.r(r),.g(g),.b(b)
);
// with Obj Sys //
object_host object_host0(
.clk(clkdiv[22]),
.rst(RST_OK),
.rotate(rotate_sig),
.move(move_sig),
.out_bus(object_ram_bus)
);
assign LED = {move_sig,rotate_sig,collision};
endmodule