Dear Remy Bohmer,

I saw your request for review and have some (little) comments which may be 
pointed out by Reinhard too.

Am 05.02.2011 um 13:43 schrieb Remy Bohmer:

> Since U-boot v2010.12 the support for the at91sam9261ek board is broken.
> This patch solves this issue. This change has been tested on this board.
> 
> Note: It requires that the 1st stage bootloader (like Atmel at91-bootstrap)
> to load U-boot at a different address compared to previous releases of
> U-boot due to conflicts in the BSS area during relocation.
> (0x23f00000 -> -0x20a00000)
> 
> Signed-off-by: Remy Bohmer <li...@bohmer.net>
> ---
> V3: This patch applied to either mainstream or the u-boot-atmel branch
>     It contains all changes required to make mainstream work again for
>     this board.
> 
>     This patch can be pulled from:
>       git://git.denx.de/u-boot-usb.git -> fix-at91sam9261ek
> 
> board/atmel/at91sam9261ek/Makefile        |    6 +-
> board/atmel/at91sam9261ek/at91sam9261ek.c |    7 +-
> board/atmel/at91sam9261ek/config.mk       |    1 -
> include/configs/at91sam9261ek.h           |  129 ++++++++++++++++------------
> 4 files changed, 81 insertions(+), 62 deletions(-)
> delete mode 100644 board/atmel/at91sam9261ek/config.mk
> 
> diff --git a/board/atmel/at91sam9261ek/Makefile 
> b/board/atmel/at91sam9261ek/Makefile
> index 9d20ba0..3351493 100644
> --- a/board/atmel/at91sam9261ek/Makefile
> +++ b/board/atmel/at91sam9261ek/Makefile

is OK

> diff --git a/board/atmel/at91sam9261ek/at91sam9261ek.c 
> b/board/atmel/at91sam9261ek/at91sam9261ek.c
> index de5cfae..25c181e 100644
> --- a/board/atmel/at91sam9261ek/at91sam9261ek.c
> +++ b/board/atmel/at91sam9261ek/at91sam9261ek.c

is OK

> diff --git a/board/atmel/at91sam9261ek/config.mk 
> b/board/atmel/at91sam9261ek/config.mk
> deleted file mode 100644
> index e554a45..0000000

> diff --git a/include/configs/at91sam9261ek.h b/include/configs/at91sam9261ek.h
> index 401478b..d601dad 100644
> --- a/include/configs/at91sam9261ek.h
> +++ b/include/configs/at91sam9261ek.h
> @@ -29,34 +29,42 @@
> 
> #define CONFIG_AT91_LEGACY

will be removed in Patch 2/2, therefore OK

> +/*
> + * WARNING:
> + * The initial boot program needs to be adapted such that it loads U-boot
> + * at the provided TEXT_BASE below. Note that the Atmel AT91-bootstrap loader
> + * might be configured such that it loads U-boot at 0x23f00000. But since
> + * U-boot is now being relocated to the end of RAM, this will result in a
> + * lockup during boot due to an overlap in the BSS segment. So, we choose a
> + * safe load adress to begin with, namely 0x20a00000
> + */
> +#define CONFIG_SYS_TEXT_BASE         0x20a00000
> +
> /* ARM asynchronous clock */
> -#define CONFIG_SYS_AT91_MAIN_CLOCK   18432000        /* 18.432 MHz crystal */
> -#define CONFIG_SYS_HZ                1000
> +#define CONFIG_SYS_AT91_SLOW_CLOCK   32768           /* slow clock xtal */
> +#define CONFIG_SYS_AT91_MAIN_CLOCK   18432000        /* main clock xtal */
> +#define CONFIG_SYS_HZ                        1000
> 
> #define CONFIG_ARM926EJS      1       /* This is an ARM926EJS Core    */
> +/* Define actual evaluation board type from used processor type */
> #ifdef CONFIG_AT91SAM9G10EK
> #define CONFIG_AT91SAM9G10    1       /* It's an Atmel AT91SAM9G10 SoC*/
> #else
> #define CONFIG_AT91SAM9261    1       /* It's an Atmel AT91SAM9261 SoC*/

do not define to '1' here

> #endif
> +#define CONFIG_AT91FAMILY
> +
> +/* Misc CPU related */
> #define CONFIG_ARCH_CPU_INIT
> #undef CONFIG_USE_IRQ                 /* we don't need IRQ/FIQ stuff  */
> -
> -#define CONFIG_CMDLINE_TAG   1       /* enable passing of ATAGs      */
> -#define CONFIG_SETUP_MEMORY_TAGS 1
> -#define CONFIG_INITRD_TAG    1
> +#define CONFIG_CMDLINE_TAG           /* enable passing of ATAGs */
> +#define CONFIG_SETUP_MEMORY_TAGS
> +#define CONFIG_INITRD_TAG
> 
> #define CONFIG_SKIP_LOWLEVEL_INIT
> 
> -/*
> - * Hardware drivers
> - */
> -#define CONFIG_AT91_GPIO     1
> -#define CONFIG_ATMEL_USART   1
> -#undef CONFIG_USART0
> -#undef CONFIG_USART1
> -#undef CONFIG_USART2
> -#define CONFIG_USART3                1       /* USART 3 is DBGU */
> +/* general purpose I/O */
> +#define CONFIG_AT91_GPIO
> 
> /* LCD */
> #define CONFIG_LCD                    1

no '1' here

> @@ -65,22 +73,31 @@
> #undef LCD_TEST_PATTERN
> #define CONFIG_LCD_INFO                       1

no '1' here ... fix globally, only define to an numerical value if that value 
is used in code, see Reinhard's mail '[STATUS: AT91/AVR32]' point '1.'

> #define CONFIG_LCD_INFO_BELOW_LOGO    1
> -#define CONFIG_SYS_WHITE_ON_BLACK            1
> +#define CONFIG_SYS_WHITE_ON_BLACK    1
> #define CONFIG_ATMEL_LCD              1
> #ifdef CONFIG_AT91SAM9261EK
> #define CONFIG_ATMEL_LCD_BGR555               1
> #else
> -#define      CONFIG_AT91SAM9G10_LCD_BASE             0x23E00000      /* LCD 
> is no more in SRAM */
> +#define      CONFIG_AT91SAM9G10_LCD_BASE     0x23E00000 /* LCD is no more in 
> SRAM */
> #endif
> #define CONFIG_SYS_CONSOLE_IS_IN_ENV          1
> 
> +/* serial console */
> +#define CONFIG_ATMEL_USART
> +#undef CONFIG_USART0
> +#undef CONFIG_USART1
> +#undef CONFIG_USART2
> +#define CONFIG_USART3                1       /* USART 3 is DBGU */

do not undef not defiend values, fix '1'

> +#define CONFIG_BAUDRATE                      115200
> +#define CONFIG_SYS_BAUDRATE_TABLE    {115200 , 19200, 38400, 57600, 9600 }
> +
> /* LED */
> #define CONFIG_AT91_LED
> -#define      CONFIG_RED_LED          AT91_PIN_PA23   /* this is the power 
> led */
> -#define      CONFIG_GREEN_LED        AT91_PIN_PA13   /* this is the user1 
> led */
> -#define      CONFIG_YELLOW_LED       AT91_PIN_PA14   /* this is the user2 
> led */
> +#define      CONFIG_RED_LED                  AT91_PIN_PA23   /* the power 
> led */
> +#define      CONFIG_GREEN_LED                AT91_PIN_PA13   /* the user1 
> led */
> +#define      CONFIG_YELLOW_LED               AT91_PIN_PA14   /* the user2 
> led */
> 
> -#define CONFIG_BOOTDELAY     3
> +#define CONFIG_BOOTDELAY             3
> 
> /*
>  * BOOTP options
> @@ -101,21 +118,28 @@
> #undef CONFIG_CMD_LOADS
> #undef CONFIG_CMD_SOURCE
> 
> -#define CONFIG_CMD_PING              1
> -#define CONFIG_CMD_DHCP              1
> -#define CONFIG_CMD_NAND              1
> -#define CONFIG_CMD_USB               1
> +#define CONFIG_CMD_PING                      1
> +#define CONFIG_CMD_DHCP                      1
> +#define CONFIG_CMD_NAND                      1
> +#define CONFIG_CMD_USB                       1
> +#define CONFIG_CMD_CACHE             1
> 
> -/* SDRAM */
> +/*
> + * SDRAM: 1 bank, 64 MB
> + * Initialized before u-boot gets started.
> + */
> #define CONFIG_NR_DRAM_BANKS          1
> -#define PHYS_SDRAM                   0x20000000
> -#define PHYS_SDRAM_SIZE                      0x04000000      /* 64 megs */
> +#define CONFIG_SYS_SDRAM_BASE                0x20000000
> +#define CONFIG_SYS_SDRAM_SIZE                0x04000000 /* 64 megs */
> 
> +/* size in bytes reserved for initial data */
> +#define CONFIG_SYS_INIT_SP_ADDR              (CONFIG_SYS_SDRAM_BASE + 0x1000 
> \
> +                                     - GENERATED_GBL_DATA_SIZE)
> /* DataFlash */
> #define CONFIG_ATMEL_DATAFLASH_SPI
> #define CONFIG_HAS_DATAFLASH          1
> -#define CONFIG_SYS_SPI_WRITE_TOUT            (5*CONFIG_SYS_HZ)
> -#define CONFIG_SYS_MAX_DATAFLASH_BANKS               2
> +#define CONFIG_SYS_SPI_WRITE_TOUT    (5*CONFIG_SYS_HZ)
> +#define CONFIG_SYS_MAX_DATAFLASH_BANKS       2
> #define CONFIG_SYS_DATAFLASH_LOGIC_ADDR_CS0   0xC0000000      /* CS0 */
> #define CONFIG_SYS_DATAFLASH_LOGIC_ADDR_CS3   0xD0000000      /* CS3 */
> #define AT91_SPI_CLK                  15000000
> @@ -125,20 +149,18 @@
> /* NAND flash */
> #ifdef CONFIG_CMD_NAND
> #define CONFIG_NAND_ATMEL
> -#define CONFIG_SYS_MAX_NAND_DEVICE           1
> -#define CONFIG_SYS_NAND_BASE                 0x40000000
> -#define CONFIG_SYS_NAND_DBW_8                        1
> -/* our ALE is AD22 */
> -#define CONFIG_SYS_NAND_MASK_ALE             (1 << 22)
> -/* our CLE is AD21 */
> -#define CONFIG_SYS_NAND_MASK_CLE             (1 << 21)
> -#define CONFIG_SYS_NAND_ENABLE_PIN           AT91_PIN_PC14
> -#define CONFIG_SYS_NAND_READY_PIN            AT91_PIN_PC15
> +#define CONFIG_SYS_MAX_NAND_DEVICE   1
> +#define CONFIG_SYS_NAND_BASE         0x40000000
> +#define CONFIG_SYS_NAND_DBW_8
> +#define CONFIG_SYS_NAND_MASK_ALE     (1 << 22)
> +#define CONFIG_SYS_NAND_MASK_CLE     (1 << 21)
> +#define CONFIG_SYS_NAND_ENABLE_PIN   AT91_PIN_PC14
> +#define CONFIG_SYS_NAND_READY_PIN    AT91_PIN_PC15
> 
> #endif
> 
> /* NOR flash - no real flash on this board */
> -#define CONFIG_SYS_NO_FLASH                  1
> +#define CONFIG_SYS_NO_FLASH          1
> 
> /* Ethernet */
> #define CONFIG_NET_MULTI              1
> @@ -155,21 +177,21 @@
> #define CONFIG_USB_ATMEL
> #define CONFIG_USB_OHCI_NEW           1
> #define CONFIG_DOS_PARTITION          1
> -#define CONFIG_SYS_USB_OHCI_CPU_INIT         1
> -#define CONFIG_SYS_USB_OHCI_REGS_BASE                0x00500000      /* 
> AT91SAM9261_UHP_BASE */
> +#define CONFIG_SYS_USB_OHCI_CPU_INIT 1
> +#define CONFIG_SYS_USB_OHCI_REGS_BASE        0x00500000      /* 
> AT91SAM9261_UHP_BASE */
> #ifdef CONFIG_AT91SAM9G10EK
> -#define CONFIG_SYS_USB_OHCI_SLOT_NAME                "at91sam9g10"
> +#define CONFIG_SYS_USB_OHCI_SLOT_NAME        "at91sam9g10"
> #else
> -#define CONFIG_SYS_USB_OHCI_SLOT_NAME                "at91sam9261"
> +#define CONFIG_SYS_USB_OHCI_SLOT_NAME        "at91sam9261"
> #endif
> #define CONFIG_SYS_USB_OHCI_MAX_ROOT_PORTS    2
> #define CONFIG_USB_STORAGE            1
> #define CONFIG_CMD_FAT                        1
> 
> -#define CONFIG_SYS_LOAD_ADDR                 0x22000000      /* load address 
> */
> +#define CONFIG_SYS_LOAD_ADDR         0x22000000      /* load address */
> 
> -#define CONFIG_SYS_MEMTEST_START             PHYS_SDRAM
> -#define CONFIG_SYS_MEMTEST_END                       0x23e00000
> +#define CONFIG_SYS_MEMTEST_START     CONFIG_SYS_SDRAM_BASE
> +#define CONFIG_SYS_MEMTEST_END               0x23e00000
> 
> #ifdef CONFIG_SYS_USE_DATAFLASH_CS0
> 
> @@ -177,7 +199,7 @@
> #define CONFIG_ENV_IS_IN_DATAFLASH    1
> #define CONFIG_SYS_MONITOR_BASE       (CONFIG_SYS_DATAFLASH_LOGIC_ADDR_CS0 + 
> 0x8400)
> #define CONFIG_ENV_OFFSET     0x4200
> -#define CONFIG_ENV_ADDR              (CONFIG_SYS_DATAFLASH_LOGIC_ADDR_CS0 + 
> CONFIG_ENV_OFFSET)
> +#define CONFIG_ENV_ADDR      (CONFIG_SYS_DATAFLASH_LOGIC_ADDR_CS0 + 
> CONFIG_ENV_OFFSET)
> #define CONFIG_ENV_SIZE               0x4200
> #define CONFIG_BOOTCOMMAND    "cp.b 0xC0042000 0x22000000 0x210000; bootm"
> #define CONFIG_BOOTARGS               "console=ttyS0,115200 "                 
> \
> @@ -202,10 +224,10 @@
> #else /* CONFIG_SYS_USE_NANDFLASH */
> 
> /* bootstrap + u-boot + env + linux in nandflash */
> -#define CONFIG_ENV_IS_IN_NAND        1
> +#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_ENV_SIZE                      0x20000         /* 1 sector = 
> 128 kB */
> #define CONFIG_BOOTCOMMAND    "nand read 0x22000000 0xA0000 0x200000; bootm"
> #define CONFIG_BOOTARGS               "console=ttyS0,115200 "                 
> \
>                               "root=/dev/mtdblock5 "                  \
> @@ -216,22 +238,19 @@
> 
> #endif
> 
> -#define CONFIG_BAUDRATE              115200
> -#define CONFIG_SYS_BAUDRATE_TABLE    {115200 , 19200, 38400, 57600, 9600 }
> -
> #define CONFIG_SYS_PROMPT             "U-Boot> "
> #define CONFIG_SYS_CBSIZE             256
> #define CONFIG_SYS_MAXARGS            16
> #define CONFIG_SYS_PBSIZE             (CONFIG_SYS_CBSIZE + 
> sizeof(CONFIG_SYS_PROMPT) + 16)
> #define CONFIG_SYS_LONGHELP           1
> -#define CONFIG_CMDLINE_EDITING       1
> +#define CONFIG_CMDLINE_EDITING               1
> 
> /*
>  * Size of malloc() pool
>  */
> #define CONFIG_SYS_MALLOC_LEN         ROUND(3 * CONFIG_ENV_SIZE + 128*1024, 
> 0x1000)
> 
> -#define CONFIG_STACKSIZE     (32*1024)       /* regular stack */
> +#define CONFIG_STACKSIZE             (32*1024) /* regular stack */
> 
> #ifdef CONFIG_USE_IRQ
> #error CONFIG_USE_IRQ not supported

please merge move of at91sam9261 to boards.cfg from Patch 2/2 here, this patch 
could IMHO still go into v2011.03; Patch 2/2 are changes for 
u-boot-atmel/rework2011xxx branch ... Reinhard do you agree?

regards

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

Reply via email to