blob: 88d6bf3420da4867b5f23b221534c2fcd193a0a1 [file] [log] [blame]
Jernej Skrabece52dc3e2021-01-11 21:11:52 +01001// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
2/*
3 * Copyright (C) 2021 Jernej Skrabec <jernej.skrabec@siol.net>
4 */
5
6#include <common.h>
7#include <clk-uclass.h>
8#include <dm.h>
9#include <errno.h>
Samuel Holland12e3faa2021-09-12 11:48:43 -050010#include <clk/sunxi.h>
Jernej Skrabece52dc3e2021-01-11 21:11:52 +010011#include <dt-bindings/clock/sun50i-h616-ccu.h>
12#include <dt-bindings/reset/sun50i-h616-ccu.h>
13#include <linux/bitops.h>
14
15static struct ccu_clk_gate h616_gates[] = {
Andre Przywara3e9aa0b2022-05-04 22:10:28 +010016 [CLK_PLL_PERIPH0] = GATE(0x020, BIT(31) | BIT(27)),
17
Andre Przywara2d1864f2022-05-05 01:25:43 +010018 [CLK_APB1] = GATE_DUMMY,
19
Samuel Holland1467d442022-11-28 01:02:24 -060020 [CLK_DE] = GATE(0x600, BIT(31)),
21 [CLK_BUS_DE] = GATE(0x60c, BIT(0)),
22
Jernej Skrabece52dc3e2021-01-11 21:11:52 +010023 [CLK_BUS_MMC0] = GATE(0x84c, BIT(0)),
24 [CLK_BUS_MMC1] = GATE(0x84c, BIT(1)),
25 [CLK_BUS_MMC2] = GATE(0x84c, BIT(2)),
26
27 [CLK_BUS_UART0] = GATE(0x90c, BIT(0)),
28 [CLK_BUS_UART1] = GATE(0x90c, BIT(1)),
29 [CLK_BUS_UART2] = GATE(0x90c, BIT(2)),
30 [CLK_BUS_UART3] = GATE(0x90c, BIT(3)),
31 [CLK_BUS_UART4] = GATE(0x90c, BIT(4)),
32 [CLK_BUS_UART5] = GATE(0x90c, BIT(5)),
33
Samuel Hollandfa7a7fa2021-09-12 09:47:24 -050034 [CLK_BUS_I2C0] = GATE(0x91c, BIT(0)),
35 [CLK_BUS_I2C1] = GATE(0x91c, BIT(1)),
36 [CLK_BUS_I2C2] = GATE(0x91c, BIT(2)),
37 [CLK_BUS_I2C3] = GATE(0x91c, BIT(3)),
38 [CLK_BUS_I2C4] = GATE(0x91c, BIT(4)),
39
Jernej Skrabece52dc3e2021-01-11 21:11:52 +010040 [CLK_SPI0] = GATE(0x940, BIT(31)),
41 [CLK_SPI1] = GATE(0x944, BIT(31)),
42
43 [CLK_BUS_SPI0] = GATE(0x96c, BIT(0)),
44 [CLK_BUS_SPI1] = GATE(0x96c, BIT(1)),
45
46 [CLK_BUS_EMAC0] = GATE(0x97c, BIT(0)),
47 [CLK_BUS_EMAC1] = GATE(0x97c, BIT(1)),
48
49 [CLK_USB_PHY0] = GATE(0xa70, BIT(29)),
50 [CLK_USB_OHCI0] = GATE(0xa70, BIT(31)),
51
52 [CLK_USB_PHY1] = GATE(0xa74, BIT(29)),
53 [CLK_USB_OHCI1] = GATE(0xa74, BIT(31)),
54
55 [CLK_USB_PHY2] = GATE(0xa78, BIT(29)),
56 [CLK_USB_OHCI2] = GATE(0xa78, BIT(31)),
57
58 [CLK_USB_PHY3] = GATE(0xa7c, BIT(29)),
59 [CLK_USB_OHCI3] = GATE(0xa7c, BIT(31)),
60
61 [CLK_BUS_OHCI0] = GATE(0xa8c, BIT(0)),
62 [CLK_BUS_OHCI1] = GATE(0xa8c, BIT(1)),
63 [CLK_BUS_OHCI2] = GATE(0xa8c, BIT(2)),
64 [CLK_BUS_OHCI3] = GATE(0xa8c, BIT(3)),
65 [CLK_BUS_EHCI0] = GATE(0xa8c, BIT(4)),
66 [CLK_BUS_EHCI1] = GATE(0xa8c, BIT(5)),
67 [CLK_BUS_EHCI2] = GATE(0xa8c, BIT(6)),
68 [CLK_BUS_EHCI3] = GATE(0xa8c, BIT(7)),
69 [CLK_BUS_OTG] = GATE(0xa8c, BIT(8)),
Samuel Holland1467d442022-11-28 01:02:24 -060070
71 [CLK_HDMI] = GATE(0xb00, BIT(31)),
72 [CLK_HDMI_SLOW] = GATE(0xb04, BIT(31)),
73 [CLK_HDMI_CEC] = GATE(0xb10, BIT(31)),
74 [CLK_BUS_HDMI] = GATE(0xb1c, BIT(0)),
75 [CLK_BUS_TCON_TOP] = GATE(0xb5c, BIT(0)),
76 [CLK_TCON_TV0] = GATE(0xb80, BIT(31)),
77 [CLK_TCON_TV1] = GATE(0xb84, BIT(31)),
78 [CLK_BUS_TCON_TV0] = GATE(0xb9c, BIT(0)),
79 [CLK_BUS_TCON_TV1] = GATE(0xb9c, BIT(1)),
Jernej Skrabece52dc3e2021-01-11 21:11:52 +010080};
81
82static struct ccu_reset h616_resets[] = {
Samuel Holland1467d442022-11-28 01:02:24 -060083 [RST_BUS_DE] = RESET(0x60c, BIT(16)),
84
Jernej Skrabece52dc3e2021-01-11 21:11:52 +010085 [RST_BUS_MMC0] = RESET(0x84c, BIT(16)),
86 [RST_BUS_MMC1] = RESET(0x84c, BIT(17)),
87 [RST_BUS_MMC2] = RESET(0x84c, BIT(18)),
88
89 [RST_BUS_UART0] = RESET(0x90c, BIT(16)),
90 [RST_BUS_UART1] = RESET(0x90c, BIT(17)),
91 [RST_BUS_UART2] = RESET(0x90c, BIT(18)),
92 [RST_BUS_UART3] = RESET(0x90c, BIT(19)),
93 [RST_BUS_UART4] = RESET(0x90c, BIT(20)),
94 [RST_BUS_UART5] = RESET(0x90c, BIT(21)),
95
Samuel Hollandfa7a7fa2021-09-12 09:47:24 -050096 [RST_BUS_I2C0] = RESET(0x91c, BIT(16)),
97 [RST_BUS_I2C1] = RESET(0x91c, BIT(17)),
98 [RST_BUS_I2C2] = RESET(0x91c, BIT(18)),
99 [RST_BUS_I2C3] = RESET(0x91c, BIT(19)),
100 [RST_BUS_I2C4] = RESET(0x91c, BIT(20)),
101
Jernej Skrabece52dc3e2021-01-11 21:11:52 +0100102 [RST_BUS_SPI0] = RESET(0x96c, BIT(16)),
103 [RST_BUS_SPI1] = RESET(0x96c, BIT(17)),
104
105 [RST_BUS_EMAC0] = RESET(0x97c, BIT(16)),
106 [RST_BUS_EMAC1] = RESET(0x97c, BIT(17)),
107
108 [RST_USB_PHY0] = RESET(0xa70, BIT(30)),
109
110 [RST_USB_PHY1] = RESET(0xa74, BIT(30)),
111
112 [RST_USB_PHY2] = RESET(0xa78, BIT(30)),
113
114 [RST_USB_PHY3] = RESET(0xa7c, BIT(30)),
115
116 [RST_BUS_OHCI0] = RESET(0xa8c, BIT(16)),
117 [RST_BUS_OHCI1] = RESET(0xa8c, BIT(17)),
118 [RST_BUS_OHCI2] = RESET(0xa8c, BIT(18)),
119 [RST_BUS_OHCI3] = RESET(0xa8c, BIT(19)),
120 [RST_BUS_EHCI0] = RESET(0xa8c, BIT(20)),
121 [RST_BUS_EHCI1] = RESET(0xa8c, BIT(21)),
122 [RST_BUS_EHCI2] = RESET(0xa8c, BIT(22)),
123 [RST_BUS_EHCI3] = RESET(0xa8c, BIT(23)),
124 [RST_BUS_OTG] = RESET(0xa8c, BIT(24)),
Samuel Holland1467d442022-11-28 01:02:24 -0600125
126 [RST_BUS_HDMI] = RESET(0xb1c, BIT(16)),
127 [RST_BUS_HDMI_SUB] = RESET(0xb1c, BIT(17)),
128 [RST_BUS_TCON_TOP] = RESET(0xb5c, BIT(16)),
129 [RST_BUS_TCON_TV0] = RESET(0xb9c, BIT(16)),
130 [RST_BUS_TCON_TV1] = RESET(0xb9c, BIT(17)),
Jernej Skrabece52dc3e2021-01-11 21:11:52 +0100131};
132
Samuel Holland751c6c62022-05-09 00:29:34 -0500133const struct ccu_desc h616_ccu_desc = {
Jernej Skrabece52dc3e2021-01-11 21:11:52 +0100134 .gates = h616_gates,
135 .resets = h616_resets,
Samuel Holland84436502022-05-09 00:29:31 -0500136 .num_gates = ARRAY_SIZE(h616_gates),
137 .num_resets = ARRAY_SIZE(h616_resets),
Jernej Skrabece52dc3e2021-01-11 21:11:52 +0100138};