Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
CTCaer
GitHub Repository: CTCaer/hekate
Path: blob/master/bdk/mem/sdram.c
3694 views
1
/*
2
* Copyright (c) 2018 naehrwert
3
* Copyright (c) 2018 balika011
4
* Copyright (c) 2019-2025 CTCaer
5
*
6
* This program is free software; you can redistribute it and/or modify it
7
* under the terms and conditions of the GNU General Public License,
8
* version 2, as published by the Free Software Foundation.
9
*
10
* This program is distributed in the hope it will be useful, but WITHOUT
11
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
12
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
13
* more details.
14
*
15
* You should have received a copy of the GNU General Public License
16
* along with this program. If not, see <http://www.gnu.org/licenses/>.
17
*/
18
19
#include <string.h>
20
21
#include <mem/mc.h>
22
#include <mem/emc_t210.h>
23
#include <mem/sdram.h>
24
#include <mem/sdram_param_t210.h>
25
#include <mem/sdram_param_t210b01.h>
26
#include <memory_map.h>
27
#include <power/max77620.h>
28
#include <power/max7762x.h>
29
#include <soc/clock.h>
30
#include <soc/fuse.h>
31
#include <soc/hw_init.h>
32
#include <soc/i2c.h>
33
#include <soc/pmc.h>
34
#include <soc/timer.h>
35
#include <soc/t210.h>
36
37
#define DRAM_ID(x) BIT(x)
38
#define DRAM_CC(x) BIT(x)
39
40
typedef struct _sdram_vendor_patch_t
41
{
42
u32 val;
43
u32 dramcf:16;
44
u32 offset:16;
45
} sdram_vendor_patch_t;
46
47
static const u8 dram_encoding_t210b01[] = {
48
/* 00 */ LPDDR4X_UNUSED,
49
/* 01 */ LPDDR4X_UNUSED,
50
/* 02 */ LPDDR4X_UNUSED,
51
/* 03 */ LPDDR4X_4GB_HYNIX_H9HCNNNBKMMLXR_NEE,
52
/* 04 */ LPDDR4X_UNUSED,
53
/* 05 */ LPDDR4X_4GB_HYNIX_H9HCNNNBKMMLXR_NEE,
54
/* 06 */ LPDDR4X_4GB_HYNIX_H9HCNNNBKMMLXR_NEE,
55
/* 07 */ LPDDR4X_UNUSED,
56
/* 08 */ LPDDR4X_NO_PATCH,
57
/* 09 */ LPDDR4X_8GB_SAMSUNG_K4UBE3D4AM_MGCJ,
58
/* 10 */ LPDDR4X_NO_PATCH,
59
/* 11 */ LPDDR4X_4GB_MICRON_MT53E512M32D2NP_046_WTE,
60
/* 12 */ LPDDR4X_NO_PATCH,
61
/* 13 */ LPDDR4X_8GB_SAMSUNG_K4UBE3D4AM_MGCJ,
62
/* 14 */ LPDDR4X_NO_PATCH,
63
/* 15 */ LPDDR4X_4GB_MICRON_MT53E512M32D2NP_046_WTE,
64
/* 16 */ LPDDR4X_UNUSED,
65
/* 17 */ LPDDR4X_4GB_SAMSUNG_K4U6E3S4AA_MGCL,
66
/* 18 */ LPDDR4X_8GB_SAMSUNG_K4UBE3D4AA_MGCL,
67
/* 19 */ LPDDR4X_4GB_SAMSUNG_K4U6E3S4AA_MGCL,
68
/* 20 */ LPDDR4X_4GB_SAMSUNG_K4U6E3S4AB_MGCL,
69
/* 21 */ LPDDR4X_4GB_SAMSUNG_K4U6E3S4AB_MGCL,
70
/* 22 */ LPDDR4X_4GB_SAMSUNG_K4U6E3S4AB_MGCL,
71
/* 23 */ LPDDR4X_8GB_SAMSUNG_K4UBE3D4AA_MGCL,
72
/* 24 */ LPDDR4X_4GB_SAMSUNG_K4U6E3S4AA_MGCL,
73
/* 25 */ LPDDR4X_4GB_MICRON_MT53E512M32D2NP_046_WTF,
74
/* 26 */ LPDDR4X_4GB_MICRON_MT53E512M32D2NP_046_WTF,
75
/* 27 */ LPDDR4X_4GB_MICRON_MT53E512M32D2NP_046_WTF,
76
/* 28 */ LPDDR4X_8GB_SAMSUNG_K4UBE3D4AA_MGCL,
77
/* 29 */ LPDDR4X_4GB_HYNIX_H54G46CYRBX267,
78
/* 30 */ LPDDR4X_4GB_HYNIX_H54G46CYRBX267,
79
/* 31 */ LPDDR4X_4GB_HYNIX_H54G46CYRBX267,
80
/* 32 */ LPDDR4X_4GB_MICRON_MT53E512M32D1NP_046_WTB,
81
/* 33 */ LPDDR4X_4GB_MICRON_MT53E512M32D1NP_046_WTB,
82
/* 34 */ LPDDR4X_4GB_MICRON_MT53E512M32D1NP_046_WTB,
83
};
84
85
#include "sdram_config.inl"
86
#include "sdram_config_t210b01.inl"
87
88
static int _sdram_wait_emc_status(u32 reg_offset, u32 bit_mask, bool updated_state, s32 emc_channel)
89
{
90
int err = 1;
91
92
for (s32 i = 0; i < EMC_STATUS_UPDATE_TIMEOUT; i++)
93
{
94
if (emc_channel)
95
{
96
if (emc_channel != 1)
97
goto done;
98
99
if (((EMC_CH1(reg_offset) & bit_mask) != 0) == updated_state)
100
{
101
err = 0;
102
break;
103
}
104
}
105
else if (((EMC(reg_offset) & bit_mask) != 0) == updated_state)
106
{
107
err = 0;
108
break;
109
}
110
usleep(1);
111
}
112
113
done:
114
return err;
115
}
116
117
static void _sdram_req_mrr_data(u32 data, bool dual_channel)
118
{
119
EMC(EMC_MRR) = data;
120
_sdram_wait_emc_status(EMC_EMC_STATUS, EMC_STATUS_MRR_DIVLD, true, EMC_CHAN0);
121
if (dual_channel)
122
_sdram_wait_emc_status(EMC_EMC_STATUS, EMC_STATUS_MRR_DIVLD, true, EMC_CHAN1);
123
}
124
125
emc_mr_data_t sdram_read_mrx(emc_mr_t mrx)
126
{
127
emc_mr_data_t data;
128
u32 mrr;
129
bool dual_rank = EMC(EMC_ADR_CFG) & 1;
130
bool dual_channel = (EMC(EMC_FBIO_CFG7) >> 2) & 1; // Each EMC channel is a RAM chip module.
131
132
// Clear left overs.
133
for (u32 i = 0; i < 16; i++)
134
{
135
(void)EMC(EMC_MRR);
136
usleep(1);
137
}
138
139
memset(&data, 0xFF, sizeof(emc_mr_data_t));
140
141
/*
142
* When a dram chip has only one rank, then the info from the 2 ranks differs.
143
* Info not matching is only allowed on different channels.
144
*/
145
146
// Get Device 0 (Rank 0) info from both dram chips (channels).
147
_sdram_req_mrr_data((2u << 30) | (mrx << 16), dual_channel);
148
149
// Ram module 0 info.
150
mrr = EMC_CH0(EMC_MRR);
151
data.chip0.rank0_ch0 = mrr & 0xFF;
152
data.chip0.rank0_ch1 = (mrr & 0xFF00 >> 8);
153
154
// Ram module 1 info.
155
if (dual_channel)
156
{
157
mrr = EMC_CH1(EMC_MRR);
158
data.chip1.rank0_ch0 = mrr & 0xFF;
159
data.chip1.rank0_ch1 = (mrr & 0xFF00 >> 8);
160
}
161
162
// If Rank 1 exists, get info.
163
if (dual_rank)
164
{
165
// Get Device 1 (Rank 1) info from both dram chips (channels).
166
_sdram_req_mrr_data((1u << 30) | (mrx << 16), dual_channel);
167
168
// Ram module 0 info.
169
mrr = EMC_CH0(EMC_MRR);
170
data.chip0.rank1_ch0 = mrr & 0xFF;
171
data.chip0.rank1_ch1 = (mrr & 0xFF00 >> 8);
172
173
// Ram module 1 info.
174
if (dual_channel)
175
{
176
mrr = EMC_CH1(EMC_MRR);
177
data.chip1.rank1_ch0 = mrr & 0xFF;
178
data.chip1.rank1_ch1 = (mrr & 0xFF00 >> 8);
179
}
180
}
181
182
return data;
183
}
184
185
static void _sdram_config_t210(const sdram_params_t210_t *params)
186
{
187
// VDDP Select.
188
PMC(APBDEV_PMC_VDDP_SEL) = params->pmc_vddp_sel;
189
usleep(params->pmc_vddp_sel_wait);
190
191
// Set DDR pad voltage.
192
PMC(APBDEV_PMC_DDR_PWR) = PMC(APBDEV_PMC_DDR_PWR); // Normally params->pmc_ddr_pwr.
193
194
// Turn on MEM IO Power.
195
PMC(APBDEV_PMC_NO_IOPOWER) &= PMC_NO_IOPOWER_SDMMC1; // Only keep SDMMC1 state. (Was params->pmc_no_io_power).
196
PMC(APBDEV_PMC_REG_SHORT) = params->pmc_reg_short;
197
198
PMC(APBDEV_PMC_DDR_CNTRL) = params->pmc_ddr_ctrl;
199
200
// Patch 1 using BCT spare variables
201
if (params->emc_bct_spare0)
202
*(vu32 *)params->emc_bct_spare0 = params->emc_bct_spare1;
203
204
// Program DPD3/DPD4 regs (coldboot path).
205
// Enable sel_dpd on unused pins.
206
u32 dpd_req = (params->emc_pmc_scratch1 & 0x3FFFFFFF) | PMC_IO_DPD_REQ_DPD_ON;
207
PMC(APBDEV_PMC_IO_DPD3_REQ) = (dpd_req ^ 0xFFFF) & 0xC000FFFF;
208
usleep(params->pmc_io_dpd3_req_wait);
209
210
// Disable e_dpd_vttgen.
211
dpd_req = (params->emc_pmc_scratch2 & 0x3FFFFFFF) | PMC_IO_DPD_REQ_DPD_ON;
212
PMC(APBDEV_PMC_IO_DPD4_REQ) = (dpd_req & 0xFFFF0000) ^ 0x3FFF0000;
213
usleep(params->pmc_io_dpd4_req_wait);
214
215
// Disable e_dpd_bg.
216
PMC(APBDEV_PMC_IO_DPD4_REQ) = (dpd_req ^ 0xFFFF) & 0xC000FFFF;
217
usleep(params->pmc_io_dpd4_req_wait);
218
219
PMC(APBDEV_PMC_WEAK_BIAS) = 0;
220
usleep(1);
221
222
// Start PLLM.
223
CLOCK(CLK_RST_CONTROLLER_PLLM_MISC1) = params->pllm_setup_control;
224
CLOCK(CLK_RST_CONTROLLER_PLLM_MISC2) = 0;
225
226
u32 pllm_div = (params->pllm_feedback_divider << 8) | params->pllm_input_divider | ((params->pllm_post_divider & 0xFFFF) << 20);
227
CLOCK(CLK_RST_CONTROLLER_PLLM_BASE) = pllm_div;
228
CLOCK(CLK_RST_CONTROLLER_PLLM_BASE) = pllm_div | PLL_BASE_ENABLE;
229
230
u32 wait_end = get_tmr_us() + 300;
231
while (!(CLOCK(CLK_RST_CONTROLLER_PLLM_BASE) & BIT(27)))
232
{
233
if (get_tmr_us() >= wait_end)
234
goto lock_timeout;
235
}
236
usleep(10);
237
238
lock_timeout:
239
// Set clock sources.
240
CLOCK(CLK_RST_CONTROLLER_CLK_SOURCE_EMC) = ((params->mc_emem_arb_misc0 >> 11) & 0x10000) | (params->emc_clock_source & 0xFFFEFFFF);
241
if (params->emc_clock_source_dll)
242
CLOCK(CLK_RST_CONTROLLER_CLK_SOURCE_EMC_DLL) = params->emc_clock_source_dll;
243
if (params->clear_clock2_mc1)
244
CLOCK(CLK_RST_CONTROLLER_CLK_ENB_W_CLR) = BIT(CLK_W_MC1); // Clear Reset to MC1.
245
246
// Enable and clear reset for memory clocks.
247
CLOCK(CLK_RST_CONTROLLER_CLK_ENB_H_SET) = BIT(CLK_H_EMC) | BIT(CLK_H_MEM);
248
CLOCK(CLK_RST_CONTROLLER_CLK_ENB_X_SET) = BIT(CLK_X_EMC_DLL);
249
CLOCK(CLK_RST_CONTROLLER_RST_DEV_H_CLR) = BIT(CLK_H_EMC) | BIT(CLK_H_MEM);
250
251
// Set pad vtt levels.
252
EMC(EMC_PMACRO_VTTGEN_CTRL_0) = params->emc_pmacro_vttgen_ctrl0;
253
EMC(EMC_PMACRO_VTTGEN_CTRL_1) = params->emc_pmacro_vttgen_ctrl1;
254
EMC(EMC_PMACRO_VTTGEN_CTRL_2) = params->emc_pmacro_vttgen_ctrl2;
255
256
// Trigger timing update so above writes take place.
257
EMC(EMC_TIMING_CONTROL) = 1;
258
usleep(10); // Ensure the regulators settle.
259
260
// Select EMC write mux.
261
EMC(EMC_DBG) = (params->emc_dbg_write_mux << 1) | params->emc_dbg;
262
263
// Patch 2 using BCT spare variables.
264
if (params->emc_bct_spare2)
265
*(vu32 *)params->emc_bct_spare2 = params->emc_bct_spare3;
266
267
// Program CMD mapping. Required before brick mapping, else
268
// we can't guarantee CK will be differential at all times.
269
EMC(EMC_FBIO_CFG7) = params->emc_fbio_cfg7;
270
EMC(EMC_CMD_MAPPING_CMD0_0) = params->emc_cmd_mapping_cmd0_0;
271
EMC(EMC_CMD_MAPPING_CMD0_1) = params->emc_cmd_mapping_cmd0_1;
272
EMC(EMC_CMD_MAPPING_CMD0_2) = params->emc_cmd_mapping_cmd0_2;
273
EMC(EMC_CMD_MAPPING_CMD1_0) = params->emc_cmd_mapping_cmd1_0;
274
EMC(EMC_CMD_MAPPING_CMD1_1) = params->emc_cmd_mapping_cmd1_1;
275
EMC(EMC_CMD_MAPPING_CMD1_2) = params->emc_cmd_mapping_cmd1_2;
276
EMC(EMC_CMD_MAPPING_CMD2_0) = params->emc_cmd_mapping_cmd2_0;
277
EMC(EMC_CMD_MAPPING_CMD2_1) = params->emc_cmd_mapping_cmd2_1;
278
EMC(EMC_CMD_MAPPING_CMD2_2) = params->emc_cmd_mapping_cmd2_2;
279
EMC(EMC_CMD_MAPPING_CMD3_0) = params->emc_cmd_mapping_cmd3_0;
280
EMC(EMC_CMD_MAPPING_CMD3_1) = params->emc_cmd_mapping_cmd3_1;
281
EMC(EMC_CMD_MAPPING_CMD3_2) = params->emc_cmd_mapping_cmd3_2;
282
EMC(EMC_CMD_MAPPING_BYTE) = params->emc_cmd_mapping_byte;
283
284
// Program brick mapping.
285
EMC(EMC_PMACRO_BRICK_MAPPING_0) = params->emc_pmacro_brick_mapping0;
286
EMC(EMC_PMACRO_BRICK_MAPPING_1) = params->emc_pmacro_brick_mapping1;
287
EMC(EMC_PMACRO_BRICK_MAPPING_2) = params->emc_pmacro_brick_mapping2;
288
289
EMC(EMC_PMACRO_BRICK_CTRL_RFU1) = (params->emc_pmacro_brick_ctrl_rfu1 & 0x1120112) | 0x1EED1EED;
290
291
// This is required to do any reads from the pad macros.
292
EMC(EMC_CONFIG_SAMPLE_DELAY) = params->emc_config_sample_delay;
293
294
// Set data pipes mode.
295
EMC(EMC_FBIO_CFG8) = params->emc_fbio_cfg8;
296
297
// Set swizzle for Rank 0.
298
EMC(EMC_SWIZZLE_RANK0_BYTE0) = params->emc_swizzle_rank0_byte0;
299
EMC(EMC_SWIZZLE_RANK0_BYTE1) = params->emc_swizzle_rank0_byte1;
300
EMC(EMC_SWIZZLE_RANK0_BYTE2) = params->emc_swizzle_rank0_byte2;
301
EMC(EMC_SWIZZLE_RANK0_BYTE3) = params->emc_swizzle_rank0_byte3;
302
// Set swizzle for Rank 1.
303
EMC(EMC_SWIZZLE_RANK1_BYTE0) = params->emc_swizzle_rank1_byte0;
304
EMC(EMC_SWIZZLE_RANK1_BYTE1) = params->emc_swizzle_rank1_byte1;
305
EMC(EMC_SWIZZLE_RANK1_BYTE2) = params->emc_swizzle_rank1_byte2;
306
EMC(EMC_SWIZZLE_RANK1_BYTE3) = params->emc_swizzle_rank1_byte3;
307
308
// Patch 3 using BCT spare variables.
309
if (params->emc_bct_spare6)
310
*(vu32 *)params->emc_bct_spare6 = params->emc_bct_spare7;
311
312
// Program calibration impedance.
313
EMC(EMC_XM2COMPPADCTRL) = params->emc_xm2_comp_pad_ctrl;
314
EMC(EMC_XM2COMPPADCTRL2) = params->emc_xm2_comp_pad_ctrl2;
315
EMC(EMC_XM2COMPPADCTRL3) = params->emc_xm2_comp_pad_ctrl3;
316
317
// Program Autocal controls.
318
EMC(EMC_AUTO_CAL_CONFIG2) = params->emc_auto_cal_config2;
319
EMC(EMC_AUTO_CAL_CONFIG3) = params->emc_auto_cal_config3;
320
EMC(EMC_AUTO_CAL_CONFIG4) = params->emc_auto_cal_config4;
321
EMC(EMC_AUTO_CAL_CONFIG5) = params->emc_auto_cal_config5;
322
EMC(EMC_AUTO_CAL_CONFIG6) = params->emc_auto_cal_config6;
323
EMC(EMC_AUTO_CAL_CONFIG7) = params->emc_auto_cal_config7;
324
EMC(EMC_AUTO_CAL_CONFIG8) = params->emc_auto_cal_config8;
325
326
// Program termination and drive strength
327
EMC(EMC_PMACRO_RX_TERM) = params->emc_pmacro_rx_term;
328
EMC(EMC_PMACRO_DQ_TX_DRV) = params->emc_pmacro_dq_tx_drive;
329
EMC(EMC_PMACRO_CA_TX_DRV) = params->emc_pmacro_ca_tx_drive;
330
EMC(EMC_PMACRO_CMD_TX_DRV) = params->emc_pmacro_cmd_tx_drive;
331
EMC(EMC_PMACRO_AUTOCAL_CFG_COMMON) = params->emc_pmacro_auto_cal_common;
332
EMC(EMC_AUTO_CAL_CHANNEL) = params->emc_auto_cal_channel;
333
EMC(EMC_PMACRO_ZCTRL) = params->emc_pmacro_zcrtl;
334
335
// Program dll config.
336
EMC(EMC_DLL_CFG_0) = params->emc_dll_cfg0;
337
EMC(EMC_DLL_CFG_1) = params->emc_dll_cfg1;
338
EMC(EMC_CFG_DIG_DLL_1) = params->emc_cfg_dig_dll_1;
339
340
// Program barrelshift.
341
EMC(EMC_DATA_BRLSHFT_0) = params->emc_data_brlshft0;
342
EMC(EMC_DATA_BRLSHFT_1) = params->emc_data_brlshft1;
343
EMC(EMC_DQS_BRLSHFT_0) = params->emc_dqs_brlshft0;
344
EMC(EMC_DQS_BRLSHFT_1) = params->emc_dqs_brlshft1;
345
EMC(EMC_CMD_BRLSHFT_0) = params->emc_cmd_brlshft0;
346
EMC(EMC_CMD_BRLSHFT_1) = params->emc_cmd_brlshft1;
347
EMC(EMC_CMD_BRLSHFT_2) = params->emc_cmd_brlshft2;
348
EMC(EMC_CMD_BRLSHFT_3) = params->emc_cmd_brlshft3;
349
EMC(EMC_QUSE_BRLSHFT_0) = params->emc_quse_brlshft0;
350
EMC(EMC_QUSE_BRLSHFT_1) = params->emc_quse_brlshft1;
351
EMC(EMC_QUSE_BRLSHFT_2) = params->emc_quse_brlshft2;
352
EMC(EMC_QUSE_BRLSHFT_3) = params->emc_quse_brlshft3;
353
354
// Program pad macros controls and termination.
355
EMC(EMC_PMACRO_BRICK_CTRL_RFU1) = (params->emc_pmacro_brick_ctrl_rfu1 & 0x1BF01BF) | 0x1E401E40;
356
EMC(EMC_PMACRO_PAD_CFG_CTRL) = params->emc_pmacro_pad_cfg_ctrl;
357
358
EMC(EMC_PMACRO_CMD_BRICK_CTRL_FDPD) = params->emc_pmacro_cmd_brick_ctrl_fdpd;
359
EMC(EMC_PMACRO_BRICK_CTRL_RFU2) = params->emc_pmacro_brick_ctrl_rfu2 & 0xFF7FFF7F;
360
EMC(EMC_PMACRO_DATA_BRICK_CTRL_FDPD) = params->emc_pmacro_data_brick_ctrl_fdpd;
361
EMC(EMC_PMACRO_BG_BIAS_CTRL_0) = params->emc_pmacro_bg_bias_ctrl0;
362
EMC(EMC_PMACRO_DATA_PAD_RX_CTRL) = params->emc_pmacro_data_pad_rx_ctrl;
363
EMC(EMC_PMACRO_CMD_PAD_RX_CTRL) = params->emc_pmacro_cmd_pad_rx_ctrl;
364
EMC(EMC_PMACRO_DATA_PAD_TX_CTRL) = params->emc_pmacro_data_pad_tx_ctrl;
365
EMC(EMC_PMACRO_DATA_RX_TERM_MODE) = params->emc_pmacro_data_rx_term_mode;
366
EMC(EMC_PMACRO_CMD_RX_TERM_MODE) = params->emc_pmacro_cmd_rx_term_mode;
367
EMC(EMC_PMACRO_CMD_PAD_TX_CTRL) = params->emc_pmacro_cmd_pad_tx_ctrl;
368
369
// Program pad macro pins/bytes.
370
EMC(EMC_CFG_3) = params->emc_cfg3;
371
EMC(EMC_PMACRO_TX_PWRD_0) = params->emc_pmacro_tx_pwrd0;
372
EMC(EMC_PMACRO_TX_PWRD_1) = params->emc_pmacro_tx_pwrd1;
373
EMC(EMC_PMACRO_TX_PWRD_2) = params->emc_pmacro_tx_pwrd2;
374
EMC(EMC_PMACRO_TX_PWRD_3) = params->emc_pmacro_tx_pwrd3;
375
EMC(EMC_PMACRO_TX_PWRD_4) = params->emc_pmacro_tx_pwrd4;
376
EMC(EMC_PMACRO_TX_PWRD_5) = params->emc_pmacro_tx_pwrd5;
377
EMC(EMC_PMACRO_TX_SEL_CLK_SRC_0) = params->emc_pmacro_tx_sel_clk_src0;
378
EMC(EMC_PMACRO_TX_SEL_CLK_SRC_1) = params->emc_pmacro_tx_sel_clk_src1;
379
EMC(EMC_PMACRO_TX_SEL_CLK_SRC_2) = params->emc_pmacro_tx_sel_clk_src2;
380
EMC(EMC_PMACRO_TX_SEL_CLK_SRC_3) = params->emc_pmacro_tx_sel_clk_src3;
381
EMC(EMC_PMACRO_TX_SEL_CLK_SRC_4) = params->emc_pmacro_tx_sel_clk_src4;
382
EMC(EMC_PMACRO_TX_SEL_CLK_SRC_5) = params->emc_pmacro_tx_sel_clk_src5;
383
EMC(EMC_PMACRO_DDLL_BYPASS) = params->emc_pmacro_ddll_bypass;
384
EMC(EMC_PMACRO_DDLL_PWRD_0) = params->emc_pmacro_ddll_pwrd0;
385
EMC(EMC_PMACRO_DDLL_PWRD_1) = params->emc_pmacro_ddll_pwrd1;
386
EMC(EMC_PMACRO_DDLL_PWRD_2) = params->emc_pmacro_ddll_pwrd2;
387
EMC(EMC_PMACRO_CMD_CTRL_0) = params->emc_pmacro_cmd_ctrl0;
388
EMC(EMC_PMACRO_CMD_CTRL_1) = params->emc_pmacro_cmd_ctrl1;
389
EMC(EMC_PMACRO_CMD_CTRL_2) = params->emc_pmacro_cmd_ctrl2;
390
391
// Program inbound vref setting.
392
EMC(EMC_PMACRO_IB_VREF_DQ_0) = params->emc_pmacro_ib_vref_dq_0;
393
EMC(EMC_PMACRO_IB_VREF_DQ_1) = params->emc_pmacro_ib_vref_dq_1;
394
EMC(EMC_PMACRO_IB_VREF_DQS_0) = params->emc_pmacro_ib_vref_dqs_0;
395
EMC(EMC_PMACRO_IB_VREF_DQS_1) = params->emc_pmacro_ib_vref_dqs_1;
396
EMC(EMC_PMACRO_IB_RXRT) = params->emc_pmacro_ib_rxrt;
397
398
// Program quse trimmers.
399
EMC(EMC_PMACRO_QUSE_DDLL_RANK0_0) = params->emc_pmacro_quse_ddll_rank0_0;
400
EMC(EMC_PMACRO_QUSE_DDLL_RANK0_1) = params->emc_pmacro_quse_ddll_rank0_1;
401
EMC(EMC_PMACRO_QUSE_DDLL_RANK0_2) = params->emc_pmacro_quse_ddll_rank0_2;
402
EMC(EMC_PMACRO_QUSE_DDLL_RANK0_3) = params->emc_pmacro_quse_ddll_rank0_3;
403
EMC(EMC_PMACRO_QUSE_DDLL_RANK0_4) = params->emc_pmacro_quse_ddll_rank0_4;
404
EMC(EMC_PMACRO_QUSE_DDLL_RANK0_5) = params->emc_pmacro_quse_ddll_rank0_5;
405
EMC(EMC_PMACRO_QUSE_DDLL_RANK1_0) = params->emc_pmacro_quse_ddll_rank1_0;
406
EMC(EMC_PMACRO_QUSE_DDLL_RANK1_1) = params->emc_pmacro_quse_ddll_rank1_1;
407
EMC(EMC_PMACRO_QUSE_DDLL_RANK1_2) = params->emc_pmacro_quse_ddll_rank1_2;
408
EMC(EMC_PMACRO_QUSE_DDLL_RANK1_3) = params->emc_pmacro_quse_ddll_rank1_3;
409
EMC(EMC_PMACRO_QUSE_DDLL_RANK1_4) = params->emc_pmacro_quse_ddll_rank1_4;
410
EMC(EMC_PMACRO_QUSE_DDLL_RANK1_5) = params->emc_pmacro_quse_ddll_rank1_5;
411
EMC(EMC_PMACRO_BRICK_CTRL_RFU1) = params->emc_pmacro_brick_ctrl_rfu1;
412
413
// Program outbound trimmers.
414
EMC(EMC_PMACRO_OB_DDLL_LONG_DQ_RANK0_0) = params->emc_pmacro_ob_ddll_long_dq_rank0_0;
415
EMC(EMC_PMACRO_OB_DDLL_LONG_DQ_RANK0_1) = params->emc_pmacro_ob_ddll_long_dq_rank0_1;
416
EMC(EMC_PMACRO_OB_DDLL_LONG_DQ_RANK0_2) = params->emc_pmacro_ob_ddll_long_dq_rank0_2;
417
EMC(EMC_PMACRO_OB_DDLL_LONG_DQ_RANK0_3) = params->emc_pmacro_ob_ddll_long_dq_rank0_3;
418
EMC(EMC_PMACRO_OB_DDLL_LONG_DQ_RANK0_4) = params->emc_pmacro_ob_ddll_long_dq_rank0_4;
419
EMC(EMC_PMACRO_OB_DDLL_LONG_DQ_RANK0_5) = params->emc_pmacro_ob_ddll_long_dq_rank0_5;
420
EMC(EMC_PMACRO_OB_DDLL_LONG_DQ_RANK1_0) = params->emc_pmacro_ob_ddll_long_dq_rank1_0;
421
EMC(EMC_PMACRO_OB_DDLL_LONG_DQ_RANK1_1) = params->emc_pmacro_ob_ddll_long_dq_rank1_1;
422
EMC(EMC_PMACRO_OB_DDLL_LONG_DQ_RANK1_2) = params->emc_pmacro_ob_ddll_long_dq_rank1_2;
423
EMC(EMC_PMACRO_OB_DDLL_LONG_DQ_RANK1_3) = params->emc_pmacro_ob_ddll_long_dq_rank1_3;
424
EMC(EMC_PMACRO_OB_DDLL_LONG_DQ_RANK1_4) = params->emc_pmacro_ob_ddll_long_dq_rank1_4;
425
EMC(EMC_PMACRO_OB_DDLL_LONG_DQ_RANK1_5) = params->emc_pmacro_ob_ddll_long_dq_rank1_5;
426
427
EMC(EMC_PMACRO_OB_DDLL_LONG_DQS_RANK0_0) = params->emc_pmacro_ob_ddll_long_dqs_rank0_0;
428
EMC(EMC_PMACRO_OB_DDLL_LONG_DQS_RANK0_1) = params->emc_pmacro_ob_ddll_long_dqs_rank0_1;
429
EMC(EMC_PMACRO_OB_DDLL_LONG_DQS_RANK0_2) = params->emc_pmacro_ob_ddll_long_dqs_rank0_2;
430
EMC(EMC_PMACRO_OB_DDLL_LONG_DQS_RANK0_3) = params->emc_pmacro_ob_ddll_long_dqs_rank0_3;
431
EMC(EMC_PMACRO_OB_DDLL_LONG_DQS_RANK0_4) = params->emc_pmacro_ob_ddll_long_dqs_rank0_4;
432
EMC(EMC_PMACRO_OB_DDLL_LONG_DQS_RANK0_5) = params->emc_pmacro_ob_ddll_long_dqs_rank0_5;
433
EMC(EMC_PMACRO_OB_DDLL_LONG_DQS_RANK1_0) = params->emc_pmacro_ob_ddll_long_dqs_rank1_0;
434
EMC(EMC_PMACRO_OB_DDLL_LONG_DQS_RANK1_1) = params->emc_pmacro_ob_ddll_long_dqs_rank1_1;
435
EMC(EMC_PMACRO_OB_DDLL_LONG_DQS_RANK1_2) = params->emc_pmacro_ob_ddll_long_dqs_rank1_2;
436
EMC(EMC_PMACRO_OB_DDLL_LONG_DQS_RANK1_3) = params->emc_pmacro_ob_ddll_long_dqs_rank1_3;
437
EMC(EMC_PMACRO_OB_DDLL_LONG_DQS_RANK1_4) = params->emc_pmacro_ob_ddll_long_dqs_rank1_4;
438
EMC(EMC_PMACRO_OB_DDLL_LONG_DQS_RANK1_5) = params->emc_pmacro_ob_ddll_long_dqs_rank1_5;
439
EMC(EMC_PMACRO_IB_DDLL_LONG_DQS_RANK0_0) = params->emc_pmacro_ib_ddll_long_dqs_rank0_0;
440
EMC(EMC_PMACRO_IB_DDLL_LONG_DQS_RANK0_1) = params->emc_pmacro_ib_ddll_long_dqs_rank0_1;
441
EMC(EMC_PMACRO_IB_DDLL_LONG_DQS_RANK0_2) = params->emc_pmacro_ib_ddll_long_dqs_rank0_2;
442
EMC(EMC_PMACRO_IB_DDLL_LONG_DQS_RANK0_3) = params->emc_pmacro_ib_ddll_long_dqs_rank0_3;
443
EMC(EMC_PMACRO_IB_DDLL_LONG_DQS_RANK1_0) = params->emc_pmacro_ib_ddll_long_dqs_rank1_0;
444
EMC(EMC_PMACRO_IB_DDLL_LONG_DQS_RANK1_1) = params->emc_pmacro_ib_ddll_long_dqs_rank1_1;
445
EMC(EMC_PMACRO_IB_DDLL_LONG_DQS_RANK1_2) = params->emc_pmacro_ib_ddll_long_dqs_rank1_2;
446
EMC(EMC_PMACRO_IB_DDLL_LONG_DQS_RANK1_3) = params->emc_pmacro_ib_ddll_long_dqs_rank1_3;
447
448
// Program clock trimmers.
449
EMC(EMC_PMACRO_DDLL_LONG_CMD_0) = params->emc_pmacro_ddll_long_cmd_0;
450
EMC(EMC_PMACRO_DDLL_LONG_CMD_1) = params->emc_pmacro_ddll_long_cmd_1;
451
EMC(EMC_PMACRO_DDLL_LONG_CMD_2) = params->emc_pmacro_ddll_long_cmd_2;
452
EMC(EMC_PMACRO_DDLL_LONG_CMD_3) = params->emc_pmacro_ddll_long_cmd_3;
453
EMC(EMC_PMACRO_DDLL_LONG_CMD_4) = params->emc_pmacro_ddll_long_cmd_4;
454
EMC(EMC_PMACRO_DDLL_SHORT_CMD_0) = params->emc_pmacro_ddll_short_cmd_0;
455
EMC(EMC_PMACRO_DDLL_SHORT_CMD_1) = params->emc_pmacro_ddll_short_cmd_1;
456
EMC(EMC_PMACRO_DDLL_SHORT_CMD_2) = params->emc_pmacro_ddll_short_cmd_2;
457
458
// Common pad macro (cpm).
459
EMC(EMC_PMACRO_COMMON_PAD_TX_CTRL) = (params->emc_pmacro_common_pad_tx_ctrl & 1) | 0xE;
460
461
// Patch 4 using BCT spare variables.
462
if (params->emc_bct_spare4)
463
*(vu32 *)params->emc_bct_spare4 = params->emc_bct_spare5;
464
465
// Trigger timing update so above writes take place.
466
EMC(EMC_TIMING_CONTROL) = 1;
467
468
// Initialize MC VPR settings.
469
MC(MC_VIDEO_PROTECT_BOM) = params->mc_video_protect_bom;
470
MC(MC_VIDEO_PROTECT_BOM_ADR_HI) = params->mc_video_protect_bom_adr_hi;
471
MC(MC_VIDEO_PROTECT_SIZE_MB) = params->mc_video_protect_size_mb;
472
MC(MC_VIDEO_PROTECT_VPR_OVERRIDE) = params->mc_video_protect_vpr_override;
473
MC(MC_VIDEO_PROTECT_VPR_OVERRIDE1) = params->mc_video_protect_vpr_override1;
474
MC(MC_VIDEO_PROTECT_GPU_OVERRIDE_0) = params->mc_video_protect_gpu_override0;
475
MC(MC_VIDEO_PROTECT_GPU_OVERRIDE_1) = params->mc_video_protect_gpu_override1;
476
477
// Program SDRAM geometry parameters.
478
MC(MC_EMEM_ADR_CFG) = params->mc_emem_adr_cfg;
479
MC(MC_EMEM_ADR_CFG_DEV0) = params->mc_emem_adr_cfg_dev0;
480
MC(MC_EMEM_ADR_CFG_DEV1) = params->mc_emem_adr_cfg_dev1;
481
MC(MC_EMEM_ADR_CFG_CHANNEL_MASK) = params->mc_emem_adr_cfg_channel_mask;
482
483
// Program bank swizzling.
484
MC(MC_EMEM_ADR_CFG_BANK_MASK_0) = params->mc_emem_adr_cfg_bank_mask0;
485
MC(MC_EMEM_ADR_CFG_BANK_MASK_1) = params->mc_emem_adr_cfg_bank_mask1;
486
MC(MC_EMEM_ADR_CFG_BANK_MASK_2) = params->mc_emem_adr_cfg_bank_mask2;
487
488
// Program external memory aperture (base and size).
489
MC(MC_EMEM_CFG) = params->mc_emem_cfg;
490
491
// Program SEC carveout (base and size).
492
MC(MC_SEC_CARVEOUT_BOM) = params->mc_sec_carveout_bom;
493
MC(MC_SEC_CARVEOUT_ADR_HI) = params->mc_sec_carveout_adr_hi;
494
MC(MC_SEC_CARVEOUT_SIZE_MB) = params->mc_sec_carveout_size_mb;
495
496
// Program MTS carveout (base and size).
497
MC(MC_MTS_CARVEOUT_BOM) = params->mc_mts_carveout_bom;
498
MC(MC_MTS_CARVEOUT_ADR_HI) = params->mc_mts_carveout_adr_hi;
499
MC(MC_MTS_CARVEOUT_SIZE_MB) = params->mc_mts_carveout_size_mb;
500
501
// Program the memory arbiter.
502
MC(MC_EMEM_ARB_CFG) = params->mc_emem_arb_cfg;
503
MC(MC_EMEM_ARB_OUTSTANDING_REQ) = params->mc_emem_arb_outstanding_req;
504
MC(MC_EMEM_ARB_REFPB_HP_CTRL) = params->emc_emem_arb_refpb_hp_ctrl;
505
MC(MC_EMEM_ARB_REFPB_BANK_CTRL) = params->emc_emem_arb_refpb_bank_ctrl;
506
MC(MC_EMEM_ARB_TIMING_RCD) = params->mc_emem_arb_timing_rcd;
507
MC(MC_EMEM_ARB_TIMING_RP) = params->mc_emem_arb_timing_rp;
508
MC(MC_EMEM_ARB_TIMING_RC) = params->mc_emem_arb_timing_rc;
509
MC(MC_EMEM_ARB_TIMING_RAS) = params->mc_emem_arb_timing_ras;
510
MC(MC_EMEM_ARB_TIMING_FAW) = params->mc_emem_arb_timing_faw;
511
MC(MC_EMEM_ARB_TIMING_RRD) = params->mc_emem_arb_timing_rrd;
512
MC(MC_EMEM_ARB_TIMING_RAP2PRE) = params->mc_emem_arb_timing_rap2pre;
513
MC(MC_EMEM_ARB_TIMING_WAP2PRE) = params->mc_emem_arb_timing_wap2pre;
514
MC(MC_EMEM_ARB_TIMING_R2R) = params->mc_emem_arb_timing_r2r;
515
MC(MC_EMEM_ARB_TIMING_W2W) = params->mc_emem_arb_timing_w2w;
516
MC(MC_EMEM_ARB_TIMING_CCDMW) = params->mc_emem_arb_timing_ccdmw;
517
MC(MC_EMEM_ARB_TIMING_R2W) = params->mc_emem_arb_timing_r2w;
518
MC(MC_EMEM_ARB_TIMING_W2R) = params->mc_emem_arb_timing_w2r;
519
MC(MC_EMEM_ARB_TIMING_RFCPB) = params->mc_emem_arb_timing_rfcpb;
520
MC(MC_EMEM_ARB_DA_TURNS) = params->mc_emem_arb_da_turns;
521
MC(MC_EMEM_ARB_DA_COVERS) = params->mc_emem_arb_da_covers;
522
MC(MC_EMEM_ARB_MISC0) = params->mc_emem_arb_misc0;
523
MC(MC_EMEM_ARB_MISC1) = params->mc_emem_arb_misc1;
524
MC(MC_EMEM_ARB_MISC2) = params->mc_emem_arb_misc2;
525
MC(MC_EMEM_ARB_RING1_THROTTLE) = params->mc_emem_arb_ring1_throttle;
526
MC(MC_EMEM_ARB_OVERRIDE) = params->mc_emem_arb_override;
527
MC(MC_EMEM_ARB_OVERRIDE_1) = params->mc_emem_arb_override1;
528
MC(MC_EMEM_ARB_RSV) = params->mc_emem_arb_rsv;
529
MC(MC_DA_CONFIG0) = params->mc_da_cfg0;
530
531
// Trigger MC timing update.
532
MC(MC_TIMING_CONTROL) = 1;
533
534
// Program second-level clock enable overrides.
535
MC(MC_CLKEN_OVERRIDE) = params->mc_clken_override;
536
537
// Program statistics gathering.
538
MC(MC_STAT_CONTROL) = params->mc_stat_control;
539
540
// Program SDRAM geometry parameters.
541
EMC(EMC_ADR_CFG) = params->emc_adr_cfg;
542
543
// Program second-level clock enable overrides.
544
EMC(EMC_CLKEN_OVERRIDE) = params->emc_clken_override;
545
546
// Program EMC pad auto calibration.
547
EMC(EMC_PMACRO_AUTOCAL_CFG_0) = params->emc_pmacro_auto_cal_cfg0;
548
EMC(EMC_PMACRO_AUTOCAL_CFG_1) = params->emc_pmacro_auto_cal_cfg1;
549
EMC(EMC_PMACRO_AUTOCAL_CFG_2) = params->emc_pmacro_auto_cal_cfg2;
550
551
EMC(EMC_AUTO_CAL_VREF_SEL_0) = params->emc_auto_cal_vref_sel0;
552
EMC(EMC_AUTO_CAL_VREF_SEL_1) = params->emc_auto_cal_vref_sel1;
553
554
// Program/Start auto calibration.
555
EMC(EMC_AUTO_CAL_INTERVAL) = params->emc_auto_cal_interval;
556
EMC(EMC_AUTO_CAL_CONFIG) = params->emc_auto_cal_config;
557
usleep(params->emc_auto_cal_wait);
558
559
// Patch 5 using BCT spare variables.
560
if (params->emc_bct_spare8)
561
*(vu32 *)params->emc_bct_spare8 = params->emc_bct_spare9;
562
563
// Program EMC timing configuration.
564
EMC(EMC_CFG_2) = params->emc_cfg2;
565
EMC(EMC_CFG_PIPE) = params->emc_cfg_pipe;
566
EMC(EMC_CFG_PIPE_1) = params->emc_cfg_pipe1;
567
EMC(EMC_CFG_PIPE_2) = params->emc_cfg_pipe2;
568
EMC(EMC_CMDQ) = params->emc_cmd_q;
569
EMC(EMC_MC2EMCQ) = params->emc_mc2emc_q;
570
EMC(EMC_MRS_WAIT_CNT) = params->emc_mrs_wait_cnt;
571
EMC(EMC_MRS_WAIT_CNT2) = params->emc_mrs_wait_cnt2;
572
EMC(EMC_FBIO_CFG5) = params->emc_fbio_cfg5;
573
EMC(EMC_RC) = params->emc_rc;
574
EMC(EMC_RFC) = params->emc_rfc;
575
EMC(EMC_RFCPB) = params->emc_rfc_pb;
576
EMC(EMC_REFCTRL2) = params->emc_ref_ctrl2;
577
EMC(EMC_RFC_SLR) = params->emc_rfc_slr;
578
EMC(EMC_RAS) = params->emc_ras;
579
EMC(EMC_RP) = params->emc_rp;
580
EMC(EMC_TPPD) = params->emc_tppd;
581
EMC(EMC_R2R) = params->emc_r2r;
582
EMC(EMC_W2W) = params->emc_w2w;
583
EMC(EMC_R2W) = params->emc_r2w;
584
EMC(EMC_W2R) = params->emc_w2r;
585
EMC(EMC_R2P) = params->emc_r2p;
586
EMC(EMC_W2P) = params->emc_w2p;
587
EMC(EMC_CCDMW) = params->emc_ccdmw;
588
EMC(EMC_RD_RCD) = params->emc_rd_rcd;
589
EMC(EMC_WR_RCD) = params->emc_wr_rcd;
590
EMC(EMC_RRD) = params->emc_rrd;
591
EMC(EMC_REXT) = params->emc_rext;
592
EMC(EMC_WEXT) = params->emc_wext;
593
EMC(EMC_WDV) = params->emc_wdv;
594
EMC(EMC_WDV_CHK) = params->emc_wdv_chk;
595
EMC(EMC_WSV) = params->emc_wsv;
596
EMC(EMC_WEV) = params->emc_wev;
597
EMC(EMC_WDV_MASK) = params->emc_wdv_mask;
598
EMC(EMC_WS_DURATION) = params->emc_ws_duration;
599
EMC(EMC_WE_DURATION) = params->emc_we_duration;
600
EMC(EMC_QUSE) = params->emc_quse;
601
EMC(EMC_QUSE_WIDTH) = params->emc_quse_width;
602
EMC(EMC_IBDLY) = params->emc_ibdly;
603
EMC(EMC_OBDLY) = params->emc_obdly;
604
EMC(EMC_EINPUT) = params->emc_einput;
605
EMC(EMC_EINPUT_DURATION) = params->emc_einput_duration;
606
EMC(EMC_PUTERM_EXTRA) = params->emc_puterm_extra;
607
EMC(EMC_PUTERM_WIDTH) = params->emc_puterm_width;
608
609
EMC(EMC_PMACRO_COMMON_PAD_TX_CTRL) = params->emc_pmacro_common_pad_tx_ctrl;
610
EMC(EMC_DBG) = params->emc_dbg;
611
612
// Clear read fifo.
613
EMC(EMC_QRST) = params->emc_qrst;
614
EMC(EMC_ISSUE_QRST) = 1;
615
EMC(EMC_ISSUE_QRST) = 0;
616
617
// Program the rest of EMC timing configuration.
618
EMC(EMC_QSAFE) = params->emc_qsafe;
619
EMC(EMC_RDV) = params->emc_rdv;
620
EMC(EMC_RDV_MASK) = params->emc_rdv_mask;
621
EMC(EMC_RDV_EARLY) = params->emc_rdv_early;
622
EMC(EMC_RDV_EARLY_MASK) = params->emc_rdv_early_mask;
623
EMC(EMC_QPOP) = params->emc_qpop;
624
EMC(EMC_REFRESH) = params->emc_refresh;
625
EMC(EMC_BURST_REFRESH_NUM) = params->emc_burst_refresh_num;
626
EMC(EMC_PRE_REFRESH_REQ_CNT) = params->emc_prerefresh_req_cnt;
627
EMC(EMC_PDEX2WR) = params->emc_pdex2wr;
628
EMC(EMC_PDEX2RD) = params->emc_pdex2rd;
629
EMC(EMC_PCHG2PDEN) = params->emc_pchg2pden;
630
EMC(EMC_ACT2PDEN) = params->emc_act2pden;
631
EMC(EMC_AR2PDEN) = params->emc_ar2pden;
632
EMC(EMC_RW2PDEN) = params->emc_rw2pden;
633
EMC(EMC_CKE2PDEN) = params->emc_cke2pden;
634
EMC(EMC_PDEX2CKE) = params->emc_pdex2che;
635
EMC(EMC_PDEX2MRR) = params->emc_pdex2mrr;
636
EMC(EMC_TXSR) = params->emc_txsr;
637
EMC(EMC_TXSRDLL) = params->emc_txsr_dll;
638
EMC(EMC_TCKE) = params->emc_tcke;
639
EMC(EMC_TCKESR) = params->emc_tckesr;
640
EMC(EMC_TPD) = params->emc_tpd;
641
EMC(EMC_TFAW) = params->emc_tfaw;
642
EMC(EMC_TRPAB) = params->emc_trpab;
643
EMC(EMC_TCLKSTABLE) = params->emc_tclkstable;
644
EMC(EMC_TCLKSTOP) = params->emc_tclkstop;
645
EMC(EMC_TREFBW) = params->emc_trefbw;
646
EMC(EMC_ODT_WRITE) = params->emc_odt_write;
647
EMC(EMC_CFG_DIG_DLL) = params->emc_cfg_dig_dll;
648
EMC(EMC_CFG_DIG_DLL_PERIOD) = params->emc_cfg_dig_dll_period;
649
650
// Don't write CFG_ADR_EN (bit 1) here - lock bit written later.
651
EMC(EMC_FBIO_SPARE) = params->emc_fbio_spare & 0xFFFFFFFD;
652
EMC(EMC_CFG_RSV) = params->emc_cfg_rsv;
653
EMC(EMC_PMC_SCRATCH1) = params->emc_pmc_scratch1;
654
EMC(EMC_PMC_SCRATCH2) = params->emc_pmc_scratch2;
655
EMC(EMC_PMC_SCRATCH3) = params->emc_pmc_scratch3;
656
EMC(EMC_ACPD_CONTROL) = params->emc_acpd_control;
657
EMC(EMC_TXDSRVTTGEN) = params->emc_txdsrvttgen;
658
659
// Set pipe bypass enable bits before sending any DRAM commands.
660
EMC(EMC_CFG) = (params->emc_cfg & 0xE) | 0x3C00000;
661
662
// Patch BootROM.
663
if (params->boot_rom_patch_control & BIT(31))
664
{
665
*(vu32 *)(APB_MISC_BASE + params->boot_rom_patch_control * 4) = params->boot_rom_patch_data;
666
667
// Trigger MC timing update.
668
MC(MC_TIMING_CONTROL) = 1;
669
}
670
671
// Release SEL_DPD_CMD.
672
PMC(APBDEV_PMC_IO_DPD3_REQ) = (params->emc_pmc_scratch1 & 0xFFF0000) | PMC_IO_DPD_REQ_DPD_OFF;
673
usleep(params->pmc_io_dpd3_req_wait);
674
675
// Stall auto call measurements if periodic calibration is disabled.
676
if (!params->emc_auto_cal_interval)
677
EMC(EMC_AUTO_CAL_CONFIG) = params->emc_auto_cal_config | 0x200;
678
679
EMC(EMC_PMACRO_BRICK_CTRL_RFU2) = params->emc_pmacro_brick_ctrl_rfu2;
680
681
// ZQ CAL setup (not actually issuing ZQ CAL now).
682
if (params->emc_zcal_warm_cold_boot_enables & 1)
683
{
684
EMC(EMC_ZCAL_WAIT_CNT) = params->emc_zcal_wait_cnt;
685
EMC(EMC_ZCAL_MRW_CMD) = params->emc_zcal_mrw_cmd;
686
}
687
688
// Trigger timing update so above writes take place.
689
EMC(EMC_TIMING_CONTROL) = 1;
690
usleep(params->emc_timing_control_wait);
691
692
// Deassert HOLD_CKE_LOW.
693
PMC(APBDEV_PMC_DDR_CNTRL) &= 0xFFF8007F;
694
usleep(params->pmc_ddr_ctrl_wait);
695
696
// Set clock enable signal.
697
u32 pin_gpio_cfg = (params->emc_pin_gpio_enable << 16) | (params->emc_pin_gpio << 12);
698
EMC(EMC_PIN) = pin_gpio_cfg;
699
(void)EMC(EMC_PIN);
700
usleep(params->emc_pin_extra_wait + 200);
701
EMC(EMC_PIN) = pin_gpio_cfg | 0x100;
702
(void)EMC(EMC_PIN);
703
704
usleep(params->emc_pin_extra_wait + 2000);
705
706
// Enable clock enable signal.
707
EMC(EMC_PIN) = pin_gpio_cfg | 0x101;
708
(void)EMC(EMC_PIN);
709
usleep(params->emc_pin_program_wait);
710
711
// Init zq calibration,
712
// Patch 6 using BCT spare variables.
713
if (params->emc_bct_spare10)
714
*(vu32 *)params->emc_bct_spare10 = params->emc_bct_spare11;
715
716
// Write mode registers.
717
EMC(EMC_MRW2) = params->emc_mrw2;
718
EMC(EMC_MRW) = params->emc_mrw1;
719
EMC(EMC_MRW3) = params->emc_mrw3;
720
EMC(EMC_MRW4) = params->emc_mrw4;
721
EMC(EMC_MRW6) = params->emc_mrw6;
722
EMC(EMC_MRW14) = params->emc_mrw14;
723
724
EMC(EMC_MRW8) = params->emc_mrw8;
725
EMC(EMC_MRW12) = params->emc_mrw12;
726
EMC(EMC_MRW9) = params->emc_mrw9;
727
EMC(EMC_MRW13) = params->emc_mrw13;
728
729
if (params->emc_zcal_warm_cold_boot_enables & 1)
730
{
731
// Issue ZQCAL start, device 0.
732
EMC(EMC_ZQ_CAL) = params->emc_zcal_init_dev0;
733
usleep(params->emc_zcal_init_wait);
734
735
// Issue ZQCAL latch.
736
EMC(EMC_ZQ_CAL) = params->emc_zcal_init_dev0 ^ 3;
737
// Same for device 1.
738
if (!(params->emc_dev_select & 2))
739
{
740
EMC(EMC_ZQ_CAL) = params->emc_zcal_init_dev1;
741
usleep(params->emc_zcal_init_wait);
742
EMC(EMC_ZQ_CAL) = params->emc_zcal_init_dev1 ^ 3;
743
}
744
}
745
746
// Set package and DPD pad control.
747
PMC(APBDEV_PMC_DDR_CFG) = params->pmc_ddr_cfg;
748
749
// Start periodic ZQ calibration (LPDDRx only).
750
EMC(EMC_ZCAL_INTERVAL) = params->emc_zcal_interval;
751
EMC(EMC_ZCAL_WAIT_CNT) = params->emc_zcal_wait_cnt;
752
EMC(EMC_ZCAL_MRW_CMD) = params->emc_zcal_mrw_cmd;
753
754
// Patch 7 using BCT spare variables.
755
if (params->emc_bct_spare12)
756
*(vu32 *)params->emc_bct_spare12 = params->emc_bct_spare13;
757
758
// Trigger timing update so above writes take place.
759
EMC(EMC_TIMING_CONTROL) = 1;
760
761
if (params->emc_extra_refresh_num)
762
EMC(EMC_REF) = (((1 << params->emc_extra_refresh_num) - 1) << 8) | (params->emc_dev_select << 30) | 3;
763
764
// Enable refresh.
765
EMC(EMC_REFCTRL) = params->emc_dev_select | BIT(31);
766
767
EMC(EMC_DYN_SELF_REF_CONTROL) = params->emc_dyn_self_ref_control;
768
EMC(EMC_CFG_UPDATE) = params->emc_cfg_update;
769
EMC(EMC_CFG) = params->emc_cfg;
770
EMC(EMC_FDPD_CTRL_DQ) = params->emc_fdpd_ctrl_dq;
771
EMC(EMC_FDPD_CTRL_CMD) = params->emc_fdpd_ctrl_cmd;
772
EMC(EMC_SEL_DPD_CTRL) = params->emc_sel_dpd_ctrl;
773
774
// Write addr swizzle lock bit.
775
EMC(EMC_FBIO_SPARE) = params->emc_fbio_spare | BIT(1);
776
777
// Re-trigger timing to latch power saving functions.
778
EMC(EMC_TIMING_CONTROL) = 1;
779
780
// Enable EMC pipe clock gating.
781
EMC(EMC_CFG_PIPE_CLK) = params->emc_cfg_pipe_clk;
782
783
// Depending on freqency, enable CMD/CLK fdpd.
784
EMC(EMC_FDPD_CTRL_CMD_NO_RAMP) = params->emc_fdpd_ctrl_cmd_no_ramp;
785
786
// Enable arbiter.
787
SYSREG(AHB_ARBITRATION_XBAR_CTRL) = (SYSREG(AHB_ARBITRATION_XBAR_CTRL) & 0xFFFEFFFF) | (params->ahb_arbitration_xbar_ctrl_meminit_done << 16);
788
789
// Lock carveouts per BCT cfg.
790
MC(MC_VIDEO_PROTECT_REG_CTRL) = params->mc_video_protect_write_access;
791
MC(MC_SEC_CARVEOUT_REG_CTRL) = params->mc_sec_carveout_protect_write_access;
792
MC(MC_MTS_CARVEOUT_REG_CTRL) = params->mc_mts_carveout_reg_ctrl;
793
794
// Disable write access to a bunch of EMC registers.
795
MC(MC_EMEM_CFG_ACCESS_CTRL) = 1;
796
}
797
798
static void _sdram_config_t210b01(const sdram_params_t210b01_t *params)
799
{
800
// VDDP Select.
801
PMC(APBDEV_PMC_VDDP_SEL) = params->pmc_vddp_sel;
802
usleep(params->pmc_vddp_sel_wait);
803
804
// Turn on MEM IO Power.
805
PMC(APBDEV_PMC_NO_IOPOWER) &= PMC_NO_IOPOWER_SDMMC1; // Only keep SDMMC1 state. (Was params->pmc_no_io_power).
806
PMC(APBDEV_PMC_REG_SHORT) = params->pmc_reg_short;
807
808
PMC(APBDEV_PMC_DDR_CNTRL) = params->pmc_ddr_ctrl;
809
810
// Patch 1 using BCT spare variables
811
if (params->emc_bct_spare0)
812
*(vu32 *)params->emc_bct_spare0 = params->emc_bct_spare1;
813
814
// Override HW FSM if needed.
815
if (params->clk_rst_pllm_misc20_override_enable)
816
CLOCK(CLK_RST_CONTROLLER_PLLM_MISC2) = params->clk_rst_pllm_misc20_override;
817
818
// Program DPD3/DPD4 regs (coldboot path).
819
// Enable sel_dpd on unused pins.
820
u32 pmc_scratch1 = ~params->emc_pmc_scratch1;
821
PMC(APBDEV_PMC_WEAK_BIAS) = (pmc_scratch1 & 0x1000) << 19 | (pmc_scratch1 & 0xFFF) << 18 | (pmc_scratch1 & 0x8000) << 15;
822
PMC(APBDEV_PMC_IO_DPD3_REQ) = (pmc_scratch1 & 0x9FFF) | PMC_IO_DPD_REQ_DPD_ON;
823
usleep(params->pmc_io_dpd3_req_wait);
824
825
// Disable e_dpd_vttgen.
826
u32 pmc_scratch2 = ~params->emc_pmc_scratch2;
827
PMC(APBDEV_PMC_IO_DPD4_REQ) = (pmc_scratch2 & 0x3FFF0000) | PMC_IO_DPD_REQ_DPD_ON;
828
usleep(params->pmc_io_dpd4_req_wait);
829
830
// Disable e_dpd_bg.
831
PMC(APBDEV_PMC_IO_DPD4_REQ) = (pmc_scratch2 & 0x1FFF) | PMC_IO_DPD_REQ_DPD_ON;
832
usleep(1);
833
834
// Program CMD mapping. Required before brick mapping, else
835
// we can't guarantee CK will be differential at all times.
836
EMC(EMC_FBIO_CFG7) = params->emc_fbio_cfg7;
837
EMC(EMC_CMD_MAPPING_CMD0_0) = params->emc_cmd_mapping_cmd0_0;
838
EMC(EMC_CMD_MAPPING_CMD0_1) = params->emc_cmd_mapping_cmd0_1;
839
EMC(EMC_CMD_MAPPING_CMD0_2) = params->emc_cmd_mapping_cmd0_2;
840
EMC(EMC_CMD_MAPPING_CMD1_0) = params->emc_cmd_mapping_cmd1_0;
841
EMC(EMC_CMD_MAPPING_CMD1_1) = params->emc_cmd_mapping_cmd1_1;
842
EMC(EMC_CMD_MAPPING_CMD1_2) = params->emc_cmd_mapping_cmd1_2;
843
EMC(EMC_CMD_MAPPING_CMD2_0) = params->emc_cmd_mapping_cmd2_0;
844
EMC(EMC_CMD_MAPPING_CMD2_1) = params->emc_cmd_mapping_cmd2_1;
845
EMC(EMC_CMD_MAPPING_CMD2_2) = params->emc_cmd_mapping_cmd2_2;
846
EMC(EMC_CMD_MAPPING_CMD3_0) = params->emc_cmd_mapping_cmd3_0;
847
EMC(EMC_CMD_MAPPING_CMD3_1) = params->emc_cmd_mapping_cmd3_1;
848
EMC(EMC_CMD_MAPPING_CMD3_2) = params->emc_cmd_mapping_cmd3_2;
849
EMC(EMC_CMD_MAPPING_BYTE) = params->emc_cmd_mapping_byte;
850
851
// Program brick mapping.
852
EMC(EMC_PMACRO_BRICK_MAPPING_0) = params->emc_pmacro_brick_mapping0;
853
EMC(EMC_PMACRO_BRICK_MAPPING_1) = params->emc_pmacro_brick_mapping1;
854
EMC(EMC_PMACRO_BRICK_MAPPING_2) = params->emc_pmacro_brick_mapping2;
855
856
// Set pad macros.
857
EMC(EMC_PMACRO_VTTGEN_CTRL_0) = params->emc_pmacro_vttgen_ctrl0;
858
EMC(EMC_PMACRO_VTTGEN_CTRL_1) = params->emc_pmacro_vttgen_ctrl1;
859
EMC(EMC_PMACRO_VTTGEN_CTRL_2) = params->emc_pmacro_vttgen_ctrl2;
860
861
// Set pad macros bias.
862
EMC(EMC_PMACRO_BG_BIAS_CTRL_0) = params->emc_pmacro_bg_bias_ctrl0;
863
864
// Patch 1 to 3 using BCT spare secure variables.
865
if (params->emc_bct_spare_secure0)
866
*(vu32 *)params->emc_bct_spare_secure0 = params->emc_bct_spare_secure1;
867
if (params->emc_bct_spare_secure2)
868
*(vu32 *)params->emc_bct_spare_secure2 = params->emc_bct_spare_secure3;
869
if (params->emc_bct_spare_secure4)
870
*(vu32 *)params->emc_bct_spare_secure4 = params->emc_bct_spare_secure5;
871
872
// Trigger timing update so above writes take place.
873
EMC(EMC_TIMING_CONTROL) = 1;
874
usleep(params->pmc_vddp_sel_wait + 2); // Ensure the regulators settle.
875
876
// Set clock sources.
877
CLOCK(CLK_RST_CONTROLLER_CLK_SOURCE_EMC) = params->emc_clock_source;
878
CLOCK(CLK_RST_CONTROLLER_CLK_SOURCE_EMC_DLL) = params->emc_clock_source_dll;
879
880
// Select EMC write mux.
881
EMC(EMC_DBG) = (params->emc_dbg_write_mux << 1) | params->emc_dbg;
882
883
// Patch 2 using BCT spare variables.
884
if (params->emc_bct_spare2)
885
*(vu32 *)params->emc_bct_spare2 = params->emc_bct_spare3;
886
887
// This is required to do any reads from the pad macros.
888
EMC(EMC_CONFIG_SAMPLE_DELAY) = params->emc_config_sample_delay;
889
890
// Set data pipes mode.
891
EMC(EMC_FBIO_CFG8) = params->emc_fbio_cfg8;
892
893
// Set swizzle for Rank 0.
894
EMC(EMC_SWIZZLE_RANK0_BYTE0) = params->emc_swizzle_rank0_byte0;
895
EMC(EMC_SWIZZLE_RANK0_BYTE1) = params->emc_swizzle_rank0_byte1;
896
EMC(EMC_SWIZZLE_RANK0_BYTE2) = params->emc_swizzle_rank0_byte2;
897
EMC(EMC_SWIZZLE_RANK0_BYTE3) = params->emc_swizzle_rank0_byte3;
898
// Set swizzle for Rank 1.
899
EMC(EMC_SWIZZLE_RANK1_BYTE0) = params->emc_swizzle_rank1_byte0;
900
EMC(EMC_SWIZZLE_RANK1_BYTE1) = params->emc_swizzle_rank1_byte1;
901
EMC(EMC_SWIZZLE_RANK1_BYTE2) = params->emc_swizzle_rank1_byte2;
902
EMC(EMC_SWIZZLE_RANK1_BYTE3) = params->emc_swizzle_rank1_byte3;
903
904
// Patch 3 using BCT spare variables.
905
if (params->emc_bct_spare6)
906
*(vu32 *)params->emc_bct_spare6 = params->emc_bct_spare7;
907
908
// Program calibration impedance.
909
EMC(EMC_XM2COMPPADCTRL) = params->emc_xm2_comp_pad_ctrl;
910
EMC(EMC_XM2COMPPADCTRL2) = params->emc_xm2_comp_pad_ctrl2;
911
EMC(EMC_XM2COMPPADCTRL3) = params->emc_xm2_comp_pad_ctrl3;
912
913
// Program Autocal controls.
914
EMC(EMC_AUTO_CAL_CONFIG2) = params->emc_auto_cal_config2;
915
EMC(EMC_AUTO_CAL_CONFIG3) = params->emc_auto_cal_config3;
916
EMC(EMC_AUTO_CAL_CONFIG4) = params->emc_auto_cal_config4;
917
EMC(EMC_AUTO_CAL_CONFIG5) = params->emc_auto_cal_config5;
918
EMC(EMC_AUTO_CAL_CONFIG6) = params->emc_auto_cal_config6;
919
EMC(EMC_AUTO_CAL_CONFIG7) = params->emc_auto_cal_config7;
920
EMC(EMC_AUTO_CAL_CONFIG8) = params->emc_auto_cal_config8;
921
922
// Program termination and drive strength
923
EMC(EMC_PMACRO_RX_TERM) = params->emc_pmacro_rx_term;
924
EMC(EMC_PMACRO_DQ_TX_DRV) = params->emc_pmacro_dq_tx_drive;
925
EMC(EMC_PMACRO_CA_TX_DRV) = params->emc_pmacro_ca_tx_drive;
926
EMC(EMC_PMACRO_CMD_TX_DRV) = params->emc_pmacro_cmd_tx_drive;
927
EMC(EMC_PMACRO_AUTOCAL_CFG_COMMON) = params->emc_pmacro_auto_cal_common;
928
EMC(EMC_AUTO_CAL_CHANNEL) = params->emc_auto_cal_channel;
929
EMC(EMC_PMACRO_ZCTRL) = params->emc_pmacro_zcrtl;
930
931
// Program dll config.
932
EMC(EMC_DLL_CFG_0) = params->emc_dll_cfg0;
933
EMC(EMC_DLL_CFG_1) = params->emc_dll_cfg1;
934
EMC(EMC_CFG_DIG_DLL_1) = params->emc_cfg_dig_dll_1;
935
936
// Program barrelshift.
937
EMC(EMC_DATA_BRLSHFT_0) = params->emc_data_brlshft0;
938
EMC(EMC_DATA_BRLSHFT_1) = params->emc_data_brlshft1;
939
EMC(EMC_DQS_BRLSHFT_0) = params->emc_dqs_brlshft0;
940
EMC(EMC_DQS_BRLSHFT_1) = params->emc_dqs_brlshft1;
941
EMC(EMC_CMD_BRLSHFT_0) = params->emc_cmd_brlshft0;
942
EMC(EMC_CMD_BRLSHFT_1) = params->emc_cmd_brlshft1;
943
EMC(EMC_CMD_BRLSHFT_2) = params->emc_cmd_brlshft2;
944
EMC(EMC_CMD_BRLSHFT_3) = params->emc_cmd_brlshft3;
945
EMC(EMC_QUSE_BRLSHFT_0) = params->emc_quse_brlshft0;
946
EMC(EMC_QUSE_BRLSHFT_1) = params->emc_quse_brlshft1;
947
EMC(EMC_QUSE_BRLSHFT_2) = params->emc_quse_brlshft2;
948
EMC(EMC_QUSE_BRLSHFT_3) = params->emc_quse_brlshft3;
949
950
// Program pad macros controls and termination.
951
EMC(EMC_PMACRO_BRICK_CTRL_RFU1) = params->emc_pmacro_brick_ctrl_rfu1;
952
EMC(EMC_PMACRO_PAD_CFG_CTRL) = params->emc_pmacro_pad_cfg_ctrl;
953
954
EMC(EMC_PMACRO_CMD_BRICK_CTRL_FDPD) = params->emc_pmacro_cmd_brick_ctrl_fdpd;
955
EMC(EMC_PMACRO_BRICK_CTRL_RFU2) = params->emc_pmacro_brick_ctrl_rfu2;
956
EMC(EMC_PMACRO_DATA_BRICK_CTRL_FDPD) = params->emc_pmacro_data_brick_ctrl_fdpd;
957
EMC(EMC_PMACRO_DATA_PAD_RX_CTRL) = params->emc_pmacro_data_pad_rx_ctrl;
958
EMC(EMC_PMACRO_CMD_PAD_RX_CTRL) = params->emc_pmacro_cmd_pad_rx_ctrl;
959
EMC(EMC_PMACRO_DATA_PAD_TX_CTRL) = params->emc_pmacro_data_pad_tx_ctrl;
960
EMC(EMC_PMACRO_DATA_RX_TERM_MODE) = params->emc_pmacro_data_rx_term_mode;
961
EMC(EMC_PMACRO_CMD_RX_TERM_MODE) = params->emc_pmacro_cmd_rx_term_mode;
962
EMC(EMC_PMACRO_CMD_PAD_TX_CTRL) = params->emc_pmacro_cmd_pad_tx_ctrl & 0xEFFFFFFF;
963
964
// Program pad macro pins/bytes.
965
EMC(EMC_CFG_3) = params->emc_cfg3;
966
EMC(EMC_PMACRO_TX_PWRD_0) = params->emc_pmacro_tx_pwrd0;
967
EMC(EMC_PMACRO_TX_PWRD_1) = params->emc_pmacro_tx_pwrd1;
968
EMC(EMC_PMACRO_TX_PWRD_2) = params->emc_pmacro_tx_pwrd2;
969
EMC(EMC_PMACRO_TX_PWRD_3) = params->emc_pmacro_tx_pwrd3;
970
EMC(EMC_PMACRO_TX_PWRD_4) = params->emc_pmacro_tx_pwrd4;
971
EMC(EMC_PMACRO_TX_PWRD_5) = params->emc_pmacro_tx_pwrd5;
972
EMC(EMC_PMACRO_TX_SEL_CLK_SRC_0) = params->emc_pmacro_tx_sel_clk_src0;
973
EMC(EMC_PMACRO_TX_SEL_CLK_SRC_1) = params->emc_pmacro_tx_sel_clk_src1;
974
EMC(EMC_PMACRO_TX_SEL_CLK_SRC_2) = params->emc_pmacro_tx_sel_clk_src2;
975
EMC(EMC_PMACRO_TX_SEL_CLK_SRC_3) = params->emc_pmacro_tx_sel_clk_src3;
976
EMC(EMC_PMACRO_TX_SEL_CLK_SRC_4) = params->emc_pmacro_tx_sel_clk_src4;
977
EMC(EMC_PMACRO_TX_SEL_CLK_SRC_5) = params->emc_pmacro_tx_sel_clk_src5;
978
979
// Program per bit pad macros.
980
EMC(EMC_PMACRO_PERBIT_FGCG_CTRL_0_B01) = params->emc_pmacro_perbit_fgcg_ctrl0;
981
EMC(EMC_PMACRO_PERBIT_FGCG_CTRL_1_B01) = params->emc_pmacro_perbit_fgcg_ctrl1;
982
EMC(EMC_PMACRO_PERBIT_FGCG_CTRL_2_B01) = params->emc_pmacro_perbit_fgcg_ctrl2;
983
EMC(EMC_PMACRO_PERBIT_FGCG_CTRL_3_B01) = params->emc_pmacro_perbit_fgcg_ctrl3;
984
EMC(EMC_PMACRO_PERBIT_FGCG_CTRL_4_B01) = params->emc_pmacro_perbit_fgcg_ctrl4;
985
EMC(EMC_PMACRO_PERBIT_FGCG_CTRL_5_B01) = params->emc_pmacro_perbit_fgcg_ctrl5;
986
EMC(EMC_PMACRO_PERBIT_RFU_CTRL_0_B01) = params->emc_pmacro_perbit_rfu_ctrl0;
987
EMC(EMC_PMACRO_PERBIT_RFU_CTRL_1_B01) = params->emc_pmacro_perbit_rfu_ctrl1;
988
EMC(EMC_PMACRO_PERBIT_RFU_CTRL_2_B01) = params->emc_pmacro_perbit_rfu_ctrl2;
989
EMC(EMC_PMACRO_PERBIT_RFU_CTRL_3_B01) = params->emc_pmacro_perbit_rfu_ctrl3;
990
EMC(EMC_PMACRO_PERBIT_RFU_CTRL_4_B01) = params->emc_pmacro_perbit_rfu_ctrl4;
991
EMC(EMC_PMACRO_PERBIT_RFU_CTRL_5_B01) = params->emc_pmacro_perbit_rfu_ctrl5;
992
EMC(EMC_PMACRO_PERBIT_RFU1_CTRL_0_B01) = params->emc_pmacro_perbit_rfu1_ctrl0;
993
EMC(EMC_PMACRO_PERBIT_RFU1_CTRL_1_B01) = params->emc_pmacro_perbit_rfu1_ctrl1;
994
EMC(EMC_PMACRO_PERBIT_RFU1_CTRL_2_B01) = params->emc_pmacro_perbit_rfu1_ctrl2;
995
EMC(EMC_PMACRO_PERBIT_RFU1_CTRL_3_B01) = params->emc_pmacro_perbit_rfu1_ctrl3;
996
EMC(EMC_PMACRO_PERBIT_RFU1_CTRL_4_B01) = params->emc_pmacro_perbit_rfu1_ctrl4;
997
EMC(EMC_PMACRO_PERBIT_RFU1_CTRL_5_B01) = params->emc_pmacro_perbit_rfu1_ctrl5;
998
EMC(EMC_PMACRO_DATA_PI_CTRL_B01) = params->emc_pmacro_data_pi_ctrl;
999
EMC(EMC_PMACRO_CMD_PI_CTRL_B01) = params->emc_pmacro_cmd_pi_ctrl;
1000
1001
EMC(EMC_PMACRO_DDLL_BYPASS) = params->emc_pmacro_ddll_bypass;
1002
EMC(EMC_PMACRO_DDLL_PWRD_0) = params->emc_pmacro_ddll_pwrd0;
1003
EMC(EMC_PMACRO_DDLL_PWRD_1) = params->emc_pmacro_ddll_pwrd1;
1004
EMC(EMC_PMACRO_DDLL_PWRD_2) = params->emc_pmacro_ddll_pwrd2;
1005
EMC(EMC_PMACRO_CMD_CTRL_0) = params->emc_pmacro_cmd_ctrl0;
1006
EMC(EMC_PMACRO_CMD_CTRL_1) = params->emc_pmacro_cmd_ctrl1;
1007
EMC(EMC_PMACRO_CMD_CTRL_2) = params->emc_pmacro_cmd_ctrl2;
1008
1009
// Program inbound vref setting.
1010
EMC(EMC_PMACRO_IB_VREF_DQ_0) = params->emc_pmacro_ib_vref_dq_0;
1011
EMC(EMC_PMACRO_IB_VREF_DQ_1) = params->emc_pmacro_ib_vref_dq_1;
1012
EMC(EMC_PMACRO_IB_VREF_DQS_0) = params->emc_pmacro_ib_vref_dqs_0;
1013
EMC(EMC_PMACRO_IB_VREF_DQS_1) = params->emc_pmacro_ib_vref_dqs_1;
1014
EMC(EMC_PMACRO_IB_RXRT) = params->emc_pmacro_ib_rxrt;
1015
1016
// Program quse trimmers.
1017
EMC(EMC_PMACRO_QUSE_DDLL_RANK0_0) = params->emc_pmacro_quse_ddll_rank0_0;
1018
EMC(EMC_PMACRO_QUSE_DDLL_RANK0_1) = params->emc_pmacro_quse_ddll_rank0_1;
1019
EMC(EMC_PMACRO_QUSE_DDLL_RANK0_2) = params->emc_pmacro_quse_ddll_rank0_2;
1020
EMC(EMC_PMACRO_QUSE_DDLL_RANK0_3) = params->emc_pmacro_quse_ddll_rank0_3;
1021
EMC(EMC_PMACRO_QUSE_DDLL_RANK0_4) = params->emc_pmacro_quse_ddll_rank0_4;
1022
EMC(EMC_PMACRO_QUSE_DDLL_RANK0_5) = params->emc_pmacro_quse_ddll_rank0_5;
1023
EMC(EMC_PMACRO_QUSE_DDLL_RANK1_0) = params->emc_pmacro_quse_ddll_rank1_0;
1024
EMC(EMC_PMACRO_QUSE_DDLL_RANK1_1) = params->emc_pmacro_quse_ddll_rank1_1;
1025
EMC(EMC_PMACRO_QUSE_DDLL_RANK1_2) = params->emc_pmacro_quse_ddll_rank1_2;
1026
EMC(EMC_PMACRO_QUSE_DDLL_RANK1_3) = params->emc_pmacro_quse_ddll_rank1_3;
1027
EMC(EMC_PMACRO_QUSE_DDLL_RANK1_4) = params->emc_pmacro_quse_ddll_rank1_4;
1028
EMC(EMC_PMACRO_QUSE_DDLL_RANK1_5) = params->emc_pmacro_quse_ddll_rank1_5;
1029
1030
// Program outbound trimmers.
1031
EMC(EMC_PMACRO_OB_DDLL_LONG_DQ_RANK0_0) = params->emc_pmacro_ob_ddll_long_dq_rank0_0;
1032
EMC(EMC_PMACRO_OB_DDLL_LONG_DQ_RANK0_1) = params->emc_pmacro_ob_ddll_long_dq_rank0_1;
1033
EMC(EMC_PMACRO_OB_DDLL_LONG_DQ_RANK0_2) = params->emc_pmacro_ob_ddll_long_dq_rank0_2;
1034
EMC(EMC_PMACRO_OB_DDLL_LONG_DQ_RANK0_3) = params->emc_pmacro_ob_ddll_long_dq_rank0_3;
1035
EMC(EMC_PMACRO_OB_DDLL_LONG_DQ_RANK0_4) = params->emc_pmacro_ob_ddll_long_dq_rank0_4;
1036
EMC(EMC_PMACRO_OB_DDLL_LONG_DQ_RANK0_5) = params->emc_pmacro_ob_ddll_long_dq_rank0_5;
1037
EMC(EMC_PMACRO_OB_DDLL_LONG_DQ_RANK1_0) = params->emc_pmacro_ob_ddll_long_dq_rank1_0;
1038
EMC(EMC_PMACRO_OB_DDLL_LONG_DQ_RANK1_1) = params->emc_pmacro_ob_ddll_long_dq_rank1_1;
1039
EMC(EMC_PMACRO_OB_DDLL_LONG_DQ_RANK1_2) = params->emc_pmacro_ob_ddll_long_dq_rank1_2;
1040
EMC(EMC_PMACRO_OB_DDLL_LONG_DQ_RANK1_3) = params->emc_pmacro_ob_ddll_long_dq_rank1_3;
1041
EMC(EMC_PMACRO_OB_DDLL_LONG_DQ_RANK1_4) = params->emc_pmacro_ob_ddll_long_dq_rank1_4;
1042
EMC(EMC_PMACRO_OB_DDLL_LONG_DQ_RANK1_5) = params->emc_pmacro_ob_ddll_long_dq_rank1_5;
1043
1044
EMC(EMC_PMACRO_OB_DDLL_LONG_DQS_RANK0_0) = params->emc_pmacro_ob_ddll_long_dqs_rank0_0;
1045
EMC(EMC_PMACRO_OB_DDLL_LONG_DQS_RANK0_1) = params->emc_pmacro_ob_ddll_long_dqs_rank0_1;
1046
EMC(EMC_PMACRO_OB_DDLL_LONG_DQS_RANK0_2) = params->emc_pmacro_ob_ddll_long_dqs_rank0_2;
1047
EMC(EMC_PMACRO_OB_DDLL_LONG_DQS_RANK0_3) = params->emc_pmacro_ob_ddll_long_dqs_rank0_3;
1048
EMC(EMC_PMACRO_OB_DDLL_LONG_DQS_RANK0_4) = params->emc_pmacro_ob_ddll_long_dqs_rank0_4;
1049
EMC(EMC_PMACRO_OB_DDLL_LONG_DQS_RANK0_5) = params->emc_pmacro_ob_ddll_long_dqs_rank0_5;
1050
EMC(EMC_PMACRO_OB_DDLL_LONG_DQS_RANK1_0) = params->emc_pmacro_ob_ddll_long_dqs_rank1_0;
1051
EMC(EMC_PMACRO_OB_DDLL_LONG_DQS_RANK1_1) = params->emc_pmacro_ob_ddll_long_dqs_rank1_1;
1052
EMC(EMC_PMACRO_OB_DDLL_LONG_DQS_RANK1_2) = params->emc_pmacro_ob_ddll_long_dqs_rank1_2;
1053
EMC(EMC_PMACRO_OB_DDLL_LONG_DQS_RANK1_3) = params->emc_pmacro_ob_ddll_long_dqs_rank1_3;
1054
EMC(EMC_PMACRO_OB_DDLL_LONG_DQS_RANK1_4) = params->emc_pmacro_ob_ddll_long_dqs_rank1_4;
1055
EMC(EMC_PMACRO_OB_DDLL_LONG_DQS_RANK1_5) = params->emc_pmacro_ob_ddll_long_dqs_rank1_5;
1056
EMC(EMC_PMACRO_IB_DDLL_LONG_DQS_RANK0_0) = params->emc_pmacro_ib_ddll_long_dqs_rank0_0;
1057
EMC(EMC_PMACRO_IB_DDLL_LONG_DQS_RANK0_1) = params->emc_pmacro_ib_ddll_long_dqs_rank0_1;
1058
EMC(EMC_PMACRO_IB_DDLL_LONG_DQS_RANK0_2) = params->emc_pmacro_ib_ddll_long_dqs_rank0_2;
1059
EMC(EMC_PMACRO_IB_DDLL_LONG_DQS_RANK0_3) = params->emc_pmacro_ib_ddll_long_dqs_rank0_3;
1060
EMC(EMC_PMACRO_IB_DDLL_LONG_DQS_RANK1_0) = params->emc_pmacro_ib_ddll_long_dqs_rank1_0;
1061
EMC(EMC_PMACRO_IB_DDLL_LONG_DQS_RANK1_1) = params->emc_pmacro_ib_ddll_long_dqs_rank1_1;
1062
EMC(EMC_PMACRO_IB_DDLL_LONG_DQS_RANK1_2) = params->emc_pmacro_ib_ddll_long_dqs_rank1_2;
1063
EMC(EMC_PMACRO_IB_DDLL_LONG_DQS_RANK1_3) = params->emc_pmacro_ib_ddll_long_dqs_rank1_3;
1064
1065
// Program clock trimmers.
1066
EMC(EMC_PMACRO_DDLL_LONG_CMD_0) = params->emc_pmacro_ddll_long_cmd_0;
1067
EMC(EMC_PMACRO_DDLL_LONG_CMD_1) = params->emc_pmacro_ddll_long_cmd_1;
1068
EMC(EMC_PMACRO_DDLL_LONG_CMD_2) = params->emc_pmacro_ddll_long_cmd_2;
1069
EMC(EMC_PMACRO_DDLL_LONG_CMD_3) = params->emc_pmacro_ddll_long_cmd_3;
1070
EMC(EMC_PMACRO_DDLL_LONG_CMD_4) = params->emc_pmacro_ddll_long_cmd_4;
1071
EMC(EMC_PMACRO_DDLL_SHORT_CMD_0) = params->emc_pmacro_ddll_short_cmd_0;
1072
EMC(EMC_PMACRO_DDLL_SHORT_CMD_1) = params->emc_pmacro_ddll_short_cmd_1;
1073
EMC(EMC_PMACRO_DDLL_SHORT_CMD_2) = params->emc_pmacro_ddll_short_cmd_2;
1074
1075
// Set DLL periodic offset.
1076
EMC(EMC_PMACRO_DDLL_PERIODIC_OFFSET) = params->emc_pmacro_ddll_periodic_offset;
1077
1078
// Patch 4 using BCT spare variables.
1079
if (params->emc_bct_spare4)
1080
*(vu32 *)params->emc_bct_spare4 = params->emc_bct_spare5;
1081
1082
// Patch 4 to 6 using BCT spare secure variables.
1083
if (params->emc_bct_spare_secure6)
1084
*(vu32 *)params->emc_bct_spare_secure6 = params->emc_bct_spare_secure7;
1085
if (params->emc_bct_spare_secure8)
1086
*(vu32 *)params->emc_bct_spare_secure8 = params->emc_bct_spare_secure9;
1087
if (params->emc_bct_spare_secure10)
1088
*(vu32 *)params->emc_bct_spare_secure10 = params->emc_bct_spare_secure11;
1089
1090
// Trigger timing update so above writes take place.
1091
EMC(EMC_TIMING_CONTROL) = 1;
1092
1093
// Initialize MC VPR settings.
1094
MC(MC_VIDEO_PROTECT_BOM) = params->mc_video_protect_bom;
1095
MC(MC_VIDEO_PROTECT_BOM_ADR_HI) = params->mc_video_protect_bom_adr_hi;
1096
MC(MC_VIDEO_PROTECT_SIZE_MB) = params->mc_video_protect_size_mb;
1097
MC(MC_VIDEO_PROTECT_VPR_OVERRIDE) = params->mc_video_protect_vpr_override;
1098
MC(MC_VIDEO_PROTECT_VPR_OVERRIDE1) = params->mc_video_protect_vpr_override1;
1099
MC(MC_VIDEO_PROTECT_GPU_OVERRIDE_0) = params->mc_video_protect_gpu_override0;
1100
MC(MC_VIDEO_PROTECT_GPU_OVERRIDE_1) = params->mc_video_protect_gpu_override1;
1101
1102
// Program SDRAM geometry parameters.
1103
MC(MC_EMEM_ADR_CFG) = params->mc_emem_adr_cfg;
1104
MC(MC_EMEM_ADR_CFG_DEV0) = params->mc_emem_adr_cfg_dev0;
1105
MC(MC_EMEM_ADR_CFG_DEV1) = params->mc_emem_adr_cfg_dev1;
1106
MC(MC_EMEM_ADR_CFG_CHANNEL_MASK) = params->mc_emem_adr_cfg_channel_mask;
1107
1108
// Program bank swizzling.
1109
MC(MC_EMEM_ADR_CFG_BANK_MASK_0) = params->mc_emem_adr_cfg_bank_mask0;
1110
MC(MC_EMEM_ADR_CFG_BANK_MASK_1) = params->mc_emem_adr_cfg_bank_mask1;
1111
MC(MC_EMEM_ADR_CFG_BANK_MASK_2) = params->mc_emem_adr_cfg_bank_mask2;
1112
1113
// Program external memory aperture (base and size).
1114
MC(MC_EMEM_CFG) = params->mc_emem_cfg;
1115
1116
// Program SEC carveout (base and size).
1117
MC(MC_SEC_CARVEOUT_BOM) = params->mc_sec_carveout_bom;
1118
MC(MC_SEC_CARVEOUT_ADR_HI) = params->mc_sec_carveout_adr_hi;
1119
MC(MC_SEC_CARVEOUT_SIZE_MB) = params->mc_sec_carveout_size_mb;
1120
1121
// Program MTS carveout (base and size).
1122
MC(MC_MTS_CARVEOUT_BOM) = params->mc_mts_carveout_bom;
1123
MC(MC_MTS_CARVEOUT_ADR_HI) = params->mc_mts_carveout_adr_hi;
1124
MC(MC_MTS_CARVEOUT_SIZE_MB) = params->mc_mts_carveout_size_mb;
1125
1126
// Program the memory arbiter.
1127
MC(MC_EMEM_ARB_CFG) = params->mc_emem_arb_cfg;
1128
MC(MC_EMEM_ARB_OUTSTANDING_REQ) = params->mc_emem_arb_outstanding_req;
1129
MC(MC_EMEM_ARB_REFPB_HP_CTRL) = params->emc_emem_arb_refpb_hp_ctrl;
1130
MC(MC_EMEM_ARB_REFPB_BANK_CTRL) = params->emc_emem_arb_refpb_bank_ctrl;
1131
MC(MC_EMEM_ARB_TIMING_RCD) = params->mc_emem_arb_timing_rcd;
1132
MC(MC_EMEM_ARB_TIMING_RP) = params->mc_emem_arb_timing_rp;
1133
MC(MC_EMEM_ARB_TIMING_RC) = params->mc_emem_arb_timing_rc;
1134
MC(MC_EMEM_ARB_TIMING_RAS) = params->mc_emem_arb_timing_ras;
1135
MC(MC_EMEM_ARB_TIMING_FAW) = params->mc_emem_arb_timing_faw;
1136
MC(MC_EMEM_ARB_TIMING_RRD) = params->mc_emem_arb_timing_rrd;
1137
MC(MC_EMEM_ARB_TIMING_RAP2PRE) = params->mc_emem_arb_timing_rap2pre;
1138
MC(MC_EMEM_ARB_TIMING_WAP2PRE) = params->mc_emem_arb_timing_wap2pre;
1139
MC(MC_EMEM_ARB_TIMING_R2R) = params->mc_emem_arb_timing_r2r;
1140
MC(MC_EMEM_ARB_TIMING_W2W) = params->mc_emem_arb_timing_w2w;
1141
MC(MC_EMEM_ARB_TIMING_CCDMW) = params->mc_emem_arb_timing_ccdmw;
1142
MC(MC_EMEM_ARB_TIMING_R2W) = params->mc_emem_arb_timing_r2w;
1143
MC(MC_EMEM_ARB_TIMING_W2R) = params->mc_emem_arb_timing_w2r;
1144
MC(MC_EMEM_ARB_TIMING_RFCPB) = params->mc_emem_arb_timing_rfcpb;
1145
MC(MC_EMEM_ARB_DA_TURNS) = params->mc_emem_arb_da_turns;
1146
MC(MC_EMEM_ARB_DA_COVERS) = params->mc_emem_arb_da_covers;
1147
MC(MC_EMEM_ARB_MISC0) = params->mc_emem_arb_misc0;
1148
MC(MC_EMEM_ARB_MISC1) = params->mc_emem_arb_misc1;
1149
MC(MC_EMEM_ARB_MISC2) = params->mc_emem_arb_misc2;
1150
MC(MC_EMEM_ARB_RING1_THROTTLE) = params->mc_emem_arb_ring1_throttle;
1151
MC(MC_EMEM_ARB_OVERRIDE) = params->mc_emem_arb_override;
1152
MC(MC_EMEM_ARB_OVERRIDE_1) = params->mc_emem_arb_override1;
1153
MC(MC_EMEM_ARB_RSV) = params->mc_emem_arb_rsv;
1154
MC(MC_DA_CONFIG0) = params->mc_da_cfg0;
1155
1156
// Trigger MC timing update.
1157
MC(MC_TIMING_CONTROL) = 1;
1158
1159
// Program second-level clock enable overrides.
1160
MC(MC_CLKEN_OVERRIDE) = params->mc_clken_override;
1161
1162
// Program statistics gathering.
1163
MC(MC_STAT_CONTROL) = params->mc_stat_control;
1164
1165
// Program SDRAM geometry parameters.
1166
EMC(EMC_ADR_CFG) = params->emc_adr_cfg;
1167
1168
// Program second-level clock enable overrides.
1169
EMC(EMC_CLKEN_OVERRIDE) = params->emc_clken_override;
1170
1171
// Program EMC pad auto calibration.
1172
EMC(EMC_PMACRO_AUTOCAL_CFG_0) = params->emc_pmacro_auto_cal_cfg0;
1173
EMC(EMC_PMACRO_AUTOCAL_CFG_1) = params->emc_pmacro_auto_cal_cfg1;
1174
EMC(EMC_PMACRO_AUTOCAL_CFG_2) = params->emc_pmacro_auto_cal_cfg2;
1175
1176
EMC(EMC_AUTO_CAL_VREF_SEL_0) = params->emc_auto_cal_vref_sel0;
1177
EMC(EMC_AUTO_CAL_VREF_SEL_1) = params->emc_auto_cal_vref_sel1;
1178
1179
// Program/Start auto calibration.
1180
EMC(EMC_AUTO_CAL_INTERVAL) = params->emc_auto_cal_interval;
1181
EMC(EMC_AUTO_CAL_CONFIG) = params->emc_auto_cal_config;
1182
usleep(params->emc_auto_cal_wait);
1183
1184
// Patch 5 using BCT spare variables.
1185
if (params->emc_bct_spare8)
1186
*(vu32 *)params->emc_bct_spare8 = params->emc_bct_spare9;
1187
1188
EMC(EMC_AUTO_CAL_CONFIG9_B01) = params->emc_auto_cal_config9;
1189
1190
// Program EMC timing configuration.
1191
EMC(EMC_CFG_2) = params->emc_cfg2;
1192
EMC(EMC_CFG_PIPE) = params->emc_cfg_pipe;
1193
EMC(EMC_CFG_PIPE_1) = params->emc_cfg_pipe1;
1194
EMC(EMC_CFG_PIPE_2) = params->emc_cfg_pipe2;
1195
EMC(EMC_CMDQ) = params->emc_cmd_q;
1196
EMC(EMC_MC2EMCQ) = params->emc_mc2emc_q;
1197
EMC(EMC_MRS_WAIT_CNT) = params->emc_mrs_wait_cnt;
1198
EMC(EMC_MRS_WAIT_CNT2) = params->emc_mrs_wait_cnt2;
1199
EMC(EMC_FBIO_CFG5) = params->emc_fbio_cfg5;
1200
EMC(EMC_RC) = params->emc_rc;
1201
EMC(EMC_RFC) = params->emc_rfc;
1202
EMC(EMC_RFCPB) = params->emc_rfc_pb;
1203
EMC(EMC_REFCTRL2) = params->emc_ref_ctrl2;
1204
EMC(EMC_RFC_SLR) = params->emc_rfc_slr;
1205
EMC(EMC_RAS) = params->emc_ras;
1206
EMC(EMC_RP) = params->emc_rp;
1207
EMC(EMC_TPPD) = params->emc_tppd;
1208
EMC(EMC_TRTM_B01) = params->emc_trtm;
1209
EMC(EMC_TWTM_B01) = params->emc_twtm;
1210
EMC(EMC_TRATM_B01) = params->emc_tratm;
1211
EMC(EMC_TWATM_B01) = params->emc_twatm;
1212
EMC(EMC_TR2REF_B01) = params->emc_tr2ref;
1213
EMC(EMC_R2R) = params->emc_r2r;
1214
EMC(EMC_W2W) = params->emc_w2w;
1215
EMC(EMC_R2W) = params->emc_r2w;
1216
EMC(EMC_W2R) = params->emc_w2r;
1217
EMC(EMC_R2P) = params->emc_r2p;
1218
EMC(EMC_W2P) = params->emc_w2p;
1219
EMC(EMC_CCDMW) = params->emc_ccdmw;
1220
EMC(EMC_RD_RCD) = params->emc_rd_rcd;
1221
EMC(EMC_WR_RCD) = params->emc_wr_rcd;
1222
EMC(EMC_RRD) = params->emc_rrd;
1223
EMC(EMC_REXT) = params->emc_rext;
1224
EMC(EMC_WEXT) = params->emc_wext;
1225
EMC(EMC_WDV) = params->emc_wdv;
1226
EMC(EMC_WDV_CHK) = params->emc_wdv_chk;
1227
EMC(EMC_WSV) = params->emc_wsv;
1228
EMC(EMC_WEV) = params->emc_wev;
1229
EMC(EMC_WDV_MASK) = params->emc_wdv_mask;
1230
EMC(EMC_WS_DURATION) = params->emc_ws_duration;
1231
EMC(EMC_WE_DURATION) = params->emc_we_duration;
1232
EMC(EMC_QUSE) = params->emc_quse;
1233
EMC(EMC_QUSE_WIDTH) = params->emc_quse_width;
1234
EMC(EMC_IBDLY) = params->emc_ibdly;
1235
EMC(EMC_OBDLY) = params->emc_obdly;
1236
EMC(EMC_EINPUT) = params->emc_einput;
1237
EMC(EMC_EINPUT_DURATION) = params->emc_einput_duration;
1238
EMC(EMC_PUTERM_EXTRA) = params->emc_puterm_extra;
1239
EMC(EMC_PUTERM_WIDTH) = params->emc_puterm_width;
1240
1241
EMC(EMC_DBG) = params->emc_dbg;
1242
1243
// Clear read fifo.
1244
EMC(EMC_QRST) = params->emc_qrst;
1245
EMC(EMC_ISSUE_QRST) = 1;
1246
EMC(EMC_ISSUE_QRST) = 0;
1247
1248
// Program the rest of EMC timing configuration.
1249
EMC(EMC_QSAFE) = params->emc_qsafe;
1250
EMC(EMC_RDV) = params->emc_rdv;
1251
EMC(EMC_RDV_MASK) = params->emc_rdv_mask;
1252
EMC(EMC_RDV_EARLY) = params->emc_rdv_early;
1253
EMC(EMC_RDV_EARLY_MASK) = params->emc_rdv_early_mask;
1254
EMC(EMC_QPOP) = params->emc_qpop;
1255
EMC(EMC_REFRESH) = params->emc_refresh;
1256
EMC(EMC_BURST_REFRESH_NUM) = params->emc_burst_refresh_num;
1257
EMC(EMC_PRE_REFRESH_REQ_CNT) = params->emc_prerefresh_req_cnt;
1258
EMC(EMC_PDEX2WR) = params->emc_pdex2wr;
1259
EMC(EMC_PDEX2RD) = params->emc_pdex2rd;
1260
EMC(EMC_PCHG2PDEN) = params->emc_pchg2pden;
1261
EMC(EMC_ACT2PDEN) = params->emc_act2pden;
1262
EMC(EMC_AR2PDEN) = params->emc_ar2pden;
1263
EMC(EMC_RW2PDEN) = params->emc_rw2pden;
1264
EMC(EMC_CKE2PDEN) = params->emc_cke2pden;
1265
EMC(EMC_PDEX2CKE) = params->emc_pdex2che;
1266
EMC(EMC_PDEX2MRR) = params->emc_pdex2mrr;
1267
EMC(EMC_TXSR) = params->emc_txsr;
1268
EMC(EMC_TXSRDLL) = params->emc_txsr_dll;
1269
EMC(EMC_TCKE) = params->emc_tcke;
1270
EMC(EMC_TCKESR) = params->emc_tckesr;
1271
EMC(EMC_TPD) = params->emc_tpd;
1272
EMC(EMC_TFAW) = params->emc_tfaw;
1273
EMC(EMC_TRPAB) = params->emc_trpab;
1274
EMC(EMC_TCLKSTABLE) = params->emc_tclkstable;
1275
EMC(EMC_TCLKSTOP) = params->emc_tclkstop;
1276
EMC(EMC_TREFBW) = params->emc_trefbw;
1277
EMC(EMC_ODT_WRITE) = params->emc_odt_write;
1278
EMC(EMC_CFG_DIG_DLL) = params->emc_cfg_dig_dll;
1279
EMC(EMC_CFG_DIG_DLL_PERIOD) = params->emc_cfg_dig_dll_period;
1280
1281
// Don't write CFG_ADR_EN (bit 1) here - lock bit written later.
1282
EMC(EMC_FBIO_SPARE) = params->emc_fbio_spare & 0xFFFFFFFD;
1283
EMC(EMC_CFG_RSV) = params->emc_cfg_rsv;
1284
EMC(EMC_PMC_SCRATCH1) = params->emc_pmc_scratch1;
1285
EMC(EMC_PMC_SCRATCH2) = params->emc_pmc_scratch2;
1286
EMC(EMC_PMC_SCRATCH3) = params->emc_pmc_scratch3;
1287
EMC(EMC_ACPD_CONTROL) = params->emc_acpd_control;
1288
EMC(EMC_TXDSRVTTGEN) = params->emc_txdsrvttgen;
1289
EMC(EMC_PMACRO_DSR_VTTGEN_CTRL_0_B01) = params->emc_pmacro_dsr_vttgen_ctrl0;
1290
1291
// Set pipe bypass enable bits before sending any DRAM commands.
1292
EMC(EMC_CFG) = (params->emc_cfg & 0xE) | 0x3C00000;
1293
1294
// BootROM patching is used as a generic patch here.
1295
if (params->boot_rom_patch_control)
1296
{
1297
*(vu32 *)params->boot_rom_patch_control = params->boot_rom_patch_data;
1298
1299
// Trigger MC timing update.
1300
MC(MC_TIMING_CONTROL) = 1;
1301
}
1302
1303
// Patch 7 to 9 using BCT spare secure variables.
1304
if (params->emc_bct_spare_secure12)
1305
*(vu32 *)params->emc_bct_spare_secure12 = params->emc_bct_spare_secure13;
1306
if (params->emc_bct_spare_secure14)
1307
*(vu32 *)params->emc_bct_spare_secure14 = params->emc_bct_spare_secure15;
1308
if (params->emc_bct_spare_secure16)
1309
*(vu32 *)params->emc_bct_spare_secure16 = params->emc_bct_spare_secure17;
1310
1311
// Release SEL_DPD_CMD.
1312
PMC(APBDEV_PMC_IO_DPD3_REQ) = (params->emc_pmc_scratch1 & 0xFFF0000) | PMC_IO_DPD_REQ_DPD_OFF;
1313
usleep(params->pmc_io_dpd3_req_wait);
1314
1315
// Set transmission pad control parameters.
1316
EMC(EMC_PMACRO_CMD_PAD_TX_CTRL) = params->emc_pmacro_cmd_pad_tx_ctrl;
1317
1318
// ZQ CAL setup (not actually issuing ZQ CAL now).
1319
if (params->emc_zcal_warm_cold_boot_enables & 1)
1320
{
1321
EMC(EMC_ZCAL_WAIT_CNT) = params->emc_zcal_wait_cnt;
1322
EMC(EMC_ZCAL_MRW_CMD) = params->emc_zcal_mrw_cmd;
1323
}
1324
1325
// Trigger timing update so above writes take place.
1326
EMC(EMC_TIMING_CONTROL) = 1;
1327
usleep(params->emc_timing_control_wait);
1328
1329
// Deassert HOLD_CKE_LOW.
1330
PMC(APBDEV_PMC_DDR_CNTRL) &= 0xFF78007F;
1331
usleep(params->pmc_ddr_ctrl_wait);
1332
1333
// Set clock enable signal.
1334
u32 pin_gpio_cfg = (params->emc_pin_gpio_enable << 16) | (params->emc_pin_gpio << 12);
1335
EMC(EMC_PIN) = pin_gpio_cfg;
1336
(void)EMC(EMC_PIN);
1337
usleep(params->emc_pin_extra_wait + 200);
1338
EMC(EMC_PIN) = pin_gpio_cfg | 0x100;
1339
(void)EMC(EMC_PIN);
1340
1341
usleep(params->emc_pin_extra_wait + 2000);
1342
1343
// Enable clock enable signal.
1344
EMC(EMC_PIN) = pin_gpio_cfg | 0x101;
1345
(void)EMC(EMC_PIN);
1346
usleep(params->emc_pin_program_wait);
1347
1348
// Init zq calibration,
1349
// Patch 6 using BCT spare variables.
1350
if (params->emc_bct_spare10)
1351
*(vu32 *)params->emc_bct_spare10 = params->emc_bct_spare11;
1352
1353
// Write mode registers.
1354
EMC(EMC_MRW2) = params->emc_mrw2;
1355
EMC(EMC_MRW) = params->emc_mrw1;
1356
EMC(EMC_MRW3) = params->emc_mrw3;
1357
EMC(EMC_MRW4) = params->emc_mrw4;
1358
EMC(EMC_MRW6) = params->emc_mrw6;
1359
EMC(EMC_MRW14) = params->emc_mrw14;
1360
1361
EMC(EMC_MRW8) = params->emc_mrw8;
1362
EMC(EMC_MRW12) = params->emc_mrw12;
1363
EMC(EMC_MRW9) = params->emc_mrw9;
1364
EMC(EMC_MRW13) = params->emc_mrw13;
1365
1366
if (params->emc_zcal_warm_cold_boot_enables & 1)
1367
{
1368
// Issue ZQCAL start, device 0.
1369
EMC(EMC_ZQ_CAL) = params->emc_zcal_init_dev0;
1370
usleep(params->emc_zcal_init_wait);
1371
1372
// Issue ZQCAL latch.
1373
EMC(EMC_ZQ_CAL) = params->emc_zcal_init_dev0 ^ 3;
1374
// Same for device 1.
1375
if (!(params->emc_dev_select & 2))
1376
{
1377
EMC(EMC_ZQ_CAL) = params->emc_zcal_init_dev1;
1378
usleep(params->emc_zcal_init_wait);
1379
EMC(EMC_ZQ_CAL) = params->emc_zcal_init_dev1 ^ 3;
1380
}
1381
}
1382
1383
// Patch 10 to 12 using BCT spare secure variables.
1384
if (params->emc_bct_spare_secure18)
1385
*(vu32 *)params->emc_bct_spare_secure18 = params->emc_bct_spare_secure19;
1386
if (params->emc_bct_spare_secure20)
1387
*(vu32 *)params->emc_bct_spare_secure20 = params->emc_bct_spare_secure21;
1388
if (params->emc_bct_spare_secure22)
1389
*(vu32 *)params->emc_bct_spare_secure22 = params->emc_bct_spare_secure23;
1390
1391
// Set package and DPD pad control.
1392
PMC(APBDEV_PMC_DDR_CFG) = params->pmc_ddr_cfg;
1393
1394
// Start periodic ZQ calibration (LPDDRx only).
1395
EMC(EMC_ZCAL_INTERVAL) = params->emc_zcal_interval;
1396
EMC(EMC_ZCAL_WAIT_CNT) = params->emc_zcal_wait_cnt;
1397
EMC(EMC_ZCAL_MRW_CMD) = params->emc_zcal_mrw_cmd;
1398
1399
// Patch 7 using BCT spare variables.
1400
if (params->emc_bct_spare12)
1401
*(vu32 *)params->emc_bct_spare12 = params->emc_bct_spare13;
1402
1403
// Trigger timing update so above writes take place.
1404
EMC(EMC_TIMING_CONTROL) = 1;
1405
1406
if (params->emc_extra_refresh_num)
1407
EMC(EMC_REF) = ((1 << params->emc_extra_refresh_num << 8) - 253) | (params->emc_dev_select << 30);
1408
1409
// Enable refresh.
1410
EMC(EMC_REFCTRL) = params->emc_dev_select | BIT(31);
1411
1412
EMC(EMC_DYN_SELF_REF_CONTROL) = params->emc_dyn_self_ref_control;
1413
EMC(EMC_CFG) = params->emc_cfg;
1414
EMC(EMC_FDPD_CTRL_DQ) = params->emc_fdpd_ctrl_dq;
1415
EMC(EMC_FDPD_CTRL_CMD) = params->emc_fdpd_ctrl_cmd;
1416
EMC(EMC_SEL_DPD_CTRL) = params->emc_sel_dpd_ctrl;
1417
1418
// Write addr swizzle lock bit.
1419
EMC(EMC_FBIO_SPARE) = params->emc_fbio_spare | BIT(1);
1420
1421
// Re-trigger timing to latch power saving functions.
1422
EMC(EMC_TIMING_CONTROL) = 1;
1423
1424
EMC(EMC_CFG_UPDATE) = params->emc_cfg_update;
1425
1426
// Enable EMC pipe clock gating.
1427
EMC(EMC_CFG_PIPE_CLK) = params->emc_cfg_pipe_clk;
1428
1429
// Depending on freqency, enable CMD/CLK fdpd.
1430
EMC(EMC_FDPD_CTRL_CMD_NO_RAMP) = params->emc_fdpd_ctrl_cmd_no_ramp;
1431
1432
// Set untranslated region requirements.
1433
MC(MC_UNTRANSLATED_REGION_CHECK_B01) = params->mc_untranslated_region_check;
1434
1435
// Lock carveouts per BCT cfg.
1436
MC(MC_VIDEO_PROTECT_REG_CTRL) = params->mc_video_protect_write_access;
1437
MC(MC_SEC_CARVEOUT_REG_CTRL) = params->mc_sec_carveout_protect_write_access;
1438
MC(MC_MTS_CARVEOUT_REG_CTRL) = params->mc_mts_carveout_reg_ctrl;
1439
1440
// Disable write access to a bunch of EMC registers.
1441
MC(MC_EMEM_CFG_ACCESS_CTRL) = 1;
1442
1443
// Enable arbiter.
1444
SYSREG(AHB_ARBITRATION_XBAR_CTRL) = (SYSREG(AHB_ARBITRATION_XBAR_CTRL) & 0xFFFEFFFF) | (params->ahb_arbitration_xbar_ctrl_meminit_done << 16);
1445
}
1446
1447
static void *_sdram_get_params_t210()
1448
{
1449
// Check if id is proper.
1450
u32 dramid = fuse_read_dramid(false);
1451
1452
// Copy base parameters.
1453
u32 *params = (u32 *)SDRAM_PARAMS_ADDR;
1454
memcpy(params, &_dram_cfg_0_samsung_4gb, sizeof(sdram_params_t210_t));
1455
1456
// Patch parameters if needed.
1457
for (u32 i = 0; i < ARRAY_SIZE(sdram_cfg_vendor_patches_t210); i++)
1458
if (sdram_cfg_vendor_patches_t210[i].dramcf & DRAM_ID(dramid))
1459
params[sdram_cfg_vendor_patches_t210[i].offset] = sdram_cfg_vendor_patches_t210[i].val;
1460
1461
return (void *)params;
1462
}
1463
1464
void *sdram_get_params_t210b01()
1465
{
1466
// Check if id is proper.
1467
u32 dramid = fuse_read_dramid(false);
1468
1469
// Copy base parameters.
1470
u32 *params = (u32 *)SDRAM_PARAMS_ADDR;
1471
memcpy(params, &_dram_cfg_08_10_12_14_samsung_hynix_4gb, sizeof(sdram_params_t210b01_t));
1472
1473
// Patch parameters if needed.
1474
u8 dram_code = dram_encoding_t210b01[dramid];
1475
if (!dram_code)
1476
return (void *)params;
1477
1478
for (u32 i = 0; i < ARRAY_SIZE(sdram_cfg_vendor_patches_t210b01); i++)
1479
if (sdram_cfg_vendor_patches_t210b01[i].dramcf & DRAM_CC(dram_code))
1480
params[sdram_cfg_vendor_patches_t210b01[i].offset] = sdram_cfg_vendor_patches_t210b01[i].val;
1481
1482
return (void *)params;
1483
}
1484
1485
/*
1486
* Function: sdram_get_params_patched
1487
*
1488
* This code implements a warmboot exploit. Warmboot, that is actually so hot, it burns Nvidia once again.
1489
* If the boot_rom_patch_control's MSB is set, it uses it as an index to
1490
* APB_MISC_BASE (u32 array) and sets it to the value of boot_rom_patch_data.
1491
* (The MSB falls out when it gets multiplied by sizeof(u32)).
1492
* Because the bootrom does not do any boundary checks, it lets us write anywhere and anything.
1493
* Ipatch hardware let us apply 12 changes to the bootrom and can be changed any time.
1494
* The first patch is not needed any more when the exploit is triggered, so we overwrite that.
1495
* 0x10459E is the address where it returns an error when the signature is not valid.
1496
* We change that to MOV R0, #0, so we pass the check.
1497
*
1498
* Note: The modulus in the header must match and validated.
1499
*/
1500
1501
void *sdram_get_params_patched()
1502
{
1503
#define IPATCH_CONFIG(addr, data) ((((addr) - 0x100000) / 2) << 16 | ((data) & 0xffff))
1504
sdram_params_t210_t *sdram_params = _sdram_get_params_t210();
1505
1506
// Disable Warmboot signature check.
1507
sdram_params->boot_rom_patch_control = BIT(31) | (((IPATCH_BASE + 4) - APB_MISC_BASE) / 4);
1508
sdram_params->boot_rom_patch_data = IPATCH_CONFIG(0x10459E, 0x2000);
1509
/*
1510
// Disable SBK lock.
1511
sdram_params->emc_bct_spare8 = (IPATCH_BASE + 7 * 4);
1512
sdram_params->emc_bct_spare9 = IPATCH_CONFIG(0x10210E, 0x2000);
1513
1514
// Disable bootrom read lock.
1515
sdram_params->emc_bct_spare10 = (IPATCH_BASE + 10 * 4);
1516
sdram_params->emc_bct_spare11 = IPATCH_CONFIG(0x100FDC, 0xF000);
1517
sdram_params->emc_bct_spare12 = (IPATCH_BASE + 11 * 4);
1518
sdram_params->emc_bct_spare13 = IPATCH_CONFIG(0x100FDE, 0xE320);
1519
*/
1520
return (void *)sdram_params;
1521
}
1522
1523
void sdram_init()
1524
{
1525
// Disable remote sense for SD1.
1526
i2c_send_byte(I2C_5, MAX77620_I2C_ADDR, MAX77620_REG_SD_CFG2, MAX77620_SD_CNF2_ROVS_EN_SD0 | MAX77620_SD_CNF2_RSVD);
1527
1528
if (hw_get_chip_id() == GP_HIDREV_MAJOR_T210)
1529
{
1530
const sdram_params_t210_t *params = (const sdram_params_t210_t *)_sdram_get_params_t210();
1531
if (params->memory_type != MEMORY_TYPE_LPDDR4)
1532
return;
1533
1534
// Set DRAM voltage.
1535
max7762x_regulator_set_voltage(REGULATOR_SD1, 1125000); // HOS: 1.125V. Bootloader: 1.1V.
1536
1537
_sdram_config_t210(params);
1538
}
1539
else
1540
{
1541
const sdram_params_t210b01_t *params = (const sdram_params_t210b01_t *)sdram_get_params_t210b01();
1542
if (params->memory_type != MEMORY_TYPE_LPDDR4)
1543
return;
1544
1545
_sdram_config_t210b01(params);
1546
}
1547
}
1548
1549