Hardware Design: SIE
Sign in or create your account | Project List | Help
Hardware Design: SIE Git Source Tree
Root/
| 1 | //---------------------------------------------------------------------------- |
| 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 |
| 123 |
Branches:
master
