blob: 1da72438d68026aab4f83b39db2dc3de4cc77e5e [file] [log] [blame]
Thomas Gleixneraf873fc2019-05-28 09:57:21 -07001// SPDX-License-Identifier: GPL-2.0-only
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002/*
3 * Ingenic SoCs pinctrl driver
4 *
5 * Copyright (c) 2017 Paul Cercueil <paul@crapouillou.net>
周琰杰 (Zhou Yanjie)d7da2a12019-12-16 00:21:04 +08006 * Copyright (c) 2019 周琰杰 (Zhou Yanjie) <zhouyanjie@wanyeetech.com>
Paul Boddiea0bb89e2020-02-28 19:19:30 +01007 * Copyright (c) 2017, 2019 Paul Boddie <paul@boddie.org.uk>
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02008 */
9
10#include <linux/compiler.h>
Linus Walleij28d6eeb2018-08-29 13:39:54 +020011#include <linux/gpio/driver.h>
Paul Cercueilb5c23aa2017-05-12 18:52:56 +020012#include <linux/interrupt.h>
13#include <linux/io.h>
14#include <linux/of_device.h>
Paul Cercueile72394e2018-08-21 18:42:32 +020015#include <linux/of_irq.h>
Paul Cercueilb5c23aa2017-05-12 18:52:56 +020016#include <linux/of_platform.h>
17#include <linux/pinctrl/pinctrl.h>
18#include <linux/pinctrl/pinmux.h>
19#include <linux/pinctrl/pinconf.h>
20#include <linux/pinctrl/pinconf-generic.h>
21#include <linux/platform_device.h>
22#include <linux/regmap.h>
23#include <linux/slab.h>
24
25#include "core.h"
26#include "pinconf.h"
27#include "pinmux.h"
28
Paul Cercueile72394e2018-08-21 18:42:32 +020029#define GPIO_PIN 0x00
30#define GPIO_MSK 0x20
31
Paul Cercueilb5c23aa2017-05-12 18:52:56 +020032#define JZ4740_GPIO_DATA 0x10
33#define JZ4740_GPIO_PULL_DIS 0x30
34#define JZ4740_GPIO_FUNC 0x40
35#define JZ4740_GPIO_SELECT 0x50
36#define JZ4740_GPIO_DIR 0x60
37#define JZ4740_GPIO_TRIG 0x70
38#define JZ4740_GPIO_FLAG 0x80
39
Zhou Yanjie0257595a2019-07-14 11:53:52 +080040#define JZ4760_GPIO_INT 0x10
41#define JZ4760_GPIO_PAT1 0x30
42#define JZ4760_GPIO_PAT0 0x40
43#define JZ4760_GPIO_FLAG 0x50
44#define JZ4760_GPIO_PEN 0x70
Paul Cercueilb5c23aa2017-05-12 18:52:56 +020045
周琰杰 (Zhou Yanjie)d7da2a12019-12-16 00:21:04 +080046#define X1830_GPIO_PEL 0x110
47#define X1830_GPIO_PEH 0x120
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +080048
Paul Cercueilb5c23aa2017-05-12 18:52:56 +020049#define REG_SET(x) ((x) + 0x4)
50#define REG_CLEAR(x) ((x) + 0x8)
51
周琰杰 (Zhou Yanjie)d7da2a12019-12-16 00:21:04 +080052#define REG_PZ_BASE(x) ((x) * 7)
53#define REG_PZ_GID2LD(x) ((x) * 7 + 0xf0)
54
55#define GPIO_PULL_DIS 0
56#define GPIO_PULL_UP 1
57#define GPIO_PULL_DOWN 2
58
Paul Cercueilb5c23aa2017-05-12 18:52:56 +020059#define PINS_PER_GPIO_CHIP 32
60
61enum jz_version {
62 ID_JZ4740,
Paul Cercueilf2a96762018-08-21 18:42:34 +020063 ID_JZ4725B,
Zhou Yanjie0257595a2019-07-14 11:53:52 +080064 ID_JZ4760,
Paul Cercueilb5c23aa2017-05-12 18:52:56 +020065 ID_JZ4770,
66 ID_JZ4780,
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +080067 ID_X1000,
Zhou Yanjie5d215952019-07-14 11:53:56 +080068 ID_X1500,
周琰杰 (Zhou Yanjie)d7da2a12019-12-16 00:21:04 +080069 ID_X1830,
Paul Cercueilb5c23aa2017-05-12 18:52:56 +020070};
71
72struct ingenic_chip_info {
73 unsigned int num_chips;
周琰杰 (Zhou Yanjie)f742e5e2019-12-16 00:21:02 +080074 unsigned int reg_offset;
Paul Cercueilbaf15642020-01-07 00:27:08 +010075 enum jz_version version;
Paul Cercueilb5c23aa2017-05-12 18:52:56 +020076
77 const struct group_desc *groups;
78 unsigned int num_groups;
79
80 const struct function_desc *functions;
81 unsigned int num_functions;
82
83 const u32 *pull_ups, *pull_downs;
84};
85
86struct ingenic_pinctrl {
87 struct device *dev;
88 struct regmap *map;
89 struct pinctrl_dev *pctl;
90 struct pinctrl_pin_desc *pdesc;
Paul Cercueilb5c23aa2017-05-12 18:52:56 +020091
92 const struct ingenic_chip_info *info;
93};
94
Paul Cercueile72394e2018-08-21 18:42:32 +020095struct ingenic_gpio_chip {
96 struct ingenic_pinctrl *jzpc;
97 struct gpio_chip gc;
98 struct irq_chip irq_chip;
99 unsigned int irq, reg_base;
100};
101
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200102static const u32 jz4740_pull_ups[4] = {
103 0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff,
104};
105
106static const u32 jz4740_pull_downs[4] = {
107 0x00000000, 0x00000000, 0x00000000, 0x00000000,
108};
109
110static int jz4740_mmc_1bit_pins[] = { 0x69, 0x68, 0x6a, };
111static int jz4740_mmc_4bit_pins[] = { 0x6b, 0x6c, 0x6d, };
112static int jz4740_uart0_data_pins[] = { 0x7a, 0x79, };
113static int jz4740_uart0_hwflow_pins[] = { 0x7e, 0x7f, };
114static int jz4740_uart1_data_pins[] = { 0x7e, 0x7f, };
115static int jz4740_lcd_8bit_pins[] = {
116 0x40, 0x41, 0x42, 0x43, 0x44, 0x45, 0x46, 0x47, 0x52, 0x53, 0x54,
117};
118static int jz4740_lcd_16bit_pins[] = {
119 0x48, 0x49, 0x4a, 0x4b, 0x4c, 0x4d, 0x4e, 0x4f, 0x55,
120};
121static int jz4740_lcd_18bit_pins[] = { 0x50, 0x51, };
122static int jz4740_lcd_18bit_tft_pins[] = { 0x56, 0x57, 0x31, 0x32, };
123static int jz4740_nand_cs1_pins[] = { 0x39, };
124static int jz4740_nand_cs2_pins[] = { 0x3a, };
125static int jz4740_nand_cs3_pins[] = { 0x3b, };
126static int jz4740_nand_cs4_pins[] = { 0x3c, };
Paul Cercueilbcad94d2020-06-07 19:42:43 +0200127static int jz4740_nand_fre_fwe_pins[] = { 0x5c, 0x5d, };
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200128static int jz4740_pwm_pwm0_pins[] = { 0x77, };
129static int jz4740_pwm_pwm1_pins[] = { 0x78, };
130static int jz4740_pwm_pwm2_pins[] = { 0x79, };
131static int jz4740_pwm_pwm3_pins[] = { 0x7a, };
132static int jz4740_pwm_pwm4_pins[] = { 0x7b, };
133static int jz4740_pwm_pwm5_pins[] = { 0x7c, };
134static int jz4740_pwm_pwm6_pins[] = { 0x7e, };
135static int jz4740_pwm_pwm7_pins[] = { 0x7f, };
136
137static int jz4740_mmc_1bit_funcs[] = { 0, 0, 0, };
138static int jz4740_mmc_4bit_funcs[] = { 0, 0, 0, };
139static int jz4740_uart0_data_funcs[] = { 1, 1, };
140static int jz4740_uart0_hwflow_funcs[] = { 1, 1, };
141static int jz4740_uart1_data_funcs[] = { 2, 2, };
142static int jz4740_lcd_8bit_funcs[] = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, };
143static int jz4740_lcd_16bit_funcs[] = { 0, 0, 0, 0, 0, 0, 0, 0, 0, };
144static int jz4740_lcd_18bit_funcs[] = { 0, 0, };
145static int jz4740_lcd_18bit_tft_funcs[] = { 0, 0, 0, 0, };
146static int jz4740_nand_cs1_funcs[] = { 0, };
147static int jz4740_nand_cs2_funcs[] = { 0, };
148static int jz4740_nand_cs3_funcs[] = { 0, };
149static int jz4740_nand_cs4_funcs[] = { 0, };
Paul Cercueilbcad94d2020-06-07 19:42:43 +0200150static int jz4740_nand_fre_fwe_funcs[] = { 0, 0, };
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200151static int jz4740_pwm_pwm0_funcs[] = { 0, };
152static int jz4740_pwm_pwm1_funcs[] = { 0, };
153static int jz4740_pwm_pwm2_funcs[] = { 0, };
154static int jz4740_pwm_pwm3_funcs[] = { 0, };
155static int jz4740_pwm_pwm4_funcs[] = { 0, };
156static int jz4740_pwm_pwm5_funcs[] = { 0, };
157static int jz4740_pwm_pwm6_funcs[] = { 0, };
158static int jz4740_pwm_pwm7_funcs[] = { 0, };
159
160#define INGENIC_PIN_GROUP(name, id) \
161 { \
162 name, \
163 id##_pins, \
164 ARRAY_SIZE(id##_pins), \
165 id##_funcs, \
166 }
167
168static const struct group_desc jz4740_groups[] = {
169 INGENIC_PIN_GROUP("mmc-1bit", jz4740_mmc_1bit),
170 INGENIC_PIN_GROUP("mmc-4bit", jz4740_mmc_4bit),
171 INGENIC_PIN_GROUP("uart0-data", jz4740_uart0_data),
172 INGENIC_PIN_GROUP("uart0-hwflow", jz4740_uart0_hwflow),
173 INGENIC_PIN_GROUP("uart1-data", jz4740_uart1_data),
174 INGENIC_PIN_GROUP("lcd-8bit", jz4740_lcd_8bit),
175 INGENIC_PIN_GROUP("lcd-16bit", jz4740_lcd_16bit),
176 INGENIC_PIN_GROUP("lcd-18bit", jz4740_lcd_18bit),
177 INGENIC_PIN_GROUP("lcd-18bit-tft", jz4740_lcd_18bit_tft),
178 { "lcd-no-pins", },
179 INGENIC_PIN_GROUP("nand-cs1", jz4740_nand_cs1),
180 INGENIC_PIN_GROUP("nand-cs2", jz4740_nand_cs2),
181 INGENIC_PIN_GROUP("nand-cs3", jz4740_nand_cs3),
182 INGENIC_PIN_GROUP("nand-cs4", jz4740_nand_cs4),
Paul Cercueilbcad94d2020-06-07 19:42:43 +0200183 INGENIC_PIN_GROUP("nand-fre-fwe", jz4740_nand_fre_fwe),
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200184 INGENIC_PIN_GROUP("pwm0", jz4740_pwm_pwm0),
185 INGENIC_PIN_GROUP("pwm1", jz4740_pwm_pwm1),
186 INGENIC_PIN_GROUP("pwm2", jz4740_pwm_pwm2),
187 INGENIC_PIN_GROUP("pwm3", jz4740_pwm_pwm3),
188 INGENIC_PIN_GROUP("pwm4", jz4740_pwm_pwm4),
189 INGENIC_PIN_GROUP("pwm5", jz4740_pwm_pwm5),
190 INGENIC_PIN_GROUP("pwm6", jz4740_pwm_pwm6),
191 INGENIC_PIN_GROUP("pwm7", jz4740_pwm_pwm7),
192};
193
194static const char *jz4740_mmc_groups[] = { "mmc-1bit", "mmc-4bit", };
195static const char *jz4740_uart0_groups[] = { "uart0-data", "uart0-hwflow", };
196static const char *jz4740_uart1_groups[] = { "uart1-data", };
197static const char *jz4740_lcd_groups[] = {
198 "lcd-8bit", "lcd-16bit", "lcd-18bit", "lcd-18bit-tft", "lcd-no-pins",
199};
200static const char *jz4740_nand_groups[] = {
Paul Cercueilbcad94d2020-06-07 19:42:43 +0200201 "nand-cs1", "nand-cs2", "nand-cs3", "nand-cs4", "nand-fre-fwe",
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200202};
203static const char *jz4740_pwm0_groups[] = { "pwm0", };
204static const char *jz4740_pwm1_groups[] = { "pwm1", };
205static const char *jz4740_pwm2_groups[] = { "pwm2", };
206static const char *jz4740_pwm3_groups[] = { "pwm3", };
207static const char *jz4740_pwm4_groups[] = { "pwm4", };
208static const char *jz4740_pwm5_groups[] = { "pwm5", };
209static const char *jz4740_pwm6_groups[] = { "pwm6", };
210static const char *jz4740_pwm7_groups[] = { "pwm7", };
211
212static const struct function_desc jz4740_functions[] = {
213 { "mmc", jz4740_mmc_groups, ARRAY_SIZE(jz4740_mmc_groups), },
214 { "uart0", jz4740_uart0_groups, ARRAY_SIZE(jz4740_uart0_groups), },
215 { "uart1", jz4740_uart1_groups, ARRAY_SIZE(jz4740_uart1_groups), },
216 { "lcd", jz4740_lcd_groups, ARRAY_SIZE(jz4740_lcd_groups), },
217 { "nand", jz4740_nand_groups, ARRAY_SIZE(jz4740_nand_groups), },
218 { "pwm0", jz4740_pwm0_groups, ARRAY_SIZE(jz4740_pwm0_groups), },
219 { "pwm1", jz4740_pwm1_groups, ARRAY_SIZE(jz4740_pwm1_groups), },
220 { "pwm2", jz4740_pwm2_groups, ARRAY_SIZE(jz4740_pwm2_groups), },
221 { "pwm3", jz4740_pwm3_groups, ARRAY_SIZE(jz4740_pwm3_groups), },
222 { "pwm4", jz4740_pwm4_groups, ARRAY_SIZE(jz4740_pwm4_groups), },
223 { "pwm5", jz4740_pwm5_groups, ARRAY_SIZE(jz4740_pwm5_groups), },
224 { "pwm6", jz4740_pwm6_groups, ARRAY_SIZE(jz4740_pwm6_groups), },
225 { "pwm7", jz4740_pwm7_groups, ARRAY_SIZE(jz4740_pwm7_groups), },
226};
227
228static const struct ingenic_chip_info jz4740_chip_info = {
229 .num_chips = 4,
周琰杰 (Zhou Yanjie)f742e5e2019-12-16 00:21:02 +0800230 .reg_offset = 0x100,
Paul Cercueilbaf15642020-01-07 00:27:08 +0100231 .version = ID_JZ4740,
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200232 .groups = jz4740_groups,
233 .num_groups = ARRAY_SIZE(jz4740_groups),
234 .functions = jz4740_functions,
235 .num_functions = ARRAY_SIZE(jz4740_functions),
236 .pull_ups = jz4740_pull_ups,
237 .pull_downs = jz4740_pull_downs,
238};
239
Paul Cercueilf2a96762018-08-21 18:42:34 +0200240static int jz4725b_mmc0_1bit_pins[] = { 0x48, 0x49, 0x5c, };
241static int jz4725b_mmc0_4bit_pins[] = { 0x5d, 0x5b, 0x56, };
242static int jz4725b_mmc1_1bit_pins[] = { 0x7a, 0x7b, 0x7c, };
243static int jz4725b_mmc1_4bit_pins[] = { 0x7d, 0x7e, 0x7f, };
244static int jz4725b_uart_data_pins[] = { 0x4c, 0x4d, };
245static int jz4725b_nand_cs1_pins[] = { 0x55, };
246static int jz4725b_nand_cs2_pins[] = { 0x56, };
247static int jz4725b_nand_cs3_pins[] = { 0x57, };
248static int jz4725b_nand_cs4_pins[] = { 0x58, };
249static int jz4725b_nand_cle_ale_pins[] = { 0x48, 0x49 };
250static int jz4725b_nand_fre_fwe_pins[] = { 0x5c, 0x5d };
251static int jz4725b_pwm_pwm0_pins[] = { 0x4a, };
252static int jz4725b_pwm_pwm1_pins[] = { 0x4b, };
253static int jz4725b_pwm_pwm2_pins[] = { 0x4c, };
254static int jz4725b_pwm_pwm3_pins[] = { 0x4d, };
255static int jz4725b_pwm_pwm4_pins[] = { 0x4e, };
256static int jz4725b_pwm_pwm5_pins[] = { 0x4f, };
Paul Cercueila3240f02019-02-07 10:55:36 -0300257static int jz4725b_lcd_8bit_pins[] = {
258 0x72, 0x73, 0x74,
259 0x60, 0x61, 0x62, 0x63,
260 0x64, 0x65, 0x66, 0x67,
261};
262static int jz4725b_lcd_16bit_pins[] = {
263 0x68, 0x69, 0x6a, 0x6b,
264 0x6c, 0x6d, 0x6e, 0x6f,
265};
266static int jz4725b_lcd_18bit_pins[] = { 0x70, 0x71, };
267static int jz4725b_lcd_24bit_pins[] = { 0x76, 0x77, 0x78, 0x79, };
268static int jz4725b_lcd_special_pins[] = { 0x76, 0x77, 0x78, 0x79, };
269static int jz4725b_lcd_generic_pins[] = { 0x75, };
Paul Cercueilf2a96762018-08-21 18:42:34 +0200270
271static int jz4725b_mmc0_1bit_funcs[] = { 1, 1, 1, };
272static int jz4725b_mmc0_4bit_funcs[] = { 1, 0, 1, };
273static int jz4725b_mmc1_1bit_funcs[] = { 0, 0, 0, };
274static int jz4725b_mmc1_4bit_funcs[] = { 0, 0, 0, };
275static int jz4725b_uart_data_funcs[] = { 1, 1, };
276static int jz4725b_nand_cs1_funcs[] = { 0, };
277static int jz4725b_nand_cs2_funcs[] = { 0, };
278static int jz4725b_nand_cs3_funcs[] = { 0, };
279static int jz4725b_nand_cs4_funcs[] = { 0, };
280static int jz4725b_nand_cle_ale_funcs[] = { 0, 0, };
281static int jz4725b_nand_fre_fwe_funcs[] = { 0, 0, };
282static int jz4725b_pwm_pwm0_funcs[] = { 0, };
283static int jz4725b_pwm_pwm1_funcs[] = { 0, };
284static int jz4725b_pwm_pwm2_funcs[] = { 0, };
285static int jz4725b_pwm_pwm3_funcs[] = { 0, };
286static int jz4725b_pwm_pwm4_funcs[] = { 0, };
287static int jz4725b_pwm_pwm5_funcs[] = { 0, };
Paul Cercueila3240f02019-02-07 10:55:36 -0300288static int jz4725b_lcd_8bit_funcs[] = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, };
289static int jz4725b_lcd_16bit_funcs[] = { 0, 0, 0, 0, 0, 0, 0, 0, };
290static int jz4725b_lcd_18bit_funcs[] = { 0, 0, };
291static int jz4725b_lcd_24bit_funcs[] = { 1, 1, 1, 1, };
292static int jz4725b_lcd_special_funcs[] = { 0, 0, 0, 0, };
293static int jz4725b_lcd_generic_funcs[] = { 0, };
Paul Cercueilf2a96762018-08-21 18:42:34 +0200294
295static const struct group_desc jz4725b_groups[] = {
296 INGENIC_PIN_GROUP("mmc0-1bit", jz4725b_mmc0_1bit),
297 INGENIC_PIN_GROUP("mmc0-4bit", jz4725b_mmc0_4bit),
298 INGENIC_PIN_GROUP("mmc1-1bit", jz4725b_mmc1_1bit),
299 INGENIC_PIN_GROUP("mmc1-4bit", jz4725b_mmc1_4bit),
300 INGENIC_PIN_GROUP("uart-data", jz4725b_uart_data),
301 INGENIC_PIN_GROUP("nand-cs1", jz4725b_nand_cs1),
302 INGENIC_PIN_GROUP("nand-cs2", jz4725b_nand_cs2),
303 INGENIC_PIN_GROUP("nand-cs3", jz4725b_nand_cs3),
304 INGENIC_PIN_GROUP("nand-cs4", jz4725b_nand_cs4),
305 INGENIC_PIN_GROUP("nand-cle-ale", jz4725b_nand_cle_ale),
306 INGENIC_PIN_GROUP("nand-fre-fwe", jz4725b_nand_fre_fwe),
307 INGENIC_PIN_GROUP("pwm0", jz4725b_pwm_pwm0),
308 INGENIC_PIN_GROUP("pwm1", jz4725b_pwm_pwm1),
309 INGENIC_PIN_GROUP("pwm2", jz4725b_pwm_pwm2),
310 INGENIC_PIN_GROUP("pwm3", jz4725b_pwm_pwm3),
311 INGENIC_PIN_GROUP("pwm4", jz4725b_pwm_pwm4),
312 INGENIC_PIN_GROUP("pwm5", jz4725b_pwm_pwm5),
Paul Cercueila3240f02019-02-07 10:55:36 -0300313 INGENIC_PIN_GROUP("lcd-8bit", jz4725b_lcd_8bit),
314 INGENIC_PIN_GROUP("lcd-16bit", jz4725b_lcd_16bit),
315 INGENIC_PIN_GROUP("lcd-18bit", jz4725b_lcd_18bit),
316 INGENIC_PIN_GROUP("lcd-24bit", jz4725b_lcd_24bit),
317 INGENIC_PIN_GROUP("lcd-special", jz4725b_lcd_special),
318 INGENIC_PIN_GROUP("lcd-generic", jz4725b_lcd_generic),
Paul Cercueilf2a96762018-08-21 18:42:34 +0200319};
320
321static const char *jz4725b_mmc0_groups[] = { "mmc0-1bit", "mmc0-4bit", };
322static const char *jz4725b_mmc1_groups[] = { "mmc1-1bit", "mmc1-4bit", };
323static const char *jz4725b_uart_groups[] = { "uart-data", };
324static const char *jz4725b_nand_groups[] = {
325 "nand-cs1", "nand-cs2", "nand-cs3", "nand-cs4",
326 "nand-cle-ale", "nand-fre-fwe",
327};
328static const char *jz4725b_pwm0_groups[] = { "pwm0", };
329static const char *jz4725b_pwm1_groups[] = { "pwm1", };
330static const char *jz4725b_pwm2_groups[] = { "pwm2", };
331static const char *jz4725b_pwm3_groups[] = { "pwm3", };
332static const char *jz4725b_pwm4_groups[] = { "pwm4", };
333static const char *jz4725b_pwm5_groups[] = { "pwm5", };
Paul Cercueila3240f02019-02-07 10:55:36 -0300334static const char *jz4725b_lcd_groups[] = {
335 "lcd-8bit", "lcd-16bit", "lcd-18bit", "lcd-24bit",
336 "lcd-special", "lcd-generic",
337};
Paul Cercueilf2a96762018-08-21 18:42:34 +0200338
339static const struct function_desc jz4725b_functions[] = {
340 { "mmc0", jz4725b_mmc0_groups, ARRAY_SIZE(jz4725b_mmc0_groups), },
341 { "mmc1", jz4725b_mmc1_groups, ARRAY_SIZE(jz4725b_mmc1_groups), },
342 { "uart", jz4725b_uart_groups, ARRAY_SIZE(jz4725b_uart_groups), },
343 { "nand", jz4725b_nand_groups, ARRAY_SIZE(jz4725b_nand_groups), },
344 { "pwm0", jz4725b_pwm0_groups, ARRAY_SIZE(jz4725b_pwm0_groups), },
345 { "pwm1", jz4725b_pwm1_groups, ARRAY_SIZE(jz4725b_pwm1_groups), },
346 { "pwm2", jz4725b_pwm2_groups, ARRAY_SIZE(jz4725b_pwm2_groups), },
347 { "pwm3", jz4725b_pwm3_groups, ARRAY_SIZE(jz4725b_pwm3_groups), },
348 { "pwm4", jz4725b_pwm4_groups, ARRAY_SIZE(jz4725b_pwm4_groups), },
349 { "pwm5", jz4725b_pwm5_groups, ARRAY_SIZE(jz4725b_pwm5_groups), },
Paul Cercueila3240f02019-02-07 10:55:36 -0300350 { "lcd", jz4725b_lcd_groups, ARRAY_SIZE(jz4725b_lcd_groups), },
Paul Cercueilf2a96762018-08-21 18:42:34 +0200351};
352
353static const struct ingenic_chip_info jz4725b_chip_info = {
354 .num_chips = 4,
周琰杰 (Zhou Yanjie)f742e5e2019-12-16 00:21:02 +0800355 .reg_offset = 0x100,
Paul Cercueilbaf15642020-01-07 00:27:08 +0100356 .version = ID_JZ4725B,
Paul Cercueilf2a96762018-08-21 18:42:34 +0200357 .groups = jz4725b_groups,
358 .num_groups = ARRAY_SIZE(jz4725b_groups),
359 .functions = jz4725b_functions,
360 .num_functions = ARRAY_SIZE(jz4725b_functions),
361 .pull_ups = jz4740_pull_ups,
362 .pull_downs = jz4740_pull_downs,
363};
364
Zhou Yanjie0257595a2019-07-14 11:53:52 +0800365static const u32 jz4760_pull_ups[6] = {
366 0xffffffff, 0xfffcf3ff, 0xffffffff, 0xffffcfff, 0xfffffb7c, 0xfffff00f,
367};
368
369static const u32 jz4760_pull_downs[6] = {
370 0x00000000, 0x00030c00, 0x00000000, 0x00003000, 0x00000483, 0x00000ff0,
371};
372
373static int jz4760_uart0_data_pins[] = { 0xa0, 0xa3, };
374static int jz4760_uart0_hwflow_pins[] = { 0xa1, 0xa2, };
375static int jz4760_uart1_data_pins[] = { 0x7a, 0x7c, };
376static int jz4760_uart1_hwflow_pins[] = { 0x7b, 0x7d, };
377static int jz4760_uart2_data_pins[] = { 0x5c, 0x5e, };
378static int jz4760_uart2_hwflow_pins[] = { 0x5d, 0x5f, };
379static int jz4760_uart3_data_pins[] = { 0x6c, 0x85, };
380static int jz4760_uart3_hwflow_pins[] = { 0x88, 0x89, };
381static int jz4760_mmc0_1bit_a_pins[] = { 0x12, 0x13, 0x14, };
382static int jz4760_mmc0_4bit_a_pins[] = { 0x15, 0x16, 0x17, };
383static int jz4760_mmc0_1bit_e_pins[] = { 0x9c, 0x9d, 0x94, };
384static int jz4760_mmc0_4bit_e_pins[] = { 0x95, 0x96, 0x97, };
385static int jz4760_mmc0_8bit_e_pins[] = { 0x98, 0x99, 0x9a, 0x9b, };
386static int jz4760_mmc1_1bit_d_pins[] = { 0x78, 0x79, 0x74, };
387static int jz4760_mmc1_4bit_d_pins[] = { 0x75, 0x76, 0x77, };
388static int jz4760_mmc1_1bit_e_pins[] = { 0x9c, 0x9d, 0x94, };
389static int jz4760_mmc1_4bit_e_pins[] = { 0x95, 0x96, 0x97, };
390static int jz4760_mmc1_8bit_e_pins[] = { 0x98, 0x99, 0x9a, 0x9b, };
391static int jz4760_mmc2_1bit_b_pins[] = { 0x3c, 0x3d, 0x34, };
392static int jz4760_mmc2_4bit_b_pins[] = { 0x35, 0x3e, 0x3f, };
393static int jz4760_mmc2_1bit_e_pins[] = { 0x9c, 0x9d, 0x94, };
394static int jz4760_mmc2_4bit_e_pins[] = { 0x95, 0x96, 0x97, };
395static int jz4760_mmc2_8bit_e_pins[] = { 0x98, 0x99, 0x9a, 0x9b, };
396static int jz4760_nemc_8bit_data_pins[] = {
397 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
398};
399static int jz4760_nemc_16bit_data_pins[] = {
400 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f,
401};
402static int jz4760_nemc_cle_ale_pins[] = { 0x20, 0x21, };
403static int jz4760_nemc_addr_pins[] = { 0x22, 0x23, 0x24, 0x25, };
404static int jz4760_nemc_rd_we_pins[] = { 0x10, 0x11, };
405static int jz4760_nemc_frd_fwe_pins[] = { 0x12, 0x13, };
406static int jz4760_nemc_wait_pins[] = { 0x1b, };
407static int jz4760_nemc_cs1_pins[] = { 0x15, };
408static int jz4760_nemc_cs2_pins[] = { 0x16, };
409static int jz4760_nemc_cs3_pins[] = { 0x17, };
410static int jz4760_nemc_cs4_pins[] = { 0x18, };
411static int jz4760_nemc_cs5_pins[] = { 0x19, };
412static int jz4760_nemc_cs6_pins[] = { 0x1a, };
413static int jz4760_i2c0_pins[] = { 0x7e, 0x7f, };
414static int jz4760_i2c1_pins[] = { 0x9e, 0x9f, };
415static int jz4760_cim_pins[] = {
416 0x26, 0x27, 0x28, 0x29,
417 0x2a, 0x2b, 0x2c, 0x2d, 0x2e, 0x2f, 0x30, 0x31,
418};
419static int jz4760_lcd_24bit_pins[] = {
420 0x40, 0x41, 0x42, 0x43, 0x44, 0x45, 0x46, 0x47,
421 0x48, 0x49, 0x4a, 0x4b, 0x4c, 0x4d, 0x4e, 0x4f,
422 0x50, 0x51, 0x52, 0x53, 0x54, 0x55, 0x56, 0x57,
423 0x58, 0x59, 0x5a, 0x5b,
424};
425static int jz4760_pwm_pwm0_pins[] = { 0x80, };
426static int jz4760_pwm_pwm1_pins[] = { 0x81, };
427static int jz4760_pwm_pwm2_pins[] = { 0x82, };
428static int jz4760_pwm_pwm3_pins[] = { 0x83, };
429static int jz4760_pwm_pwm4_pins[] = { 0x84, };
430static int jz4760_pwm_pwm5_pins[] = { 0x85, };
431static int jz4760_pwm_pwm6_pins[] = { 0x6a, };
432static int jz4760_pwm_pwm7_pins[] = { 0x6b, };
433
434static int jz4760_uart0_data_funcs[] = { 0, 0, };
435static int jz4760_uart0_hwflow_funcs[] = { 0, 0, };
436static int jz4760_uart1_data_funcs[] = { 0, 0, };
437static int jz4760_uart1_hwflow_funcs[] = { 0, 0, };
438static int jz4760_uart2_data_funcs[] = { 0, 0, };
439static int jz4760_uart2_hwflow_funcs[] = { 0, 0, };
440static int jz4760_uart3_data_funcs[] = { 0, 1, };
441static int jz4760_uart3_hwflow_funcs[] = { 0, 0, };
442static int jz4760_mmc0_1bit_a_funcs[] = { 1, 1, 0, };
443static int jz4760_mmc0_4bit_a_funcs[] = { 1, 1, 1, };
444static int jz4760_mmc0_1bit_e_funcs[] = { 0, 0, 0, };
445static int jz4760_mmc0_4bit_e_funcs[] = { 0, 0, 0, };
446static int jz4760_mmc0_8bit_e_funcs[] = { 0, 0, 0, 0, };
447static int jz4760_mmc1_1bit_d_funcs[] = { 0, 0, 0, };
448static int jz4760_mmc1_4bit_d_funcs[] = { 0, 0, 0, };
449static int jz4760_mmc1_1bit_e_funcs[] = { 1, 1, 1, };
450static int jz4760_mmc1_4bit_e_funcs[] = { 1, 1, 1, };
451static int jz4760_mmc1_8bit_e_funcs[] = { 1, 1, 1, 1, };
452static int jz4760_mmc2_1bit_b_funcs[] = { 0, 0, 0, };
453static int jz4760_mmc2_4bit_b_funcs[] = { 0, 0, 0, };
454static int jz4760_mmc2_1bit_e_funcs[] = { 2, 2, 2, };
455static int jz4760_mmc2_4bit_e_funcs[] = { 2, 2, 2, };
456static int jz4760_mmc2_8bit_e_funcs[] = { 2, 2, 2, 2, };
457static int jz4760_nemc_8bit_data_funcs[] = { 0, 0, 0, 0, 0, 0, 0, 0, };
458static int jz4760_nemc_16bit_data_funcs[] = { 0, 0, 0, 0, 0, 0, 0, 0, };
459static int jz4760_nemc_cle_ale_funcs[] = { 0, 0, };
460static int jz4760_nemc_addr_funcs[] = { 0, 0, 0, 0, };
461static int jz4760_nemc_rd_we_funcs[] = { 0, 0, };
462static int jz4760_nemc_frd_fwe_funcs[] = { 0, 0, };
463static int jz4760_nemc_wait_funcs[] = { 0, };
464static int jz4760_nemc_cs1_funcs[] = { 0, };
465static int jz4760_nemc_cs2_funcs[] = { 0, };
466static int jz4760_nemc_cs3_funcs[] = { 0, };
467static int jz4760_nemc_cs4_funcs[] = { 0, };
468static int jz4760_nemc_cs5_funcs[] = { 0, };
469static int jz4760_nemc_cs6_funcs[] = { 0, };
470static int jz4760_i2c0_funcs[] = { 0, 0, };
471static int jz4760_i2c1_funcs[] = { 0, 0, };
472static int jz4760_cim_funcs[] = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, };
473static int jz4760_lcd_24bit_funcs[] = {
474 0, 0, 0, 0, 0, 0, 0, 0,
475 0, 0, 0, 0, 0, 0, 0, 0,
476 0, 0, 0, 0, 0, 0, 0, 0,
477 0, 0, 0, 0,
478};
479static int jz4760_pwm_pwm0_funcs[] = { 0, };
480static int jz4760_pwm_pwm1_funcs[] = { 0, };
481static int jz4760_pwm_pwm2_funcs[] = { 0, };
482static int jz4760_pwm_pwm3_funcs[] = { 0, };
483static int jz4760_pwm_pwm4_funcs[] = { 0, };
484static int jz4760_pwm_pwm5_funcs[] = { 0, };
485static int jz4760_pwm_pwm6_funcs[] = { 0, };
486static int jz4760_pwm_pwm7_funcs[] = { 0, };
487
488static const struct group_desc jz4760_groups[] = {
489 INGENIC_PIN_GROUP("uart0-data", jz4760_uart0_data),
490 INGENIC_PIN_GROUP("uart0-hwflow", jz4760_uart0_hwflow),
491 INGENIC_PIN_GROUP("uart1-data", jz4760_uart1_data),
492 INGENIC_PIN_GROUP("uart1-hwflow", jz4760_uart1_hwflow),
493 INGENIC_PIN_GROUP("uart2-data", jz4760_uart2_data),
494 INGENIC_PIN_GROUP("uart2-hwflow", jz4760_uart2_hwflow),
495 INGENIC_PIN_GROUP("uart3-data", jz4760_uart3_data),
496 INGENIC_PIN_GROUP("uart3-hwflow", jz4760_uart3_hwflow),
497 INGENIC_PIN_GROUP("mmc0-1bit-a", jz4760_mmc0_1bit_a),
498 INGENIC_PIN_GROUP("mmc0-4bit-a", jz4760_mmc0_4bit_a),
499 INGENIC_PIN_GROUP("mmc0-1bit-e", jz4760_mmc0_1bit_e),
500 INGENIC_PIN_GROUP("mmc0-4bit-e", jz4760_mmc0_4bit_e),
501 INGENIC_PIN_GROUP("mmc0-8bit-e", jz4760_mmc0_8bit_e),
502 INGENIC_PIN_GROUP("mmc1-1bit-d", jz4760_mmc1_1bit_d),
503 INGENIC_PIN_GROUP("mmc1-4bit-d", jz4760_mmc1_4bit_d),
504 INGENIC_PIN_GROUP("mmc1-1bit-e", jz4760_mmc1_1bit_e),
505 INGENIC_PIN_GROUP("mmc1-4bit-e", jz4760_mmc1_4bit_e),
506 INGENIC_PIN_GROUP("mmc1-8bit-e", jz4760_mmc1_8bit_e),
507 INGENIC_PIN_GROUP("mmc2-1bit-b", jz4760_mmc2_1bit_b),
508 INGENIC_PIN_GROUP("mmc2-4bit-b", jz4760_mmc2_4bit_b),
509 INGENIC_PIN_GROUP("mmc2-1bit-e", jz4760_mmc2_1bit_e),
510 INGENIC_PIN_GROUP("mmc2-4bit-e", jz4760_mmc2_4bit_e),
511 INGENIC_PIN_GROUP("mmc2-8bit-e", jz4760_mmc2_8bit_e),
512 INGENIC_PIN_GROUP("nemc-8bit-data", jz4760_nemc_8bit_data),
513 INGENIC_PIN_GROUP("nemc-16bit-data", jz4760_nemc_16bit_data),
514 INGENIC_PIN_GROUP("nemc-cle-ale", jz4760_nemc_cle_ale),
515 INGENIC_PIN_GROUP("nemc-addr", jz4760_nemc_addr),
516 INGENIC_PIN_GROUP("nemc-rd-we", jz4760_nemc_rd_we),
517 INGENIC_PIN_GROUP("nemc-frd-fwe", jz4760_nemc_frd_fwe),
518 INGENIC_PIN_GROUP("nemc-wait", jz4760_nemc_wait),
519 INGENIC_PIN_GROUP("nemc-cs1", jz4760_nemc_cs1),
520 INGENIC_PIN_GROUP("nemc-cs2", jz4760_nemc_cs2),
521 INGENIC_PIN_GROUP("nemc-cs3", jz4760_nemc_cs3),
522 INGENIC_PIN_GROUP("nemc-cs4", jz4760_nemc_cs4),
523 INGENIC_PIN_GROUP("nemc-cs5", jz4760_nemc_cs5),
524 INGENIC_PIN_GROUP("nemc-cs6", jz4760_nemc_cs6),
525 INGENIC_PIN_GROUP("i2c0-data", jz4760_i2c0),
526 INGENIC_PIN_GROUP("i2c1-data", jz4760_i2c1),
527 INGENIC_PIN_GROUP("cim-data", jz4760_cim),
528 INGENIC_PIN_GROUP("lcd-24bit", jz4760_lcd_24bit),
529 { "lcd-no-pins", },
530 INGENIC_PIN_GROUP("pwm0", jz4760_pwm_pwm0),
531 INGENIC_PIN_GROUP("pwm1", jz4760_pwm_pwm1),
532 INGENIC_PIN_GROUP("pwm2", jz4760_pwm_pwm2),
533 INGENIC_PIN_GROUP("pwm3", jz4760_pwm_pwm3),
534 INGENIC_PIN_GROUP("pwm4", jz4760_pwm_pwm4),
535 INGENIC_PIN_GROUP("pwm5", jz4760_pwm_pwm5),
536 INGENIC_PIN_GROUP("pwm6", jz4760_pwm_pwm6),
537 INGENIC_PIN_GROUP("pwm7", jz4760_pwm_pwm7),
538};
539
540static const char *jz4760_uart0_groups[] = { "uart0-data", "uart0-hwflow", };
541static const char *jz4760_uart1_groups[] = { "uart1-data", "uart1-hwflow", };
542static const char *jz4760_uart2_groups[] = { "uart2-data", "uart2-hwflow", };
543static const char *jz4760_uart3_groups[] = { "uart3-data", "uart3-hwflow", };
544static const char *jz4760_mmc0_groups[] = {
545 "mmc0-1bit-a", "mmc0-4bit-a",
546 "mmc0-1bit-e", "mmc0-4bit-e", "mmc0-8bit-e",
547};
548static const char *jz4760_mmc1_groups[] = {
549 "mmc1-1bit-d", "mmc1-4bit-d",
550 "mmc1-1bit-e", "mmc1-4bit-e", "mmc1-8bit-e",
551};
552static const char *jz4760_mmc2_groups[] = {
553 "mmc2-1bit-b", "mmc2-4bit-b",
554 "mmc2-1bit-e", "mmc2-4bit-e", "mmc2-8bit-e",
555};
556static const char *jz4760_nemc_groups[] = {
557 "nemc-8bit-data", "nemc-16bit-data", "nemc-cle-ale",
558 "nemc-addr", "nemc-rd-we", "nemc-frd-fwe", "nemc-wait",
559};
560static const char *jz4760_cs1_groups[] = { "nemc-cs1", };
561static const char *jz4760_cs2_groups[] = { "nemc-cs2", };
562static const char *jz4760_cs3_groups[] = { "nemc-cs3", };
563static const char *jz4760_cs4_groups[] = { "nemc-cs4", };
564static const char *jz4760_cs5_groups[] = { "nemc-cs5", };
565static const char *jz4760_cs6_groups[] = { "nemc-cs6", };
566static const char *jz4760_i2c0_groups[] = { "i2c0-data", };
567static const char *jz4760_i2c1_groups[] = { "i2c1-data", };
568static const char *jz4760_cim_groups[] = { "cim-data", };
569static const char *jz4760_lcd_groups[] = { "lcd-24bit", "lcd-no-pins", };
570static const char *jz4760_pwm0_groups[] = { "pwm0", };
571static const char *jz4760_pwm1_groups[] = { "pwm1", };
572static const char *jz4760_pwm2_groups[] = { "pwm2", };
573static const char *jz4760_pwm3_groups[] = { "pwm3", };
574static const char *jz4760_pwm4_groups[] = { "pwm4", };
575static const char *jz4760_pwm5_groups[] = { "pwm5", };
576static const char *jz4760_pwm6_groups[] = { "pwm6", };
577static const char *jz4760_pwm7_groups[] = { "pwm7", };
578
579static const struct function_desc jz4760_functions[] = {
580 { "uart0", jz4760_uart0_groups, ARRAY_SIZE(jz4760_uart0_groups), },
581 { "uart1", jz4760_uart1_groups, ARRAY_SIZE(jz4760_uart1_groups), },
582 { "uart2", jz4760_uart2_groups, ARRAY_SIZE(jz4760_uart2_groups), },
583 { "uart3", jz4760_uart3_groups, ARRAY_SIZE(jz4760_uart3_groups), },
584 { "mmc0", jz4760_mmc0_groups, ARRAY_SIZE(jz4760_mmc0_groups), },
585 { "mmc1", jz4760_mmc1_groups, ARRAY_SIZE(jz4760_mmc1_groups), },
586 { "mmc2", jz4760_mmc2_groups, ARRAY_SIZE(jz4760_mmc2_groups), },
587 { "nemc", jz4760_nemc_groups, ARRAY_SIZE(jz4760_nemc_groups), },
588 { "nemc-cs1", jz4760_cs1_groups, ARRAY_SIZE(jz4760_cs1_groups), },
589 { "nemc-cs2", jz4760_cs2_groups, ARRAY_SIZE(jz4760_cs2_groups), },
590 { "nemc-cs3", jz4760_cs3_groups, ARRAY_SIZE(jz4760_cs3_groups), },
591 { "nemc-cs4", jz4760_cs4_groups, ARRAY_SIZE(jz4760_cs4_groups), },
592 { "nemc-cs5", jz4760_cs5_groups, ARRAY_SIZE(jz4760_cs5_groups), },
593 { "nemc-cs6", jz4760_cs6_groups, ARRAY_SIZE(jz4760_cs6_groups), },
594 { "i2c0", jz4760_i2c0_groups, ARRAY_SIZE(jz4760_i2c0_groups), },
595 { "i2c1", jz4760_i2c1_groups, ARRAY_SIZE(jz4760_i2c1_groups), },
596 { "cim", jz4760_cim_groups, ARRAY_SIZE(jz4760_cim_groups), },
597 { "lcd", jz4760_lcd_groups, ARRAY_SIZE(jz4760_lcd_groups), },
598 { "pwm0", jz4760_pwm0_groups, ARRAY_SIZE(jz4760_pwm0_groups), },
599 { "pwm1", jz4760_pwm1_groups, ARRAY_SIZE(jz4760_pwm1_groups), },
600 { "pwm2", jz4760_pwm2_groups, ARRAY_SIZE(jz4760_pwm2_groups), },
601 { "pwm3", jz4760_pwm3_groups, ARRAY_SIZE(jz4760_pwm3_groups), },
602 { "pwm4", jz4760_pwm4_groups, ARRAY_SIZE(jz4760_pwm4_groups), },
603 { "pwm5", jz4760_pwm5_groups, ARRAY_SIZE(jz4760_pwm5_groups), },
604 { "pwm6", jz4760_pwm6_groups, ARRAY_SIZE(jz4760_pwm6_groups), },
605 { "pwm7", jz4760_pwm7_groups, ARRAY_SIZE(jz4760_pwm7_groups), },
606};
607
608static const struct ingenic_chip_info jz4760_chip_info = {
609 .num_chips = 6,
周琰杰 (Zhou Yanjie)f742e5e2019-12-16 00:21:02 +0800610 .reg_offset = 0x100,
Paul Cercueilbaf15642020-01-07 00:27:08 +0100611 .version = ID_JZ4760,
Zhou Yanjie0257595a2019-07-14 11:53:52 +0800612 .groups = jz4760_groups,
613 .num_groups = ARRAY_SIZE(jz4760_groups),
614 .functions = jz4760_functions,
615 .num_functions = ARRAY_SIZE(jz4760_functions),
616 .pull_ups = jz4760_pull_ups,
617 .pull_downs = jz4760_pull_downs,
618};
619
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200620static const u32 jz4770_pull_ups[6] = {
621 0x3fffffff, 0xfff0030c, 0xffffffff, 0xffff4fff, 0xfffffb7c, 0xffa7f00f,
622};
623
624static const u32 jz4770_pull_downs[6] = {
625 0x00000000, 0x000f0c03, 0x00000000, 0x0000b000, 0x00000483, 0x00580ff0,
626};
627
628static int jz4770_uart0_data_pins[] = { 0xa0, 0xa3, };
629static int jz4770_uart0_hwflow_pins[] = { 0xa1, 0xa2, };
630static int jz4770_uart1_data_pins[] = { 0x7a, 0x7c, };
631static int jz4770_uart1_hwflow_pins[] = { 0x7b, 0x7d, };
Zhou Yanjieff656e42019-01-28 23:19:57 +0800632static int jz4770_uart2_data_pins[] = { 0x5c, 0x5e, };
633static int jz4770_uart2_hwflow_pins[] = { 0x5d, 0x5f, };
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200634static int jz4770_uart3_data_pins[] = { 0x6c, 0x85, };
635static int jz4770_uart3_hwflow_pins[] = { 0x88, 0x89, };
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200636static int jz4770_mmc0_1bit_a_pins[] = { 0x12, 0x13, 0x14, };
Zhou Yanjieff656e42019-01-28 23:19:57 +0800637static int jz4770_mmc0_4bit_a_pins[] = { 0x15, 0x16, 0x17, };
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200638static int jz4770_mmc0_1bit_e_pins[] = { 0x9c, 0x9d, 0x94, };
Zhou Yanjieff656e42019-01-28 23:19:57 +0800639static int jz4770_mmc0_4bit_e_pins[] = { 0x95, 0x96, 0x97, };
640static int jz4770_mmc0_8bit_e_pins[] = { 0x98, 0x99, 0x9a, 0x9b, };
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200641static int jz4770_mmc1_1bit_d_pins[] = { 0x78, 0x79, 0x74, };
Zhou Yanjieff656e42019-01-28 23:19:57 +0800642static int jz4770_mmc1_4bit_d_pins[] = { 0x75, 0x76, 0x77, };
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200643static int jz4770_mmc1_1bit_e_pins[] = { 0x9c, 0x9d, 0x94, };
Zhou Yanjieff656e42019-01-28 23:19:57 +0800644static int jz4770_mmc1_4bit_e_pins[] = { 0x95, 0x96, 0x97, };
645static int jz4770_mmc1_8bit_e_pins[] = { 0x98, 0x99, 0x9a, 0x9b, };
Zhou Yanjie5de1a732019-01-28 23:19:58 +0800646static int jz4770_mmc2_1bit_b_pins[] = { 0x3c, 0x3d, 0x34, };
647static int jz4770_mmc2_4bit_b_pins[] = { 0x35, 0x3e, 0x3f, };
648static int jz4770_mmc2_1bit_e_pins[] = { 0x9c, 0x9d, 0x94, };
649static int jz4770_mmc2_4bit_e_pins[] = { 0x95, 0x96, 0x97, };
650static int jz4770_mmc2_8bit_e_pins[] = { 0x98, 0x99, 0x9a, 0x9b, };
Zhou Yanjieff656e42019-01-28 23:19:57 +0800651static int jz4770_nemc_8bit_data_pins[] = {
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200652 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
653};
Zhou Yanjieff656e42019-01-28 23:19:57 +0800654static int jz4770_nemc_16bit_data_pins[] = {
655 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f,
656};
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200657static int jz4770_nemc_cle_ale_pins[] = { 0x20, 0x21, };
658static int jz4770_nemc_addr_pins[] = { 0x22, 0x23, 0x24, 0x25, };
659static int jz4770_nemc_rd_we_pins[] = { 0x10, 0x11, };
660static int jz4770_nemc_frd_fwe_pins[] = { 0x12, 0x13, };
Zhou Yanjie5de1a732019-01-28 23:19:58 +0800661static int jz4770_nemc_wait_pins[] = { 0x1b, };
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200662static int jz4770_nemc_cs1_pins[] = { 0x15, };
663static int jz4770_nemc_cs2_pins[] = { 0x16, };
664static int jz4770_nemc_cs3_pins[] = { 0x17, };
665static int jz4770_nemc_cs4_pins[] = { 0x18, };
666static int jz4770_nemc_cs5_pins[] = { 0x19, };
667static int jz4770_nemc_cs6_pins[] = { 0x1a, };
Zhou Yanjieff656e42019-01-28 23:19:57 +0800668static int jz4770_i2c0_pins[] = { 0x7e, 0x7f, };
669static int jz4770_i2c1_pins[] = { 0x9e, 0x9f, };
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200670static int jz4770_i2c2_pins[] = { 0xb0, 0xb1, };
Zhou Yanjieff656e42019-01-28 23:19:57 +0800671static int jz4770_cim_8bit_pins[] = {
672 0x26, 0x27, 0x28, 0x29,
673 0x2a, 0x2b, 0x2c, 0x2d, 0x2e, 0x2f, 0x30, 0x31,
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200674};
Zhou Yanjieff656e42019-01-28 23:19:57 +0800675static int jz4770_cim_12bit_pins[] = {
676 0x32, 0x33, 0xb0, 0xb1,
677};
678static int jz4770_lcd_24bit_pins[] = {
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200679 0x40, 0x41, 0x42, 0x43, 0x44, 0x45, 0x46, 0x47,
680 0x48, 0x49, 0x4a, 0x4b, 0x4c, 0x4d, 0x4e, 0x4f,
681 0x50, 0x51, 0x52, 0x53, 0x54, 0x55, 0x56, 0x57,
Zhou Yanjieff656e42019-01-28 23:19:57 +0800682 0x58, 0x59, 0x5a, 0x5b,
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200683};
684static int jz4770_pwm_pwm0_pins[] = { 0x80, };
685static int jz4770_pwm_pwm1_pins[] = { 0x81, };
686static int jz4770_pwm_pwm2_pins[] = { 0x82, };
687static int jz4770_pwm_pwm3_pins[] = { 0x83, };
688static int jz4770_pwm_pwm4_pins[] = { 0x84, };
689static int jz4770_pwm_pwm5_pins[] = { 0x85, };
690static int jz4770_pwm_pwm6_pins[] = { 0x6a, };
691static int jz4770_pwm_pwm7_pins[] = { 0x6b, };
Zhou Yanjie5de1a732019-01-28 23:19:58 +0800692static int jz4770_mac_rmii_pins[] = {
693 0xa9, 0xab, 0xaa, 0xac, 0xa5, 0xa4, 0xad, 0xae, 0xa6, 0xa8,
694};
695static int jz4770_mac_mii_pins[] = { 0xa7, 0xaf, };
Paul Cercueilae75b532019-11-19 16:52:11 +0100696static int jz4770_otg_pins[] = { 0x8a, };
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200697
698static int jz4770_uart0_data_funcs[] = { 0, 0, };
699static int jz4770_uart0_hwflow_funcs[] = { 0, 0, };
700static int jz4770_uart1_data_funcs[] = { 0, 0, };
701static int jz4770_uart1_hwflow_funcs[] = { 0, 0, };
Zhou Yanjieff656e42019-01-28 23:19:57 +0800702static int jz4770_uart2_data_funcs[] = { 0, 0, };
703static int jz4770_uart2_hwflow_funcs[] = { 0, 0, };
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200704static int jz4770_uart3_data_funcs[] = { 0, 1, };
705static int jz4770_uart3_hwflow_funcs[] = { 0, 0, };
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200706static int jz4770_mmc0_1bit_a_funcs[] = { 1, 1, 0, };
Zhou Yanjieff656e42019-01-28 23:19:57 +0800707static int jz4770_mmc0_4bit_a_funcs[] = { 1, 1, 1, };
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200708static int jz4770_mmc0_1bit_e_funcs[] = { 0, 0, 0, };
Zhou Yanjieff656e42019-01-28 23:19:57 +0800709static int jz4770_mmc0_4bit_e_funcs[] = { 0, 0, 0, };
710static int jz4770_mmc0_8bit_e_funcs[] = { 0, 0, 0, 0, };
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200711static int jz4770_mmc1_1bit_d_funcs[] = { 0, 0, 0, };
Zhou Yanjieff656e42019-01-28 23:19:57 +0800712static int jz4770_mmc1_4bit_d_funcs[] = { 0, 0, 0, };
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200713static int jz4770_mmc1_1bit_e_funcs[] = { 1, 1, 1, };
Zhou Yanjieff656e42019-01-28 23:19:57 +0800714static int jz4770_mmc1_4bit_e_funcs[] = { 1, 1, 1, };
715static int jz4770_mmc1_8bit_e_funcs[] = { 1, 1, 1, 1, };
Zhou Yanjie5de1a732019-01-28 23:19:58 +0800716static int jz4770_mmc2_1bit_b_funcs[] = { 0, 0, 0, };
717static int jz4770_mmc2_4bit_b_funcs[] = { 0, 0, 0, };
718static int jz4770_mmc2_1bit_e_funcs[] = { 2, 2, 2, };
719static int jz4770_mmc2_4bit_e_funcs[] = { 2, 2, 2, };
720static int jz4770_mmc2_8bit_e_funcs[] = { 2, 2, 2, 2, };
Zhou Yanjieff656e42019-01-28 23:19:57 +0800721static int jz4770_nemc_8bit_data_funcs[] = { 0, 0, 0, 0, 0, 0, 0, 0, };
722static int jz4770_nemc_16bit_data_funcs[] = { 0, 0, 0, 0, 0, 0, 0, 0, };
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200723static int jz4770_nemc_cle_ale_funcs[] = { 0, 0, };
724static int jz4770_nemc_addr_funcs[] = { 0, 0, 0, 0, };
725static int jz4770_nemc_rd_we_funcs[] = { 0, 0, };
726static int jz4770_nemc_frd_fwe_funcs[] = { 0, 0, };
Zhou Yanjie5de1a732019-01-28 23:19:58 +0800727static int jz4770_nemc_wait_funcs[] = { 0, };
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200728static int jz4770_nemc_cs1_funcs[] = { 0, };
729static int jz4770_nemc_cs2_funcs[] = { 0, };
730static int jz4770_nemc_cs3_funcs[] = { 0, };
731static int jz4770_nemc_cs4_funcs[] = { 0, };
732static int jz4770_nemc_cs5_funcs[] = { 0, };
733static int jz4770_nemc_cs6_funcs[] = { 0, };
734static int jz4770_i2c0_funcs[] = { 0, 0, };
735static int jz4770_i2c1_funcs[] = { 0, 0, };
736static int jz4770_i2c2_funcs[] = { 2, 2, };
Zhou Yanjieff656e42019-01-28 23:19:57 +0800737static int jz4770_cim_8bit_funcs[] = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, };
738static int jz4770_cim_12bit_funcs[] = { 0, 0, 0, 0, };
739static int jz4770_lcd_24bit_funcs[] = {
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200740 0, 0, 0, 0, 0, 0, 0, 0,
741 0, 0, 0, 0, 0, 0, 0, 0,
Zhou Yanjieff656e42019-01-28 23:19:57 +0800742 0, 0, 0, 0, 0, 0, 0, 0,
743 0, 0, 0, 0,
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200744};
745static int jz4770_pwm_pwm0_funcs[] = { 0, };
746static int jz4770_pwm_pwm1_funcs[] = { 0, };
747static int jz4770_pwm_pwm2_funcs[] = { 0, };
748static int jz4770_pwm_pwm3_funcs[] = { 0, };
749static int jz4770_pwm_pwm4_funcs[] = { 0, };
750static int jz4770_pwm_pwm5_funcs[] = { 0, };
751static int jz4770_pwm_pwm6_funcs[] = { 0, };
752static int jz4770_pwm_pwm7_funcs[] = { 0, };
Zhou Yanjie5de1a732019-01-28 23:19:58 +0800753static int jz4770_mac_rmii_funcs[] = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, };
754static int jz4770_mac_mii_funcs[] = { 0, 0, };
Paul Cercueilae75b532019-11-19 16:52:11 +0100755static int jz4770_otg_funcs[] = { 0, };
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200756
757static const struct group_desc jz4770_groups[] = {
758 INGENIC_PIN_GROUP("uart0-data", jz4770_uart0_data),
759 INGENIC_PIN_GROUP("uart0-hwflow", jz4770_uart0_hwflow),
760 INGENIC_PIN_GROUP("uart1-data", jz4770_uart1_data),
761 INGENIC_PIN_GROUP("uart1-hwflow", jz4770_uart1_hwflow),
762 INGENIC_PIN_GROUP("uart2-data", jz4770_uart2_data),
763 INGENIC_PIN_GROUP("uart2-hwflow", jz4770_uart2_hwflow),
764 INGENIC_PIN_GROUP("uart3-data", jz4770_uart3_data),
765 INGENIC_PIN_GROUP("uart3-hwflow", jz4770_uart3_hwflow),
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200766 INGENIC_PIN_GROUP("mmc0-1bit-a", jz4770_mmc0_1bit_a),
Zhou Yanjieff656e42019-01-28 23:19:57 +0800767 INGENIC_PIN_GROUP("mmc0-4bit-a", jz4770_mmc0_4bit_a),
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200768 INGENIC_PIN_GROUP("mmc0-1bit-e", jz4770_mmc0_1bit_e),
Zhou Yanjieff656e42019-01-28 23:19:57 +0800769 INGENIC_PIN_GROUP("mmc0-4bit-e", jz4770_mmc0_4bit_e),
770 INGENIC_PIN_GROUP("mmc0-8bit-e", jz4770_mmc0_8bit_e),
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200771 INGENIC_PIN_GROUP("mmc1-1bit-d", jz4770_mmc1_1bit_d),
Zhou Yanjieff656e42019-01-28 23:19:57 +0800772 INGENIC_PIN_GROUP("mmc1-4bit-d", jz4770_mmc1_4bit_d),
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200773 INGENIC_PIN_GROUP("mmc1-1bit-e", jz4770_mmc1_1bit_e),
Zhou Yanjieff656e42019-01-28 23:19:57 +0800774 INGENIC_PIN_GROUP("mmc1-4bit-e", jz4770_mmc1_4bit_e),
775 INGENIC_PIN_GROUP("mmc1-8bit-e", jz4770_mmc1_8bit_e),
Zhou Yanjie5de1a732019-01-28 23:19:58 +0800776 INGENIC_PIN_GROUP("mmc2-1bit-b", jz4770_mmc2_1bit_b),
777 INGENIC_PIN_GROUP("mmc2-4bit-b", jz4770_mmc2_4bit_b),
778 INGENIC_PIN_GROUP("mmc2-1bit-e", jz4770_mmc2_1bit_e),
779 INGENIC_PIN_GROUP("mmc2-4bit-e", jz4770_mmc2_4bit_e),
780 INGENIC_PIN_GROUP("mmc2-8bit-e", jz4770_mmc2_8bit_e),
Zhou Yanjieff656e42019-01-28 23:19:57 +0800781 INGENIC_PIN_GROUP("nemc-8bit-data", jz4770_nemc_8bit_data),
782 INGENIC_PIN_GROUP("nemc-16bit-data", jz4770_nemc_16bit_data),
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200783 INGENIC_PIN_GROUP("nemc-cle-ale", jz4770_nemc_cle_ale),
784 INGENIC_PIN_GROUP("nemc-addr", jz4770_nemc_addr),
785 INGENIC_PIN_GROUP("nemc-rd-we", jz4770_nemc_rd_we),
786 INGENIC_PIN_GROUP("nemc-frd-fwe", jz4770_nemc_frd_fwe),
Zhou Yanjie5de1a732019-01-28 23:19:58 +0800787 INGENIC_PIN_GROUP("nemc-wait", jz4770_nemc_wait),
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200788 INGENIC_PIN_GROUP("nemc-cs1", jz4770_nemc_cs1),
789 INGENIC_PIN_GROUP("nemc-cs2", jz4770_nemc_cs2),
790 INGENIC_PIN_GROUP("nemc-cs3", jz4770_nemc_cs3),
791 INGENIC_PIN_GROUP("nemc-cs4", jz4770_nemc_cs4),
792 INGENIC_PIN_GROUP("nemc-cs5", jz4770_nemc_cs5),
793 INGENIC_PIN_GROUP("nemc-cs6", jz4770_nemc_cs6),
794 INGENIC_PIN_GROUP("i2c0-data", jz4770_i2c0),
795 INGENIC_PIN_GROUP("i2c1-data", jz4770_i2c1),
796 INGENIC_PIN_GROUP("i2c2-data", jz4770_i2c2),
Zhou Yanjieff656e42019-01-28 23:19:57 +0800797 INGENIC_PIN_GROUP("cim-data-8bit", jz4770_cim_8bit),
798 INGENIC_PIN_GROUP("cim-data-12bit", jz4770_cim_12bit),
799 INGENIC_PIN_GROUP("lcd-24bit", jz4770_lcd_24bit),
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200800 { "lcd-no-pins", },
801 INGENIC_PIN_GROUP("pwm0", jz4770_pwm_pwm0),
802 INGENIC_PIN_GROUP("pwm1", jz4770_pwm_pwm1),
803 INGENIC_PIN_GROUP("pwm2", jz4770_pwm_pwm2),
804 INGENIC_PIN_GROUP("pwm3", jz4770_pwm_pwm3),
805 INGENIC_PIN_GROUP("pwm4", jz4770_pwm_pwm4),
806 INGENIC_PIN_GROUP("pwm5", jz4770_pwm_pwm5),
807 INGENIC_PIN_GROUP("pwm6", jz4770_pwm_pwm6),
808 INGENIC_PIN_GROUP("pwm7", jz4770_pwm_pwm7),
Zhou Yanjie5de1a732019-01-28 23:19:58 +0800809 INGENIC_PIN_GROUP("mac-rmii", jz4770_mac_rmii),
810 INGENIC_PIN_GROUP("mac-mii", jz4770_mac_mii),
Paul Cercueilae75b532019-11-19 16:52:11 +0100811 INGENIC_PIN_GROUP("otg-vbus", jz4770_otg),
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200812};
813
814static const char *jz4770_uart0_groups[] = { "uart0-data", "uart0-hwflow", };
815static const char *jz4770_uart1_groups[] = { "uart1-data", "uart1-hwflow", };
816static const char *jz4770_uart2_groups[] = { "uart2-data", "uart2-hwflow", };
817static const char *jz4770_uart3_groups[] = { "uart3-data", "uart3-hwflow", };
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200818static const char *jz4770_mmc0_groups[] = {
Zhou Yanjieff656e42019-01-28 23:19:57 +0800819 "mmc0-1bit-a", "mmc0-4bit-a",
820 "mmc0-1bit-e", "mmc0-4bit-e", "mmc0-8bit-e",
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200821};
822static const char *jz4770_mmc1_groups[] = {
Zhou Yanjieff656e42019-01-28 23:19:57 +0800823 "mmc1-1bit-d", "mmc1-4bit-d",
824 "mmc1-1bit-e", "mmc1-4bit-e", "mmc1-8bit-e",
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200825};
Zhou Yanjie5de1a732019-01-28 23:19:58 +0800826static const char *jz4770_mmc2_groups[] = {
827 "mmc2-1bit-b", "mmc2-4bit-b",
828 "mmc2-1bit-e", "mmc2-4bit-e", "mmc2-8bit-e",
829};
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200830static const char *jz4770_nemc_groups[] = {
Zhou Yanjieff656e42019-01-28 23:19:57 +0800831 "nemc-8bit-data", "nemc-16bit-data", "nemc-cle-ale",
Zhou Yanjie5de1a732019-01-28 23:19:58 +0800832 "nemc-addr", "nemc-rd-we", "nemc-frd-fwe", "nemc-wait",
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200833};
834static const char *jz4770_cs1_groups[] = { "nemc-cs1", };
Zhou Yanjieff656e42019-01-28 23:19:57 +0800835static const char *jz4770_cs2_groups[] = { "nemc-cs2", };
836static const char *jz4770_cs3_groups[] = { "nemc-cs3", };
837static const char *jz4770_cs4_groups[] = { "nemc-cs4", };
838static const char *jz4770_cs5_groups[] = { "nemc-cs5", };
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200839static const char *jz4770_cs6_groups[] = { "nemc-cs6", };
840static const char *jz4770_i2c0_groups[] = { "i2c0-data", };
841static const char *jz4770_i2c1_groups[] = { "i2c1-data", };
842static const char *jz4770_i2c2_groups[] = { "i2c2-data", };
Zhou Yanjieff656e42019-01-28 23:19:57 +0800843static const char *jz4770_cim_groups[] = { "cim-data-8bit", "cim-data-12bit", };
844static const char *jz4770_lcd_groups[] = { "lcd-24bit", "lcd-no-pins", };
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200845static const char *jz4770_pwm0_groups[] = { "pwm0", };
846static const char *jz4770_pwm1_groups[] = { "pwm1", };
847static const char *jz4770_pwm2_groups[] = { "pwm2", };
848static const char *jz4770_pwm3_groups[] = { "pwm3", };
849static const char *jz4770_pwm4_groups[] = { "pwm4", };
850static const char *jz4770_pwm5_groups[] = { "pwm5", };
851static const char *jz4770_pwm6_groups[] = { "pwm6", };
852static const char *jz4770_pwm7_groups[] = { "pwm7", };
Zhou Yanjie5de1a732019-01-28 23:19:58 +0800853static const char *jz4770_mac_groups[] = { "mac-rmii", "mac-mii", };
Paul Cercueilae75b532019-11-19 16:52:11 +0100854static const char *jz4770_otg_groups[] = { "otg-vbus", };
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200855
856static const struct function_desc jz4770_functions[] = {
857 { "uart0", jz4770_uart0_groups, ARRAY_SIZE(jz4770_uart0_groups), },
858 { "uart1", jz4770_uart1_groups, ARRAY_SIZE(jz4770_uart1_groups), },
859 { "uart2", jz4770_uart2_groups, ARRAY_SIZE(jz4770_uart2_groups), },
860 { "uart3", jz4770_uart3_groups, ARRAY_SIZE(jz4770_uart3_groups), },
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200861 { "mmc0", jz4770_mmc0_groups, ARRAY_SIZE(jz4770_mmc0_groups), },
862 { "mmc1", jz4770_mmc1_groups, ARRAY_SIZE(jz4770_mmc1_groups), },
Zhou Yanjie5de1a732019-01-28 23:19:58 +0800863 { "mmc2", jz4770_mmc2_groups, ARRAY_SIZE(jz4770_mmc2_groups), },
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200864 { "nemc", jz4770_nemc_groups, ARRAY_SIZE(jz4770_nemc_groups), },
865 { "nemc-cs1", jz4770_cs1_groups, ARRAY_SIZE(jz4770_cs1_groups), },
Zhou Yanjieff656e42019-01-28 23:19:57 +0800866 { "nemc-cs2", jz4770_cs2_groups, ARRAY_SIZE(jz4770_cs2_groups), },
867 { "nemc-cs3", jz4770_cs3_groups, ARRAY_SIZE(jz4770_cs3_groups), },
868 { "nemc-cs4", jz4770_cs4_groups, ARRAY_SIZE(jz4770_cs4_groups), },
869 { "nemc-cs5", jz4770_cs5_groups, ARRAY_SIZE(jz4770_cs5_groups), },
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200870 { "nemc-cs6", jz4770_cs6_groups, ARRAY_SIZE(jz4770_cs6_groups), },
871 { "i2c0", jz4770_i2c0_groups, ARRAY_SIZE(jz4770_i2c0_groups), },
872 { "i2c1", jz4770_i2c1_groups, ARRAY_SIZE(jz4770_i2c1_groups), },
873 { "i2c2", jz4770_i2c2_groups, ARRAY_SIZE(jz4770_i2c2_groups), },
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200874 { "cim", jz4770_cim_groups, ARRAY_SIZE(jz4770_cim_groups), },
875 { "lcd", jz4770_lcd_groups, ARRAY_SIZE(jz4770_lcd_groups), },
876 { "pwm0", jz4770_pwm0_groups, ARRAY_SIZE(jz4770_pwm0_groups), },
877 { "pwm1", jz4770_pwm1_groups, ARRAY_SIZE(jz4770_pwm1_groups), },
878 { "pwm2", jz4770_pwm2_groups, ARRAY_SIZE(jz4770_pwm2_groups), },
879 { "pwm3", jz4770_pwm3_groups, ARRAY_SIZE(jz4770_pwm3_groups), },
880 { "pwm4", jz4770_pwm4_groups, ARRAY_SIZE(jz4770_pwm4_groups), },
881 { "pwm5", jz4770_pwm5_groups, ARRAY_SIZE(jz4770_pwm5_groups), },
882 { "pwm6", jz4770_pwm6_groups, ARRAY_SIZE(jz4770_pwm6_groups), },
883 { "pwm7", jz4770_pwm7_groups, ARRAY_SIZE(jz4770_pwm7_groups), },
Zhou Yanjie5de1a732019-01-28 23:19:58 +0800884 { "mac", jz4770_mac_groups, ARRAY_SIZE(jz4770_mac_groups), },
Paul Cercueilae75b532019-11-19 16:52:11 +0100885 { "otg", jz4770_otg_groups, ARRAY_SIZE(jz4770_otg_groups), },
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200886};
887
888static const struct ingenic_chip_info jz4770_chip_info = {
889 .num_chips = 6,
周琰杰 (Zhou Yanjie)f742e5e2019-12-16 00:21:02 +0800890 .reg_offset = 0x100,
Paul Cercueilbaf15642020-01-07 00:27:08 +0100891 .version = ID_JZ4770,
Paul Cercueilb5c23aa2017-05-12 18:52:56 +0200892 .groups = jz4770_groups,
893 .num_groups = ARRAY_SIZE(jz4770_groups),
894 .functions = jz4770_functions,
895 .num_functions = ARRAY_SIZE(jz4770_functions),
896 .pull_ups = jz4770_pull_ups,
897 .pull_downs = jz4770_pull_downs,
898};
899
Zhou Yanjieff656e42019-01-28 23:19:57 +0800900static int jz4780_uart2_data_pins[] = { 0x66, 0x67, };
901static int jz4780_uart2_hwflow_pins[] = { 0x65, 0x64, };
902static int jz4780_uart4_data_pins[] = { 0x54, 0x4a, };
903static int jz4780_mmc0_8bit_a_pins[] = { 0x04, 0x05, 0x06, 0x07, 0x18, };
904static int jz4780_i2c3_pins[] = { 0x6a, 0x6b, };
905static int jz4780_i2c4_e_pins[] = { 0x8c, 0x8d, };
906static int jz4780_i2c4_f_pins[] = { 0xb9, 0xb8, };
Paul Boddiea0bb89e2020-02-28 19:19:30 +0100907static int jz4780_hdmi_ddc_pins[] = { 0xb9, 0xb8, };
Zhou Yanjieff656e42019-01-28 23:19:57 +0800908
909static int jz4780_uart2_data_funcs[] = { 1, 1, };
910static int jz4780_uart2_hwflow_funcs[] = { 1, 1, };
911static int jz4780_uart4_data_funcs[] = { 2, 2, };
912static int jz4780_mmc0_8bit_a_funcs[] = { 1, 1, 1, 1, 1, };
913static int jz4780_i2c3_funcs[] = { 1, 1, };
914static int jz4780_i2c4_e_funcs[] = { 1, 1, };
915static int jz4780_i2c4_f_funcs[] = { 1, 1, };
Paul Boddiea0bb89e2020-02-28 19:19:30 +0100916static int jz4780_hdmi_ddc_funcs[] = { 0, 0, };
Zhou Yanjieff656e42019-01-28 23:19:57 +0800917
918static const struct group_desc jz4780_groups[] = {
919 INGENIC_PIN_GROUP("uart0-data", jz4770_uart0_data),
920 INGENIC_PIN_GROUP("uart0-hwflow", jz4770_uart0_hwflow),
921 INGENIC_PIN_GROUP("uart1-data", jz4770_uart1_data),
922 INGENIC_PIN_GROUP("uart1-hwflow", jz4770_uart1_hwflow),
923 INGENIC_PIN_GROUP("uart2-data", jz4780_uart2_data),
924 INGENIC_PIN_GROUP("uart2-hwflow", jz4780_uart2_hwflow),
925 INGENIC_PIN_GROUP("uart3-data", jz4770_uart3_data),
926 INGENIC_PIN_GROUP("uart3-hwflow", jz4770_uart3_hwflow),
927 INGENIC_PIN_GROUP("uart4-data", jz4780_uart4_data),
928 INGENIC_PIN_GROUP("mmc0-1bit-a", jz4770_mmc0_1bit_a),
929 INGENIC_PIN_GROUP("mmc0-4bit-a", jz4770_mmc0_4bit_a),
930 INGENIC_PIN_GROUP("mmc0-8bit-a", jz4780_mmc0_8bit_a),
931 INGENIC_PIN_GROUP("mmc0-1bit-e", jz4770_mmc0_1bit_e),
932 INGENIC_PIN_GROUP("mmc0-4bit-e", jz4770_mmc0_4bit_e),
933 INGENIC_PIN_GROUP("mmc1-1bit-d", jz4770_mmc1_1bit_d),
934 INGENIC_PIN_GROUP("mmc1-4bit-d", jz4770_mmc1_4bit_d),
935 INGENIC_PIN_GROUP("mmc1-1bit-e", jz4770_mmc1_1bit_e),
936 INGENIC_PIN_GROUP("mmc1-4bit-e", jz4770_mmc1_4bit_e),
Zhou Yanjie5de1a732019-01-28 23:19:58 +0800937 INGENIC_PIN_GROUP("mmc2-1bit-b", jz4770_mmc2_1bit_b),
938 INGENIC_PIN_GROUP("mmc2-4bit-b", jz4770_mmc2_4bit_b),
939 INGENIC_PIN_GROUP("mmc2-1bit-e", jz4770_mmc2_1bit_e),
940 INGENIC_PIN_GROUP("mmc2-4bit-e", jz4770_mmc2_4bit_e),
Zhou Yanjieff656e42019-01-28 23:19:57 +0800941 INGENIC_PIN_GROUP("nemc-data", jz4770_nemc_8bit_data),
942 INGENIC_PIN_GROUP("nemc-cle-ale", jz4770_nemc_cle_ale),
943 INGENIC_PIN_GROUP("nemc-addr", jz4770_nemc_addr),
944 INGENIC_PIN_GROUP("nemc-rd-we", jz4770_nemc_rd_we),
945 INGENIC_PIN_GROUP("nemc-frd-fwe", jz4770_nemc_frd_fwe),
Zhou Yanjie5de1a732019-01-28 23:19:58 +0800946 INGENIC_PIN_GROUP("nemc-wait", jz4770_nemc_wait),
Zhou Yanjieff656e42019-01-28 23:19:57 +0800947 INGENIC_PIN_GROUP("nemc-cs1", jz4770_nemc_cs1),
948 INGENIC_PIN_GROUP("nemc-cs2", jz4770_nemc_cs2),
949 INGENIC_PIN_GROUP("nemc-cs3", jz4770_nemc_cs3),
950 INGENIC_PIN_GROUP("nemc-cs4", jz4770_nemc_cs4),
951 INGENIC_PIN_GROUP("nemc-cs5", jz4770_nemc_cs5),
952 INGENIC_PIN_GROUP("nemc-cs6", jz4770_nemc_cs6),
953 INGENIC_PIN_GROUP("i2c0-data", jz4770_i2c0),
954 INGENIC_PIN_GROUP("i2c1-data", jz4770_i2c1),
955 INGENIC_PIN_GROUP("i2c2-data", jz4770_i2c2),
956 INGENIC_PIN_GROUP("i2c3-data", jz4780_i2c3),
957 INGENIC_PIN_GROUP("i2c4-data-e", jz4780_i2c4_e),
958 INGENIC_PIN_GROUP("i2c4-data-f", jz4780_i2c4_f),
Paul Boddiea0bb89e2020-02-28 19:19:30 +0100959 INGENIC_PIN_GROUP("hdmi-ddc", jz4780_hdmi_ddc),
Zhou Yanjieff656e42019-01-28 23:19:57 +0800960 INGENIC_PIN_GROUP("cim-data", jz4770_cim_8bit),
961 INGENIC_PIN_GROUP("lcd-24bit", jz4770_lcd_24bit),
962 { "lcd-no-pins", },
963 INGENIC_PIN_GROUP("pwm0", jz4770_pwm_pwm0),
964 INGENIC_PIN_GROUP("pwm1", jz4770_pwm_pwm1),
965 INGENIC_PIN_GROUP("pwm2", jz4770_pwm_pwm2),
966 INGENIC_PIN_GROUP("pwm3", jz4770_pwm_pwm3),
967 INGENIC_PIN_GROUP("pwm4", jz4770_pwm_pwm4),
968 INGENIC_PIN_GROUP("pwm5", jz4770_pwm_pwm5),
969 INGENIC_PIN_GROUP("pwm6", jz4770_pwm_pwm6),
970 INGENIC_PIN_GROUP("pwm7", jz4770_pwm_pwm7),
971};
972
973static const char *jz4780_uart2_groups[] = { "uart2-data", "uart2-hwflow", };
974static const char *jz4780_uart4_groups[] = { "uart4-data", };
975static const char *jz4780_mmc0_groups[] = {
976 "mmc0-1bit-a", "mmc0-4bit-a", "mmc0-8bit-a",
977 "mmc0-1bit-e", "mmc0-4bit-e",
978};
979static const char *jz4780_mmc1_groups[] = {
980 "mmc1-1bit-d", "mmc1-4bit-d", "mmc1-1bit-e", "mmc1-4bit-e",
981};
Zhou Yanjie5de1a732019-01-28 23:19:58 +0800982static const char *jz4780_mmc2_groups[] = {
983 "mmc2-1bit-b", "mmc2-4bit-b", "mmc2-1bit-e", "mmc2-4bit-e",
984};
Zhou Yanjieff656e42019-01-28 23:19:57 +0800985static const char *jz4780_nemc_groups[] = {
986 "nemc-data", "nemc-cle-ale", "nemc-addr",
Zhou Yanjie5de1a732019-01-28 23:19:58 +0800987 "nemc-rd-we", "nemc-frd-fwe", "nemc-wait",
Zhou Yanjieff656e42019-01-28 23:19:57 +0800988};
989static const char *jz4780_i2c3_groups[] = { "i2c3-data", };
990static const char *jz4780_i2c4_groups[] = { "i2c4-data-e", "i2c4-data-f", };
991static const char *jz4780_cim_groups[] = { "cim-data", };
Paul Boddiea0bb89e2020-02-28 19:19:30 +0100992static const char *jz4780_hdmi_ddc_groups[] = { "hdmi-ddc", };
Zhou Yanjieff656e42019-01-28 23:19:57 +0800993
994static const struct function_desc jz4780_functions[] = {
995 { "uart0", jz4770_uart0_groups, ARRAY_SIZE(jz4770_uart0_groups), },
996 { "uart1", jz4770_uart1_groups, ARRAY_SIZE(jz4770_uart1_groups), },
997 { "uart2", jz4780_uart2_groups, ARRAY_SIZE(jz4780_uart2_groups), },
998 { "uart3", jz4770_uart3_groups, ARRAY_SIZE(jz4770_uart3_groups), },
999 { "uart4", jz4780_uart4_groups, ARRAY_SIZE(jz4780_uart4_groups), },
1000 { "mmc0", jz4780_mmc0_groups, ARRAY_SIZE(jz4780_mmc0_groups), },
1001 { "mmc1", jz4780_mmc1_groups, ARRAY_SIZE(jz4780_mmc1_groups), },
Zhou Yanjie5de1a732019-01-28 23:19:58 +08001002 { "mmc2", jz4780_mmc2_groups, ARRAY_SIZE(jz4780_mmc2_groups), },
Zhou Yanjieff656e42019-01-28 23:19:57 +08001003 { "nemc", jz4780_nemc_groups, ARRAY_SIZE(jz4780_nemc_groups), },
1004 { "nemc-cs1", jz4770_cs1_groups, ARRAY_SIZE(jz4770_cs1_groups), },
1005 { "nemc-cs2", jz4770_cs2_groups, ARRAY_SIZE(jz4770_cs2_groups), },
1006 { "nemc-cs3", jz4770_cs3_groups, ARRAY_SIZE(jz4770_cs3_groups), },
1007 { "nemc-cs4", jz4770_cs4_groups, ARRAY_SIZE(jz4770_cs4_groups), },
1008 { "nemc-cs5", jz4770_cs5_groups, ARRAY_SIZE(jz4770_cs5_groups), },
1009 { "nemc-cs6", jz4770_cs6_groups, ARRAY_SIZE(jz4770_cs6_groups), },
1010 { "i2c0", jz4770_i2c0_groups, ARRAY_SIZE(jz4770_i2c0_groups), },
1011 { "i2c1", jz4770_i2c1_groups, ARRAY_SIZE(jz4770_i2c1_groups), },
1012 { "i2c2", jz4770_i2c2_groups, ARRAY_SIZE(jz4770_i2c2_groups), },
1013 { "i2c3", jz4780_i2c3_groups, ARRAY_SIZE(jz4780_i2c3_groups), },
1014 { "i2c4", jz4780_i2c4_groups, ARRAY_SIZE(jz4780_i2c4_groups), },
1015 { "cim", jz4780_cim_groups, ARRAY_SIZE(jz4780_cim_groups), },
1016 { "lcd", jz4770_lcd_groups, ARRAY_SIZE(jz4770_lcd_groups), },
1017 { "pwm0", jz4770_pwm0_groups, ARRAY_SIZE(jz4770_pwm0_groups), },
1018 { "pwm1", jz4770_pwm1_groups, ARRAY_SIZE(jz4770_pwm1_groups), },
1019 { "pwm2", jz4770_pwm2_groups, ARRAY_SIZE(jz4770_pwm2_groups), },
1020 { "pwm3", jz4770_pwm3_groups, ARRAY_SIZE(jz4770_pwm3_groups), },
1021 { "pwm4", jz4770_pwm4_groups, ARRAY_SIZE(jz4770_pwm4_groups), },
1022 { "pwm5", jz4770_pwm5_groups, ARRAY_SIZE(jz4770_pwm5_groups), },
1023 { "pwm6", jz4770_pwm6_groups, ARRAY_SIZE(jz4770_pwm6_groups), },
1024 { "pwm7", jz4770_pwm7_groups, ARRAY_SIZE(jz4770_pwm7_groups), },
Paul Boddiea0bb89e2020-02-28 19:19:30 +01001025 { "hdmi-ddc", jz4780_hdmi_ddc_groups,
1026 ARRAY_SIZE(jz4780_hdmi_ddc_groups), },
Zhou Yanjieff656e42019-01-28 23:19:57 +08001027};
1028
1029static const struct ingenic_chip_info jz4780_chip_info = {
1030 .num_chips = 6,
周琰杰 (Zhou Yanjie)f742e5e2019-12-16 00:21:02 +08001031 .reg_offset = 0x100,
Paul Cercueilbaf15642020-01-07 00:27:08 +01001032 .version = ID_JZ4780,
Zhou Yanjieff656e42019-01-28 23:19:57 +08001033 .groups = jz4780_groups,
1034 .num_groups = ARRAY_SIZE(jz4780_groups),
1035 .functions = jz4780_functions,
1036 .num_functions = ARRAY_SIZE(jz4780_functions),
1037 .pull_ups = jz4770_pull_ups,
1038 .pull_downs = jz4770_pull_downs,
1039};
1040
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001041static const u32 x1000_pull_ups[4] = {
周琰杰 (Zhou Yanjie)b4a93722019-12-16 00:21:00 +08001042 0xffffffff, 0xfdffffff, 0x0dffffff, 0x0000003f,
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001043};
1044
1045static const u32 x1000_pull_downs[4] = {
1046 0x00000000, 0x02000000, 0x02000000, 0x00000000,
1047};
1048
1049static int x1000_uart0_data_pins[] = { 0x4a, 0x4b, };
1050static int x1000_uart0_hwflow_pins[] = { 0x4c, 0x4d, };
1051static int x1000_uart1_data_a_pins[] = { 0x04, 0x05, };
1052static int x1000_uart1_data_d_pins[] = { 0x62, 0x63, };
周琰杰 (Zhou Yanjie)b4a93722019-12-16 00:21:00 +08001053static int x1000_uart1_hwflow_pins[] = { 0x64, 0x65, };
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001054static int x1000_uart2_data_a_pins[] = { 0x02, 0x03, };
1055static int x1000_uart2_data_d_pins[] = { 0x65, 0x64, };
周琰杰 (Zhou Yanjie)3b31e9b2019-12-16 00:21:01 +08001056static int x1000_sfc_pins[] = { 0x1d, 0x1c, 0x1e, 0x1f, 0x1a, 0x1b, };
1057static int x1000_ssi_dt_a_22_pins[] = { 0x16, };
1058static int x1000_ssi_dt_a_29_pins[] = { 0x1d, };
1059static int x1000_ssi_dt_d_pins[] = { 0x62, };
1060static int x1000_ssi_dr_a_23_pins[] = { 0x17, };
1061static int x1000_ssi_dr_a_28_pins[] = { 0x1c, };
1062static int x1000_ssi_dr_d_pins[] = { 0x63, };
1063static int x1000_ssi_clk_a_24_pins[] = { 0x18, };
1064static int x1000_ssi_clk_a_26_pins[] = { 0x1a, };
1065static int x1000_ssi_clk_d_pins[] = { 0x60, };
1066static int x1000_ssi_gpc_a_20_pins[] = { 0x14, };
1067static int x1000_ssi_gpc_a_31_pins[] = { 0x1f, };
1068static int x1000_ssi_ce0_a_25_pins[] = { 0x19, };
1069static int x1000_ssi_ce0_a_27_pins[] = { 0x1b, };
1070static int x1000_ssi_ce0_d_pins[] = { 0x61, };
1071static int x1000_ssi_ce1_a_21_pins[] = { 0x15, };
1072static int x1000_ssi_ce1_a_30_pins[] = { 0x1e, };
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001073static int x1000_mmc0_1bit_pins[] = { 0x18, 0x19, 0x17, };
1074static int x1000_mmc0_4bit_pins[] = { 0x16, 0x15, 0x14, };
1075static int x1000_mmc0_8bit_pins[] = { 0x13, 0x12, 0x11, 0x10, };
1076static int x1000_mmc1_1bit_pins[] = { 0x40, 0x41, 0x42, };
1077static int x1000_mmc1_4bit_pins[] = { 0x43, 0x44, 0x45, };
周琰杰 (Zhou Yanjie)b4a93722019-12-16 00:21:00 +08001078static int x1000_emc_8bit_data_pins[] = {
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001079 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
1080};
周琰杰 (Zhou Yanjie)b4a93722019-12-16 00:21:00 +08001081static int x1000_emc_16bit_data_pins[] = {
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001082 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f,
1083};
周琰杰 (Zhou Yanjie)b4a93722019-12-16 00:21:00 +08001084static int x1000_emc_addr_pins[] = {
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001085 0x20, 0x21, 0x22, 0x23, 0x24, 0x25, 0x26, 0x27,
1086 0x28, 0x29, 0x2a, 0x2b, 0x2c, 0x2d, 0x2e, 0x2f,
1087};
周琰杰 (Zhou Yanjie)b4a93722019-12-16 00:21:00 +08001088static int x1000_emc_rd_we_pins[] = { 0x30, 0x31, };
1089static int x1000_emc_wait_pins[] = { 0x34, };
1090static int x1000_emc_cs1_pins[] = { 0x32, };
1091static int x1000_emc_cs2_pins[] = { 0x33, };
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001092static int x1000_i2c0_pins[] = { 0x38, 0x37, };
1093static int x1000_i2c1_a_pins[] = { 0x01, 0x00, };
1094static int x1000_i2c1_c_pins[] = { 0x5b, 0x5a, };
1095static int x1000_i2c2_pins[] = { 0x61, 0x60, };
1096static int x1000_cim_pins[] = {
1097 0x08, 0x09, 0x0a, 0x0b,
1098 0x13, 0x12, 0x11, 0x10, 0x0f, 0x0e, 0x0d, 0x0c,
1099};
1100static int x1000_lcd_8bit_pins[] = {
1101 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
1102 0x30, 0x31, 0x32, 0x33, 0x34,
1103};
1104static int x1000_lcd_16bit_pins[] = {
1105 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f,
1106};
1107static int x1000_pwm_pwm0_pins[] = { 0x59, };
1108static int x1000_pwm_pwm1_pins[] = { 0x5a, };
1109static int x1000_pwm_pwm2_pins[] = { 0x5b, };
1110static int x1000_pwm_pwm3_pins[] = { 0x26, };
1111static int x1000_pwm_pwm4_pins[] = { 0x58, };
1112static int x1000_mac_pins[] = {
1113 0x27, 0x28, 0x29, 0x2a, 0x2b, 0x2c, 0x2d, 0x2e, 0x2f, 0x26,
1114};
1115
1116static int x1000_uart0_data_funcs[] = { 0, 0, };
1117static int x1000_uart0_hwflow_funcs[] = { 0, 0, };
1118static int x1000_uart1_data_a_funcs[] = { 2, 2, };
1119static int x1000_uart1_data_d_funcs[] = { 1, 1, };
周琰杰 (Zhou Yanjie)b4a93722019-12-16 00:21:00 +08001120static int x1000_uart1_hwflow_funcs[] = { 1, 1, };
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001121static int x1000_uart2_data_a_funcs[] = { 2, 2, };
1122static int x1000_uart2_data_d_funcs[] = { 0, 0, };
周琰杰 (Zhou Yanjie)3b31e9b2019-12-16 00:21:01 +08001123static int x1000_sfc_funcs[] = { 1, 1, 1, 1, 1, 1, };
1124static int x1000_ssi_dt_a_22_funcs[] = { 2, };
1125static int x1000_ssi_dt_a_29_funcs[] = { 2, };
1126static int x1000_ssi_dt_d_funcs[] = { 0, };
1127static int x1000_ssi_dr_a_23_funcs[] = { 2, };
1128static int x1000_ssi_dr_a_28_funcs[] = { 2, };
1129static int x1000_ssi_dr_d_funcs[] = { 0, };
1130static int x1000_ssi_clk_a_24_funcs[] = { 2, };
1131static int x1000_ssi_clk_a_26_funcs[] = { 2, };
1132static int x1000_ssi_clk_d_funcs[] = { 0, };
1133static int x1000_ssi_gpc_a_20_funcs[] = { 2, };
1134static int x1000_ssi_gpc_a_31_funcs[] = { 2, };
1135static int x1000_ssi_ce0_a_25_funcs[] = { 2, };
1136static int x1000_ssi_ce0_a_27_funcs[] = { 2, };
1137static int x1000_ssi_ce0_d_funcs[] = { 0, };
1138static int x1000_ssi_ce1_a_21_funcs[] = { 2, };
1139static int x1000_ssi_ce1_a_30_funcs[] = { 2, };
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001140static int x1000_mmc0_1bit_funcs[] = { 1, 1, 1, };
1141static int x1000_mmc0_4bit_funcs[] = { 1, 1, 1, };
1142static int x1000_mmc0_8bit_funcs[] = { 1, 1, 1, 1, 1, };
1143static int x1000_mmc1_1bit_funcs[] = { 0, 0, 0, };
1144static int x1000_mmc1_4bit_funcs[] = { 0, 0, 0, };
周琰杰 (Zhou Yanjie)b4a93722019-12-16 00:21:00 +08001145static int x1000_emc_8bit_data_funcs[] = { 0, 0, 0, 0, 0, 0, 0, 0, };
1146static int x1000_emc_16bit_data_funcs[] = { 0, 0, 0, 0, 0, 0, 0, 0, };
1147static int x1000_emc_addr_funcs[] = {
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001148 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
1149};
周琰杰 (Zhou Yanjie)b4a93722019-12-16 00:21:00 +08001150static int x1000_emc_rd_we_funcs[] = { 0, 0, };
1151static int x1000_emc_wait_funcs[] = { 0, };
1152static int x1000_emc_cs1_funcs[] = { 0, };
1153static int x1000_emc_cs2_funcs[] = { 0, };
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001154static int x1000_i2c0_funcs[] = { 0, 0, };
1155static int x1000_i2c1_a_funcs[] = { 2, 2, };
1156static int x1000_i2c1_c_funcs[] = { 0, 0, };
1157static int x1000_i2c2_funcs[] = { 1, 1, };
1158static int x1000_cim_funcs[] = { 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, };
1159static int x1000_lcd_8bit_funcs[] = {
1160 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1161};
1162static int x1000_lcd_16bit_funcs[] = { 1, 1, 1, 1, 1, 1, 1, 1, };
1163static int x1000_pwm_pwm0_funcs[] = { 0, };
1164static int x1000_pwm_pwm1_funcs[] = { 1, };
1165static int x1000_pwm_pwm2_funcs[] = { 1, };
1166static int x1000_pwm_pwm3_funcs[] = { 2, };
1167static int x1000_pwm_pwm4_funcs[] = { 0, };
1168static int x1000_mac_funcs[] = { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, };
1169
1170static const struct group_desc x1000_groups[] = {
1171 INGENIC_PIN_GROUP("uart0-data", x1000_uart0_data),
1172 INGENIC_PIN_GROUP("uart0-hwflow", x1000_uart0_hwflow),
1173 INGENIC_PIN_GROUP("uart1-data-a", x1000_uart1_data_a),
1174 INGENIC_PIN_GROUP("uart1-data-d", x1000_uart1_data_d),
周琰杰 (Zhou Yanjie)b4a93722019-12-16 00:21:00 +08001175 INGENIC_PIN_GROUP("uart1-hwflow", x1000_uart1_hwflow),
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001176 INGENIC_PIN_GROUP("uart2-data-a", x1000_uart2_data_a),
1177 INGENIC_PIN_GROUP("uart2-data-d", x1000_uart2_data_d),
周琰杰 (Zhou Yanjie)3b31e9b2019-12-16 00:21:01 +08001178 INGENIC_PIN_GROUP("sfc", x1000_sfc),
1179 INGENIC_PIN_GROUP("ssi-dt-a-22", x1000_ssi_dt_a_22),
1180 INGENIC_PIN_GROUP("ssi-dt-a-29", x1000_ssi_dt_a_29),
1181 INGENIC_PIN_GROUP("ssi-dt-d", x1000_ssi_dt_d),
1182 INGENIC_PIN_GROUP("ssi-dr-a-23", x1000_ssi_dr_a_23),
1183 INGENIC_PIN_GROUP("ssi-dr-a-28", x1000_ssi_dr_a_28),
1184 INGENIC_PIN_GROUP("ssi-dr-d", x1000_ssi_dr_d),
1185 INGENIC_PIN_GROUP("ssi-clk-a-24", x1000_ssi_clk_a_24),
1186 INGENIC_PIN_GROUP("ssi-clk-a-26", x1000_ssi_clk_a_26),
1187 INGENIC_PIN_GROUP("ssi-clk-d", x1000_ssi_clk_d),
1188 INGENIC_PIN_GROUP("ssi-gpc-a-20", x1000_ssi_gpc_a_20),
1189 INGENIC_PIN_GROUP("ssi-gpc-a-31", x1000_ssi_gpc_a_31),
1190 INGENIC_PIN_GROUP("ssi-ce0-a-25", x1000_ssi_ce0_a_25),
1191 INGENIC_PIN_GROUP("ssi-ce0-a-27", x1000_ssi_ce0_a_27),
1192 INGENIC_PIN_GROUP("ssi-ce0-d", x1000_ssi_ce0_d),
1193 INGENIC_PIN_GROUP("ssi-ce1-a-21", x1000_ssi_ce1_a_21),
1194 INGENIC_PIN_GROUP("ssi-ce1-a-30", x1000_ssi_ce1_a_30),
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001195 INGENIC_PIN_GROUP("mmc0-1bit", x1000_mmc0_1bit),
1196 INGENIC_PIN_GROUP("mmc0-4bit", x1000_mmc0_4bit),
1197 INGENIC_PIN_GROUP("mmc0-8bit", x1000_mmc0_8bit),
1198 INGENIC_PIN_GROUP("mmc1-1bit", x1000_mmc1_1bit),
1199 INGENIC_PIN_GROUP("mmc1-4bit", x1000_mmc1_4bit),
周琰杰 (Zhou Yanjie)b4a93722019-12-16 00:21:00 +08001200 INGENIC_PIN_GROUP("emc-8bit-data", x1000_emc_8bit_data),
1201 INGENIC_PIN_GROUP("emc-16bit-data", x1000_emc_16bit_data),
1202 INGENIC_PIN_GROUP("emc-addr", x1000_emc_addr),
1203 INGENIC_PIN_GROUP("emc-rd-we", x1000_emc_rd_we),
1204 INGENIC_PIN_GROUP("emc-wait", x1000_emc_wait),
1205 INGENIC_PIN_GROUP("emc-cs1", x1000_emc_cs1),
1206 INGENIC_PIN_GROUP("emc-cs2", x1000_emc_cs2),
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001207 INGENIC_PIN_GROUP("i2c0-data", x1000_i2c0),
1208 INGENIC_PIN_GROUP("i2c1-data-a", x1000_i2c1_a),
1209 INGENIC_PIN_GROUP("i2c1-data-c", x1000_i2c1_c),
1210 INGENIC_PIN_GROUP("i2c2-data", x1000_i2c2),
1211 INGENIC_PIN_GROUP("cim-data", x1000_cim),
1212 INGENIC_PIN_GROUP("lcd-8bit", x1000_lcd_8bit),
1213 INGENIC_PIN_GROUP("lcd-16bit", x1000_lcd_16bit),
1214 { "lcd-no-pins", },
1215 INGENIC_PIN_GROUP("pwm0", x1000_pwm_pwm0),
1216 INGENIC_PIN_GROUP("pwm1", x1000_pwm_pwm1),
1217 INGENIC_PIN_GROUP("pwm2", x1000_pwm_pwm2),
1218 INGENIC_PIN_GROUP("pwm3", x1000_pwm_pwm3),
1219 INGENIC_PIN_GROUP("pwm4", x1000_pwm_pwm4),
1220 INGENIC_PIN_GROUP("mac", x1000_mac),
1221};
1222
1223static const char *x1000_uart0_groups[] = { "uart0-data", "uart0-hwflow", };
1224static const char *x1000_uart1_groups[] = {
周琰杰 (Zhou Yanjie)b4a93722019-12-16 00:21:00 +08001225 "uart1-data-a", "uart1-data-d", "uart1-hwflow",
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001226};
1227static const char *x1000_uart2_groups[] = { "uart2-data-a", "uart2-data-d", };
周琰杰 (Zhou Yanjie)3b31e9b2019-12-16 00:21:01 +08001228static const char *x1000_sfc_groups[] = { "sfc", };
1229static const char *x1000_ssi_groups[] = {
1230 "ssi-dt-a-22", "ssi-dt-a-29", "ssi-dt-d",
1231 "ssi-dr-a-23", "ssi-dr-a-28", "ssi-dr-d",
1232 "ssi-clk-a-24", "ssi-clk-a-26", "ssi-clk-d",
1233 "ssi-gpc-a-20", "ssi-gpc-a-31",
1234 "ssi-ce0-a-25", "ssi-ce0-a-27", "ssi-ce0-d",
1235 "ssi-ce1-a-21", "ssi-ce1-a-30",
1236};
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001237static const char *x1000_mmc0_groups[] = {
1238 "mmc0-1bit", "mmc0-4bit", "mmc0-8bit",
1239};
1240static const char *x1000_mmc1_groups[] = {
周琰杰 (Zhou Yanjie)b4a93722019-12-16 00:21:00 +08001241 "mmc1-1bit", "mmc1-4bit",
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001242};
周琰杰 (Zhou Yanjie)b4a93722019-12-16 00:21:00 +08001243static const char *x1000_emc_groups[] = {
1244 "emc-8bit-data", "emc-16bit-data",
1245 "emc-addr", "emc-rd-we", "emc-wait",
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001246};
周琰杰 (Zhou Yanjie)b4a93722019-12-16 00:21:00 +08001247static const char *x1000_cs1_groups[] = { "emc-cs1", };
1248static const char *x1000_cs2_groups[] = { "emc-cs2", };
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001249static const char *x1000_i2c0_groups[] = { "i2c0-data", };
1250static const char *x1000_i2c1_groups[] = { "i2c1-data-a", "i2c1-data-c", };
1251static const char *x1000_i2c2_groups[] = { "i2c2-data", };
1252static const char *x1000_cim_groups[] = { "cim-data", };
1253static const char *x1000_lcd_groups[] = {
1254 "lcd-8bit", "lcd-16bit", "lcd-no-pins",
1255};
1256static const char *x1000_pwm0_groups[] = { "pwm0", };
1257static const char *x1000_pwm1_groups[] = { "pwm1", };
1258static const char *x1000_pwm2_groups[] = { "pwm2", };
1259static const char *x1000_pwm3_groups[] = { "pwm3", };
1260static const char *x1000_pwm4_groups[] = { "pwm4", };
1261static const char *x1000_mac_groups[] = { "mac", };
1262
1263static const struct function_desc x1000_functions[] = {
1264 { "uart0", x1000_uart0_groups, ARRAY_SIZE(x1000_uart0_groups), },
1265 { "uart1", x1000_uart1_groups, ARRAY_SIZE(x1000_uart1_groups), },
1266 { "uart2", x1000_uart2_groups, ARRAY_SIZE(x1000_uart2_groups), },
周琰杰 (Zhou Yanjie)3b31e9b2019-12-16 00:21:01 +08001267 { "sfc", x1000_sfc_groups, ARRAY_SIZE(x1000_sfc_groups), },
1268 { "ssi", x1000_ssi_groups, ARRAY_SIZE(x1000_ssi_groups), },
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001269 { "mmc0", x1000_mmc0_groups, ARRAY_SIZE(x1000_mmc0_groups), },
1270 { "mmc1", x1000_mmc1_groups, ARRAY_SIZE(x1000_mmc1_groups), },
周琰杰 (Zhou Yanjie)b4a93722019-12-16 00:21:00 +08001271 { "emc", x1000_emc_groups, ARRAY_SIZE(x1000_emc_groups), },
1272 { "emc-cs1", x1000_cs1_groups, ARRAY_SIZE(x1000_cs1_groups), },
1273 { "emc-cs2", x1000_cs2_groups, ARRAY_SIZE(x1000_cs2_groups), },
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001274 { "i2c0", x1000_i2c0_groups, ARRAY_SIZE(x1000_i2c0_groups), },
1275 { "i2c1", x1000_i2c1_groups, ARRAY_SIZE(x1000_i2c1_groups), },
1276 { "i2c2", x1000_i2c2_groups, ARRAY_SIZE(x1000_i2c2_groups), },
1277 { "cim", x1000_cim_groups, ARRAY_SIZE(x1000_cim_groups), },
1278 { "lcd", x1000_lcd_groups, ARRAY_SIZE(x1000_lcd_groups), },
1279 { "pwm0", x1000_pwm0_groups, ARRAY_SIZE(x1000_pwm0_groups), },
1280 { "pwm1", x1000_pwm1_groups, ARRAY_SIZE(x1000_pwm1_groups), },
1281 { "pwm2", x1000_pwm2_groups, ARRAY_SIZE(x1000_pwm2_groups), },
1282 { "pwm3", x1000_pwm3_groups, ARRAY_SIZE(x1000_pwm3_groups), },
1283 { "pwm4", x1000_pwm4_groups, ARRAY_SIZE(x1000_pwm4_groups), },
1284 { "mac", x1000_mac_groups, ARRAY_SIZE(x1000_mac_groups), },
1285};
1286
1287static const struct ingenic_chip_info x1000_chip_info = {
1288 .num_chips = 4,
周琰杰 (Zhou Yanjie)f742e5e2019-12-16 00:21:02 +08001289 .reg_offset = 0x100,
Paul Cercueilbaf15642020-01-07 00:27:08 +01001290 .version = ID_X1000,
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001291 .groups = x1000_groups,
1292 .num_groups = ARRAY_SIZE(x1000_groups),
1293 .functions = x1000_functions,
1294 .num_functions = ARRAY_SIZE(x1000_functions),
1295 .pull_ups = x1000_pull_ups,
1296 .pull_downs = x1000_pull_downs,
1297};
1298
Zhou Yanjie5d215952019-07-14 11:53:56 +08001299static int x1500_uart0_data_pins[] = { 0x4a, 0x4b, };
1300static int x1500_uart0_hwflow_pins[] = { 0x4c, 0x4d, };
1301static int x1500_uart1_data_a_pins[] = { 0x04, 0x05, };
1302static int x1500_uart1_data_d_pins[] = { 0x62, 0x63, };
周琰杰 (Zhou Yanjie)b4a93722019-12-16 00:21:00 +08001303static int x1500_uart1_hwflow_pins[] = { 0x64, 0x65, };
Zhou Yanjie5d215952019-07-14 11:53:56 +08001304static int x1500_uart2_data_a_pins[] = { 0x02, 0x03, };
1305static int x1500_uart2_data_d_pins[] = { 0x65, 0x64, };
周琰杰 (Zhou Yanjie)b4a93722019-12-16 00:21:00 +08001306static int x1500_mmc_1bit_pins[] = { 0x18, 0x19, 0x17, };
1307static int x1500_mmc_4bit_pins[] = { 0x16, 0x15, 0x14, };
Zhou Yanjie5d215952019-07-14 11:53:56 +08001308static int x1500_i2c0_pins[] = { 0x38, 0x37, };
1309static int x1500_i2c1_a_pins[] = { 0x01, 0x00, };
1310static int x1500_i2c1_c_pins[] = { 0x5b, 0x5a, };
1311static int x1500_i2c2_pins[] = { 0x61, 0x60, };
1312static int x1500_cim_pins[] = {
1313 0x08, 0x09, 0x0a, 0x0b,
1314 0x13, 0x12, 0x11, 0x10, 0x0f, 0x0e, 0x0d, 0x0c,
1315};
1316static int x1500_pwm_pwm0_pins[] = { 0x59, };
1317static int x1500_pwm_pwm1_pins[] = { 0x5a, };
1318static int x1500_pwm_pwm2_pins[] = { 0x5b, };
1319static int x1500_pwm_pwm3_pins[] = { 0x26, };
1320static int x1500_pwm_pwm4_pins[] = { 0x58, };
1321
1322static int x1500_uart0_data_funcs[] = { 0, 0, };
1323static int x1500_uart0_hwflow_funcs[] = { 0, 0, };
1324static int x1500_uart1_data_a_funcs[] = { 2, 2, };
1325static int x1500_uart1_data_d_funcs[] = { 1, 1, };
周琰杰 (Zhou Yanjie)b4a93722019-12-16 00:21:00 +08001326static int x1500_uart1_hwflow_funcs[] = { 1, 1, };
Zhou Yanjie5d215952019-07-14 11:53:56 +08001327static int x1500_uart2_data_a_funcs[] = { 2, 2, };
1328static int x1500_uart2_data_d_funcs[] = { 0, 0, };
周琰杰 (Zhou Yanjie)b4a93722019-12-16 00:21:00 +08001329static int x1500_mmc_1bit_funcs[] = { 1, 1, 1, };
1330static int x1500_mmc_4bit_funcs[] = { 1, 1, 1, };
Zhou Yanjie5d215952019-07-14 11:53:56 +08001331static int x1500_i2c0_funcs[] = { 0, 0, };
1332static int x1500_i2c1_a_funcs[] = { 2, 2, };
1333static int x1500_i2c1_c_funcs[] = { 0, 0, };
1334static int x1500_i2c2_funcs[] = { 1, 1, };
1335static int x1500_cim_funcs[] = { 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, };
1336static int x1500_pwm_pwm0_funcs[] = { 0, };
1337static int x1500_pwm_pwm1_funcs[] = { 1, };
1338static int x1500_pwm_pwm2_funcs[] = { 1, };
1339static int x1500_pwm_pwm3_funcs[] = { 2, };
1340static int x1500_pwm_pwm4_funcs[] = { 0, };
1341
1342static const struct group_desc x1500_groups[] = {
1343 INGENIC_PIN_GROUP("uart0-data", x1500_uart0_data),
1344 INGENIC_PIN_GROUP("uart0-hwflow", x1500_uart0_hwflow),
1345 INGENIC_PIN_GROUP("uart1-data-a", x1500_uart1_data_a),
1346 INGENIC_PIN_GROUP("uart1-data-d", x1500_uart1_data_d),
周琰杰 (Zhou Yanjie)b4a93722019-12-16 00:21:00 +08001347 INGENIC_PIN_GROUP("uart1-hwflow", x1500_uart1_hwflow),
Zhou Yanjie5d215952019-07-14 11:53:56 +08001348 INGENIC_PIN_GROUP("uart2-data-a", x1500_uart2_data_a),
1349 INGENIC_PIN_GROUP("uart2-data-d", x1500_uart2_data_d),
周琰杰 (Zhou Yanjie)3b31e9b2019-12-16 00:21:01 +08001350 INGENIC_PIN_GROUP("sfc", x1000_sfc),
周琰杰 (Zhou Yanjie)b4a93722019-12-16 00:21:00 +08001351 INGENIC_PIN_GROUP("mmc-1bit", x1500_mmc_1bit),
1352 INGENIC_PIN_GROUP("mmc-4bit", x1500_mmc_4bit),
Zhou Yanjie5d215952019-07-14 11:53:56 +08001353 INGENIC_PIN_GROUP("i2c0-data", x1500_i2c0),
1354 INGENIC_PIN_GROUP("i2c1-data-a", x1500_i2c1_a),
1355 INGENIC_PIN_GROUP("i2c1-data-c", x1500_i2c1_c),
1356 INGENIC_PIN_GROUP("i2c2-data", x1500_i2c2),
1357 INGENIC_PIN_GROUP("cim-data", x1500_cim),
1358 { "lcd-no-pins", },
1359 INGENIC_PIN_GROUP("pwm0", x1500_pwm_pwm0),
1360 INGENIC_PIN_GROUP("pwm1", x1500_pwm_pwm1),
1361 INGENIC_PIN_GROUP("pwm2", x1500_pwm_pwm2),
1362 INGENIC_PIN_GROUP("pwm3", x1500_pwm_pwm3),
1363 INGENIC_PIN_GROUP("pwm4", x1500_pwm_pwm4),
1364};
1365
1366static const char *x1500_uart0_groups[] = { "uart0-data", "uart0-hwflow", };
1367static const char *x1500_uart1_groups[] = {
周琰杰 (Zhou Yanjie)b4a93722019-12-16 00:21:00 +08001368 "uart1-data-a", "uart1-data-d", "uart1-hwflow",
Zhou Yanjie5d215952019-07-14 11:53:56 +08001369};
1370static const char *x1500_uart2_groups[] = { "uart2-data-a", "uart2-data-d", };
周琰杰 (Zhou Yanjie)b4a93722019-12-16 00:21:00 +08001371static const char *x1500_mmc_groups[] = { "mmc-1bit", "mmc-4bit", };
Zhou Yanjie5d215952019-07-14 11:53:56 +08001372static const char *x1500_i2c0_groups[] = { "i2c0-data", };
1373static const char *x1500_i2c1_groups[] = { "i2c1-data-a", "i2c1-data-c", };
1374static const char *x1500_i2c2_groups[] = { "i2c2-data", };
1375static const char *x1500_cim_groups[] = { "cim-data", };
1376static const char *x1500_lcd_groups[] = { "lcd-no-pins", };
1377static const char *x1500_pwm0_groups[] = { "pwm0", };
1378static const char *x1500_pwm1_groups[] = { "pwm1", };
1379static const char *x1500_pwm2_groups[] = { "pwm2", };
1380static const char *x1500_pwm3_groups[] = { "pwm3", };
1381static const char *x1500_pwm4_groups[] = { "pwm4", };
1382
1383static const struct function_desc x1500_functions[] = {
1384 { "uart0", x1500_uart0_groups, ARRAY_SIZE(x1500_uart0_groups), },
1385 { "uart1", x1500_uart1_groups, ARRAY_SIZE(x1500_uart1_groups), },
1386 { "uart2", x1500_uart2_groups, ARRAY_SIZE(x1500_uart2_groups), },
周琰杰 (Zhou Yanjie)3b31e9b2019-12-16 00:21:01 +08001387 { "sfc", x1000_sfc_groups, ARRAY_SIZE(x1000_sfc_groups), },
周琰杰 (Zhou Yanjie)b4a93722019-12-16 00:21:00 +08001388 { "mmc", x1500_mmc_groups, ARRAY_SIZE(x1500_mmc_groups), },
Zhou Yanjie5d215952019-07-14 11:53:56 +08001389 { "i2c0", x1500_i2c0_groups, ARRAY_SIZE(x1500_i2c0_groups), },
1390 { "i2c1", x1500_i2c1_groups, ARRAY_SIZE(x1500_i2c1_groups), },
1391 { "i2c2", x1500_i2c2_groups, ARRAY_SIZE(x1500_i2c2_groups), },
1392 { "cim", x1500_cim_groups, ARRAY_SIZE(x1500_cim_groups), },
1393 { "lcd", x1500_lcd_groups, ARRAY_SIZE(x1500_lcd_groups), },
1394 { "pwm0", x1500_pwm0_groups, ARRAY_SIZE(x1500_pwm0_groups), },
1395 { "pwm1", x1500_pwm1_groups, ARRAY_SIZE(x1500_pwm1_groups), },
1396 { "pwm2", x1500_pwm2_groups, ARRAY_SIZE(x1500_pwm2_groups), },
1397 { "pwm3", x1500_pwm3_groups, ARRAY_SIZE(x1500_pwm3_groups), },
1398 { "pwm4", x1500_pwm4_groups, ARRAY_SIZE(x1500_pwm4_groups), },
1399};
1400
1401static const struct ingenic_chip_info x1500_chip_info = {
1402 .num_chips = 4,
周琰杰 (Zhou Yanjie)f742e5e2019-12-16 00:21:02 +08001403 .reg_offset = 0x100,
Paul Cercueilbaf15642020-01-07 00:27:08 +01001404 .version = ID_X1500,
Zhou Yanjie5d215952019-07-14 11:53:56 +08001405 .groups = x1500_groups,
1406 .num_groups = ARRAY_SIZE(x1500_groups),
1407 .functions = x1500_functions,
1408 .num_functions = ARRAY_SIZE(x1500_functions),
1409 .pull_ups = x1000_pull_ups,
1410 .pull_downs = x1000_pull_downs,
1411};
1412
周琰杰 (Zhou Yanjie)d7da2a12019-12-16 00:21:04 +08001413static const u32 x1830_pull_ups[4] = {
1414 0x5fdfffc0, 0xffffefff, 0x1ffffbff, 0x0fcff3fc,
1415};
1416
1417static const u32 x1830_pull_downs[4] = {
1418 0x5fdfffc0, 0xffffefff, 0x1ffffbff, 0x0fcff3fc,
1419};
1420
1421static int x1830_uart0_data_pins[] = { 0x33, 0x36, };
1422static int x1830_uart0_hwflow_pins[] = { 0x34, 0x35, };
1423static int x1830_uart1_data_pins[] = { 0x38, 0x37, };
1424static int x1830_sfc_pins[] = { 0x17, 0x18, 0x1a, 0x19, 0x1b, 0x1c, };
1425static int x1830_ssi0_dt_pins[] = { 0x4c, };
1426static int x1830_ssi0_dr_pins[] = { 0x4b, };
1427static int x1830_ssi0_clk_pins[] = { 0x4f, };
1428static int x1830_ssi0_gpc_pins[] = { 0x4d, };
1429static int x1830_ssi0_ce0_pins[] = { 0x50, };
1430static int x1830_ssi0_ce1_pins[] = { 0x4e, };
1431static int x1830_ssi1_dt_c_pins[] = { 0x53, };
1432static int x1830_ssi1_dr_c_pins[] = { 0x54, };
1433static int x1830_ssi1_clk_c_pins[] = { 0x57, };
1434static int x1830_ssi1_gpc_c_pins[] = { 0x55, };
1435static int x1830_ssi1_ce0_c_pins[] = { 0x58, };
1436static int x1830_ssi1_ce1_c_pins[] = { 0x56, };
1437static int x1830_ssi1_dt_d_pins[] = { 0x62, };
1438static int x1830_ssi1_dr_d_pins[] = { 0x63, };
1439static int x1830_ssi1_clk_d_pins[] = { 0x66, };
1440static int x1830_ssi1_gpc_d_pins[] = { 0x64, };
1441static int x1830_ssi1_ce0_d_pins[] = { 0x67, };
1442static int x1830_ssi1_ce1_d_pins[] = { 0x65, };
1443static int x1830_mmc0_1bit_pins[] = { 0x24, 0x25, 0x20, };
1444static int x1830_mmc0_4bit_pins[] = { 0x21, 0x22, 0x23, };
1445static int x1830_mmc1_1bit_pins[] = { 0x42, 0x43, 0x44, };
1446static int x1830_mmc1_4bit_pins[] = { 0x45, 0x46, 0x47, };
1447static int x1830_i2c0_pins[] = { 0x0c, 0x0d, };
1448static int x1830_i2c1_pins[] = { 0x39, 0x3a, };
1449static int x1830_i2c2_pins[] = { 0x5b, 0x5c, };
周琰杰 (Zhou Yanjie)b2954742020-02-16 19:17:08 +08001450static int x1830_lcd_rgb_18bit_pins[] = {
1451 0x62, 0x63, 0x64, 0x65, 0x66, 0x67,
1452 0x68, 0x69, 0x6c, 0x6d, 0x6e, 0x6f,
1453 0x70, 0x71, 0x72, 0x73, 0x76, 0x77,
1454 0x78, 0x79, 0x7a, 0x7b,
1455};
1456static int x1830_lcd_slcd_8bit_pins[] = {
1457 0x62, 0x63, 0x64, 0x65, 0x66, 0x67, 0x6c, 0x6d,
1458 0x69, 0x72, 0x73, 0x7b, 0x7a,
1459};
1460static int x1830_lcd_slcd_16bit_pins[] = {
1461 0x6e, 0x6f, 0x70, 0x71, 0x76, 0x77, 0x78, 0x79,
1462};
周琰杰 (Zhou Yanjie)d7da2a12019-12-16 00:21:04 +08001463static int x1830_pwm_pwm0_b_pins[] = { 0x31, };
1464static int x1830_pwm_pwm0_c_pins[] = { 0x4b, };
1465static int x1830_pwm_pwm1_b_pins[] = { 0x32, };
1466static int x1830_pwm_pwm1_c_pins[] = { 0x4c, };
1467static int x1830_pwm_pwm2_c_8_pins[] = { 0x48, };
1468static int x1830_pwm_pwm2_c_13_pins[] = { 0x4d, };
1469static int x1830_pwm_pwm3_c_9_pins[] = { 0x49, };
1470static int x1830_pwm_pwm3_c_14_pins[] = { 0x4e, };
1471static int x1830_pwm_pwm4_c_15_pins[] = { 0x4f, };
1472static int x1830_pwm_pwm4_c_25_pins[] = { 0x59, };
1473static int x1830_pwm_pwm5_c_16_pins[] = { 0x50, };
1474static int x1830_pwm_pwm5_c_26_pins[] = { 0x5a, };
1475static int x1830_pwm_pwm6_c_17_pins[] = { 0x51, };
1476static int x1830_pwm_pwm6_c_27_pins[] = { 0x5b, };
1477static int x1830_pwm_pwm7_c_18_pins[] = { 0x52, };
1478static int x1830_pwm_pwm7_c_28_pins[] = { 0x5c, };
1479static int x1830_mac_pins[] = {
1480 0x29, 0x30, 0x2f, 0x28, 0x2e, 0x2d, 0x2a, 0x2b, 0x26, 0x27,
1481};
1482
1483static int x1830_uart0_data_funcs[] = { 0, 0, };
1484static int x1830_uart0_hwflow_funcs[] = { 0, 0, };
1485static int x1830_uart1_data_funcs[] = { 0, 0, };
1486static int x1830_sfc_funcs[] = { 1, 1, 1, 1, 1, 1, };
1487static int x1830_ssi0_dt_funcs[] = { 0, };
1488static int x1830_ssi0_dr_funcs[] = { 0, };
1489static int x1830_ssi0_clk_funcs[] = { 0, };
1490static int x1830_ssi0_gpc_funcs[] = { 0, };
1491static int x1830_ssi0_ce0_funcs[] = { 0, };
1492static int x1830_ssi0_ce1_funcs[] = { 0, };
1493static int x1830_ssi1_dt_c_funcs[] = { 1, };
1494static int x1830_ssi1_dr_c_funcs[] = { 1, };
1495static int x1830_ssi1_clk_c_funcs[] = { 1, };
1496static int x1830_ssi1_gpc_c_funcs[] = { 1, };
1497static int x1830_ssi1_ce0_c_funcs[] = { 1, };
1498static int x1830_ssi1_ce1_c_funcs[] = { 1, };
1499static int x1830_ssi1_dt_d_funcs[] = { 2, };
1500static int x1830_ssi1_dr_d_funcs[] = { 2, };
1501static int x1830_ssi1_clk_d_funcs[] = { 2, };
1502static int x1830_ssi1_gpc_d_funcs[] = { 2, };
1503static int x1830_ssi1_ce0_d_funcs[] = { 2, };
1504static int x1830_ssi1_ce1_d_funcs[] = { 2, };
1505static int x1830_mmc0_1bit_funcs[] = { 0, 0, 0, };
1506static int x1830_mmc0_4bit_funcs[] = { 0, 0, 0, };
1507static int x1830_mmc1_1bit_funcs[] = { 0, 0, 0, };
1508static int x1830_mmc1_4bit_funcs[] = { 0, 0, 0, };
1509static int x1830_i2c0_funcs[] = { 1, 1, };
1510static int x1830_i2c1_funcs[] = { 0, 0, };
1511static int x1830_i2c2_funcs[] = { 1, 1, };
周琰杰 (Zhou Yanjie)b2954742020-02-16 19:17:08 +08001512static int x1830_lcd_rgb_18bit_funcs[] = {
1513 0, 0, 0, 0, 0, 0,
1514 0, 0, 0, 0, 0, 0,
1515 0, 0, 0, 0, 0, 0,
1516 0, 0, 0, 0,
1517};
1518static int x1830_lcd_slcd_8bit_funcs[] = {
1519 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1520};
1521static int x1830_lcd_slcd_16bit_funcs[] = { 1, 1, 1, 1, 1, 1, 1, 1, };
周琰杰 (Zhou Yanjie)d7da2a12019-12-16 00:21:04 +08001522static int x1830_pwm_pwm0_b_funcs[] = { 0, };
1523static int x1830_pwm_pwm0_c_funcs[] = { 1, };
1524static int x1830_pwm_pwm1_b_funcs[] = { 0, };
1525static int x1830_pwm_pwm1_c_funcs[] = { 1, };
1526static int x1830_pwm_pwm2_c_8_funcs[] = { 0, };
1527static int x1830_pwm_pwm2_c_13_funcs[] = { 1, };
1528static int x1830_pwm_pwm3_c_9_funcs[] = { 0, };
1529static int x1830_pwm_pwm3_c_14_funcs[] = { 1, };
1530static int x1830_pwm_pwm4_c_15_funcs[] = { 1, };
1531static int x1830_pwm_pwm4_c_25_funcs[] = { 0, };
1532static int x1830_pwm_pwm5_c_16_funcs[] = { 1, };
1533static int x1830_pwm_pwm5_c_26_funcs[] = { 0, };
1534static int x1830_pwm_pwm6_c_17_funcs[] = { 1, };
1535static int x1830_pwm_pwm6_c_27_funcs[] = { 0, };
1536static int x1830_pwm_pwm7_c_18_funcs[] = { 1, };
1537static int x1830_pwm_pwm7_c_28_funcs[] = { 0, };
1538static int x1830_mac_funcs[] = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, };
1539
1540static const struct group_desc x1830_groups[] = {
1541 INGENIC_PIN_GROUP("uart0-data", x1830_uart0_data),
1542 INGENIC_PIN_GROUP("uart0-hwflow", x1830_uart0_hwflow),
1543 INGENIC_PIN_GROUP("uart1-data", x1830_uart1_data),
1544 INGENIC_PIN_GROUP("sfc", x1830_sfc),
1545 INGENIC_PIN_GROUP("ssi0-dt", x1830_ssi0_dt),
1546 INGENIC_PIN_GROUP("ssi0-dr", x1830_ssi0_dr),
1547 INGENIC_PIN_GROUP("ssi0-clk", x1830_ssi0_clk),
1548 INGENIC_PIN_GROUP("ssi0-gpc", x1830_ssi0_gpc),
1549 INGENIC_PIN_GROUP("ssi0-ce0", x1830_ssi0_ce0),
1550 INGENIC_PIN_GROUP("ssi0-ce1", x1830_ssi0_ce1),
1551 INGENIC_PIN_GROUP("ssi1-dt-c", x1830_ssi1_dt_c),
1552 INGENIC_PIN_GROUP("ssi1-dr-c", x1830_ssi1_dr_c),
1553 INGENIC_PIN_GROUP("ssi1-clk-c", x1830_ssi1_clk_c),
1554 INGENIC_PIN_GROUP("ssi1-gpc-c", x1830_ssi1_gpc_c),
1555 INGENIC_PIN_GROUP("ssi1-ce0-c", x1830_ssi1_ce0_c),
1556 INGENIC_PIN_GROUP("ssi1-ce1-c", x1830_ssi1_ce1_c),
1557 INGENIC_PIN_GROUP("ssi1-dt-d", x1830_ssi1_dt_d),
1558 INGENIC_PIN_GROUP("ssi1-dr-d", x1830_ssi1_dr_d),
1559 INGENIC_PIN_GROUP("ssi1-clk-d", x1830_ssi1_clk_d),
1560 INGENIC_PIN_GROUP("ssi1-gpc-d", x1830_ssi1_gpc_d),
1561 INGENIC_PIN_GROUP("ssi1-ce0-d", x1830_ssi1_ce0_d),
1562 INGENIC_PIN_GROUP("ssi1-ce1-d", x1830_ssi1_ce1_d),
1563 INGENIC_PIN_GROUP("mmc0-1bit", x1830_mmc0_1bit),
1564 INGENIC_PIN_GROUP("mmc0-4bit", x1830_mmc0_4bit),
1565 INGENIC_PIN_GROUP("mmc1-1bit", x1830_mmc1_1bit),
1566 INGENIC_PIN_GROUP("mmc1-4bit", x1830_mmc1_4bit),
1567 INGENIC_PIN_GROUP("i2c0-data", x1830_i2c0),
1568 INGENIC_PIN_GROUP("i2c1-data", x1830_i2c1),
1569 INGENIC_PIN_GROUP("i2c2-data", x1830_i2c2),
周琰杰 (Zhou Yanjie)b2954742020-02-16 19:17:08 +08001570 INGENIC_PIN_GROUP("lcd-rgb-18bit", x1830_lcd_rgb_18bit),
1571 INGENIC_PIN_GROUP("lcd-slcd-8bit", x1830_lcd_slcd_8bit),
1572 INGENIC_PIN_GROUP("lcd-slcd-16bit", x1830_lcd_slcd_16bit),
1573 { "lcd-no-pins", },
周琰杰 (Zhou Yanjie)d7da2a12019-12-16 00:21:04 +08001574 INGENIC_PIN_GROUP("pwm0-b", x1830_pwm_pwm0_b),
1575 INGENIC_PIN_GROUP("pwm0-c", x1830_pwm_pwm0_c),
1576 INGENIC_PIN_GROUP("pwm1-b", x1830_pwm_pwm1_b),
1577 INGENIC_PIN_GROUP("pwm1-c", x1830_pwm_pwm1_c),
1578 INGENIC_PIN_GROUP("pwm2-c-8", x1830_pwm_pwm2_c_8),
1579 INGENIC_PIN_GROUP("pwm2-c-13", x1830_pwm_pwm2_c_13),
1580 INGENIC_PIN_GROUP("pwm3-c-9", x1830_pwm_pwm3_c_9),
1581 INGENIC_PIN_GROUP("pwm3-c-14", x1830_pwm_pwm3_c_14),
1582 INGENIC_PIN_GROUP("pwm4-c-15", x1830_pwm_pwm4_c_15),
1583 INGENIC_PIN_GROUP("pwm4-c-25", x1830_pwm_pwm4_c_25),
1584 INGENIC_PIN_GROUP("pwm5-c-16", x1830_pwm_pwm5_c_16),
1585 INGENIC_PIN_GROUP("pwm5-c-26", x1830_pwm_pwm5_c_26),
1586 INGENIC_PIN_GROUP("pwm6-c-17", x1830_pwm_pwm6_c_17),
1587 INGENIC_PIN_GROUP("pwm6-c-27", x1830_pwm_pwm6_c_27),
1588 INGENIC_PIN_GROUP("pwm7-c-18", x1830_pwm_pwm7_c_18),
1589 INGENIC_PIN_GROUP("pwm7-c-28", x1830_pwm_pwm7_c_28),
1590 INGENIC_PIN_GROUP("mac", x1830_mac),
1591};
1592
1593static const char *x1830_uart0_groups[] = { "uart0-data", "uart0-hwflow", };
1594static const char *x1830_uart1_groups[] = { "uart1-data", };
1595static const char *x1830_sfc_groups[] = { "sfc", };
1596static const char *x1830_ssi0_groups[] = {
1597 "ssi0-dt", "ssi0-dr", "ssi0-clk", "ssi0-gpc", "ssi0-ce0", "ssi0-ce1",
1598};
1599static const char *x1830_ssi1_groups[] = {
1600 "ssi1-dt-c", "ssi1-dt-d",
1601 "ssi1-dr-c", "ssi1-dr-d",
1602 "ssi1-clk-c", "ssi1-clk-d",
1603 "ssi1-gpc-c", "ssi1-gpc-d",
1604 "ssi1-ce0-c", "ssi1-ce0-d",
1605 "ssi1-ce1-c", "ssi1-ce1-d",
1606};
1607static const char *x1830_mmc0_groups[] = { "mmc0-1bit", "mmc0-4bit", };
1608static const char *x1830_mmc1_groups[] = { "mmc1-1bit", "mmc1-4bit", };
1609static const char *x1830_i2c0_groups[] = { "i2c0-data", };
1610static const char *x1830_i2c1_groups[] = { "i2c1-data", };
1611static const char *x1830_i2c2_groups[] = { "i2c2-data", };
周琰杰 (Zhou Yanjie)b2954742020-02-16 19:17:08 +08001612static const char *x1830_lcd_groups[] = {
1613 "lcd-rgb-18bit", "lcd-slcd-8bit", "lcd-slcd-16bit", "lcd-no-pins",
1614};
周琰杰 (Zhou Yanjie)d7da2a12019-12-16 00:21:04 +08001615static const char *x1830_pwm0_groups[] = { "pwm0-b", "pwm0-c", };
1616static const char *x1830_pwm1_groups[] = { "pwm1-b", "pwm1-c", };
1617static const char *x1830_pwm2_groups[] = { "pwm2-c-8", "pwm2-c-13", };
1618static const char *x1830_pwm3_groups[] = { "pwm3-c-9", "pwm3-c-14", };
1619static const char *x1830_pwm4_groups[] = { "pwm4-c-15", "pwm4-c-25", };
1620static const char *x1830_pwm5_groups[] = { "pwm5-c-16", "pwm5-c-26", };
1621static const char *x1830_pwm6_groups[] = { "pwm6-c-17", "pwm6-c-27", };
1622static const char *x1830_pwm7_groups[] = { "pwm7-c-18", "pwm7-c-28", };
1623static const char *x1830_mac_groups[] = { "mac", };
1624
1625static const struct function_desc x1830_functions[] = {
1626 { "uart0", x1830_uart0_groups, ARRAY_SIZE(x1830_uart0_groups), },
1627 { "uart1", x1830_uart1_groups, ARRAY_SIZE(x1830_uart1_groups), },
1628 { "sfc", x1830_sfc_groups, ARRAY_SIZE(x1830_sfc_groups), },
1629 { "ssi0", x1830_ssi0_groups, ARRAY_SIZE(x1830_ssi0_groups), },
1630 { "ssi1", x1830_ssi1_groups, ARRAY_SIZE(x1830_ssi1_groups), },
1631 { "mmc0", x1830_mmc0_groups, ARRAY_SIZE(x1830_mmc0_groups), },
1632 { "mmc1", x1830_mmc1_groups, ARRAY_SIZE(x1830_mmc1_groups), },
1633 { "i2c0", x1830_i2c0_groups, ARRAY_SIZE(x1830_i2c0_groups), },
1634 { "i2c1", x1830_i2c1_groups, ARRAY_SIZE(x1830_i2c1_groups), },
1635 { "i2c2", x1830_i2c2_groups, ARRAY_SIZE(x1830_i2c2_groups), },
周琰杰 (Zhou Yanjie)b2954742020-02-16 19:17:08 +08001636 { "lcd", x1830_lcd_groups, ARRAY_SIZE(x1830_lcd_groups), },
周琰杰 (Zhou Yanjie)d7da2a12019-12-16 00:21:04 +08001637 { "pwm0", x1830_pwm0_groups, ARRAY_SIZE(x1830_pwm0_groups), },
1638 { "pwm1", x1830_pwm1_groups, ARRAY_SIZE(x1830_pwm1_groups), },
1639 { "pwm2", x1830_pwm2_groups, ARRAY_SIZE(x1830_pwm2_groups), },
1640 { "pwm3", x1830_pwm3_groups, ARRAY_SIZE(x1830_pwm3_groups), },
1641 { "pwm4", x1830_pwm4_groups, ARRAY_SIZE(x1830_pwm4_groups), },
1642 { "pwm5", x1830_pwm5_groups, ARRAY_SIZE(x1830_pwm4_groups), },
1643 { "pwm6", x1830_pwm6_groups, ARRAY_SIZE(x1830_pwm4_groups), },
1644 { "pwm7", x1830_pwm7_groups, ARRAY_SIZE(x1830_pwm4_groups), },
1645 { "mac", x1830_mac_groups, ARRAY_SIZE(x1830_mac_groups), },
1646};
1647
1648static const struct ingenic_chip_info x1830_chip_info = {
1649 .num_chips = 4,
1650 .reg_offset = 0x1000,
Paul Cercueilbaf15642020-01-07 00:27:08 +01001651 .version = ID_X1830,
周琰杰 (Zhou Yanjie)d7da2a12019-12-16 00:21:04 +08001652 .groups = x1830_groups,
1653 .num_groups = ARRAY_SIZE(x1830_groups),
1654 .functions = x1830_functions,
1655 .num_functions = ARRAY_SIZE(x1830_functions),
1656 .pull_ups = x1830_pull_ups,
1657 .pull_downs = x1830_pull_downs,
1658};
1659
Zhou Yanjieb71c1842019-01-28 23:19:59 +08001660static u32 ingenic_gpio_read_reg(struct ingenic_gpio_chip *jzgc, u8 reg)
Paul Cercueile72394e2018-08-21 18:42:32 +02001661{
1662 unsigned int val;
1663
1664 regmap_read(jzgc->jzpc->map, jzgc->reg_base + reg, &val);
1665
1666 return (u32) val;
1667}
1668
Zhou Yanjieb71c1842019-01-28 23:19:59 +08001669static void ingenic_gpio_set_bit(struct ingenic_gpio_chip *jzgc,
Paul Cercueile72394e2018-08-21 18:42:32 +02001670 u8 reg, u8 offset, bool set)
1671{
1672 if (set)
1673 reg = REG_SET(reg);
1674 else
1675 reg = REG_CLEAR(reg);
1676
1677 regmap_write(jzgc->jzpc->map, jzgc->reg_base + reg, BIT(offset));
1678}
1679
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001680static void ingenic_gpio_shadow_set_bit(struct ingenic_gpio_chip *jzgc,
1681 u8 reg, u8 offset, bool set)
1682{
1683 if (set)
1684 reg = REG_SET(reg);
1685 else
1686 reg = REG_CLEAR(reg);
1687
周琰杰 (Zhou Yanjie)d7da2a12019-12-16 00:21:04 +08001688 regmap_write(jzgc->jzpc->map, REG_PZ_BASE(
1689 jzgc->jzpc->info->reg_offset) + reg, BIT(offset));
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001690}
1691
1692static void ingenic_gpio_shadow_set_bit_load(struct ingenic_gpio_chip *jzgc)
1693{
周琰杰 (Zhou Yanjie)d7da2a12019-12-16 00:21:04 +08001694 regmap_write(jzgc->jzpc->map, REG_PZ_GID2LD(
1695 jzgc->jzpc->info->reg_offset),
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001696 jzgc->gc.base / PINS_PER_GPIO_CHIP);
1697}
1698
Paul Cercueile72394e2018-08-21 18:42:32 +02001699static inline bool ingenic_gpio_get_value(struct ingenic_gpio_chip *jzgc,
1700 u8 offset)
1701{
Zhou Yanjieb71c1842019-01-28 23:19:59 +08001702 unsigned int val = ingenic_gpio_read_reg(jzgc, GPIO_PIN);
Paul Cercueile72394e2018-08-21 18:42:32 +02001703
1704 return !!(val & BIT(offset));
1705}
1706
1707static void ingenic_gpio_set_value(struct ingenic_gpio_chip *jzgc,
1708 u8 offset, int value)
1709{
Paul Cercueilbaf15642020-01-07 00:27:08 +01001710 if (jzgc->jzpc->info->version >= ID_JZ4760)
Zhou Yanjie0257595a2019-07-14 11:53:52 +08001711 ingenic_gpio_set_bit(jzgc, JZ4760_GPIO_PAT0, offset, !!value);
Paul Cercueile72394e2018-08-21 18:42:32 +02001712 else
Zhou Yanjieb71c1842019-01-28 23:19:59 +08001713 ingenic_gpio_set_bit(jzgc, JZ4740_GPIO_DATA, offset, !!value);
Paul Cercueile72394e2018-08-21 18:42:32 +02001714}
1715
1716static void irq_set_type(struct ingenic_gpio_chip *jzgc,
1717 u8 offset, unsigned int type)
1718{
1719 u8 reg1, reg2;
Paul Cercueilf831f932020-01-07 00:27:10 +01001720 bool val1, val2;
1721
1722 switch (type) {
1723 case IRQ_TYPE_EDGE_RISING:
1724 val1 = val2 = true;
1725 break;
1726 case IRQ_TYPE_EDGE_FALLING:
1727 val1 = false;
1728 val2 = true;
1729 break;
1730 case IRQ_TYPE_LEVEL_HIGH:
1731 val1 = true;
1732 val2 = false;
1733 break;
1734 case IRQ_TYPE_LEVEL_LOW:
1735 default:
1736 val1 = val2 = false;
1737 break;
1738 }
Paul Cercueile72394e2018-08-21 18:42:32 +02001739
Paul Cercueilbaf15642020-01-07 00:27:08 +01001740 if (jzgc->jzpc->info->version >= ID_JZ4760) {
Zhou Yanjie0257595a2019-07-14 11:53:52 +08001741 reg1 = JZ4760_GPIO_PAT1;
1742 reg2 = JZ4760_GPIO_PAT0;
Paul Cercueile72394e2018-08-21 18:42:32 +02001743 } else {
1744 reg1 = JZ4740_GPIO_TRIG;
1745 reg2 = JZ4740_GPIO_DIR;
1746 }
1747
Paul Cercueilf831f932020-01-07 00:27:10 +01001748 if (jzgc->jzpc->info->version >= ID_X1000) {
1749 ingenic_gpio_shadow_set_bit(jzgc, reg2, offset, val1);
1750 ingenic_gpio_shadow_set_bit(jzgc, reg1, offset, val2);
1751 ingenic_gpio_shadow_set_bit_load(jzgc);
1752 } else {
1753 ingenic_gpio_set_bit(jzgc, reg2, offset, val1);
1754 ingenic_gpio_set_bit(jzgc, reg1, offset, val2);
Paul Cercueile72394e2018-08-21 18:42:32 +02001755 }
1756}
1757
1758static void ingenic_gpio_irq_mask(struct irq_data *irqd)
1759{
1760 struct gpio_chip *gc = irq_data_get_irq_chip_data(irqd);
1761 struct ingenic_gpio_chip *jzgc = gpiochip_get_data(gc);
1762
Zhou Yanjieb71c1842019-01-28 23:19:59 +08001763 ingenic_gpio_set_bit(jzgc, GPIO_MSK, irqd->hwirq, true);
Paul Cercueile72394e2018-08-21 18:42:32 +02001764}
1765
1766static void ingenic_gpio_irq_unmask(struct irq_data *irqd)
1767{
1768 struct gpio_chip *gc = irq_data_get_irq_chip_data(irqd);
1769 struct ingenic_gpio_chip *jzgc = gpiochip_get_data(gc);
1770
Zhou Yanjieb71c1842019-01-28 23:19:59 +08001771 ingenic_gpio_set_bit(jzgc, GPIO_MSK, irqd->hwirq, false);
Paul Cercueile72394e2018-08-21 18:42:32 +02001772}
1773
1774static void ingenic_gpio_irq_enable(struct irq_data *irqd)
1775{
1776 struct gpio_chip *gc = irq_data_get_irq_chip_data(irqd);
1777 struct ingenic_gpio_chip *jzgc = gpiochip_get_data(gc);
1778 int irq = irqd->hwirq;
1779
Paul Cercueilbaf15642020-01-07 00:27:08 +01001780 if (jzgc->jzpc->info->version >= ID_JZ4760)
Zhou Yanjie0257595a2019-07-14 11:53:52 +08001781 ingenic_gpio_set_bit(jzgc, JZ4760_GPIO_INT, irq, true);
Paul Cercueile72394e2018-08-21 18:42:32 +02001782 else
Zhou Yanjieb71c1842019-01-28 23:19:59 +08001783 ingenic_gpio_set_bit(jzgc, JZ4740_GPIO_SELECT, irq, true);
Paul Cercueile72394e2018-08-21 18:42:32 +02001784
1785 ingenic_gpio_irq_unmask(irqd);
1786}
1787
1788static void ingenic_gpio_irq_disable(struct irq_data *irqd)
1789{
1790 struct gpio_chip *gc = irq_data_get_irq_chip_data(irqd);
1791 struct ingenic_gpio_chip *jzgc = gpiochip_get_data(gc);
1792 int irq = irqd->hwirq;
1793
1794 ingenic_gpio_irq_mask(irqd);
1795
Paul Cercueilbaf15642020-01-07 00:27:08 +01001796 if (jzgc->jzpc->info->version >= ID_JZ4760)
Zhou Yanjie0257595a2019-07-14 11:53:52 +08001797 ingenic_gpio_set_bit(jzgc, JZ4760_GPIO_INT, irq, false);
Paul Cercueile72394e2018-08-21 18:42:32 +02001798 else
Zhou Yanjieb71c1842019-01-28 23:19:59 +08001799 ingenic_gpio_set_bit(jzgc, JZ4740_GPIO_SELECT, irq, false);
Paul Cercueile72394e2018-08-21 18:42:32 +02001800}
1801
1802static void ingenic_gpio_irq_ack(struct irq_data *irqd)
1803{
1804 struct gpio_chip *gc = irq_data_get_irq_chip_data(irqd);
1805 struct ingenic_gpio_chip *jzgc = gpiochip_get_data(gc);
1806 int irq = irqd->hwirq;
1807 bool high;
1808
1809 if (irqd_get_trigger_type(irqd) == IRQ_TYPE_EDGE_BOTH) {
1810 /*
1811 * Switch to an interrupt for the opposite edge to the one that
1812 * triggered the interrupt being ACKed.
1813 */
1814 high = ingenic_gpio_get_value(jzgc, irq);
1815 if (high)
1816 irq_set_type(jzgc, irq, IRQ_TYPE_EDGE_FALLING);
1817 else
1818 irq_set_type(jzgc, irq, IRQ_TYPE_EDGE_RISING);
1819 }
1820
Paul Cercueilbaf15642020-01-07 00:27:08 +01001821 if (jzgc->jzpc->info->version >= ID_JZ4760)
Zhou Yanjie0257595a2019-07-14 11:53:52 +08001822 ingenic_gpio_set_bit(jzgc, JZ4760_GPIO_FLAG, irq, false);
Paul Cercueile72394e2018-08-21 18:42:32 +02001823 else
Zhou Yanjieb71c1842019-01-28 23:19:59 +08001824 ingenic_gpio_set_bit(jzgc, JZ4740_GPIO_DATA, irq, true);
Paul Cercueile72394e2018-08-21 18:42:32 +02001825}
1826
1827static int ingenic_gpio_irq_set_type(struct irq_data *irqd, unsigned int type)
1828{
1829 struct gpio_chip *gc = irq_data_get_irq_chip_data(irqd);
1830 struct ingenic_gpio_chip *jzgc = gpiochip_get_data(gc);
1831
1832 switch (type) {
1833 case IRQ_TYPE_EDGE_BOTH:
1834 case IRQ_TYPE_EDGE_RISING:
1835 case IRQ_TYPE_EDGE_FALLING:
1836 irq_set_handler_locked(irqd, handle_edge_irq);
1837 break;
1838 case IRQ_TYPE_LEVEL_HIGH:
1839 case IRQ_TYPE_LEVEL_LOW:
1840 irq_set_handler_locked(irqd, handle_level_irq);
1841 break;
1842 default:
1843 irq_set_handler_locked(irqd, handle_bad_irq);
1844 }
1845
1846 if (type == IRQ_TYPE_EDGE_BOTH) {
1847 /*
1848 * The hardware does not support interrupts on both edges. The
1849 * best we can do is to set up a single-edge interrupt and then
1850 * switch to the opposing edge when ACKing the interrupt.
1851 */
1852 bool high = ingenic_gpio_get_value(jzgc, irqd->hwirq);
1853
1854 type = high ? IRQ_TYPE_EDGE_FALLING : IRQ_TYPE_EDGE_RISING;
1855 }
1856
1857 irq_set_type(jzgc, irqd->hwirq, type);
1858 return 0;
1859}
1860
1861static int ingenic_gpio_irq_set_wake(struct irq_data *irqd, unsigned int on)
1862{
1863 struct gpio_chip *gc = irq_data_get_irq_chip_data(irqd);
1864 struct ingenic_gpio_chip *jzgc = gpiochip_get_data(gc);
1865
1866 return irq_set_irq_wake(jzgc->irq, on);
1867}
1868
1869static void ingenic_gpio_irq_handler(struct irq_desc *desc)
1870{
1871 struct gpio_chip *gc = irq_desc_get_handler_data(desc);
1872 struct ingenic_gpio_chip *jzgc = gpiochip_get_data(gc);
1873 struct irq_chip *irq_chip = irq_data_get_irq_chip(&desc->irq_data);
1874 unsigned long flag, i;
1875
1876 chained_irq_enter(irq_chip, desc);
1877
Paul Cercueilbaf15642020-01-07 00:27:08 +01001878 if (jzgc->jzpc->info->version >= ID_JZ4760)
Zhou Yanjie0257595a2019-07-14 11:53:52 +08001879 flag = ingenic_gpio_read_reg(jzgc, JZ4760_GPIO_FLAG);
Paul Cercueile72394e2018-08-21 18:42:32 +02001880 else
Zhou Yanjieb71c1842019-01-28 23:19:59 +08001881 flag = ingenic_gpio_read_reg(jzgc, JZ4740_GPIO_FLAG);
Paul Cercueile72394e2018-08-21 18:42:32 +02001882
1883 for_each_set_bit(i, &flag, 32)
1884 generic_handle_irq(irq_linear_revmap(gc->irq.domain, i));
1885 chained_irq_exit(irq_chip, desc);
1886}
1887
1888static void ingenic_gpio_set(struct gpio_chip *gc,
1889 unsigned int offset, int value)
1890{
1891 struct ingenic_gpio_chip *jzgc = gpiochip_get_data(gc);
1892
1893 ingenic_gpio_set_value(jzgc, offset, value);
1894}
1895
1896static int ingenic_gpio_get(struct gpio_chip *gc, unsigned int offset)
1897{
1898 struct ingenic_gpio_chip *jzgc = gpiochip_get_data(gc);
1899
1900 return (int) ingenic_gpio_get_value(jzgc, offset);
1901}
1902
1903static int ingenic_gpio_direction_input(struct gpio_chip *gc,
1904 unsigned int offset)
1905{
1906 return pinctrl_gpio_direction_input(gc->base + offset);
1907}
1908
1909static int ingenic_gpio_direction_output(struct gpio_chip *gc,
1910 unsigned int offset, int value)
1911{
1912 ingenic_gpio_set(gc, offset, value);
1913 return pinctrl_gpio_direction_output(gc->base + offset);
1914}
1915
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02001916static inline void ingenic_config_pin(struct ingenic_pinctrl *jzpc,
1917 unsigned int pin, u8 reg, bool set)
1918{
1919 unsigned int idx = pin % PINS_PER_GPIO_CHIP;
1920 unsigned int offt = pin / PINS_PER_GPIO_CHIP;
1921
周琰杰 (Zhou Yanjie)f742e5e2019-12-16 00:21:02 +08001922 regmap_write(jzpc->map, offt * jzpc->info->reg_offset +
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02001923 (set ? REG_SET(reg) : REG_CLEAR(reg)), BIT(idx));
1924}
1925
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001926static inline void ingenic_shadow_config_pin(struct ingenic_pinctrl *jzpc,
1927 unsigned int pin, u8 reg, bool set)
1928{
1929 unsigned int idx = pin % PINS_PER_GPIO_CHIP;
1930
周琰杰 (Zhou Yanjie)f742e5e2019-12-16 00:21:02 +08001931 regmap_write(jzpc->map, REG_PZ_BASE(jzpc->info->reg_offset) +
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001932 (set ? REG_SET(reg) : REG_CLEAR(reg)), BIT(idx));
1933}
1934
1935static inline void ingenic_shadow_config_pin_load(struct ingenic_pinctrl *jzpc,
1936 unsigned int pin)
1937{
周琰杰 (Zhou Yanjie)d7da2a12019-12-16 00:21:04 +08001938 regmap_write(jzpc->map, REG_PZ_GID2LD(jzpc->info->reg_offset),
1939 pin / PINS_PER_GPIO_CHIP);
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08001940}
1941
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02001942static inline bool ingenic_get_pin_config(struct ingenic_pinctrl *jzpc,
1943 unsigned int pin, u8 reg)
1944{
1945 unsigned int idx = pin % PINS_PER_GPIO_CHIP;
1946 unsigned int offt = pin / PINS_PER_GPIO_CHIP;
1947 unsigned int val;
1948
周琰杰 (Zhou Yanjie)f742e5e2019-12-16 00:21:02 +08001949 regmap_read(jzpc->map, offt * jzpc->info->reg_offset + reg, &val);
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02001950
1951 return val & BIT(idx);
1952}
1953
Paul Cercueilebd66512018-08-21 18:42:33 +02001954static int ingenic_gpio_get_direction(struct gpio_chip *gc, unsigned int offset)
1955{
1956 struct ingenic_gpio_chip *jzgc = gpiochip_get_data(gc);
1957 struct ingenic_pinctrl *jzpc = jzgc->jzpc;
1958 unsigned int pin = gc->base + offset;
1959
Matti Vaittinen3c827872020-02-14 15:57:12 +02001960 if (jzpc->info->version >= ID_JZ4760) {
1961 if (ingenic_get_pin_config(jzpc, pin, JZ4760_GPIO_PAT1))
1962 return GPIO_LINE_DIRECTION_IN;
1963 return GPIO_LINE_DIRECTION_OUT;
1964 }
Paul Cercueilebd66512018-08-21 18:42:33 +02001965
1966 if (ingenic_get_pin_config(jzpc, pin, JZ4740_GPIO_SELECT))
Matti Vaittinen3c827872020-02-14 15:57:12 +02001967 return GPIO_LINE_DIRECTION_IN;
Paul Cercueilebd66512018-08-21 18:42:33 +02001968
Matti Vaittinen3c827872020-02-14 15:57:12 +02001969 if (ingenic_get_pin_config(jzpc, pin, JZ4740_GPIO_DIR))
1970 return GPIO_LINE_DIRECTION_OUT;
1971
1972 return GPIO_LINE_DIRECTION_IN;
Paul Cercueilebd66512018-08-21 18:42:33 +02001973}
1974
Julia Lawall5bf7b842017-08-10 12:06:23 +02001975static const struct pinctrl_ops ingenic_pctlops = {
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02001976 .get_groups_count = pinctrl_generic_get_group_count,
1977 .get_group_name = pinctrl_generic_get_group_name,
1978 .get_group_pins = pinctrl_generic_get_group_pins,
1979 .dt_node_to_map = pinconf_generic_dt_node_to_map_all,
1980 .dt_free_map = pinconf_generic_dt_free_map,
1981};
1982
Paul Cercueil9a0f1342020-05-03 18:45:49 +02001983static int ingenic_gpio_irq_request(struct irq_data *data)
1984{
1985 struct gpio_chip *gpio_chip = irq_data_get_irq_chip_data(data);
1986 int ret;
1987
1988 ret = ingenic_gpio_direction_input(gpio_chip, data->hwirq);
1989 if (ret)
1990 return ret;
1991
1992 return gpiochip_reqres_irq(gpio_chip, data->hwirq);
1993}
1994
1995static void ingenic_gpio_irq_release(struct irq_data *data)
1996{
1997 struct gpio_chip *gpio_chip = irq_data_get_irq_chip_data(data);
1998
1999 return gpiochip_relres_irq(gpio_chip, data->hwirq);
2000}
2001
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002002static int ingenic_pinmux_set_pin_fn(struct ingenic_pinctrl *jzpc,
2003 int pin, int func)
2004{
2005 unsigned int idx = pin % PINS_PER_GPIO_CHIP;
2006 unsigned int offt = pin / PINS_PER_GPIO_CHIP;
2007
2008 dev_dbg(jzpc->dev, "set pin P%c%u to function %u\n",
2009 'A' + offt, idx, func);
2010
Paul Cercueilbaf15642020-01-07 00:27:08 +01002011 if (jzpc->info->version >= ID_X1000) {
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08002012 ingenic_shadow_config_pin(jzpc, pin, JZ4760_GPIO_INT, false);
2013 ingenic_shadow_config_pin(jzpc, pin, GPIO_MSK, false);
2014 ingenic_shadow_config_pin(jzpc, pin, JZ4760_GPIO_PAT1, func & 0x2);
2015 ingenic_shadow_config_pin(jzpc, pin, JZ4760_GPIO_PAT0, func & 0x1);
2016 ingenic_shadow_config_pin_load(jzpc, pin);
Paul Cercueilbaf15642020-01-07 00:27:08 +01002017 } else if (jzpc->info->version >= ID_JZ4760) {
Zhou Yanjie0257595a2019-07-14 11:53:52 +08002018 ingenic_config_pin(jzpc, pin, JZ4760_GPIO_INT, false);
Paul Cercueile72394e2018-08-21 18:42:32 +02002019 ingenic_config_pin(jzpc, pin, GPIO_MSK, false);
Zhou Yanjie0257595a2019-07-14 11:53:52 +08002020 ingenic_config_pin(jzpc, pin, JZ4760_GPIO_PAT1, func & 0x2);
2021 ingenic_config_pin(jzpc, pin, JZ4760_GPIO_PAT0, func & 0x1);
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002022 } else {
2023 ingenic_config_pin(jzpc, pin, JZ4740_GPIO_FUNC, true);
2024 ingenic_config_pin(jzpc, pin, JZ4740_GPIO_TRIG, func & 0x2);
2025 ingenic_config_pin(jzpc, pin, JZ4740_GPIO_SELECT, func > 0);
2026 }
2027
2028 return 0;
2029}
2030
2031static int ingenic_pinmux_set_mux(struct pinctrl_dev *pctldev,
2032 unsigned int selector, unsigned int group)
2033{
2034 struct ingenic_pinctrl *jzpc = pinctrl_dev_get_drvdata(pctldev);
2035 struct function_desc *func;
2036 struct group_desc *grp;
2037 unsigned int i;
2038
2039 func = pinmux_generic_get_function(pctldev, selector);
2040 if (!func)
2041 return -EINVAL;
2042
2043 grp = pinctrl_generic_get_group(pctldev, group);
2044 if (!grp)
2045 return -EINVAL;
2046
2047 dev_dbg(pctldev->dev, "enable function %s group %s\n",
2048 func->name, grp->name);
2049
2050 for (i = 0; i < grp->num_pins; i++) {
2051 int *pin_modes = grp->data;
2052
2053 ingenic_pinmux_set_pin_fn(jzpc, grp->pins[i], pin_modes[i]);
2054 }
2055
2056 return 0;
2057}
2058
2059static int ingenic_pinmux_gpio_set_direction(struct pinctrl_dev *pctldev,
2060 struct pinctrl_gpio_range *range,
2061 unsigned int pin, bool input)
2062{
2063 struct ingenic_pinctrl *jzpc = pinctrl_dev_get_drvdata(pctldev);
2064 unsigned int idx = pin % PINS_PER_GPIO_CHIP;
2065 unsigned int offt = pin / PINS_PER_GPIO_CHIP;
2066
2067 dev_dbg(pctldev->dev, "set pin P%c%u to %sput\n",
2068 'A' + offt, idx, input ? "in" : "out");
2069
Paul Cercueilbaf15642020-01-07 00:27:08 +01002070 if (jzpc->info->version >= ID_X1000) {
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08002071 ingenic_shadow_config_pin(jzpc, pin, JZ4760_GPIO_INT, false);
2072 ingenic_shadow_config_pin(jzpc, pin, GPIO_MSK, true);
2073 ingenic_shadow_config_pin(jzpc, pin, JZ4760_GPIO_PAT1, input);
2074 ingenic_shadow_config_pin_load(jzpc, pin);
Paul Cercueilbaf15642020-01-07 00:27:08 +01002075 } else if (jzpc->info->version >= ID_JZ4760) {
Zhou Yanjie0257595a2019-07-14 11:53:52 +08002076 ingenic_config_pin(jzpc, pin, JZ4760_GPIO_INT, false);
Paul Cercueile72394e2018-08-21 18:42:32 +02002077 ingenic_config_pin(jzpc, pin, GPIO_MSK, true);
Zhou Yanjie0257595a2019-07-14 11:53:52 +08002078 ingenic_config_pin(jzpc, pin, JZ4760_GPIO_PAT1, input);
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002079 } else {
2080 ingenic_config_pin(jzpc, pin, JZ4740_GPIO_SELECT, false);
Paul Cercueil0084a782018-06-27 13:49:02 +02002081 ingenic_config_pin(jzpc, pin, JZ4740_GPIO_DIR, !input);
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002082 ingenic_config_pin(jzpc, pin, JZ4740_GPIO_FUNC, false);
2083 }
2084
2085 return 0;
2086}
2087
Julia Lawall5bf7b842017-08-10 12:06:23 +02002088static const struct pinmux_ops ingenic_pmxops = {
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002089 .get_functions_count = pinmux_generic_get_function_count,
2090 .get_function_name = pinmux_generic_get_function_name,
2091 .get_function_groups = pinmux_generic_get_function_groups,
2092 .set_mux = ingenic_pinmux_set_mux,
2093 .gpio_set_direction = ingenic_pinmux_gpio_set_direction,
2094};
2095
2096static int ingenic_pinconf_get(struct pinctrl_dev *pctldev,
2097 unsigned int pin, unsigned long *config)
2098{
2099 struct ingenic_pinctrl *jzpc = pinctrl_dev_get_drvdata(pctldev);
2100 enum pin_config_param param = pinconf_to_config_param(*config);
2101 unsigned int idx = pin % PINS_PER_GPIO_CHIP;
2102 unsigned int offt = pin / PINS_PER_GPIO_CHIP;
2103 bool pull;
2104
Paul Cercueilbaf15642020-01-07 00:27:08 +01002105 if (jzpc->info->version >= ID_JZ4760)
Zhou Yanjie0257595a2019-07-14 11:53:52 +08002106 pull = !ingenic_get_pin_config(jzpc, pin, JZ4760_GPIO_PEN);
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002107 else
2108 pull = !ingenic_get_pin_config(jzpc, pin, JZ4740_GPIO_PULL_DIS);
2109
2110 switch (param) {
2111 case PIN_CONFIG_BIAS_DISABLE:
2112 if (pull)
2113 return -EINVAL;
2114 break;
2115
2116 case PIN_CONFIG_BIAS_PULL_UP:
2117 if (!pull || !(jzpc->info->pull_ups[offt] & BIT(idx)))
2118 return -EINVAL;
2119 break;
2120
2121 case PIN_CONFIG_BIAS_PULL_DOWN:
2122 if (!pull || !(jzpc->info->pull_downs[offt] & BIT(idx)))
2123 return -EINVAL;
2124 break;
2125
2126 default:
2127 return -ENOTSUPP;
2128 }
2129
2130 *config = pinconf_to_config_packed(param, 1);
2131 return 0;
2132}
2133
2134static void ingenic_set_bias(struct ingenic_pinctrl *jzpc,
周琰杰 (Zhou Yanjie)d7da2a12019-12-16 00:21:04 +08002135 unsigned int pin, unsigned int bias)
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002136{
Paul Cercueilbaf15642020-01-07 00:27:08 +01002137 if (jzpc->info->version >= ID_X1830) {
周琰杰 (Zhou Yanjie)d7da2a12019-12-16 00:21:04 +08002138 unsigned int idx = pin % PINS_PER_GPIO_CHIP;
2139 unsigned int half = PINS_PER_GPIO_CHIP / 2;
2140 unsigned int idxh = pin % half * 2;
2141 unsigned int offt = pin / PINS_PER_GPIO_CHIP;
2142
2143 if (idx < half) {
2144 regmap_write(jzpc->map, offt * jzpc->info->reg_offset +
2145 REG_CLEAR(X1830_GPIO_PEL), 3 << idxh);
2146 regmap_write(jzpc->map, offt * jzpc->info->reg_offset +
2147 REG_SET(X1830_GPIO_PEL), bias << idxh);
2148 } else {
2149 regmap_write(jzpc->map, offt * jzpc->info->reg_offset +
2150 REG_CLEAR(X1830_GPIO_PEH), 3 << idxh);
2151 regmap_write(jzpc->map, offt * jzpc->info->reg_offset +
2152 REG_SET(X1830_GPIO_PEH), bias << idxh);
2153 }
2154
Paul Cercueilbaf15642020-01-07 00:27:08 +01002155 } else if (jzpc->info->version >= ID_JZ4760) {
周琰杰 (Zhou Yanjie)d7da2a12019-12-16 00:21:04 +08002156 ingenic_config_pin(jzpc, pin, JZ4760_GPIO_PEN, !bias);
2157 } else {
2158 ingenic_config_pin(jzpc, pin, JZ4740_GPIO_PULL_DIS, !bias);
2159 }
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002160}
2161
Paul Cercueil7009d042019-11-19 16:52:10 +01002162static void ingenic_set_output_level(struct ingenic_pinctrl *jzpc,
2163 unsigned int pin, bool high)
2164{
Paul Cercueilbaf15642020-01-07 00:27:08 +01002165 if (jzpc->info->version >= ID_JZ4760)
Paul Cercueil7009d042019-11-19 16:52:10 +01002166 ingenic_config_pin(jzpc, pin, JZ4760_GPIO_PAT0, high);
2167 else
2168 ingenic_config_pin(jzpc, pin, JZ4740_GPIO_DATA, high);
2169}
2170
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002171static int ingenic_pinconf_set(struct pinctrl_dev *pctldev, unsigned int pin,
2172 unsigned long *configs, unsigned int num_configs)
2173{
2174 struct ingenic_pinctrl *jzpc = pinctrl_dev_get_drvdata(pctldev);
2175 unsigned int idx = pin % PINS_PER_GPIO_CHIP;
2176 unsigned int offt = pin / PINS_PER_GPIO_CHIP;
Paul Cercueil7009d042019-11-19 16:52:10 +01002177 unsigned int cfg, arg;
2178 int ret;
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002179
2180 for (cfg = 0; cfg < num_configs; cfg++) {
2181 switch (pinconf_to_config_param(configs[cfg])) {
2182 case PIN_CONFIG_BIAS_DISABLE:
2183 case PIN_CONFIG_BIAS_PULL_UP:
2184 case PIN_CONFIG_BIAS_PULL_DOWN:
Paul Cercueil7009d042019-11-19 16:52:10 +01002185 case PIN_CONFIG_OUTPUT:
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002186 continue;
2187 default:
2188 return -ENOTSUPP;
2189 }
2190 }
2191
2192 for (cfg = 0; cfg < num_configs; cfg++) {
Paul Cercueil7009d042019-11-19 16:52:10 +01002193 arg = pinconf_to_config_argument(configs[cfg]);
2194
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002195 switch (pinconf_to_config_param(configs[cfg])) {
2196 case PIN_CONFIG_BIAS_DISABLE:
2197 dev_dbg(jzpc->dev, "disable pull-over for pin P%c%u\n",
2198 'A' + offt, idx);
周琰杰 (Zhou Yanjie)d7da2a12019-12-16 00:21:04 +08002199 ingenic_set_bias(jzpc, pin, GPIO_PULL_DIS);
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002200 break;
2201
2202 case PIN_CONFIG_BIAS_PULL_UP:
2203 if (!(jzpc->info->pull_ups[offt] & BIT(idx)))
2204 return -EINVAL;
2205 dev_dbg(jzpc->dev, "set pull-up for pin P%c%u\n",
2206 'A' + offt, idx);
周琰杰 (Zhou Yanjie)d7da2a12019-12-16 00:21:04 +08002207 ingenic_set_bias(jzpc, pin, GPIO_PULL_UP);
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002208 break;
2209
2210 case PIN_CONFIG_BIAS_PULL_DOWN:
2211 if (!(jzpc->info->pull_downs[offt] & BIT(idx)))
2212 return -EINVAL;
2213 dev_dbg(jzpc->dev, "set pull-down for pin P%c%u\n",
2214 'A' + offt, idx);
周琰杰 (Zhou Yanjie)d7da2a12019-12-16 00:21:04 +08002215 ingenic_set_bias(jzpc, pin, GPIO_PULL_DOWN);
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002216 break;
2217
Paul Cercueil7009d042019-11-19 16:52:10 +01002218 case PIN_CONFIG_OUTPUT:
2219 ret = pinctrl_gpio_direction_output(pin);
2220 if (ret)
2221 return ret;
2222
2223 ingenic_set_output_level(jzpc, pin, arg);
2224 break;
2225
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002226 default:
Josh Poimboeufd6d43a92020-02-20 09:35:09 -06002227 /* unreachable */
2228 break;
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002229 }
2230 }
2231
2232 return 0;
2233}
2234
2235static int ingenic_pinconf_group_get(struct pinctrl_dev *pctldev,
2236 unsigned int group, unsigned long *config)
2237{
2238 const unsigned int *pins;
2239 unsigned int i, npins, old = 0;
2240 int ret;
2241
2242 ret = pinctrl_generic_get_group_pins(pctldev, group, &pins, &npins);
2243 if (ret)
2244 return ret;
2245
2246 for (i = 0; i < npins; i++) {
2247 if (ingenic_pinconf_get(pctldev, pins[i], config))
2248 return -ENOTSUPP;
2249
2250 /* configs do not match between two pins */
2251 if (i && (old != *config))
2252 return -ENOTSUPP;
2253
2254 old = *config;
2255 }
2256
2257 return 0;
2258}
2259
2260static int ingenic_pinconf_group_set(struct pinctrl_dev *pctldev,
2261 unsigned int group, unsigned long *configs,
2262 unsigned int num_configs)
2263{
2264 const unsigned int *pins;
2265 unsigned int i, npins;
2266 int ret;
2267
2268 ret = pinctrl_generic_get_group_pins(pctldev, group, &pins, &npins);
2269 if (ret)
2270 return ret;
2271
2272 for (i = 0; i < npins; i++) {
2273 ret = ingenic_pinconf_set(pctldev,
2274 pins[i], configs, num_configs);
2275 if (ret)
2276 return ret;
2277 }
2278
2279 return 0;
2280}
2281
Julia Lawall5bf7b842017-08-10 12:06:23 +02002282static const struct pinconf_ops ingenic_confops = {
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002283 .is_generic = true,
2284 .pin_config_get = ingenic_pinconf_get,
2285 .pin_config_set = ingenic_pinconf_set,
2286 .pin_config_group_get = ingenic_pinconf_group_get,
2287 .pin_config_group_set = ingenic_pinconf_group_set,
2288};
2289
2290static const struct regmap_config ingenic_pinctrl_regmap_config = {
2291 .reg_bits = 32,
2292 .val_bits = 32,
2293 .reg_stride = 4,
2294};
2295
Paul Cercueile72394e2018-08-21 18:42:32 +02002296static const struct of_device_id ingenic_gpio_of_match[] __initconst = {
2297 { .compatible = "ingenic,jz4740-gpio", },
Zhou Yanjie0257595a2019-07-14 11:53:52 +08002298 { .compatible = "ingenic,jz4760-gpio", },
Paul Cercueile72394e2018-08-21 18:42:32 +02002299 { .compatible = "ingenic,jz4770-gpio", },
2300 { .compatible = "ingenic,jz4780-gpio", },
Zhou Yanjiefe1ad5e2019-07-14 11:53:54 +08002301 { .compatible = "ingenic,x1000-gpio", },
周琰杰 (Zhou Yanjie)d7da2a12019-12-16 00:21:04 +08002302 { .compatible = "ingenic,x1830-gpio", },
Paul Cercueile72394e2018-08-21 18:42:32 +02002303 {},
2304};
2305
2306static int __init ingenic_gpio_probe(struct ingenic_pinctrl *jzpc,
2307 struct device_node *node)
2308{
2309 struct ingenic_gpio_chip *jzgc;
2310 struct device *dev = jzpc->dev;
Linus Walleij142b8762019-10-01 15:32:09 +02002311 struct gpio_irq_chip *girq;
Paul Cercueile72394e2018-08-21 18:42:32 +02002312 unsigned int bank;
2313 int err;
2314
2315 err = of_property_read_u32(node, "reg", &bank);
2316 if (err) {
2317 dev_err(dev, "Cannot read \"reg\" property: %i\n", err);
2318 return err;
2319 }
2320
2321 jzgc = devm_kzalloc(dev, sizeof(*jzgc), GFP_KERNEL);
2322 if (!jzgc)
2323 return -ENOMEM;
2324
2325 jzgc->jzpc = jzpc;
周琰杰 (Zhou Yanjie)f742e5e2019-12-16 00:21:02 +08002326 jzgc->reg_base = bank * jzpc->info->reg_offset;
Paul Cercueile72394e2018-08-21 18:42:32 +02002327
2328 jzgc->gc.label = devm_kasprintf(dev, GFP_KERNEL, "GPIO%c", 'A' + bank);
2329 if (!jzgc->gc.label)
2330 return -ENOMEM;
2331
2332 /* DO NOT EXPAND THIS: FOR BACKWARD GPIO NUMBERSPACE COMPATIBIBILITY
2333 * ONLY: WORK TO TRANSITION CONSUMERS TO USE THE GPIO DESCRIPTOR API IN
2334 * <linux/gpio/consumer.h> INSTEAD.
2335 */
2336 jzgc->gc.base = bank * 32;
2337
2338 jzgc->gc.ngpio = 32;
2339 jzgc->gc.parent = dev;
2340 jzgc->gc.of_node = node;
2341 jzgc->gc.owner = THIS_MODULE;
2342
2343 jzgc->gc.set = ingenic_gpio_set;
2344 jzgc->gc.get = ingenic_gpio_get;
2345 jzgc->gc.direction_input = ingenic_gpio_direction_input;
2346 jzgc->gc.direction_output = ingenic_gpio_direction_output;
Paul Cercueilebd66512018-08-21 18:42:33 +02002347 jzgc->gc.get_direction = ingenic_gpio_get_direction;
Thierry Redingd6471d62020-04-01 22:05:27 +02002348 jzgc->gc.request = gpiochip_generic_request;
2349 jzgc->gc.free = gpiochip_generic_free;
Paul Cercueile72394e2018-08-21 18:42:32 +02002350
Paul Cercueile72394e2018-08-21 18:42:32 +02002351 jzgc->irq = irq_of_parse_and_map(node, 0);
2352 if (!jzgc->irq)
2353 return -EINVAL;
2354
2355 jzgc->irq_chip.name = jzgc->gc.label;
2356 jzgc->irq_chip.irq_enable = ingenic_gpio_irq_enable;
2357 jzgc->irq_chip.irq_disable = ingenic_gpio_irq_disable;
2358 jzgc->irq_chip.irq_unmask = ingenic_gpio_irq_unmask;
2359 jzgc->irq_chip.irq_mask = ingenic_gpio_irq_mask;
2360 jzgc->irq_chip.irq_ack = ingenic_gpio_irq_ack;
2361 jzgc->irq_chip.irq_set_type = ingenic_gpio_irq_set_type;
2362 jzgc->irq_chip.irq_set_wake = ingenic_gpio_irq_set_wake;
Paul Cercueil9a0f1342020-05-03 18:45:49 +02002363 jzgc->irq_chip.irq_request_resources = ingenic_gpio_irq_request;
2364 jzgc->irq_chip.irq_release_resources = ingenic_gpio_irq_release;
Paul Cercueile72394e2018-08-21 18:42:32 +02002365 jzgc->irq_chip.flags = IRQCHIP_MASK_ON_SUSPEND;
2366
Linus Walleij142b8762019-10-01 15:32:09 +02002367 girq = &jzgc->gc.irq;
2368 girq->chip = &jzgc->irq_chip;
2369 girq->parent_handler = ingenic_gpio_irq_handler;
2370 girq->num_parents = 1;
2371 girq->parents = devm_kcalloc(dev, 1, sizeof(*girq->parents),
2372 GFP_KERNEL);
2373 if (!girq->parents)
2374 return -ENOMEM;
2375 girq->parents[0] = jzgc->irq;
2376 girq->default_type = IRQ_TYPE_NONE;
2377 girq->handler = handle_level_irq;
2378
2379 err = devm_gpiochip_add_data(dev, &jzgc->gc, jzgc);
Paul Cercueile72394e2018-08-21 18:42:32 +02002380 if (err)
2381 return err;
2382
Paul Cercueile72394e2018-08-21 18:42:32 +02002383 return 0;
2384}
2385
Paul Cercueil4717b112018-08-21 18:42:31 +02002386static int __init ingenic_pinctrl_probe(struct platform_device *pdev)
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002387{
2388 struct device *dev = &pdev->dev;
2389 struct ingenic_pinctrl *jzpc;
2390 struct pinctrl_desc *pctl_desc;
2391 void __iomem *base;
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002392 const struct ingenic_chip_info *chip_info;
Paul Cercueile72394e2018-08-21 18:42:32 +02002393 struct device_node *node;
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002394 unsigned int i;
2395 int err;
2396
2397 jzpc = devm_kzalloc(dev, sizeof(*jzpc), GFP_KERNEL);
2398 if (!jzpc)
2399 return -ENOMEM;
2400
Paul Cercueil94f7a2c2020-01-07 00:27:11 +01002401 base = devm_platform_ioremap_resource(pdev, 0);
Wei Yongjun119fcf42018-01-17 11:29:17 +00002402 if (IS_ERR(base))
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002403 return PTR_ERR(base);
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002404
2405 jzpc->map = devm_regmap_init_mmio(dev, base,
2406 &ingenic_pinctrl_regmap_config);
2407 if (IS_ERR(jzpc->map)) {
2408 dev_err(dev, "Failed to create regmap\n");
2409 return PTR_ERR(jzpc->map);
2410 }
2411
2412 jzpc->dev = dev;
Paul Cercueilbaf15642020-01-07 00:27:08 +01002413 jzpc->info = chip_info = of_device_get_match_data(dev);
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002414
2415 pctl_desc = devm_kzalloc(&pdev->dev, sizeof(*pctl_desc), GFP_KERNEL);
2416 if (!pctl_desc)
2417 return -ENOMEM;
2418
2419 /* fill in pinctrl_desc structure */
2420 pctl_desc->name = dev_name(dev);
2421 pctl_desc->owner = THIS_MODULE;
2422 pctl_desc->pctlops = &ingenic_pctlops;
2423 pctl_desc->pmxops = &ingenic_pmxops;
2424 pctl_desc->confops = &ingenic_confops;
2425 pctl_desc->npins = chip_info->num_chips * PINS_PER_GPIO_CHIP;
Kees Cooka86854d2018-06-12 14:07:58 -07002426 pctl_desc->pins = jzpc->pdesc = devm_kcalloc(&pdev->dev,
2427 pctl_desc->npins, sizeof(*jzpc->pdesc), GFP_KERNEL);
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002428 if (!jzpc->pdesc)
2429 return -ENOMEM;
2430
2431 for (i = 0; i < pctl_desc->npins; i++) {
2432 jzpc->pdesc[i].number = i;
2433 jzpc->pdesc[i].name = kasprintf(GFP_KERNEL, "P%c%d",
2434 'A' + (i / PINS_PER_GPIO_CHIP),
2435 i % PINS_PER_GPIO_CHIP);
2436 }
2437
2438 jzpc->pctl = devm_pinctrl_register(dev, pctl_desc, jzpc);
Dan Carpentere7f4c4b2017-06-14 12:12:09 +03002439 if (IS_ERR(jzpc->pctl)) {
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002440 dev_err(dev, "Failed to register pinctrl\n");
Dan Carpentere7f4c4b2017-06-14 12:12:09 +03002441 return PTR_ERR(jzpc->pctl);
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002442 }
2443
2444 for (i = 0; i < chip_info->num_groups; i++) {
2445 const struct group_desc *group = &chip_info->groups[i];
2446
2447 err = pinctrl_generic_add_group(jzpc->pctl, group->name,
2448 group->pins, group->num_pins, group->data);
Paul Burton823dd712018-08-25 10:53:28 -07002449 if (err < 0) {
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002450 dev_err(dev, "Failed to register group %s\n",
2451 group->name);
2452 return err;
2453 }
2454 }
2455
2456 for (i = 0; i < chip_info->num_functions; i++) {
2457 const struct function_desc *func = &chip_info->functions[i];
2458
2459 err = pinmux_generic_add_function(jzpc->pctl, func->name,
2460 func->group_names, func->num_group_names,
2461 func->data);
Paul Burton823dd712018-08-25 10:53:28 -07002462 if (err < 0) {
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002463 dev_err(dev, "Failed to register function %s\n",
2464 func->name);
2465 return err;
2466 }
2467 }
2468
2469 dev_set_drvdata(dev, jzpc->map);
2470
Paul Cercueile72394e2018-08-21 18:42:32 +02002471 for_each_child_of_node(dev->of_node, node) {
2472 if (of_match_node(ingenic_gpio_of_match, node)) {
2473 err = ingenic_gpio_probe(jzpc, node);
2474 if (err)
2475 return err;
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002476 }
2477 }
2478
2479 return 0;
2480}
2481
Paul Cercueilbaf15642020-01-07 00:27:08 +01002482static const struct of_device_id ingenic_pinctrl_of_match[] = {
2483 { .compatible = "ingenic,jz4740-pinctrl", .data = &jz4740_chip_info },
2484 { .compatible = "ingenic,jz4725b-pinctrl", .data = &jz4725b_chip_info },
2485 { .compatible = "ingenic,jz4760-pinctrl", .data = &jz4760_chip_info },
Paul Cercueil5ffdbb72020-01-07 00:27:09 +01002486 { .compatible = "ingenic,jz4760b-pinctrl", .data = &jz4760_chip_info },
Paul Cercueilbaf15642020-01-07 00:27:08 +01002487 { .compatible = "ingenic,jz4770-pinctrl", .data = &jz4770_chip_info },
2488 { .compatible = "ingenic,jz4780-pinctrl", .data = &jz4780_chip_info },
2489 { .compatible = "ingenic,x1000-pinctrl", .data = &x1000_chip_info },
Paul Cercueil5ffdbb72020-01-07 00:27:09 +01002490 { .compatible = "ingenic,x1000e-pinctrl", .data = &x1000_chip_info },
Paul Cercueilbaf15642020-01-07 00:27:08 +01002491 { .compatible = "ingenic,x1500-pinctrl", .data = &x1500_chip_info },
2492 { .compatible = "ingenic,x1830-pinctrl", .data = &x1830_chip_info },
2493 {},
2494};
2495
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002496static struct platform_driver ingenic_pinctrl_driver = {
2497 .driver = {
2498 .name = "pinctrl-ingenic",
Paul Cercueil5ec008b2020-01-07 00:27:07 +01002499 .of_match_table = ingenic_pinctrl_of_match,
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002500 },
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002501};
2502
2503static int __init ingenic_pinctrl_drv_register(void)
2504{
Paul Cercueil4717b112018-08-21 18:42:31 +02002505 return platform_driver_probe(&ingenic_pinctrl_driver,
2506 ingenic_pinctrl_probe);
Paul Cercueilb5c23aa2017-05-12 18:52:56 +02002507}
Paul Cercueil556a36a2018-08-21 18:42:30 +02002508subsys_initcall(ingenic_pinctrl_drv_register);