blob: 036fd20eb46a0f9373c13c3b1338277d06b6e544 [file] [log] [blame]
Dirk Eibachac44ffb2009-07-27 08:49:48 +02001/*
2 * (C) Copyright 2009
3 * Dirk Eibach, Guntermann & Drunck GmbH, eibach@gdsys.de
4 *
5 * Based on include/configs/canyonlands.h
6 * (C) Copyright 2008
7 * Stefan Roese, DENX Software Engineering, sr@denx.de.
8 *
Wolfgang Denkd79de1d2013-07-08 09:37:19 +02009 * SPDX-License-Identifier: GPL-2.0+
Dirk Eibachac44ffb2009-07-27 08:49:48 +020010 */
11
12/*
Dirk Eibach62dbcba2009-09-09 12:36:07 +020013 * intip.h - configuration for CompactCenter aka intip (460EX) and DevCon-Center
Dirk Eibachac44ffb2009-07-27 08:49:48 +020014 */
15#ifndef __CONFIG_H
16#define __CONFIG_H
17
18/*
19 * High Level Configuration Options
20 */
21/*
Dirk Eibach62dbcba2009-09-09 12:36:07 +020022 * This config file is used for CompactCenter(codename intip) and DevCon-Center
Dirk Eibachac44ffb2009-07-27 08:49:48 +020023 */
24#define CONFIG_460EX 1 /* Specific PPC460EX */
25#ifdef CONFIG_DEVCONCENTER
26#define CONFIG_HOSTNAME devconcenter
Dirk Eibachac44ffb2009-07-27 08:49:48 +020027#else
Dirk Eibach62dbcba2009-09-09 12:36:07 +020028#define CONFIG_HOSTNAME intip
Dirk Eibachac44ffb2009-07-27 08:49:48 +020029#endif
30#define CONFIG_440 1
Dirk Eibachac44ffb2009-07-27 08:49:48 +020031
Wolfgang Denk291ba1b2010-10-06 09:05:45 +020032#ifndef CONFIG_SYS_TEXT_BASE
33#define CONFIG_SYS_TEXT_BASE 0xFFFA0000
34#endif
35
Dirk Eibachac44ffb2009-07-27 08:49:48 +020036/*
37 * Include common defines/options for all AMCC eval boards
38 */
39#include "amcc-common.h"
40
41#define CONFIG_SYS_CLK_FREQ 66666667 /* external freq to pll */
42
Dirk Eibachac44ffb2009-07-27 08:49:48 +020043#define CONFIG_BOARD_EARLY_INIT_R 1 /* Call board_early_init_r */
44#define CONFIG_MISC_INIT_R 1 /* Call misc_init_r */
45#define CONFIG_BOARD_TYPES 1 /* support board types */
Dirk Eibachac44ffb2009-07-27 08:49:48 +020046#define CFG_ALT_MEMTEST
47
48/*
49 * Base addresses -- Note these are effective addresses where the
50 * actual resources get mapped (not physical addresses)
51 */
52#define CONFIG_SYS_PCI_MEMBASE 0x80000000 /* mapped PCI memory */
53#define CONFIG_SYS_PCI_BASE 0xd0000000 /* internal PCI regs */
54#define CONFIG_SYS_PCI_TARGBASE CONFIG_SYS_PCI_MEMBASE
55
56/* EBC stuff */
57#ifdef CONFIG_DEVCONCENTER /* Devcon-Center has 128 MB of flash */
58#define CONFIG_SYS_FLASH_BASE 0xF8000000 /* later mapped here */
59#define CONFIG_SYS_FLASH_SIZE (128 << 20)
60#else
61#define CONFIG_SYS_FLASH_BASE 0xFC000000 /* later mapped here */
62#define CONFIG_SYS_FLASH_SIZE (64 << 20)
63#endif
64
65#define CONFIG_SYS_NVRAM_BASE 0xE0000000
66#define CONFIG_SYS_UART_BASE 0xE0100000
67#define CONFIG_SYS_IO_BASE 0xE0200000
68
69#define CONFIG_SYS_BOOT_BASE_ADDR 0xFF000000 /* EBC Boot Space */
70#define CONFIG_SYS_FLASH_BASE_PHYS_H 0x4
71#ifdef CONFIG_DEVCONCENTER /* Devcon-Center has 128 MB of flash */
72#define CONFIG_SYS_FLASH_BASE_PHYS_L 0xC8000000
73#else
74#define CONFIG_SYS_FLASH_BASE_PHYS_L 0xCC000000
75#endif
76#define CONFIG_SYS_FLASH_BASE_PHYS \
77 (((u64)CONFIG_SYS_FLASH_BASE_PHYS_H << 32) \
78 | (u64)CONFIG_SYS_FLASH_BASE_PHYS_L)
79
80#define CONFIG_SYS_OCM_BASE 0xE3000000 /* OCM: 64k */
81#define CONFIG_SYS_SRAM_BASE 0xE8000000 /* SRAM: 256k */
Wolfgang Denk2fc54d92010-09-10 23:04:05 +020082#define CONFIG_SYS_SRAM_SIZE (256 << 10)
Dirk Eibachac44ffb2009-07-27 08:49:48 +020083#define CONFIG_SYS_LOCAL_CONF_REGS 0xEF000000
84
Dirk Eibachac44ffb2009-07-27 08:49:48 +020085#define CONFIG_SYS_AHB_BASE 0xE2000000 /* int. AHB periph. */
86
87/*
88 * Initial RAM & stack pointer (placed in OCM)
89 */
90#define CONFIG_SYS_INIT_RAM_ADDR CONFIG_SYS_OCM_BASE /* OCM */
Wolfgang Denk1c2e98e2010-10-26 13:32:32 +020091#define CONFIG_SYS_INIT_RAM_SIZE (4 << 10)
Dirk Eibachac44ffb2009-07-27 08:49:48 +020092#define CONFIG_SYS_GBL_DATA_OFFSET \
Wolfgang Denk0191e472010-10-26 14:34:52 +020093 (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
Dirk Eibachac44ffb2009-07-27 08:49:48 +020094#define CONFIG_SYS_INIT_SP_OFFSET CONFIG_SYS_GBL_DATA_OFFSET
95
96/*
97 * Serial Port
98 */
Stefan Roese3ddce572010-09-20 16:05:31 +020099#define CONFIG_CONS_INDEX 1 /* Use UART0 */
Dirk Eibachac44ffb2009-07-27 08:49:48 +0200100
101/*
102 * Environment
103 */
104/*
105 * Define here the location of the environment variables (FLASH).
106 */
107#define CONFIG_ENV_IS_IN_FLASH 1 /* use FLASH for environment vars */
108#define CONFIG_SYS_NOR_CS 0 /* NOR chip connected to CSx */
109
110/*
111 * FLASH related
112 */
113#define CONFIG_SYS_FLASH_CFI /* The flash is CFI compatible */
114#define CONFIG_FLASH_CFI_DRIVER /* Use common CFI driver */
115#define CONFIG_SYS_FLASH_CFI_AMD_RESET 1 /* Use AMD reset cmd */
116
117#define CONFIG_SYS_FLASH_BANKS_LIST {CONFIG_SYS_FLASH_BASE}
118#define CONFIG_SYS_MAX_FLASH_BANKS 1 /* max num of memory banks */
119#ifdef CONFIG_DEVCONCENTER
120#define CONFIG_SYS_MAX_FLASH_SECT 1024 /* max num of sectors per chip*/
121#else
122#define CONFIG_SYS_MAX_FLASH_SECT 512 /* max num of sectors per chip*/
123#endif
124
125#define CONFIG_SYS_FLASH_ERASE_TOUT 120000 /* Timeout for Flash Erase/ms */
126#define CONFIG_SYS_FLASH_WRITE_TOUT 500 /* Timeout for Flash Write/ms */
127
128#define CONFIG_SYS_FLASH_USE_BUFFER_WRITE 1 /* buff'd writes (20x faster) */
129#define CONFIG_SYS_FLASH_EMPTY_INFO /* 'E' for empty sector on flinfo */
130
131#ifdef CONFIG_ENV_IS_IN_FLASH
132#define CONFIG_ENV_SECT_SIZE 0x20000 /* size of one complete sector*/
133#define CONFIG_ENV_ADDR (CONFIG_SYS_MONITOR_BASE - CONFIG_ENV_SECT_SIZE)
134#define CONFIG_ENV_SIZE 0x4000 /* Total Size of Environment Sector */
135
136/* Address and size of Redundant Environment Sector */
137#define CONFIG_ENV_ADDR_REDUND (CONFIG_ENV_ADDR - CONFIG_ENV_SECT_SIZE)
138#define CONFIG_ENV_SIZE_REDUND (CONFIG_ENV_SIZE)
139#endif /* CONFIG_ENV_IS_IN_FLASH */
140
141/*
142 * DDR SDRAM
143 */
144
145#define CONFIG_AUTOCALIB "silent\0" /* default is non-verbose */
146
147#define CONFIG_PPC4xx_DDR_AUTOCALIBRATION /* IBM DDR autocalibration */
148#define DEBUG_PPC4xx_DDR_AUTOCALIBRATION /* dynamic DDR autocal debug */
149#undef CONFIG_PPC4xx_DDR_METHOD_A
150
151/* DDR1/2 SDRAM Device Control Register Data Values */
152/* Memory Queue */
153#define CONFIG_SYS_SDRAM_R0BAS 0x0000f800
154#define CONFIG_SYS_SDRAM_R1BAS 0x00000000
155#define CONFIG_SYS_SDRAM_R2BAS 0x00000000
156#define CONFIG_SYS_SDRAM_R3BAS 0x00000000
157#define CONFIG_SYS_SDRAM_PLBADDULL 0x00000000
158#define CONFIG_SYS_SDRAM_PLBADDUHB 0x00000008
Dirk Eibach9d4396c2009-09-21 13:27:14 +0200159#define CONFIG_SYS_SDRAM_CONF1LL 0x80001C00
Dirk Eibachac44ffb2009-07-27 08:49:48 +0200160#define CONFIG_SYS_SDRAM_CONF1HB 0x80001C80
161#define CONFIG_SYS_SDRAM_CONFPATHB 0x10a68000
162
163/* SDRAM Controller */
164#define CONFIG_SYS_SDRAM0_MB0CF 0x00000201
165#define CONFIG_SYS_SDRAM0_MB1CF 0x00000000
166#define CONFIG_SYS_SDRAM0_MB2CF 0x00000000
167#define CONFIG_SYS_SDRAM0_MB3CF 0x00000000
Dirk Eibach9d4396c2009-09-21 13:27:14 +0200168#define CONFIG_SYS_SDRAM0_MCOPT1 0x05120000
Dirk Eibachac44ffb2009-07-27 08:49:48 +0200169#define CONFIG_SYS_SDRAM0_MCOPT2 0x00000000
170#define CONFIG_SYS_SDRAM0_MODT0 0x00000000
171#define CONFIG_SYS_SDRAM0_MODT1 0x00000000
172#define CONFIG_SYS_SDRAM0_MODT2 0x00000000
173#define CONFIG_SYS_SDRAM0_MODT3 0x00000000
174#define CONFIG_SYS_SDRAM0_CODT 0x00000020
175#define CONFIG_SYS_SDRAM0_RTR 0x06180000
176#define CONFIG_SYS_SDRAM0_INITPLR0 0xA8380000
177#define CONFIG_SYS_SDRAM0_INITPLR1 0x81900400
178#define CONFIG_SYS_SDRAM0_INITPLR2 0x81020000
179#define CONFIG_SYS_SDRAM0_INITPLR3 0x81030000
Dirk Eibach9d4396c2009-09-21 13:27:14 +0200180#define CONFIG_SYS_SDRAM0_INITPLR4 0x81010002
Dirk Eibach23b80f42011-10-04 11:13:55 +0200181#define CONFIG_SYS_SDRAM0_INITPLR5 0xE4000552
Dirk Eibachac44ffb2009-07-27 08:49:48 +0200182#define CONFIG_SYS_SDRAM0_INITPLR6 0x81900400
183#define CONFIG_SYS_SDRAM0_INITPLR7 0x8A880000
184#define CONFIG_SYS_SDRAM0_INITPLR8 0x8A880000
185#define CONFIG_SYS_SDRAM0_INITPLR9 0x8A880000
186#define CONFIG_SYS_SDRAM0_INITPLR10 0x8A880000
Dirk Eibach23b80f42011-10-04 11:13:55 +0200187#define CONFIG_SYS_SDRAM0_INITPLR11 0x81000452
Dirk Eibach9d4396c2009-09-21 13:27:14 +0200188#define CONFIG_SYS_SDRAM0_INITPLR12 0x81010382
189#define CONFIG_SYS_SDRAM0_INITPLR13 0x81010002
Dirk Eibachac44ffb2009-07-27 08:49:48 +0200190#define CONFIG_SYS_SDRAM0_INITPLR14 0x00000000
191#define CONFIG_SYS_SDRAM0_INITPLR15 0x00000000
192#define CONFIG_SYS_SDRAM0_RQDC 0x80000038
Dirk Eibach9d4396c2009-09-21 13:27:14 +0200193#define CONFIG_SYS_SDRAM0_RFDC 0x00000257
194#define CONFIG_SYS_SDRAM0_RDCC 0x40000000
Dirk Eibachac44ffb2009-07-27 08:49:48 +0200195#define CONFIG_SYS_SDRAM0_DLCR 0x00000000
196#define CONFIG_SYS_SDRAM0_CLKTR 0x40000000
Dirk Eibach23b80f42011-10-04 11:13:55 +0200197#define CONFIG_SYS_SDRAM0_WRDTR 0x86000823
Dirk Eibachac44ffb2009-07-27 08:49:48 +0200198#define CONFIG_SYS_SDRAM0_SDTR1 0x80201000
199#define CONFIG_SYS_SDRAM0_SDTR2 0x32204232
Dirk Eibach9d4396c2009-09-21 13:27:14 +0200200#define CONFIG_SYS_SDRAM0_SDTR3 0x090C0D15
Dirk Eibach23b80f42011-10-04 11:13:55 +0200201#define CONFIG_SYS_SDRAM0_MMODE 0x00000452
Dirk Eibach9d4396c2009-09-21 13:27:14 +0200202#define CONFIG_SYS_SDRAM0_MEMODE 0x00000002
Dirk Eibachac44ffb2009-07-27 08:49:48 +0200203
204#define CONFIG_SYS_MBYTES_SDRAM 256 /* 256MB */
205
206/*
207 * I2C
208 */
Dirk Eibach42b204f2013-04-25 02:40:01 +0000209#define CONFIG_SYS_I2C_PPC4XX_SPEED_0 400000
Dirk Eibachac44ffb2009-07-27 08:49:48 +0200210
Dirk Eibachac44ffb2009-07-27 08:49:48 +0200211#define CONFIG_SYS_I2C_EEPROM_ADDR (0xa8>>1)
212#define CONFIG_SYS_I2C_EEPROM_ADDR_LEN 1
213#define CONFIG_SYS_EEPROM_PAGE_WRITE_BITS 3
214#define CONFIG_SYS_EEPROM_PAGE_WRITE_DELAY_MS 10
215
216/* I2C bootstrap EEPROM */
217#define CONFIG_4xx_CONFIG_I2C_EEPROM_ADDR 0x54
218#define CONFIG_4xx_CONFIG_I2C_EEPROM_OFFSET 0
219#define CONFIG_4xx_CONFIG_BLOCKSIZE 16
220
Dirk Eibachac44ffb2009-07-27 08:49:48 +0200221/* RTC configuration */
222#define CONFIG_RTC_DS1337 1
223#define CONFIG_SYS_I2C_RTC_ADDR 0x68
224
225/*
226 * Ethernet
227 */
228#define CONFIG_IBM_EMAC4_V4 1
229
230#define CONFIG_HAS_ETH0
231#define CONFIG_HAS_ETH1
232
233#define CONFIG_PHY_ADDR 2 /* PHY address, See schematics */
234#define CONFIG_PHY1_ADDR 3
235
236#define CONFIG_PHY_RESET 1 /* reset phy upon startup */
237#define CONFIG_PHY_GIGE 1 /* Include GbE speed/duplex detection */
238#define CONFIG_PHY_DYNAMIC_ANEG 1
239
240/*
241 * USB-OHCI
242 */
243#define CONFIG_USB_OHCI_NEW
Dirk Eibachac44ffb2009-07-27 08:49:48 +0200244#undef CONFIG_SYS_OHCI_BE_CONTROLLER /* 460EX has little endian descriptors*/
245#define CONFIG_SYS_OHCI_SWAP_REG_ACCESS /* 460EX has little endian register */
246#define CONFIG_SYS_OHCI_USE_NPS /* force NoPowerSwitching mode */
247#define CONFIG_SYS_USB_OHCI_REGS_BASE (CONFIG_SYS_AHB_BASE | 0xd0000)
248#define CONFIG_SYS_USB_OHCI_SLOT_NAME "ppc440"
249#define CONFIG_SYS_USB_OHCI_MAX_ROOT_PORTS 15
250
251/*
252 * Default environment variables
253 */
254#define CONFIG_EXTRA_ENV_SETTINGS \
255 CONFIG_AMCC_DEF_ENV \
256 CONFIG_AMCC_DEF_ENV_POWERPC \
257 CONFIG_AMCC_DEF_ENV_NOR_UPD \
258 "kernel_addr=fc000000\0" \
259 "fdt_addr=fc1e0000\0" \
260 "ramdisk_addr=fc200000\0" \
261 "pciconfighost=1\0" \
262 "pcie_mode=RP:RP\0" \
263 ""
264
265/*
266 * Commands additional to the ones defined in amcc-common.h
267 */
Dirk Eibachac44ffb2009-07-27 08:49:48 +0200268#define CONFIG_CMD_PCI
269#define CONFIG_CMD_SDRAM
Dirk Eibachac44ffb2009-07-27 08:49:48 +0200270
271/* Partitions */
Dirk Eibachac44ffb2009-07-27 08:49:48 +0200272
273/*
274 * PCI stuff
275 */
276/* General PCI */
Gabor Juhosb4458732013-05-30 07:06:12 +0000277#define CONFIG_PCI_INDIRECT_BRIDGE /* indirect PCI bridge support */
Dirk Eibachac44ffb2009-07-27 08:49:48 +0200278#define CONFIG_PCI_SCAN_SHOW /* show pci devices on startup */
279#define CONFIG_PCI_CONFIG_HOST_BRIDGE
280#define CONFIG_PCI_DISABLE_PCIE
281
282/* Board-specific PCI */
283#define CONFIG_SYS_PCI_TARGET_INIT /* let board init pci target */
284#undef CONFIG_SYS_PCI_MASTER_INIT
285
286#define CONFIG_SYS_PCI_SUBSYS_VENDORID 0x1014 /* IBM */
287#define CONFIG_SYS_PCI_SUBSYS_DEVICEID 0xcafe /* Whatever */
288
Dirk Eibachac44ffb2009-07-27 08:49:48 +0200289/*
290 * External Bus Controller (EBC) Setup
291 */
292
293/*
294 * CompactCenter has 64MBytes of NOR FLASH (Spansion 29GL512), but the
295 * boot EBC mapping only supports a maximum of 16MBytes
296 * (4.ff00.0000 - 4.ffff.ffff).
297 * To solve this problem, the FLASH has to get remapped to another
298 * EBC address which accepts bigger regions:
299 *
300 * 0xfc00.0000 -> 4.cc00.0000
301 */
302
Dirk Eibachac44ffb2009-07-27 08:49:48 +0200303/* Memory Bank 0 (NOR-FLASH) initialization */
304#define CONFIG_SYS_EBC_PB0AP 0x10055e00
305#define CONFIG_SYS_EBC_PB0CR (CONFIG_SYS_BOOT_BASE_ADDR | 0x9a000)
306
307/* Memory Bank 1 (NVRAM) initialization */
308#define CONFIG_SYS_EBC_PB1AP 0x02815480
309/* BAS=NVRAM,BS=1MB,BU=R/W,BW=8bit*/
310#define CONFIG_SYS_EBC_PB1CR (CONFIG_SYS_NVRAM_BASE | 0x18000)
311
312/* Memory Bank 2 (UART) initialization */
313#define CONFIG_SYS_EBC_PB2AP 0x02815480
314/* BAS=UART,BS=1MB,BU=R/W,BW=16bit*/
315#define CONFIG_SYS_EBC_PB2CR (CONFIG_SYS_UART_BASE | 0x1A000)
316
317/* Memory Bank 3 (IO) initialization */
318#define CONFIG_SYS_EBC_PB3AP 0x02815480
319/* BAS=IO,BS=1MB,BU=R/W,BW=16bit*/
320#define CONFIG_SYS_EBC_PB3CR (CONFIG_SYS_IO_BASE | 0x1A000)
321
322/*
323 * PPC4xx GPIO Configuration
324 */
325/* 460EX: Use USB configuration */
326#define CONFIG_SYS_4xx_GPIO_TABLE { /* Out GPIO Alternate1 Alternate2 Alternate3 */ \
327{ \
328/* GPIO Core 0 */ \
329{GPIO0_BASE, GPIO_BI , GPIO_ALT1, GPIO_OUT_0}, /* GPIO0 GMC1TxD(0) USB2HostD(0) */ \
330{GPIO0_BASE, GPIO_BI , GPIO_ALT1, GPIO_OUT_0}, /* GPIO1 GMC1TxD(1) USB2HostD(1) */ \
331{GPIO0_BASE, GPIO_BI , GPIO_ALT1, GPIO_OUT_0}, /* GPIO2 GMC1TxD(2) USB2HostD(2) */ \
332{GPIO0_BASE, GPIO_BI , GPIO_ALT1, GPIO_OUT_0}, /* GPIO3 GMC1TxD(3) USB2HostD(3) */ \
333{GPIO0_BASE, GPIO_BI , GPIO_ALT1, GPIO_OUT_0}, /* GPIO4 GMC1TxD(4) USB2HostD(4) */ \
334{GPIO0_BASE, GPIO_BI , GPIO_ALT1, GPIO_OUT_0}, /* GPIO5 GMC1TxD(5) USB2HostD(5) */ \
335{GPIO0_BASE, GPIO_BI , GPIO_ALT1, GPIO_OUT_0}, /* GPIO6 GMC1TxD(6) USB2HostD(6) */ \
336{GPIO0_BASE, GPIO_BI , GPIO_ALT1, GPIO_OUT_0}, /* GPIO7 GMC1TxD(7) USB2HostD(7) */ \
337{GPIO0_BASE, GPIO_BI , GPIO_ALT1, GPIO_OUT_0}, /* GPIO8 GMC1RxD(0) USB2OTGD(0) */ \
338{GPIO0_BASE, GPIO_BI , GPIO_ALT1, GPIO_OUT_0}, /* GPIO9 GMC1RxD(1) USB2OTGD(1) */ \
339{GPIO0_BASE, GPIO_BI , GPIO_ALT1, GPIO_OUT_0}, /* GPIO10 GMC1RxD(2) USB2OTGD(2) */ \
340{GPIO0_BASE, GPIO_BI , GPIO_ALT1, GPIO_OUT_0}, /* GPIO11 GMC1RxD(3) USB2OTGD(3) */ \
341{GPIO0_BASE, GPIO_BI , GPIO_ALT1, GPIO_OUT_0}, /* GPIO12 GMC1RxD(4) USB2OTGD(4) */ \
342{GPIO0_BASE, GPIO_BI , GPIO_ALT1, GPIO_OUT_0}, /* GPIO13 GMC1RxD(5) USB2OTGD(5) */ \
343{GPIO0_BASE, GPIO_BI , GPIO_ALT1, GPIO_OUT_0}, /* GPIO14 GMC1RxD(6) USB2OTGD(6) */ \
344{GPIO0_BASE, GPIO_BI , GPIO_ALT1, GPIO_OUT_0}, /* GPIO15 GMC1RxD(7) USB2OTGD(7) */ \
345{GPIO0_BASE, GPIO_IN , GPIO_SEL, GPIO_OUT_0}, /* GPIO16 GMC1TxER USB2HostStop */ \
346{GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0}, /* GPIO17 GMC1CD USB2HostNext */ \
347{GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0}, /* GPIO18 GMC1RxER USB2HostDir */ \
348{GPIO0_BASE, GPIO_IN, GPIO_SEL, GPIO_OUT_0}, /* GPIO19 GMC1TxEN USB2OTGStop */ \
349{GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0}, /* GPIO20 GMC1CRS USB2OTGNext */ \
350{GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0}, /* GPIO21 GMC1RxDV USB2OTGDir */ \
351{GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0}, /* GPIO22 NFRDY */ \
352{GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0}, /* GPIO23 NFREN */ \
353{GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0}, /* GPIO24 NFWEN */ \
354{GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0}, /* GPIO25 NFCLE */ \
355{GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0}, /* GPIO26 NFALE */ \
356{GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0}, /* GPIO27 IRQ(0) */ \
357{GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0}, /* GPIO28 IRQ(1) */ \
358{GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0}, /* GPIO29 IRQ(2) */ \
359{GPIO0_BASE, GPIO_OUT, GPIO_SEL , GPIO_OUT_1}, /* GPIO30 PerPar0 DMAReq2 IRQ(7)*/ \
360{GPIO0_BASE, GPIO_OUT, GPIO_SEL , GPIO_OUT_1}, /* GPIO31 PerPar1 DMAAck2 IRQ(8)*/ \
361}, \
362{ \
363/* GPIO Core 1 */ \
364{GPIO1_BASE, GPIO_OUT, GPIO_SEL , GPIO_OUT_1}, /* GPIO32 PerPar2 EOT2/TC2 IRQ(9)*/ \
365{GPIO1_BASE, GPIO_OUT, GPIO_SEL , GPIO_OUT_1}, /* GPIO33 PerPar3 DMAReq3 IRQ(4)*/ \
366{GPIO1_BASE, GPIO_OUT, GPIO_ALT3, GPIO_OUT_1}, /* GPIO34 UART0_DCD_N UART1_DSR_CTS_N UART2_SOUT*/ \
367{GPIO1_BASE, GPIO_IN , GPIO_ALT3, GPIO_OUT_0}, /* GPIO35 UART0_8PIN_DSR_N UART1_RTS_DTR_N UART2_SIN*/ \
368{GPIO1_BASE, GPIO_IN , GPIO_ALT3, GPIO_OUT_0}, /* GPIO36 UART0_8PIN_CTS_N DMAAck3 UART3_SIN*/ \
369{GPIO1_BASE, GPIO_BI , GPIO_ALT2, GPIO_OUT_0}, /* GPIO37 UART0_RTS_N EOT3/TC3 UART3_SOUT*/ \
370{GPIO1_BASE, GPIO_OUT, GPIO_ALT2, GPIO_OUT_1}, /* GPIO38 UART0_DTR_N UART1_SOUT */ \
371{GPIO1_BASE, GPIO_IN , GPIO_ALT2, GPIO_OUT_0}, /* GPIO39 UART0_RI_N UART1_SIN */ \
372{GPIO1_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0}, /* GPIO40 IRQ(3) */ \
373{GPIO1_BASE, GPIO_OUT, GPIO_ALT1, GPIO_OUT_0}, /* GPIO41 CS(1) */ \
374{GPIO1_BASE, GPIO_OUT, GPIO_ALT1, GPIO_OUT_0}, /* GPIO42 CS(2) */ \
375{GPIO1_BASE, GPIO_OUT, GPIO_ALT1, GPIO_OUT_0}, /* GPIO43 CS(3) DMAReq1 IRQ(10)*/ \
376{GPIO1_BASE, GPIO_IN , GPIO_ALT3, GPIO_OUT_0}, /* GPIO44 CS(4) DMAAck1 IRQ(11)*/ \
377{GPIO1_BASE, GPIO_IN , GPIO_ALT3, GPIO_OUT_0}, /* GPIO45 CS(5) EOT/TC1 IRQ(12)*/ \
378{GPIO1_BASE, GPIO_OUT, GPIO_ALT1, GPIO_OUT_0}, /* GPIO46 PerAddr(5) DMAReq0 IRQ(13)*/ \
379{GPIO1_BASE, GPIO_OUT, GPIO_ALT1, GPIO_OUT_0}, /* GPIO47 PerAddr(6) DMAAck0 IRQ(14)*/ \
380{GPIO1_BASE, GPIO_OUT, GPIO_ALT1, GPIO_OUT_0}, /* GPIO48 PerAddr(7) EOT/TC0 IRQ(15)*/ \
381{GPIO1_BASE, GPIO_IN , GPIO_SEL , GPIO_OUT_0}, /* GPIO49 Unselect via TraceSelect Bit */ \
382{GPIO1_BASE, GPIO_IN , GPIO_SEL , GPIO_OUT_0}, /* GPIO50 USB_SERVICE_SUSPEND_N */ \
383{GPIO1_BASE, GPIO_OUT, GPIO_SEL , GPIO_OUT_1}, /* GPIO51 SPI_CSS_N */ \
384{GPIO1_BASE, GPIO_OUT, GPIO_SEL , GPIO_OUT_1}, /* GPIO52 FPGA_PROGRAM_UC_N */ \
385{GPIO1_BASE, GPIO_IN , GPIO_SEL , GPIO_OUT_0}, /* GPIO53 FPGA_INIT_UC_N */ \
386{GPIO1_BASE, GPIO_OUT, GPIO_SEL , GPIO_OUT_1}, /* GPIO54 WD_STROBE */ \
387{GPIO1_BASE, GPIO_OUT, GPIO_SEL , GPIO_OUT_1}, /* GPIO55 LED_2_OUT */ \
388{GPIO1_BASE, GPIO_OUT, GPIO_SEL , GPIO_OUT_1}, /* GPIO56 LED_1_OUT */ \
389{GPIO1_BASE, GPIO_IN , GPIO_SEL , GPIO_OUT_0}, /* GPIO57 Unselect via TraceSelect Bit */ \
390{GPIO1_BASE, GPIO_IN , GPIO_SEL , GPIO_OUT_0}, /* GPIO58 Unselect via TraceSelect Bit */ \
391{GPIO1_BASE, GPIO_IN , GPIO_SEL , GPIO_OUT_0}, /* GPIO59 Unselect via TraceSelect Bit */ \
392{GPIO1_BASE, GPIO_IN , GPIO_SEL , GPIO_OUT_0}, /* GPIO60 Unselect via TraceSelect Bit */ \
393{GPIO1_BASE, GPIO_OUT, GPIO_SEL , GPIO_OUT_0}, /* GPIO61 STARTUP_FINISHED_N */ \
394{GPIO1_BASE, GPIO_OUT, GPIO_SEL , GPIO_OUT_1}, /* GPIO62 STARTUP_FINISHED */ \
395{GPIO1_BASE, GPIO_IN , GPIO_SEL , GPIO_OUT_0}, /* GPIO63 SERVICE_PORT_ACTIVE */ \
396} \
397}
398
399#endif /* __CONFIG_H */