5 #ifndef CPU_SAMSUNG_EXYNOS5420_SETUP_H
6 #define CPU_SAMSUNG_EXYNOS5420_SETUP_H
12 #define NOT_AVAILABLE 0
13 #define DATA_MASK 0xFFFFF
15 #define ENABLE_BIT 0x1
16 #define DISABLE_BIT 0x0
17 #define CA_SWAP_EN (1 << 0)
20 #define TZPC0_BASE 0x10100000
21 #define TZPC1_BASE 0x10110000
22 #define TZPC2_BASE 0x10120000
23 #define TZPC3_BASE 0x10130000
24 #define TZPC4_BASE 0x10140000
25 #define TZPC5_BASE 0x10150000
26 #define TZPC6_BASE 0x10160000
27 #define TZPC7_BASE 0x10170000
28 #define TZPC8_BASE 0x10180000
29 #define TZPC9_BASE 0x10190000
31 #define APLL_FOUT (1 << 0)
32 #define KPLL_FOUT (1 << 0)
34 #define CLK_DIV_CPERI1_VAL 0x3f3f0000
37 #define APLL_CON1_VAL (0x0020f300)
40 #define MPLL_CON1_VAL (0x0020f300)
43 #define CPLL_CON1_VAL (0x0020f300)
46 #define DPLL_CON1_VAL (0x0020f300)
49 #define GPLL_CON1_VAL (NOT_AVAILABLE)
52 #define EPLL_CON1_VAL 0x00000000
53 #define EPLL_CON2_VAL 0x00000080
56 #define VPLL_CON1_VAL 0x0020f300
57 #define VPLL_CON2_VAL NOT_AVAILABLE
60 #define RPLL_CON1_VAL 0x00000000
61 #define RPLL_CON2_VAL 0x00000080
64 #define BPLL_CON1_VAL 0x0020f300
67 #define SPLL_CON1_VAL 0x0020f300
70 #define IPLL_CON1_VAL 0x00000080
73 #define KPLL_CON1_VAL 0x200000
76 #define set_pll(mdiv, pdiv, sdiv) (1<<31 | mdiv<<16 | pdiv<<8 | sdiv)
82 #define MUX_APLL_SEL 1
84 #define CLK_SRC_CPU_VAL ((MUX_HPM_SEL << 20) \
85 | (MUX_CPU_SEL << 16) \
89 #define DMC_MEMCONTROL_CLK_STOP_DISABLE (0 << 0)
90 #define DMC_MEMCONTROL_DPWRDN_DISABLE (0 << 1)
91 #define DMC_MEMCONTROL_DPWRDN_ACTIVE_PRECHARGE (0 << 2)
92 #define DMC_MEMCONTROL_DSREF_DISABLE (0 << 5)
93 #define DMC_MEMCONTROL_DSREF_ENABLE (1 << 5)
94 #define DMC_MEMCONTROL_ADD_LAT_PALL_CYCLE(x) (x << 6)
96 #define DMC_MEMCONTROL_MEM_TYPE_LPDDR3 (7 << 8)
97 #define DMC_MEMCONTROL_MEM_TYPE_DDR3 (6 << 8)
98 #define DMC_MEMCONTROL_MEM_TYPE_LPDDR2 (5 << 8)
100 #define DMC_MEMCONTROL_MEM_WIDTH_32BIT (2 << 12)
102 #define DMC_MEMCONTROL_NUM_CHIP_1 (0 << 16)
103 #define DMC_MEMCONTROL_NUM_CHIP_2 (1 << 16)
105 #define DMC_MEMCONTROL_BL_8 (3 << 20)
106 #define DMC_MEMCONTROL_BL_4 (2 << 20)
108 #define DMC_MEMCONTROL_PZQ_DISABLE (0 << 24)
110 #define DMC_MEMCONTROL_MRR_BYTE_7_0 (0 << 25)
111 #define DMC_MEMCONTROL_MRR_BYTE_15_8 (1 << 25)
112 #define DMC_MEMCONTROL_MRR_BYTE_23_16 (2 << 25)
113 #define DMC_MEMCONTROL_MRR_BYTE_31_24 (3 << 25)
116 #define DMC_MEMCONFIGx_CHIP_MAP_INTERLEAVED (1 << 12)
117 #define DMC_MEMCONFIG_CHIP_MAP_SPLIT (2 << 12)
118 #define DMC_MEMCONFIGx_CHIP_COL_10 (3 << 8)
119 #define DMC_MEMCONFIGx_CHIP_ROW_14 (2 << 4)
120 #define DMC_MEMCONFIGx_CHIP_ROW_15 (3 << 4)
121 #define DMC_MEMCONFIGx_CHIP_ROW_16 (4 << 4)
122 #define DMC_MEMCONFIGx_CHIP_BANK_8 (3 << 0)
124 #define DMC_MEMBASECONFIG0_VAL DMC_MEMBASECONFIG_VAL(0x40)
125 #define DMC_MEMBASECONFIG1_VAL DMC_MEMBASECONFIG_VAL(0x80)
127 #define DMC_PRECHCONFIG_VAL 0xFF000000
128 #define DMC_PWRDNCONFIG_VAL 0xFFFF00FF
130 #define DMC_CONCONTROL_RESET_VAL 0x0FFF0000
131 #define DFI_INIT_START (1 << 28)
132 #define EMPTY (1 << 8)
133 #define AREF_EN (1 << 5)
135 #define DFI_INIT_COMPLETE_CHO (1 << 2)
136 #define DFI_INIT_COMPLETE_CH1 (1 << 3)
138 #define RDLVL_COMPLETE_CHO (1 << 14)
139 #define RDLVL_COMPLETE_CH1 (1 << 15)
141 #define CLK_STOP_EN (1 << 0)
142 #define DPWRDN_EN (1 << 1)
143 #define DSREF_EN (1 << 5)
146 #define DMC_CONCONTROL_IO_PD_CON_DISABLE (0 << 3)
147 #define DMC_CONCONTROL_AREF_EN_DISABLE (0 << 5)
148 #define DMC_CONCONTROL_RD_FETCH_DISABLE (0x0 << 12)
149 #define DMC_CONCONTROL_TIMEOUT_LEVEL0 (0xFFF << 16)
150 #define DMC_CONCONTROL_DFI_INIT_START_DISABLE (0 << 28)
153 #define CLK_SRC_FSYS0_VAL 0x33033300
154 #define CLK_DIV_FSYS0_VAL 0x0
155 #define CLK_DIV_FSYS1_VAL 0x04f13c4f
156 #define CLK_DIV_FSYS2_VAL 0x041d0000
158 #define DMC_CONCONTROL_IO_PD_CON(x) (x << 6)
161 #define HPM_RATIO 0x2
162 #define COPY_RATIO 0x0
165 #define CLK_DIV_CPU1_VAL ((HPM_RATIO << 4) \
169 #define CLK_SRC_CORE0_VAL 0x00000000
172 #define CLK_SRC_CORE1_VAL 0x100
175 #define CLK_DIV_CORE0_VAL 0x00120000
178 #define CLK_DIV_CORE1_VAL 0x07070700
181 #define CLK_DIV_SYSRGT_VAL 0x00000111
184 #define CLK_DIV_ACP_VAL 0x12
187 #define CLK_DIV_SYSLFT_VAL 0x00000311
190 #define CLK_SRC_CDREX_VAL 0x00000001
191 #define MUX_MCLK_CDR_MSPLL (1 << 4)
192 #define MUX_BPLL_SEL_FOUTBPLL (1 << 0)
193 #define BPLL_SEL_MASK 0x7
197 #define CLK_DIV_CDREX0_VAL 0x30010100
198 #define CLK_DIV_CDREX1_VAL 0x300
200 #define CLK_DIV_CDREX_VAL 0x17010100
203 #define CLK_DIV_CPU0_VAL 0x01440020
206 #define CLK_SRC_TOP0_VAL 0x11101102
207 #define CLK_SRC_TOP1_VAL 0x00200000
208 #define CLK_SRC_TOP2_VAL 0x11101010
209 #define CLK_SRC_TOP3_VAL 0x11111111
210 #define CLK_SRC_TOP4_VAL 0x11110111
211 #define CLK_SRC_TOP5_VAL 0x11111111
212 #define CLK_SRC_TOP6_VAL 0x11110111
213 #define CLK_SRC_TOP7_VAL 0x00022200
216 #define CLK_DIV_TOP0_VAL 0x22512211
217 #define CLK_DIV_TOP1_VAL 0x13200900
218 #define CLK_DIV_TOP2_VAL 0x11101110
221 #define APLL_LOCK_VAL (0x320)
223 #define MPLL_LOCK_VAL (0x258)
225 #define BPLL_LOCK_VAL (0x258)
227 #define CPLL_LOCK_VAL (0x190)
229 #define DPLL_LOCK_VAL (0x190)
231 #define GPLL_LOCK_VAL NOT_AVAILABLE
233 #define IPLL_LOCK_VAL (0x320)
235 #define KPLL_LOCK_VAL (0x258)
237 #define SPLL_LOCK_VAL (0x320)
239 #define RPLL_LOCK_VAL (0x2328)
241 #define EPLL_LOCK_VAL (0x2328)
243 #define VPLL_LOCK_VAL (0x258)
245 #define MUX_APLL_SEL_MASK (1 << 0)
246 #define MUX_MPLL_SEL_MASK (1 << 8)
247 #define MPLL_SEL_MOUT_MPLLFOUT (2 << 8)
248 #define MUX_CPLL_SEL_MASK (1 << 8)
249 #define MUX_EPLL_SEL_MASK (1 << 12)
250 #define MUX_VPLL_SEL_MASK (1 << 16)
251 #define MUX_GPLL_SEL_MASK (1 << 28)
252 #define MUX_BPLL_SEL_MASK (1 << 0)
253 #define MUX_HPM_SEL_MASK (1 << 20)
254 #define HPM_SEL_SCLK_MPLL (1 << 21)
255 #define PLL_LOCKED (1 << 29)
256 #define APLL_CON0_LOCKED (1 << 29)
257 #define MPLL_CON0_LOCKED (1 << 29)
258 #define BPLL_CON0_LOCKED (1 << 29)
259 #define CPLL_CON0_LOCKED (1 << 29)
260 #define EPLL_CON0_LOCKED (1 << 29)
261 #define GPLL_CON0_LOCKED (1 << 29)
262 #define VPLL_CON0_LOCKED (1 << 29)
263 #define CLK_REG_DISABLE 0x0
264 #define TOP2_VAL 0x0110000
267 #define CLK_SRC_LEX_VAL 0x0
270 #define CLK_DIV_LEX_VAL 0x10
273 #define CLK_DIV_R0X_VAL 0x10
276 #define CLK_DIV_R1X_VAL 0x10
279 #define CLK_DIV_ISP2_VAL 0x1
282 #define SRC_KFC_HPM_SEL (1 << 15)
285 #define CLK_SRC_KFC_VAL 0x00008001
288 #define CLK_DIV_KFC_VAL 0x03300110
291 #define CLK_DIV2_RATIO 0x10111150
294 #define CLK_DIV4_RATIO 0x00000003
297 #define CLK_DIV_G2D 0x00000010
308 #define CLK_SRC_PERIC0_VAL ((SPDIF_SEL << 28) \
310 | (UART4_SEL << 20) \
311 | (UART3_SEL << 16) \
312 | (UART2_SEL << 12) \
325 #define CLK_SRC_PERIC1_VAL ((SPI2_SEL << 28) \
328 | (AUDIO2_SEL << 16) \
329 | (AUDIO2_SEL << 12) \
333 #define CLK_SRC_ISP_VAL 0x33366000
334 #define CLK_DIV_ISP0_VAL 0x13131300
335 #define CLK_DIV_ISP1_VAL 0xbb110202
338 #define SPI0_ISP_RATIO 0xf
339 #define SPI1_ISP_RATIO 0xf
340 #define SCLK_DIV_ISP_VAL (SPI1_ISP_RATIO << 12) \
341 | (SPI0_ISP_RATIO << 0)
345 #define UART4_RATIO 9
346 #define UART3_RATIO 9
347 #define UART2_RATIO 9
348 #define UART1_RATIO 9
349 #define UART0_RATIO 9
351 #define CLK_DIV_PERIC0_VAL ((PWM_RATIO << 28) \
352 | (UART4_RATIO << 24) \
353 | (UART3_RATIO << 20) \
354 | (UART2_RATIO << 16) \
355 | (UART1_RATIO << 12) \
356 | (UART0_RATIO << 8))
359 #define SPI2_RATIO 0x1
360 #define SPI1_RATIO 0x1
361 #define SPI0_RATIO 0x1
362 #define CLK_DIV_PERIC1_VAL ((SPI2_RATIO << 28) \
363 | (SPI1_RATIO << 24) \
364 | (SPI0_RATIO << 20))
367 #define PCM2_RATIO 0x3
368 #define PCM1_RATIO 0x3
369 #define CLK_DIV_PERIC2_VAL ((PCM2_RATIO << 24) \
370 | (PCM1_RATIO << 16))
373 #define AUDIO2_RATIO 0x5
374 #define AUDIO1_RATIO 0x5
375 #define AUDIO0_RATIO 0x5
376 #define CLK_DIV_PERIC3_VAL ((AUDIO2_RATIO << 28) \
377 | (AUDIO1_RATIO << 24) \
378 | (AUDIO0_RATIO << 20))
381 #define SPI2_PRE_RATIO 0x3
382 #define SPI1_PRE_RATIO 0x3
383 #define SPI0_PRE_RATIO 0x3
384 #define CLK_DIV_PERIC4_VAL ((SPI2_PRE_RATIO << 24) \
385 | (SPI1_PRE_RATIO << 16) \
386 | (SPI0_PRE_RATIO << 8))
389 #define MMC2_RATIO_MASK 0xf
390 #define MMC2_RATIO_VAL 0x3
391 #define MMC2_RATIO_OFFSET 0
393 #define MMC2_PRE_RATIO_MASK 0xff
394 #define MMC2_PRE_RATIO_VAL 0x9
395 #define MMC2_PRE_RATIO_OFFSET 8
397 #define MMC3_RATIO_MASK 0xf
398 #define MMC3_RATIO_VAL 0x1
399 #define MMC3_RATIO_OFFSET 16
401 #define MMC3_PRE_RATIO_MASK 0xff
402 #define MMC3_PRE_RATIO_VAL 0x0
403 #define MMC3_PRE_RATIO_OFFSET 24
406 #define CLK_SRC_LEX_VAL 0x0
409 #define CLK_DIV_LEX_VAL 0x10
412 #define CLK_DIV_R0X_VAL 0x10
415 #define CLK_DIV_R1X_VAL 0x10
418 #define CLK_DIV_ISP2_VAL 0x1
421 #define CLK_SRC_DISP1_0_VAL 0x10006000
422 #define CLK_DIV_DISP1_0_VAL 0x01050210
428 #define CLK_DIV_DISP1_0_FIMD1 (2 << 0)
431 #define CLK_GATE_DP1_ALLOW (1 << 4)
434 #define CLK_C2C_MASK (1 << 1)
437 #define CLK_SMMUG2D_MASK (1 << 7)
438 #define CLK_SMMUSSS_MASK (1 << 6)
439 #define CLK_SMMUMDMA_MASK (1 << 5)
440 #define CLK_ID_REMAPPER_MASK (1 << 4)
441 #define CLK_G2D_MASK (1 << 3)
442 #define CLK_SSS_MASK (1 << 2)
443 #define CLK_MDMA_MASK (1 << 1)
444 #define CLK_SECJTAG_MASK (1 << 0)
447 #define CLK_EFCLK_MASK (1 << 16)
450 #define CLK_UART_ISP_MASK (1 << 31)
451 #define CLK_WDT_ISP_MASK (1 << 30)
452 #define CLK_PWM_ISP_MASK (1 << 28)
453 #define CLK_MTCADC_ISP_MASK (1 << 27)
454 #define CLK_I2C1_ISP_MASK (1 << 26)
455 #define CLK_I2C0_ISP_MASK (1 << 25)
456 #define CLK_MPWM_ISP_MASK (1 << 24)
457 #define CLK_MCUCTL_ISP_MASK (1 << 23)
458 #define CLK_INT_COMB_ISP_MASK (1 << 22)
459 #define CLK_SMMU_MCUISP_MASK (1 << 13)
460 #define CLK_SMMU_SCALERP_MASK (1 << 12)
461 #define CLK_SMMU_SCALERC_MASK (1 << 11)
462 #define CLK_SMMU_FD_MASK (1 << 10)
463 #define CLK_SMMU_DRC_MASK (1 << 9)
464 #define CLK_SMMU_ISP_MASK (1 << 8)
465 #define CLK_GICISP_MASK (1 << 7)
466 #define CLK_ARM9S_MASK (1 << 6)
467 #define CLK_MCUISP_MASK (1 << 5)
468 #define CLK_SCALERP_MASK (1 << 4)
469 #define CLK_SCALERC_MASK (1 << 3)
470 #define CLK_FD_MASK (1 << 2)
471 #define CLK_DRC_MASK (1 << 1)
472 #define CLK_ISP_MASK (1 << 0)
475 #define CLK_SPI1_ISP_MASK (1 << 13)
476 #define CLK_SPI0_ISP_MASK (1 << 12)
477 #define CLK_SMMU3DNR_MASK (1 << 7)
478 #define CLK_SMMUDIS1_MASK (1 << 6)
479 #define CLK_SMMUDIS0_MASK (1 << 5)
480 #define CLK_SMMUODC_MASK (1 << 4)
481 #define CLK_3DNR_MASK (1 << 2)
482 #define CLK_DIS_MASK (1 << 1)
483 #define CLK_ODC_MASK (1 << 0)
486 #define CLK_SMMUFIMC_LITE2_MASK (1 << 20)
487 #define CLK_SMMUFIMC_LITE1_MASK (1 << 12)
488 #define CLK_SMMUFIMC_LITE0_MASK (1 << 11)
489 #define CLK_SMMUGSCL3_MASK (1 << 10)
490 #define CLK_SMMUGSCL2_MASK (1 << 9)
491 #define CLK_SMMUGSCL1_MASK (1 << 8)
492 #define CLK_SMMUGSCL0_MASK (1 << 7)
493 #define CLK_GSCL_WRAP_B_MASK (1 << 6)
494 #define CLK_GSCL_WRAP_A_MASK (1 << 5)
495 #define CLK_CAMIF_TOP_MASK (1 << 4)
496 #define CLK_GSCL3_MASK (1 << 3)
497 #define CLK_GSCL2_MASK (1 << 2)
498 #define CLK_GSCL1_MASK (1 << 1)
499 #define CLK_GSCL0_MASK (1 << 0)
502 #define CLK_SMMUMFCR_MASK (1 << 2)
503 #define CLK_SMMUMFCL_MASK (1 << 1)
504 #define CLK_MFC_MASK (1 << 0)
506 #define SCLK_MPWM_ISP_MASK (1 << 0)
509 #define CLK_SMMUTVX_MASK (1 << 9)
510 #define CLK_ASYNCTVX_MASK (1 << 7)
511 #define CLK_HDMI_MASK (1 << 6)
512 #define CLK_MIXER_MASK (1 << 5)
513 #define CLK_DSIM1_MASK (1 << 3)
516 #define AUDIO0_SEL_EPLL (0x6 << 28)
517 #define AUDIO0_RATIO 0x5
518 #define PCM0_RATIO 0x3
519 #define DIV_MAU_VAL (PCM0_RATIO << 24 | AUDIO0_RATIO << 20)
522 #define CLK_SMMUMDMA1_MASK (1 << 9)
523 #define CLK_SMMUJPEG_MASK (1 << 7)
524 #define CLK_SMMUROTATOR_MASK (1 << 6)
525 #define CLK_MDMA1_MASK (1 << 4)
526 #define CLK_JPEG_MASK (1 << 2)
527 #define CLK_ROTATOR_MASK (1 << 1)
530 #define CLK_WDT_IOP_MASK (1 << 30)
531 #define CLK_SMMUMCU_IOP_MASK (1 << 26)
532 #define CLK_SATA_PHY_I2C_MASK (1 << 25)
533 #define CLK_SATA_PHY_CTRL_MASK (1 << 24)
534 #define CLK_MCUCTL_MASK (1 << 23)
535 #define CLK_NFCON_MASK (1 << 22)
536 #define CLK_SMMURTIC_MASK (1 << 11)
537 #define CLK_RTIC_MASK (1 << 9)
538 #define CLK_MIPI_HSI_MASK (1 << 8)
539 #define CLK_USBOTG_MASK (1 << 7)
540 #define CLK_SATA_MASK (1 << 6)
541 #define CLK_PDMA1_MASK (1 << 2)
542 #define CLK_PDMA0_MASK (1 << 1)
543 #define CLK_MCU_IOP_MASK (1 << 0)
546 #define CLK_HS_I2C3_MASK (1 << 31)
547 #define CLK_HS_I2C2_MASK (1 << 30)
548 #define CLK_HS_I2C1_MASK (1 << 29)
549 #define CLK_HS_I2C0_MASK (1 << 28)
550 #define CLK_AC97_MASK (1 << 27)
551 #define CLK_SPDIF_MASK (1 << 26)
552 #define CLK_PCM2_MASK (1 << 23)
553 #define CLK_PCM1_MASK (1 << 22)
554 #define CLK_I2S2_MASK (1 << 21)
555 #define CLK_I2S1_MASK (1 << 20)
556 #define CLK_SPI2_MASK (1 << 18)
557 #define CLK_SPI0_MASK (1 << 16)
558 #define CLK_I2CHDMI_MASK (1 << 14)
559 #define CLK_I2C7_MASK (1 << 13)
560 #define CLK_I2C6_MASK (1 << 12)
561 #define CLK_I2C5_MASK (1 << 11)
562 #define CLK_I2C4_MASK (1 << 10)
563 #define CLK_I2C3_MASK (1 << 9)
564 #define CLK_I2C2_MASK (1 << 8)
565 #define CLK_I2C1_MASK (1 << 7)
566 #define CLK_I2C0_MASK (1 << 6)
569 #define CLK_RTC_MASK (1 << 20)
570 #define CLK_TZPC9_MASK (1 << 15)
571 #define CLK_TZPC8_MASK (1 << 14)
572 #define CLK_TZPC7_MASK (1 << 13)
573 #define CLK_TZPC6_MASK (1 << 12)
574 #define CLK_TZPC5_MASK (1 << 11)
575 #define CLK_TZPC4_MASK (1 << 10)
576 #define CLK_TZPC3_MASK (1 << 9)
577 #define CLK_TZPC2_MASK (1 << 8)
578 #define CLK_TZPC1_MASK (1 << 7)
579 #define CLK_TZPC0_MASK (1 << 6)
580 #define CLK_CHIPID_MASK (1 << 0)
583 #define CLK_ACP_MASK (1 << 7)
586 #define CLK_TZASC_DRBXW_MASK (1 << 23)
587 #define CLK_TZASC_DRBXR_MASK (1 << 22)
588 #define CLK_TZASC_XLBXW_MASK (1 << 21)
589 #define CLK_TZASC_XLBXR_MASK (1 << 20)
590 #define CLK_TZASC_XR1BXW_MASK (1 << 19)
591 #define CLK_TZASC_XR1BXR_MASK (1 << 18)
592 #define CLK_DPHY1_MASK (1 << 5)
593 #define CLK_DPHY0_MASK (1 << 4)
605 #define DECPROTXSET 0xFF
607 #define LPDDR3PHY_CTRL_PHY_RESET (1 << 0)
608 #define LPDDR3PHY_CTRL_PHY_RESET_OFF (0 << 0)
612 #define PHY_CON0_RESET_VAL 0x17020a40
613 #define P0_CMD_EN (1 << 14)
614 #define BYTE_RDLVL_EN (1 << 13)
615 #define CTRL_SHGATE (1 << 8)
617 #define PHY_CON1_RESET_VAL 0x09210100
618 #define RDLVL_PASS_ADJ_VAL 0x6
619 #define RDLVL_PASS_ADJ_OFFSET 16
620 #define CTRL_GATEDURADJ_MASK (0xf << 20)
621 #define READ_LEVELLING_DDR3 0x0100
623 #define PHY_CON2_RESET_VAL 0x00010004
624 #define INIT_DESKEW_EN (1 << 6)
625 #define DLL_DESKEW_EN (1 << 12)
626 #define RDLVL_GATE_EN (1 << 24)
627 #define RDLVL_EN (1 << 25)
628 #define RDLVL_INCR_ADJ (0x1 << 16)
631 #define DREX_PAUSE_EN (1 << 0)
633 #define BYPASS_EN (1 << 22)
636 #define PHY_CON0_VAL 0x17021A00
638 #define PHY_CON12_RESET_VAL 0x10100070
639 #define PHY_CON12_VAL 0x10107F50
640 #define CTRL_START (1 << 6)
641 #define CTRL_DLL_ON (1 << 5)
642 #define CTRL_FORCE_MASK (0x7F << 8)
643 #define CTRL_LOCK_COARSE_MASK (0x7F << 10)
645 #define CTRL_OFFSETD_RESET_VAL 0x8
646 #define CTRL_OFFSETD_VAL 0x7F
648 #define CTRL_OFFSETR0 0x7F
649 #define CTRL_OFFSETR1 0x7F
650 #define CTRL_OFFSETR2 0x7F
651 #define CTRL_OFFSETR3 0x7F
652 #define PHY_CON4_VAL (CTRL_OFFSETR0 << 0 | \
653 CTRL_OFFSETR1 << 8 | \
654 CTRL_OFFSETR2 << 16 | \
656 #define PHY_CON4_RESET_VAL 0x08080808
658 #define CTRL_OFFSETW0 0x7F
659 #define CTRL_OFFSETW1 0x7F
660 #define CTRL_OFFSETW2 0x7F
661 #define CTRL_OFFSETW3 0x7F
662 #define PHY_CON6_VAL (CTRL_OFFSETW0 << 0 | \
663 CTRL_OFFSETW1 << 8 | \
664 CTRL_OFFSETW2 << 16 | \
666 #define PHY_CON6_RESET_VAL 0x08080808
668 #define PHY_CON14_RESET_VAL 0x001F0000
669 #define CTRL_PULLD_DQS 0xF
670 #define CTRL_PULLD_DQS_OFFSET 0
673 #define PHY_CON16_RESET_VAL 0x08000304
675 #define ZQ_CLK_EN (1 << 27)
676 #define ZQ_CLK_DIV_EN (1 << 18)
677 #define ZQ_MANUAL_MODE_OFFSET 2
678 #define ZQ_LONG_CALIBRATION 0x1
679 #define ZQ_MANUAL_STR (1 << 1)
680 #define ZQ_DONE (1 << 0)
681 #define ZQ_MODE_DDS_OFFSET 24
683 #define LONG_CALIBRATION (ZQ_LONG_CALIBRATION << ZQ_MANUAL_MODE_OFFSET)
685 #define CTRL_RDLVL_GATE_ENABLE 1
686 #define CTRL_RDLVL_GATE_DISABLE 0
688 #define CTRL_RDLVL_DATA_ENABLE (1 << 1)
690 #define DIRECT_CMD_NOP 0x07000000
691 #define DIRECT_CMD_PALL 0x01000000
692 #define DIRECT_CMD_ZQINIT 0x0a000000
693 #define DIRECT_CMD_CHANNEL_SHIFT 28
694 #define DIRECT_CMD_CHIP_SHIFT 20
695 #define DIRECT_CMD_BANK_SHIFT 16
696 #define DIRECT_CMD_REFA (5 << 24)
697 #define DIRECT_CMD_MRS1 0x71C00
698 #define DIRECT_CMD_MRS2 0x10BFC
699 #define DIRECT_CMD_MRS3 0x0050C
700 #define DIRECT_CMD_MRS4 0x00868
701 #define DIRECT_CMD_MRS5 0x00C04
704 #define IMPEDANCE_48_OHM 4
705 #define IMPEDANCE_40_OHM 5
706 #define IMPEDANCE_34_OHM 6
707 #define IMPEDANCE_30_OHM 7
708 #define PHY_CON39_VAL_48_OHM 0x09240924
709 #define PHY_CON39_VAL_40_OHM 0x0B6D0B6D
710 #define PHY_CON39_VAL_34_OHM 0x0DB60DB6
711 #define PHY_CON39_VAL_30_OHM 0x0FFF0FFF
713 #define CTRL_BSTLEN_OFFSET 8
714 #define CTRL_RDLAT_OFFSET 0
716 #define CMD_DEFAULT_LPDDR3 0xF
717 #define CMD_DEFAULT_OFFSET 0
718 #define T_WRDATA_EN 0x7
719 #define T_WRDATA_EN_DDR3 0x8
720 #define T_WRDATA_EN_OFFSET 16
721 #define T_WRDATA_EN_MASK 0x1f
723 #define PHY_CON31_VAL 0x0C183060
724 #define PHY_CON32_VAL 0x60C18306
725 #define PHY_CON33_VAL 0x00000030
727 #define PHY_CON31_RESET_VAL 0x0
728 #define PHY_CON32_RESET_VAL 0x0
729 #define PHY_CON33_RESET_VAL 0x0
731 #define SL_DLL_DYN_CON_EN (1 << 1)
732 #define FP_RESYNC (1 << 3)
733 #define CTRL_START (1 << 6)
735 #define DMC_AREF_EN (1 << 5)
736 #define DMC_CONCONTROL_EMPTY (1 << 8)
737 #define DFI_INIT_START (1 << 28)
739 #define DMC_MEMCONTROL_VAL 0x00312700
740 #define CLK_STOP_EN (1 << 0)
741 #define DPWRDN_EN (1 << 1)
742 #define DSREF_EN (1 << 5)
745 #define DMC_CHIP_MASK_256MB 0x7f0
746 #define DMC_CHIP_MASK_512MB 0x7e0
747 #define DMC_CHIP_MASK_1GB 0x7c0
748 #define DMC_CHIP_MASK_2GB 0x780
749 #define DMC_CHIP_MASK_4GB 0x700
751 #define MEMCONFIG_VAL 0x1323
752 #define PRECHCONFIG_DEFAULT_VAL 0xFF000000
753 #define PWRDNCONFIG_DEFAULT_VAL 0xFFFF00FF
755 #define DFI_INIT_COMPLETE (1 << 3)
757 #define BRBRSVCONTROL_VAL 0x00000033
758 #define BRBRSVCONFIG_VAL 0x88778877
761 #define MEMIF_CG_EN (1 << 3)
762 #define SCG_CG_EN (1 << 2)
763 #define BUSIF_WR_CG_EN (1 << 1)
764 #define BUSIF_RD_CG_EN (1 << 0)
765 #define DMC_INTERNAL_CG (MEMIF_CG_EN | SCG_CG_EN | \
766 BUSIF_WR_CG_EN | BUSIF_RD_CG_EN)
769 #define PHY_CONTROL0_RESET_VAL 0x0
770 #define MEM_TERM_EN (1 << 31)
771 #define PHY_TERM_EN (1 << 30)
772 #define DMC_CTRL_SHGATE (1 << 29)
773 #define CTRL_ATGATE (1 << 6)
774 #define FP_RSYNC (1 << 3)
777 #define IMP_OUTPUT_DRV_40_OHM 0x5
778 #define IMP_OUTPUT_DRV_30_OHM 0x7
779 #define DA_3_DS_OFFSET 25
780 #define DA_2_DS_OFFSET 22
781 #define DA_1_DS_OFFSET 19
782 #define DA_0_DS_OFFSET 16
783 #define CA_CK_DRVR_DS_OFFSET 9
784 #define CA_CKE_DRVR_DS_OFFSET 6
785 #define CA_CS_DRVR_DS_OFFSET 3
786 #define CA_ADR_DRVR_DS_OFFSET 0
788 #define PHY_CON42_CTRL_BSTLEN_SHIFT 8
789 #define PHY_CON42_CTRL_RDLAT_SHIFT 0
void update_reset_dll(struct exynos5_dmc *, enum ddr_mode)
int ddr3_mem_ctrl_init(struct mem_timings *mem, unsigned long mem_iv_size, int mem_reset)
void dmc_config_mrs(struct mem_timings *mem, struct exynos5_dmc *dmc)
int dmc_config_zq(struct mem_timings *mem, struct exynos5_phy_control *phy0_ctrl, struct exynos5_phy_control *phy1_ctrl)
void dmc_config_prech(struct mem_timings *mem, struct exynos5_dmc *dmc)
@ SETUP_ERR_RDLV_COMPLETE_TIMEOUT
@ SETUP_ERR_ZQ_CALIBRATION_FAILURE
void dmc_config_memory(struct mem_timings *mem, struct exynos5_dmc *dmc)
int lpddr3_mem_ctrl_init(int reset)
static void __noreturn reset(void)