These are the initial support files for the AMCC dual PPC460GT Arches reference 
board.


Signed-off-by: Adam Graham <[EMAIL PROTECTED]>
Signed-off-by: Victor Gallardo <[EMAIL PROTECTED]>

---
 Makefile                      |    3 +
 board/amcc/arches/Makefile    |   51 ++++
 board/amcc/arches/arches.c    |  356 +++++++++++++++++++++++++++++
 board/amcc/arches/config.mk   |   41 ++++
 board/amcc/arches/init.S      |  110 +++++++++
 board/amcc/arches/u-boot.lds  |  143 ++++++++++++
 include/configs/amcc-common.h |   20 ++-
 include/configs/arches.h      |  505 +++++++++++++++++++++++++++++++++++++++++
 include/ppc440.h              |    3 +
 9 files changed, 1231 insertions(+), 1 deletions(-)
 create mode 100644 board/amcc/arches/Makefile
 create mode 100644 board/amcc/arches/arches.c
 create mode 100644 board/amcc/arches/config.mk
 create mode 100644 board/amcc/arches/init.S
 create mode 100644 board/amcc/arches/u-boot.lds
 create mode 100644 include/configs/arches.h

diff --git a/Makefile b/Makefile
index 7c13ce8..2241290 100644
--- a/Makefile
+++ b/Makefile
@@ -1186,6 +1186,9 @@ APC405_config:    unconfig
 AR405_config:  unconfig
        @$(MKCONFIG) $(@:_config=) ppc ppc4xx ar405 esd
 
+arches_config: unconfig
+       @$(MKCONFIG) $(@:_config=) ppc ppc4xx arches amcc
+
 ASH405_config: unconfig
        @$(MKCONFIG) $(@:_config=) ppc ppc4xx ash405 esd
 
diff --git a/board/amcc/arches/Makefile b/board/amcc/arches/Makefile
new file mode 100644
index 0000000..6b0c838
--- /dev/null
+++ b/board/amcc/arches/Makefile
@@ -0,0 +1,51 @@
+#
+# (C) Copyright 2008
+# Stefan Roese, DENX Software Engineering, [EMAIL PROTECTED]
+#
+# See file CREDITS for list of people who contributed to this
+# project.
+#
+# This program is free software; you can redistribute it and/or
+# modify it under the terms of the GNU General Public License as
+# published by the Free Software Foundation; either version 2 of
+# the License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 59 Temple Place, Suite 330, Boston,
+# MA 02111-1307 USA
+#
+
+include $(TOPDIR)/config.mk
+
+LIB    = $(obj)lib$(BOARD).a
+
+COBJS  := $(BOARD).o
+SOBJS  := init.o
+
+SRCS   := $(SOBJS:.o=.S) $(COBJS:.o=.c)
+OBJS   := $(addprefix $(obj),$(COBJS))
+SOBJS  := $(addprefix $(obj),$(SOBJS))
+
+$(LIB):        $(OBJS) $(SOBJS)
+       $(AR) $(ARFLAGS) $@ $(OBJS) $(SOBJS)
+
+clean:
+       rm -f $(SOBJS) $(OBJS)
+
+distclean:     clean
+       rm -f $(LIB) core *.bak .depend
+
+#########################################################################
+
+# defines $(obj).depend target
+include $(SRCTREE)/rules.mk
+
+sinclude $(obj).depend
+
+#########################################################################
diff --git a/board/amcc/arches/arches.c b/board/amcc/arches/arches.c
new file mode 100644
index 0000000..34b6bb1
--- /dev/null
+++ b/board/amcc/arches/arches.c
@@ -0,0 +1,356 @@
+/*
+ * (C) Copyright 2008
+ * Adam Graham, Applied Micro Circuits Corp., [EMAIL PROTECTED]
+ * Victor Gallardo, Applied Micro Circuits Corp., [EMAIL PROTECTED]
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; either version 2 of
+ * the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
+ * MA 02111-1307 USA
+ */
+
+#include <common.h>
+#include <libfdt.h>
+#include <fdt_support.h>
+#include <asm/processor.h>
+#include <asm/io.h>
+#include <asm/mmu.h>
+#include <asm/4xx_pcie.h>
+
+/*
+ * FPGA read/write helper macros
+ */
+#define FPGA_READ(offset) ({                           \
+       in_8((void *)(CFG_FPGA_BASE + offset)); })
+#define FPGA_WRITE(offset, data) ({                    \
+       out_8((void *)(CFG_FPGA_BASE + offset), data); })
+
+/*
+ * CPLD read/write helper macros
+ */
+#define CPLD_READ(offset) ({                           \
+       out_8((void *)(CFG_CPLD_ADDR), offset);         \
+       in_8((void *)(CFG_CPLD_DATA)); })
+#define CPLD_WRITE(offset, data) ({                    \
+       out_8((void *)(CFG_CPLD_ADDR), offset);         \
+       out_8((void *)(CFG_CPLD_DATA), data); })
+
+DECLARE_GLOBAL_DATA_PTR;
+
+int board_early_init_f(void)
+{
+       /*
+        * Setup the interrupt controller polarities, triggers, etc.
+        */
+       mtdcr(uic0sr, 0xffffffff);      /* clear all */
+       mtdcr(uic0er, 0x00000000);      /* disable all */
+       mtdcr(uic0cr, 0x00000005);      /* ATI & UIC1 crit are critical */
+       mtdcr(uic0pr, 0xffffffff);      /* per ref-board manual */
+       mtdcr(uic0tr, 0x00000000);      /* per ref-board manual */
+       mtdcr(uic0vr, 0x00000000);      /* int31 highest, base=0x000 */
+       mtdcr(uic0sr, 0xffffffff);      /* clear all */
+
+       mtdcr(uic1sr, 0xffffffff);      /* clear all */
+       mtdcr(uic1er, 0x00000000);      /* disable all */
+       mtdcr(uic1cr, 0x00000000);      /* all non-critical */
+       mtdcr(uic1pr, 0xffffffff);      /* per ref-board manual */
+       mtdcr(uic1tr, 0x00000000);      /* per ref-board manual */
+       mtdcr(uic1vr, 0x00000000);      /* int31 highest, base=0x000 */
+       mtdcr(uic1sr, 0xffffffff);      /* clear all */
+
+       mtdcr(uic2sr, 0xffffffff);      /* clear all */
+       mtdcr(uic2er, 0x00000000);      /* disable all */
+       mtdcr(uic2cr, 0x00000000);      /* all non-critical */
+       mtdcr(uic2pr, 0xffffffff);      /* per ref-board manual */
+       mtdcr(uic2tr, 0x00000000);      /* per ref-board manual */
+       mtdcr(uic2vr, 0x00000000);      /* int31 highest, base=0x000 */
+       mtdcr(uic2sr, 0xffffffff);      /* clear all */
+
+       mtdcr(uic3sr, 0xffffffff);      /* clear all */
+       mtdcr(uic3er, 0x00000000);      /* disable all */
+       mtdcr(uic3cr, 0x00000000);      /* all non-critical */
+       mtdcr(uic3pr, 0xffffffff);      /* per ref-board manual */
+       mtdcr(uic3tr, 0x00000000);      /* per ref-board manual */
+       mtdcr(uic3vr, 0x00000000);      /* int31 highest, base=0x000 */
+       mtdcr(uic3sr, 0xffffffff);      /* clear all */
+
+       /*
+        * Configure PFC (Pin Function Control) registers
+        * UART0: 4 pins
+        */
+       mtsdr(SDR0_PFC1, 0x00040000);
+
+       /* Enable PCI host functionality in SDR0_PCI0 */
+       mtsdr(SDR0_PCI0, 0xe0000000);
+
+       return 0;
+}
+
+u32 get_cpu_num(void)
+{
+       return FPGA_READ(3);
+}
+
+int checkboard(void)
+{
+       char *s = getenv("serial#");
+
+       printf("Board: Arches - AMCC DUAL PPC460GT Reference Design\n");
+       printf("       Revision %02X.%02X ", FPGA_READ(0), FPGA_READ(1));
+
+       /* Only CPU0 has access to CPLD registers */
+       if (get_cpu_num() == 0)
+               printf("(FPGA=%02X, CPLD=%02X)\n", FPGA_READ(2), CPLD_READ(0));
+       else
+               printf("(FPGA=%02X, CPLD=xx)\n", FPGA_READ(2));
+
+       if (s != NULL)
+               printf("       Serial# %s\n", s);
+
+       return 0;
+}
+
+/*
+ *  pci_target_init
+ *
+ *     The bootstrap configuration provides default settings for the pci
+ *     inbound map (PIM). But the bootstrap config choices are limited and
+ *     may not be sufficient for a given board.
+ */
+#if defined(CONFIG_PCI) && defined(CFG_PCI_TARGET_INIT)
+void pci_target_init(struct pci_controller *hose)
+{
+       /*
+        * Disable everything
+        */
+       out_le32((void *)PCIX0_PIM0SA, 0);      /* disable */
+       out_le32((void *)PCIX0_PIM1SA, 0);      /* disable */
+       out_le32((void *)PCIX0_PIM2SA, 0);      /* disable */
+       out_le32((void *)PCIX0_EROMBA, 0);      /* disable expansion rom */
+
+       /*
+        * Map all of SDRAM to PCI address 0x0000_0000. Note that the 440
+        * strapping options to not support sizes such as 128/256 MB.
+        */
+       out_le32((void *)PCIX0_PIM0LAL, CFG_SDRAM_BASE);
+       out_le32((void *)PCIX0_PIM0LAH, 0);
+       out_le32((void *)PCIX0_PIM0SA, ~(gd->ram_size - 1) | 1);
+       out_le32((void *)PCIX0_BAR0, 0);
+
+       /*
+        * Program the board's subsystem id/vendor id
+        */
+       out_le16((void *)PCIX0_SBSYSVID, CFG_PCI_SUBSYS_VENDORID);
+       out_le16((void *)PCIX0_SBSYSID, CFG_PCI_SUBSYS_DEVICEID);
+
+       out_le16((void *)PCIX0_CMD, in16r(PCIX0_CMD) | PCI_COMMAND_MEMORY);
+}
+#endif /* defined(CONFIG_PCI) && defined(CFG_PCI_TARGET_INIT) */
+
+#if defined(CONFIG_PCI)
+/*
+ * is_pci_host
+ *
+ * This routine is called to determine if a pci scan should be
+ * performed. With various hardware environments (especially cPCI and
+ * PPMC) it's insufficient to depend on the state of the arbiter enable
+ * bit in the strap register, or generic host/adapter assumptions.
+ *
+ * Rather than hard-code a bad assumption in the general 440 code, the
+ * 440 pci code requires the board to decide at runtime.
+ *
+ * Return 0 for adapter mode, non-zero for host (monarch) mode.
+ */
+int is_pci_host(struct pci_controller *hose)
+{
+       /* Board is always configured as host. */
+       return 1;
+}
+
+static struct pci_controller pcie_hose[2] = { {0}, {0} };
+
+void pcie_setup_hoses(int busno)
+{
+       struct pci_controller *hose;
+       int i, bus;
+       int ret = 0;
+       char *env;
+       unsigned int delay;
+       int end;
+
+       /*
+        * assume we're called after the PCIX hose is initialized, which takes
+        * bus ID 0 and therefore start numbering PCIe's from 1.
+        */
+       bus = busno;
+
+#if defined(CONFIG_RAPIDIO)
+       end = 0;
+#else
+       end = 1;
+#endif
+
+       for (i = 0; i <= end; i++) {
+
+               if (is_end_point(i))
+                       ret = ppc4xx_init_pcie_endport(i);
+               else
+                       ret = ppc4xx_init_pcie_rootport(i);
+               if (ret) {
+                       printf("PCIE%d: initialization as %s failed\n", i,
+                              is_end_point(i) ? "endpoint" : "root-complex");
+                       continue;
+               }
+
+               hose = &pcie_hose[i];
+               hose->first_busno = bus;
+               hose->last_busno = bus;
+               hose->current_busno = bus;
+
+               /* setup mem resource */
+               pci_set_region(hose->regions + 0,
+                              CFG_PCIE_MEMBASE + i * CFG_PCIE_MEMSIZE,
+                              CFG_PCIE_MEMBASE + i * CFG_PCIE_MEMSIZE,
+                              CFG_PCIE_MEMSIZE,
+                              PCI_REGION_MEM);
+               hose->region_count = 1;
+               pci_register_hose(hose);
+
+               if (is_end_point(i)) {
+                       ppc4xx_setup_pcie_endpoint(hose, i);
+                       /*
+                        * Reson for no scanning is endpoint can not generate
+                        * upstream configuration accesses.
+                        */
+               } else {
+                       ppc4xx_setup_pcie_rootpoint(hose, i);
+                       env = getenv("pciscandelay");
+                       if (env != NULL) {
+                               delay = simple_strtoul(env, NULL, 10);
+                               if (delay > 5)
+                                       printf("Warning, expect noticable "
+                                               "delay before PCIe scan due "
+                                               "to 'pciscandelay' value!\n");
+                               mdelay(delay * 1000);
+                       }
+
+                       /*
+                        * Config access can only go down stream
+                        */
+                       hose->last_busno = pci_hose_scan(hose);
+                       bus = hose->last_busno + 1;
+               }
+       }
+}
+#endif /* CONFIG_PCI */
+
+int board_early_init_r(void)
+{
+       /*
+        * Arches has 32MBytes of NOR FLASH (Spansion 29GL256), but the
+        * boot EBC mapping only supports a maximum of 16MBytes
+        * (4.ff00.0000 - 4.ffff.ffff).
+        * To solve this problem, the FLASH has to get remapped to another
+        * EBC address which accepts bigger regions:
+        *
+        * 0xfe00.0000 -> 4.ce00.0000
+        */
+
+       /* Remap the NOR FLASH to 0xcc00.0000 ... 0xcfff.ffff */
+       mtebc(pb0cr, CFG_FLASH_BASE_PHYS_L | EBC_BXCR_BS_32MB |
+                               EBC_BXCR_BU_RW | EBC_BXCR_BW_16BIT);
+
+       /* Remove TLB entry of boot EBC mapping */
+       remove_tlb(CFG_BOOT_BASE_ADDR, 16 << 20);
+
+       /* Add TLB entry for 0xfe00.0000 -> 0x4.ce00.0000 */
+       program_tlb(CFG_FLASH_BASE_PHYS, CFG_FLASH_BASE, CFG_FLASH_SIZE,
+                               TLB_WORD2_I_ENABLE);
+
+       /*
+        * Now accessing of the whole 32Mbytes of NOR FLASH at virtual address
+        * 0xfe00.0000 is possible
+        */
+
+       /*
+        * Clear potential errors resulting from auto-calibration.
+        * If not done, then we could get an interrupt later on when
+        * exceptions are enabled.
+        */
+       set_mcsr(get_mcsr());
+
+       return 0;
+}
+
+int misc_init_r(void)
+{
+       u32 eth_cfg = 0;
+       u32 eth_pll;
+       int timeout;
+
+       /*
+        * Set EMAC mode/configuration (GMII, SGMII, RGMII...).
+        * This is board specific, so let's do it here.
+        */
+
+       /* enable SGMII mode */
+       eth_cfg |= (SDR0_ETH_CFG_SGMII0_ENABLE |
+                       SDR0_ETH_CFG_SGMII1_ENABLE |
+                       SDR0_ETH_CFG_SGMII2_ENABLE);
+
+       /* Set EMAC for MDIO */
+       eth_cfg |= SDR0_ETH_CFG_MDIO_SEL_EMAC0;
+
+       /* bypass the TAHOE0/TAHOE1 cores for U-Boot */
+       eth_cfg |= (SDR0_ETH_CFG_TAHOE0_BYPASS | SDR0_ETH_CFG_TAHOE1_BYPASS);
+
+       mtsdr(SDR0_ETH_CFG, eth_cfg);
+
+       /* reset SGMII interface */
+       mtsdr(SDR0_SRST1,   0x00000380);
+       mtsdr(SDR0_ETH_STS, 0xFFFFFFFF);
+       mtsdr(SDR0_SRST1,   0x00000000);
+
+       for (timeout = 60; timeout > 0; timeout--) {
+               udelay(1000);
+               mfsdr(SDR0_ETH_PLL, eth_pll);
+               if ((eth_pll & 0x80000000) != 0)
+                       break;
+       }
+
+       if (timeout == 0)
+               printf("timeout: while waiting for SGMII PLL lock\n");
+
+       return 0;
+}
+
+#if defined(CONFIG_OF_LIBFDT) && defined(CONFIG_OF_BOARD_SETUP)
+void ft_board_setup(void *blob, bd_t *bd)
+{
+       u32 val[4];
+       int rc;
+
+       ft_cpu_setup(blob, bd);
+
+       /* Fixup NOR mapping */
+       val[0] = 0;                             /* chip select number */
+       val[1] = 0;                             /* always 0 */
+       val[2] = CFG_FLASH_BASE_PHYS_L;         /* we fixed up this address */
+       val[3] = gd->bd->bi_flashsize;
+       rc = fdt_find_and_setprop(blob, "/plb/opb/ebc", "ranges",
+                               val, sizeof(val), 1);
+       if (rc)
+               printf("Unable to update property NOR mapping, err=%s\n",
+                               fdt_strerror(rc));
+}
+#endif /* defined(CONFIG_OF_LIBFDT) && defined(CONFIG_OF_BOARD_SETUP) */
diff --git a/board/amcc/arches/config.mk b/board/amcc/arches/config.mk
new file mode 100644
index 0000000..065e39e
--- /dev/null
+++ b/board/amcc/arches/config.mk
@@ -0,0 +1,41 @@
+#
+# (C) Copyright 2008
+# Wolfgang Denk, DENX Software Engineering, [EMAIL PROTECTED]
+#
+# See file CREDITS for list of people who contributed to this
+# project.
+#
+# This program is free software; you can redistribute it and/or
+# modify it under the terms of the GNU General Public License as
+# published by the Free Software Foundation; either version 2 of
+# the License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 59 Temple Place, Suite 330, Boston,
+# MA 02111-1307 USA
+#
+#
+# AMCC dual 460GT Evaluation Board (Arches) board
+#
+
+sinclude $(OBJTREE)/board/$(BOARDDIR)/config.tmp
+
+ifndef TEXT_BASE
+TEXT_BASE = 0xFFFA0000
+endif
+
+PLATFORM_CPPFLAGS += -DCONFIG_440=1
+
+ifeq ($(debug),1)
+PLATFORM_CPPFLAGS += -DDEBUG
+endif
+
+ifeq ($(dbcr),1)
+PLATFORM_CPPFLAGS += -DCFG_INIT_DBCR=0x8cff0000
+endif
diff --git a/board/amcc/arches/init.S b/board/amcc/arches/init.S
new file mode 100644
index 0000000..d53f044
--- /dev/null
+++ b/board/amcc/arches/init.S
@@ -0,0 +1,110 @@
+/*
+ * (C) Copyright 2008
+ * Adam Graham, Applied Micro Circuits Corp., [EMAIL PROTECTED]
+ * Victor Gallardo, Applied Micro Circuits Corp., [EMAIL PROTECTED]
+ *
+ * See file CREDITS for list of people who contributed to this
+ * project.
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; either version 2 of
+ * the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.         See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
+ * MA 02111-1307 USA
+ */
+
+#include <ppc_asm.tmpl>
+#include <config.h>
+#include <asm-ppc/mmu.h>
+
+/**************************************************************************
+ * TLB TABLE
+ *
+ * This table is used by the cpu boot code to setup the initial tlb
+ * entries. Rather than make broad assumptions in the cpu source tree,
+ * this table lets each board set things up however they like.
+ *
+ *  Pointer to the table is returned in r1
+ *
+ *************************************************************************/
+       .section .bootpg,"ax"
+       .globl tlbtab
+
+tlbtab:
+       tlbtab_start
+
+       /*
+        * BOOT_CS (FLASH) must be first. Before relocation SA_I can be off to
+        * use the speed up boot process. It is patched after relocation to
+        * enable SA_I
+        */
+       tlbentry(CFG_BOOT_BASE_ADDR, SZ_16M, CFG_BOOT_BASE_ADDR,
+                                       4, AC_R|AC_W|AC_X|SA_G) /* TLB 0 */
+
+       /*
+        * TLB entries for SDRAM are not needed on this platform.
+        * They are dynamically generated in the SPD DDR(2) detection
+        * routine.
+        */
+
+#ifdef CFG_INIT_RAM_DCACHE
+       /* TLB-entry for init-ram in dcache (SA_I must be turned off!) */
+       tlbentry(CFG_INIT_RAM_ADDR, SZ_4K, CFG_INIT_RAM_ADDR,
+                                       0, AC_R|AC_W|AC_X|SA_G)
+#endif
+
+       tlbentry(CFG_PCI_BASE, SZ_256M, 0x00000000, 0xC,
+                                       AC_R|AC_W|SA_G|SA_I)
+       tlbentry(CFG_PCI_MEMBASE, SZ_256M, 0x20000000, 0xC,
+                                       AC_R|AC_W|SA_G|SA_I)
+       tlbentry(CFG_PCIE_MEMBASE, SZ_256M, 0xB0000000, 0xD,
+                                       AC_R|AC_W|SA_G|SA_I)
+
+       tlbentry(CFG_PCIE0_CFGBASE, SZ_16M, 0x00000000, 0xD,
+                                       AC_R|AC_W|SA_G|SA_I)
+       tlbentry(CFG_PCIE0_XCFGBASE, SZ_1K, 0x10000000, 0xD,
+                                       AC_R|AC_W|SA_G|SA_I)
+
+#if defined(CONFIG_RAPIDIO)
+        /* TLB-entries for RapidIO (SRIO) */
+        tlbentry(CFG_SRGPL0_REG_BAR, SZ_16M, CFG_SRGPL0_REG_BAR,
+                                       0xD, AC_R|AC_W|SA_G|SA_I)
+        tlbentry(CFG_SRGPL0_CFG_BAR, SZ_16M, CFG_SRGPL0_CFG_BAR,
+                                       0xD, AC_R|AC_W|SA_G|SA_I)
+        tlbentry(CFG_SRGPL0_MNT_BAR, SZ_16M, CFG_SRGPL0_MNT_BAR,
+                                       0xD, AC_R|AC_W|SA_G|SA_I)
+        tlbentry(CFG_I2ODMA_BASE, SZ_1K,  0x00100000,
+                                       0x4, AC_R|AC_W|SA_G|SA_I)
+#else
+       tlbentry(CFG_PCIE1_CFGBASE, SZ_16M, 0x20000000, 0xD,
+                                       AC_R|AC_W|SA_G|SA_I)
+       tlbentry(CFG_PCIE1_XCFGBASE, SZ_1K, 0x30000000, 0xD,
+                                       AC_R|AC_W|SA_G|SA_I)
+#endif
+
+       /* PCIe UTL register */
+       tlbentry(CFG_PCIE_BASE, SZ_16K, 0x08010000,
+                                       0xC, AC_R|AC_W|SA_G|SA_I)
+
+       /* TLB-entry for FPGA */
+       tlbentry(CFG_FPGA_BASE, SZ_16M, CFG_FPGA_BASE,
+                                       4, AC_R|AC_W|SA_G|SA_I)
+
+       /* TLB-entry for OCM */
+       tlbentry(CFG_OCM_BASE, SZ_64K, 0x00040000,
+                                       4, AC_R|AC_W|AC_X|SA_I)
+
+       /* TLB-entry for Local Configuration registers => peripherals */
+       tlbentry(CFG_LOCAL_CONF_REGS, SZ_16M, CFG_LOCAL_CONF_REGS,
+                                       4, AC_R|AC_W|AC_X|SA_G|SA_I)
+
+       tlbtab_end
diff --git a/board/amcc/arches/u-boot.lds b/board/amcc/arches/u-boot.lds
new file mode 100644
index 0000000..0a2e7a1
--- /dev/null
+++ b/board/amcc/arches/u-boot.lds
@@ -0,0 +1,143 @@
+/*
+ * (C) Copyright 2008
+ * Wolfgang Denk, DENX Software Engineering, [EMAIL PROTECTED]
+ *
+ * See file CREDITS for list of people who contributed to this
+ * project.
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; either version 2 of
+ * the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
+ * MA 02111-1307 USA
+ */
+
+OUTPUT_ARCH(powerpc)
+/* Do we need any of these for elf?
+   __DYNAMIC = 0;    */
+SECTIONS
+{
+  .resetvec 0xFFFFFFFC :
+  {
+    *(.resetvec)
+  } = 0xffff
+
+  .bootpg 0xFFFFF000 :
+  {
+    cpu/ppc4xx/start.o (.bootpg)
+  } = 0xffff
+
+  /* Read-only sections, merged into text segment: */
+  . = + SIZEOF_HEADERS;
+  .interp : { *(.interp) }
+  .hash          : { *(.hash)          }
+  .dynsym        : { *(.dynsym)                }
+  .dynstr        : { *(.dynstr)                }
+  .rel.text      : { *(.rel.text)              }
+  .rela.text     : { *(.rela.text)     }
+  .rel.data      : { *(.rel.data)              }
+  .rela.data     : { *(.rela.data)     }
+  .rel.rodata    : { *(.rel.rodata)    }
+  .rela.rodata   : { *(.rela.rodata)   }
+  .rel.got       : { *(.rel.got)               }
+  .rela.got      : { *(.rela.got)              }
+  .rel.ctors     : { *(.rel.ctors)     }
+  .rela.ctors    : { *(.rela.ctors)    }
+  .rel.dtors     : { *(.rel.dtors)     }
+  .rela.dtors    : { *(.rela.dtors)    }
+  .rel.bss       : { *(.rel.bss)               }
+  .rela.bss      : { *(.rela.bss)              }
+  .rel.plt       : { *(.rel.plt)               }
+  .rela.plt      : { *(.rela.plt)              }
+  .init          : { *(.init)  }
+  .plt : { *(.plt) }
+  .text      :
+  {
+    /* WARNING - the following is hand-optimized to fit within */
+    /* the sector layout of our flash chips!   XXX FIXME XXX   */
+
+    cpu/ppc4xx/start.o (.text)
+    board/amcc/arches/init.o   (.text)
+
+    *(.text)
+    *(.fixup)
+    *(.got1)
+  }
+  _etext = .;
+  PROVIDE (etext = .);
+  .rodata    :
+  {
+    *(.rodata)
+    *(.rodata1)
+    *(.rodata.str1.4)
+  }
+  .fini      : { *(.fini)    } =0
+  .ctors     : { *(.ctors)   }
+  .dtors     : { *(.dtors)   }
+
+  /* Read-write section, merged into data segment: */
+  . = (. + 0x00FF) & 0xFFFFFF00;
+  _erotext = .;
+  PROVIDE (erotext = .);
+  .reloc   :
+  {
+    *(.got)
+    _GOT2_TABLE_ = .;
+    *(.got2)
+    _FIXUP_TABLE_ = .;
+    *(.fixup)
+  }
+  __got2_entries = (_FIXUP_TABLE_ - _GOT2_TABLE_) >>2;
+  __fixup_entries = (. - _FIXUP_TABLE_)>>2;
+
+  .data    :
+  {
+    *(.data)
+    *(.data1)
+    *(.sdata)
+    *(.sdata2)
+    *(.dynamic)
+    CONSTRUCTORS
+  }
+  _edata  =  .;
+  PROVIDE (edata = .);
+
+  . = .;
+  __u_boot_cmd_start = .;
+  .u_boot_cmd : { *(.u_boot_cmd) }
+  __u_boot_cmd_end = .;
+
+
+  . = .;
+  __start___ex_table = .;
+  __ex_table : { *(__ex_table) }
+  __stop___ex_table = .;
+
+  . = ALIGN(256);
+  __init_begin = .;
+  .text.init : { *(.text.init) }
+  .data.init : { *(.data.init) }
+  . = ALIGN(256);
+  __init_end = .;
+
+  __bss_start = .;
+  .bss       :
+  {
+   *(.sbss) *(.scommon)
+   *(.dynbss)
+   *(.bss)
+   *(COMMON)
+  }
+
+  _end = . ;
+  PROVIDE (end = .);
+}
diff --git a/include/configs/amcc-common.h b/include/configs/amcc-common.h
index 1f27d78..fb19e0d 100644
--- a/include/configs/amcc-common.h
+++ b/include/configs/amcc-common.h
@@ -55,6 +55,14 @@
 #endif
 
 /*
+ * Only very few boards have default netdev not set to eth0 (like Arches)
+ */
+#if !defined(CONFIG_NETDEV)
+#define CONFIG_NETDEV             eth0
+#endif
+
+
+/*
  * Commands
  */
 #include <config_cmd_default.h>
@@ -147,9 +155,11 @@
 /*
  * Booting and default environment
  */
+#if !defined(CONFIG_PREBOOT)
 #define CONFIG_PREBOOT "echo;" \
        "echo Type \"run flash_nfs\" to mount root filesystem over NFS;" \
        "echo"
+#endif
 #define CONFIG_BOOTCOMMAND     "run flash_self"
 
 /*
@@ -184,7 +194,7 @@
  * General common environment variables shared on all AMCC eval boards
  */
 #define CONFIG_AMCC_DEF_ENV                                            \
-       "netdev=eth0\0"                                                 \
+       "netdev=" xstr(CONFIG_NETDEV) "\0"                              \
        "nfsargs=setenv bootargs root=/dev/nfs rw "                     \
                "nfsroot=${serverip}:${rootpath}\0"                     \
        "ramargs=setenv bootargs root=/dev/ram rw\0"                    \
@@ -197,8 +207,10 @@
        "initrd_high=30000000\0"                                        \
        "kernel_addr_r=400000\0"                                        \
        "fdt_addr_r=800000\0"                                           \
+       "ramdisk_addr_r=C00000\0"                                       \
        "hostname=" xstr(CONFIG_HOSTNAME) "\0"                          \
        "bootfile=" xstr(CONFIG_HOSTNAME) "/uImage\0"                   \
+       "ramdisk_file=" xstr(CONFIG_HOSTNAME) "/uRamdisk\0"             \
        CONFIG_AMCC_DEF_ENV_ROOTPATH
 
 /*
@@ -214,6 +226,12 @@
                "tftp ${fdt_addr_r} ${fdt_file}; "                      \
                "run nfsargs addip addtty addmisc;"                     \
                "bootm ${kernel_addr_r} - ${fdt_addr_r}\0"              \
+       "net_self_load=tftp ${kernel_addr_r} ${bootfile};"              \
+               "tftp ${fdt_addr_r} ${fdt_file};"                       \
+               "tftp ${ramdisk_addr_r} ${ramdisk_file};\0"             \
+       "net_self=run net_self_load;"                                   \
+               "run ramargs addip addtty addmisc;"                     \
+               "bootm ${kernel_addr_r} ${ramdisk_addr_r} ${fdt_addr_r}\0" \
        "fdt_file=" xstr(CONFIG_HOSTNAME) "/" xstr(CONFIG_HOSTNAME) ".dtb\0"
 
 /*
diff --git a/include/configs/arches.h b/include/configs/arches.h
new file mode 100644
index 0000000..6ad862f
--- /dev/null
+++ b/include/configs/arches.h
@@ -0,0 +1,505 @@
+/*
+ * (C) Copyright 2008
+ * Adam Graham, Applied Micro Circuits Corp., [EMAIL PROTECTED]
+ * Victor Gallardo, Applied Micro Circuits Corp., [EMAIL PROTECTED]
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; either version 2 of
+ * the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
+ * MA 02111-1307 USA
+ */
+
+/************************************************************************
+ * arches.h - configuration for Arches (460GT)
+ ***********************************************************************/
+#ifndef __CONFIG_H
+#define __CONFIG_H
+
+/*-----------------------------------------------------------------------
+ * High Level Configuration Options
+ *----------------------------------------------------------------------*/
+/* This config file is used for Arches (460GT) */
+#define CONFIG_ARCHES          1       /* Board is Arches              */
+#define CONFIG_460GT           1       /* Specific PPC460GT            */
+#define CONFIG_440             1
+#define CONFIG_4xx             1       /* ... PPC4xx family */
+#define CONFIG_NETDEV           eth1
+
+/*
+ * Update default PREBOOT environment variables
+ * defined in amcc-common.h
+ */
+#define CONFIG_PREBOOT \
+       "setenv ethact ppc_4xx_eth1;" \
+       "echo;" \
+       "echo Type \"run flash_nfs\" to mount root filesystem over NFS;" \
+       "echo;"
+
+/*
+ * Include common defines/options for all AMCC eval boards
+ */
+#define CONFIG_HOSTNAME                arches
+#include "amcc-common.h"
+
+#define CONFIG_SYS_CLK_FREQ    66666667        /* external freq to pll */
+
+#define CONFIG_BOARD_EARLY_INIT_F      1       /* Call board_early_init_f */
+#define CONFIG_BOARD_EARLY_INIT_R      1       /* Call board_early_init_r */
+#define CONFIG_MISC_INIT_R             1       /* Call misc_init_r */
+#define CONFIG_BOARD_TYPES             1       /* support board types */
+
+/*-----------------------------------------------------------------------
+ * RapidIO I/O and Registers
+ *----------------------------------------------------------------------*/
+
+#define CONFIG_RAPIDIO
+#define CFG_460GT_SRIO_ERRATA_1
+
+#define SRGPL0_REG_BAR        0x0000000DAA000000ull /*  16MB */
+#define SRGPL0_CFG_BAR        0x0000000DAB000000ull /*  16MB */
+#define SRGPL0_MNT_BAR        0x0000000DAC000000ull /*  16MB */
+#define SRGPL0_MSG_BAR        0x0000000DAD000000ull /*  16MB */
+#define SRGPL0_OUT_BAR        0x0000000DB0000000ull /* 256MB */
+
+#define CFG_SRGPL0_REG_BAR    0xAA000000 /*  16MB */
+#define CFG_SRGPL0_CFG_BAR    0xAB000000 /*  16MB */
+#define CFG_SRGPL0_MNT_BAR    0xAC000000 /*  16MB */
+#define CFG_SRGPL0_MSG_BAR    0xAD000000 /*  16MB */
+
+#define CFG_I2ODMA_BASE       0xCF000000
+#define CFG_I2ODMA_PHYS_ADDR  0x0000000400100000ull
+
+#define CONFIG_PPC4XX_RAPIDIO_PROMISCUOUS_MODE
+#undef  CONFIG_PPC4XX_RAPIDIO_DEBUG
+#undef  CONFIG_PPC4XX_RAPIDIO_IN_BAR_USE_OCM
+#define CONFIG_PPC4XX_RAPIDIO_USE_HB_PLB
+#undef  CONFIG_PPC4XX_RAPIDIO_LOOPBACK
+
+/* EBC stuff */
+#define CFG_NAND_ADDR          0xE0000000
+#define CFG_FPGA_BASE          0xE1000000
+#define CFG_CPLD_ADDR          (CFG_FPGA_BASE + 0x00080000)
+#define CFG_CPLD_DATA          (CFG_FPGA_BASE + 0x00080002)
+#define CFG_BOOT_BASE_ADDR     0xFF000000      /* EBC Boot Space: 0xFF000000 */
+#define CFG_FLASH_BASE         0xFE000000      /* later mapped to this addr  */
+#define CFG_FLASH_BASE_PHYS_H  0x4
+#define CFG_FLASH_BASE_PHYS_L  0xCE000000
+#define CFG_FLASH_BASE_PHYS    (((u64)CFG_FLASH_BASE_PHYS_H << 32) | \
+                                (u64)CFG_FLASH_BASE_PHYS_L)
+#define CFG_FLASH_SIZE         (32 << 20)
+
+#define CFG_OCM_BASE           0xE3000000      /* OCM: 64k             */
+#define CFG_OCM_PHYS_ADDR       0x0000000400040000ull
+
+#define CFG_SRAM_BASE          0xE8000000      /* SRAM: 256k           */
+#define CFG_LOCAL_CONF_REGS    0xEF000000
+
+#define CFG_PERIPHERAL_BASE    0xEF600000      /* internal peripherals */
+
+#define CFG_AHB_BASE           0xE2000000      /* internal AHB peripherals */
+
+/*-----------------------------------------------------------------------
+ * Initial RAM & stack pointer (placed in OCM)
+ *----------------------------------------------------------------------*/
+#define CFG_INIT_RAM_ADDR      CFG_OCM_BASE    /* OCM                  */
+#define CFG_INIT_RAM_END       (4 << 10)
+#define CFG_GBL_DATA_SIZE      256             /* num bytes initial data */
+#define CFG_GBL_DATA_OFFSET    (CFG_INIT_RAM_END - CFG_GBL_DATA_SIZE)
+#define CFG_INIT_SP_OFFSET     CFG_GBL_DATA_OFFSET
+
+/*-----------------------------------------------------------------------
+ * Serial Port
+ *----------------------------------------------------------------------*/
+#undef CONFIG_UART1_CONSOLE    /* define this if you want console on UART1 */
+
+/*-----------------------------------------------------------------------
+ * Environment
+ *----------------------------------------------------------------------*/
+/*
+ * Define here the location of the environment variables (FLASH).
+ */
+#define        CONFIG_ENV_IS_IN_FLASH  1       /* use FLASH for environment 
vars */
+
+/*-----------------------------------------------------------------------
+ * FLASH related
+ *----------------------------------------------------------------------*/
+#define CFG_FLASH_CFI                  /* The flash is CFI compatible  */
+#define CONFIG_FLASH_CFI_DRIVER                /* Use common CFI driver        
*/
+#define CFG_FLASH_CFI_AMD_RESET        1       /* Use AMD (Spansion) reset cmd 
*/
+
+#define CFG_FLASH_BANKS_LIST    {CFG_FLASH_BASE}
+#define CFG_MAX_FLASH_BANKS    1       /* max number of memory banks        */
+#define CFG_MAX_FLASH_SECT     512     /* max number of sectors on one chip */
+
+#define CFG_FLASH_ERASE_TOUT   120000  /* Timeout for Flash Erase (in ms)   */
+#define CFG_FLASH_WRITE_TOUT   500     /* Timeout for Flash Write (in ms)   */
+
+#define CFG_FLASH_USE_BUFFER_WRITE 1   /* use buffered writes (20x faster)  */
+#define CFG_FLASH_EMPTY_INFO           /* print 'E' for empty sector flinfo */
+
+#ifdef CONFIG_ENV_IS_IN_FLASH
+#define CONFIG_ENV_SECT_SIZE   0x20000         /* size of 1 complete sector */
+#define CONFIG_ENV_ADDR                (CFG_MONITOR_BASE - 
CONFIG_ENV_SECT_SIZE)
+#define        CONFIG_ENV_SIZE         0x4000  /* Total Size of Environment 
Sector  */
+
+/* Address and size of Redundant Environment Sector    */
+#define CONFIG_ENV_ADDR_REDUND (CONFIG_ENV_ADDR - CONFIG_ENV_SECT_SIZE)
+#define CONFIG_ENV_SIZE_REDUND (CONFIG_ENV_SIZE)
+#endif /* CFG_ENV_IS_IN_FLASH */
+
+/*----------------------------------------------------------------------------
+ * DDR SDRAM
+ *---------------------------------------------------------------------------*/
+#define CONFIG_AUTOCALIB       "silent\0"      /* default is non-verbose    */
+
+#define        CONFIG_PPC4xx_DDR_AUTOCALIBRATION       /* IBM DDR 
autocalibration   */
+#define        DEBUG_PPC4xx_DDR_AUTOCALIBRATION        /* dynamic DDR autocal 
debug */
+#undef CONFIG_PPC4xx_DDR_METHOD_A
+
+#define CFG_MBYTES_SDRAM       512
+
+/* DDR1/2 SDRAM Device Control Register Data Values */
+/* Memory Queue */
+#define        CFG_SDRAM_R0BAS                 0x0000f000
+#define        CFG_SDRAM_R1BAS                 0x00000000
+#define        CFG_SDRAM_R2BAS                 0x00000000
+#define        CFG_SDRAM_R3BAS                 0x00000000
+#define CFG_SDRAM_PLBADDULL            0x00000000
+#define CFG_SDRAM_PLBADDUHB            0x00000008
+#define CFG_SDRAM_CONF1LL              0x00001080
+#define CFG_SDRAM_CONF1HB              0x00001080
+#define CFG_SDRAM_CONFPATHB            0x10a68000
+
+/* SDRAM Controller */
+#define CFG_SDRAM0_MB0CF               0x00000701
+#define CFG_SDRAM0_MB1CF               0x00000000
+#define CFG_SDRAM0_MB2CF               0x00000000
+#define CFG_SDRAM0_MB3CF               0x00000000
+#define CFG_SDRAM0_MCOPT1              0x05322000
+#define CFG_SDRAM0_MCOPT2              0x00000000
+#define CFG_SDRAM0_MODT0               0x01000000
+#define CFG_SDRAM0_MODT1               0x00000000
+#define CFG_SDRAM0_MODT2               0x00000000
+#define CFG_SDRAM0_MODT3               0x00000000
+#define CFG_SDRAM0_CODT                        0x00800021
+#define CFG_SDRAM0_RTR                 0x06180000
+#define CFG_SDRAM0_INITPLR0            0xb5380000
+#define CFG_SDRAM0_INITPLR1            0x82100400
+#define CFG_SDRAM0_INITPLR2            0x80820000
+#define CFG_SDRAM0_INITPLR3            0x80830000
+#define CFG_SDRAM0_INITPLR4            0x80810040
+#define CFG_SDRAM0_INITPLR5            0x80800532
+#define CFG_SDRAM0_INITPLR6            0x82100400
+#define CFG_SDRAM0_INITPLR7            0x8a080000
+#define CFG_SDRAM0_INITPLR8            0x8a080000
+#define CFG_SDRAM0_INITPLR9            0x8a080000
+#define CFG_SDRAM0_INITPLR10           0x8a080000
+#define CFG_SDRAM0_INITPLR11           0x80000432
+#define CFG_SDRAM0_INITPLR12           0x808103c0
+#define CFG_SDRAM0_INITPLR13           0x80810040
+#define CFG_SDRAM0_INITPLR14           0x00000000
+#define CFG_SDRAM0_INITPLR15           0x00000000
+#define CFG_SDRAM0_RQDC                        0x80000038
+#define CFG_SDRAM0_RFDC                        0x00000257
+#define CFG_SDRAM0_RDCC                        0x40000000
+#define CFG_SDRAM0_DLCR                        0x03000091
+#define CFG_SDRAM0_CLKTR               0x40000000
+#define CFG_SDRAM0_WRDTR               0x82000823
+#define CFG_SDRAM0_SDTR1               0x80201000
+#define CFG_SDRAM0_SDTR2               0x42204243
+#define CFG_SDRAM0_SDTR3               0x090c0d1a
+#define CFG_SDRAM0_MMODE               0x00000432
+#define CFG_SDRAM0_MEMODE              0x00000004
+
+/*-----------------------------------------------------------------------
+ * I2C
+ *----------------------------------------------------------------------*/
+#define CFG_I2C_SPEED          400000  /* I2C speed                    */
+
+#define CFG_I2C_MULTI_EEPROMS
+#define CFG_I2C_EEPROM_ADDR            (0xa8>>1)
+#define CFG_I2C_EEPROM_ADDR_LEN                1
+#define CFG_EEPROM_PAGE_WRITE_ENABLE
+#define CFG_EEPROM_PAGE_WRITE_BITS     3
+#define CFG_EEPROM_PAGE_WRITE_DELAY_MS 10
+
+/* I2C SYSMON (LM75, AD7414 is almost compatible)                      */
+#define CONFIG_DTT_LM75                1               /* ON Semi's LM75       
*/
+#define CONFIG_DTT_AD7414      1               /* use AD7414           */
+#define CFG_I2C_DTT_ADDR       0x4a            /* AD7414 I2C address   */
+#define CONFIG_DTT_SENSORS     { 0 }           /* Sensor addresses     */
+#define CFG_DTT_MAX_TEMP       70
+#define CFG_DTT_LOW_TEMP       -30
+#define CFG_DTT_HYSTERESIS     3
+
+/*-----------------------------------------------------------------------
+ * Ethernet
+ *----------------------------------------------------------------------*/
+#define CONFIG_FIXED_PHY       0xFFFFFFFF
+#define CONFIG_IBM_EMAC4_V4    1
+#define CONFIG_PHY_ADDR                CONFIG_FIXED_PHY
+#define CONFIG_PHY1_ADDR       0
+#define CONFIG_PHY2_ADDR       1
+#define CONFIG_HAS_ETH0
+#define CONFIG_HAS_ETH1
+#define CONFIG_HAS_ETH2
+
+#define CFG_FIXED_PHY_PORT(devnum, speed, duplex) \
+               {devnum, speed, duplex},
+#define CFG_FIXED_PHY_PORTS \
+               CFG_FIXED_PHY_PORT(0, 1000, FULL) \
+
+#define CONFIG_M88E1112_PHY
+#define CONFIG_PHY_RESET       1       /* reset phy upon startup       */
+#define CONFIG_PHY_GIGE                1       /* Include GbE speed/duplex 
detection */
+#define CONFIG_PHY_DYNAMIC_ANEG        1
+
+/*
+ * The following PHY addresses 0xB,0xC,0xD are reserved
+ * in M88E1112 so use these for GPCS PHY addresses
+ */
+#define CONFIG_GPCS_PHY_ADDR    0xB
+#define CONFIG_GPCS_PHY1_ADDR   0xC
+#define CONFIG_GPCS_PHY2_ADDR   0xD
+
+/*
+ * Default environment variables
+ */
+#define        CONFIG_EXTRA_ENV_SETTINGS                                       
\
+       CONFIG_AMCC_DEF_ENV                                             \
+       CONFIG_AMCC_DEF_ENV_POWERPC                                     \
+       CONFIG_AMCC_DEF_ENV_NOR_UPD                                     \
+       "kernel_addr=fe000000\0"                                        \
+       "fdt_addr=fe1e0000\0"                                           \
+       "ramdisk_addr=fe200000\0"                                       \
+       "pciconfighost=1\0"                                             \
+       "pcie_mode=RP:RP\0"                                             \
+       ""
+
+/*
+ * Commands additional to the ones defined in amcc-common.h
+ */
+#define CONFIG_CMD_DTT
+#define CONFIG_CMD_PCI
+
+/* Partitions */
+#define CONFIG_MAC_PARTITION
+#define CONFIG_DOS_PARTITION
+#define CONFIG_ISO_PARTITION
+
+/*-----------------------------------------------------------------------
+ * PCI stuff
+ *----------------------------------------------------------------------*/
+/* General PCI */
+#define CONFIG_PCI                     /* include pci support          */
+#undef  CONFIG_PCI_PNP                 /* do pci plug-and-play   */
+#define CONFIG_PCI_SCAN_SHOW           /* show pci devices on startup  */
+#define CONFIG_PCI_CONFIG_HOST_BRIDGE
+
+/* Board-specific PCI */
+#define CFG_PCI_TARGET_INIT            /* let board init pci target    */
+#undef CFG_PCI_MASTER_INIT
+
+#define CFG_PCI_SUBSYS_VENDORID 0x1014 /* IBM                          */
+#define CFG_PCI_SUBSYS_DEVICEID 0xcafe /* Whatever                     */
+
+/*-----------------------------------------------------------------------
+ * Base addresses -- Note these are effective addresses where the
+ * actual resources get mapped (not physical addresses)
+ *----------------------------------------------------------------------*/
+#define CFG_PCI_MEMBASE                0x80000000      /* mapped PCI memory    
*/
+#define CFG_PCI_BASE           0xd0000000      /* internal PCI regs    */
+#define CFG_PCI_TARGBASE       CFG_PCI_MEMBASE
+
+#define CFG_PCIE_MEMBASE       0xb0000000      /* mapped PCIe memory   */
+#define CFG_PCIE_MEMSIZE       0x08000000      /* smallest inc for PCIe port */
+#define CFG_PCIE_BASE          0xc4000000      /* PCIe UTL regs */
+
+#define CFG_PCIE0_CFGBASE      0xc0000000
+#define CFG_PCIE1_CFGBASE      0xc1000000
+#define CFG_PCIE0_XCFGBASE     0xc3000000
+#define CFG_PCIE1_XCFGBASE     0xc3001000
+
+#define        CFG_PCIE0_UTLBASE       0xc08010000ULL  /* 36bit physical addr  
*/
+
+/* base address of inbound PCIe window */
+#define CFG_PCIE_INBOUND_BASE  0x000000000ULL  /* 36bit physical addr  */
+
+/*-----------------------------------------------------------------------
+ * External Bus Controller (EBC) Setup
+ *----------------------------------------------------------------------*/
+
+/*
+ * Arches has 32MBytes of NOR FLASH (Spansion 29GL256), but the
+ * boot EBC mapping only supports a maximum of 16MBytes
+ * (4.ff00.0000 - 4.ffff.ffff).
+ * To solve this problem, the FLASH has to get remapped to another
+ * EBC address which accepts bigger regions:
+ *
+ * 0xfe00.0000 -> 4.ce00.0000
+ */
+
+/* Memory Bank 0 (NOR-FLASH) initialization */
+#define CFG_EBC_PB0AP          0x10055e00
+#define CFG_EBC_PB0CR          (CFG_BOOT_BASE_ADDR | 0x9a000)
+
+/* Memory Bank 1 (FPGA) initialization */
+#define CFG_EBC_PB1AP          0x7f8ffe80
+#define CFG_EBC_PB1CR          (CFG_FPGA_BASE | 0x3a000)
+/* BAS=FPGA,BS=2MB,BU=R/W,BW=16bit*/
+
+#define CFG_EBC_CFG            0xB8400000              /*  EBC0_CFG */
+
+/*
+ * PPC4xx GPIO Configuration
+ */
+/* 460GT: Use EMAC2+3 configuration */
+#define CFG_4xx_GPIO_TABLE {                                           \
+/*  Out                  GPIO  Alternate1      Alternate2      Alternate3 */   
\
+       {                                                               \
+       /* GPIO Core 0 */                                               \
+               {GPIO0_BASE, GPIO_OUT, GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO0        GMC1TxD(0)      USB2HostD(0)    */      \
+               {GPIO0_BASE, GPIO_OUT, GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO1        GMC1TxD(1)      USB2HostD(1)    */      \
+               {GPIO0_BASE, GPIO_OUT, GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO2        GMC1TxD(2)      USB2HostD(2)    */      \
+               {GPIO0_BASE, GPIO_OUT, GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO3        GMC1TxD(3)      USB2HostD(3)    */      \
+               {GPIO0_BASE, GPIO_OUT, GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO4        GMC1TxD(4)      USB2HostD(4)    */      \
+               {GPIO0_BASE, GPIO_OUT, GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO5        GMC1TxD(5)      USB2HostD(5)    */      \
+               {GPIO0_BASE, GPIO_OUT, GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO6        GMC1TxD(6)      USB2HostD(6)    */      \
+               {GPIO0_BASE, GPIO_OUT, GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO7        GMC1TxD(7)      USB2HostD(7)    */      \
+               {GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO8        GMC1RxD(0)      USB2OTGD(0)     */      \
+               {GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO9        GMC1RxD(1)      USB2OTGD(1)     */      \
+               {GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO10 GMC1RxD(2)    USB2OTGD(2)     */              \
+               {GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO11 GMC1RxD(3)    USB2OTGD(3)     */              \
+               {GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO12 GMC1RxD(4)    USB2OTGD(4)     */              \
+               {GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO13 GMC1RxD(5)    USB2OTGD(5)     */              \
+               {GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO14 GMC1RxD(6)    USB2OTGD(6)     */              \
+               {GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO15 GMC1RxD(7)    USB2OTGD(7)     */              \
+               {GPIO0_BASE, GPIO_OUT, GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO16 GMC1TxER      USB2HostStop    */              \
+               {GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO17 GMC1CD                USB2HostNext    */      \
+               {GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO18 GMC1RxER      USB2HostDir     */              \
+               {GPIO0_BASE, GPIO_OUT, GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO19 GMC1TxEN      USB2OTGStop     */              \
+               {GPIO0_BASE, GPIO_BI , GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO20 GMC1CRS       USB2OTGNext     */              \
+               {GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO21 GMC1RxDV      USB2OTGDir      */              \
+               {GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO22 NFRDY                         */              \
+               {GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO23 NFREN                         */              \
+               {GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO24 NFWEN                         */              \
+               {GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO25 NFCLE                         */              \
+               {GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO26 NFALE                         */              \
+               {GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO27 IRQ(0)                                */      \
+               {GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO28 IRQ(1)                                */      \
+               {GPIO0_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO29 IRQ(2)                                */      \
+               {GPIO0_BASE, GPIO_OUT, GPIO_SEL , GPIO_OUT_1},          \
+               /* GPIO30 PerPar0       DMAReq2         IRQ(7) */       \
+               {GPIO0_BASE, GPIO_OUT, GPIO_SEL , GPIO_OUT_1},          \
+               /* GPIO31 PerPar1       DMAAck2         IRQ(8) */       \
+       },                                                              \
+       {                                                               \
+       /* GPIO Core 1 */                                               \
+               {GPIO1_BASE, GPIO_OUT, GPIO_SEL , GPIO_OUT_1},          \
+               /* GPIO32 PerPar2       EOT2/TC2        IRQ(9) */       \
+               {GPIO1_BASE, GPIO_OUT, GPIO_SEL , GPIO_OUT_1},          \
+               /* GPIO33 PerPar3       DMAReq3         IRQ(4) */       \
+               {GPIO1_BASE, GPIO_OUT, GPIO_ALT3, GPIO_OUT_1},          \
+               /* GPIO34 UART0_DCD_N   UART1_DSR_CTS_N UART2_SOUT */   \
+               {GPIO1_BASE, GPIO_IN , GPIO_ALT3, GPIO_OUT_0},          \
+               /* GPIO35 UART0_8PIN_DSR_N UART1_RTS_DTR_N UART2_SIN */ \
+               {GPIO1_BASE, GPIO_IN , GPIO_ALT3, GPIO_OUT_0},          \
+               /* GPIO36 UART0_8PIN_CTS_N DMAAck3      UART3_SIN */    \
+               {GPIO1_BASE, GPIO_BI , GPIO_ALT2, GPIO_OUT_0},          \
+               /* GPIO37 UART0_RTS_N   EOT3/TC3        UART3_SOUT */   \
+               {GPIO1_BASE, GPIO_OUT, GPIO_ALT2, GPIO_OUT_1},          \
+               /* GPIO38 UART0_DTR_N   UART1_SOUT      */              \
+               {GPIO1_BASE, GPIO_IN , GPIO_ALT2, GPIO_OUT_0},          \
+               /* GPIO39 UART0_RI_N    UART1_SIN       */              \
+               {GPIO1_BASE, GPIO_IN , GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO40 IRQ(3)                                */      \
+               {GPIO1_BASE, GPIO_OUT, GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO41 CS(1)                         */              \
+               {GPIO1_BASE, GPIO_OUT, GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO42 CS(2)                         */              \
+               {GPIO1_BASE, GPIO_OUT, GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO43 CS(3)         DMAReq1         IRQ(10) */      \
+               {GPIO1_BASE, GPIO_IN , GPIO_ALT3, GPIO_OUT_0},          \
+               /* GPIO44 CS(4)         DMAAck1         IRQ(11) */      \
+               {GPIO1_BASE, GPIO_IN , GPIO_ALT3, GPIO_OUT_0},          \
+               /* GPIO45 CS(5)         EOT/TC1         IRQ(12) */      \
+               {GPIO1_BASE, GPIO_OUT, GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO46 PerAddr(5)    DMAReq0         IRQ(13) */      \
+               {GPIO1_BASE, GPIO_OUT, GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO47 PerAddr(6)    DMAAck0         IRQ(14) */      \
+               {GPIO1_BASE, GPIO_OUT, GPIO_ALT1, GPIO_OUT_0},          \
+               /* GPIO48 PerAddr(7)    EOT/TC0         IRQ(15) */      \
+               {GPIO1_BASE, GPIO_IN , GPIO_SEL , GPIO_OUT_0},          \
+               /* GPIO49  Unselect via TraceSelect Bit */              \
+               {GPIO1_BASE, GPIO_IN , GPIO_SEL , GPIO_OUT_0},          \
+               /* GPIO50  Unselect via TraceSelect Bit */              \
+               {GPIO1_BASE, GPIO_IN , GPIO_SEL , GPIO_OUT_0},          \
+               /* GPIO51  Unselect via TraceSelect Bit */              \
+               {GPIO1_BASE, GPIO_IN , GPIO_SEL , GPIO_OUT_0},          \
+               /* GPIO52  Unselect via TraceSelect Bit */              \
+               {GPIO1_BASE, GPIO_IN , GPIO_SEL , GPIO_OUT_0},          \
+               /* GPIO53  Unselect via TraceSelect Bit */              \
+               {GPIO1_BASE, GPIO_IN , GPIO_SEL , GPIO_OUT_0},          \
+               /* GPIO54  Unselect via TraceSelect Bit */              \
+               {GPIO1_BASE, GPIO_IN , GPIO_SEL , GPIO_OUT_0},          \
+               /* GPIO55  Unselect via TraceSelect Bit */              \
+               {GPIO1_BASE, GPIO_IN , GPIO_SEL , GPIO_OUT_0},          \
+               /* GPIO56  Unselect via TraceSelect Bit */              \
+               {GPIO1_BASE, GPIO_IN , GPIO_SEL , GPIO_OUT_0},          \
+               /* GPIO57  Unselect via TraceSelect Bit */              \
+               {GPIO1_BASE, GPIO_IN , GPIO_SEL , GPIO_OUT_0},          \
+               /* GPIO58  Unselect via TraceSelect Bit */              \
+               {GPIO1_BASE, GPIO_IN , GPIO_SEL , GPIO_OUT_0},          \
+               /* GPIO59  Unselect via TraceSelect Bit */              \
+               {GPIO1_BASE, GPIO_IN , GPIO_SEL , GPIO_OUT_0},          \
+               /* GPIO60  Unselect via TraceSelect Bit */              \
+               {GPIO1_BASE, GPIO_IN , GPIO_SEL , GPIO_OUT_0},          \
+               /* GPIO61  Unselect via TraceSelect Bit */              \
+               {GPIO1_BASE, GPIO_IN , GPIO_SEL , GPIO_OUT_0},          \
+               /* GPIO62  Unselect via TraceSelect Bit */              \
+               {GPIO1_BASE, GPIO_IN , GPIO_SEL , GPIO_OUT_0},          \
+               /* GPIO63  Unselect via TraceSelect Bit */              \
+       }                                                               \
+}
+
+#endif /* __CONFIG_H */
diff --git a/include/ppc440.h b/include/ppc440.h
index be8d3ff..7ffc640 100644
--- a/include/ppc440.h
+++ b/include/ppc440.h
@@ -1349,6 +1349,9 @@
 #define SDR0_ETH_CFG_ZMII_RMII_MODE_10M                0x10
 #define SDR0_ETH_CFG_ZMII_RMII_MODE_100M       0x11
 
+/* Ethernet Status Register */
+#define SDR0_ETH_STS           0x4104
+
 /* Miscealleneaous Function Reg. (SDR0_MFR) */
 #define SDR0_MFR               0x4300
 #define SDR0_MFR_T0TxFL                0x00800000      /* force parity error 
TAHOE0 Tx FIFO bits 0:63 */
-- 
1.5.5

_______________________________________________
U-Boot mailing list
U-Boot@lists.denx.de
http://lists.denx.de/mailman/listinfo/u-boot

Reply via email to