blob: 4a0010b5c7d9cfffaddd412e26ba984d8613e730 [file] [log] [blame]
Masahiro Yamadabb2ff9d2014-10-03 19:21:06 +09001/*
Masahiro Yamada9d6652c2016-09-17 03:33:09 +09002 * Copyright (C) 2013-2014 Panasonic Corporation
3 * Copyright (C) 2015-2016 Socionext Inc.
Masahiro Yamadabb2ff9d2014-10-03 19:21:06 +09004 *
5 * SPDX-License-Identifier: GPL-2.0+
6 */
7
Masahiro Yamadaeb6aeca2017-01-21 18:05:25 +09008#include <linux/delay.h>
Masahiro Yamada663a23f2015-05-29 17:30:00 +09009#include <linux/io.h>
Masahiro Yamadaefdf3402016-01-09 01:51:13 +090010
11#include "../init.h"
12#include "../sc-regs.h"
Masahiro Yamadabb2ff9d2014-10-03 19:21:06 +090013
Masahiro Yamada9d6652c2016-09-17 03:33:09 +090014int uniphier_sld8_dpll_init(const struct uniphier_board_data *bd)
Masahiro Yamadabb2ff9d2014-10-03 19:21:06 +090015{
16 u32 tmp;
17 /*
18 * Set DPLL SSC parameters for DPLLCTRL3
19 * [23] DIVN_TEST 0x1
20 * [22:16] DIVN 0x50
21 * [10] FREFSEL_TEST 0x1
22 * [9:8] FREFSEL 0x2
23 * [4] ICPD_TEST 0x1
24 * [3:0] ICPD 0xb
25 */
26 tmp = readl(SC_DPLLCTRL3);
27 tmp &= ~0x00ff0717;
28 tmp |= 0x00d0061b;
29 writel(tmp, SC_DPLLCTRL3);
30
31 /*
32 * Set DPLL SSC parameters for DPLLCTRL
33 * <-1%> <-2%>
34 * [29:20] SSC_UPCNT 132 (0x084) 132 (0x084)
35 * [14:0] SSC_dK 6335(0x18bf) 12710(0x31a6)
36 */
37 tmp = readl(SC_DPLLCTRL);
38 tmp &= ~0x3ff07fff;
Masahiro Yamadaab615502016-09-17 03:33:08 +090039#ifdef DPLL_SSC_RATE_1PER
Masahiro Yamadabb2ff9d2014-10-03 19:21:06 +090040 tmp |= 0x084018bf;
41#else
42 tmp |= 0x084031a6;
43#endif
44 writel(tmp, SC_DPLLCTRL);
45
46 /*
47 * Set DPLL SSC parameters for DPLLCTRL2
48 * [31:29] SSC_STEP 0
49 * [27] SSC_REG_REF 1
50 * [26:20] SSC_M 79 (0x4f)
51 * [19:0] SSC_K 964689 (0xeb851)
52 */
53 tmp = readl(SC_DPLLCTRL2);
54 tmp &= ~0xefffffff;
55 tmp |= 0x0cfeb851;
56 writel(tmp, SC_DPLLCTRL2);
Masahiro Yamadabb2ff9d2014-10-03 19:21:06 +090057
Masahiro Yamada9d6652c2016-09-17 03:33:09 +090058 /* Wait 500 usec until dpll gets stable */
59 udelay(500);
Masahiro Yamada75f16f82015-09-22 00:27:39 +090060
61 return 0;
Masahiro Yamadabb2ff9d2014-10-03 19:21:06 +090062}