forked from pulp-platform/axi_spi_slave
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathspi_slave_regs.sv
75 lines (70 loc) · 2.05 KB
/
spi_slave_regs.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
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
// Copyright 2015 ETH Zurich and University of Bologna.
// Copyright and related rights are licensed under the Solderpad Hardware
// License, Version 0.51 (the “License”); you may not use this file except in
// compliance with the License. You may obtain a copy of the License at
// http://solderpad.org/licenses/SHL-0.51. Unless required by applicable law
// or agreed to in writing, software, hardware and materials distributed under
// this License is distributed on an “AS IS” BASIS, WITHOUT WARRANTIES OR
// CONDITIONS OF ANY KIND, either express or implied. See the License for the
// specific language governing permissions and limitations under the License.
module spi_slave_regs #(
parameter REG_SIZE = 8
) (
input logic sclk,
input logic rstn,
input logic [REG_SIZE-1:0] wr_data,
input logic [1:0] wr_addr,
input logic wr_data_valid,
output logic [REG_SIZE-1:0] rd_data,
input logic [1:0] rd_addr,
output logic [7:0] dummy_cycles,
output logic en_qpi,
output logic [15:0] wrap_length
);
logic [REG_SIZE-1:0] reg0; // bit 0 enables qpi
logic [REG_SIZE-1:0] reg1; // number of dummy cycles
logic [REG_SIZE-1:0] reg2; // wrap length, low
logic [REG_SIZE-1:0] reg3; // wrap length, high
assign en_qpi = reg0[0];
assign dummy_cycles = reg1;
assign wrap_length = {reg3,reg2};
always_comb
begin
case(rd_addr)
2'b00:
rd_data = reg0;
2'b01:
rd_data = reg1;
2'b10:
rd_data = reg2;
2'b11:
rd_data = reg3;
endcase
end
always @(posedge sclk or negedge rstn)
begin
if (rstn == 0)
begin
reg0= 'h0;
reg1= 'd32;
reg2= 'h0;
reg3= 'h0;
end
else
begin
if (wr_data_valid)
begin
case(wr_addr)
2'b00:
reg0=wr_data;
2'b01:
reg1=wr_data;
2'b10:
reg2=wr_data;
2'b11:
reg3=wr_data;
endcase
end
end
end
endmodule