blob: 46386f1aba46470240bb9ea886e3e0de7b16366e [file] [log] [blame]
Peng Fan690eea12021-08-07 16:00:45 +08001/* SPDX-License-Identifier: GPL-2.0+ */
2/*
3 * Copyright 2021 NXP
4 */
5
6#ifndef _ASM_ARCH_IMX8ULP_PCC_H
7#define _ASM_ARCH_IMX8ULP_PCC_H
8
9#include <asm/arch/cgc.h>
10
Alice Guo23ee0e12021-10-29 09:46:29 +080011enum pcc1_entry {
12 ADC1_PCC1_SLOT = 34,
13};
14
Peng Fan690eea12021-08-07 16:00:45 +080015enum pcc3_entry {
16 DMA1_MP_PCC3_SLOT = 1,
17 DMA1_CH0_PCC3_SLOT = 2,
18 DMA1_CH1_PCC3_SLOT = 3,
19 DMA1_CH2_PCC3_SLOT = 4,
20 DMA1_CH3_PCC3_SLOT = 5,
21 DMA1_CH4_PCC3_SLOT = 6,
22 DMA1_CH5_PCC3_SLOT = 7,
23 DMA1_CH6_PCC3_SLOT = 8,
24 DMA1_CH7_PCC3_SLOT = 9,
25 DMA1_CH8_PCC3_SLOT = 10,
26 DMA1_CH9_PCC3_SLOT = 11,
27 DMA1_CH10_PCC3_SLOT = 12,
28 DMA1_CH11_PCC3_SLOT = 13,
29 DMA1_CH12_PCC3_SLOT = 14,
30 DMA1_CH13_PCC3_SLOT = 15,
31 DMA1_CH14_PCC3_SLOT = 16,
32 DMA1_CH15_PCC3_SLOT = 17,
33 DMA1_CH16_PCC3_SLOT = 18,
34 DMA1_CH17_PCC3_SLOT = 19,
35 DMA1_CH18_PCC3_SLOT = 20,
36 DMA1_CH19_PCC3_SLOT = 21,
37 DMA1_CH20_PCC3_SLOT = 22,
38 DMA1_CH21_PCC3_SLOT = 23,
39 DMA1_CH22_PCC3_SLOT = 24,
40 DMA1_CH23_PCC3_SLOT = 25,
41 DMA1_CH24_PCC3_SLOT = 26,
42 DMA1_CH25_PCC3_SLOT = 27,
43 DMA1_CH26_PCC3_SLOT = 28,
44 DMA1_CH27_PCC3_SLOT = 29,
45 DMA1_CH28_PCC3_SLOT = 30,
46 DMA1_CH29_PCC3_SLOT = 31,
47 DMA1_CH30_PCC3_SLOT = 32,
48 DMA1_CH31_PCC3_SLOT = 33,
49 MU0_B_PCC3_SLOT = 34,
50 MU3_A_PCC3_SLOT = 35,
51 LLWU1_PCC3_SLOT = 38,
52 UPOWER_PCC3_SLOT = 40,
53 WDOG3_PCC3_SLOT = 42,
54 WDOG4_PCC3_SLOT = 43,
55 XRDC_MGR_PCC3_SLOT = 47,
56 SEMA42_1_PCC3_SLOT = 48,
57 ROMCP1_PCC3_SLOT = 49,
58 LPIT1_PCC3_SLOT = 50,
59 TPM4_PCC3_SLOT = 51,
60 TPM5_PCC3_SLOT = 52,
61 FLEXIO1_PCC3_SLOT = 53,
62 I3C2_PCC3_SLOT = 54,
63 LPI2C4_PCC3_SLOT = 55,
64 LPI2C5_PCC3_SLOT = 56,
65 LPUART4_PCC3_SLOT = 57,
66 LPUART5_PCC3_SLOT = 58,
67 LPSPI4_PCC3_SLOT = 59,
68 LPSPI5_PCC3_SLOT = 60,
69};
70
71enum pcc4_entry {
72 FLEXSPI2_PCC4_SLOT = 1,
73 TPM6_PCC4_SLOT = 2,
74 TPM7_PCC4_SLOT = 3,
75 LPI2C6_PCC4_SLOT = 4,
76 LPI2C7_PCC4_SLOT = 5,
77 LPUART6_PCC4_SLOT = 6,
78 LPUART7_PCC4_SLOT = 7,
79 SAI4_PCC4_SLOT = 8,
80 SAI5_PCC4_SLOT = 9,
81 PCTLE_PCC4_SLOT = 10,
82 PCTLF_PCC4_SLOT = 11,
83 SDHC0_PCC4_SLOT = 13,
84 SDHC1_PCC4_SLOT = 14,
85 SDHC2_PCC4_SLOT = 15,
86 USB0_PCC4_SLOT = 16,
87 USBPHY_PCC4_SLOT = 17,
88 USB1_PCC4_SLOT = 18,
89 USB1PHY_PCC4_SLOT = 19,
90 USB_XBAR_PCC4_SLOT = 20,
91 ENET_PCC4_SLOT = 21,
92 SFA1_PCC4_SLOT = 22,
93 RGPIOE_PCC4_SLOT = 30,
94 RGPIOF_PCC4_SLOT = 31,
95};
96
Ye Lida0469d2021-10-29 09:46:18 +080097enum pcc5_entry {
98 DMA2_MP_PCC5_SLOT = 0,
99 DMA2_CH0_PCC5_SLOT = 1,
100 DMA2_CH1_PCC5_SLOT = 2,
101 DMA2_CH2_PCC5_SLOT = 3,
102 DMA2_CH3_PCC5_SLOT = 4,
103 DMA2_CH4_PCC5_SLOT = 5,
104 DMA2_CH5_PCC5_SLOT = 6,
105 DMA2_CH6_PCC5_SLOT = 7,
106 DMA2_CH7_PCC5_SLOT = 8,
107 DMA2_CH8_PCC5_SLOT = 9,
108 DMA2_CH9_PCC5_SLOT = 10,
109 DMA2_CH10_PCC5_SLOT = 11,
110 DMA2_CH11_PCC5_SLOT = 12,
111 DMA2_CH12_PCC5_SLOT = 13,
112 DMA2_CH13_PCC5_SLOT = 14,
113 DMA2_CH14_PCC5_SLOT = 15,
114 DMA2_CH15_PCC5_SLOT = 16,
115 DMA2_CH16_PCC5_SLOT = 17,
116 DMA2_CH17_PCC5_SLOT = 18,
117 DMA2_CH18_PCC5_SLOT = 19,
118 DMA2_CH19_PCC5_SLOT = 20,
119 DMA2_CH20_PCC5_SLOT = 21,
120 DMA2_CH21_PCC5_SLOT = 22,
121 DMA2_CH22_PCC5_SLOT = 23,
122 DMA2_CH23_PCC5_SLOT = 24,
123 DMA2_CH24_PCC5_SLOT = 25,
124 DMA2_CH25_PCC5_SLOT = 26,
125 DMA2_CH26_PCC5_SLOT = 27,
126 DMA2_CH27_PCC5_SLOT = 28,
127 DMA2_CH28_PCC5_SLOT = 29,
128 DMA2_CH29_PCC5_SLOT = 30,
129 DMA2_CH30_PCC5_SLOT = 31,
130 DMA2_CH31_PCC5_SLOT = 32,
131 MU2_B_PCC5_SLOT = 33,
132 MU3_B_PCC5_SLOT = 34,
133 SEMA42_2_PCC5_SLOT = 35,
134 CMC2_PCC5_SLOT = 36,
135 AVD_SIM_PCC5_SLOT = 37,
136 LPAV_CGC_PCC5_SLOT = 38,
137 PCC5_PCC5_SLOT = 39,
138 TPM8_PCC5_SLOT = 40,
139 SAI6_PCC5_SLOT = 41,
140 SAI7_PCC5_SLOT = 42,
141 SPDIF_PCC5_SLOT = 43,
142 ISI_PCC5_SLOT = 44,
143 CSI_REGS_PCC5_SLOT = 45,
144 CSI_PCC5_SLOT = 47,
145 DSI_PCC5_SLOT = 48,
146 WDOG5_PCC5_SLOT = 50,
147 EPDC_PCC5_SLOT = 51,
148 PXP_PCC5_SLOT = 52,
149 SFA2_PCC5_SLOT = 53,
150 GPU2D_PCC5_SLOT = 60,
151 GPU3D_PCC5_SLOT = 61,
152 DCNANO_PCC5_SLOT = 62,
153 LPDDR4_PCC5_SLOT = 66,
154 CSI_CLK_UI_PCC5_SLOT = 67,
155 CSI_CLK_ESC_PCC5_SLOT = 68,
156 RGPIOD_PCC5_SLOT = 69,
157};
158
Peng Fan690eea12021-08-07 16:00:45 +0800159/* PCC registers */
160#define PCC_PR_OFFSET 31
161#define PCC_PR_MASK (0x1 << PCC_PR_OFFSET)
162#define PCC_CGC_OFFSET 30
163#define PCC_CGC_MASK (0x1 << PCC_CGC_OFFSET)
164#define PCC_INUSE_OFFSET 29
165#define PCC_INUSE_MASK (0x1 << PCC_INUSE_OFFSET)
166#define PCC_PCS_OFFSET 24
167#define PCC_PCS_MASK (0x7 << PCC_PCS_OFFSET)
168#define PCC_FRAC_OFFSET 3
169#define PCC_FRAC_MASK (0x1 << PCC_FRAC_OFFSET)
170#define PCC_PCD_OFFSET 0
171#define PCC_PCD_MASK (0x7 << PCC_PCD_OFFSET)
172
173enum pcc_clksrc_type {
174 CLKSRC_PER_PLAT = 0,
175 CLKSRC_PER_BUS = 1,
176 CLKSRC_NO_PCS = 2,
177};
178
179enum pcc_div_type {
180 PCC_HAS_DIV,
181 PCC_NO_DIV,
182};
183
184enum pcc_rst_b {
185 PCC_HAS_RST_B,
186 PCC_NO_RST_B,
187};
188
189/* This structure keeps info for each pcc slot */
190struct pcc_entry {
191 u32 pcc_base;
192 u32 pcc_slot;
193 enum pcc_clksrc_type clksrc;
194 enum pcc_div_type div;
195 enum pcc_rst_b rst_b;
196};
197
198int pcc_clock_enable(int pcc_controller, int pcc_clk_slot, bool enable);
Ye Lida0469d2021-10-29 09:46:18 +0800199int pcc_clock_sel(int pcc_controller, int pcc_clk_slot, enum cgc_clk src);
Peng Fan690eea12021-08-07 16:00:45 +0800200int pcc_clock_div_config(int pcc_controller, int pcc_clk_slot, bool frac, u8 div);
201bool pcc_clock_is_enable(int pcc_controller, int pcc_clk_slot);
Ye Lida0469d2021-10-29 09:46:18 +0800202int pcc_clock_get_clksrc(int pcc_controller, int pcc_clk_slot, enum cgc_clk *src);
Peng Fan690eea12021-08-07 16:00:45 +0800203int pcc_reset_peripheral(int pcc_controller, int pcc_clk_slot, bool reset);
204u32 pcc_clock_get_rate(int pcc_controller, int pcc_clk_slot);
205#endif