Back to home page

OSCL-LXR

 
 

    


0001 /* SPDX-License-Identifier: GPL-2.0 */
0002 #ifndef __ASM_ARCH_MFP_PXA27X_H
0003 #define __ASM_ARCH_MFP_PXA27X_H
0004 
0005 /*
0006  * NOTE:  for those special-function bidirectional GPIOs, as described
0007  * in the "PXA27x Developer's Manual" Section 24.4.2.1, only its input
0008  * alternative is preserved, the direction is actually selected by the
0009  * specific controller, and this should work in most cases.
0010  */
0011 
0012 #include "mfp-pxa2xx.h"
0013 
0014 /* Note: GPIO3/GPIO4 will be driven by Power I2C when PCFR/PI2C_EN
0015  * bit is set, regardless of the GPIO configuration
0016  */
0017 #define GPIO3_GPIO      MFP_CFG_IN(GPIO3, AF0)
0018 #define GPIO4_GPIO      MFP_CFG_IN(GPIO4, AF0)
0019 
0020 /* GPIO */
0021 #define GPIO85_GPIO     MFP_CFG_IN(GPIO85, AF0)
0022 #define GPIO86_GPIO     MFP_CFG_IN(GPIO86, AF0)
0023 #define GPIO87_GPIO     MFP_CFG_IN(GPIO87, AF0)
0024 #define GPIO88_GPIO     MFP_CFG_IN(GPIO88, AF0)
0025 #define GPIO89_GPIO     MFP_CFG_IN(GPIO89, AF0)
0026 #define GPIO90_GPIO     MFP_CFG_IN(GPIO90, AF0)
0027 #define GPIO91_GPIO     MFP_CFG_IN(GPIO91, AF0)
0028 #define GPIO92_GPIO     MFP_CFG_IN(GPIO92, AF0)
0029 #define GPIO93_GPIO     MFP_CFG_IN(GPIO93, AF0)
0030 #define GPIO94_GPIO     MFP_CFG_IN(GPIO94, AF0)
0031 #define GPIO95_GPIO     MFP_CFG_IN(GPIO95, AF0)
0032 #define GPIO96_GPIO     MFP_CFG_IN(GPIO96, AF0)
0033 #define GPIO97_GPIO     MFP_CFG_IN(GPIO97, AF0)
0034 #define GPIO98_GPIO     MFP_CFG_IN(GPIO98, AF0)
0035 #define GPIO99_GPIO     MFP_CFG_IN(GPIO99, AF0)
0036 #define GPIO100_GPIO        MFP_CFG_IN(GPIO100, AF0)
0037 #define GPIO101_GPIO        MFP_CFG_IN(GPIO101, AF0)
0038 #define GPIO102_GPIO        MFP_CFG_IN(GPIO102, AF0)
0039 #define GPIO103_GPIO        MFP_CFG_IN(GPIO103, AF0)
0040 #define GPIO104_GPIO        MFP_CFG_IN(GPIO104, AF0)
0041 #define GPIO105_GPIO        MFP_CFG_IN(GPIO105, AF0)
0042 #define GPIO106_GPIO        MFP_CFG_IN(GPIO106, AF0)
0043 #define GPIO107_GPIO        MFP_CFG_IN(GPIO107, AF0)
0044 #define GPIO108_GPIO        MFP_CFG_IN(GPIO108, AF0)
0045 #define GPIO109_GPIO        MFP_CFG_IN(GPIO109, AF0)
0046 #define GPIO110_GPIO        MFP_CFG_IN(GPIO110, AF0)
0047 #define GPIO111_GPIO        MFP_CFG_IN(GPIO111, AF0)
0048 #define GPIO112_GPIO        MFP_CFG_IN(GPIO112, AF0)
0049 #define GPIO113_GPIO        MFP_CFG_IN(GPIO113, AF0)
0050 #define GPIO114_GPIO        MFP_CFG_IN(GPIO114, AF0)
0051 #define GPIO115_GPIO        MFP_CFG_IN(GPIO115, AF0)
0052 #define GPIO116_GPIO        MFP_CFG_IN(GPIO116, AF0)
0053 #define GPIO117_GPIO        MFP_CFG_IN(GPIO117, AF0)
0054 #define GPIO118_GPIO        MFP_CFG_IN(GPIO118, AF0)
0055 #define GPIO119_GPIO        MFP_CFG_IN(GPIO119, AF0)
0056 #define GPIO120_GPIO        MFP_CFG_IN(GPIO120, AF0)
0057 
0058 /* Crystal and Clock Signals */
0059 #define GPIO9_HZ_CLK        MFP_CFG_OUT(GPIO9,  AF1, DRIVE_LOW)
0060 #define GPIO10_HZ_CLK       MFP_CFG_OUT(GPIO10, AF1, DRIVE_LOW)
0061 #define GPIO11_48_MHz       MFP_CFG_OUT(GPIO11, AF3, DRIVE_LOW)
0062 #define GPIO12_48_MHz       MFP_CFG_OUT(GPIO12, AF3, DRIVE_LOW)
0063 #define GPIO13_CLK_EXT      MFP_CFG_IN(GPIO13, AF1)
0064 
0065 /* OS Timer Signals */
0066 #define GPIO11_EXT_SYNC_0   MFP_CFG_IN(GPIO11, AF1)
0067 #define GPIO12_EXT_SYNC_1   MFP_CFG_IN(GPIO12, AF1)
0068 #define GPIO9_CHOUT_0       MFP_CFG_OUT(GPIO9,  AF3, DRIVE_LOW)
0069 #define GPIO10_CHOUT_1      MFP_CFG_OUT(GPIO10, AF3, DRIVE_LOW)
0070 #define GPIO11_CHOUT_0      MFP_CFG_OUT(GPIO11, AF1, DRIVE_LOW)
0071 #define GPIO12_CHOUT_1      MFP_CFG_OUT(GPIO12, AF1, DRIVE_LOW)
0072 
0073 /* SDRAM and Static Memory I/O Signals */
0074 #define GPIO20_nSDCS_2      MFP_CFG_OUT(GPIO20, AF1, DRIVE_HIGH)
0075 #define GPIO21_nSDCS_3      MFP_CFG_OUT(GPIO21, AF1, DRIVE_HIGH)
0076 #define GPIO15_nCS_1        MFP_CFG_OUT(GPIO15, AF2, DRIVE_HIGH)
0077 #define GPIO78_nCS_2        MFP_CFG_OUT(GPIO78, AF2, DRIVE_HIGH)
0078 #define GPIO79_nCS_3        MFP_CFG_OUT(GPIO79, AF2, DRIVE_HIGH)
0079 #define GPIO80_nCS_4        MFP_CFG_OUT(GPIO80, AF2, DRIVE_HIGH)
0080 #define GPIO33_nCS_5        MFP_CFG_OUT(GPIO33, AF2, DRIVE_HIGH)
0081 
0082 /* Miscellaneous I/O and DMA Signals */
0083 #define GPIO21_DVAL_0       MFP_CFG_OUT(GPIO21, AF2, DRIVE_HIGH)
0084 #define GPIO116_DVAL_0      MFP_CFG_OUT(GPIO116, AF1, DRIVE_HIGH)
0085 #define GPIO33_DVAL_1       MFP_CFG_OUT(GPIO33, AF1, DRIVE_HIGH)
0086 #define GPIO96_DVAL_1       MFP_CFG_OUT(GPIO96, AF2, DRIVE_HIGH)
0087 #define GPIO18_RDY      MFP_CFG_IN(GPIO18, AF1)
0088 #define GPIO20_DREQ_0       MFP_CFG_IN(GPIO20, AF1)
0089 #define GPIO115_DREQ_0      MFP_CFG_IN(GPIO115, AF1)
0090 #define GPIO80_DREQ_1       MFP_CFG_IN(GPIO80, AF1)
0091 #define GPIO97_DREQ_1       MFP_CFG_IN(GPIO97, AF2)
0092 #define GPIO85_DREQ_2       MFP_CFG_IN(GPIO85, AF2)
0093 #define GPIO100_DREQ_2      MFP_CFG_IN(GPIO100, AF2)
0094 
0095 /* Alternate Bus Master Mode I/O Signals */
0096 #define GPIO20_MBREQ        MFP_CFG_IN(GPIO20, AF2)
0097 #define GPIO80_MBREQ        MFP_CFG_IN(GPIO80, AF2)
0098 #define GPIO96_MBREQ        MFP_CFG_IN(GPIO96, AF2)
0099 #define GPIO115_MBREQ       MFP_CFG_IN(GPIO115, AF3)
0100 #define GPIO21_MBGNT        MFP_CFG_OUT(GPIO21, AF3, DRIVE_LOW)
0101 #define GPIO33_MBGNT        MFP_CFG_OUT(GPIO33, AF3, DRIVE_LOW)
0102 #define GPIO97_MBGNT        MFP_CFG_OUT(GPIO97, AF2, DRIVE_LOW)
0103 #define GPIO116_MBGNT       MFP_CFG_OUT(GPIO116, AF3, DRIVE_LOW)
0104 
0105 /* PC CARD */
0106 #define GPIO15_nPCE_1       MFP_CFG_OUT(GPIO15, AF1, DRIVE_HIGH)
0107 #define GPIO85_nPCE_1       MFP_CFG_OUT(GPIO85, AF1, DRIVE_HIGH)
0108 #define GPIO86_nPCE_1       MFP_CFG_OUT(GPIO86, AF1, DRIVE_HIGH)
0109 #define GPIO102_nPCE_1      MFP_CFG_OUT(GPIO102, AF1, DRIVE_HIGH)
0110 #define GPIO54_nPCE_2       MFP_CFG_OUT(GPIO54, AF2, DRIVE_HIGH)
0111 #define GPIO78_nPCE_2       MFP_CFG_OUT(GPIO78, AF1, DRIVE_HIGH)
0112 #define GPIO87_nPCE_2       MFP_CFG_IN(GPIO87, AF1)
0113 #define GPIO55_nPREG        MFP_CFG_OUT(GPIO55, AF2, DRIVE_HIGH)
0114 #define GPIO50_nPIOR        MFP_CFG_OUT(GPIO50, AF2, DRIVE_HIGH)
0115 #define GPIO51_nPIOW        MFP_CFG_OUT(GPIO51, AF2, DRIVE_HIGH)
0116 #define GPIO49_nPWE     MFP_CFG_OUT(GPIO49, AF2, DRIVE_HIGH)
0117 #define GPIO48_nPOE     MFP_CFG_OUT(GPIO48, AF2, DRIVE_HIGH)
0118 #define GPIO57_nIOIS16      MFP_CFG_IN(GPIO57, AF1)
0119 #define GPIO56_nPWAIT       MFP_CFG_IN(GPIO56, AF1)
0120 #define GPIO79_PSKTSEL      MFP_CFG_OUT(GPIO79, AF1, DRIVE_HIGH)
0121 #define GPIO104_PSKTSEL     MFP_CFG_OUT(GPIO104, AF1, DRIVE_HIGH)
0122 
0123 /* I2C */
0124 #define GPIO117_I2C_SCL     MFP_CFG_IN(GPIO117, AF1)
0125 #define GPIO118_I2C_SDA     MFP_CFG_IN(GPIO118, AF1)
0126 
0127 /* FFUART */
0128 #define GPIO9_FFUART_CTS    MFP_CFG_IN(GPIO9, AF3)
0129 #define GPIO26_FFUART_CTS   MFP_CFG_IN(GPIO26, AF3)
0130 #define GPIO35_FFUART_CTS   MFP_CFG_IN(GPIO35, AF1)
0131 #define GPIO100_FFUART_CTS  MFP_CFG_IN(GPIO100, AF3)
0132 #define GPIO10_FFUART_DCD   MFP_CFG_IN(GPIO10, AF1)
0133 #define GPIO36_FFUART_DCD   MFP_CFG_IN(GPIO36, AF1)
0134 #define GPIO33_FFUART_DSR   MFP_CFG_IN(GPIO33, AF2)
0135 #define GPIO37_FFUART_DSR   MFP_CFG_IN(GPIO37, AF1)
0136 #define GPIO38_FFUART_RI    MFP_CFG_IN(GPIO38, AF1)
0137 #define GPIO89_FFUART_RI    MFP_CFG_IN(GPIO89, AF3)
0138 #define GPIO19_FFUART_RXD   MFP_CFG_IN(GPIO19, AF3)
0139 #define GPIO33_FFUART_RXD   MFP_CFG_IN(GPIO33, AF1)
0140 #define GPIO34_FFUART_RXD   MFP_CFG_IN(GPIO34, AF1)
0141 #define GPIO41_FFUART_RXD   MFP_CFG_IN(GPIO41, AF1)
0142 #define GPIO53_FFUART_RXD   MFP_CFG_IN(GPIO53, AF1)
0143 #define GPIO85_FFUART_RXD   MFP_CFG_IN(GPIO85, AF1)
0144 #define GPIO96_FFUART_RXD   MFP_CFG_IN(GPIO96, AF3)
0145 #define GPIO102_FFUART_RXD  MFP_CFG_IN(GPIO102, AF3)
0146 #define GPIO16_FFUART_TXD   MFP_CFG_OUT(GPIO16, AF3, DRIVE_HIGH)
0147 #define GPIO37_FFUART_TXD   MFP_CFG_OUT(GPIO37, AF3, DRIVE_HIGH)
0148 #define GPIO39_FFUART_TXD   MFP_CFG_OUT(GPIO39, AF2, DRIVE_HIGH)
0149 #define GPIO83_FFUART_TXD   MFP_CFG_OUT(GPIO83, AF2, DRIVE_HIGH)
0150 #define GPIO99_FFUART_TXD   MFP_CFG_OUT(GPIO99, AF3, DRIVE_HIGH)
0151 #define GPIO27_FFUART_RTS   MFP_CFG_OUT(GPIO27, AF3, DRIVE_HIGH)
0152 #define GPIO41_FFUART_RTS   MFP_CFG_OUT(GPIO41, AF2, DRIVE_HIGH)
0153 #define GPIO83_FFUART_RTS   MFP_CFG_OUT(GPIO83, AF3, DRIVE_HIGH)
0154 #define GPIO98_FFUART_RTS   MFP_CFG_OUT(GPIO98, AF3, DRIVE_HIGH)
0155 #define GPIO40_FFUART_DTR   MFP_CFG_OUT(GPIO40, AF2, DRIVE_HIGH)
0156 #define GPIO82_FFUART_DTR   MFP_CFG_OUT(GPIO82, AF3, DRIVE_HIGH)
0157 
0158 /* BTUART */
0159 #define GPIO44_BTUART_CTS   MFP_CFG_IN(GPIO44, AF1)
0160 #define GPIO42_BTUART_RXD   MFP_CFG_IN(GPIO42, AF1)
0161 #define GPIO45_BTUART_RTS   MFP_CFG_OUT(GPIO45, AF2, DRIVE_HIGH)
0162 #define GPIO45_BTUART_RTS_LPM_LOW   MFP_CFG_OUT(GPIO45, AF2, DRIVE_LOW)
0163 #define GPIO43_BTUART_TXD   MFP_CFG_OUT(GPIO43, AF2, DRIVE_HIGH)
0164 #define GPIO43_BTUART_TXD_LPM_LOW   MFP_CFG_OUT(GPIO43, AF2, DRIVE_LOW)
0165 
0166 /* STUART */
0167 #define GPIO46_STUART_RXD   MFP_CFG_IN(GPIO46, AF2)
0168 #define GPIO47_STUART_TXD   MFP_CFG_OUT(GPIO47, AF1, DRIVE_HIGH)
0169 
0170 /* FICP */
0171 #define GPIO42_FICP_RXD     MFP_CFG_IN(GPIO42, AF2)
0172 #define GPIO46_FICP_RXD     MFP_CFG_IN(GPIO46, AF1)
0173 #define GPIO43_FICP_TXD     MFP_CFG_OUT(GPIO43, AF1, DRIVE_HIGH)
0174 #define GPIO47_FICP_TXD     MFP_CFG_OUT(GPIO47, AF2, DRIVE_HIGH)
0175 
0176 /* PWM 0/1/2/3 */
0177 #define GPIO11_PWM2_OUT     MFP_CFG_OUT(GPIO11, AF2, DRIVE_LOW)
0178 #define GPIO12_PWM3_OUT     MFP_CFG_OUT(GPIO12, AF2, DRIVE_LOW)
0179 #define GPIO16_PWM0_OUT     MFP_CFG_OUT(GPIO16, AF2, DRIVE_LOW)
0180 #define GPIO17_PWM1_OUT     MFP_CFG_OUT(GPIO17, AF2, DRIVE_LOW)
0181 #define GPIO38_PWM1_OUT     MFP_CFG_OUT(GPIO38, AF3, DRIVE_LOW)
0182 #define GPIO46_PWM2_OUT     MFP_CFG_OUT(GPIO46, AF2, DRIVE_LOW)
0183 #define GPIO47_PWM3_OUT     MFP_CFG_OUT(GPIO47, AF3, DRIVE_LOW)
0184 #define GPIO79_PWM2_OUT     MFP_CFG_OUT(GPIO79, AF3, DRIVE_LOW)
0185 #define GPIO80_PWM3_OUT     MFP_CFG_OUT(GPIO80, AF3, DRIVE_LOW)
0186 #define GPIO115_PWM1_OUT    MFP_CFG_OUT(GPIO115, AF3, DRIVE_LOW)
0187 
0188 /* AC97 */
0189 #define GPIO31_AC97_SYNC    MFP_CFG_OUT(GPIO31, AF2, DRIVE_LOW)
0190 #define GPIO94_AC97_SYNC    MFP_CFG_OUT(GPIO94, AF1, DRIVE_LOW)
0191 #define GPIO30_AC97_SDATA_OUT   MFP_CFG_OUT(GPIO30, AF2, DRIVE_LOW)
0192 #define GPIO93_AC97_SDATA_OUT   MFP_CFG_OUT(GPIO93, AF1, DRIVE_LOW)
0193 #define GPIO45_AC97_SYSCLK  MFP_CFG_OUT(GPIO45, AF1, DRIVE_LOW)
0194 #define GPIO89_AC97_SYSCLK  MFP_CFG_OUT(GPIO89, AF1, DRIVE_LOW)
0195 #define GPIO98_AC97_SYSCLK  MFP_CFG_OUT(GPIO98, AF1, DRIVE_LOW)
0196 #define GPIO95_AC97_nRESET  MFP_CFG_OUT(GPIO95, AF1, DRIVE_LOW)
0197 #define GPIO113_AC97_nRESET MFP_CFG_OUT(GPIO113, AF2, DRIVE_LOW)
0198 #define GPIO28_AC97_BITCLK  MFP_CFG_IN(GPIO28, AF1)
0199 #define GPIO29_AC97_SDATA_IN_0  MFP_CFG_IN(GPIO29, AF1)
0200 #define GPIO116_AC97_SDATA_IN_0 MFP_CFG_IN(GPIO116, AF2)
0201 #define GPIO99_AC97_SDATA_IN_1  MFP_CFG_IN(GPIO99, AF2)
0202 
0203 /* I2S */
0204 #define GPIO28_I2S_BITCLK_IN    MFP_CFG_IN(GPIO28, AF2)
0205 #define GPIO28_I2S_BITCLK_OUT   MFP_CFG_OUT(GPIO28, AF1, DRIVE_LOW)
0206 #define GPIO29_I2S_SDATA_IN MFP_CFG_IN(GPIO29, AF2)
0207 #define GPIO30_I2S_SDATA_OUT    MFP_CFG_OUT(GPIO30, AF1, DRIVE_LOW)
0208 #define GPIO31_I2S_SYNC     MFP_CFG_OUT(GPIO31, AF1, DRIVE_LOW)
0209 #define GPIO113_I2S_SYSCLK  MFP_CFG_OUT(GPIO113, AF1, DRIVE_LOW)
0210 
0211 /* SSP 1 */
0212 #define GPIO23_SSP1_SCLK_IN MFP_CFG_IN(GPIO23, AF2)
0213 #define GPIO23_SSP1_SCLK    MFP_CFG_OUT(GPIO23, AF2, DRIVE_LOW)
0214 #define GPIO29_SSP1_SCLK    MFP_CFG_IN(GPIO29, AF3)
0215 #define GPIO27_SSP1_SYSCLK  MFP_CFG_OUT(GPIO27, AF1, DRIVE_LOW)
0216 #define GPIO53_SSP1_SYSCLK  MFP_CFG_OUT(GPIO53, AF3, DRIVE_LOW)
0217 #define GPIO24_SSP1_SFRM    MFP_CFG_IN(GPIO24, AF2)
0218 #define GPIO28_SSP1_SFRM    MFP_CFG_IN(GPIO28, AF3)
0219 #define GPIO25_SSP1_TXD     MFP_CFG_OUT(GPIO25, AF2, DRIVE_LOW)
0220 #define GPIO57_SSP1_TXD     MFP_CFG_OUT(GPIO57, AF3, DRIVE_LOW)
0221 #define GPIO26_SSP1_RXD     MFP_CFG_IN(GPIO26, AF1)
0222 #define GPIO27_SSP1_SCLKEN  MFP_CFG_IN(GPIO27, AF2)
0223 
0224 /* SSP 2 */
0225 #define GPIO19_SSP2_SCLK    MFP_CFG_IN(GPIO19, AF1)
0226 #define GPIO22_SSP2_SCLK    MFP_CFG_IN(GPIO22, AF3)
0227 #define GPIO29_SSP2_SCLK    MFP_CFG_OUT(GPIO29, AF3, DRIVE_LOW)
0228 #define GPIO36_SSP2_SCLK    MFP_CFG_IN(GPIO36, AF2)
0229 #define GPIO50_SSP2_SCLK    MFP_CFG_IN(GPIO50, AF3)
0230 #define GPIO22_SSP2_SYSCLK  MFP_CFG_OUT(GPIO22, AF2, DRIVE_LOW)
0231 #define GPIO14_SSP2_SFRM    MFP_CFG_IN(GPIO14, AF2)
0232 #define GPIO37_SSP2_SFRM    MFP_CFG_IN(GPIO37, AF2)
0233 #define GPIO87_SSP2_SFRM    MFP_CFG_OUT(GPIO87, AF3, DRIVE_LOW)
0234 #define GPIO88_SSP2_SFRM    MFP_CFG_IN(GPIO88, AF3)
0235 #define GPIO13_SSP2_TXD     MFP_CFG_OUT(GPIO13, AF1, DRIVE_LOW)
0236 #define GPIO38_SSP2_TXD     MFP_CFG_OUT(GPIO38, AF2, DRIVE_LOW)
0237 #define GPIO87_SSP2_TXD     MFP_CFG_OUT(GPIO87, AF1, DRIVE_LOW)
0238 #define GPIO89_SSP2_TXD     MFP_CFG_OUT(GPIO89, AF3, DRIVE_LOW)
0239 #define GPIO11_SSP2_RXD     MFP_CFG_IN(GPIO11, AF2)
0240 #define GPIO29_SSP2_RXD     MFP_CFG_OUT(GPIO29, AF1, DRIVE_LOW)
0241 #define GPIO40_SSP2_RXD     MFP_CFG_IN(GPIO40, AF1)
0242 #define GPIO86_SSP2_RXD     MFP_CFG_IN(GPIO86, AF1)
0243 #define GPIO88_SSP2_RXD     MFP_CFG_IN(GPIO88, AF2)
0244 #define GPIO22_SSP2_EXTCLK  MFP_CFG_IN(GPIO22, AF1)
0245 #define GPIO27_SSP2_EXTCLK  MFP_CFG_IN(GPIO27, AF1)
0246 #define GPIO22_SSP2_SCLKEN  MFP_CFG_IN(GPIO22, AF2)
0247 #define GPIO23_SSP2_SCLKEN  MFP_CFG_IN(GPIO23, AF2)
0248 
0249 /* SSP 3 */
0250 #define GPIO34_SSP3_SCLK    MFP_CFG_IN(GPIO34, AF3)
0251 #define GPIO40_SSP3_SCLK    MFP_CFG_OUT(GPIO40, AF3, DRIVE_LOW)
0252 #define GPIO52_SSP3_SCLK    MFP_CFG_IN(GPIO52, AF2)
0253 #define GPIO84_SSP3_SCLK    MFP_CFG_IN(GPIO84, AF1)
0254 #define GPIO45_SSP3_SYSCLK  MFP_CFG_OUT(GPIO45, AF3, DRIVE_LOW)
0255 #define GPIO35_SSP3_SFRM    MFP_CFG_IN(GPIO35, AF3)
0256 #define GPIO39_SSP3_SFRM    MFP_CFG_IN(GPIO39, AF3)
0257 #define GPIO83_SSP3_SFRM    MFP_CFG_IN(GPIO83, AF1)
0258 #define GPIO35_SSP3_TXD     MFP_CFG_OUT(GPIO35, AF3, DRIVE_LOW)
0259 #define GPIO38_SSP3_TXD     MFP_CFG_OUT(GPIO38, AF1, DRIVE_LOW)
0260 #define GPIO81_SSP3_TXD     MFP_CFG_OUT(GPIO81, AF1, DRIVE_LOW)
0261 #define GPIO41_SSP3_RXD     MFP_CFG_IN(GPIO41, AF3)
0262 #define GPIO82_SSP3_RXD     MFP_CFG_IN(GPIO82, AF1)
0263 #define GPIO89_SSP3_RXD     MFP_CFG_IN(GPIO89, AF1)
0264 
0265 /* MMC */
0266 #define GPIO32_MMC_CLK      MFP_CFG_OUT(GPIO32, AF2, DRIVE_LOW)
0267 #define GPIO92_MMC_DAT_0    MFP_CFG_IN(GPIO92, AF1)
0268 #define GPIO109_MMC_DAT_1   MFP_CFG_IN(GPIO109, AF1)
0269 #define GPIO110_MMC_DAT_2   MFP_CFG_IN(GPIO110, AF1)
0270 #define GPIO111_MMC_DAT_3   MFP_CFG_IN(GPIO111, AF1)
0271 #define GPIO112_MMC_CMD     MFP_CFG_IN(GPIO112, AF1)
0272 
0273 /* LCD */
0274 #define GPIO58_LCD_LDD_0    MFP_CFG_OUT(GPIO58, AF2, DRIVE_LOW)
0275 #define GPIO59_LCD_LDD_1    MFP_CFG_OUT(GPIO59, AF2, DRIVE_LOW)
0276 #define GPIO60_LCD_LDD_2    MFP_CFG_OUT(GPIO60, AF2, DRIVE_LOW)
0277 #define GPIO61_LCD_LDD_3    MFP_CFG_OUT(GPIO61, AF2, DRIVE_LOW)
0278 #define GPIO62_LCD_LDD_4    MFP_CFG_OUT(GPIO62, AF2, DRIVE_LOW)
0279 #define GPIO63_LCD_LDD_5    MFP_CFG_OUT(GPIO63, AF2, DRIVE_LOW)
0280 #define GPIO64_LCD_LDD_6    MFP_CFG_OUT(GPIO64, AF2, DRIVE_LOW)
0281 #define GPIO65_LCD_LDD_7    MFP_CFG_OUT(GPIO65, AF2, DRIVE_LOW)
0282 #define GPIO66_LCD_LDD_8    MFP_CFG_OUT(GPIO66, AF2, DRIVE_LOW)
0283 #define GPIO67_LCD_LDD_9    MFP_CFG_OUT(GPIO67, AF2, DRIVE_LOW)
0284 #define GPIO68_LCD_LDD_10   MFP_CFG_OUT(GPIO68, AF2, DRIVE_LOW)
0285 #define GPIO69_LCD_LDD_11   MFP_CFG_OUT(GPIO69, AF2, DRIVE_LOW)
0286 #define GPIO70_LCD_LDD_12   MFP_CFG_OUT(GPIO70, AF2, DRIVE_LOW)
0287 #define GPIO71_LCD_LDD_13   MFP_CFG_OUT(GPIO71, AF2, DRIVE_LOW)
0288 #define GPIO72_LCD_LDD_14   MFP_CFG_OUT(GPIO72, AF2, DRIVE_LOW)
0289 #define GPIO73_LCD_LDD_15   MFP_CFG_OUT(GPIO73, AF2, DRIVE_LOW)
0290 #define GPIO86_LCD_LDD_16   MFP_CFG_OUT(GPIO86, AF2, DRIVE_LOW)
0291 #define GPIO87_LCD_LDD_17   MFP_CFG_OUT(GPIO87, AF2, DRIVE_LOW)
0292 #define GPIO74_LCD_FCLK     MFP_CFG_OUT(GPIO74, AF2, DRIVE_LOW)
0293 #define GPIO75_LCD_LCLK     MFP_CFG_OUT(GPIO75, AF2, DRIVE_LOW)
0294 #define GPIO76_LCD_PCLK     MFP_CFG_OUT(GPIO76, AF2, DRIVE_LOW)
0295 #define GPIO77_LCD_BIAS     MFP_CFG_OUT(GPIO77, AF2, DRIVE_LOW)
0296 #define GPIO14_LCD_VSYNC    MFP_CFG_IN(GPIO14, AF1)
0297 #define GPIO19_LCD_CS       MFP_CFG_OUT(GPIO19, AF2, DRIVE_LOW)
0298 
0299 /* Keypad */
0300 #define GPIO93_KP_DKIN_0    MFP_CFG_IN(GPIO93, AF1)
0301 #define GPIO94_KP_DKIN_1    MFP_CFG_IN(GPIO94, AF1)
0302 #define GPIO95_KP_DKIN_2    MFP_CFG_IN(GPIO95, AF1)
0303 #define GPIO96_KP_DKIN_3    MFP_CFG_IN(GPIO96, AF1)
0304 #define GPIO97_KP_DKIN_4    MFP_CFG_IN(GPIO97, AF1)
0305 #define GPIO98_KP_DKIN_5    MFP_CFG_IN(GPIO98, AF1)
0306 #define GPIO99_KP_DKIN_6    MFP_CFG_IN(GPIO99, AF1)
0307 #define GPIO13_KP_KDIN_7    MFP_CFG_IN(GPIO13, AF2)
0308 #define GPIO100_KP_MKIN_0   MFP_CFG_IN(GPIO100, AF1)
0309 #define GPIO101_KP_MKIN_1   MFP_CFG_IN(GPIO101, AF1)
0310 #define GPIO102_KP_MKIN_2   MFP_CFG_IN(GPIO102, AF1)
0311 #define GPIO34_KP_MKIN_3    MFP_CFG_IN(GPIO34, AF2)
0312 #define GPIO37_KP_MKIN_3    MFP_CFG_IN(GPIO37, AF3)
0313 #define GPIO97_KP_MKIN_3    MFP_CFG_IN(GPIO97, AF3)
0314 #define GPIO98_KP_MKIN_4    MFP_CFG_IN(GPIO98, AF3)
0315 #define GPIO38_KP_MKIN_4    MFP_CFG_IN(GPIO38, AF2)
0316 #define GPIO39_KP_MKIN_4    MFP_CFG_IN(GPIO39, AF1)
0317 #define GPIO16_KP_MKIN_5    MFP_CFG_IN(GPIO16, AF1)
0318 #define GPIO90_KP_MKIN_5    MFP_CFG_IN(GPIO90, AF1)
0319 #define GPIO99_KP_MKIN_5    MFP_CFG_IN(GPIO99, AF3)
0320 #define GPIO17_KP_MKIN_6    MFP_CFG_IN(GPIO17, AF1)
0321 #define GPIO91_KP_MKIN_6    MFP_CFG_IN(GPIO91, AF1)
0322 #define GPIO95_KP_MKIN_6    MFP_CFG_IN(GPIO95, AF3)
0323 #define GPIO13_KP_MKIN_7    MFP_CFG_IN(GPIO13, AF3)
0324 #define GPIO36_KP_MKIN_7    MFP_CFG_IN(GPIO36, AF3)
0325 #define GPIO103_KP_MKOUT_0  MFP_CFG_OUT(GPIO103, AF2, DRIVE_HIGH)
0326 #define GPIO104_KP_MKOUT_1  MFP_CFG_OUT(GPIO104, AF2, DRIVE_HIGH)
0327 #define GPIO105_KP_MKOUT_2  MFP_CFG_OUT(GPIO105, AF2, DRIVE_HIGH)
0328 #define GPIO106_KP_MKOUT_3  MFP_CFG_OUT(GPIO106, AF2, DRIVE_HIGH)
0329 #define GPIO107_KP_MKOUT_4  MFP_CFG_OUT(GPIO107, AF2, DRIVE_HIGH)
0330 #define GPIO108_KP_MKOUT_5  MFP_CFG_OUT(GPIO108, AF2, DRIVE_HIGH)
0331 #define GPIO35_KP_MKOUT_6   MFP_CFG_OUT(GPIO35, AF2, DRIVE_HIGH)
0332 #define GPIO22_KP_MKOUT_7   MFP_CFG_OUT(GPIO22, AF1, DRIVE_HIGH)
0333 #define GPIO40_KP_MKOUT_6   MFP_CFG_OUT(GPIO40, AF1, DRIVE_HIGH)
0334 #define GPIO41_KP_MKOUT_7   MFP_CFG_OUT(GPIO41, AF1, DRIVE_HIGH)
0335 #define GPIO96_KP_MKOUT_6   MFP_CFG_OUT(GPIO96, AF3, DRIVE_HIGH)
0336 
0337 /* USB P3 */
0338 #define GPIO10_USB_P3_5     MFP_CFG_IN(GPIO10, AF3)
0339 #define GPIO11_USB_P3_1     MFP_CFG_IN(GPIO11, AF3)
0340 #define GPIO30_USB_P3_2     MFP_CFG_OUT(GPIO30, AF3, DRIVE_LOW)
0341 #define GPIO31_USB_P3_6     MFP_CFG_OUT(GPIO31, AF3, DRIVE_LOW)
0342 #define GPIO56_USB_P3_4     MFP_CFG_OUT(GPIO56, AF1, DRIVE_LOW)
0343 #define GPIO86_USB_P3_5     MFP_CFG_IN(GPIO86, AF3)
0344 #define GPIO87_USB_P3_1     MFP_CFG_IN(GPIO87, AF3)
0345 #define GPIO90_USB_P3_5     MFP_CFG_IN(GPIO90, AF2)
0346 #define GPIO91_USB_P3_1     MFP_CFG_IN(GPIO91, AF2)
0347 #define GPIO113_USB_P3_3    MFP_CFG_IN(GPIO113, AF3)
0348 
0349 /* USB P2 */
0350 #define GPIO34_USB_P2_2     MFP_CFG_OUT(GPIO34, AF1, DRIVE_LOW)
0351 #define GPIO35_USB_P2_1     MFP_CFG_IN(GPIO35, AF2)
0352 #define GPIO36_USB_P2_4     MFP_CFG_OUT(GPIO36, AF1, DRIVE_LOW)
0353 #define GPIO37_USB_P2_8     MFP_CFG_OUT(GPIO37, AF1, DRIVE_LOW)
0354 #define GPIO38_USB_P2_3     MFP_CFG_IN(GPIO38, AF3)
0355 #define GPIO39_USB_P2_6     MFP_CFG_OUT(GPIO39, AF1, DRIVE_LOW)
0356 #define GPIO40_USB_P2_5     MFP_CFG_IN(GPIO40, AF3)
0357 #define GPIO41_USB_P2_7     MFP_CFG_IN(GPIO41, AF2)
0358 #define GPIO53_USB_P2_3     MFP_CFG_IN(GPIO53, AF2)
0359 
0360 /* USB Host Port 1/2 */
0361 #define GPIO88_USBH1_PWR    MFP_CFG_IN(GPIO88, AF1)
0362 #define GPIO89_USBH1_PEN    MFP_CFG_OUT(GPIO89, AF2, DRIVE_LOW)
0363 #define GPIO119_USBH2_PWR   MFP_CFG_IN(GPIO119, AF1)
0364 #define GPIO120_USBH2_PEN   MFP_CFG_OUT(GPIO120, AF2, DRIVE_LOW)
0365 
0366 /* QCI - default to Master Mode: CIF_FV/CIF_LV Direction In */
0367 #define GPIO115_CIF_DD_3    MFP_CFG_IN(GPIO115, AF2)
0368 #define GPIO116_CIF_DD_2    MFP_CFG_IN(GPIO116, AF1)
0369 #define GPIO12_CIF_DD_7     MFP_CFG_IN(GPIO12, AF2)
0370 #define GPIO17_CIF_DD_6     MFP_CFG_IN(GPIO17, AF2)
0371 #define GPIO23_CIF_MCLK     MFP_CFG_OUT(GPIO23, AF1, DRIVE_LOW)
0372 #define GPIO24_CIF_FV       MFP_CFG_IN(GPIO24, AF1)
0373 #define GPIO25_CIF_LV       MFP_CFG_IN(GPIO25, AF1)
0374 #define GPIO26_CIF_PCLK     MFP_CFG_IN(GPIO26, AF2)
0375 #define GPIO27_CIF_DD_0     MFP_CFG_IN(GPIO27, AF3)
0376 #define GPIO42_CIF_MCLK     MFP_CFG_OUT(GPIO42, AF3, DRIVE_LOW)
0377 #define GPIO43_CIF_FV       MFP_CFG_IN(GPIO43, AF3)
0378 #define GPIO44_CIF_LV       MFP_CFG_IN(GPIO44, AF3)
0379 #define GPIO45_CIF_PCLK     MFP_CFG_IN(GPIO45, AF3)
0380 #define GPIO47_CIF_DD_0     MFP_CFG_IN(GPIO47, AF1)
0381 #define GPIO48_CIF_DD_5     MFP_CFG_IN(GPIO48, AF1)
0382 #define GPIO50_CIF_DD_3     MFP_CFG_IN(GPIO50, AF1)
0383 #define GPIO51_CIF_DD_2     MFP_CFG_IN(GPIO51, AF1)
0384 #define GPIO52_CIF_DD_4     MFP_CFG_IN(GPIO52, AF1)
0385 #define GPIO53_CIF_MCLK     MFP_CFG_OUT(GPIO53, AF2, DRIVE_LOW)
0386 #define GPIO54_CIF_PCLK     MFP_CFG_IN(GPIO54, AF3)
0387 #define GPIO55_CIF_DD_1     MFP_CFG_IN(GPIO55, AF1)
0388 #define GPIO81_CIF_DD_0     MFP_CFG_IN(GPIO81, AF2)
0389 #define GPIO82_CIF_DD_5     MFP_CFG_IN(GPIO82, AF3)
0390 #define GPIO83_CIF_DD_4     MFP_CFG_IN(GPIO83, AF3)
0391 #define GPIO84_CIF_FV       MFP_CFG_IN(GPIO84, AF3)
0392 #define GPIO85_CIF_LV       MFP_CFG_IN(GPIO85, AF3)
0393 #define GPIO90_CIF_DD_4     MFP_CFG_IN(GPIO90, AF3)
0394 #define GPIO91_CIF_DD_5     MFP_CFG_IN(GPIO91, AF3)
0395 #define GPIO93_CIF_DD_6     MFP_CFG_IN(GPIO93, AF2)
0396 #define GPIO94_CIF_DD_5     MFP_CFG_IN(GPIO94, AF2)
0397 #define GPIO95_CIF_DD_4     MFP_CFG_IN(GPIO95, AF2)
0398 #define GPIO98_CIF_DD_0     MFP_CFG_IN(GPIO98, AF2)
0399 #define GPIO103_CIF_DD_3    MFP_CFG_IN(GPIO103, AF1)
0400 #define GPIO104_CIF_DD_2    MFP_CFG_IN(GPIO104, AF1)
0401 #define GPIO105_CIF_DD_1    MFP_CFG_IN(GPIO105, AF1)
0402 #define GPIO106_CIF_DD_9    MFP_CFG_IN(GPIO106, AF1)
0403 #define GPIO107_CIF_DD_8    MFP_CFG_IN(GPIO107, AF1)
0404 #define GPIO108_CIF_DD_7    MFP_CFG_IN(GPIO108, AF1)
0405 #define GPIO114_CIF_DD_1    MFP_CFG_IN(GPIO114, AF1)
0406 
0407 /* Universal Subscriber ID Interface */
0408 #define GPIO114_UVS0        MFP_CFG_OUT(GPIO114, AF2, DRIVE_LOW)
0409 #define GPIO115_nUVS1       MFP_CFG_OUT(GPIO115, AF2, DRIVE_LOW)
0410 #define GPIO116_nUVS2       MFP_CFG_OUT(GPIO116, AF2, DRIVE_LOW)
0411 #define GPIO14_UCLK     MFP_CFG_OUT(GPIO14, AF3, DRIVE_LOW)
0412 #define GPIO91_UCLK     MFP_CFG_OUT(GPIO91, AF2, DRIVE_LOW)
0413 #define GPIO19_nURST        MFP_CFG_OUT(GPIO19, AF3, DRIVE_LOW)
0414 #define GPIO90_nURST        MFP_CFG_OUT(GPIO90, AF2, DRIVE_LOW)
0415 #define GPIO116_UDET        MFP_CFG_IN(GPIO116, AF3)
0416 #define GPIO114_UEN     MFP_CFG_OUT(GPIO114, AF1, DRIVE_LOW)
0417 #define GPIO115_UEN     MFP_CFG_OUT(GPIO115, AF1, DRIVE_LOW)
0418 
0419 /* Mobile Scalable Link (MSL) Interface */
0420 #define GPIO81_BB_OB_DAT_0  MFP_CFG_OUT(GPIO81, AF2, DRIVE_LOW)
0421 #define GPIO48_BB_OB_DAT_1  MFP_CFG_OUT(GPIO48, AF1, DRIVE_LOW)
0422 #define GPIO50_BB_OB_DAT_2  MFP_CFG_OUT(GPIO50, AF1, DRIVE_LOW)
0423 #define GPIO51_BB_OB_DAT_3  MFP_CFG_OUT(GPIO51, AF1, DRIVE_LOW)
0424 #define GPIO52_BB_OB_CLK    MFP_CFG_OUT(GPIO52, AF1, DRIVE_LOW)
0425 #define GPIO53_BB_OB_STB    MFP_CFG_OUT(GPIO53, AF1, DRIVE_LOW)
0426 #define GPIO54_BB_OB_WAIT   MFP_CFG_IN(GPIO54, AF2)
0427 #define GPIO82_BB_IB_DAT_0  MFP_CFG_IN(GPIO82, AF2)
0428 #define GPIO55_BB_IB_DAT_1  MFP_CFG_IN(GPIO55, AF2)
0429 #define GPIO56_BB_IB_DAT_2  MFP_CFG_IN(GPIO56, AF2)
0430 #define GPIO57_BB_IB_DAT_3  MFP_CFG_IN(GPIO57, AF2)
0431 #define GPIO83_BB_IB_CLK    MFP_CFG_IN(GPIO83, AF2)
0432 #define GPIO84_BB_IB_STB    MFP_CFG_IN(GPIO84, AF2)
0433 #define GPIO85_BB_IB_WAIT   MFP_CFG_OUT(GPIO85, AF2, DRIVE_LOW)
0434 
0435 /* Memory Stick Host Controller */
0436 #define GPIO92_MSBS     MFP_CFG_OUT(GPIO92, AF2, DRIVE_LOW)
0437 #define GPIO109_MSSDIO      MFP_CFG_IN(GPIO109, AF2)
0438 #define GPIO112_nMSINS      MFP_CFG_IN(GPIO112, AF2)
0439 #define GPIO32_MSSCLK       MFP_CFG_OUT(GPIO32, AF1, DRIVE_LOW)
0440 
0441 /* commonly used pin configurations */
0442 #define GPIOxx_LCD_16BPP    \
0443     GPIO58_LCD_LDD_0,   \
0444     GPIO59_LCD_LDD_1,   \
0445     GPIO60_LCD_LDD_2,   \
0446     GPIO61_LCD_LDD_3,   \
0447     GPIO62_LCD_LDD_4,   \
0448     GPIO63_LCD_LDD_5,   \
0449     GPIO64_LCD_LDD_6,   \
0450     GPIO65_LCD_LDD_7,   \
0451     GPIO66_LCD_LDD_8,   \
0452     GPIO67_LCD_LDD_9,   \
0453     GPIO68_LCD_LDD_10,  \
0454     GPIO69_LCD_LDD_11,  \
0455     GPIO70_LCD_LDD_12,  \
0456     GPIO71_LCD_LDD_13,  \
0457     GPIO72_LCD_LDD_14,  \
0458     GPIO73_LCD_LDD_15
0459 
0460 #define GPIOxx_LCD_TFT_16BPP    \
0461     GPIOxx_LCD_16BPP,   \
0462     GPIO74_LCD_FCLK,    \
0463     GPIO75_LCD_LCLK,    \
0464     GPIO76_LCD_PCLK,    \
0465     GPIO77_LCD_BIAS
0466 
0467 /* these enable a work-around for a hw bug in pxa27x during ac97 warm reset */
0468 #define GPIO113_AC97_nRESET_GPIO_HIGH MFP_CFG_OUT(GPIO113, AF0, DEFAULT)
0469 #define GPIO95_AC97_nRESET_GPIO_HIGH MFP_CFG_OUT(GPIO95, AF0, DEFAULT)
0470 
0471 extern int keypad_set_wake(unsigned int on);
0472 #endif /* __ASM_ARCH_MFP_PXA27X_H */