xref: /linux/arch/arm/mach-pxa/mfp-pxa25x.h (revision 498495dba268b20e8eadd7fe93c140c68b6cc9d2)
1*b2441318SGreg Kroah-Hartman /* SPDX-License-Identifier: GPL-2.0 */
2a09e64fbSRussell King #ifndef __ASM_ARCH_MFP_PXA25X_H
3a09e64fbSRussell King #define __ASM_ARCH_MFP_PXA25X_H
4a09e64fbSRussell King 
54c25c5d2SArnd Bergmann #include "mfp-pxa2xx.h"
6a09e64fbSRussell King 
7a09e64fbSRussell King /* GPIO */
8a09e64fbSRussell King #define GPIO2_GPIO		MFP_CFG_IN(GPIO2, AF0)
9a09e64fbSRussell King #define GPIO3_GPIO		MFP_CFG_IN(GPIO3, AF0)
10a09e64fbSRussell King #define GPIO4_GPIO		MFP_CFG_IN(GPIO4, AF0)
11a09e64fbSRussell King #define GPIO5_GPIO		MFP_CFG_IN(GPIO5, AF0)
12a09e64fbSRussell King #define GPIO6_GPIO		MFP_CFG_IN(GPIO6, AF0)
13a09e64fbSRussell King #define GPIO7_GPIO		MFP_CFG_IN(GPIO7, AF0)
14a09e64fbSRussell King #define GPIO8_GPIO		MFP_CFG_IN(GPIO8, AF0)
15a09e64fbSRussell King 
16a09e64fbSRussell King #define GPIO1_RST		MFP_CFG_IN(GPIO1, AF1)
17a09e64fbSRussell King 
18a09e64fbSRussell King /* Crystal and Clock Signals */
19a09e64fbSRussell King #define GPIO10_RTCCLK		MFP_CFG_OUT(GPIO10, AF1, DRIVE_LOW)
204fa7c24eSEric Miao #define GPIO70_RTCCLK		MFP_CFG_OUT(GPIO70, AF1, DRIVE_LOW)
21a09e64fbSRussell King #define GPIO7_48MHz		MFP_CFG_OUT(GPIO7,  AF1, DRIVE_LOW)
22a09e64fbSRussell King #define GPIO11_3_6MHz		MFP_CFG_OUT(GPIO11, AF1, DRIVE_LOW)
23a09e64fbSRussell King #define GPIO71_3_6MHz		MFP_CFG_OUT(GPIO71, AF1, DRIVE_LOW)
24a09e64fbSRussell King #define GPIO12_32KHz		MFP_CFG_OUT(GPIO12, AF1, DRIVE_LOW)
25a09e64fbSRussell King #define GPIO72_32kHz		MFP_CFG_OUT(GPIO72, AF1, DRIVE_LOW)
26a09e64fbSRussell King 
27a09e64fbSRussell King /* SDRAM and Static Memory I/O Signals */
28a09e64fbSRussell King #define GPIO15_nCS_1		MFP_CFG_OUT(GPIO15, AF2, DRIVE_HIGH)
29a09e64fbSRussell King #define GPIO78_nCS_2		MFP_CFG_OUT(GPIO78, AF2, DRIVE_HIGH)
30a09e64fbSRussell King #define GPIO79_nCS_3		MFP_CFG_OUT(GPIO79, AF2, DRIVE_HIGH)
31a09e64fbSRussell King #define GPIO80_nCS_4		MFP_CFG_OUT(GPIO80, AF2, DRIVE_HIGH)
32a09e64fbSRussell King #define GPIO33_nCS_5		MFP_CFG_OUT(GPIO33, AF2, DRIVE_HIGH)
33a09e64fbSRussell King 
34a09e64fbSRussell King /* Miscellaneous I/O and DMA Signals */
35a09e64fbSRussell King #define GPIO18_RDY		MFP_CFG_IN(GPIO18, AF1)
36a09e64fbSRussell King #define GPIO20_DREQ_0		MFP_CFG_IN(GPIO20, AF1)
37a09e64fbSRussell King #define GPIO19_DREQ_1		MFP_CFG_IN(GPIO19, AF1)
38a09e64fbSRussell King 
39a09e64fbSRussell King /* Alternate Bus Master Mode I/O Signals */
40a09e64fbSRussell King #define GPIO13_MBGNT		MFP_CFG_OUT(GPIO13, AF2, DRIVE_LOW)
41a09e64fbSRussell King #define GPIO73_MBGNT		MFP_CFG_OUT(GPIO73, AF1, DRIVE_LOW)
42a09e64fbSRussell King #define GPIO14_MBREQ		MFP_CFG_IN(GPIO14, AF1)
43a09e64fbSRussell King #define GPIO66_MBREQ		MFP_CFG_IN(GPIO66, AF1)
44a09e64fbSRussell King 
45a09e64fbSRussell King /* PC CARD */
46a09e64fbSRussell King #define GPIO52_nPCE_1		MFP_CFG_OUT(GPIO52, AF2, DRIVE_HIGH)
47a09e64fbSRussell King #define GPIO53_nPCE_2		MFP_CFG_OUT(GPIO53, AF2, DRIVE_HIGH)
48a09e64fbSRussell King #define GPIO55_nPREG		MFP_CFG_OUT(GPIO55, AF2, DRIVE_HIGH)
49a09e64fbSRussell King #define GPIO50_nPIOR		MFP_CFG_OUT(GPIO50, AF2, DRIVE_HIGH)
50a09e64fbSRussell King #define GPIO51_nPIOW		MFP_CFG_OUT(GPIO51, AF2, DRIVE_HIGH)
51a09e64fbSRussell King #define GPIO49_nPWE		MFP_CFG_OUT(GPIO49, AF2, DRIVE_HIGH)
52a09e64fbSRussell King #define GPIO48_nPOE		MFP_CFG_OUT(GPIO48, AF2, DRIVE_HIGH)
53a09e64fbSRussell King #define GPIO57_nIOIS16		MFP_CFG_IN(GPIO57, AF1)
54a09e64fbSRussell King #define GPIO56_nPWAIT		MFP_CFG_IN(GPIO56, AF1)
55a09e64fbSRussell King #define GPIO54_nPSKTSEL		MFP_CFG_OUT(GPIO54, AF2, DRIVE_HIGH)
56a09e64fbSRussell King 
57a09e64fbSRussell King /* FFUART */
58a09e64fbSRussell King #define GPIO34_FFUART_RXD	MFP_CFG_IN(GPIO34, AF1)
59a09e64fbSRussell King #define GPIO35_FFUART_CTS	MFP_CFG_IN(GPIO35, AF1)
60a09e64fbSRussell King #define GPIO36_FFUART_DCD	MFP_CFG_IN(GPIO36, AF1)
61a09e64fbSRussell King #define GPIO37_FFUART_DSR	MFP_CFG_IN(GPIO37, AF1)
62a09e64fbSRussell King #define GPIO38_FFUART_RI	MFP_CFG_IN(GPIO38, AF1)
63a09e64fbSRussell King #define GPIO39_FFUART_TXD	MFP_CFG_OUT(GPIO39, AF2, DRIVE_HIGH)
64a09e64fbSRussell King #define GPIO40_FFUART_DTR	MFP_CFG_OUT(GPIO40, AF2, DRIVE_HIGH)
65a09e64fbSRussell King #define GPIO41_FFUART_RTS	MFP_CFG_OUT(GPIO41, AF2, DRIVE_HIGH)
66a09e64fbSRussell King 
67a09e64fbSRussell King /* BTUART */
68a09e64fbSRussell King #define GPIO42_BTUART_RXD	MFP_CFG_IN(GPIO42, AF1)
69a09e64fbSRussell King #define GPIO43_BTUART_TXD	MFP_CFG_OUT(GPIO43, AF2, DRIVE_HIGH)
70a09e64fbSRussell King #define GPIO44_BTUART_CTS	MFP_CFG_IN(GPIO44, AF1)
71a09e64fbSRussell King #define GPIO45_BTUART_RTS	MFP_CFG_OUT(GPIO45, AF2, DRIVE_HIGH)
72a09e64fbSRussell King 
73a09e64fbSRussell King /* STUART */
74a09e64fbSRussell King #define GPIO46_STUART_RXD	MFP_CFG_IN(GPIO46, AF2)
75a09e64fbSRussell King #define GPIO47_STUART_TXD	MFP_CFG_OUT(GPIO47, AF1, DRIVE_HIGH)
76a09e64fbSRussell King 
77a09e64fbSRussell King /* HWUART */
78a09e64fbSRussell King #define GPIO42_HWUART_RXD	MFP_CFG_IN(GPIO42, AF3)
79a09e64fbSRussell King #define GPIO43_HWUART_TXD	MFP_CFG_OUT(GPIO43, AF3, DRIVE_HIGH)
80a09e64fbSRussell King #define GPIO44_HWUART_CTS	MFP_CFG_IN(GPIO44, AF3)
81a09e64fbSRussell King #define GPIO45_HWUART_RTS	MFP_CFG_OUT(GPIO45, AF3, DRIVE_HIGH)
82a09e64fbSRussell King #define GPIO48_HWUART_TXD	MFP_CFG_OUT(GPIO48, AF1, DRIVE_HIGH)
83a09e64fbSRussell King #define GPIO49_HWUART_RXD	MFP_CFG_IN(GPIO49, AF1)
84a09e64fbSRussell King #define GPIO50_HWUART_CTS	MFP_CFG_IN(GPIO50, AF1)
85a09e64fbSRussell King #define GPIO51_HWUART_RTS	MFP_CFG_OUT(GPIO51, AF1, DRIVE_HIGH)
86a09e64fbSRussell King 
87a09e64fbSRussell King /* FICP */
88a09e64fbSRussell King #define GPIO46_FICP_RXD		MFP_CFG_IN(GPIO46, AF1)
89a09e64fbSRussell King #define GPIO47_FICP_TXD		MFP_CFG_OUT(GPIO47, AF2, DRIVE_HIGH)
90a09e64fbSRussell King 
91a09e64fbSRussell King /* PWM 0/1 */
92a09e64fbSRussell King #define GPIO16_PWM0_OUT		MFP_CFG_OUT(GPIO16, AF2, DRIVE_LOW)
93a09e64fbSRussell King #define GPIO17_PWM1_OUT		MFP_CFG_OUT(GPIO17, AF2, DRIVE_LOW)
94a09e64fbSRussell King 
95a09e64fbSRussell King /* AC97 */
96a09e64fbSRussell King #define GPIO28_AC97_BITCLK	MFP_CFG_IN(GPIO28, AF1)
97a09e64fbSRussell King #define GPIO29_AC97_SDATA_IN_0	MFP_CFG_IN(GPIO29, AF1)
98a09e64fbSRussell King #define GPIO30_AC97_SDATA_OUT	MFP_CFG_OUT(GPIO30, AF2, DRIVE_LOW)
99a09e64fbSRussell King #define GPIO31_AC97_SYNC	MFP_CFG_OUT(GPIO31, AF2, DRIVE_LOW)
100a09e64fbSRussell King #define GPIO32_AC97_SDATA_IN_1	MFP_CFG_IN(GPIO32, AF1)
101a09e64fbSRussell King 
102a09e64fbSRussell King /* I2S */
103a09e64fbSRussell King #define GPIO28_I2S_BITCLK_IN	MFP_CFG_IN(GPIO28, AF2)
104a09e64fbSRussell King #define GPIO28_I2S_BITCLK_OUT	MFP_CFG_OUT(GPIO28, AF1, DRIVE_LOW)
105a09e64fbSRussell King #define GPIO29_I2S_SDATA_IN	MFP_CFG_IN(GPIO29, AF2)
106a09e64fbSRussell King #define GPIO30_I2S_SDATA_OUT	MFP_CFG_OUT(GPIO30, AF1, DRIVE_LOW)
107a09e64fbSRussell King #define GPIO31_I2S_SYNC		MFP_CFG_OUT(GPIO31, AF1, DRIVE_LOW)
108a09e64fbSRussell King #define GPIO32_I2S_SYSCLK	MFP_CFG_OUT(GPIO32, AF1, DRIVE_LOW)
109a09e64fbSRussell King 
110a09e64fbSRussell King /* SSP 1 */
111a09e64fbSRussell King #define GPIO23_SSP1_SCLK	MFP_CFG_OUT(GPIO23, AF2, DRIVE_LOW)
112a09e64fbSRussell King #define GPIO24_SSP1_SFRM	MFP_CFG_OUT(GPIO24, AF2, DRIVE_LOW)
113a09e64fbSRussell King #define GPIO25_SSP1_TXD		MFP_CFG_OUT(GPIO25, AF2, DRIVE_LOW)
114a09e64fbSRussell King #define GPIO26_SSP1_RXD		MFP_CFG_IN(GPIO26, AF1)
115a09e64fbSRussell King #define GPIO27_SSP1_EXTCLK	MFP_CFG_IN(GPIO27, AF1)
116a09e64fbSRussell King 
117a09e64fbSRussell King /* SSP 2 - NSSP */
118a09e64fbSRussell King #define GPIO81_SSP2_CLK_OUT 	MFP_CFG_OUT(GPIO81, AF1, DRIVE_LOW)
119a09e64fbSRussell King #define GPIO81_SSP2_CLK_IN  	MFP_CFG_IN(GPIO81, AF1)
120a09e64fbSRussell King #define GPIO82_SSP2_FRM_OUT 	MFP_CFG_OUT(GPIO82, AF1, DRIVE_LOW)
121a09e64fbSRussell King #define GPIO82_SSP2_FRM_IN  	MFP_CFG_IN(GPIO82, AF1)
122a09e64fbSRussell King #define GPIO83_SSP2_TXD      	MFP_CFG_OUT(GPIO83, AF1, DRIVE_LOW)
123a09e64fbSRussell King #define GPIO83_SSP2_RXD      	MFP_CFG_IN(GPIO83, AF2)
124a09e64fbSRussell King #define GPIO84_SSP2_TXD      	MFP_CFG_OUT(GPIO84, AF1, DRIVE_LOW)
125a09e64fbSRussell King #define GPIO84_SSP2_RXD      	MFP_CFG_IN(GPIO84, AF2)
126a09e64fbSRussell King 
127a09e64fbSRussell King /* MMC */
128a09e64fbSRussell King #define GPIO6_MMC_CLK		MFP_CFG_OUT(GPIO6, AF1, DRIVE_LOW)
129a09e64fbSRussell King #define GPIO8_MMC_CS0		MFP_CFG_OUT(GPIO8, AF1, DRIVE_LOW)
130a09e64fbSRussell King #define GPIO9_MMC_CS1		MFP_CFG_OUT(GPIO9, AF1, DRIVE_LOW)
131a09e64fbSRussell King #define GPIO34_MMC_CS0		MFP_CFG_OUT(GPIO34, AF2, DRIVE_LOW)
132a09e64fbSRussell King #define GPIO39_MMC_CS1		MFP_CFG_OUT(GPIO39, AF1, DRIVE_LOW)
133a09e64fbSRussell King #define GPIO53_MMC_CLK		MFP_CFG_OUT(GPIO53, AF1, DRIVE_LOW)
134a09e64fbSRussell King #define GPIO54_MMC_CLK		MFP_CFG_OUT(GPIO54, AF1, DRIVE_LOW)
135a09e64fbSRussell King #define GPIO69_MMC_CLK		MFP_CFG_OUT(GPIO69, AF1, DRIVE_LOW)
136a09e64fbSRussell King #define GPIO67_MMC_CS0		MFP_CFG_OUT(GPIO67, AF1, DRIVE_LOW)
137a09e64fbSRussell King #define GPIO68_MMC_CS1		MFP_CFG_OUT(GPIO68, AF1, DRIVE_LOW)
138a09e64fbSRussell King 
139a09e64fbSRussell King /* LCD */
140a09e64fbSRussell King #define GPIO58_LCD_LDD_0	MFP_CFG_OUT(GPIO58, AF2, DRIVE_LOW)
141a09e64fbSRussell King #define GPIO59_LCD_LDD_1	MFP_CFG_OUT(GPIO59, AF2, DRIVE_LOW)
142a09e64fbSRussell King #define GPIO60_LCD_LDD_2	MFP_CFG_OUT(GPIO60, AF2, DRIVE_LOW)
143a09e64fbSRussell King #define GPIO61_LCD_LDD_3	MFP_CFG_OUT(GPIO61, AF2, DRIVE_LOW)
144a09e64fbSRussell King #define GPIO62_LCD_LDD_4	MFP_CFG_OUT(GPIO62, AF2, DRIVE_LOW)
145a09e64fbSRussell King #define GPIO63_LCD_LDD_5	MFP_CFG_OUT(GPIO63, AF2, DRIVE_LOW)
146a09e64fbSRussell King #define GPIO64_LCD_LDD_6	MFP_CFG_OUT(GPIO64, AF2, DRIVE_LOW)
147a09e64fbSRussell King #define GPIO65_LCD_LDD_7	MFP_CFG_OUT(GPIO65, AF2, DRIVE_LOW)
148a09e64fbSRussell King #define GPIO66_LCD_LDD_8	MFP_CFG_OUT(GPIO66, AF2, DRIVE_LOW)
149a09e64fbSRussell King #define GPIO67_LCD_LDD_9	MFP_CFG_OUT(GPIO67, AF2, DRIVE_LOW)
150a09e64fbSRussell King #define GPIO68_LCD_LDD_10	MFP_CFG_OUT(GPIO68, AF2, DRIVE_LOW)
151a09e64fbSRussell King #define GPIO69_LCD_LDD_11	MFP_CFG_OUT(GPIO69, AF2, DRIVE_LOW)
152a09e64fbSRussell King #define GPIO70_LCD_LDD_12	MFP_CFG_OUT(GPIO70, AF2, DRIVE_LOW)
153a09e64fbSRussell King #define GPIO71_LCD_LDD_13	MFP_CFG_OUT(GPIO71, AF2, DRIVE_LOW)
154a09e64fbSRussell King #define GPIO72_LCD_LDD_14	MFP_CFG_OUT(GPIO72, AF2, DRIVE_LOW)
155a09e64fbSRussell King #define GPIO73_LCD_LDD_15	MFP_CFG_OUT(GPIO73, AF2, DRIVE_LOW)
156a09e64fbSRussell King #define GPIO74_LCD_FCLK		MFP_CFG_OUT(GPIO74, AF2, DRIVE_LOW)
157a09e64fbSRussell King #define GPIO75_LCD_LCLK		MFP_CFG_OUT(GPIO75, AF2, DRIVE_LOW)
158a09e64fbSRussell King #define GPIO76_LCD_PCLK		MFP_CFG_OUT(GPIO76, AF2, DRIVE_LOW)
1594fa7c24eSEric Miao #define GPIO77_LCD_BIAS		MFP_CFG_OUT(GPIO77, AF2, DRIVE_LOW)
160a09e64fbSRussell King 
161067455aaSEric Miao #ifdef CONFIG_CPU_PXA26x
162067455aaSEric Miao /* GPIO */
163067455aaSEric Miao #define GPIO85_GPIO		MFP_CFG_IN(GPIO85, AF0)
164067455aaSEric Miao #define GPIO86_GPIO		MFP_CFG_IN(GPIO86, AF1)
165067455aaSEric Miao #define GPIO87_GPIO		MFP_CFG_IN(GPIO87, AF1)
166067455aaSEric Miao #define GPIO88_GPIO		MFP_CFG_IN(GPIO88, AF1)
167067455aaSEric Miao #define GPIO89_GPIO		MFP_CFG_IN(GPIO89, AF1)
168067455aaSEric Miao 
169067455aaSEric Miao /* SDRAM */
170067455aaSEric Miao #define GPIO86_nSDCS2		MFP_CFG_OUT(GPIO86, AF0, DRIVE_HIGH)
171067455aaSEric Miao #define GPIO87_nSDCS3		MFP_CFG_OUT(GPIO87, AF0, DRIVE_HIGH)
172067455aaSEric Miao #define GPIO88_RDnWR		MFP_CFG_OUT(GPIO88, AF0, DRIVE_HIGH)
173067455aaSEric Miao 
174067455aaSEric Miao /* USB */
175067455aaSEric Miao #define GPIO9_USB_RCV		MFP_CFG_IN(GPIO9, AF1)
176067455aaSEric Miao #define GPIO32_USB_VP		MFP_CFG_IN(GPIO32, AF2)
177067455aaSEric Miao #define GPIO34_USB_VM		MFP_CFG_IN(GPIO34, AF2)
178067455aaSEric Miao #define GPIO39_USB_VPO		MFP_CFG_OUT(GPIO39, AF3, DRIVE_LOW)
179067455aaSEric Miao #define GPIO56_USB_VMO		MFP_CFG_OUT(GPIO56, AF1, DRIVE_LOW)
180067455aaSEric Miao #define GPIO57_USB_nOE		MFP_CFG_OUT(GPIO57, AF1, DRIVE_HIGH)
181067455aaSEric Miao 
182067455aaSEric Miao /* ASSP */
183067455aaSEric Miao #define GPIO28_ASSP_BITCLK_IN	MFP_CFG_IN(GPIO28, AF3)
184067455aaSEric Miao #define GPIO28_ASSP_BITCLK_OUT	MFP_CFG_OUT(GPIO28, AF3, DRIVE_LOW)
185067455aaSEric Miao #define GPIO29_ASSP_RXD		MFP_CFG_IN(GPIO29, AF3)
186067455aaSEric Miao #define GPIO30_ASSP_TXD		MFP_CFG_OUT(GPIO30, AF3, DRIVE_LOW)
187067455aaSEric Miao #define GPIO31_ASSP_SFRM_IN	MFP_CFG_IN(GPIO31, AF1)
188067455aaSEric Miao #define GPIO31_ASSP_SFRM_OUT	MFP_CFG_OUT(GPIO31, AF3, DRIVE_LOW)
189463de209SEric Miao 
190463de209SEric Miao /* AC97 */
191463de209SEric Miao #define GPIO89_AC97_nRESET	MFP_CFG_OUT(GPIO89, AF0, DRIVE_HIGH)
192463de209SEric Miao #endif	/* CONFIG_CPU_PXA26x */
193067455aaSEric Miao 
19407bae6c3SEric Miao /* commonly used pin configurations */
19507bae6c3SEric Miao #define GPIOxx_LCD_16BPP	\
19607bae6c3SEric Miao 	GPIO58_LCD_LDD_0,	\
19707bae6c3SEric Miao 	GPIO59_LCD_LDD_1,	\
19807bae6c3SEric Miao 	GPIO60_LCD_LDD_2,	\
19907bae6c3SEric Miao 	GPIO61_LCD_LDD_3,	\
20007bae6c3SEric Miao 	GPIO62_LCD_LDD_4,	\
20107bae6c3SEric Miao 	GPIO63_LCD_LDD_5,	\
20207bae6c3SEric Miao 	GPIO64_LCD_LDD_6,	\
20307bae6c3SEric Miao 	GPIO65_LCD_LDD_7,	\
20407bae6c3SEric Miao 	GPIO66_LCD_LDD_8,	\
20507bae6c3SEric Miao 	GPIO67_LCD_LDD_9,	\
20607bae6c3SEric Miao 	GPIO68_LCD_LDD_10,	\
20707bae6c3SEric Miao 	GPIO69_LCD_LDD_11,	\
20807bae6c3SEric Miao 	GPIO70_LCD_LDD_12,	\
20907bae6c3SEric Miao 	GPIO71_LCD_LDD_13,	\
21007bae6c3SEric Miao 	GPIO72_LCD_LDD_14,	\
21107bae6c3SEric Miao 	GPIO73_LCD_LDD_15
21207bae6c3SEric Miao 
21307bae6c3SEric Miao #define GPIOxx_LCD_DSTN_16BPP	\
21407bae6c3SEric Miao 	GPIOxx_LCD_16BPP,	\
21507bae6c3SEric Miao 	GPIO74_LCD_FCLK,	\
21607bae6c3SEric Miao 	GPIO75_LCD_LCLK,	\
21707bae6c3SEric Miao 	GPIO76_LCD_PCLK
21807bae6c3SEric Miao 
21907bae6c3SEric Miao #define GPIOxx_LCD_TFT_16BPP	\
22007bae6c3SEric Miao 	GPIOxx_LCD_16BPP,	\
22107bae6c3SEric Miao 	GPIO74_LCD_FCLK,	\
22207bae6c3SEric Miao 	GPIO75_LCD_LCLK,	\
22307bae6c3SEric Miao 	GPIO76_LCD_PCLK,	\
22407bae6c3SEric Miao 	GPIO77_LCD_BIAS
22507bae6c3SEric Miao 
226a09e64fbSRussell King #endif /* __ASM_ARCH_MFP_PXA25X_H */
227