xref: /OK3568_Linux_fs/u-boot/drivers/pinctrl/rockchip/pinctrl-rockchip.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0+ */
2*4882a593Smuzhiyun /*
3*4882a593Smuzhiyun  * (C) Copyright 2019 Rockchip Electronics Co., Ltd
4*4882a593Smuzhiyun  */
5*4882a593Smuzhiyun 
6*4882a593Smuzhiyun #ifndef __DRIVERS_PINCTRL_ROCKCHIP_H
7*4882a593Smuzhiyun #define __DRIVERS_PINCTRL_ROCKCHIP_H
8*4882a593Smuzhiyun 
9*4882a593Smuzhiyun #include <dt-bindings/pinctrl/rockchip.h>
10*4882a593Smuzhiyun #include <linux/types.h>
11*4882a593Smuzhiyun 
12*4882a593Smuzhiyun #define RK_GPIO0_A0	0
13*4882a593Smuzhiyun #define RK_GPIO0_A1	1
14*4882a593Smuzhiyun #define RK_GPIO0_A2	2
15*4882a593Smuzhiyun #define RK_GPIO0_A3	3
16*4882a593Smuzhiyun #define RK_GPIO0_A4	4
17*4882a593Smuzhiyun #define RK_GPIO0_A5	5
18*4882a593Smuzhiyun #define RK_GPIO0_A6	6
19*4882a593Smuzhiyun #define RK_GPIO0_A7	7
20*4882a593Smuzhiyun #define RK_GPIO0_B0	8
21*4882a593Smuzhiyun #define RK_GPIO0_B1	9
22*4882a593Smuzhiyun #define RK_GPIO0_B2	10
23*4882a593Smuzhiyun #define RK_GPIO0_B3	11
24*4882a593Smuzhiyun #define RK_GPIO0_B4	12
25*4882a593Smuzhiyun #define RK_GPIO0_B5	13
26*4882a593Smuzhiyun #define RK_GPIO0_B6	14
27*4882a593Smuzhiyun #define RK_GPIO0_B7	15
28*4882a593Smuzhiyun #define RK_GPIO0_C0	16
29*4882a593Smuzhiyun #define RK_GPIO0_C1	17
30*4882a593Smuzhiyun #define RK_GPIO0_C2	18
31*4882a593Smuzhiyun #define RK_GPIO0_C3	19
32*4882a593Smuzhiyun #define RK_GPIO0_C4	20
33*4882a593Smuzhiyun #define RK_GPIO0_C5	21
34*4882a593Smuzhiyun #define RK_GPIO0_C6	22
35*4882a593Smuzhiyun #define RK_GPIO0_C7	23
36*4882a593Smuzhiyun #define RK_GPIO0_D0	24
37*4882a593Smuzhiyun #define RK_GPIO0_D1	25
38*4882a593Smuzhiyun #define RK_GPIO0_D2	26
39*4882a593Smuzhiyun #define RK_GPIO0_D3	27
40*4882a593Smuzhiyun #define RK_GPIO0_D4	28
41*4882a593Smuzhiyun #define RK_GPIO0_D5	29
42*4882a593Smuzhiyun #define RK_GPIO0_D6	30
43*4882a593Smuzhiyun #define RK_GPIO0_D7	31
44*4882a593Smuzhiyun 
45*4882a593Smuzhiyun #define RK_GPIO1_A0	32
46*4882a593Smuzhiyun #define RK_GPIO1_A1	33
47*4882a593Smuzhiyun #define RK_GPIO1_A2	34
48*4882a593Smuzhiyun #define RK_GPIO1_A3	35
49*4882a593Smuzhiyun #define RK_GPIO1_A4	36
50*4882a593Smuzhiyun #define RK_GPIO1_A5	37
51*4882a593Smuzhiyun #define RK_GPIO1_A6	38
52*4882a593Smuzhiyun #define RK_GPIO1_A7	39
53*4882a593Smuzhiyun #define RK_GPIO1_B0	40
54*4882a593Smuzhiyun #define RK_GPIO1_B1	41
55*4882a593Smuzhiyun #define RK_GPIO1_B2	42
56*4882a593Smuzhiyun #define RK_GPIO1_B3	43
57*4882a593Smuzhiyun #define RK_GPIO1_B4	44
58*4882a593Smuzhiyun #define RK_GPIO1_B5	45
59*4882a593Smuzhiyun #define RK_GPIO1_B6	46
60*4882a593Smuzhiyun #define RK_GPIO1_B7	47
61*4882a593Smuzhiyun #define RK_GPIO1_C0	48
62*4882a593Smuzhiyun #define RK_GPIO1_C1	49
63*4882a593Smuzhiyun #define RK_GPIO1_C2	50
64*4882a593Smuzhiyun #define RK_GPIO1_C3	51
65*4882a593Smuzhiyun #define RK_GPIO1_C4	52
66*4882a593Smuzhiyun #define RK_GPIO1_C5	53
67*4882a593Smuzhiyun #define RK_GPIO1_C6	54
68*4882a593Smuzhiyun #define RK_GPIO1_C7	55
69*4882a593Smuzhiyun #define RK_GPIO1_D0	56
70*4882a593Smuzhiyun #define RK_GPIO1_D1	57
71*4882a593Smuzhiyun #define RK_GPIO1_D2	58
72*4882a593Smuzhiyun #define RK_GPIO1_D3	59
73*4882a593Smuzhiyun #define RK_GPIO1_D4	60
74*4882a593Smuzhiyun #define RK_GPIO1_D5	61
75*4882a593Smuzhiyun #define RK_GPIO1_D6	62
76*4882a593Smuzhiyun #define RK_GPIO1_D7	63
77*4882a593Smuzhiyun 
78*4882a593Smuzhiyun #define RK_GPIO2_A0	64
79*4882a593Smuzhiyun #define RK_GPIO2_A1	65
80*4882a593Smuzhiyun #define RK_GPIO2_A2	66
81*4882a593Smuzhiyun #define RK_GPIO2_A3	67
82*4882a593Smuzhiyun #define RK_GPIO2_A4	68
83*4882a593Smuzhiyun #define RK_GPIO2_A5	69
84*4882a593Smuzhiyun #define RK_GPIO2_A6	70
85*4882a593Smuzhiyun #define RK_GPIO2_A7	71
86*4882a593Smuzhiyun #define RK_GPIO2_B0	72
87*4882a593Smuzhiyun #define RK_GPIO2_B1	73
88*4882a593Smuzhiyun #define RK_GPIO2_B2	74
89*4882a593Smuzhiyun #define RK_GPIO2_B3	75
90*4882a593Smuzhiyun #define RK_GPIO2_B4	76
91*4882a593Smuzhiyun #define RK_GPIO2_B5	77
92*4882a593Smuzhiyun #define RK_GPIO2_B6	78
93*4882a593Smuzhiyun #define RK_GPIO2_B7	79
94*4882a593Smuzhiyun #define RK_GPIO2_C0	80
95*4882a593Smuzhiyun #define RK_GPIO2_C1	81
96*4882a593Smuzhiyun #define RK_GPIO2_C2	82
97*4882a593Smuzhiyun #define RK_GPIO2_C3	83
98*4882a593Smuzhiyun #define RK_GPIO2_C4	84
99*4882a593Smuzhiyun #define RK_GPIO2_C5	85
100*4882a593Smuzhiyun #define RK_GPIO2_C6	86
101*4882a593Smuzhiyun #define RK_GPIO2_C7	87
102*4882a593Smuzhiyun #define RK_GPIO2_D0	88
103*4882a593Smuzhiyun #define RK_GPIO2_D1	89
104*4882a593Smuzhiyun #define RK_GPIO2_D2	90
105*4882a593Smuzhiyun #define RK_GPIO2_D3	91
106*4882a593Smuzhiyun #define RK_GPIO2_D4	92
107*4882a593Smuzhiyun #define RK_GPIO2_D5	93
108*4882a593Smuzhiyun #define RK_GPIO2_D6	94
109*4882a593Smuzhiyun #define RK_GPIO2_D7	95
110*4882a593Smuzhiyun 
111*4882a593Smuzhiyun #define RK_GPIO3_A0	96
112*4882a593Smuzhiyun #define RK_GPIO3_A1	97
113*4882a593Smuzhiyun #define RK_GPIO3_A2	98
114*4882a593Smuzhiyun #define RK_GPIO3_A3	99
115*4882a593Smuzhiyun #define RK_GPIO3_A4	100
116*4882a593Smuzhiyun #define RK_GPIO3_A5	101
117*4882a593Smuzhiyun #define RK_GPIO3_A6	102
118*4882a593Smuzhiyun #define RK_GPIO3_A7	103
119*4882a593Smuzhiyun #define RK_GPIO3_B0	104
120*4882a593Smuzhiyun #define RK_GPIO3_B1	105
121*4882a593Smuzhiyun #define RK_GPIO3_B2	106
122*4882a593Smuzhiyun #define RK_GPIO3_B3	107
123*4882a593Smuzhiyun #define RK_GPIO3_B4	108
124*4882a593Smuzhiyun #define RK_GPIO3_B5	109
125*4882a593Smuzhiyun #define RK_GPIO3_B6	110
126*4882a593Smuzhiyun #define RK_GPIO3_B7	111
127*4882a593Smuzhiyun #define RK_GPIO3_C0	112
128*4882a593Smuzhiyun #define RK_GPIO3_C1	113
129*4882a593Smuzhiyun #define RK_GPIO3_C2	114
130*4882a593Smuzhiyun #define RK_GPIO3_C3	115
131*4882a593Smuzhiyun #define RK_GPIO3_C4	116
132*4882a593Smuzhiyun #define RK_GPIO3_C5	117
133*4882a593Smuzhiyun #define RK_GPIO3_C6	118
134*4882a593Smuzhiyun #define RK_GPIO3_C7	119
135*4882a593Smuzhiyun #define RK_GPIO3_D0	120
136*4882a593Smuzhiyun #define RK_GPIO3_D1	121
137*4882a593Smuzhiyun #define RK_GPIO3_D2	122
138*4882a593Smuzhiyun #define RK_GPIO3_D3	123
139*4882a593Smuzhiyun #define RK_GPIO3_D4	124
140*4882a593Smuzhiyun #define RK_GPIO3_D5	125
141*4882a593Smuzhiyun #define RK_GPIO3_D6	126
142*4882a593Smuzhiyun #define RK_GPIO3_D7	127
143*4882a593Smuzhiyun 
144*4882a593Smuzhiyun #define RK_GPIO4_A0	128
145*4882a593Smuzhiyun #define RK_GPIO4_A1	129
146*4882a593Smuzhiyun #define RK_GPIO4_A2	130
147*4882a593Smuzhiyun #define RK_GPIO4_A3	131
148*4882a593Smuzhiyun #define RK_GPIO4_A4	132
149*4882a593Smuzhiyun #define RK_GPIO4_A5	133
150*4882a593Smuzhiyun #define RK_GPIO4_A6	134
151*4882a593Smuzhiyun #define RK_GPIO4_A7	135
152*4882a593Smuzhiyun #define RK_GPIO4_B0	136
153*4882a593Smuzhiyun #define RK_GPIO4_B1	137
154*4882a593Smuzhiyun #define RK_GPIO4_B2	138
155*4882a593Smuzhiyun #define RK_GPIO4_B3	139
156*4882a593Smuzhiyun #define RK_GPIO4_B4	140
157*4882a593Smuzhiyun #define RK_GPIO4_B5	141
158*4882a593Smuzhiyun #define RK_GPIO4_B6	142
159*4882a593Smuzhiyun #define RK_GPIO4_B7	143
160*4882a593Smuzhiyun #define RK_GPIO4_C0	144
161*4882a593Smuzhiyun #define RK_GPIO4_C1	145
162*4882a593Smuzhiyun #define RK_GPIO4_C2	146
163*4882a593Smuzhiyun #define RK_GPIO4_C3	147
164*4882a593Smuzhiyun #define RK_GPIO4_C4	148
165*4882a593Smuzhiyun #define RK_GPIO4_C5	149
166*4882a593Smuzhiyun #define RK_GPIO4_C6	150
167*4882a593Smuzhiyun #define RK_GPIO4_C7	151
168*4882a593Smuzhiyun #define RK_GPIO4_D0	152
169*4882a593Smuzhiyun #define RK_GPIO4_D1	153
170*4882a593Smuzhiyun #define RK_GPIO4_D2	154
171*4882a593Smuzhiyun #define RK_GPIO4_D3	155
172*4882a593Smuzhiyun #define RK_GPIO4_D4	156
173*4882a593Smuzhiyun #define RK_GPIO4_D5	157
174*4882a593Smuzhiyun #define RK_GPIO4_D6	158
175*4882a593Smuzhiyun #define RK_GPIO4_D7	159
176*4882a593Smuzhiyun 
177*4882a593Smuzhiyun #define RK_GENMASK_VAL(h, l, v) \
178*4882a593Smuzhiyun 	(GENMASK(((h) + 16), ((l) + 16)) | (((v) << (l)) & GENMASK((h), (l))))
179*4882a593Smuzhiyun 
180*4882a593Smuzhiyun /**
181*4882a593Smuzhiyun  * Encode variants of iomux registers into a type variable
182*4882a593Smuzhiyun  */
183*4882a593Smuzhiyun #define IOMUX_GPIO_ONLY		BIT(0)
184*4882a593Smuzhiyun #define IOMUX_WIDTH_4BIT	BIT(1)
185*4882a593Smuzhiyun #define IOMUX_SOURCE_PMU	BIT(2)
186*4882a593Smuzhiyun #define IOMUX_UNROUTED		BIT(3)
187*4882a593Smuzhiyun #define IOMUX_WIDTH_3BIT	BIT(4)
188*4882a593Smuzhiyun #define IOMUX_8WIDTH_2BIT	BIT(5)
189*4882a593Smuzhiyun #define IOMUX_WRITABLE_32BIT	BIT(6)
190*4882a593Smuzhiyun #define IOMUX_L_SOURCE_PMU	BIT(7)
191*4882a593Smuzhiyun 
192*4882a593Smuzhiyun /**
193*4882a593Smuzhiyun  * Defined some common pins constants
194*4882a593Smuzhiyun  */
195*4882a593Smuzhiyun #define ROCKCHIP_PULL_BITS_PER_PIN	2
196*4882a593Smuzhiyun #define ROCKCHIP_PULL_PINS_PER_REG	8
197*4882a593Smuzhiyun #define ROCKCHIP_PULL_BANK_STRIDE	16
198*4882a593Smuzhiyun #define ROCKCHIP_DRV_BITS_PER_PIN	2
199*4882a593Smuzhiyun #define ROCKCHIP_DRV_PINS_PER_REG	8
200*4882a593Smuzhiyun #define ROCKCHIP_DRV_BANK_STRIDE	16
201*4882a593Smuzhiyun #define ROCKCHIP_DRV_3BITS_PER_PIN	3
202*4882a593Smuzhiyun 
203*4882a593Smuzhiyun /**
204*4882a593Smuzhiyun  * @type: iomux variant using IOMUX_* constants
205*4882a593Smuzhiyun  * @offset: if initialized to -1 it will be autocalculated, by specifying
206*4882a593Smuzhiyun  *	    an initial offset value the relevant source offset can be reset
207*4882a593Smuzhiyun  *	    to a new value for autocalculating the following iomux registers.
208*4882a593Smuzhiyun  */
209*4882a593Smuzhiyun struct rockchip_iomux {
210*4882a593Smuzhiyun 	int				type;
211*4882a593Smuzhiyun 	int				offset;
212*4882a593Smuzhiyun };
213*4882a593Smuzhiyun 
214*4882a593Smuzhiyun #define DRV_TYPE_IO_MASK		GENMASK(31, 16)
215*4882a593Smuzhiyun #define DRV_TYPE_WRITABLE_32BIT		BIT(31)
216*4882a593Smuzhiyun 
217*4882a593Smuzhiyun /**
218*4882a593Smuzhiyun  * enum type index corresponding to rockchip_perpin_drv_list arrays index.
219*4882a593Smuzhiyun  */
220*4882a593Smuzhiyun enum rockchip_pin_drv_type {
221*4882a593Smuzhiyun 	DRV_TYPE_IO_DEFAULT = 0,
222*4882a593Smuzhiyun 	DRV_TYPE_IO_1V8_OR_3V0,
223*4882a593Smuzhiyun 	DRV_TYPE_IO_1V8_ONLY,
224*4882a593Smuzhiyun 	DRV_TYPE_IO_1V8_3V0_AUTO,
225*4882a593Smuzhiyun 	DRV_TYPE_IO_3V3_ONLY,
226*4882a593Smuzhiyun 	DRV_TYPE_MAX
227*4882a593Smuzhiyun };
228*4882a593Smuzhiyun 
229*4882a593Smuzhiyun #define PULL_TYPE_IO_MASK		GENMASK(31, 16)
230*4882a593Smuzhiyun #define PULL_TYPE_WRITABLE_32BIT	BIT(31)
231*4882a593Smuzhiyun 
232*4882a593Smuzhiyun /**
233*4882a593Smuzhiyun  * enum type index corresponding to rockchip_pull_list arrays index.
234*4882a593Smuzhiyun  */
235*4882a593Smuzhiyun enum rockchip_pin_pull_type {
236*4882a593Smuzhiyun 	PULL_TYPE_IO_DEFAULT = 0,
237*4882a593Smuzhiyun 	PULL_TYPE_IO_1V8_ONLY,
238*4882a593Smuzhiyun 	PULL_TYPE_MAX
239*4882a593Smuzhiyun };
240*4882a593Smuzhiyun 
241*4882a593Smuzhiyun /**
242*4882a593Smuzhiyun  * enum mux route register type, should be invalid/default/topgrf/pmugrf.
243*4882a593Smuzhiyun  * INVALID: means do not need to set mux route
244*4882a593Smuzhiyun  * DEFAULT: means same regmap as pin iomux
245*4882a593Smuzhiyun  * TOPGRF: means mux route setting in topgrf
246*4882a593Smuzhiyun  * PMUGRF: means mux route setting in pmugrf
247*4882a593Smuzhiyun  */
248*4882a593Smuzhiyun enum rockchip_pin_route_type {
249*4882a593Smuzhiyun 	ROUTE_TYPE_DEFAULT = 0,
250*4882a593Smuzhiyun 	ROUTE_TYPE_TOPGRF = 1,
251*4882a593Smuzhiyun 	ROUTE_TYPE_PMUGRF = 2,
252*4882a593Smuzhiyun 
253*4882a593Smuzhiyun 	ROUTE_TYPE_INVALID = -1,
254*4882a593Smuzhiyun };
255*4882a593Smuzhiyun 
256*4882a593Smuzhiyun /**
257*4882a593Smuzhiyun  * @drv_type: drive strength variant using rockchip_perpin_drv_type
258*4882a593Smuzhiyun  * @offset: if initialized to -1 it will be autocalculated, by specifying
259*4882a593Smuzhiyun  *	    an initial offset value the relevant source offset can be reset
260*4882a593Smuzhiyun  *	    to a new value for autocalculating the following drive strength
261*4882a593Smuzhiyun  *	    registers. if used chips own cal_drv func instead to calculate
262*4882a593Smuzhiyun  *	    registers offset, the variant could be ignored.
263*4882a593Smuzhiyun  */
264*4882a593Smuzhiyun struct rockchip_drv {
265*4882a593Smuzhiyun 	enum rockchip_pin_drv_type	drv_type;
266*4882a593Smuzhiyun 	int				offset;
267*4882a593Smuzhiyun };
268*4882a593Smuzhiyun 
269*4882a593Smuzhiyun /**
270*4882a593Smuzhiyun  * @priv: common pinctrl private basedata
271*4882a593Smuzhiyun  * @pin_base: first pin number
272*4882a593Smuzhiyun  * @nr_pins: number of pins in this bank
273*4882a593Smuzhiyun  * @name: name of the bank
274*4882a593Smuzhiyun  * @bank_num: number of the bank, to account for holes
275*4882a593Smuzhiyun  * @iomux: array describing the 4 iomux sources of the bank
276*4882a593Smuzhiyun  * @drv: array describing the 4 drive strength sources of the bank
277*4882a593Smuzhiyun  * @pull_type: array describing the 4 pull type sources of the bank
278*4882a593Smuzhiyun  * @recalced_mask: bits describing the mux recalced pins of per bank
279*4882a593Smuzhiyun  * @route_mask: bits describing the routing pins of per bank
280*4882a593Smuzhiyun  */
281*4882a593Smuzhiyun struct rockchip_pin_bank {
282*4882a593Smuzhiyun 	struct rockchip_pinctrl_priv	*priv;
283*4882a593Smuzhiyun 	u32				pin_base;
284*4882a593Smuzhiyun 	u8				nr_pins;
285*4882a593Smuzhiyun 	char				*name;
286*4882a593Smuzhiyun 	u8				bank_num;
287*4882a593Smuzhiyun 	struct rockchip_iomux		iomux[4];
288*4882a593Smuzhiyun 	struct rockchip_drv		drv[4];
289*4882a593Smuzhiyun 	enum rockchip_pin_pull_type	pull_type[4];
290*4882a593Smuzhiyun 	u32				recalced_mask;
291*4882a593Smuzhiyun 	u32				route_mask;
292*4882a593Smuzhiyun };
293*4882a593Smuzhiyun 
294*4882a593Smuzhiyun #define PIN_BANK(id, pins, label)			\
295*4882a593Smuzhiyun 	{						\
296*4882a593Smuzhiyun 		.bank_num	= id,			\
297*4882a593Smuzhiyun 		.nr_pins	= pins,			\
298*4882a593Smuzhiyun 		.name		= label,		\
299*4882a593Smuzhiyun 		.iomux		= {			\
300*4882a593Smuzhiyun 			{ .offset = -1 },		\
301*4882a593Smuzhiyun 			{ .offset = -1 },		\
302*4882a593Smuzhiyun 			{ .offset = -1 },		\
303*4882a593Smuzhiyun 			{ .offset = -1 },		\
304*4882a593Smuzhiyun 		},					\
305*4882a593Smuzhiyun 	}
306*4882a593Smuzhiyun 
307*4882a593Smuzhiyun #define PIN_BANK_IOMUX_FLAGS(id, pins, label, iom0, iom1, iom2, iom3)	\
308*4882a593Smuzhiyun 	{								\
309*4882a593Smuzhiyun 		.bank_num	= id,					\
310*4882a593Smuzhiyun 		.nr_pins	= pins,					\
311*4882a593Smuzhiyun 		.name		= label,				\
312*4882a593Smuzhiyun 		.iomux		= {					\
313*4882a593Smuzhiyun 			{ .type = iom0, .offset = -1 },			\
314*4882a593Smuzhiyun 			{ .type = iom1, .offset = -1 },			\
315*4882a593Smuzhiyun 			{ .type = iom2, .offset = -1 },			\
316*4882a593Smuzhiyun 			{ .type = iom3, .offset = -1 },			\
317*4882a593Smuzhiyun 		},							\
318*4882a593Smuzhiyun 	}
319*4882a593Smuzhiyun 
320*4882a593Smuzhiyun #define PIN_BANK_IOMUX_FLAGS_OFFSET(id, pins, label, iom0, iom1, iom2,	\
321*4882a593Smuzhiyun 				    iom3, offset0, offset1, offset2,	\
322*4882a593Smuzhiyun 				    offset3)				\
323*4882a593Smuzhiyun 	{								\
324*4882a593Smuzhiyun 		.bank_num	= id,					\
325*4882a593Smuzhiyun 		.nr_pins	= pins,					\
326*4882a593Smuzhiyun 		.name		= label,				\
327*4882a593Smuzhiyun 		.iomux		= {					\
328*4882a593Smuzhiyun 			{ .type = iom0, .offset = offset0 },		\
329*4882a593Smuzhiyun 			{ .type = iom1, .offset = offset1 },		\
330*4882a593Smuzhiyun 			{ .type = iom2, .offset = offset2 },		\
331*4882a593Smuzhiyun 			{ .type = iom3, .offset = offset3 },		\
332*4882a593Smuzhiyun 		},							\
333*4882a593Smuzhiyun 	}
334*4882a593Smuzhiyun 
335*4882a593Smuzhiyun #define PIN_BANK_DRV_FLAGS(id, pins, label, type0, type1, type2, type3) \
336*4882a593Smuzhiyun 	{								\
337*4882a593Smuzhiyun 		.bank_num	= id,					\
338*4882a593Smuzhiyun 		.nr_pins	= pins,					\
339*4882a593Smuzhiyun 		.name		= label,				\
340*4882a593Smuzhiyun 		.iomux		= {					\
341*4882a593Smuzhiyun 			{ .offset = -1 },				\
342*4882a593Smuzhiyun 			{ .offset = -1 },				\
343*4882a593Smuzhiyun 			{ .offset = -1 },				\
344*4882a593Smuzhiyun 			{ .offset = -1 },				\
345*4882a593Smuzhiyun 		},							\
346*4882a593Smuzhiyun 		.drv		= {					\
347*4882a593Smuzhiyun 			{ .drv_type = type0, .offset = -1 },		\
348*4882a593Smuzhiyun 			{ .drv_type = type1, .offset = -1 },		\
349*4882a593Smuzhiyun 			{ .drv_type = type2, .offset = -1 },		\
350*4882a593Smuzhiyun 			{ .drv_type = type3, .offset = -1 },		\
351*4882a593Smuzhiyun 		},							\
352*4882a593Smuzhiyun 	}
353*4882a593Smuzhiyun 
354*4882a593Smuzhiyun #define PIN_BANK_IOMUX_FLAGS_PULL_FLAGS(id, pins, label, iom0, iom1,	\
355*4882a593Smuzhiyun 					iom2, iom3, pull0, pull1,	\
356*4882a593Smuzhiyun 					pull2, pull3)			\
357*4882a593Smuzhiyun 	{								\
358*4882a593Smuzhiyun 		.bank_num	= id,					\
359*4882a593Smuzhiyun 		.nr_pins	= pins,					\
360*4882a593Smuzhiyun 		.name		= label,				\
361*4882a593Smuzhiyun 		.iomux		= {					\
362*4882a593Smuzhiyun 			{ .type = iom0, .offset = -1 },			\
363*4882a593Smuzhiyun 			{ .type = iom1, .offset = -1 },			\
364*4882a593Smuzhiyun 			{ .type = iom2, .offset = -1 },			\
365*4882a593Smuzhiyun 			{ .type = iom3, .offset = -1 },			\
366*4882a593Smuzhiyun 		},							\
367*4882a593Smuzhiyun 		.pull_type[0] = pull0,					\
368*4882a593Smuzhiyun 		.pull_type[1] = pull1,					\
369*4882a593Smuzhiyun 		.pull_type[2] = pull2,					\
370*4882a593Smuzhiyun 		.pull_type[3] = pull3,					\
371*4882a593Smuzhiyun 	}
372*4882a593Smuzhiyun 
373*4882a593Smuzhiyun #define PIN_BANK_DRV_FLAGS_PULL_FLAGS(id, pins, label, drv0, drv1,	\
374*4882a593Smuzhiyun 				      drv2, drv3, pull0, pull1,		\
375*4882a593Smuzhiyun 				      pull2, pull3)			\
376*4882a593Smuzhiyun 	{								\
377*4882a593Smuzhiyun 		.bank_num	= id,					\
378*4882a593Smuzhiyun 		.nr_pins	= pins,					\
379*4882a593Smuzhiyun 		.name		= label,				\
380*4882a593Smuzhiyun 		.iomux		= {					\
381*4882a593Smuzhiyun 			{ .offset = -1 },				\
382*4882a593Smuzhiyun 			{ .offset = -1 },				\
383*4882a593Smuzhiyun 			{ .offset = -1 },				\
384*4882a593Smuzhiyun 			{ .offset = -1 },				\
385*4882a593Smuzhiyun 		},							\
386*4882a593Smuzhiyun 		.drv		= {					\
387*4882a593Smuzhiyun 			{ .drv_type = drv0, .offset = -1 },		\
388*4882a593Smuzhiyun 			{ .drv_type = drv1, .offset = -1 },		\
389*4882a593Smuzhiyun 			{ .drv_type = drv2, .offset = -1 },		\
390*4882a593Smuzhiyun 			{ .drv_type = drv3, .offset = -1 },		\
391*4882a593Smuzhiyun 		},							\
392*4882a593Smuzhiyun 		.pull_type[0] = pull0,					\
393*4882a593Smuzhiyun 		.pull_type[1] = pull1,					\
394*4882a593Smuzhiyun 		.pull_type[2] = pull2,					\
395*4882a593Smuzhiyun 		.pull_type[3] = pull3,					\
396*4882a593Smuzhiyun 	}
397*4882a593Smuzhiyun 
398*4882a593Smuzhiyun #define PIN_BANK_IOMUX_DRV_FLAGS_OFFSET(id, pins, label, iom0, iom1,	\
399*4882a593Smuzhiyun 					iom2, iom3, drv0, drv1, drv2,	\
400*4882a593Smuzhiyun 					drv3, offset0, offset1,		\
401*4882a593Smuzhiyun 					offset2, offset3)		\
402*4882a593Smuzhiyun 	{								\
403*4882a593Smuzhiyun 		.bank_num	= id,					\
404*4882a593Smuzhiyun 		.nr_pins	= pins,					\
405*4882a593Smuzhiyun 		.name		= label,				\
406*4882a593Smuzhiyun 		.iomux		= {					\
407*4882a593Smuzhiyun 			{ .type = iom0, .offset = -1 },			\
408*4882a593Smuzhiyun 			{ .type = iom1, .offset = -1 },			\
409*4882a593Smuzhiyun 			{ .type = iom2, .offset = -1 },			\
410*4882a593Smuzhiyun 			{ .type = iom3, .offset = -1 },			\
411*4882a593Smuzhiyun 		},							\
412*4882a593Smuzhiyun 		.drv		= {					\
413*4882a593Smuzhiyun 			{ .drv_type = drv0, .offset = offset0 },	\
414*4882a593Smuzhiyun 			{ .drv_type = drv1, .offset = offset1 },	\
415*4882a593Smuzhiyun 			{ .drv_type = drv2, .offset = offset2 },	\
416*4882a593Smuzhiyun 			{ .drv_type = drv3, .offset = offset3 },	\
417*4882a593Smuzhiyun 		},							\
418*4882a593Smuzhiyun 	}
419*4882a593Smuzhiyun 
420*4882a593Smuzhiyun #define PIN_BANK_IOMUX_DRV_PULL_FLAGS(id, pins, label, iom0, iom1,	\
421*4882a593Smuzhiyun 				      iom2, iom3, drv0, drv1, drv2,	\
422*4882a593Smuzhiyun 				      drv3, pull0, pull1, pull2,	\
423*4882a593Smuzhiyun 				      pull3)				\
424*4882a593Smuzhiyun 	{								\
425*4882a593Smuzhiyun 		.bank_num	= id,					\
426*4882a593Smuzhiyun 		.nr_pins	= pins,					\
427*4882a593Smuzhiyun 		.name		= label,				\
428*4882a593Smuzhiyun 		.iomux		= {					\
429*4882a593Smuzhiyun 			{ .type = iom0, .offset = -1 },			\
430*4882a593Smuzhiyun 			{ .type = iom1, .offset = -1 },			\
431*4882a593Smuzhiyun 			{ .type = iom2, .offset = -1 },			\
432*4882a593Smuzhiyun 			{ .type = iom3, .offset = -1 },			\
433*4882a593Smuzhiyun 		},							\
434*4882a593Smuzhiyun 		.drv		= {					\
435*4882a593Smuzhiyun 			{ .drv_type = drv0, .offset = -1 },		\
436*4882a593Smuzhiyun 			{ .drv_type = drv1, .offset = -1 },		\
437*4882a593Smuzhiyun 			{ .drv_type = drv2, .offset = -1 },		\
438*4882a593Smuzhiyun 			{ .drv_type = drv3, .offset = -1 },		\
439*4882a593Smuzhiyun 		},							\
440*4882a593Smuzhiyun 		.pull_type[0] = pull0,					\
441*4882a593Smuzhiyun 		.pull_type[1] = pull1,					\
442*4882a593Smuzhiyun 		.pull_type[2] = pull2,					\
443*4882a593Smuzhiyun 		.pull_type[3] = pull3,					\
444*4882a593Smuzhiyun 	}
445*4882a593Smuzhiyun 
446*4882a593Smuzhiyun #define PIN_BANK_IOMUX_FLAGS_DRV_FLAGS_OFFSET_PULL_FLAGS(id, pins,	\
447*4882a593Smuzhiyun 					      label, iom0, iom1, iom2,  \
448*4882a593Smuzhiyun 					      iom3, drv0, drv1, drv2,   \
449*4882a593Smuzhiyun 					      drv3, offset0, offset1,   \
450*4882a593Smuzhiyun 					      offset2, offset3, pull0,  \
451*4882a593Smuzhiyun 					      pull1, pull2, pull3)	\
452*4882a593Smuzhiyun 	{								\
453*4882a593Smuzhiyun 		.bank_num	= id,					\
454*4882a593Smuzhiyun 		.nr_pins	= pins,					\
455*4882a593Smuzhiyun 		.name		= label,				\
456*4882a593Smuzhiyun 		.iomux		= {					\
457*4882a593Smuzhiyun 			{ .type = iom0, .offset = -1 },			\
458*4882a593Smuzhiyun 			{ .type = iom1, .offset = -1 },			\
459*4882a593Smuzhiyun 			{ .type = iom2, .offset = -1 },			\
460*4882a593Smuzhiyun 			{ .type = iom3, .offset = -1 },			\
461*4882a593Smuzhiyun 		},							\
462*4882a593Smuzhiyun 		.drv		= {					\
463*4882a593Smuzhiyun 			{ .drv_type = drv0, .offset = offset0 },	\
464*4882a593Smuzhiyun 			{ .drv_type = drv1, .offset = offset1 },	\
465*4882a593Smuzhiyun 			{ .drv_type = drv2, .offset = offset2 },	\
466*4882a593Smuzhiyun 			{ .drv_type = drv3, .offset = offset3 },	\
467*4882a593Smuzhiyun 		},							\
468*4882a593Smuzhiyun 		.pull_type[0] = pull0,					\
469*4882a593Smuzhiyun 		.pull_type[1] = pull1,					\
470*4882a593Smuzhiyun 		.pull_type[2] = pull2,					\
471*4882a593Smuzhiyun 		.pull_type[3] = pull3,					\
472*4882a593Smuzhiyun 	}
473*4882a593Smuzhiyun 
474*4882a593Smuzhiyun #define PIN_BANK_MUX_ROUTE_FLAGS(ID, PIN, FUNC, REG, VAL, FLAG)		\
475*4882a593Smuzhiyun 	{								\
476*4882a593Smuzhiyun 		.bank_num	= ID,					\
477*4882a593Smuzhiyun 		.pin		= PIN,					\
478*4882a593Smuzhiyun 		.func		= FUNC,					\
479*4882a593Smuzhiyun 		.route_offset	= REG,					\
480*4882a593Smuzhiyun 		.route_val	= VAL,					\
481*4882a593Smuzhiyun 		.route_type	= FLAG,					\
482*4882a593Smuzhiyun 	}
483*4882a593Smuzhiyun 
484*4882a593Smuzhiyun #define MR_DEFAULT(ID, PIN, FUNC, REG, VAL)	\
485*4882a593Smuzhiyun 	PIN_BANK_MUX_ROUTE_FLAGS(ID, PIN, FUNC, REG, VAL, ROUTE_TYPE_DEFAULT)
486*4882a593Smuzhiyun 
487*4882a593Smuzhiyun #define MR_TOPGRF(ID, PIN, FUNC, REG, VAL)	\
488*4882a593Smuzhiyun 	PIN_BANK_MUX_ROUTE_FLAGS(ID, PIN, FUNC, REG, VAL, ROUTE_TYPE_TOPGRF)
489*4882a593Smuzhiyun 
490*4882a593Smuzhiyun #define MR_PMUGRF(ID, PIN, FUNC, REG, VAL)	\
491*4882a593Smuzhiyun 	PIN_BANK_MUX_ROUTE_FLAGS(ID, PIN, FUNC, REG, VAL, ROUTE_TYPE_PMUGRF)
492*4882a593Smuzhiyun 
493*4882a593Smuzhiyun #define RK3588_PIN_BANK_FLAGS(ID, PIN, LABEL, M, P)			\
494*4882a593Smuzhiyun 	PIN_BANK_IOMUX_FLAGS_PULL_FLAGS(ID, PIN, LABEL, M, M, M, M, P, P, P, P)
495*4882a593Smuzhiyun 
496*4882a593Smuzhiyun /**
497*4882a593Smuzhiyun  * struct rockchip_mux_recalced_data: recalculate a pin iomux data.
498*4882a593Smuzhiyun  * @num: bank number.
499*4882a593Smuzhiyun  * @pin: pin number.
500*4882a593Smuzhiyun  * @reg: register offset.
501*4882a593Smuzhiyun  * @bit: index at register.
502*4882a593Smuzhiyun  * @mask: mask bit
503*4882a593Smuzhiyun  */
504*4882a593Smuzhiyun struct rockchip_mux_recalced_data {
505*4882a593Smuzhiyun 	u8 num;
506*4882a593Smuzhiyun 	u8 pin;
507*4882a593Smuzhiyun 	u32 reg;
508*4882a593Smuzhiyun 	u8 bit;
509*4882a593Smuzhiyun 	u8 mask;
510*4882a593Smuzhiyun };
511*4882a593Smuzhiyun 
512*4882a593Smuzhiyun /**
513*4882a593Smuzhiyun  * struct rockchip_mux_route_data: route a pin iomux data.
514*4882a593Smuzhiyun  * @bank_num: bank number.
515*4882a593Smuzhiyun  * @pin: index at register or used to calc index.
516*4882a593Smuzhiyun  * @func: the min pin.
517*4882a593Smuzhiyun  * @route_type: the register type.
518*4882a593Smuzhiyun  * @route_offset: the max pin.
519*4882a593Smuzhiyun  * @route_val: the register offset.
520*4882a593Smuzhiyun  */
521*4882a593Smuzhiyun struct rockchip_mux_route_data {
522*4882a593Smuzhiyun 	u8 bank_num;
523*4882a593Smuzhiyun 	u8 pin;
524*4882a593Smuzhiyun 	u8 func;
525*4882a593Smuzhiyun 	enum rockchip_pin_route_type route_type : 8;
526*4882a593Smuzhiyun 	u32 route_offset;
527*4882a593Smuzhiyun 	u32 route_val;
528*4882a593Smuzhiyun };
529*4882a593Smuzhiyun 
530*4882a593Smuzhiyun /**
531*4882a593Smuzhiyun  */
532*4882a593Smuzhiyun struct rockchip_pin_ctrl {
533*4882a593Smuzhiyun 	struct rockchip_pin_bank	*pin_banks;
534*4882a593Smuzhiyun 	u32				nr_banks;
535*4882a593Smuzhiyun 	u32				nr_pins;
536*4882a593Smuzhiyun 	int				grf_mux_offset;
537*4882a593Smuzhiyun 	int				pmu_mux_offset;
538*4882a593Smuzhiyun 	int				grf_drv_offset;
539*4882a593Smuzhiyun 	int				pmu_drv_offset;
540*4882a593Smuzhiyun 	struct rockchip_mux_recalced_data *iomux_recalced;
541*4882a593Smuzhiyun 	u32				niomux_recalced;
542*4882a593Smuzhiyun 	struct rockchip_mux_route_data *iomux_routes;
543*4882a593Smuzhiyun 	u32				niomux_routes;
544*4882a593Smuzhiyun 
545*4882a593Smuzhiyun 	int	(*set_mux)(struct rockchip_pin_bank *bank,
546*4882a593Smuzhiyun 			   int pin, int mux);
547*4882a593Smuzhiyun 	int	(*set_pull)(struct rockchip_pin_bank *bank,
548*4882a593Smuzhiyun 			    int pin_num, int pull);
549*4882a593Smuzhiyun 	int	(*set_drive)(struct rockchip_pin_bank *bank,
550*4882a593Smuzhiyun 			     int pin_num, int strength);
551*4882a593Smuzhiyun 	int	(*set_schmitt)(struct rockchip_pin_bank *bank,
552*4882a593Smuzhiyun 			       int pin_num, int enable);
553*4882a593Smuzhiyun };
554*4882a593Smuzhiyun 
555*4882a593Smuzhiyun /**
556*4882a593Smuzhiyun  */
557*4882a593Smuzhiyun struct rockchip_pinctrl_priv {
558*4882a593Smuzhiyun 	struct rockchip_pin_ctrl	*ctrl;
559*4882a593Smuzhiyun 	struct regmap			*regmap_base;
560*4882a593Smuzhiyun 	struct regmap			*regmap_pmu;
561*4882a593Smuzhiyun };
562*4882a593Smuzhiyun 
563*4882a593Smuzhiyun extern const struct pinctrl_ops rockchip_pinctrl_ops;
564*4882a593Smuzhiyun int rockchip_pinctrl_probe(struct udevice *dev);
565*4882a593Smuzhiyun void rockchip_get_recalced_mux(struct rockchip_pin_bank *bank, int pin,
566*4882a593Smuzhiyun 			       int *reg, u8 *bit, int *mask);
567*4882a593Smuzhiyun int rockchip_get_mux_data(int mux_type, int pin, u8 *bit, int *mask);
568*4882a593Smuzhiyun int rockchip_translate_drive_value(int type, int strength);
569*4882a593Smuzhiyun int rockchip_translate_pull_value(int type, int pull);
570*4882a593Smuzhiyun 
571*4882a593Smuzhiyun #endif /* __DRIVERS_PINCTRL_ROCKCHIP_H */
572