Mario Six | 538b575 | 2018-08-06 10:23:30 +0200 | [diff] [blame] | 1 | MPC83xx RAM controller |
| 2 | |
| 3 | This driver supplies support for the embedded RAM controller on MCP83xx-series |
| 4 | SoCs. |
| 5 | |
| 6 | For static configuration mode, each controller node should have child nodes |
| 7 | describing the actual RAM modules installed. |
| 8 | |
| 9 | Controller node |
| 10 | =============== |
| 11 | |
| 12 | Required properties: |
| 13 | - compatible: Must be "fsl,mpc83xx-mem-controller" |
| 14 | - reg: The address of the RAM controller's register space |
| 15 | - #address-cells: Must be 2 |
| 16 | - #size-cells: Must be 1 |
| 17 | - driver_software_override: DDR driver software override is enabled (1) or |
| 18 | disabled (0) |
| 19 | - p_impedance_override: DDR driver software p-impedance override; possible |
| 20 | values: |
| 21 | * DSO_P_IMPEDANCE_HIGHEST_Z |
| 22 | * DSO_P_IMPEDANCE_MUCH_HIGHER_Z |
| 23 | * DSO_P_IMPEDANCE_HIGHER_Z |
| 24 | * DSO_P_IMPEDANCE_NOMINAL |
| 25 | * DSO_P_IMPEDANCE_LOWER_Z |
| 26 | - n_impedance_override: DDR driver software n-impedance override; possible |
| 27 | values: |
| 28 | * DSO_N_IMPEDANCE_HIGHEST_Z |
| 29 | * DSO_N_IMPEDANCE_MUCH_HIGHER_Z |
| 30 | * DSO_N_IMPEDANCE_HIGHER_Z |
| 31 | * DSO_N_IMPEDANCE_NOMINAL |
| 32 | * DSO_N_IMPEDANCE_LOWER_Z |
| 33 | - odt_termination_value: ODT termination value for I/Os; possible values: |
| 34 | * ODT_TERMINATION_75_OHM |
| 35 | * ODT_TERMINATION_150_OHM |
| 36 | - ddr_type: Selects voltage level for DDR pads; possible |
| 37 | values: |
| 38 | * DDR_TYPE_DDR2_1_8_VOLT |
| 39 | * DDR_TYPE_DDR1_2_5_VOLT |
| 40 | - mvref_sel: Determine where MVREF_SEL signal is generated; |
| 41 | possible values: |
| 42 | * MVREF_SEL_EXTERNAL |
| 43 | * MVREF_SEL_INTERNAL_GVDD |
| 44 | - m_odr: Disable memory transaction reordering; possible |
| 45 | values: |
| 46 | * M_ODR_ENABLE |
| 47 | * M_ODR_DISABLE |
| 48 | - clock_adjust: Clock adjust; possible values: |
| 49 | * CLOCK_ADJUST_025 |
| 50 | * CLOCK_ADJUST_05 |
| 51 | * CLOCK_ADJUST_075 |
| 52 | * CLOCK_ADJUST_1 |
| 53 | - ext_refresh_rec: Extended refresh recovery time; possible values: |
| 54 | 0, 16, 32, 48, 64, 80, 96, 112 |
| 55 | - read_to_write: Read-to-write turnaround; possible values: |
| 56 | 0, 1, 2, 3 |
| 57 | - write_to_read: Write-to-read turnaround; possible values: |
| 58 | 0, 1, 2, 3 |
| 59 | - read_to_read: Read-to-read turnaround; possible values: |
| 60 | 0, 1, 2, 3 |
| 61 | - write_to_write: Write-to-write turnaround; possible values: |
| 62 | 0, 1, 2, 3 |
| 63 | - active_powerdown_exit: Active powerdown exit timing; possible values: |
| 64 | 1, 2, 3, 4, 5, 6, 7 |
| 65 | - precharge_powerdown_exit: Precharge powerdown exit timing; possible values: |
| 66 | 1, 2, 3, 4, 5, 6, 7 |
| 67 | - odt_powerdown_exit: ODT powerdown exit timing; possible values: |
| 68 | 0, 1, 2, 3, 4, 5, 6, 7, 8, |
| 69 | 9, 10, 11, 12, 13, 14, 15 |
| 70 | - mode_reg_set_cycle: Mode register set cycle time; possible values: |
| 71 | 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15 |
| 72 | - precharge_to_activate: Precharge-to-acitvate interval; possible values: |
| 73 | 1, 2, 3, 4, 5, 6, 7 |
| 74 | - activate_to_precharge: Activate to precharge interval; possible values: |
| 75 | 4, 5, 6, 7, 8, 9, 10, 11, 12, |
| 76 | 13, 14, 15, 16, 17, 18, 19 |
| 77 | - activate_to_readwrite: Activate to read/write interval for SDRAM; |
| 78 | possible values: |
| 79 | 1, 2, 3, 4, 5, 6, 7 |
| 80 | - mcas_latency: MCAS latency from READ command; possible values: |
| 81 | * CASLAT_20 |
| 82 | * CASLAT_25 |
| 83 | * CASLAT_30 |
| 84 | * CASLAT_35 |
| 85 | * CASLAT_40 |
| 86 | * CASLAT_45 |
| 87 | * CASLAT_50 |
| 88 | * CASLAT_55 |
| 89 | * CASLAT_60 |
| 90 | * CASLAT_65 |
| 91 | * CASLAT_70 |
| 92 | * CASLAT_75 |
| 93 | * CASLAT_80 |
| 94 | - refresh_recovery: Refresh recovery time; possible values: |
| 95 | 8, 9, 10, 11, 12, 13, 14, 15, |
| 96 | 16, 17, 18, 19, 20, 21, 22, 23 |
| 97 | - last_data_to_precharge: Last data to precharge minimum interval; possible |
| 98 | values: |
| 99 | 1, 2, 3, 4, 5, 6, 7 |
| 100 | - activate_to_activate: Activate-to-activate interval; possible values: |
| 101 | 1, 2, 3, 4, 5, 6, 7 |
| 102 | - last_write_data_to_read: Last write data pair to read command issue |
| 103 | interval; possible values: |
| 104 | 1, 2, 3, 4, 5, 6, 7 |
| 105 | - additive_latency: Additive latency; possible values: |
| 106 | 0, 1, 2, 3, 4, 5 |
| 107 | - mcas_to_preamble_override: MCAS-to-preamble-override; possible values: |
| 108 | * READ_LAT |
| 109 | * READ_LAT_PLUS_1_4 |
| 110 | * READ_LAT_PLUS_1_2 |
| 111 | * READ_LAT_PLUS_3_4 |
| 112 | * READ_LAT_PLUS_1 |
| 113 | * READ_LAT_PLUS_5_4 |
| 114 | * READ_LAT_PLUS_3_2 |
| 115 | * READ_LAT_PLUS_7_4 |
| 116 | * READ_LAT_PLUS_2 |
| 117 | * READ_LAT_PLUS_9_4 |
| 118 | * READ_LAT_PLUS_5_2 |
| 119 | * READ_LAT_PLUS_11_4 |
| 120 | * READ_LAT_PLUS_3 |
| 121 | * READ_LAT_PLUS_13_4 |
| 122 | * READ_LAT_PLUS_7_2 |
| 123 | * READ_LAT_PLUS_15_4 |
| 124 | * READ_LAT_PLUS_4 |
| 125 | * READ_LAT_PLUS_17_4 |
| 126 | * READ_LAT_PLUS_9_2 |
| 127 | * READ_LAT_PLUS_19_4 |
| 128 | - write_latency: Write latency; possible values: |
| 129 | 1, 2, 3, 4, 5, 6, 7 |
| 130 | - read_to_precharge: Read to precharge; possible values: |
| 131 | 1, 2, 3, 4 |
| 132 | - write_cmd_to_write_data: Write command to write data strobe timing |
| 133 | adjustment; possible values: |
| 134 | * CLOCK_DELAY_0 |
| 135 | * CLOCK_DELAY_1_4 |
| 136 | * CLOCK_DELAY_1_2 |
| 137 | * CLOCK_DELAY_3_4 |
| 138 | * CLOCK_DELAY_1 |
| 139 | * CLOCK_DELAY_5_4 |
| 140 | * CLOCK_DELAY_3_2 |
| 141 | - minimum_cke_pulse_width: Minimum CKE pulse width; possible values: |
| 142 | 1, 2, 3, 4 |
| 143 | - four_activates_window: Window for four activates; possible values: |
| 144 | 1, 2, 3, 4 8, 9, 10, 11, 12, |
| 145 | 13, 14, 15, 16, 17, 18, 19 |
| 146 | - self_refresh: Self refresh (during sleep); possible values: |
| 147 | * SREN_DISABLE |
| 148 | * SREN_ENABLE |
| 149 | - ecc: Support for ECC; possible values: |
| 150 | * ECC_DISABLE |
| 151 | * ECC_ENABLE |
| 152 | - registered_dram: Support for registered DRAM; possible values: |
| 153 | * RD_DISABLE |
| 154 | * RD_ENABLE |
| 155 | - sdram_type: Type of SDRAM device to be used; possible values: |
| 156 | * TYPE_DDR1 |
| 157 | * TYPE_DDR2 |
| 158 | - dynamic_power_management: Dynamic power management mode; possible values: |
| 159 | * DYN_PWR_DISABLE |
| 160 | * DYN_PWR_ENABLE |
| 161 | - databus_width: DRAM data bus width; possible values |
| 162 | * DATA_BUS_WIDTH_16 |
| 163 | * DATA_BUS_WIDTH_32 |
| 164 | - nc_auto_precharge: Non-concurrent auto-precharge; possible values: |
| 165 | * NCAP_DISABLE |
| 166 | * NCAP_ENABLE |
| 167 | - timing_2t: 2T timing; possible values: |
| 168 | * TIMING_1T |
| 169 | * TIMING_2T |
| 170 | - bank_interleaving_ctrl: Bank (chip select) interleaving control; possible |
| 171 | values: |
| 172 | * INTERLEAVE_NONE |
| 173 | * INTERLEAVE_1_AND_2 |
| 174 | - precharge_bit_8: Precharge bin 8; possible values |
| 175 | * PRECHARGE_MA_10 |
| 176 | * PRECHARGE_MA_8 |
| 177 | - half_strength: Global half-strength override; possible values: |
| 178 | * STRENGTH_FULL |
| 179 | * STRENGTH_HALF |
| 180 | - bypass_initialization: Bypass initialization; possible values: |
| 181 | * INITIALIZATION_DONT_BYPASS |
| 182 | * INITIALIZATION_BYPASS |
| 183 | - force_self_refresh: Force self refresh; possible values: |
| 184 | * MODE_NORMAL |
| 185 | * MODE_REFRESH |
| 186 | - dll_reset: DLL reset; possible values: |
| 187 | * DLL_RESET_ENABLE |
| 188 | * DLL_RESET_DISABLE |
| 189 | - dqs_config: DQS configuration; possible values: |
| 190 | * DQS_TRUE |
| 191 | - odt_config: ODT configuration; possible values: |
| 192 | * ODT_ASSERT_NEVER |
| 193 | * ODT_ASSERT_WRITES |
| 194 | * ODT_ASSERT_READS |
| 195 | * ODT_ASSERT_ALWAYS |
| 196 | - posted_refreshes: Number of posted refreshes |
| 197 | 1, 2, 3, 4, 5, 6, 7, 8 |
| 198 | - sdmode: Initial value loaded into the DDR SDRAM mode |
| 199 | register |
| 200 | - esdmode: Initial value loaded into the DDR SDRAM extended |
| 201 | mode register |
| 202 | - esdmode2: Initial value loaded into the DDR SDRAM extended |
| 203 | mode 2 register |
| 204 | - esdmode3: Initial value loaded into the DDR SDRAM extended |
| 205 | mode 3 register |
| 206 | - refresh_interval: Refresh interval; possible values: |
| 207 | 0 - 65535 |
| 208 | - precharge_interval: Precharge interval; possible values: |
| 209 | 0 - 16383 |
| 210 | |
| 211 | RAM module node: |
| 212 | ================ |
| 213 | |
| 214 | Required properties: |
| 215 | - reg: A triple <cs addr size>, which consists of: |
| 216 | * cs - the chipselect used to drive this RAM module |
| 217 | * addr - the address where this RAM module's memory is map |
| 218 | to in the global memory space |
| 219 | * size - the size of the RAM module's memory in bytes |
| 220 | - auto_precharge: Chip select auto-precharge; possible values: |
| 221 | * AUTO_PRECHARGE_ENABLE |
| 222 | * AUTO_PRECHARGE_DISABLE |
| 223 | - odt_rd_cfg: ODT for reads configuration; possible values: |
| 224 | * ODT_RD_NEVER |
| 225 | * ODT_RD_ONLY_CURRENT |
| 226 | * ODT_RD_ONLY_OTHER_CS |
| 227 | * ODT_RD_ONLY_OTHER_DIMM |
| 228 | * ODT_RD_ALL |
| 229 | - odt_wr_cfg: ODT for writes configuration; possible values: |
| 230 | * ODT_WR_NEVER |
| 231 | * ODT_WR_ONLY_CURRENT |
| 232 | * ODT_WR_ONLY_OTHER_CS |
| 233 | * ODT_WR_ONLY_OTHER_DIMM |
| 234 | * ODT_WR_ALL |
| 235 | - bank_bits: Number of bank bits for SDRAM on chip select; possible |
| 236 | values: |
| 237 | 2, 3 |
| 238 | - row_bits: Number of row bits for SDRAM on chip select; possible values: |
| 239 | 12, 13, 14 |
| 240 | - col_bits: Number of column bits for SDRAM on chip select; possible |
| 241 | values: |
| 242 | 8, 9, 10, 11 |
| 243 | |
| 244 | Example: |
| 245 | |
| 246 | memory@2000 { |
| 247 | #address-cells = <2>; |
| 248 | #size-cells = <1>; |
| 249 | compatible = "fsl,mpc83xx-mem-controller"; |
| 250 | reg = <0x2000 0x1000>; |
| 251 | device_type = "memory"; |
Simon Glass | 07a8b62 | 2023-02-13 08:56:35 -0700 | [diff] [blame^] | 252 | bootph-all; |
Mario Six | 538b575 | 2018-08-06 10:23:30 +0200 | [diff] [blame] | 253 | |
| 254 | driver_software_override = <DSO_ENABLE>; |
| 255 | p_impedance_override = <DSO_P_IMPEDANCE_NOMINAL>; |
| 256 | n_impedance_override = <DSO_N_IMPEDANCE_NOMINAL>; |
| 257 | odt_termination_value = <ODT_TERMINATION_150_OHM>; |
| 258 | ddr_type = <DDR_TYPE_DDR2_1_8_VOLT>; |
| 259 | |
| 260 | clock_adjust = <CLOCK_ADJUST_05>; |
| 261 | |
| 262 | read_to_write = <0>; |
| 263 | write_to_read = <0>; |
| 264 | read_to_read = <0>; |
| 265 | write_to_write = <0>; |
| 266 | active_powerdown_exit = <2>; |
| 267 | precharge_powerdown_exit = <6>; |
| 268 | odt_powerdown_exit = <8>; |
| 269 | mode_reg_set_cycle = <2>; |
| 270 | |
| 271 | precharge_to_activate = <2>; |
| 272 | activate_to_precharge = <6>; |
| 273 | activate_to_readwrite = <2>; |
| 274 | mcas_latency = <CASLAT_40>; |
| 275 | refresh_recovery = <17>; |
| 276 | last_data_to_precharge = <2>; |
| 277 | activate_to_activate = <2>; |
| 278 | last_write_data_to_read = <2>; |
| 279 | |
| 280 | additive_latency = <0>; |
| 281 | mcas_to_preamble_override = <READ_LAT_PLUS_1_2>; |
| 282 | write_latency = <3>; |
| 283 | read_to_precharge = <2>; |
| 284 | write_cmd_to_write_data = <CLOCK_DELAY_1_2>; |
| 285 | minimum_cke_pulse_width = <3>; |
| 286 | four_activates_window = <5>; |
| 287 | |
| 288 | self_refresh = <SREN_ENABLE>; |
| 289 | sdram_type = <TYPE_DDR2>; |
| 290 | databus_width = <DATA_BUS_WIDTH_32>; |
| 291 | |
| 292 | force_self_refresh = <MODE_NORMAL>; |
| 293 | dll_reset = <DLL_RESET_ENABLE>; |
| 294 | dqs_config = <DQS_TRUE>; |
| 295 | odt_config = <ODT_ASSERT_READS>; |
| 296 | posted_refreshes = <1>; |
| 297 | |
| 298 | refresh_interval = <2084>; |
| 299 | precharge_interval = <256>; |
| 300 | |
| 301 | sdmode = <0x0242>; |
| 302 | esdmode = <0x0440>; |
| 303 | |
| 304 | ram@0 { |
| 305 | reg = <0x0 0x0 0x8000000>; |
| 306 | compatible = "nanya,nt5tu64m16hg"; |
| 307 | |
| 308 | odt_rd_cfg = <ODT_RD_NEVER>; |
| 309 | odt_wr_cfg = <ODT_WR_ONLY_CURRENT>; |
| 310 | bank_bits = <3>; |
| 311 | row_bits = <13>; |
| 312 | col_bits = <10>; |
| 313 | }; |
| 314 | }; |