OpenCores
URL https://opencores.org/ocsvn/m1_core/m1_core/trunk

Subversion Repositories m1_core

[/] [m1_core/] [trunk/] [hdl/] [rtl/] [wb_ddr_ctrl/] [ddr_include.v] - Blame information for rev 54

Details | Compare with Previous | View Log

Line No. Rev Author Line
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

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.