1 |
34 |
fafa1971 |
//---------------------------------------------------------------------------
|
2 |
|
|
// Wishbone DDR Controller
|
3 |
|
|
//
|
4 |
|
|
// (c) Joerg Bornschein (<jb@capsec.org>)
|
5 |
|
|
//---------------------------------------------------------------------------
|
6 |
|
|
|
7 |
|
|
`ifdef WBDDR_INCLUDE_V
|
8 |
|
|
`else
|
9 |
|
|
`define WBDDR_INCLUDE_V
|
10 |
|
|
|
11 |
|
|
`timescale 1ns/10ps
|
12 |
|
|
|
13 |
|
|
//---------------------------------------------------------------------------
|
14 |
|
|
// Frequency and timeouts
|
15 |
|
|
//---------------------------------------------------------------------------
|
16 |
|
|
`define SYS_CLK_FREQUENCY 50000 // in kHz
|
17 |
|
|
`define DDR_CLK_MULTIPLY 5
|
18 |
|
|
`define DDR_CLK_DIVIDE 2
|
19 |
|
|
|
20 |
|
|
//---------------------------------------------------------------------------
|
21 |
|
|
// Width
|
22 |
|
|
//---------------------------------------------------------------------------
|
23 |
|
|
`define CMD_WIDTH 3
|
24 |
|
|
`define A_WIDTH 13
|
25 |
|
|
`define BA_WIDTH 2
|
26 |
|
|
`define DQ_WIDTH 16
|
27 |
|
|
`define DQS_WIDTH 2
|
28 |
|
|
`define DM_WIDTH 2
|
29 |
|
|
|
30 |
|
|
`define RFIFO_WIDTH (2 * `DQ_WIDTH )
|
31 |
|
|
`define WFIFO_WIDTH (2 * (`DQ_WIDTH + `DM_WIDTH))
|
32 |
|
|
`define CBA_WIDTH (`CMD_WIDTH+`BA_WIDTH+`A_WIDTH)
|
33 |
|
|
|
34 |
|
|
// Ranges
|
35 |
|
|
`define CMD_RNG (`CMD_WIDTH-1):0
|
36 |
|
|
`define A_RNG (`A_WIDTH-1):0
|
37 |
|
|
`define BA_RNG (`BA_WIDTH-1):0
|
38 |
|
|
`define DQ_RNG (`DQ_WIDTH-1):0
|
39 |
|
|
`define DQS_RNG (`DQS_WIDTH-1):0
|
40 |
|
|
`define DM_RNG (`DM_WIDTH-1):0
|
41 |
|
|
|
42 |
|
|
`define RFIFO_RNG (`RFIFO_WIDTH-1):0
|
43 |
|
|
`define WFIFO_RNG (`WFIFO_WIDTH-1):0
|
44 |
|
|
`define WFIFO_D0_RNG (1*`DQ_WIDTH-1):0
|
45 |
|
|
`define WFIFO_D1_RNG (2*`DQ_WIDTH-1):(`DQ_WIDTH)
|
46 |
|
|
`define WFIFO_M0_RNG (2*`DQ_WIDTH+1*`DM_WIDTH-1):(2*`DQ_WIDTH+0*`DM_WIDTH)
|
47 |
|
|
`define WFIFO_M1_RNG (2*`DQ_WIDTH+2*`DM_WIDTH-1):(2*`DQ_WIDTH+1*`DM_WIDTH)
|
48 |
|
|
`define CBA_RNG (`CBA_WIDTH-1):0
|
49 |
|
|
`define CBA_CMD_RNG (`CBA_WIDTH-1):(`CBA_WIDTH-3)
|
50 |
|
|
`define CBA_BA_RNG (`CBA_WIDTH-4):(`CBA_WIDTH-5)
|
51 |
|
|
`define CBA_A_RNG (`CBA_WIDTH-6):0
|
52 |
|
|
|
53 |
|
|
`define ROW_RNG 12:0
|
54 |
|
|
|
55 |
|
|
//----------------------------------------------------------------------------
|
56 |
|
|
// Configuration registers
|
57 |
|
|
//----------------------------------------------------------------------------
|
58 |
|
|
`define DDR_INIT_EMRS `A_WIDTH'b0000000000000 // DLL enable
|
59 |
|
|
`define DDR_INIT_MRS1 `A_WIDTH'b0000101100011 // BURST=8, CL=2.5, DLL RESET
|
60 |
|
|
`define DDR_INIT_MRS2 `A_WIDTH'b0000001100011 // BURST=8, CL=2.5
|
61 |
|
|
|
62 |
|
|
//----------------------------------------------------------------------------
|
63 |
|
|
// FML constants
|
64 |
|
|
//----------------------------------------------------------------------------
|
65 |
|
|
`define FML_ADR_RNG 25:4
|
66 |
|
|
`define FML_ADR_BA_RNG 25:24
|
67 |
|
|
`define FML_ADR_ROW_RNG 23:11
|
68 |
|
|
`define FML_ADR_COL_RNG 10:4
|
69 |
|
|
`define FML_DAT_RNG 31:0
|
70 |
|
|
`define FML_BE_RNG 3:0
|
71 |
|
|
|
72 |
|
|
//----------------------------------------------------------------------------
|
73 |
|
|
// DDR constants
|
74 |
|
|
//----------------------------------------------------------------------------
|
75 |
|
|
`define DDR_CMD_NOP 3'b111
|
76 |
|
|
`define DDR_CMD_ACT 3'b011
|
77 |
|
|
`define DDR_CMD_READ 3'b101
|
78 |
|
|
`define DDR_CMD_WRITE 3'b100
|
79 |
|
|
`define DDR_CMD_TERM 3'b110
|
80 |
|
|
`define DDR_CMD_PRE 3'b010
|
81 |
|
|
`define DDR_CMD_AR 3'b001
|
82 |
|
|
`define DDR_CMD_MRS 3'b000
|
83 |
|
|
|
84 |
|
|
`define ADR_BA_RNG 25:24
|
85 |
|
|
`define ADR_ROW_RNG 23:11
|
86 |
|
|
`define ADR_COL_RNG 10:4
|
87 |
|
|
|
88 |
|
|
`define T_MRD 2 // Mode register set
|
89 |
|
|
`define T_RP 2 // Precharge Command Period
|
90 |
|
|
`define T_RFC 8 // Precharge Command Period
|
91 |
|
|
|
92 |
|
|
//----------------------------------------------------------------------------
|
93 |
|
|
// Buffer Cache
|
94 |
|
|
//----------------------------------------------------------------------------
|
95 |
|
|
`define WAY_WIDTH (`WB_DAT_WIDTH + `WB_SEL_WIDTH)
|
96 |
|
|
`define WAY_LINE_RNG (`WAY_WIDTH-1):0
|
97 |
|
|
`define WAY_DAT_RNG 31:0
|
98 |
|
|
`define WAY_VALID_RNG 35:32
|
99 |
|
|
|
100 |
|
|
`define TAG_LINE_RNG 32:0
|
101 |
|
|
`define TAG_LINE_TAG0_RNG 14:0
|
102 |
|
|
`define TAG_LINE_TAG1_RNG 29:15
|
103 |
|
|
`define TAG_LINE_DIRTY0_RNG 30
|
104 |
|
|
`define TAG_LINE_DIRTY1_RNG 31
|
105 |
|
|
`define TAG_LINE_LRU_RNG 32
|
106 |
|
|
|
107 |
|
|
//----------------------------------------------------------------------------
|
108 |
|
|
// Whishbone constants
|
109 |
|
|
//----------------------------------------------------------------------------
|
110 |
|
|
`define WB_ADR_WIDTH 32
|
111 |
|
|
`define WB_DAT_WIDTH 32
|
112 |
|
|
`define WB_SEL_WIDTH 4
|
113 |
|
|
|
114 |
|
|
`define WB_ADR_RNG (`WB_ADR_WIDTH-1):0
|
115 |
|
|
`define WB_DAT_RNG (`WB_DAT_WIDTH-1):0
|
116 |
|
|
`define WB_SEL_RNG (`WB_SEL_WIDTH-1):0
|
117 |
|
|
|
118 |
|
|
`define WB_WORD_RNG 3:2
|
119 |
|
|
`define WB_SET_RNG 10:4
|
120 |
|
|
`define WB_TAG_RNG 25:11
|
121 |
|
|
|
122 |
|
|
`endif
|