xref: /openbmc/u-boot/drivers/pinctrl/renesas/sh_pfc.h (revision 103c45fb0daab924308046454b4aaad4a09237c4)
1910df4d0SMarek Vasut /*
2910df4d0SMarek Vasut  * SuperH Pin Function Controller Support
3910df4d0SMarek Vasut  *
4910df4d0SMarek Vasut  * Copyright (c) 2008 Magnus Damm
5910df4d0SMarek Vasut  *
6910df4d0SMarek Vasut  * This file is subject to the terms and conditions of the GNU General Public
7910df4d0SMarek Vasut  * License.  See the file "COPYING" in the main directory of this archive
8910df4d0SMarek Vasut  * for more details.
9910df4d0SMarek Vasut  */
10910df4d0SMarek Vasut 
11910df4d0SMarek Vasut #ifndef __SH_PFC_H
12910df4d0SMarek Vasut #define __SH_PFC_H
13910df4d0SMarek Vasut 
14910df4d0SMarek Vasut #include <linux/stringify.h>
15910df4d0SMarek Vasut 
16910df4d0SMarek Vasut enum {
17910df4d0SMarek Vasut 	PINMUX_TYPE_NONE,
18910df4d0SMarek Vasut 	PINMUX_TYPE_FUNCTION,
19910df4d0SMarek Vasut 	PINMUX_TYPE_GPIO,
20910df4d0SMarek Vasut 	PINMUX_TYPE_OUTPUT,
21910df4d0SMarek Vasut 	PINMUX_TYPE_INPUT,
22910df4d0SMarek Vasut };
23910df4d0SMarek Vasut 
24910df4d0SMarek Vasut #define SH_PFC_PIN_CFG_INPUT		(1 << 0)
25910df4d0SMarek Vasut #define SH_PFC_PIN_CFG_OUTPUT		(1 << 1)
26910df4d0SMarek Vasut #define SH_PFC_PIN_CFG_PULL_UP		(1 << 2)
27910df4d0SMarek Vasut #define SH_PFC_PIN_CFG_PULL_DOWN	(1 << 3)
28910df4d0SMarek Vasut #define SH_PFC_PIN_CFG_IO_VOLTAGE	(1 << 4)
29910df4d0SMarek Vasut #define SH_PFC_PIN_CFG_DRIVE_STRENGTH	(1 << 5)
30910df4d0SMarek Vasut #define SH_PFC_PIN_CFG_NO_GPIO		(1 << 31)
31910df4d0SMarek Vasut 
32910df4d0SMarek Vasut struct sh_pfc_pin {
33910df4d0SMarek Vasut 	u16 pin;
34910df4d0SMarek Vasut 	u16 enum_id;
35910df4d0SMarek Vasut 	const char *name;
36910df4d0SMarek Vasut 	unsigned int configs;
37910df4d0SMarek Vasut };
38910df4d0SMarek Vasut 
39*bf8d2dabSMarek Vasut #define SH_PFC_PIN_GROUP_ALIAS(alias, n)		\
40910df4d0SMarek Vasut 	{						\
41*bf8d2dabSMarek Vasut 		.name = #alias,				\
42910df4d0SMarek Vasut 		.pins = n##_pins,			\
43910df4d0SMarek Vasut 		.mux = n##_mux,				\
44910df4d0SMarek Vasut 		.nr_pins = ARRAY_SIZE(n##_pins),	\
45910df4d0SMarek Vasut 	}
46*bf8d2dabSMarek Vasut #define SH_PFC_PIN_GROUP(n)	SH_PFC_PIN_GROUP_ALIAS(n, n)
47910df4d0SMarek Vasut 
48910df4d0SMarek Vasut struct sh_pfc_pin_group {
49910df4d0SMarek Vasut 	const char *name;
50910df4d0SMarek Vasut 	const unsigned int *pins;
51910df4d0SMarek Vasut 	const unsigned int *mux;
52910df4d0SMarek Vasut 	unsigned int nr_pins;
53910df4d0SMarek Vasut };
54910df4d0SMarek Vasut 
55910df4d0SMarek Vasut /*
56910df4d0SMarek Vasut  * Using union vin_data saves memory occupied by the VIN data pins.
57910df4d0SMarek Vasut  * VIN_DATA_PIN_GROUP() is  a macro  used  to describe the VIN pin groups
58910df4d0SMarek Vasut  * in this case.
59910df4d0SMarek Vasut  */
60910df4d0SMarek Vasut #define VIN_DATA_PIN_GROUP(n, s)				\
61910df4d0SMarek Vasut 	{							\
62910df4d0SMarek Vasut 		.name = #n#s,					\
63910df4d0SMarek Vasut 		.pins = n##_pins.data##s,			\
64910df4d0SMarek Vasut 		.mux = n##_mux.data##s,				\
65910df4d0SMarek Vasut 		.nr_pins = ARRAY_SIZE(n##_pins.data##s),	\
66910df4d0SMarek Vasut 	}
67910df4d0SMarek Vasut 
68910df4d0SMarek Vasut union vin_data {
69910df4d0SMarek Vasut 	unsigned int data24[24];
70910df4d0SMarek Vasut 	unsigned int data20[20];
71910df4d0SMarek Vasut 	unsigned int data16[16];
72910df4d0SMarek Vasut 	unsigned int data12[12];
73910df4d0SMarek Vasut 	unsigned int data10[10];
74910df4d0SMarek Vasut 	unsigned int data8[8];
75910df4d0SMarek Vasut 	unsigned int data4[4];
76910df4d0SMarek Vasut };
77910df4d0SMarek Vasut 
78910df4d0SMarek Vasut #define SH_PFC_FUNCTION(n)				\
79910df4d0SMarek Vasut 	{						\
80910df4d0SMarek Vasut 		.name = #n,				\
81910df4d0SMarek Vasut 		.groups = n##_groups,			\
82910df4d0SMarek Vasut 		.nr_groups = ARRAY_SIZE(n##_groups),	\
83910df4d0SMarek Vasut 	}
84910df4d0SMarek Vasut 
85910df4d0SMarek Vasut struct sh_pfc_function {
86910df4d0SMarek Vasut 	const char *name;
87910df4d0SMarek Vasut 	const char * const *groups;
88910df4d0SMarek Vasut 	unsigned int nr_groups;
89910df4d0SMarek Vasut };
90910df4d0SMarek Vasut 
91910df4d0SMarek Vasut struct pinmux_func {
92910df4d0SMarek Vasut 	u16 enum_id;
93910df4d0SMarek Vasut 	const char *name;
94910df4d0SMarek Vasut };
95910df4d0SMarek Vasut 
96910df4d0SMarek Vasut struct pinmux_cfg_reg {
97910df4d0SMarek Vasut 	u32 reg;
98910df4d0SMarek Vasut 	u8 reg_width, field_width;
99910df4d0SMarek Vasut 	const u16 *enum_ids;
100910df4d0SMarek Vasut 	const u8 *var_field_width;
101910df4d0SMarek Vasut };
102910df4d0SMarek Vasut 
103910df4d0SMarek Vasut /*
104910df4d0SMarek Vasut  * Describe a config register consisting of several fields of the same width
105910df4d0SMarek Vasut  *   - name: Register name (unused, for documentation purposes only)
106910df4d0SMarek Vasut  *   - r: Physical register address
107910df4d0SMarek Vasut  *   - r_width: Width of the register (in bits)
108910df4d0SMarek Vasut  *   - f_width: Width of the fixed-width register fields (in bits)
109910df4d0SMarek Vasut  * This macro must be followed by initialization data: For each register field
110910df4d0SMarek Vasut  * (from left to right, i.e. MSB to LSB), 2^f_width enum IDs must be specified,
111910df4d0SMarek Vasut  * one for each possible combination of the register field bit values.
112910df4d0SMarek Vasut  */
113910df4d0SMarek Vasut #define PINMUX_CFG_REG(name, r, r_width, f_width) \
114910df4d0SMarek Vasut 	.reg = r, .reg_width = r_width, .field_width = f_width,		\
115910df4d0SMarek Vasut 	.enum_ids = (const u16 [(r_width / f_width) * (1 << f_width)])
116910df4d0SMarek Vasut 
117910df4d0SMarek Vasut /*
118910df4d0SMarek Vasut  * Describe a config register consisting of several fields of different widths
119910df4d0SMarek Vasut  *   - name: Register name (unused, for documentation purposes only)
120910df4d0SMarek Vasut  *   - r: Physical register address
121910df4d0SMarek Vasut  *   - r_width: Width of the register (in bits)
122910df4d0SMarek Vasut  *   - var_fw0, var_fwn...: List of widths of the register fields (in bits),
123910df4d0SMarek Vasut  *                          From left to right (i.e. MSB to LSB)
124910df4d0SMarek Vasut  * This macro must be followed by initialization data: For each register field
125910df4d0SMarek Vasut  * (from left to right, i.e. MSB to LSB), 2^var_fwi enum IDs must be specified,
126910df4d0SMarek Vasut  * one for each possible combination of the register field bit values.
127910df4d0SMarek Vasut  */
128910df4d0SMarek Vasut #define PINMUX_CFG_REG_VAR(name, r, r_width, var_fw0, var_fwn...) \
129910df4d0SMarek Vasut 	.reg = r, .reg_width = r_width,	\
130910df4d0SMarek Vasut 	.var_field_width = (const u8 [r_width]) \
131910df4d0SMarek Vasut 		{ var_fw0, var_fwn, 0 }, \
132910df4d0SMarek Vasut 	.enum_ids = (const u16 [])
133910df4d0SMarek Vasut 
134910df4d0SMarek Vasut struct pinmux_drive_reg_field {
135910df4d0SMarek Vasut 	u16 pin;
136910df4d0SMarek Vasut 	u8 offset;
137910df4d0SMarek Vasut 	u8 size;
138910df4d0SMarek Vasut };
139910df4d0SMarek Vasut 
140910df4d0SMarek Vasut struct pinmux_drive_reg {
141910df4d0SMarek Vasut 	u32 reg;
142910df4d0SMarek Vasut 	const struct pinmux_drive_reg_field fields[8];
143910df4d0SMarek Vasut };
144910df4d0SMarek Vasut 
145910df4d0SMarek Vasut #define PINMUX_DRIVE_REG(name, r) \
146910df4d0SMarek Vasut 	.reg = r, \
147910df4d0SMarek Vasut 	.fields =
148910df4d0SMarek Vasut 
149*bf8d2dabSMarek Vasut struct pinmux_bias_reg {
150*bf8d2dabSMarek Vasut 	u32 puen;		/* Pull-enable or pull-up control register */
151*bf8d2dabSMarek Vasut 	u32 pud;		/* Pull-up/down control register (optional) */
152*bf8d2dabSMarek Vasut 	const u16 pins[32];
153*bf8d2dabSMarek Vasut };
154*bf8d2dabSMarek Vasut 
155*bf8d2dabSMarek Vasut #define PINMUX_BIAS_REG(name1, r1, name2, r2) \
156*bf8d2dabSMarek Vasut 	.puen = r1,	\
157*bf8d2dabSMarek Vasut 	.pud = r2,	\
158*bf8d2dabSMarek Vasut 	.pins =
159*bf8d2dabSMarek Vasut 
160*bf8d2dabSMarek Vasut struct pinmux_ioctrl_reg {
161*bf8d2dabSMarek Vasut 	u32 reg;
162*bf8d2dabSMarek Vasut };
163*bf8d2dabSMarek Vasut 
164910df4d0SMarek Vasut struct pinmux_data_reg {
165910df4d0SMarek Vasut 	u32 reg;
166910df4d0SMarek Vasut 	u8 reg_width;
167910df4d0SMarek Vasut 	const u16 *enum_ids;
168910df4d0SMarek Vasut };
169910df4d0SMarek Vasut 
170910df4d0SMarek Vasut /*
171910df4d0SMarek Vasut  * Describe a data register
172910df4d0SMarek Vasut  *   - name: Register name (unused, for documentation purposes only)
173910df4d0SMarek Vasut  *   - r: Physical register address
174910df4d0SMarek Vasut  *   - r_width: Width of the register (in bits)
175910df4d0SMarek Vasut  * This macro must be followed by initialization data: For each register bit
176910df4d0SMarek Vasut  * (from left to right, i.e. MSB to LSB), one enum ID must be specified.
177910df4d0SMarek Vasut  */
178910df4d0SMarek Vasut #define PINMUX_DATA_REG(name, r, r_width) \
179910df4d0SMarek Vasut 	.reg = r, .reg_width = r_width,	\
180910df4d0SMarek Vasut 	.enum_ids = (const u16 [r_width]) \
181910df4d0SMarek Vasut 
182910df4d0SMarek Vasut struct pinmux_irq {
183910df4d0SMarek Vasut 	const short *gpios;
184910df4d0SMarek Vasut };
185910df4d0SMarek Vasut 
186910df4d0SMarek Vasut /*
187910df4d0SMarek Vasut  * Describe the mapping from GPIOs to a single IRQ
188910df4d0SMarek Vasut  *   - ids...: List of GPIOs that are mapped to the same IRQ
189910df4d0SMarek Vasut  */
190910df4d0SMarek Vasut #define PINMUX_IRQ(ids...)			   \
191910df4d0SMarek Vasut 	{ .gpios = (const short []) { ids, -1 } }
192910df4d0SMarek Vasut 
193910df4d0SMarek Vasut struct pinmux_range {
194910df4d0SMarek Vasut 	u16 begin;
195910df4d0SMarek Vasut 	u16 end;
196910df4d0SMarek Vasut 	u16 force;
197910df4d0SMarek Vasut };
198910df4d0SMarek Vasut 
199*bf8d2dabSMarek Vasut struct sh_pfc_window {
200*bf8d2dabSMarek Vasut 	phys_addr_t phys;
201*bf8d2dabSMarek Vasut 	void __iomem *virt;
202*bf8d2dabSMarek Vasut 	unsigned long size;
203910df4d0SMarek Vasut };
204910df4d0SMarek Vasut 
205910df4d0SMarek Vasut struct sh_pfc_pin_range;
206910df4d0SMarek Vasut 
207910df4d0SMarek Vasut struct sh_pfc {
208910df4d0SMarek Vasut 	struct device *dev;
209910df4d0SMarek Vasut 	const struct sh_pfc_soc_info *info;
210910df4d0SMarek Vasut 
211910df4d0SMarek Vasut 	void *regs;
212910df4d0SMarek Vasut 
213910df4d0SMarek Vasut 	struct sh_pfc_pin_range *ranges;
214910df4d0SMarek Vasut 	unsigned int nr_ranges;
215910df4d0SMarek Vasut 
216910df4d0SMarek Vasut 	unsigned int nr_gpio_pins;
217910df4d0SMarek Vasut 
218910df4d0SMarek Vasut 	struct sh_pfc_chip *gpio;
219910df4d0SMarek Vasut };
220910df4d0SMarek Vasut 
221910df4d0SMarek Vasut struct sh_pfc_soc_operations {
222910df4d0SMarek Vasut 	int (*init)(struct sh_pfc *pfc);
223910df4d0SMarek Vasut 	unsigned int (*get_bias)(struct sh_pfc *pfc, unsigned int pin);
224910df4d0SMarek Vasut 	void (*set_bias)(struct sh_pfc *pfc, unsigned int pin,
225910df4d0SMarek Vasut 			 unsigned int bias);
226910df4d0SMarek Vasut 	int (*pin_to_pocctrl)(struct sh_pfc *pfc, unsigned int pin, u32 *pocctrl);
227910df4d0SMarek Vasut };
228910df4d0SMarek Vasut 
229910df4d0SMarek Vasut struct sh_pfc_soc_info {
230910df4d0SMarek Vasut 	const char *name;
231910df4d0SMarek Vasut 	const struct sh_pfc_soc_operations *ops;
232910df4d0SMarek Vasut 
233910df4d0SMarek Vasut 	struct pinmux_range input;
234910df4d0SMarek Vasut 	struct pinmux_range output;
235910df4d0SMarek Vasut 	struct pinmux_range function;
236910df4d0SMarek Vasut 
237910df4d0SMarek Vasut 	const struct sh_pfc_pin *pins;
238910df4d0SMarek Vasut 	unsigned int nr_pins;
239910df4d0SMarek Vasut 	const struct sh_pfc_pin_group *groups;
240910df4d0SMarek Vasut 	unsigned int nr_groups;
241910df4d0SMarek Vasut 	const struct sh_pfc_function *functions;
242910df4d0SMarek Vasut 	unsigned int nr_functions;
243910df4d0SMarek Vasut 
244910df4d0SMarek Vasut 	const struct pinmux_cfg_reg *cfg_regs;
245910df4d0SMarek Vasut 	const struct pinmux_drive_reg *drive_regs;
246*bf8d2dabSMarek Vasut 	const struct pinmux_bias_reg *bias_regs;
247*bf8d2dabSMarek Vasut 	const struct pinmux_ioctrl_reg *ioctrl_regs;
248910df4d0SMarek Vasut 	const struct pinmux_data_reg *data_regs;
249910df4d0SMarek Vasut 
250910df4d0SMarek Vasut 	const u16 *pinmux_data;
251910df4d0SMarek Vasut 	unsigned int pinmux_data_size;
252910df4d0SMarek Vasut 
253910df4d0SMarek Vasut 	const struct pinmux_irq *gpio_irq;
254910df4d0SMarek Vasut 	unsigned int gpio_irq_size;
255910df4d0SMarek Vasut 
256910df4d0SMarek Vasut 	u32 unlock_reg;
257910df4d0SMarek Vasut };
258910df4d0SMarek Vasut 
259*bf8d2dabSMarek Vasut u32 sh_pfc_read(struct sh_pfc *pfc, u32 reg);
260*bf8d2dabSMarek Vasut void sh_pfc_write(struct sh_pfc *pfc, u32 reg, u32 data);
261*bf8d2dabSMarek Vasut const struct pinmux_bias_reg *
262*bf8d2dabSMarek Vasut sh_pfc_pin_to_bias_reg(const struct sh_pfc *pfc, unsigned int pin,
263*bf8d2dabSMarek Vasut 		       unsigned int *bit);
264f6e545a7SMarek Vasut int sh_pfc_config_mux_for_gpio(struct udevice *dev, unsigned pin_selector);
265910df4d0SMarek Vasut 
2667547ad4cSMarek Vasut extern const struct sh_pfc_soc_info r8a7790_pinmux_info;
267427c75dfSMarek Vasut extern const struct sh_pfc_soc_info r8a7791_pinmux_info;
268ab2d09b4SMarek Vasut extern const struct sh_pfc_soc_info r8a7792_pinmux_info;
269427c75dfSMarek Vasut extern const struct sh_pfc_soc_info r8a7793_pinmux_info;
27034e93605SMarek Vasut extern const struct sh_pfc_soc_info r8a7794_pinmux_info;
271910df4d0SMarek Vasut extern const struct sh_pfc_soc_info r8a7795_pinmux_info;
272910df4d0SMarek Vasut extern const struct sh_pfc_soc_info r8a7796_pinmux_info;
273c106bb53SMarek Vasut extern const struct sh_pfc_soc_info r8a77970_pinmux_info;
274cb13e46aSMarek Vasut extern const struct sh_pfc_soc_info r8a77990_pinmux_info;
275a59e6976SMarek Vasut extern const struct sh_pfc_soc_info r8a77995_pinmux_info;
276910df4d0SMarek Vasut /* -----------------------------------------------------------------------------
277910df4d0SMarek Vasut  * Helper macros to create pin and port lists
278910df4d0SMarek Vasut  */
279910df4d0SMarek Vasut 
280910df4d0SMarek Vasut /*
281910df4d0SMarek Vasut  * sh_pfc_soc_info pinmux_data array macros
282910df4d0SMarek Vasut  */
283910df4d0SMarek Vasut 
284910df4d0SMarek Vasut /*
285910df4d0SMarek Vasut  * Describe generic pinmux data
286910df4d0SMarek Vasut  *   - data_or_mark: *_DATA or *_MARK enum ID
287910df4d0SMarek Vasut  *   - ids...: List of enum IDs to associate with data_or_mark
288910df4d0SMarek Vasut  */
289910df4d0SMarek Vasut #define PINMUX_DATA(data_or_mark, ids...)	data_or_mark, ids, 0
290910df4d0SMarek Vasut 
291910df4d0SMarek Vasut /*
292910df4d0SMarek Vasut  * Describe a pinmux configuration without GPIO function that needs
293910df4d0SMarek Vasut  * configuration in a Peripheral Function Select Register (IPSR)
294910df4d0SMarek Vasut  *   - ipsr: IPSR field (unused, for documentation purposes only)
295910df4d0SMarek Vasut  *   - fn: Function name, referring to a field in the IPSR
296910df4d0SMarek Vasut  */
297910df4d0SMarek Vasut #define PINMUX_IPSR_NOGP(ipsr, fn)					\
298910df4d0SMarek Vasut 	PINMUX_DATA(fn##_MARK, FN_##fn)
299910df4d0SMarek Vasut 
300910df4d0SMarek Vasut /*
301910df4d0SMarek Vasut  * Describe a pinmux configuration with GPIO function that needs configuration
302910df4d0SMarek Vasut  * in both a Peripheral Function Select Register (IPSR) and in a
303910df4d0SMarek Vasut  * GPIO/Peripheral Function Select Register (GPSR)
304910df4d0SMarek Vasut  *   - ipsr: IPSR field
305910df4d0SMarek Vasut  *   - fn: Function name, also referring to the IPSR field
306910df4d0SMarek Vasut  */
307910df4d0SMarek Vasut #define PINMUX_IPSR_GPSR(ipsr, fn)					\
308910df4d0SMarek Vasut 	PINMUX_DATA(fn##_MARK, FN_##fn, FN_##ipsr)
309910df4d0SMarek Vasut 
310910df4d0SMarek Vasut /*
311910df4d0SMarek Vasut  * Describe a pinmux configuration without GPIO function that needs
312910df4d0SMarek Vasut  * configuration in a Peripheral Function Select Register (IPSR), and where the
313910df4d0SMarek Vasut  * pinmux function has a representation in a Module Select Register (MOD_SEL).
314910df4d0SMarek Vasut  *   - ipsr: IPSR field (unused, for documentation purposes only)
315910df4d0SMarek Vasut  *   - fn: Function name, also referring to the IPSR field
316910df4d0SMarek Vasut  *   - msel: Module selector
317910df4d0SMarek Vasut  */
318910df4d0SMarek Vasut #define PINMUX_IPSR_NOGM(ipsr, fn, msel)				\
319910df4d0SMarek Vasut 	PINMUX_DATA(fn##_MARK, FN_##fn, FN_##msel)
320910df4d0SMarek Vasut 
321910df4d0SMarek Vasut /*
322910df4d0SMarek Vasut  * Describe a pinmux configuration with GPIO function where the pinmux function
323910df4d0SMarek Vasut  * has no representation in a Peripheral Function Select Register (IPSR), but
324910df4d0SMarek Vasut  * instead solely depends on a group selection.
325910df4d0SMarek Vasut  *   - gpsr: GPSR field
326910df4d0SMarek Vasut  *   - fn: Function name, also referring to the GPSR field
327910df4d0SMarek Vasut  *   - gsel: Group selector
328910df4d0SMarek Vasut  */
329910df4d0SMarek Vasut #define PINMUX_IPSR_NOFN(gpsr, fn, gsel)				\
330910df4d0SMarek Vasut 	PINMUX_DATA(fn##_MARK, FN_##gpsr, FN_##gsel)
331910df4d0SMarek Vasut 
332910df4d0SMarek Vasut /*
333910df4d0SMarek Vasut  * Describe a pinmux configuration with GPIO function that needs configuration
334910df4d0SMarek Vasut  * in both a Peripheral Function Select Register (IPSR) and a GPIO/Peripheral
335910df4d0SMarek Vasut  * Function Select Register (GPSR), and where the pinmux function has a
336910df4d0SMarek Vasut  * representation in a Module Select Register (MOD_SEL).
337910df4d0SMarek Vasut  *   - ipsr: IPSR field
338910df4d0SMarek Vasut  *   - fn: Function name, also referring to the IPSR field
339910df4d0SMarek Vasut  *   - msel: Module selector
340910df4d0SMarek Vasut  */
341910df4d0SMarek Vasut #define PINMUX_IPSR_MSEL(ipsr, fn, msel)				\
342910df4d0SMarek Vasut 	PINMUX_DATA(fn##_MARK, FN_##msel, FN_##fn, FN_##ipsr)
343910df4d0SMarek Vasut 
344910df4d0SMarek Vasut /*
345910df4d0SMarek Vasut  * Describe a pinmux configuration for a single-function pin with GPIO
346910df4d0SMarek Vasut  * capability.
347910df4d0SMarek Vasut  *   - fn: Function name
348910df4d0SMarek Vasut  */
349910df4d0SMarek Vasut #define PINMUX_SINGLE(fn)						\
350910df4d0SMarek Vasut 	PINMUX_DATA(fn##_MARK, FN_##fn)
351910df4d0SMarek Vasut 
352910df4d0SMarek Vasut /*
353910df4d0SMarek Vasut  * GP port style (32 ports banks)
354910df4d0SMarek Vasut  */
355910df4d0SMarek Vasut 
356910df4d0SMarek Vasut #define PORT_GP_CFG_1(bank, pin, fn, sfx, cfg)				\
357910df4d0SMarek Vasut 	fn(bank, pin, GP_##bank##_##pin, sfx, cfg)
358910df4d0SMarek Vasut #define PORT_GP_1(bank, pin, fn, sfx)	PORT_GP_CFG_1(bank, pin, fn, sfx, 0)
359910df4d0SMarek Vasut 
360910df4d0SMarek Vasut #define PORT_GP_CFG_4(bank, fn, sfx, cfg)				\
361910df4d0SMarek Vasut 	PORT_GP_CFG_1(bank, 0,  fn, sfx, cfg),				\
362910df4d0SMarek Vasut 	PORT_GP_CFG_1(bank, 1,  fn, sfx, cfg),				\
363910df4d0SMarek Vasut 	PORT_GP_CFG_1(bank, 2,  fn, sfx, cfg),				\
364910df4d0SMarek Vasut 	PORT_GP_CFG_1(bank, 3,  fn, sfx, cfg)
365910df4d0SMarek Vasut #define PORT_GP_4(bank, fn, sfx)	PORT_GP_CFG_4(bank, fn, sfx, 0)
366910df4d0SMarek Vasut 
367c106bb53SMarek Vasut #define PORT_GP_CFG_6(bank, fn, sfx, cfg)				\
368c106bb53SMarek Vasut 	PORT_GP_CFG_4(bank, fn, sfx, cfg),				\
369*bf8d2dabSMarek Vasut 	PORT_GP_CFG_1(bank, 4,  fn, sfx, cfg),				\
370*bf8d2dabSMarek Vasut 	PORT_GP_CFG_1(bank, 5,  fn, sfx, cfg)
371c106bb53SMarek Vasut #define PORT_GP_6(bank, fn, sfx)	PORT_GP_CFG_6(bank, fn, sfx, 0)
372c106bb53SMarek Vasut 
373910df4d0SMarek Vasut #define PORT_GP_CFG_8(bank, fn, sfx, cfg)				\
374*bf8d2dabSMarek Vasut 	PORT_GP_CFG_6(bank, fn, sfx, cfg),				\
375910df4d0SMarek Vasut 	PORT_GP_CFG_1(bank, 6,  fn, sfx, cfg),				\
376910df4d0SMarek Vasut 	PORT_GP_CFG_1(bank, 7,  fn, sfx, cfg)
377910df4d0SMarek Vasut #define PORT_GP_8(bank, fn, sfx)	PORT_GP_CFG_8(bank, fn, sfx, 0)
378910df4d0SMarek Vasut 
379910df4d0SMarek Vasut #define PORT_GP_CFG_9(bank, fn, sfx, cfg)				\
380910df4d0SMarek Vasut 	PORT_GP_CFG_8(bank, fn, sfx, cfg),				\
381910df4d0SMarek Vasut 	PORT_GP_CFG_1(bank, 8,  fn, sfx, cfg)
382910df4d0SMarek Vasut #define PORT_GP_9(bank, fn, sfx)	PORT_GP_CFG_9(bank, fn, sfx, 0)
383910df4d0SMarek Vasut 
384910df4d0SMarek Vasut #define PORT_GP_CFG_10(bank, fn, sfx, cfg)				\
385910df4d0SMarek Vasut 	PORT_GP_CFG_9(bank, fn, sfx, cfg),				\
386910df4d0SMarek Vasut 	PORT_GP_CFG_1(bank, 9,  fn, sfx, cfg)
387910df4d0SMarek Vasut #define PORT_GP_10(bank, fn, sfx)	PORT_GP_CFG_10(bank, fn, sfx, 0)
388910df4d0SMarek Vasut 
389634f9f0dSTakeshi Kihara #define PORT_GP_CFG_11(bank, fn, sfx, cfg)				\
390910df4d0SMarek Vasut 	PORT_GP_CFG_10(bank, fn, sfx, cfg),				\
391634f9f0dSTakeshi Kihara 	PORT_GP_CFG_1(bank, 10,  fn, sfx, cfg)
392634f9f0dSTakeshi Kihara #define PORT_GP_11(bank, fn, sfx)	PORT_GP_CFG_11(bank, fn, sfx, 0)
393634f9f0dSTakeshi Kihara 
394634f9f0dSTakeshi Kihara #define PORT_GP_CFG_12(bank, fn, sfx, cfg)				\
395*bf8d2dabSMarek Vasut 	PORT_GP_CFG_10(bank, fn, sfx, cfg),				\
396*bf8d2dabSMarek Vasut 	PORT_GP_CFG_1(bank, 10, fn, sfx, cfg),				\
397910df4d0SMarek Vasut 	PORT_GP_CFG_1(bank, 11, fn, sfx, cfg)
398910df4d0SMarek Vasut #define PORT_GP_12(bank, fn, sfx)	PORT_GP_CFG_12(bank, fn, sfx, 0)
399910df4d0SMarek Vasut 
400910df4d0SMarek Vasut #define PORT_GP_CFG_14(bank, fn, sfx, cfg)				\
401910df4d0SMarek Vasut 	PORT_GP_CFG_12(bank, fn, sfx, cfg),				\
402910df4d0SMarek Vasut 	PORT_GP_CFG_1(bank, 12, fn, sfx, cfg),				\
403910df4d0SMarek Vasut 	PORT_GP_CFG_1(bank, 13, fn, sfx, cfg)
404910df4d0SMarek Vasut #define PORT_GP_14(bank, fn, sfx)	PORT_GP_CFG_14(bank, fn, sfx, 0)
405910df4d0SMarek Vasut 
406910df4d0SMarek Vasut #define PORT_GP_CFG_15(bank, fn, sfx, cfg)				\
407910df4d0SMarek Vasut 	PORT_GP_CFG_14(bank, fn, sfx, cfg),				\
408910df4d0SMarek Vasut 	PORT_GP_CFG_1(bank, 14, fn, sfx, cfg)
409910df4d0SMarek Vasut #define PORT_GP_15(bank, fn, sfx)	PORT_GP_CFG_15(bank, fn, sfx, 0)
410910df4d0SMarek Vasut 
411910df4d0SMarek Vasut #define PORT_GP_CFG_16(bank, fn, sfx, cfg)				\
412910df4d0SMarek Vasut 	PORT_GP_CFG_15(bank, fn, sfx, cfg),				\
413910df4d0SMarek Vasut 	PORT_GP_CFG_1(bank, 15, fn, sfx, cfg)
414910df4d0SMarek Vasut #define PORT_GP_16(bank, fn, sfx)	PORT_GP_CFG_16(bank, fn, sfx, 0)
415910df4d0SMarek Vasut 
416910df4d0SMarek Vasut #define PORT_GP_CFG_17(bank, fn, sfx, cfg)				\
417910df4d0SMarek Vasut 	PORT_GP_CFG_16(bank, fn, sfx, cfg),				\
418910df4d0SMarek Vasut 	PORT_GP_CFG_1(bank, 16, fn, sfx, cfg)
419910df4d0SMarek Vasut #define PORT_GP_17(bank, fn, sfx)	PORT_GP_CFG_17(bank, fn, sfx, 0)
420910df4d0SMarek Vasut 
421910df4d0SMarek Vasut #define PORT_GP_CFG_18(bank, fn, sfx, cfg)				\
422910df4d0SMarek Vasut 	PORT_GP_CFG_17(bank, fn, sfx, cfg),				\
423910df4d0SMarek Vasut 	PORT_GP_CFG_1(bank, 17, fn, sfx, cfg)
424910df4d0SMarek Vasut #define PORT_GP_18(bank, fn, sfx)	PORT_GP_CFG_18(bank, fn, sfx, 0)
425910df4d0SMarek Vasut 
426910df4d0SMarek Vasut #define PORT_GP_CFG_20(bank, fn, sfx, cfg)				\
427910df4d0SMarek Vasut 	PORT_GP_CFG_18(bank, fn, sfx, cfg),				\
428910df4d0SMarek Vasut 	PORT_GP_CFG_1(bank, 18, fn, sfx, cfg),				\
429910df4d0SMarek Vasut 	PORT_GP_CFG_1(bank, 19, fn, sfx, cfg)
430910df4d0SMarek Vasut #define PORT_GP_20(bank, fn, sfx)	PORT_GP_CFG_20(bank, fn, sfx, 0)
431910df4d0SMarek Vasut 
432910df4d0SMarek Vasut #define PORT_GP_CFG_21(bank, fn, sfx, cfg)				\
433910df4d0SMarek Vasut 	PORT_GP_CFG_20(bank, fn, sfx, cfg),				\
434910df4d0SMarek Vasut 	PORT_GP_CFG_1(bank, 20, fn, sfx, cfg)
435910df4d0SMarek Vasut #define PORT_GP_21(bank, fn, sfx)	PORT_GP_CFG_21(bank, fn, sfx, 0)
436910df4d0SMarek Vasut 
437c106bb53SMarek Vasut #define PORT_GP_CFG_22(bank, fn, sfx, cfg)				\
438*bf8d2dabSMarek Vasut 	PORT_GP_CFG_21(bank, fn, sfx, cfg),				\
439*bf8d2dabSMarek Vasut 	PORT_GP_CFG_1(bank, 21, fn, sfx, cfg)
440c106bb53SMarek Vasut #define PORT_GP_22(bank, fn, sfx)	PORT_GP_CFG_22(bank, fn, sfx, 0)
441c106bb53SMarek Vasut 
442910df4d0SMarek Vasut #define PORT_GP_CFG_23(bank, fn, sfx, cfg)				\
443*bf8d2dabSMarek Vasut 	PORT_GP_CFG_22(bank, fn, sfx, cfg),				\
444910df4d0SMarek Vasut 	PORT_GP_CFG_1(bank, 22, fn, sfx, cfg)
445910df4d0SMarek Vasut #define PORT_GP_23(bank, fn, sfx)	PORT_GP_CFG_23(bank, fn, sfx, 0)
446910df4d0SMarek Vasut 
447910df4d0SMarek Vasut #define PORT_GP_CFG_24(bank, fn, sfx, cfg)				\
448910df4d0SMarek Vasut 	PORT_GP_CFG_23(bank, fn, sfx, cfg),				\
449910df4d0SMarek Vasut 	PORT_GP_CFG_1(bank, 23, fn, sfx, cfg)
450910df4d0SMarek Vasut #define PORT_GP_24(bank, fn, sfx)	PORT_GP_CFG_24(bank, fn, sfx, 0)
451910df4d0SMarek Vasut 
452*bf8d2dabSMarek Vasut #define PORT_GP_CFG_25(bank, fn, sfx, cfg)				\
453910df4d0SMarek Vasut 	PORT_GP_CFG_24(bank, fn, sfx, cfg),				\
454*bf8d2dabSMarek Vasut 	PORT_GP_CFG_1(bank, 24, fn, sfx, cfg)
455*bf8d2dabSMarek Vasut #define PORT_GP_25(bank, fn, sfx)	PORT_GP_CFG_25(bank, fn, sfx, 0)
456*bf8d2dabSMarek Vasut 
457*bf8d2dabSMarek Vasut #define PORT_GP_CFG_26(bank, fn, sfx, cfg)				\
458*bf8d2dabSMarek Vasut 	PORT_GP_CFG_25(bank, fn, sfx, cfg),				\
459910df4d0SMarek Vasut 	PORT_GP_CFG_1(bank, 25, fn, sfx, cfg)
460910df4d0SMarek Vasut #define PORT_GP_26(bank, fn, sfx)	PORT_GP_CFG_26(bank, fn, sfx, 0)
461910df4d0SMarek Vasut 
462910df4d0SMarek Vasut #define PORT_GP_CFG_28(bank, fn, sfx, cfg)				\
463910df4d0SMarek Vasut 	PORT_GP_CFG_26(bank, fn, sfx, cfg),				\
464910df4d0SMarek Vasut 	PORT_GP_CFG_1(bank, 26, fn, sfx, cfg),				\
465910df4d0SMarek Vasut 	PORT_GP_CFG_1(bank, 27, fn, sfx, cfg)
466910df4d0SMarek Vasut #define PORT_GP_28(bank, fn, sfx)	PORT_GP_CFG_28(bank, fn, sfx, 0)
467910df4d0SMarek Vasut 
468910df4d0SMarek Vasut #define PORT_GP_CFG_29(bank, fn, sfx, cfg)				\
469910df4d0SMarek Vasut 	PORT_GP_CFG_28(bank, fn, sfx, cfg),				\
470910df4d0SMarek Vasut 	PORT_GP_CFG_1(bank, 28, fn, sfx, cfg)
471910df4d0SMarek Vasut #define PORT_GP_29(bank, fn, sfx)	PORT_GP_CFG_29(bank, fn, sfx, 0)
472910df4d0SMarek Vasut 
473910df4d0SMarek Vasut #define PORT_GP_CFG_30(bank, fn, sfx, cfg)				\
474910df4d0SMarek Vasut 	PORT_GP_CFG_29(bank, fn, sfx, cfg),				\
475910df4d0SMarek Vasut 	PORT_GP_CFG_1(bank, 29, fn, sfx, cfg)
476910df4d0SMarek Vasut #define PORT_GP_30(bank, fn, sfx)	PORT_GP_CFG_30(bank, fn, sfx, 0)
477910df4d0SMarek Vasut 
478910df4d0SMarek Vasut #define PORT_GP_CFG_32(bank, fn, sfx, cfg)				\
479910df4d0SMarek Vasut 	PORT_GP_CFG_30(bank, fn, sfx, cfg),				\
480910df4d0SMarek Vasut 	PORT_GP_CFG_1(bank, 30, fn, sfx, cfg),				\
481910df4d0SMarek Vasut 	PORT_GP_CFG_1(bank, 31, fn, sfx, cfg)
482910df4d0SMarek Vasut #define PORT_GP_32(bank, fn, sfx)	PORT_GP_CFG_32(bank, fn, sfx, 0)
483910df4d0SMarek Vasut 
484910df4d0SMarek Vasut #define PORT_GP_32_REV(bank, fn, sfx)					\
485910df4d0SMarek Vasut 	PORT_GP_1(bank, 31, fn, sfx), PORT_GP_1(bank, 30, fn, sfx),	\
486910df4d0SMarek Vasut 	PORT_GP_1(bank, 29, fn, sfx), PORT_GP_1(bank, 28, fn, sfx),	\
487910df4d0SMarek Vasut 	PORT_GP_1(bank, 27, fn, sfx), PORT_GP_1(bank, 26, fn, sfx),	\
488910df4d0SMarek Vasut 	PORT_GP_1(bank, 25, fn, sfx), PORT_GP_1(bank, 24, fn, sfx),	\
489910df4d0SMarek Vasut 	PORT_GP_1(bank, 23, fn, sfx), PORT_GP_1(bank, 22, fn, sfx),	\
490910df4d0SMarek Vasut 	PORT_GP_1(bank, 21, fn, sfx), PORT_GP_1(bank, 20, fn, sfx),	\
491910df4d0SMarek Vasut 	PORT_GP_1(bank, 19, fn, sfx), PORT_GP_1(bank, 18, fn, sfx),	\
492910df4d0SMarek Vasut 	PORT_GP_1(bank, 17, fn, sfx), PORT_GP_1(bank, 16, fn, sfx),	\
493910df4d0SMarek Vasut 	PORT_GP_1(bank, 15, fn, sfx), PORT_GP_1(bank, 14, fn, sfx),	\
494910df4d0SMarek Vasut 	PORT_GP_1(bank, 13, fn, sfx), PORT_GP_1(bank, 12, fn, sfx),	\
495910df4d0SMarek Vasut 	PORT_GP_1(bank, 11, fn, sfx), PORT_GP_1(bank, 10, fn, sfx),	\
496910df4d0SMarek Vasut 	PORT_GP_1(bank, 9,  fn, sfx), PORT_GP_1(bank, 8,  fn, sfx),	\
497910df4d0SMarek Vasut 	PORT_GP_1(bank, 7,  fn, sfx), PORT_GP_1(bank, 6,  fn, sfx),	\
498910df4d0SMarek Vasut 	PORT_GP_1(bank, 5,  fn, sfx), PORT_GP_1(bank, 4,  fn, sfx),	\
499910df4d0SMarek Vasut 	PORT_GP_1(bank, 3,  fn, sfx), PORT_GP_1(bank, 2,  fn, sfx),	\
500910df4d0SMarek Vasut 	PORT_GP_1(bank, 1,  fn, sfx), PORT_GP_1(bank, 0,  fn, sfx)
501910df4d0SMarek Vasut 
502910df4d0SMarek Vasut /* GP_ALL(suffix) - Expand to a list of GP_#_#_suffix */
503910df4d0SMarek Vasut #define _GP_ALL(bank, pin, name, sfx, cfg)	name##_##sfx
504910df4d0SMarek Vasut #define GP_ALL(str)			CPU_ALL_PORT(_GP_ALL, str)
505910df4d0SMarek Vasut 
506910df4d0SMarek Vasut /* PINMUX_GPIO_GP_ALL - Expand to a list of sh_pfc_pin entries */
507910df4d0SMarek Vasut #define _GP_GPIO(bank, _pin, _name, sfx, cfg)				\
508910df4d0SMarek Vasut 	{								\
509910df4d0SMarek Vasut 		.pin = (bank * 32) + _pin,				\
510910df4d0SMarek Vasut 		.name = __stringify(_name),				\
511910df4d0SMarek Vasut 		.enum_id = _name##_DATA,				\
512910df4d0SMarek Vasut 		.configs = cfg,						\
513910df4d0SMarek Vasut 	}
514910df4d0SMarek Vasut #define PINMUX_GPIO_GP_ALL()		CPU_ALL_PORT(_GP_GPIO, unused)
515910df4d0SMarek Vasut 
516910df4d0SMarek Vasut /* PINMUX_DATA_GP_ALL -  Expand to a list of name_DATA, name_FN marks */
517910df4d0SMarek Vasut #define _GP_DATA(bank, pin, name, sfx, cfg)	PINMUX_DATA(name##_DATA, name##_FN)
518910df4d0SMarek Vasut #define PINMUX_DATA_GP_ALL()		CPU_ALL_PORT(_GP_DATA, unused)
519910df4d0SMarek Vasut 
520910df4d0SMarek Vasut /*
521910df4d0SMarek Vasut  * PORT style (linear pin space)
522910df4d0SMarek Vasut  */
523910df4d0SMarek Vasut 
524910df4d0SMarek Vasut #define PORT_1(pn, fn, pfx, sfx) fn(pn, pfx, sfx)
525910df4d0SMarek Vasut 
526910df4d0SMarek Vasut #define PORT_10(pn, fn, pfx, sfx)					  \
527910df4d0SMarek Vasut 	PORT_1(pn,   fn, pfx##0, sfx), PORT_1(pn+1, fn, pfx##1, sfx),	  \
528910df4d0SMarek Vasut 	PORT_1(pn+2, fn, pfx##2, sfx), PORT_1(pn+3, fn, pfx##3, sfx),	  \
529910df4d0SMarek Vasut 	PORT_1(pn+4, fn, pfx##4, sfx), PORT_1(pn+5, fn, pfx##5, sfx),	  \
530910df4d0SMarek Vasut 	PORT_1(pn+6, fn, pfx##6, sfx), PORT_1(pn+7, fn, pfx##7, sfx),	  \
531910df4d0SMarek Vasut 	PORT_1(pn+8, fn, pfx##8, sfx), PORT_1(pn+9, fn, pfx##9, sfx)
532910df4d0SMarek Vasut 
533910df4d0SMarek Vasut #define PORT_90(pn, fn, pfx, sfx)					  \
534910df4d0SMarek Vasut 	PORT_10(pn+10, fn, pfx##1, sfx), PORT_10(pn+20, fn, pfx##2, sfx), \
535910df4d0SMarek Vasut 	PORT_10(pn+30, fn, pfx##3, sfx), PORT_10(pn+40, fn, pfx##4, sfx), \
536910df4d0SMarek Vasut 	PORT_10(pn+50, fn, pfx##5, sfx), PORT_10(pn+60, fn, pfx##6, sfx), \
537910df4d0SMarek Vasut 	PORT_10(pn+70, fn, pfx##7, sfx), PORT_10(pn+80, fn, pfx##8, sfx), \
538910df4d0SMarek Vasut 	PORT_10(pn+90, fn, pfx##9, sfx)
539910df4d0SMarek Vasut 
540910df4d0SMarek Vasut /* PORT_ALL(suffix) - Expand to a list of PORT_#_suffix */
541910df4d0SMarek Vasut #define _PORT_ALL(pn, pfx, sfx)		pfx##_##sfx
542910df4d0SMarek Vasut #define PORT_ALL(str)			CPU_ALL_PORT(_PORT_ALL, PORT, str)
543910df4d0SMarek Vasut 
544910df4d0SMarek Vasut /* PINMUX_GPIO - Expand to a sh_pfc_pin entry */
545910df4d0SMarek Vasut #define PINMUX_GPIO(_pin)						\
546910df4d0SMarek Vasut 	[GPIO_##_pin] = {						\
547910df4d0SMarek Vasut 		.pin = (u16)-1,						\
548910df4d0SMarek Vasut 		.name = __stringify(GPIO_##_pin),			\
549910df4d0SMarek Vasut 		.enum_id = _pin##_DATA,					\
550910df4d0SMarek Vasut 	}
551910df4d0SMarek Vasut 
552910df4d0SMarek Vasut /* SH_PFC_PIN_CFG - Expand to a sh_pfc_pin entry (named PORT#) with config */
553910df4d0SMarek Vasut #define SH_PFC_PIN_CFG(_pin, cfgs)					\
554910df4d0SMarek Vasut 	{								\
555910df4d0SMarek Vasut 		.pin = _pin,						\
556910df4d0SMarek Vasut 		.name = __stringify(PORT##_pin),			\
557910df4d0SMarek Vasut 		.enum_id = PORT##_pin##_DATA,				\
558910df4d0SMarek Vasut 		.configs = cfgs,					\
559910df4d0SMarek Vasut 	}
560910df4d0SMarek Vasut 
561910df4d0SMarek Vasut /* SH_PFC_PIN_NAMED - Expand to a sh_pfc_pin entry with the given name */
562910df4d0SMarek Vasut #define SH_PFC_PIN_NAMED(row, col, _name)				\
563910df4d0SMarek Vasut 	{								\
564910df4d0SMarek Vasut 		.pin = PIN_NUMBER(row, col),				\
565910df4d0SMarek Vasut 		.name = __stringify(PIN_##_name),			\
566910df4d0SMarek Vasut 		.configs = SH_PFC_PIN_CFG_NO_GPIO,			\
567910df4d0SMarek Vasut 	}
568910df4d0SMarek Vasut 
569910df4d0SMarek Vasut /* SH_PFC_PIN_NAMED_CFG - Expand to a sh_pfc_pin entry with the given name */
570910df4d0SMarek Vasut #define SH_PFC_PIN_NAMED_CFG(row, col, _name, cfgs)			\
571910df4d0SMarek Vasut 	{								\
572910df4d0SMarek Vasut 		.pin = PIN_NUMBER(row, col),				\
573910df4d0SMarek Vasut 		.name = __stringify(PIN_##_name),			\
574910df4d0SMarek Vasut 		.configs = SH_PFC_PIN_CFG_NO_GPIO | cfgs,		\
575910df4d0SMarek Vasut 	}
576910df4d0SMarek Vasut 
577910df4d0SMarek Vasut /* PINMUX_DATA_ALL - Expand to a list of PORT_name_DATA, PORT_name_FN0,
578910df4d0SMarek Vasut  *		     PORT_name_OUT, PORT_name_IN marks
579910df4d0SMarek Vasut  */
580910df4d0SMarek Vasut #define _PORT_DATA(pn, pfx, sfx)					\
581910df4d0SMarek Vasut 	PINMUX_DATA(PORT##pfx##_DATA, PORT##pfx##_FN0,			\
582910df4d0SMarek Vasut 		    PORT##pfx##_OUT, PORT##pfx##_IN)
583910df4d0SMarek Vasut #define PINMUX_DATA_ALL()		CPU_ALL_PORT(_PORT_DATA, , unused)
584910df4d0SMarek Vasut 
585910df4d0SMarek Vasut /* GPIO_FN(name) - Expand to a sh_pfc_pin entry for a function GPIO */
586910df4d0SMarek Vasut #define PINMUX_GPIO_FN(gpio, base, data_or_mark)			\
587910df4d0SMarek Vasut 	[gpio - (base)] = {						\
588910df4d0SMarek Vasut 		.name = __stringify(gpio),				\
589910df4d0SMarek Vasut 		.enum_id = data_or_mark,				\
590910df4d0SMarek Vasut 	}
591910df4d0SMarek Vasut #define GPIO_FN(str)							\
592910df4d0SMarek Vasut 	PINMUX_GPIO_FN(GPIO_FN_##str, PINMUX_FN_BASE, str##_MARK)
593910df4d0SMarek Vasut 
594910df4d0SMarek Vasut /*
595910df4d0SMarek Vasut  * PORTnCR helper macro for SH-Mobile/R-Mobile
596910df4d0SMarek Vasut  */
597910df4d0SMarek Vasut #define PORTCR(nr, reg)							\
598910df4d0SMarek Vasut 	{								\
599910df4d0SMarek Vasut 		PINMUX_CFG_REG_VAR("PORT" nr "CR", reg, 8, 2, 2, 1, 3) {\
600910df4d0SMarek Vasut 			/* PULMD[1:0], handled by .set_bias() */	\
601910df4d0SMarek Vasut 			0, 0, 0, 0,					\
602910df4d0SMarek Vasut 			/* IE and OE */					\
603910df4d0SMarek Vasut 			0, PORT##nr##_OUT, PORT##nr##_IN, 0,		\
604910df4d0SMarek Vasut 			/* SEC, not supported */			\
605910df4d0SMarek Vasut 			0, 0,						\
606910df4d0SMarek Vasut 			/* PTMD[2:0] */					\
607910df4d0SMarek Vasut 			PORT##nr##_FN0, PORT##nr##_FN1,			\
608910df4d0SMarek Vasut 			PORT##nr##_FN2, PORT##nr##_FN3,			\
609910df4d0SMarek Vasut 			PORT##nr##_FN4, PORT##nr##_FN5,			\
610910df4d0SMarek Vasut 			PORT##nr##_FN6, PORT##nr##_FN7			\
611910df4d0SMarek Vasut 		}							\
612910df4d0SMarek Vasut 	}
613910df4d0SMarek Vasut 
614910df4d0SMarek Vasut /*
615910df4d0SMarek Vasut  * GPIO number helper macro for R-Car
616910df4d0SMarek Vasut  */
617910df4d0SMarek Vasut #define RCAR_GP_PIN(bank, pin)		(((bank) * 32) + (pin))
618910df4d0SMarek Vasut 
619910df4d0SMarek Vasut #endif /* __SH_PFC_H */
620