I have pushed this to arm/next. Tom Daniel Gorsulowski wrote: > This patch implements several updates: > -disable CONFIG_ENV_OVERWRITE > -add new hardware style variants and set the arch numbers appropriate > -pass the serial# and hardware revision to the kernel > -removed unused macros from include/configs/meesc.h > -fixed multiline comment style > > Signed-off-by: Daniel Gorsulowski <daniel.gorsulow...@esd.eu> > --- > v2: - don't write the ethernet address to the EMAC module anymore > > v3: - removed function meesc_set_arch_number and moved code to checkboard() > - reworked function get_board_serial() > - removed unused macros from include/configs/meesc.h > > v4: - fixed commit message (to many characters) > - fixed indentation in switch-case statement > - fixed multiline comment style > > v5: - changed error message on invalid hw_type ("FATAL" to "ERROR") > > board/esd/meesc/meesc.c | 65 +++++++++++++++++++++++++++++++++++++++++----- > include/configs/meesc.h | 25 ++++++------------ > 2 files changed, 66 insertions(+), 24 deletions(-) > > diff --git a/board/esd/meesc/meesc.c b/board/esd/meesc/meesc.c > index 636d0ed..efba60d 100644 > --- a/board/esd/meesc/meesc.c > +++ b/board/esd/meesc/meesc.c > @@ -126,8 +126,10 @@ static void meesc_ethercat_hw_init(void) > AT91_SMC_NRDPULSE_(4) | AT91_SMC_NCS_RDPULSE_(9)); > at91_sys_write(AT91_SMC1_CYCLE(0), > AT91_SMC_NWECYCLE_(10) | AT91_SMC_NRDCYCLE_(5)); > - /* Configure behavior at external wait signal, byte-select mode, 16 bit > - data bus width, none data float wait states and TDF optimization */ > + /* > + * Configure behavior at external wait signal, byte-select mode, 16 bit > + * data bus width, none data float wait states and TDF optimization > + */ > at91_sys_write(AT91_SMC1_MODE(0), > AT91_SMC_READMODE | AT91_SMC_EXNWMODE_READY | > AT91_SMC_BAT_SELECT | AT91_SMC_DBW_16 | AT91_SMC_TDF_(0) | > @@ -156,8 +158,32 @@ int board_eth_init(bd_t *bis) > int checkboard(void) > { > char str[32]; > - > - puts("Board: esd CAN-EtherCAT Gateway"); > + u_char hw_type; /* hardware type */ > + > + /* read the "Type" register of the ET1100 controller */ > + hw_type = readb(CONFIG_ET1100_BASE); > + > + switch (hw_type) { > + case 0x11: > + case 0x3F: > + /* ET1100 present, arch number of MEESC-Board */ > + gd->bd->bi_arch_number = MACH_TYPE_MEESC; > + puts("Board: CAN-EtherCAT Gateway"); > + break; > + case 0xFF: > + /* no ET1100 present, arch number of EtherCAN/2-Board */ > + gd->bd->bi_arch_number = MACH_TYPE_ETHERCAN2; > + puts("Board: EtherCAN/2 Gateway"); > + /* switch on LED1D */ > + at91_set_gpio_output(AT91_PIN_PB12, 1); > + break; > + default: > + /* assume, no ET1100 present, arch number of EtherCAN/2-Board */ > + gd->bd->bi_arch_number = MACH_TYPE_ETHERCAN2; > + printf("ERROR! Read invalid hw_type: %02X\n", hw_type); > + puts("Board: EtherCAN/2 Gateway"); > + break; > + } > if (getenv_r("serial#", str, sizeof(str)) > 0) { > puts(", serial# "); > puts(str); > @@ -167,6 +193,32 @@ int checkboard(void) > return 0; > } > > +#ifdef CONFIG_SERIAL_TAG > +void get_board_serial(struct tag_serialnr *serialnr) > +{ > + char *str; > + > + char *serial = getenv("serial#"); > + if (serial) { > + str = strchr(serial, '_'); > + if (str && (strlen(str) >= 4)) { > + serialnr->high = (*(str + 1) << 8) | *(str + 2); > + serialnr->low = simple_strtoul(str + 3, NULL, 16); > + } > + } else { > + serialnr->high = 0; > + serialnr->low = 0; > + } > +} > +#endif > + > +#ifdef CONFIG_REVISION_TAG > +u32 get_board_rev(void) > +{ > + return hw_rev | 0x100; > +} > +#endif > + > int board_init(void) > { > /* Peripheral Clock Enable Register */ > @@ -174,8 +226,8 @@ int board_init(void) > 1 << AT91SAM9263_ID_PIOB | > 1 << AT91SAM9263_ID_PIOCDE); > > - /* arch number of MEESC-Board */ > - gd->bd->bi_arch_number = MACH_TYPE_MEESC; > + /* initialize ET1100 Controller */ > + meesc_ethercat_hw_init(); > > /* adress of boot parameters */ > gd->bd->bi_boot_params = PHYS_SDRAM + 0x100; > @@ -184,7 +236,6 @@ int board_init(void) > #ifdef CONFIG_CMD_NAND > meesc_nand_hw_init(); > #endif > - meesc_ethercat_hw_init(); > #ifdef CONFIG_HAS_DATAFLASH > at91_spi0_hw_init(1 << 0); > #endif > diff --git a/include/configs/meesc.h b/include/configs/meesc.h > index 8253172..b996854 100644 > --- a/include/configs/meesc.h > +++ b/include/configs/meesc.h > @@ -36,13 +36,14 @@ > #define CONFIG_MEESC 1 /* Board is esd MEESC */ > #define CONFIG_ARM926EJS 1 /* This is an ARM926EJS Core */ > #define CONFIG_AT91SAM9263 1 /* It's an AT91SAM9263 SoC */ > -#define CONFIG_ENV_OVERWRITE 1 /* necessary on prototypes */ > #define CONFIG_DISPLAY_BOARDINFO 1 > #define CONFIG_DISPLAY_CPUINFO 1 /* display cpu info and > speed */ > #define CONFIG_PREBOOT /* enable preboot > variable */ > #define CONFIG_CMDLINE_TAG 1 /* enable passing of ATAGs */ > #define CONFIG_SETUP_MEMORY_TAGS 1 > #define CONFIG_INITRD_TAG 1 > +#define CONFIG_SERIAL_TAG 1 > +#define CONFIG_REVISION_TAG 1 > #undef CONFIG_USE_IRQ /* don't need IRQ/FIQ > stuff */ > > #define CONFIG_SKIP_LOWLEVEL_INIT > @@ -138,12 +139,13 @@ > #define CONFIG_SYS_USE_DATAFLASH 1 > #undef CONFIG_SYS_USE_NANDFLASH > > -#ifdef CONFIG_SYS_USE_DATAFLASH > - > /* CAN */ > #define CONFIG_AT91_CAN 1 > > -/* bootstrap + u-boot + env + linux in dataflash on CS0 */ > +/* hw-controller addresses */ > +#define CONFIG_ET1100_BASE 0x70000000 > + > +/* bootstrap + u-boot + env in dataflash on CS0 */ > #define CONFIG_ENV_IS_IN_DATAFLASH 1 > #define CONFIG_SYS_MONITOR_BASE > (CONFIG_SYS_DATAFLASH_LOGIC_ADDR_CS0 + \ > 0x8400) > @@ -151,18 +153,6 @@ > #define CONFIG_ENV_ADDR > (CONFIG_SYS_DATAFLASH_LOGIC_ADDR_CS0 + \ > CONFIG_ENV_OFFSET) > #define CONFIG_ENV_SIZE 0x4200 > -#define CONFIG_BOOTCOMMAND "cp.b C0042000 22000000 210000; bootm" > - > -#else /* CONFIG_SYS_USE_NANDFLASH */ > - > -/* bootstrap + u-boot + env + linux in nandflash */ > -#define CONFIG_ENV_IS_IN_NAND 1 > -#define CONFIG_ENV_OFFSET 0x60000 > -#define CONFIG_ENV_OFFSET_REDUND 0x80000 > -#define CONFIG_ENV_SIZE 0x20000 /* 1 sector = > 128 kB */ > -#define CONFIG_BOOTCOMMAND "nand read 22000000 A0000 200000; bootm" > - > -#endif > > #define CONFIG_BAUDRATE 115200 > #define CONFIG_SYS_BAUDRATE_TABLE {115200 , 19200, 38400, 57600, 9600 } > @@ -178,7 +168,8 @@ > /* > * Size of malloc() pool > */ > -#define CONFIG_SYS_MALLOC_LEN 0x2D000 > +#define CONFIG_SYS_MALLOC_LEN ROUND(3 * CONFIG_ENV_SIZE + \ > + 128*1024, 0x1000) > #define CONFIG_SYS_GBL_DATA_SIZE 128 /* 128 bytes for initial data */ > > #define CONFIG_STACKSIZE (32 * 1024) /* regular stack */
_______________________________________________ U-Boot mailing list U-Boot@lists.denx.de http://lists.denx.de/mailman/listinfo/u-boot