]> Joshua Wise's Git repositories - fpgaboy.git/blame_incremental - System.v
Add mock up LCDC
[fpgaboy.git] / System.v
... / ...
CommitLineData
1
2`timescale 1ns / 1ps
3module ROM(
4 input [15:0] address,
5 inout [7:0] data,
6 input clk,
7 input wr, rd);
8
9 reg [7:0] rom [2047:0];
10 initial $readmemh("rom.hex", rom);
11
12 wire decode = address[15:13] == 0;
13 wire [7:0] odata = rom[address[11:0]];
14 assign data = (rd && decode) ? odata : 8'bzzzzzzzz;
15 //assign data = rd ? odata : 8'bzzzzzzzz;
16endmodule
17
18module InternalRAM(
19 input [15:0] address,
20 inout [7:0] data,
21 input clk,
22 input wr, rd);
23
24 // synthesis attribute ram_style of reg is block
25 reg [7:0] ram [8191:0];
26
27 wire decode = address[15:13] == 3'b110;
28 reg [7:0] odata;
29 assign data = (rd && decode) ? odata : 8'bzzzzzzzz;
30
31 always @(negedge clk)
32 begin
33 if (decode) // This has to go this way. The only way XST knows how to do
34 begin // block ram is chip select, write enable, and always
35 if (wr) // reading. "else if rd" does not cut it ...
36 ram[address[12:0]] <= data;
37 odata <= ram[address[12:0]];
38 end
39 end
40endmodule
41
42module Switches(
43 input [15:0] address,
44 inout [7:0] data,
45 input clk,
46 input wr, rd,
47 input [7:0] switches,
48 output reg [7:0] ledout = 0);
49
50 wire decode = address == 16'hFF51;
51 reg [7:0] odata;
52 assign data = (rd && decode) ? odata : 8'bzzzzzzzz;
53
54 always @(negedge clk)
55 begin
56 if (decode && rd)
57 odata <= switches;
58 else if (decode && wr)
59 ledout <= data;
60 end
61endmodule
62
63module CoreTop(
64 input xtal,
65 input [7:0] switches,
66 input [3:0] buttons,
67 output wire [7:0] leds,
68 output serio,
69 output wire [3:0] digits,
70 output wire [7:0] seven);
71
72 wire clk;
73 CPUDCM dcm (.CLKIN_IN(xtal), .CLKFX_OUT(clk));
74
75 wire [15:0] addr;
76 wire [7:0] data;
77 wire wr, rd;
78
79 wire irq, tmrirq, lcdcirq;
80 wire [7:0] jaddr;
81 wire [1:0] state;
82
83 GBZ80Core core(
84 .clk(clk),
85 .busaddress(addr),
86 .busdata(data),
87 .buswr(wr),
88 .busrd(rd),
89 .irq(irq),
90 .jaddr(jaddr),
91 .state(state));
92
93 ROM rom(
94 .address(addr),
95 .data(data),
96 .clk(clk),
97 .wr(wr),
98 .rd(rd));
99
100 LCDC lcdc(
101 .addr(addr),
102 .data(data),
103 .clk(clk),
104 .wr(wr),
105 .rd(rd),
106 .irq(lcdcirq));
107
108 AddrMon amon(
109 .addr(addr),
110 .clk(clk),
111 .digit(digits),
112 .out(seven),
113 .freeze(buttons[0]),
114 .periods(
115 (state == 2'b00) ? 4'b0010 :
116 (state == 2'b01) ? 4'b0001 :
117 (state == 2'b10) ? 4'b1000 :
118 4'b0100) );
119
120 Switches sw(
121 .address(addr),
122 .data(data),
123 .clk(clk),
124 .wr(wr),
125 .rd(rd),
126 .ledout(leds),
127 .switches(switches)
128 );
129
130 UART nouart ( /* no u */
131 .clk(clk),
132 .wr(wr),
133 .rd(rd),
134 .addr(addr),
135 .data(data),
136 .serial(serio)
137 );
138
139 InternalRAM ram(
140 .address(addr),
141 .data(data),
142 .clk(clk),
143 .wr(wr),
144 .rd(rd)
145 );
146
147 Timer tmr(
148 .clk(clk),
149 .wr(wr),
150 .rd(rd),
151 .addr(addr),
152 .data(data),
153 .irq(tmrirq)
154 );
155
156 Interrupt intr(
157 .clk(clk),
158 .rd(rd),
159 .wr(wr),
160 .addr(addr),
161 .data(data),
162 .vblank(0),
163 .lcdc(lcdcirq),
164 .tovf(tmrirq),
165 .serial(0),
166 .buttons(0),
167 .master(irq),
168 .jaddr(jaddr));
169endmodule
170
171module TestBench();
172 reg clk = 1;
173 wire [15:0] addr;
174 wire [7:0] data;
175 wire wr, rd;
176
177 wire irq, tmrirq;
178 wire [7:0] jaddr;
179
180 wire [7:0] leds;
181 wire [7:0] switches;
182
183 always #62 clk <= ~clk;
184 GBZ80Core core(
185 .clk(clk),
186 .busaddress(addr),
187 .busdata(data),
188 .buswr(wr),
189 .busrd(rd),
190 .irq(irq),
191 .jaddr(jaddr));
192
193 ROM rom(
194 .clk(clk),
195 .address(addr),
196 .data(data),
197 .wr(wr),
198 .rd(rd));
199
200 InternalRAM ram(
201 .address(addr),
202 .data(data),
203 .clk(clk),
204 .wr(wr),
205 .rd(rd));
206
207 wire serio;
208 UART uart(
209 .addr(addr),
210 .data(data),
211 .clk(clk),
212 .wr(wr),
213 .rd(rd),
214 .serial(serio));
215
216 Timer tmr(
217 .clk(clk),
218 .wr(wr),
219 .rd(rd),
220 .addr(addr),
221 .data(data),
222 .irq(tmrirq));
223
224 Interrupt intr(
225 .clk(clk),
226 .rd(rd),
227 .wr(wr),
228 .addr(addr),
229 .data(data),
230 .vblank(0),
231 .lcdc(0),
232 .tovf(tmrirq),
233 .serial(0),
234 .buttons(0),
235 .master(irq),
236 .jaddr(jaddr));
237
238 Switches sw(
239 .clk(clk),
240 .address(addr),
241 .data(data),
242 .wr(wr),
243 .rd(rd),
244 .switches(switches),
245 .ledout(leds));
246endmodule
This page took 0.028871 seconds and 4 git commands to generate.