update/fix AcTux3 board

Signed-off-by: Michael Schwingen <michael@schwingen.org>
This commit is contained in:
Michael Schwingen 2011-05-23 00:00:06 +02:00 committed by Albert ARIBAUD
parent af0504858c
commit 8b5ab4c1b6
4 changed files with 115 additions and 94 deletions

View File

@ -36,13 +36,25 @@
#include <malloc.h> #include <malloc.h>
#include <asm/arch/ixp425.h> #include <asm/arch/ixp425.h>
#include <asm/io.h> #include <asm/io.h>
#include <miiphy.h> #include <miiphy.h>
#include "actux3_hw.h" #include "actux3_hw.h"
DECLARE_GLOBAL_DATA_PTR; DECLARE_GLOBAL_DATA_PTR;
int board_early_init_f(void)
{
/* CS1: IPAC-X */
writel(0x94d10013, IXP425_EXP_CS1);
/* CS5: Debug port */
writel(0x9d520003, IXP425_EXP_CS5);
/* CS6: Release/Option register */
writel(0x81860001, IXP425_EXP_CS6);
/* CS7: LEDs */
writel(0x80900003, IXP425_EXP_CS7);
return 0;
}
int board_init(void) int board_init(void)
{ {
gd->bd->bi_arch_number = MACH_TYPE_ACTUX3; gd->bd->bi_arch_number = MACH_TYPE_ACTUX3;
@ -79,17 +91,9 @@ int board_init (void)
*/ */
GPIO_OUTPUT_ENABLE(CONFIG_SYS_GPIO_PCI_CLK); GPIO_OUTPUT_ENABLE(CONFIG_SYS_GPIO_PCI_CLK);
GPIO_OUTPUT_ENABLE(CONFIG_SYS_GPIO_EXTBUS_CLK); GPIO_OUTPUT_ENABLE(CONFIG_SYS_GPIO_EXTBUS_CLK);
*IXP425_GPIO_GPCLKR = 0x011001FF; writel(0x011001FF, IXP425_GPIO_GPCLKR);
/* CS1: IPAC-X */
*IXP425_EXP_CS1 = 0x94d10013;
/* CS5: Debug port */
*IXP425_EXP_CS5 = 0x9d520003;
/* CS6: Release/Option register */
*IXP425_EXP_CS6 = 0x81860001;
/* CS7: LEDs */
*IXP425_EXP_CS7 = 0x80900003;
/* we need a minimum PCI reset pulse width after enabling the clock */
udelay(533); udelay(533);
GPIO_OUTPUT_SET(CONFIG_SYS_GPIO_IORST); GPIO_OUTPUT_SET(CONFIG_SYS_GPIO_IORST);
GPIO_OUTPUT_SET(CONFIG_SYS_GPIO_ETHRST); GPIO_OUTPUT_SET(CONFIG_SYS_GPIO_ETHRST);
@ -123,7 +127,7 @@ int checkboard (void)
} }
putc('\n'); putc('\n');
return (0); return 0;
} }
/************************************************************************* /*************************************************************************
@ -139,10 +143,8 @@ u32 get_board_rev (void)
int dram_init(void) int dram_init(void)
{ {
gd->bd->bi_dram[0].start = PHYS_SDRAM_1; gd->ram_size = get_ram_size(CONFIG_SYS_SDRAM_BASE, 128<<20);
gd->bd->bi_dram[0].size = PHYS_SDRAM_1_SIZE; return 0;
return (0);
} }
void reset_phy(void) void reset_phy(void)

View File

@ -1,4 +0,0 @@
CONFIG_SYS_TEXT_BASE = 0x00e00000
# include NPE ethernet driver
BOARDLIBS = arch/arm/cpu/ixp/npe/libnpe.o

View File

@ -30,34 +30,29 @@ SECTIONS
. = ALIGN (4); . = ALIGN (4);
.text : { .text : {
arch/arm/cpu/ixp/start.o (.text) arch/arm/cpu/ixp/start.o(.text*)
lib/string.o (.text) net/libnet.o(.text*)
lib/vsprintf.o (.text) board/actux3/libactux3.o(.text*)
arch/arm/lib/board.o (.text) arch/arm/cpu/ixp/libixp.o(.text*)
common/dlmalloc.o (.text) drivers/serial/libserial.o(.text*)
arch/arm/cpu/ixp/cpu.o (.text)
. = env_offset; . = env_offset;
common/env_embedded.o(.ppcenv) common/env_embedded.o(.ppcenv)
*(.text*)
* (.text)
} }
. = ALIGN(4); . = ALIGN(4);
.rodata : { .rodata : {
*(SORT_BY_ALIGNMENT(SORT_BY_NAME(.rodata*))) *(SORT_BY_ALIGNMENT(SORT_BY_NAME(.rodata*)))
} }
. = ALIGN(4); . = ALIGN(4);
.data : { .data : {
*(.data) *(.data*)
} }
. = ALIGN(4); . = ALIGN(4);
.got : { .got : {
*(.got) *(.got)
} }
. =.; . =.;
__u_boot_cmd_start =.; __u_boot_cmd_start =.;
.u_boot_cmd : { .u_boot_cmd : {
@ -66,10 +61,27 @@ SECTIONS
__u_boot_cmd_end =.; __u_boot_cmd_end =.;
. = ALIGN (4); . = ALIGN (4);
.rel.dyn : {
__rel_dyn_start = .;
*(.rel*)
__rel_dyn_end = .;
}
.dynsym : {
__dynsym_start = .;
*(.dynsym)
}
.bss __rel_dyn_start (OVERLAY) : {
__bss_start = .; __bss_start = .;
.bss (NOLOAD): { *(.bss*)
*(.bss)
. = ALIGN(4); . = ALIGN(4);
_end = .;
} }
__bss_end__ =.; __bss_end__ =.;
/DISCARD/ : { *(.dynstr*) }
/DISCARD/ : { *(.dynamic*) }
/DISCARD/ : { *(.plt*) }
/DISCARD/ : { *(.interp*) }
/DISCARD/ : { *(.gnu*) }
} }

View File

@ -37,12 +37,12 @@
#define CONFIG_BAUDRATE 115200 #define CONFIG_BAUDRATE 115200
#define CONFIG_BOOTDELAY 3 #define CONFIG_BOOTDELAY 3
#define CONFIG_ZERO_BOOTDELAY_CHECK /* check for keypress on bootdelay==0 */ #define CONFIG_ZERO_BOOTDELAY_CHECK /* check for keypress on bootdelay==0 */
#define CONFIG_BOARD_EARLY_INIT_F 1
#define CONFIG_SYS_LDSCRIPT "board/actux3/u-boot.lds"
/*************************************************************** /***************************************************************
* U-boot generic defines start here. * U-boot generic defines start here.
***************************************************************/ ***************************************************************/
#undef CONFIG_USE_IRQ
/* Size of malloc() pool */ /* Size of malloc() pool */
#define CONFIG_SYS_MALLOC_LEN (CONFIG_ENV_SIZE + 128*1024) #define CONFIG_SYS_MALLOC_LEN (CONFIG_ENV_SIZE + 128*1024)
@ -82,8 +82,9 @@
#define CONFIG_SYS_MEMTEST_START 0x00400000 #define CONFIG_SYS_MEMTEST_START 0x00400000
#define CONFIG_SYS_MEMTEST_END 0x00800000 #define CONFIG_SYS_MEMTEST_END 0x00800000
/* spec says 66.666 MHz, but it appears to be 33 */ /* timer clock - 2* OSC_IN system clock */
#define CONFIG_SYS_HZ 3333333 #define CONFIG_IXP425_TIMER_CLK 66666666
#define CONFIG_SYS_HZ 1000
/* default load address */ /* default load address */
#define CONFIG_SYS_LOAD_ADDR 0x00010000 #define CONFIG_SYS_LOAD_ADDR 0x00010000
@ -99,10 +100,6 @@
* The stack sizes are set up in start.S using the settings below * The stack sizes are set up in start.S using the settings below
*/ */
#define CONFIG_STACKSIZE (128*1024) /* regular stack */ #define CONFIG_STACKSIZE (128*1024) /* regular stack */
#ifdef CONFIG_USE_IRQ
# define CONFIG_STACKSIZE_IRQ (4*1024) /* IRQ stack */
# define CONFIG_STACKSIZE_FIQ (4*1024) /* FIQ stack */
#endif
/* Expansion bus settings */ /* Expansion bus settings */
#define CONFIG_SYS_EXP_CS0 0xbd113442 #define CONFIG_SYS_EXP_CS0 0xbd113442
@ -110,7 +107,7 @@
/* SDRAM settings */ /* SDRAM settings */
#define CONFIG_NR_DRAM_BANKS 1 #define CONFIG_NR_DRAM_BANKS 1
#define PHYS_SDRAM_1 0x00000000 #define PHYS_SDRAM_1 0x00000000
#define CONFIG_SYS_DRAM_BASE 0x00000000 #define CONFIG_SYS_SDRAM_BASE 0x00000000
/* 16MB SDRAM */ /* 16MB SDRAM */
#define CONFIG_SYS_SDR_CONFIG 0x3A #define CONFIG_SYS_SDR_CONFIG 0x3A
@ -120,6 +117,7 @@
#define CONFIG_SYS_DRAM_SIZE 0x01000000 #define CONFIG_SYS_DRAM_SIZE 0x01000000
/* FLASH organization */ /* FLASH organization */
#define CONFIG_SYS_TEXT_BASE 0x50000000
#define CONFIG_SYS_MAX_FLASH_BANKS 1 #define CONFIG_SYS_MAX_FLASH_BANKS 1
/* max number of sectors on one chip */ /* max number of sectors on one chip */
#define CONFIG_SYS_MAX_FLASH_SECT 140 #define CONFIG_SYS_MAX_FLASH_SECT 140
@ -129,6 +127,7 @@
#define CONFIG_SYS_FLASH_BASE PHYS_FLASH_1 #define CONFIG_SYS_FLASH_BASE PHYS_FLASH_1
#define CONFIG_SYS_MONITOR_BASE PHYS_FLASH_1 #define CONFIG_SYS_MONITOR_BASE PHYS_FLASH_1
#define CONFIG_SYS_MONITOR_LEN (256 << 10) #define CONFIG_SYS_MONITOR_LEN (256 << 10)
#define CONFIG_BOARD_SIZE_LIMIT 262144
/* Use common CFI driver */ /* Use common CFI driver */
#define CONFIG_SYS_FLASH_CFI #define CONFIG_SYS_FLASH_CFI
@ -149,6 +148,11 @@
#define CONFIG_PHY_ADDR 0x10 #define CONFIG_PHY_ADDR 0x10
/* MII PHY management */ /* MII PHY management */
#define CONFIG_MII 1 #define CONFIG_MII 1
/* fixed-speed switch without standard PHY registers on MII */
#define CONFIG_MII_NPE0_FIXEDLINK 1
#define CONFIG_MII_NPE0_SPEED 100
#define CONFIG_MII_NPE0_FULLDUPLEX 1
/* Number of ethernet rx buffers & descriptors */ /* Number of ethernet rx buffers & descriptors */
#define CONFIG_SYS_RX_ETH_BUFFER 16 #define CONFIG_SYS_RX_ETH_BUFFER 16
#define CONFIG_RESET_PHY_R 1 #define CONFIG_RESET_PHY_R 1
@ -183,13 +187,15 @@
"npe_ucode=50040000\0" \ "npe_ucode=50040000\0" \
"mtd=IXP4XX-Flash.0:256k(uboot),64k(ucode),1152k(linux),-(root)\0" \ "mtd=IXP4XX-Flash.0:256k(uboot),64k(ucode),1152k(linux),-(root)\0" \
"kerneladdr=50050000\0" \ "kerneladdr=50050000\0" \
"kernelfile=actux3/uImage\0" \
"rootfile=actux3/rootfs\0" \
"rootaddr=50170000\0" \ "rootaddr=50170000\0" \
"loadaddr=10000\0" \ "loadaddr=10000\0" \
"updateboot_ser=mw.b 10000 ff 40000;" \ "updateboot_ser=mw.b 10000 ff 40000;" \
" loady ${loadaddr};" \ " loady ${loadaddr};" \
" run eraseboot writeboot\0" \ " run eraseboot writeboot\0" \
"updateboot_net=mw.b 10000 ff 40000;" \ "updateboot_net=mw.b 10000 ff 40000;" \
" tftp ${loadaddr} u-boot.bin;" \ " tftp ${loadaddr} actux3/u-boot.bin;" \
" run eraseboot writeboot\0" \ " run eraseboot writeboot\0" \
"eraseboot=protect off 50000000 50003fff;" \ "eraseboot=protect off 50000000 50003fff;" \
" protect off 50006000 5003ffff;" \ " protect off 50006000 5003ffff;" \
@ -197,8 +203,9 @@
" erase 50006000 5003ffff\0" \ " erase 50006000 5003ffff\0" \
"writeboot=cp.b 10000 50000000 4000;" \ "writeboot=cp.b 10000 50000000 4000;" \
" cp.b 16000 50006000 3a000\0" \ " cp.b 16000 50006000 3a000\0" \
"eraseenv=protect off 50004000 50005fff;" \ "updateucode=loady;" \
" erase 50004000 50005fff\0" \ " era ${npe_ucode} +${filesize};" \
" cp.b ${loadaddr} ${npe_ucode} ${filesize}\0" \
"updateroot=tftp ${loadaddr} ${rootfile};" \ "updateroot=tftp ${loadaddr} ${rootfile};" \
" era ${rootaddr} +${filesize};" \ " era ${rootaddr} +${filesize};" \
" cp.b ${loadaddr} ${rootaddr} ${filesize}\0" \ " cp.b ${loadaddr} ${rootaddr} ${filesize}\0" \
@ -209,7 +216,7 @@
" rootfstype=squashfs,jffs2 init=/etc/preinit\0" \ " rootfstype=squashfs,jffs2 init=/etc/preinit\0" \
"netargs=setenv bootargs mtdparts=${mtd} root=/dev/mtdblock3" \ "netargs=setenv bootargs mtdparts=${mtd} root=/dev/mtdblock3" \
" rootfstype=squashfs,jffs2 init=/etc/preinit\0" \ " rootfstype=squashfs,jffs2 init=/etc/preinit\0" \
"addtty=setenv bootargs ${bootargs} console=ttyS0,${baudrate}\0" \ "addtty=setenv bootargs ${bootargs} console=ttyS1,${baudrate}\0" \
"addeth=setenv bootargs ${bootargs} ethaddr=${ethaddr}\0" \ "addeth=setenv bootargs ${bootargs} ethaddr=${ethaddr}\0" \
"boot_flash=run flashargs addtty addeth;" \ "boot_flash=run flashargs addtty addeth;" \
" bootm ${kerneladdr}\0" \ " bootm ${kerneladdr}\0" \
@ -217,4 +224,8 @@
" tftpboot ${loadaddr} ${kernelfile};" \ " tftpboot ${loadaddr} ${kernelfile};" \
" bootm\0" " bootm\0"
/* additions for new relocation code, must be added to all boards */
#define CONFIG_SYS_INIT_SP_ADDR \
(CONFIG_SYS_SDRAM_BASE + 0x1000 - GENERATED_GBL_DATA_SIZE)
#endif /* __CONFIG_H */ #endif /* __CONFIG_H */