-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhpi_io_intf.sv
45 lines (41 loc) · 1.63 KB
/
hpi_io_intf.sv
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
// Interface between NIOS II and EZ-OTG chip
module hpi_io_intf( input Clk, Reset,
input [1:0] from_sw_address,
output[15:0] from_sw_data_in,
input [15:0] from_sw_data_out,
input from_sw_r, from_sw_w, from_sw_cs, from_sw_reset, // Active low
inout [15:0] OTG_DATA,
output[1:0] OTG_ADDR,
output OTG_RD_N, OTG_WR_N, OTG_CS_N, OTG_RST_N // Active low
);
// Buffer (register) for from_sw_data_out because inout bus should be driven
// by a register, not combinational logic.
logic [15:0] from_sw_data_out_buffer;
// TODO: Fill in the blanks below.
always_ff @ (posedge Clk)
begin
if(Reset)
begin
from_sw_data_out_buffer <= 16'h0000;
OTG_ADDR <= 2'b00;
OTG_RD_N <= 1'b1;
OTG_WR_N <= 1'b1;
OTG_CS_N <= 1'b0;
OTG_RST_N <= 1'b0;
from_sw_data_in <= 16'h0000;
end
else
begin
from_sw_data_out_buffer <= from_sw_data_out;
OTG_ADDR <= from_sw_address;
OTG_RD_N <= from_sw_r;
OTG_WR_N <= from_sw_w;
OTG_CS_N <= from_sw_cs;
OTG_RST_N <= 1'b1;
from_sw_data_in <= OTG_DATA;
end
end
// OTG_DATA should be high Z (tristated) when NIOS is not writing to OTG_DATA inout bus.
// Look at tristate.sv in lab 6 for an example.
assign OTG_DATA = ~from_sw_w ? from_sw_data_out_buffer : {16'bZ};
endmodule