blob: 0d9240519c2525ac5293b29d94293b1ecd3e0d77 [file] [log] [blame]
Masahiro Yamada019df872015-09-22 00:27:41 +09001/*
2 * Copyright (C) 2015 Masahiro Yamada <yamada.masahiro@socionext.com>
3 *
4 * SPDX-License-Identifier: GPL-2.0+
5 */
6
Masahiro Yamada29d63a52016-07-22 20:20:11 +09007#include <linux/bitops.h>
Masahiro Yamada019df872015-09-22 00:27:41 +09008#include <linux/io.h>
Masahiro Yamada107b3fb2016-01-09 01:51:13 +09009
10#include "../init.h"
11#include "../sc-regs.h"
Masahiro Yamada019df872015-09-22 00:27:41 +090012
Masahiro Yamada5b660062016-03-30 20:17:02 +090013void uniphier_pxs2_clk_init(void)
Masahiro Yamada019df872015-09-22 00:27:41 +090014{
15 u32 tmp;
16
17 /* deassert reset */
18 tmp = readl(SC_RSTCTRL);
19#ifdef CONFIG_USB_XHCI_UNIPHIER
20 tmp |= SC_RSTCTRL_NRST_USB3B0 | SC_RSTCTRL_NRST_GIO;
21#endif
22#ifdef CONFIG_UNIPHIER_ETH
23 tmp |= SC_RSTCTRL_NRST_ETHER;
24#endif
25#ifdef CONFIG_NAND_DENALI
26 tmp |= SC_RSTCTRL_NRST_NAND;
27#endif
28 writel(tmp, SC_RSTCTRL);
29 readl(SC_RSTCTRL); /* dummy read */
30
31#ifdef CONFIG_USB_XHCI_UNIPHIER
32 tmp = readl(SC_RSTCTRL2);
33 tmp |= SC_RSTCTRL2_NRST_USB3B1;
34 writel(tmp, SC_RSTCTRL2);
35 readl(SC_RSTCTRL2); /* dummy read */
Masahiro Yamada29d63a52016-07-22 20:20:11 +090036
37 tmp = readl(SC_RSTCTRL6);
38 tmp |= 0x37;
39 writel(tmp, SC_RSTCTRL6);
Masahiro Yamada019df872015-09-22 00:27:41 +090040#endif
41
Masahiro Yamada67976302016-03-30 20:17:42 +090042 /* provide clocks */
Masahiro Yamada019df872015-09-22 00:27:41 +090043 tmp = readl(SC_CLKCTRL);
44#ifdef CONFIG_USB_XHCI_UNIPHIER
Masahiro Yamada29d63a52016-07-22 20:20:11 +090045 tmp |= BIT(20) | BIT(19) | SC_CLKCTRL_CEN_USB31 | SC_CLKCTRL_CEN_USB30 |
Masahiro Yamada019df872015-09-22 00:27:41 +090046 SC_CLKCTRL_CEN_GIO;
47#endif
48#ifdef CONFIG_UNIPHIER_ETH
49 tmp |= SC_CLKCTRL_CEN_ETHER;
50#endif
51#ifdef CONFIG_NAND_DENALI
52 tmp |= SC_CLKCTRL_CEN_NAND;
53#endif
54 writel(tmp, SC_CLKCTRL);
55 readl(SC_CLKCTRL); /* dummy read */
56}