xref: /linux/drivers/pinctrl/mediatek/pinctrl-mt6893.c (revision eafd95ea74846eda3e3eac6b2bb7f34619d8a6f8)
1*80045071SAngeloGioacchino Del Regno // SPDX-License-Identifier: GPL-2.0
2*80045071SAngeloGioacchino Del Regno /*
3*80045071SAngeloGioacchino Del Regno  * Copyright (C) 2019 MediaTek Inc.
4*80045071SAngeloGioacchino Del Regno  * Copyright (C) 2024 Collabora Ltd.
5*80045071SAngeloGioacchino Del Regno  *                    AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
6*80045071SAngeloGioacchino Del Regno  */
7*80045071SAngeloGioacchino Del Regno 
8*80045071SAngeloGioacchino Del Regno #include <linux/module.h>
9*80045071SAngeloGioacchino Del Regno #include "pinctrl-mtk-mt6893.h"
10*80045071SAngeloGioacchino Del Regno #include "pinctrl-paris.h"
11*80045071SAngeloGioacchino Del Regno 
12*80045071SAngeloGioacchino Del Regno #define PIN_FIELD_BASE(s_pin, e_pin, i_base, s_addr, x_addrs, s_bit, x_bits)  \
13*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_CALC(s_pin, e_pin, i_base, s_addr, x_addrs, s_bit, x_bits, \
14*80045071SAngeloGioacchino Del Regno 		32, 0)
15*80045071SAngeloGioacchino Del Regno 
16*80045071SAngeloGioacchino Del Regno #define PINS_FIELD_BASE(s_pin, e_pin, i_base, s_addr, x_addrs, s_bit, x_bits) \
17*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_CALC(s_pin, e_pin, i_base, s_addr, x_addrs, s_bit, x_bits, \
18*80045071SAngeloGioacchino Del Regno 		32, 1)
19*80045071SAngeloGioacchino Del Regno 
20*80045071SAngeloGioacchino Del Regno static const struct mtk_pin_field_calc mt6893_pin_mode_range[] = {
21*80045071SAngeloGioacchino Del Regno 	PIN_FIELD(0, 219, 0x0300, 0x10, 0, 4),
22*80045071SAngeloGioacchino Del Regno };
23*80045071SAngeloGioacchino Del Regno 
24*80045071SAngeloGioacchino Del Regno static const struct mtk_pin_field_calc mt6893_pin_dir_range[] = {
25*80045071SAngeloGioacchino Del Regno 	PIN_FIELD(0, 219, 0x0000, 0x10, 0, 1),
26*80045071SAngeloGioacchino Del Regno };
27*80045071SAngeloGioacchino Del Regno 
28*80045071SAngeloGioacchino Del Regno static const struct mtk_pin_field_calc mt6893_pin_di_range[] = {
29*80045071SAngeloGioacchino Del Regno 	PIN_FIELD(0, 219, 0x0200, 0x10, 0, 1),
30*80045071SAngeloGioacchino Del Regno };
31*80045071SAngeloGioacchino Del Regno 
32*80045071SAngeloGioacchino Del Regno static const struct mtk_pin_field_calc mt6893_pin_do_range[] = {
33*80045071SAngeloGioacchino Del Regno 	PIN_FIELD(0, 219, 0x0100, 0x10, 0, 1),
34*80045071SAngeloGioacchino Del Regno };
35*80045071SAngeloGioacchino Del Regno 
36*80045071SAngeloGioacchino Del Regno static const struct mtk_pin_field_calc mt6893_pin_smt_range[] = {
37*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(0, 9, 2, 0x00f0, 0x10, 7, 1),
38*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(10, 15, 1, 0x0090, 0x10, 4, 1),
39*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(16, 17, 5, 0x00c0, 0x10, 8, 1),
40*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(18, 25, 7, 0x00f0, 0x10, 1, 1),
41*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(26, 30, 6, 0x00e0, 0x10, 6, 1),
42*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(31, 35, 6, 0x00e0, 0x10, 2, 1),
43*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(36, 36, 6, 0x00e0, 0x10, 16, 1),
44*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(37, 39, 6, 0x00e0, 0x10, 15, 1),
45*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(40, 41, 6, 0x00e0, 0x10, 0, 1),
46*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(42, 42, 6, 0x00e0, 0x10, 5, 1),
47*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(43, 44, 6, 0x00e0, 0x10, 3, 1),
48*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(45, 45, 6, 0x00e0, 0x10, 12, 1),
49*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(46, 46, 6, 0x00e0, 0x10, 14, 1),
50*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(47, 47, 6, 0x00e0, 0x10, 13, 1),
51*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(48, 49, 6, 0x00e0, 0x10, 10, 1),
52*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(50, 50, 6, 0x00e0, 0x10, 9, 1),
53*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(51, 52, 3, 0x0090, 0x10, 6, 1),
54*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(53, 56, 3, 0x0090, 0x10, 8, 1),
55*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(57, 60, 3, 0x0090, 0x10, 2, 1),
56*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(61, 61, 3, 0x0090, 0x10, 1, 1),
57*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(62, 62, 4, 0x0050, 0x10, 1, 1),
58*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(63, 73, 3, 0x0090, 0x10, 0, 1),
59*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(74, 84, 4, 0x0050, 0x10, 0, 1),
60*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(85, 86, 4, 0x0050, 0x10, 4, 1),
61*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(87, 88, 4, 0x0050, 0x10, 2, 1),
62*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(89, 90, 2, 0x00f0, 0x10, 26, 1),
63*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(91, 91, 2, 0x00f0, 0x10, 0, 1),
64*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(92, 95, 2, 0x0100, 0x10, 0, 1),
65*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(96, 96, 2, 0x00f0, 0x10, 30, 1),
66*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(97, 97, 2, 0x00f0, 0x10, 28, 1),
67*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(98, 98, 2, 0x00f0, 0x10, 31, 1),
68*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(99, 102, 2, 0x00f0, 0x10, 29, 1),
69*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(103, 105, 2, 0x00f0, 0x10, 24, 1),
70*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(106, 106, 2, 0x00f0, 0x10, 25, 1),
71*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(107, 108, 2, 0x00f0, 0x10, 5, 1),
72*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(109, 113, 2, 0x00f0, 0x10, 8, 1),
73*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(114, 116, 2, 0x00f0, 0x10, 16, 1),
74*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(117, 117, 2, 0x00f0, 0x10, 17, 1),
75*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(118, 118, 2, 0x00f0, 0x10, 10, 1),
76*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(119, 119, 2, 0x00f0, 0x10, 18, 1),
77*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(120, 120, 2, 0x00f0, 0x10, 15, 1),
78*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(121, 121, 2, 0x00f0, 0x10, 23, 1),
79*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(122, 122, 2, 0x00f0, 0x10, 14, 1),
80*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(123, 123, 2, 0x00f0, 0x10, 22, 1),
81*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(124, 124, 2, 0x00f0, 0x10, 13, 1),
82*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(125, 125, 2, 0x00f0, 0x10, 21, 1),
83*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(126, 129, 2, 0x00f0, 0x10, 9, 1),
84*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(130, 135, 2, 0x00f0, 0x10, 4, 1),
85*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(136, 138, 2, 0x00f0, 0x10, 1, 1),
86*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(139, 139, 2, 0x00f0, 0x10, 12, 1),
87*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(140, 140, 2, 0x00f0, 0x10, 20, 1),
88*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(141, 141, 2, 0x00f0, 0x10, 11, 1),
89*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(142, 142, 2, 0x00f0, 0x10, 19, 1),
90*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(143, 148, 1, 0x0090, 0x10, 3, 1),
91*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(149, 151, 1, 0x0090, 0x10, 0, 1),
92*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(152, 155, 5, 0x00c0, 0x10, 10, 1),
93*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(156, 156, 5, 0x00c0, 0x10, 14, 1),
94*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(157, 159, 5, 0x00c0, 0x10, 13, 1),
95*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(160, 161, 5, 0x00c0, 0x10, 11, 1),
96*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(162, 171, 5, 0x00c0, 0x10, 0, 1),
97*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(172, 173, 5, 0x00c0, 0x10, 4, 1),
98*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(174, 174, 5, 0x00c0, 0x10, 3, 1),
99*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(175, 175, 5, 0x00c0, 0x10, 6, 1),
100*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(176, 177, 5, 0x00c0, 0x10, 1, 1),
101*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(178, 182, 5, 0x00c0, 0x10, 7, 1),
102*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(183, 183, 7, 0x00f0, 0x10, 3, 1),
103*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(184, 190, 7, 0x00f0, 0x10, 4, 1),
104*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(191, 191, 7, 0x00f0, 0x10, 5, 1),
105*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(192, 192, 7, 0x00f0, 0x10, 2, 1),
106*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(193, 193, 7, 0x00f0, 0x10, 4, 1),
107*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(194, 194, 7, 0x00f0, 0x10, 6, 1),
108*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(195, 195, 7, 0x00f0, 0x10, 12, 1),
109*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(196, 199, 7, 0x00f0, 0x10, 0, 1),
110*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(200, 200, 7, 0x00f0, 0x10, 11, 1),
111*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(201, 201, 7, 0x00f0, 0x10, 14, 1),
112*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(202, 202, 7, 0x00f0, 0x10, 10, 1),
113*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(203, 203, 7, 0x00f0, 0x10, 13, 1),
114*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(204, 205, 6, 0x00e0, 0x10, 7, 1),
115*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(206, 208, 7, 0x00f0, 0x10, 15, 1),
116*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(209, 211, 7, 0x00f0, 0x10, 7, 1),
117*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(212, 213, 7, 0x00f0, 0x10, 8, 1),
118*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(214, 219, 7, 0x00f0, 0x10, 0, 1),
119*80045071SAngeloGioacchino Del Regno };
120*80045071SAngeloGioacchino Del Regno 
121*80045071SAngeloGioacchino Del Regno static const struct mtk_pin_field_calc mt6893_pin_ies_range[] = {
122*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(0, 9, 2, 0x0060, 0x10, 12, 1),
123*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(10, 15, 1, 0x0020, 0x10, 9, 1),
124*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(16, 17, 5, 0x0030, 0x10, 21, 1),
125*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(18, 25, 7, 0x0050, 0x10, 10, 1),
126*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(26, 30, 6, 0x0040, 0x10, 10, 1),
127*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(31, 31, 6, 0x0040, 0x10, 6, 1),
128*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(32, 32, 6, 0x0040, 0x10, 3, 1),
129*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(33, 33, 6, 0x0040, 0x10, 5, 1),
130*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(34, 34, 6, 0x0040, 0x10, 2, 1),
131*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(35, 35, 6, 0x0040, 0x10, 4, 1),
132*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(36, 39, 6, 0x0040, 0x10, 23, 1),
133*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(40, 41, 6, 0x0040, 0x10, 0, 1),
134*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(42, 42, 6, 0x0040, 0x10, 9, 1),
135*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(43, 44, 6, 0x0040, 0x10, 7, 1),
136*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(45, 45, 6, 0x0040, 0x10, 20, 1),
137*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(46, 46, 6, 0x0040, 0x10, 22, 1),
138*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(47, 47, 6, 0x0040, 0x10, 21, 1),
139*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(48, 49, 6, 0x0040, 0x10, 18, 1),
140*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(50, 50, 6, 0x0040, 0x10, 17, 1),
141*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(51, 52, 3, 0x0020, 0x10, 16, 1),
142*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(53, 53, 3, 0x0020, 0x10, 21, 1),
143*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(54, 54, 3, 0x0020, 0x10, 18, 1),
144*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(55, 55, 3, 0x0020, 0x10, 20, 1),
145*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(56, 56, 3, 0x0020, 0x10, 19, 1),
146*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(57, 60, 3, 0x0020, 0x10, 12, 1),
147*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(61, 61, 3, 0x0020, 0x10, 11, 1),
148*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(62, 62, 4, 0x0010, 0x10, 11, 1),
149*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(63, 64, 3, 0x0020, 0x10, 0, 1),
150*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(65, 72, 3, 0x0020, 0x10, 3, 1),
151*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(73, 73, 3, 0x0020, 0x10, 2, 1),
152*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(74, 84, 4, 0x0010, 0x10, 0, 1),
153*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(85, 86, 4, 0x0010, 0x10, 14, 1),
154*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(87, 88, 4, 0x0010, 0x10, 12, 1),
155*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(89, 90, 2, 0x0070, 0x10, 19, 1),
156*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(91, 91, 2, 0x0060, 0x10, 0, 1),
157*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(92, 92, 2, 0x0070, 0x10, 28, 1),
158*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(93, 93, 2, 0x0070, 0x10, 30, 1),
159*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(94, 94, 2, 0x0070, 0x10, 29, 1),
160*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(95, 95, 2, 0x0070, 0x10, 31, 1),
161*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(96, 96, 2, 0x0070, 0x10, 26, 1),
162*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(97, 97, 2, 0x0070, 0x10, 21, 1),
163*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(98, 98, 2, 0x0070, 0x10, 27, 1),
164*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(99, 102, 2, 0x0070, 0x10, 22, 1),
165*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(103, 103, 2, 0x0070, 0x10, 17, 1),
166*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(104, 104, 2, 0x0070, 0x10, 16, 1),
167*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(105, 105, 2, 0x0070, 0x10, 18, 1),
168*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(106, 106, 2, 0x0070, 0x10, 15, 1),
169*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(107, 108, 2, 0x0060, 0x10, 10, 1),
170*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(109, 109, 2, 0x0060, 0x10, 25, 1),
171*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(110, 110, 2, 0x0060, 0x10, 22, 1),
172*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(111, 111, 2, 0x0060, 0x10, 24, 1),
173*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(112, 112, 2, 0x0060, 0x10, 26, 1),
174*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(113, 113, 2, 0x0060, 0x10, 23, 1),
175*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(114, 114, 2, 0x0070, 0x10, 7, 1),
176*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(115, 115, 2, 0x0070, 0x10, 6, 1),
177*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(116, 116, 2, 0x0070, 0x10, 8, 1),
178*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(117, 117, 2, 0x0070, 0x10, 5, 1),
179*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(118, 118, 2, 0x0060, 0x10, 31, 1),
180*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(119, 119, 2, 0x0070, 0x10, 9, 1),
181*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(120, 120, 2, 0x0070, 0x10, 4, 1),
182*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(121, 121, 2, 0x0070, 0x10, 14, 1),
183*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(122, 122, 2, 0x0070, 0x10, 3, 1),
184*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(123, 123, 2, 0x0070, 0x10, 13, 1),
185*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(124, 124, 2, 0x0070, 0x10, 2, 1),
186*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(125, 125, 2, 0x0070, 0x10, 12, 1),
187*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(126, 129, 2, 0x0060, 0x10, 27, 1),
188*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(130, 132, 2, 0x0060, 0x10, 7, 1),
189*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(133, 135, 2, 0x0060, 0x10, 4, 1),
190*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(136, 138, 2, 0x0060, 0x10, 1, 1),
191*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(139, 139, 2, 0x0070, 0x10, 1, 1),
192*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(140, 140, 2, 0x0070, 0x10, 11, 1),
193*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(141, 141, 2, 0x0070, 0x10, 0, 1),
194*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(142, 142, 2, 0x0070, 0x10, 10, 1),
195*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(143, 145, 1, 0x0020, 0x10, 6, 1),
196*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(146, 148, 1, 0x0020, 0x10, 3, 1),
197*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(149, 151, 1, 0x0020, 0x10, 0, 1),
198*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(152, 152, 5, 0x0030, 0x10, 26, 1),
199*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(153, 153, 5, 0x0030, 0x10, 25, 1),
200*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(154, 155, 5, 0x0030, 0x10, 23, 1),
201*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(156, 158, 5, 0x0030, 0x10, 29, 1),
202*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(159, 159, 5, 0x0040, 0x10, 0, 1),
203*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(160, 161, 5, 0x0030, 0x10, 27, 1),
204*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(162, 171, 5, 0x0030, 0x10, 0, 1),
205*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(172, 173, 5, 0x0030, 0x10, 13, 1),
206*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(174, 174, 5, 0x0030, 0x10, 12, 1),
207*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(175, 175, 5, 0x0030, 0x10, 15, 1),
208*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(176, 177, 5, 0x0030, 0x10, 10, 1),
209*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(178, 182, 5, 0x0030, 0x10, 16, 1),
210*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(183, 184, 7, 0x0050, 0x10, 19, 1),
211*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(185, 185, 7, 0x0050, 0x10, 22, 1),
212*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(186, 186, 7, 0x0050, 0x10, 24, 1),
213*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(187, 187, 7, 0x0050, 0x10, 26, 1),
214*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(188, 188, 7, 0x0050, 0x10, 21, 1),
215*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(189, 189, 7, 0x0050, 0x10, 25, 1),
216*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(190, 191, 7, 0x0050, 0x10, 27, 1),
217*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(192, 192, 7, 0x0050, 0x10, 18, 1),
218*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(193, 193, 7, 0x0050, 0x10, 23, 1),
219*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(194, 194, 7, 0x0050, 0x10, 29, 1),
220*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(195, 195, 7, 0x0060, 0x10, 5, 1),
221*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(196, 196, 7, 0x0050, 0x10, 6, 1),
222*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(197, 197, 7, 0x0050, 0x10, 8, 1),
223*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(198, 198, 7, 0x0050, 0x10, 7, 1),
224*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(199, 199, 7, 0x0050, 0x10, 3, 1),
225*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(200, 200, 7, 0x0060, 0x10, 4, 1),
226*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(201, 201, 7, 0x0060, 0x10, 7, 1),
227*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(202, 202, 7, 0x0060, 0x10, 3, 1),
228*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(203, 203, 7, 0x0060, 0x10, 6, 1),
229*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(204, 205, 6, 0x0040, 0x10, 15, 1),
230*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(206, 208, 7, 0x0060, 0x10, 8, 1),
231*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(209, 209, 7, 0x0060, 0x10, 0, 1),
232*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(210, 210, 7, 0x0050, 0x10, 31, 1),
233*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(211, 211, 7, 0x0060, 0x10, 1, 1),
234*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(212, 212, 7, 0x0050, 0x10, 30, 1),
235*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(213, 213, 7, 0x0060, 0x10, 2, 1),
236*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(214, 214, 7, 0x0050, 0x10, 0, 1),
237*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(215, 215, 7, 0x0050, 0x10, 9, 1),
238*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(216, 217, 7, 0x0050, 0x10, 4, 1),
239*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(218, 219, 7, 0x0050, 0x10, 1, 1),
240*80045071SAngeloGioacchino Del Regno };
241*80045071SAngeloGioacchino Del Regno 
242*80045071SAngeloGioacchino Del Regno static const struct mtk_pin_field_calc mt6893_pin_pu_range[] = {
243*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(0, 9, 2, 0x00a0, 0x10, 12, 1),
244*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(16, 17, 5, 0x0070, 0x10, 21, 1),
245*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(18, 25, 7, 0x0090, 0x10, 10, 1),
246*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(26, 30, 6, 0x0080, 0x10, 10, 1),
247*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(31, 31, 6, 0x0080, 0x10, 6, 1),
248*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(32, 32, 6, 0x0080, 0x10, 3, 1),
249*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(33, 33, 6, 0x0080, 0x10, 5, 1),
250*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(34, 34, 6, 0x0080, 0x10, 2, 1),
251*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(35, 35, 6, 0x0080, 0x10, 4, 1),
252*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(36, 39, 6, 0x0080, 0x10, 17, 1),
253*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(40, 41, 6, 0x0080, 0x10, 0, 1),
254*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(42, 42, 6, 0x0080, 0x10, 9, 1),
255*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(43, 44, 6, 0x0080, 0x10, 7, 1),
256*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(57, 60, 3, 0x0050, 0x10, 12, 1),
257*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(61, 61, 3, 0x0050, 0x10, 11, 1),
258*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(62, 62, 4, 0x0030, 0x10, 11, 1),
259*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(63, 64, 3, 0x0050, 0x10, 0, 1),
260*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(65, 72, 3, 0x0050, 0x10, 3, 1),
261*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(73, 73, 3, 0x0050, 0x10, 2, 1),
262*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(74, 84, 4, 0x0030, 0x10, 0, 1),
263*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(85, 86, 4, 0x0030, 0x10, 14, 1),
264*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(87, 88, 4, 0x0030, 0x10, 12, 1),
265*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(89, 90, 2, 0x00b0, 0x10, 19, 1),
266*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(91, 91, 2, 0x00a0, 0x10, 0, 1),
267*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(92, 92, 2, 0x00b0, 0x10, 28, 1),
268*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(93, 93, 2, 0x00b0, 0x10, 30, 1),
269*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(94, 94, 2, 0x00b0, 0x10, 29, 1),
270*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(95, 95, 2, 0x00b0, 0x10, 31, 1),
271*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(96, 96, 2, 0x00b0, 0x10, 26, 1),
272*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(97, 97, 2, 0x00b0, 0x10, 21, 1),
273*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(98, 98, 2, 0x00b0, 0x10, 27, 1),
274*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(99, 102, 2, 0x00b0, 0x10, 22, 1),
275*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(103, 103, 2, 0x00b0, 0x10, 17, 1),
276*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(104, 104, 2, 0x00b0, 0x10, 16, 1),
277*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(105, 105, 2, 0x00b0, 0x10, 18, 1),
278*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(106, 106, 2, 0x00b0, 0x10, 15, 1),
279*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(107, 108, 2, 0x00a0, 0x10, 10, 1),
280*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(109, 109, 2, 0x00a0, 0x10, 25, 1),
281*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(110, 110, 2, 0x00a0, 0x10, 22, 1),
282*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(111, 111, 2, 0x00a0, 0x10, 24, 1),
283*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(112, 112, 2, 0x00a0, 0x10, 26, 1),
284*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(113, 113, 2, 0x00a0, 0x10, 23, 1),
285*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(114, 114, 2, 0x00b0, 0x10, 7, 1),
286*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(115, 115, 2, 0x00b0, 0x10, 6, 1),
287*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(116, 116, 2, 0x00b0, 0x10, 8, 1),
288*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(117, 117, 2, 0x00b0, 0x10, 5, 1),
289*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(118, 118, 2, 0x00a0, 0x10, 31, 1),
290*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(119, 119, 2, 0x00b0, 0x10, 9, 1),
291*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(120, 120, 2, 0x00b0, 0x10, 4, 1),
292*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(121, 121, 2, 0x00b0, 0x10, 14, 1),
293*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(122, 122, 2, 0x00b0, 0x10, 3, 1),
294*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(123, 123, 2, 0x00b0, 0x10, 13, 1),
295*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(124, 124, 2, 0x00b0, 0x10, 2, 1),
296*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(125, 125, 2, 0x00b0, 0x10, 12, 1),
297*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(126, 129, 2, 0x00a0, 0x10, 27, 1),
298*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(130, 132, 2, 0x00a0, 0x10, 7, 1),
299*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(133, 135, 2, 0x00a0, 0x10, 4, 1),
300*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(136, 138, 2, 0x00a0, 0x10, 1, 1),
301*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(139, 139, 2, 0x00b0, 0x10, 1, 1),
302*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(140, 140, 2, 0x00b0, 0x10, 11, 1),
303*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(141, 141, 2, 0x00b0, 0x10, 0, 1),
304*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(142, 142, 2, 0x00b0, 0x10, 10, 1),
305*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(143, 145, 1, 0x0050, 0x10, 6, 1),
306*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(146, 148, 1, 0x0050, 0x10, 3, 1),
307*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(149, 151, 1, 0x0050, 0x10, 0, 1),
308*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(156, 159, 5, 0x0070, 0x10, 25, 1),
309*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(160, 161, 5, 0x0070, 0x10, 23, 1),
310*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(162, 171, 5, 0x0070, 0x10, 0, 1),
311*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(172, 173, 5, 0x0070, 0x10, 13, 1),
312*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(174, 174, 5, 0x0070, 0x10, 12, 1),
313*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(175, 175, 5, 0x0070, 0x10, 15, 1),
314*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(176, 177, 5, 0x0070, 0x10, 10, 1),
315*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(178, 182, 5, 0x0070, 0x10, 16, 1),
316*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(195, 195, 7, 0x0090, 0x10, 25, 1),
317*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(196, 196, 7, 0x0090, 0x10, 6, 1),
318*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(197, 197, 7, 0x0090, 0x10, 8, 1),
319*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(198, 198, 7, 0x0090, 0x10, 7, 1),
320*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(199, 199, 7, 0x0090, 0x10, 3, 1),
321*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(200, 200, 7, 0x0090, 0x10, 24, 1),
322*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(201, 201, 7, 0x0090, 0x10, 27, 1),
323*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(202, 202, 7, 0x0090, 0x10, 23, 1),
324*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(203, 203, 7, 0x0090, 0x10, 26, 1),
325*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(204, 205, 6, 0x0080, 0x10, 15, 1),
326*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(206, 208, 7, 0x0090, 0x10, 28, 1),
327*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(209, 209, 7, 0x0090, 0x10, 20, 1),
328*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(210, 210, 7, 0x0090, 0x10, 19, 1),
329*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(211, 211, 7, 0x0090, 0x10, 21, 1),
330*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(212, 212, 7, 0x0090, 0x10, 18, 1),
331*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(213, 213, 7, 0x0090, 0x10, 22, 1),
332*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(214, 214, 7, 0x0090, 0x10, 0, 1),
333*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(215, 215, 7, 0x0090, 0x10, 9, 1),
334*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(216, 217, 7, 0x0090, 0x10, 4, 1),
335*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(218, 219, 7, 0x0090, 0x10, 1, 1),
336*80045071SAngeloGioacchino Del Regno };
337*80045071SAngeloGioacchino Del Regno 
338*80045071SAngeloGioacchino Del Regno static const struct mtk_pin_field_calc mt6893_pin_pd_range[] = {
339*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(0, 9, 2, 0x0080, 0x10, 12, 1),
340*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(16, 17, 5, 0x0050, 0x10, 21, 1),
341*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(18, 25, 7, 0x0070, 0x10, 10, 1),
342*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(26, 30, 6, 0x0060, 0x10, 10, 1),
343*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(31, 31, 6, 0x0060, 0x10, 6, 1),
344*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(32, 32, 6, 0x0060, 0x10, 3, 1),
345*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(33, 33, 6, 0x0060, 0x10, 5, 1),
346*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(34, 34, 6, 0x0060, 0x10, 2, 1),
347*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(35, 35, 6, 0x0060, 0x10, 4, 1),
348*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(36, 39, 6, 0x0060, 0x10, 17, 1),
349*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(40, 41, 6, 0x0060, 0x10, 0, 1),
350*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(42, 42, 6, 0x0060, 0x10, 9, 1),
351*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(43, 44, 6, 0x0060, 0x10, 7, 1),
352*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(57, 60, 3, 0x0030, 0x10, 12, 1),
353*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(61, 61, 3, 0x0030, 0x10, 11, 1),
354*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(62, 62, 4, 0x0020, 0x10, 11, 1),
355*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(63, 64, 3, 0x0030, 0x10, 0, 1),
356*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(65, 72, 3, 0x0030, 0x10, 3, 1),
357*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(73, 73, 3, 0x0030, 0x10, 2, 1),
358*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(74, 84, 4, 0x0020, 0x10, 0, 1),
359*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(85, 86, 4, 0x0020, 0x10, 14, 1),
360*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(87, 88, 4, 0x0020, 0x10, 12, 1),
361*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(89, 90, 2, 0x0090, 0x10, 19, 1),
362*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(91, 91, 2, 0x0080, 0x10, 0, 1),
363*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(92, 92, 2, 0x0090, 0x10, 28, 1),
364*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(93, 93, 2, 0x0090, 0x10, 30, 1),
365*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(94, 94, 2, 0x0090, 0x10, 29, 1),
366*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(95, 95, 2, 0x0090, 0x10, 31, 1),
367*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(96, 96, 2, 0x0090, 0x10, 26, 1),
368*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(97, 97, 2, 0x0090, 0x10, 21, 1),
369*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(98, 98, 2, 0x0090, 0x10, 27, 1),
370*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(99, 102, 2, 0x0090, 0x10, 22, 1),
371*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(103, 103, 2, 0x0090, 0x10, 17, 1),
372*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(104, 104, 2, 0x0090, 0x10, 16, 1),
373*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(105, 105, 2, 0x0090, 0x10, 18, 1),
374*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(106, 106, 2, 0x0090, 0x10, 15, 1),
375*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(107, 108, 2, 0x0080, 0x10, 10, 1),
376*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(109, 109, 2, 0x0080, 0x10, 25, 1),
377*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(110, 110, 2, 0x0080, 0x10, 22, 1),
378*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(111, 111, 2, 0x0080, 0x10, 24, 1),
379*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(112, 112, 2, 0x0080, 0x10, 26, 1),
380*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(113, 113, 2, 0x0080, 0x10, 23, 1),
381*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(114, 114, 2, 0x0090, 0x10, 7, 1),
382*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(115, 115, 2, 0x0090, 0x10, 6, 1),
383*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(116, 116, 2, 0x0090, 0x10, 8, 1),
384*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(117, 117, 2, 0x0090, 0x10, 5, 1),
385*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(118, 118, 2, 0x0080, 0x10, 31, 1),
386*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(119, 119, 2, 0x0090, 0x10, 9, 1),
387*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(120, 120, 2, 0x0090, 0x10, 4, 1),
388*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(121, 121, 2, 0x0090, 0x10, 14, 1),
389*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(122, 122, 2, 0x0090, 0x10, 3, 1),
390*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(123, 123, 2, 0x0090, 0x10, 13, 1),
391*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(124, 124, 2, 0x0090, 0x10, 2, 1),
392*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(125, 125, 2, 0x0090, 0x10, 12, 1),
393*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(126, 129, 2, 0x0080, 0x10, 27, 1),
394*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(130, 132, 2, 0x0080, 0x10, 7, 1),
395*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(133, 135, 2, 0x0080, 0x10, 4, 1),
396*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(136, 138, 2, 0x0080, 0x10, 1, 1),
397*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(139, 139, 2, 0x0090, 0x10, 1, 1),
398*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(140, 140, 2, 0x0090, 0x10, 11, 1),
399*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(141, 141, 2, 0x0090, 0x10, 0, 1),
400*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(142, 142, 2, 0x0090, 0x10, 10, 1),
401*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(143, 145, 1, 0x0030, 0x10, 6, 1),
402*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(146, 148, 1, 0x0030, 0x10, 3, 1),
403*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(149, 151, 1, 0x0030, 0x10, 0, 1),
404*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(156, 159, 5, 0x0050, 0x10, 25, 1),
405*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(160, 161, 5, 0x0050, 0x10, 23, 1),
406*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(162, 171, 5, 0x0050, 0x10, 0, 1),
407*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(172, 173, 5, 0x0050, 0x10, 13, 1),
408*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(174, 174, 5, 0x0050, 0x10, 12, 1),
409*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(175, 175, 5, 0x0050, 0x10, 15, 1),
410*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(176, 177, 5, 0x0050, 0x10, 10, 1),
411*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(178, 182, 5, 0x0050, 0x10, 16, 1),
412*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(195, 195, 7, 0x0070, 0x10, 25, 1),
413*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(196, 196, 7, 0x0070, 0x10, 6, 1),
414*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(197, 197, 7, 0x0070, 0x10, 8, 1),
415*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(198, 198, 7, 0x0070, 0x10, 7, 1),
416*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(199, 199, 7, 0x0070, 0x10, 3, 1),
417*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(200, 200, 7, 0x0070, 0x10, 24, 1),
418*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(201, 201, 7, 0x0070, 0x10, 27, 1),
419*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(202, 202, 7, 0x0070, 0x10, 23, 1),
420*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(203, 203, 7, 0x0070, 0x10, 26, 1),
421*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(204, 205, 6, 0x0060, 0x10, 15, 1),
422*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(206, 208, 7, 0x0070, 0x10, 28, 1),
423*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(209, 209, 7, 0x0070, 0x10, 20, 1),
424*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(210, 210, 7, 0x0070, 0x10, 19, 1),
425*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(211, 211, 7, 0x0070, 0x10, 21, 1),
426*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(212, 212, 7, 0x0070, 0x10, 18, 1),
427*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(213, 213, 7, 0x0070, 0x10, 22, 1),
428*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(214, 214, 7, 0x0070, 0x10, 0, 1),
429*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(215, 215, 7, 0x0070, 0x10, 9, 1),
430*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(216, 217, 7, 0x0070, 0x10, 4, 1),
431*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(218, 219, 7, 0x0070, 0x10, 1, 1),
432*80045071SAngeloGioacchino Del Regno };
433*80045071SAngeloGioacchino Del Regno 
434*80045071SAngeloGioacchino Del Regno static const struct mtk_pin_field_calc mt6893_pin_drv_range[] = {
435*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(0, 9, 2, 0x0000, 0x10, 21, 3),
436*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(10, 15, 1, 0x0000, 0x10, 12, 3),
437*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(16, 17, 5, 0x0000, 0x10, 18, 3),
438*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(18, 25, 7, 0x0000, 0x10, 3, 3),
439*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(26, 30, 6, 0x0000, 0x10, 15, 3),
440*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(31, 35, 6, 0x0000, 0x10, 6, 3),
441*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(36, 36, 6, 0x0010, 0x10, 7, 3),
442*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(37, 39, 6, 0x0010, 0x10, 4, 3),
443*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(40, 41, 6, 0x0000, 0x10, 0, 3),
444*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(42, 42, 6, 0x0000, 0x10, 12, 3),
445*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(43, 44, 6, 0x0000, 0x10, 9, 3),
446*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(45, 45, 6, 0x0000, 0x10, 30, 2),
447*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(46, 46, 6, 0x0010, 0x10, 2, 2),
448*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(47, 47, 6, 0x0010, 0x10, 0, 2),
449*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(48, 49, 6, 0x0000, 0x10, 26, 2),
450*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(50, 50, 6, 0x0000, 0x10, 24, 2),
451*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(51, 52, 3, 0x0000, 0x10, 18, 3),
452*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(53, 56, 3, 0x0000, 0x10, 24, 3),
453*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(57, 60, 3, 0x0000, 0x10, 6, 3),
454*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(61, 61, 3, 0x0000, 0x10, 3, 3),
455*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(62, 62, 4, 0x0000, 0x10, 3, 3),
456*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(63, 73, 3, 0x0000, 0x10, 0, 3),
457*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(74, 84, 4, 0x0000, 0x10, 0, 3),
458*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(85, 86, 4, 0x0000, 0x10, 12, 3),
459*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(87, 88, 4, 0x0000, 0x10, 6, 3),
460*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(89, 90, 2, 0x0020, 0x10, 15, 3),
461*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(91, 91, 2, 0x0000, 0x10, 0, 3),
462*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(92, 95, 2, 0x0030, 0x10, 3, 3),
463*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(96, 96, 2, 0x0020, 0x10, 27, 3),
464*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(97, 97, 2, 0x0020, 0x10, 21, 3),
465*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(98, 98, 2, 0x0030, 0x10, 0, 3),
466*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(99, 102, 2, 0x0020, 0x10, 24, 3),
467*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(103, 105, 2, 0x0020, 0x10, 9, 3),
468*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(106, 106, 2, 0x0020, 0x10, 12, 3),
469*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(107, 108, 2, 0x0000, 0x10, 15, 3),
470*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(109, 113, 2, 0x0000, 0x10, 24, 3),
471*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(114, 117, 2, 0x0010, 0x10, 18, 3),
472*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(118, 118, 2, 0x0010, 0x10, 0, 3),
473*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(119, 119, 2, 0x0010, 0x10, 21, 3),
474*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(120, 120, 2, 0x0010, 0x10, 15, 3),
475*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(121, 121, 2, 0x0020, 0x10, 6, 3),
476*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(122, 122, 2, 0x0010, 0x10, 12, 3),
477*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(123, 123, 2, 0x0020, 0x10, 3, 3),
478*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(124, 124, 2, 0x0010, 0x10, 9, 3),
479*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(125, 125, 2, 0x0020, 0x10, 0, 3),
480*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(126, 129, 2, 0x0000, 0x10, 27, 3),
481*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(130, 135, 2, 0x0000, 0x10, 12, 3),
482*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(136, 138, 2, 0x0000, 0x10, 3, 3),
483*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(139, 139, 2, 0x0010, 0x10, 6, 3),
484*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(140, 140, 2, 0x0010, 0x10, 27, 3),
485*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(141, 141, 2, 0x0010, 0x10, 3, 3),
486*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(142, 142, 2, 0x0010, 0x10, 24, 3),
487*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(143, 148, 1, 0x0000, 0x10, 9, 3),
488*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(149, 151, 1, 0x0000, 0x10, 0, 3),
489*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(152, 155, 5, 0x0000, 0x10, 24, 3),
490*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(156, 156, 5, 0x0010, 0x10, 6, 3),
491*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(157, 159, 5, 0x0010, 0x10, 3, 3),
492*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(160, 160, 5, 0x0000, 0x10, 27, 3),
493*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(161, 161, 5, 0x0010, 0x10, 0, 3),
494*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(162, 171, 5, 0x0000, 0x10, 0, 3),
495*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(172, 172, 5, 0x0000, 0x10, 15, 3),
496*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(173, 173, 5, 0x0000, 0x10, 3, 3),
497*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(174, 174, 5, 0x0000, 0x10, 12, 3),
498*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(175, 177, 5, 0x0000, 0x10, 3, 3),
499*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(178, 182, 5, 0x0000, 0x10, 3, 3),
500*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(183, 183, 7, 0x0000, 0x10, 9, 3),
501*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(184, 190, 7, 0x0000, 0x10, 12, 3),
502*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(191, 191, 7, 0x0000, 0x10, 15, 3),
503*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(192, 192, 7, 0x0000, 0x10, 6, 3),
504*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(193, 193, 7, 0x0000, 0x10, 12, 3),
505*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(194, 194, 7, 0x0000, 0x10, 18, 3),
506*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(195, 195, 7, 0x0010, 0x10, 3, 3),
507*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(196, 199, 7, 0x0000, 0x10, 0, 3),
508*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(200, 200, 7, 0x0010, 0x10, 0, 3),
509*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(201, 201, 7, 0x0010, 0x10, 9, 3),
510*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(202, 202, 7, 0x0000, 0x10, 27, 3),
511*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(203, 203, 7, 0x0010, 0x10, 6, 3),
512*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(204, 205, 6, 0x0000, 0x10, 18, 3),
513*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(206, 208, 7, 0x0010, 0x10, 12, 3),
514*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(209, 212, 7, 0x0000, 0x10, 21, 3),
515*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(213, 213, 7, 0x0000, 0x10, 24, 3),
516*80045071SAngeloGioacchino Del Regno 	PINS_FIELD_BASE(214, 219, 7, 0x0000, 0x10, 0, 3),
517*80045071SAngeloGioacchino Del Regno };
518*80045071SAngeloGioacchino Del Regno 
519*80045071SAngeloGioacchino Del Regno static const struct mtk_pin_field_calc mt6893_pin_pupd_range[] = {
520*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(10, 15, 1, 0x0040, 0x10, 0, 1),
521*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(45, 45, 6, 0x0070, 0x10, 3, 1),
522*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(46, 46, 6, 0x0070, 0x10, 5, 1),
523*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(47, 47, 6, 0x0070, 0x10, 4, 1),
524*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(48, 49, 6, 0x0070, 0x10, 1, 1),
525*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(50, 50, 6, 0x0070, 0x10, 0, 1),
526*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(51, 52, 3, 0x0040, 0x10, 0, 1),
527*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(53, 53, 3, 0x0040, 0x10, 5, 1),
528*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(54, 54, 3, 0x0040, 0x10, 2, 1),
529*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(55, 55, 3, 0x0040, 0x10, 4, 1),
530*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(56, 56, 3, 0x0040, 0x10, 3, 1),
531*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(152, 152, 5, 0x0060, 0x10, 3, 1),
532*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(153, 153, 5, 0x0060, 0x10, 2, 1),
533*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(154, 155, 5, 0x0060, 0x10, 0, 1),
534*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(183, 184, 7, 0x0080, 0x10, 1, 1),
535*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(185, 185, 7, 0x0080, 0x10, 4, 1),
536*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(186, 186, 7, 0x0080, 0x10, 6, 1),
537*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(187, 187, 7, 0x0080, 0x10, 8, 1),
538*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(188, 188, 7, 0x0080, 0x10, 3, 1),
539*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(189, 189, 7, 0x0080, 0x10, 7, 1),
540*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(190, 191, 7, 0x0080, 0x10, 9, 1),
541*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(192, 192, 7, 0x0080, 0x10, 0, 1),
542*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(193, 193, 7, 0x0080, 0x10, 5, 1),
543*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(194, 194, 7, 0x0080, 0x10, 11, 1),
544*80045071SAngeloGioacchino Del Regno };
545*80045071SAngeloGioacchino Del Regno 
546*80045071SAngeloGioacchino Del Regno static const struct mtk_pin_field_calc mt6893_pin_r0_range[] = {
547*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(10, 15, 1, 0x0060, 0x10, 0, 1),
548*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(24, 24, 7, 0x00e0, 0x10, 0, 1),
549*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(25, 25, 7, 0x00e0, 0x10, 2, 1),
550*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(45, 45, 6, 0x0090, 0x10, 3, 1),
551*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(46, 46, 6, 0x0090, 0x10, 5, 1),
552*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(47, 47, 6, 0x0090, 0x10, 4, 1),
553*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(48, 49, 6, 0x0090, 0x10, 1, 1),
554*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(50, 50, 6, 0x0090, 0x10, 0, 1),
555*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(51, 52, 3, 0x0060, 0x10, 0, 1),
556*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(53, 53, 3, 0x0060, 0x10, 5, 1),
557*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(54, 54, 3, 0x0060, 0x10, 2, 1),
558*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(55, 55, 3, 0x0060, 0x10, 4, 1),
559*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(56, 56, 3, 0x0060, 0x10, 3, 1),
560*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(118, 118, 2, 0x00e0, 0x10, 0, 1),
561*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(119, 119, 2, 0x00e0, 0x10, 12, 1),
562*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(120, 120, 2, 0x00e0, 0x10, 10, 1),
563*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(121, 121, 2, 0x00e0, 0x10, 22, 1),
564*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(122, 122, 2, 0x00e0, 0x10, 8, 1),
565*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(123, 123, 2, 0x00e0, 0x10, 20, 1),
566*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(124, 124, 2, 0x00e0, 0x10, 6, 1),
567*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(125, 125, 2, 0x00e0, 0x10, 18, 1),
568*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(139, 139, 2, 0x00e0, 0x10, 4, 1),
569*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(140, 140, 2, 0x00e0, 0x10, 16, 1),
570*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(141, 141, 2, 0x00e0, 0x10, 2, 1),
571*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(142, 142, 2, 0x00e0, 0x10, 14, 1),
572*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(152, 152, 5, 0x0080, 0x10, 3, 1),
573*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(153, 153, 5, 0x0080, 0x10, 2, 1),
574*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(154, 155, 5, 0x0080, 0x10, 0, 1),
575*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(160, 160, 5, 0x00b0, 0x10, 0, 1),
576*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(161, 161, 5, 0x00b0, 0x10, 2, 1),
577*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(183, 184, 7, 0x00a0, 0x10, 1, 1),
578*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(185, 185, 7, 0x00a0, 0x10, 4, 1),
579*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(186, 186, 7, 0x00a0, 0x10, 6, 1),
580*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(187, 187, 7, 0x00a0, 0x10, 8, 1),
581*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(188, 188, 7, 0x00a0, 0x10, 3, 1),
582*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(189, 189, 7, 0x00a0, 0x10, 7, 1),
583*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(190, 191, 7, 0x00a0, 0x10, 9, 1),
584*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(192, 192, 7, 0x00a0, 0x10, 0, 1),
585*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(193, 193, 7, 0x00a0, 0x10, 5, 1),
586*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(194, 194, 7, 0x00a0, 0x10, 11, 1),
587*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(200, 200, 7, 0x00e0, 0x10, 6, 1),
588*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(201, 201, 7, 0x00e0, 0x10, 10, 1),
589*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(202, 202, 7, 0x00e0, 0x10, 4, 1),
590*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(203, 203, 7, 0x00e0, 0x10, 8, 1),
591*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(204, 204, 6, 0x00d0, 0x10, 0, 1),
592*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(205, 205, 6, 0x00d0, 0x10, 2, 1),
593*80045071SAngeloGioacchino Del Regno };
594*80045071SAngeloGioacchino Del Regno 
595*80045071SAngeloGioacchino Del Regno static const struct mtk_pin_field_calc mt6893_pin_r1_range[] = {
596*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(10, 15, 1, 0x0070, 0x10, 0, 1),
597*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(24, 24, 7, 0x00e0, 0x10, 1, 1),
598*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(25, 25, 7, 0x00e0, 0x10, 3, 1),
599*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(45, 45, 6, 0x00a0, 0x10, 3, 1),
600*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(46, 46, 6, 0x00a0, 0x10, 5, 1),
601*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(47, 47, 6, 0x00a0, 0x10, 4, 1),
602*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(48, 49, 6, 0x00a0, 0x10, 1, 1),
603*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(50, 50, 6, 0x00a0, 0x10, 0, 1),
604*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(51, 52, 3, 0x0070, 0x10, 0, 1),
605*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(53, 53, 3, 0x0070, 0x10, 5, 1),
606*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(54, 54, 3, 0x0070, 0x10, 2, 1),
607*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(55, 55, 3, 0x0070, 0x10, 4, 1),
608*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(56, 56, 3, 0x0070, 0x10, 3, 1),
609*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(118, 118, 2, 0x00e0, 0x10, 1, 1),
610*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(119, 119, 2, 0x00e0, 0x10, 13, 1),
611*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(120, 120, 2, 0x00e0, 0x10, 11, 1),
612*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(121, 121, 2, 0x00e0, 0x10, 23, 1),
613*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(122, 122, 2, 0x00e0, 0x10, 9, 1),
614*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(123, 123, 2, 0x00e0, 0x10, 21, 1),
615*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(124, 124, 2, 0x00e0, 0x10, 7, 1),
616*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(125, 125, 2, 0x00e0, 0x10, 19, 1),
617*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(139, 139, 2, 0x00e0, 0x10, 5, 1),
618*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(140, 140, 2, 0x00e0, 0x10, 17, 1),
619*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(141, 141, 2, 0x00e0, 0x10, 3, 1),
620*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(142, 142, 2, 0x00e0, 0x10, 15, 1),
621*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(152, 152, 5, 0x0090, 0x10, 3, 1),
622*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(153, 153, 5, 0x0090, 0x10, 2, 1),
623*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(154, 155, 5, 0x0090, 0x10, 0, 1),
624*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(160, 160, 5, 0x00b0, 0x10, 1, 1),
625*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(161, 161, 5, 0x00b0, 0x10, 3, 1),
626*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(183, 184, 7, 0x00b0, 0x10, 1, 1),
627*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(185, 185, 7, 0x00b0, 0x10, 4, 1),
628*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(186, 186, 7, 0x00b0, 0x10, 6, 1),
629*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(187, 187, 7, 0x00b0, 0x10, 8, 1),
630*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(188, 188, 7, 0x00b0, 0x10, 3, 1),
631*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(189, 189, 7, 0x00b0, 0x10, 7, 1),
632*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(190, 191, 7, 0x00b0, 0x10, 9, 1),
633*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(192, 192, 7, 0x00b0, 0x10, 0, 1),
634*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(193, 193, 7, 0x00b0, 0x10, 5, 1),
635*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(194, 194, 7, 0x00b0, 0x10, 11, 1),
636*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(200, 200, 7, 0x00e0, 0x10, 7, 1),
637*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(201, 201, 7, 0x00e0, 0x10, 11, 1),
638*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(202, 202, 7, 0x00e0, 0x10, 5, 1),
639*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(203, 203, 7, 0x00e0, 0x10, 9, 1),
640*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(204, 204, 6, 0x00d0, 0x10, 1, 1),
641*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(205, 205, 6, 0x00d0, 0x10, 3, 1),
642*80045071SAngeloGioacchino Del Regno };
643*80045071SAngeloGioacchino Del Regno 
644*80045071SAngeloGioacchino Del Regno static const struct mtk_pin_field_calc mt6893_pin_drv_adv_range[] = {
645*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(24, 24, 7, 0x0030, 0x10, 0, 3),
646*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(25, 25, 7, 0x0030, 0x10, 3, 3),
647*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(89, 89, 2, 0x0050, 0x10, 6, 5),
648*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(90, 90, 2, 0x0050, 0x10, 11, 5),
649*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(118, 118, 2, 0x0040, 0x10, 0, 3),
650*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(119, 119, 2, 0x0040, 0x10, 18, 3),
651*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(120, 120, 2, 0x0040, 0x10, 15, 3),
652*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(121, 121, 2, 0x0050, 0x10, 3, 3),
653*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(122, 122, 2, 0x0040, 0x10, 12, 3),
654*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(123, 123, 2, 0x0050, 0x10, 0, 3),
655*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(124, 124, 2, 0x0040, 0x10, 9, 3),
656*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(125, 125, 2, 0x0040, 0x10, 27, 3),
657*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(139, 139, 2, 0x0040, 0x10, 6, 3),
658*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(140, 140, 2, 0x0040, 0x10, 24, 3),
659*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(141, 141, 2, 0x0040, 0x10, 3, 3),
660*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(142, 142, 2, 0x0040, 0x10, 21, 3),
661*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(160, 160, 5, 0x0020, 0x10, 0, 3),
662*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(161, 161, 5, 0x0020, 0x10, 3, 3),
663*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(200, 200, 7, 0x0030, 0x10, 9, 3),
664*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(201, 201, 7, 0x0030, 0x10, 15, 3),
665*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(202, 202, 7, 0x0030, 0x10, 6, 3),
666*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(203, 203, 7, 0x0030, 0x10, 12, 3),
667*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(204, 204, 6, 0x0020, 0x10, 0, 3),
668*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(205, 205, 6, 0x0020, 0x10, 3, 3),
669*80045071SAngeloGioacchino Del Regno };
670*80045071SAngeloGioacchino Del Regno 
671*80045071SAngeloGioacchino Del Regno static const struct mtk_pin_field_calc mt6893_pin_rsel_range[] = {
672*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(24, 24, 7, 0x00e0, 0x10, 0, 2),
673*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(25, 25, 7, 0x00e0, 0x10, 2, 2),
674*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(118, 118, 2, 0x00e0, 0x10, 0, 2),
675*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(119, 119, 2, 0x00e0, 0x10, 12, 2),
676*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(120, 120, 2, 0x00e0, 0x10, 10, 2),
677*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(121, 121, 2, 0x00e0, 0x10, 22, 2),
678*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(122, 122, 2, 0x00e0, 0x10, 8, 2),
679*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(123, 123, 2, 0x00e0, 0x10, 20, 2),
680*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(124, 124, 2, 0x00e0, 0x10, 6, 2),
681*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(125, 125, 2, 0x00e0, 0x10, 18, 2),
682*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(139, 139, 2, 0x00e0, 0x10, 4, 2),
683*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(140, 140, 2, 0x00e0, 0x10, 16, 2),
684*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(141, 141, 2, 0x00e0, 0x10, 2, 2),
685*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(142, 142, 2, 0x00e0, 0x10, 14, 2),
686*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(160, 160, 5, 0x00b0, 0x10, 0, 2),
687*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(161, 161, 5, 0x00b0, 0x10, 2, 2),
688*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(200, 200, 7, 0x00e0, 0x10, 6, 2),
689*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(201, 201, 7, 0x00e0, 0x10, 10, 2),
690*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(202, 202, 7, 0x00e0, 0x10, 4, 2),
691*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(203, 203, 7, 0x00e0, 0x10, 8, 2),
692*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(204, 204, 6, 0x00d0, 0x10, 0, 2),
693*80045071SAngeloGioacchino Del Regno 	PIN_FIELD_BASE(205, 205, 6, 0x00d0, 0x10, 2, 2),
694*80045071SAngeloGioacchino Del Regno };
695*80045071SAngeloGioacchino Del Regno 
696*80045071SAngeloGioacchino Del Regno static const unsigned int mt6893_pull_type[] = {
697*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 0 */		MTK_PULL_PU_PD_TYPE, /* 1 */
698*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 2 */		MTK_PULL_PU_PD_TYPE, /* 3 */
699*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 4 */		MTK_PULL_PU_PD_TYPE, /* 5 */
700*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 6 */		MTK_PULL_PU_PD_TYPE, /* 7 */
701*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 8 */		MTK_PULL_PU_PD_TYPE, /* 9 */
702*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PUPD_R1R0_TYPE, /* 10 */	MTK_PULL_PUPD_R1R0_TYPE, /* 11 */
703*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PUPD_R1R0_TYPE, /* 12 */	MTK_PULL_PUPD_R1R0_TYPE, /* 13 */
704*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PUPD_R1R0_TYPE, /* 14 */	MTK_PULL_PUPD_R1R0_TYPE, /* 15 */
705*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 16 */		MTK_PULL_PU_PD_TYPE, /* 17 */
706*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 18 */		MTK_PULL_PU_PD_TYPE, /* 19 */
707*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 20 */		MTK_PULL_PU_PD_TYPE, /* 21 */
708*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 22 */		MTK_PULL_PU_PD_TYPE, /* 23 */
709*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_RSEL_TYPE, /* 24 */	MTK_PULL_PU_PD_RSEL_TYPE, /* 25 */
710*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 26 */		MTK_PULL_PU_PD_TYPE, /* 27 */
711*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 28 */		MTK_PULL_PU_PD_TYPE, /* 29 */
712*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 30 */		MTK_PULL_PU_PD_TYPE, /* 31 */
713*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 32 */		MTK_PULL_PU_PD_TYPE, /* 33 */
714*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 34 */		MTK_PULL_PU_PD_TYPE, /* 35 */
715*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 36 */		MTK_PULL_PU_PD_TYPE, /* 37 */
716*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 38 */		MTK_PULL_PU_PD_TYPE, /* 39 */
717*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 40 */		MTK_PULL_PU_PD_TYPE, /* 41 */
718*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 42 */		MTK_PULL_PU_PD_TYPE, /* 43 */
719*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 44 */		MTK_PULL_PUPD_R1R0_TYPE, /* 45 */
720*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PUPD_R1R0_TYPE, /* 46 */	MTK_PULL_PUPD_R1R0_TYPE, /* 47 */
721*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PUPD_R1R0_TYPE, /* 48 */	MTK_PULL_PUPD_R1R0_TYPE, /* 49 */
722*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PUPD_R1R0_TYPE, /* 50 */	MTK_PULL_PUPD_R1R0_TYPE, /* 51 */
723*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PUPD_R1R0_TYPE, /* 52 */	MTK_PULL_PUPD_R1R0_TYPE, /* 53 */
724*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PUPD_R1R0_TYPE, /* 54 */	MTK_PULL_PUPD_R1R0_TYPE, /* 55 */
725*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PUPD_R1R0_TYPE, /* 56 */	MTK_PULL_PU_PD_TYPE, /* 57 */
726*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 58 */		MTK_PULL_PU_PD_TYPE, /* 59 */
727*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 60 */		MTK_PULL_PU_PD_TYPE, /* 61 */
728*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 62 */		MTK_PULL_PU_PD_TYPE, /* 63 */
729*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 64 */		MTK_PULL_PU_PD_TYPE, /* 65 */
730*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 66 */		MTK_PULL_PU_PD_TYPE, /* 67 */
731*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 68 */		MTK_PULL_PU_PD_TYPE, /* 69 */
732*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 70 */		MTK_PULL_PU_PD_TYPE, /* 71 */
733*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 72 */		MTK_PULL_PU_PD_TYPE, /* 73 */
734*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 74 */		MTK_PULL_PU_PD_TYPE, /* 75 */
735*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 76 */		MTK_PULL_PU_PD_TYPE, /* 77 */
736*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 78 */		MTK_PULL_PU_PD_TYPE, /* 79 */
737*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 80 */		MTK_PULL_PU_PD_TYPE, /* 81 */
738*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 82 */		MTK_PULL_PU_PD_TYPE, /* 83 */
739*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 84 */		MTK_PULL_PU_PD_TYPE, /* 85 */
740*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 86 */		MTK_PULL_PU_PD_TYPE, /* 87 */
741*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 88 */		MTK_PULL_PU_PD_TYPE, /* 89 */
742*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 90 */		MTK_PULL_PU_PD_TYPE, /* 91 */
743*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 92 */		MTK_PULL_PU_PD_TYPE, /* 93 */
744*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 94 */		MTK_PULL_PU_PD_TYPE, /* 95 */
745*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 96 */		MTK_PULL_PU_PD_TYPE, /* 97 */
746*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 98 */		MTK_PULL_PU_PD_TYPE, /* 99 */
747*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 100 */		MTK_PULL_PU_PD_TYPE, /* 101 */
748*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 102 */		MTK_PULL_PU_PD_TYPE, /* 103 */
749*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 104 */		MTK_PULL_PU_PD_TYPE, /* 105 */
750*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 106 */		MTK_PULL_PU_PD_TYPE, /* 107 */
751*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 108 */		MTK_PULL_PU_PD_TYPE, /* 109 */
752*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 110 */		MTK_PULL_PU_PD_TYPE, /* 111 */
753*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 112 */		MTK_PULL_PU_PD_TYPE, /* 113 */
754*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 114 */		MTK_PULL_PU_PD_TYPE, /* 115 */
755*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 116 */		MTK_PULL_PU_PD_TYPE, /* 117 */
756*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_RSEL_TYPE, /* 118 */	MTK_PULL_PU_PD_RSEL_TYPE, /* 119 */
757*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_RSEL_TYPE, /* 120 */	MTK_PULL_PU_PD_RSEL_TYPE, /* 121 */
758*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_RSEL_TYPE, /* 122 */	MTK_PULL_PU_PD_RSEL_TYPE, /* 123 */
759*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_RSEL_TYPE, /* 124 */	MTK_PULL_PU_PD_RSEL_TYPE, /* 125 */
760*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 126 */		MTK_PULL_PU_PD_TYPE, /* 127 */
761*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 128 */		MTK_PULL_PU_PD_TYPE, /* 129 */
762*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 130 */		MTK_PULL_PU_PD_TYPE, /* 131 */
763*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 132 */		MTK_PULL_PU_PD_TYPE, /* 133 */
764*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 134 */		MTK_PULL_PU_PD_TYPE, /* 135 */
765*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 136 */		MTK_PULL_PU_PD_TYPE, /* 137 */
766*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 138 */		MTK_PULL_PU_PD_TYPE, /* 139 */
767*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_RSEL_TYPE, /* 140 */	MTK_PULL_PU_PD_RSEL_TYPE, /* 141 */
768*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_RSEL_TYPE, /* 142 */	MTK_PULL_PU_PD_TYPE, /* 143 */
769*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 144 */		MTK_PULL_PU_PD_TYPE, /* 145 */
770*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 146 */		MTK_PULL_PU_PD_TYPE, /* 147 */
771*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 148 */		MTK_PULL_PU_PD_TYPE, /* 149 */
772*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 150 */		MTK_PULL_PU_PD_TYPE, /* 151 */
773*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PUPD_R1R0_TYPE, /* 152 */	MTK_PULL_PUPD_R1R0_TYPE, /* 153 */
774*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PUPD_R1R0_TYPE, /* 154 */	MTK_PULL_PUPD_R1R0_TYPE, /* 155 */
775*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 156 */		MTK_PULL_PU_PD_TYPE, /* 157 */
776*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 158 */		MTK_PULL_PU_PD_TYPE, /* 159 */
777*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_RSEL_TYPE, /* 160 */	MTK_PULL_PU_PD_RSEL_TYPE, /* 161 */
778*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 162 */		MTK_PULL_PU_PD_TYPE, /* 163 */
779*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 164 */		MTK_PULL_PU_PD_TYPE, /* 165 */
780*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 166 */		MTK_PULL_PU_PD_TYPE, /* 167 */
781*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 168 */		MTK_PULL_PU_PD_TYPE, /* 169 */
782*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 170 */		MTK_PULL_PU_PD_TYPE, /* 171 */
783*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 172 */		MTK_PULL_PU_PD_TYPE, /* 173 */
784*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 174 */		MTK_PULL_PU_PD_TYPE, /* 175 */
785*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 176 */		MTK_PULL_PU_PD_TYPE, /* 177 */
786*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 178 */		MTK_PULL_PU_PD_TYPE, /* 179 */
787*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 180 */		MTK_PULL_PU_PD_TYPE, /* 181 */
788*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 182 */		MTK_PULL_PUPD_R1R0_TYPE, /* 183 */
789*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PUPD_R1R0_TYPE, /* 184 */	MTK_PULL_PUPD_R1R0_TYPE, /* 185 */
790*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PUPD_R1R0_TYPE, /* 186 */	MTK_PULL_PUPD_R1R0_TYPE, /* 187 */
791*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PUPD_R1R0_TYPE, /* 188 */	MTK_PULL_PUPD_R1R0_TYPE, /* 189 */
792*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PUPD_R1R0_TYPE, /* 190 */	MTK_PULL_PUPD_R1R0_TYPE, /* 191 */
793*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PUPD_R1R0_TYPE, /* 192 */	MTK_PULL_PUPD_R1R0_TYPE, /* 193 */
794*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PUPD_R1R0_TYPE, /* 194 */	MTK_PULL_PU_PD_TYPE, /* 195 */
795*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 196 */		MTK_PULL_PU_PD_TYPE, /* 197 */
796*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 198 */		MTK_PULL_PU_PD_TYPE, /* 199 */
797*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_RSEL_TYPE, /* 200 */	MTK_PULL_PU_PD_RSEL_TYPE, /* 201 */
798*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_RSEL_TYPE, /* 202 */	MTK_PULL_PU_PD_RSEL_TYPE, /* 203 */
799*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_RSEL_TYPE, /* 204 */	MTK_PULL_PU_PD_RSEL_TYPE, /* 205 */
800*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 206 */		MTK_PULL_PU_PD_TYPE, /* 207 */
801*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 208 */		MTK_PULL_PU_PD_TYPE, /* 209 */
802*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 210 */		MTK_PULL_PU_PD_TYPE, /* 211 */
803*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 212 */		MTK_PULL_PU_PD_TYPE, /* 213 */
804*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 214 */		MTK_PULL_PU_PD_TYPE, /* 215 */
805*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 216 */		MTK_PULL_PU_PD_TYPE, /* 217 */
806*80045071SAngeloGioacchino Del Regno 	MTK_PULL_PU_PD_TYPE, /* 218 */		MTK_PULL_PU_PD_TYPE, /* 219 */
807*80045071SAngeloGioacchino Del Regno };
808*80045071SAngeloGioacchino Del Regno 
809*80045071SAngeloGioacchino Del Regno static const char * const mt6893_pinctrl_register_base_name[] = {
810*80045071SAngeloGioacchino Del Regno 	"base", "rm", "bm", "bl", "br", "lm", "lb", "rt", "lt", "tl",
811*80045071SAngeloGioacchino Del Regno };
812*80045071SAngeloGioacchino Del Regno 
813*80045071SAngeloGioacchino Del Regno static const struct mtk_pin_reg_calc mt6893_reg_cals[PINCTRL_PIN_REG_MAX] = {
814*80045071SAngeloGioacchino Del Regno 	[PINCTRL_PIN_REG_MODE] = MTK_RANGE(mt6893_pin_mode_range),
815*80045071SAngeloGioacchino Del Regno 	[PINCTRL_PIN_REG_DIR] = MTK_RANGE(mt6893_pin_dir_range),
816*80045071SAngeloGioacchino Del Regno 	[PINCTRL_PIN_REG_DI] = MTK_RANGE(mt6893_pin_di_range),
817*80045071SAngeloGioacchino Del Regno 	[PINCTRL_PIN_REG_DO] = MTK_RANGE(mt6893_pin_do_range),
818*80045071SAngeloGioacchino Del Regno 	[PINCTRL_PIN_REG_SR] = MTK_RANGE(mt6893_pin_dir_range),
819*80045071SAngeloGioacchino Del Regno 	[PINCTRL_PIN_REG_SMT] = MTK_RANGE(mt6893_pin_smt_range),
820*80045071SAngeloGioacchino Del Regno 	[PINCTRL_PIN_REG_IES] = MTK_RANGE(mt6893_pin_ies_range),
821*80045071SAngeloGioacchino Del Regno 	[PINCTRL_PIN_REG_PU] = MTK_RANGE(mt6893_pin_pu_range),
822*80045071SAngeloGioacchino Del Regno 	[PINCTRL_PIN_REG_PD] = MTK_RANGE(mt6893_pin_pd_range),
823*80045071SAngeloGioacchino Del Regno 	[PINCTRL_PIN_REG_DRV] = MTK_RANGE(mt6893_pin_drv_range),
824*80045071SAngeloGioacchino Del Regno 	[PINCTRL_PIN_REG_PUPD] = MTK_RANGE(mt6893_pin_pupd_range),
825*80045071SAngeloGioacchino Del Regno 	[PINCTRL_PIN_REG_R0] = MTK_RANGE(mt6893_pin_r0_range),
826*80045071SAngeloGioacchino Del Regno 	[PINCTRL_PIN_REG_R1] = MTK_RANGE(mt6893_pin_r1_range),
827*80045071SAngeloGioacchino Del Regno 	[PINCTRL_PIN_REG_DRV_ADV] = MTK_RANGE(mt6893_pin_drv_adv_range),
828*80045071SAngeloGioacchino Del Regno 	[PINCTRL_PIN_REG_RSEL] = MTK_RANGE(mt6893_pin_rsel_range),
829*80045071SAngeloGioacchino Del Regno };
830*80045071SAngeloGioacchino Del Regno 
831*80045071SAngeloGioacchino Del Regno static const struct mtk_eint_hw mt6893_eint_hw = {
832*80045071SAngeloGioacchino Del Regno 	.port_mask = 7,
833*80045071SAngeloGioacchino Del Regno 	.ports     = 7,
834*80045071SAngeloGioacchino Del Regno 	.ap_num    = 224,
835*80045071SAngeloGioacchino Del Regno 	.db_cnt    = 32,
836*80045071SAngeloGioacchino Del Regno 	.db_time   = debounce_time_mt6765,
837*80045071SAngeloGioacchino Del Regno };
838*80045071SAngeloGioacchino Del Regno 
839*80045071SAngeloGioacchino Del Regno static const struct mtk_pin_soc mt6893_data = {
840*80045071SAngeloGioacchino Del Regno 	.reg_cal = mt6893_reg_cals,
841*80045071SAngeloGioacchino Del Regno 	.pins = mtk_pins_mt6893,
842*80045071SAngeloGioacchino Del Regno 	.npins = ARRAY_SIZE(mtk_pins_mt6893),
843*80045071SAngeloGioacchino Del Regno 	.ngrps = ARRAY_SIZE(mtk_pins_mt6893),
844*80045071SAngeloGioacchino Del Regno 	.eint_hw = &mt6893_eint_hw,
845*80045071SAngeloGioacchino Del Regno 	.nfuncs = 8,
846*80045071SAngeloGioacchino Del Regno 	.gpio_m = 0,
847*80045071SAngeloGioacchino Del Regno 	.base_names = mt6893_pinctrl_register_base_name,
848*80045071SAngeloGioacchino Del Regno 	.nbase_names = ARRAY_SIZE(mt6893_pinctrl_register_base_name),
849*80045071SAngeloGioacchino Del Regno 	.pull_type = mt6893_pull_type,
850*80045071SAngeloGioacchino Del Regno 	.bias_set_combo = mtk_pinconf_bias_set_combo,
851*80045071SAngeloGioacchino Del Regno 	.bias_get_combo = mtk_pinconf_bias_get_combo,
852*80045071SAngeloGioacchino Del Regno 	.drive_set = mtk_pinconf_drive_set_rev1,
853*80045071SAngeloGioacchino Del Regno 	.drive_get = mtk_pinconf_drive_get_rev1,
854*80045071SAngeloGioacchino Del Regno 	.adv_drive_set = mtk_pinconf_adv_drive_set_raw,
855*80045071SAngeloGioacchino Del Regno 	.adv_drive_get = mtk_pinconf_adv_drive_get_raw,
856*80045071SAngeloGioacchino Del Regno };
857*80045071SAngeloGioacchino Del Regno 
858*80045071SAngeloGioacchino Del Regno static const struct of_device_id mt6893_pinctrl_of_match[] = {
859*80045071SAngeloGioacchino Del Regno 	{ .compatible = "mediatek,mt6893-pinctrl", .data = &mt6893_data },
860*80045071SAngeloGioacchino Del Regno 	{ /* sentinel */ }
861*80045071SAngeloGioacchino Del Regno };
862*80045071SAngeloGioacchino Del Regno 
863*80045071SAngeloGioacchino Del Regno static struct platform_driver mt6893_pinctrl_driver = {
864*80045071SAngeloGioacchino Del Regno 	.driver = {
865*80045071SAngeloGioacchino Del Regno 		.name = "mt6893-pinctrl",
866*80045071SAngeloGioacchino Del Regno 		.of_match_table = mt6893_pinctrl_of_match,
867*80045071SAngeloGioacchino Del Regno 		.pm = pm_sleep_ptr(&mtk_paris_pinctrl_pm_ops)
868*80045071SAngeloGioacchino Del Regno 	},
869*80045071SAngeloGioacchino Del Regno 	.probe = mtk_paris_pinctrl_probe,
870*80045071SAngeloGioacchino Del Regno };
871*80045071SAngeloGioacchino Del Regno 
mt6893_pinctrl_init(void)872*80045071SAngeloGioacchino Del Regno static int __init mt6893_pinctrl_init(void)
873*80045071SAngeloGioacchino Del Regno {
874*80045071SAngeloGioacchino Del Regno 	return platform_driver_register(&mt6893_pinctrl_driver);
875*80045071SAngeloGioacchino Del Regno }
876*80045071SAngeloGioacchino Del Regno 
877*80045071SAngeloGioacchino Del Regno arch_initcall(mt6893_pinctrl_init);
878*80045071SAngeloGioacchino Del Regno 
879*80045071SAngeloGioacchino Del Regno MODULE_DESCRIPTION("MediaTek MT6893 Pinctrl Driver");
880