Dear Siarhei Siamashka,

On 20/10/15 08:39, Siarhei Siamashka wrote:
> ODROID-X uses a slightly older revision of the same base board
> as the ODROID-X2. But the CPU module in ODROID-X uses an older
> 1.4GHz revision of Exynos4412 SoC and less RAM (1GiB instead
> of 2GiB).
> 
> The current U-Boot code deadlocks on ODROID-X when probing the RAM
> size via get_ram_size() function. Reducing CONFIG_NR_DRAM_BANKS
> from 8 to 4 can fix this problem. But this constant is used in
> a lot of places in U-Boot, while SDRAM_BANK_SIZE can be easily
> replaced with the code which relies on runtime detection of the
> board type. So we change 4 or 8 banks of 256MiB with just one
> fake bank of 2GiB or 1GiB. The runtime detection check tries to
> read the PRO_ID register in the hope that it might be different
> between Exynos4412 and Exynos4412 Prime and enough to detect
> the difference between X and X2 board variants.
> 
> Signed-off-by: Siarhei Siamashka <siarhei.siamas...@gmail.com>
> ---
> 
> I'm assuming that the X and X2 hardware is nearly identical
> and can be supported with a common code in U-Boot, based on
> the changelog of PCB revisions:
>     http://com.odroid.com/sigong/blog/blog_list.php?bid=132
> 
> This is an RFC patch because I don't have an X2 board and can't
> test if checking the PRO_ID register is good enough. If it does
> not work, then maybe some other method could be tried (probe
> the DRAM controller registers?).
> 
> Also does the number of DRAM banks have any special meaning on
> this platform in U-Boot and Linux (after the proprietary blob
> has already initialized the DRAM controller)?
> 
> If this approach is wrong, then what would be the best way to
> add support for the ODROID-X board?
> 
> Thanks.
> 
>  board/samsung/common/board.c  | 21 +++++++++++++++++----
>  board/samsung/odroid/odroid.c | 14 ++++++++++----
>  include/configs/odroid.h      | 10 ++++++----
>  3 files changed, 33 insertions(+), 12 deletions(-)
> 
> diff --git a/board/samsung/common/board.c b/board/samsung/common/board.c
> index d32c75d..ac3ed4c 100644
> --- a/board/samsung/common/board.c
> +++ b/board/samsung/common/board.c
> @@ -94,14 +94,26 @@ int board_init(void)
>       return exynos_init();
>  }
>  
> +static u32 get_sdram_bank_size(void)
> +{
> +     u32 sdram_bank_size = SDRAM_BANK_SIZE;
> +#ifdef CONFIG_BOARD_TYPES
> +     if (strcmp(CONFIG_SYS_BOARD, "odroid") == 0 &&
> +         strcmp(get_board_type(), "x") == 0)
> +             sdram_bank_size = SDRAM_BANK_SIZE_ODROIDX;
> +#endif
> +     return sdram_bank_size;
> +}
> +
>  int dram_init(void)
>  {
>       unsigned int i;
>       u32 addr;
> +     u32 sdram_bank_size = get_sdram_bank_size();
>  
>       for (i = 0; i < CONFIG_NR_DRAM_BANKS; i++) {
> -             addr = CONFIG_SYS_SDRAM_BASE + (i * SDRAM_BANK_SIZE);
> -             gd->ram_size += get_ram_size((long *)addr, SDRAM_BANK_SIZE);
> +             addr = CONFIG_SYS_SDRAM_BASE + (i * sdram_bank_size);
> +             gd->ram_size += get_ram_size((long *)addr, sdram_bank_size);
>       }
>       return 0;
>  }
> @@ -110,10 +122,11 @@ void dram_init_banksize(void)
>  {
>       unsigned int i;
>       u32 addr, size;
> +     u32 sdram_bank_size = get_sdram_bank_size();
>  
>       for (i = 0; i < CONFIG_NR_DRAM_BANKS; i++) {
> -             addr = CONFIG_SYS_SDRAM_BASE + (i * SDRAM_BANK_SIZE);
> -             size = get_ram_size((long *)addr, SDRAM_BANK_SIZE);
> +             addr = CONFIG_SYS_SDRAM_BASE + (i * sdram_bank_size);
> +             size = get_ram_size((long *)addr, sdram_bank_size);
>  
>               gd->bd->bi_dram[i].start = addr;
>               gd->bd->bi_dram[i].size = size;
> diff --git a/board/samsung/odroid/odroid.c b/board/samsung/odroid/odroid.c
> index 32155f1..e98e3be 100644
> --- a/board/samsung/odroid/odroid.c
> +++ b/board/samsung/odroid/odroid.c
> @@ -30,6 +30,7 @@ DECLARE_GLOBAL_DATA_PTR;
>  enum {
>       ODROID_TYPE_U3,
>       ODROID_TYPE_X2,
> +     ODROID_TYPE_X,
>       ODROID_TYPES,
>  };
>  
> @@ -56,15 +57,20 @@ void set_board_type(void)
>       sdelay(200000);
>  
>       /* Check GPC1 pin2 - LED supplied by XCL205 - X2 only */
> -     if (readl(XCL205_STATE_GPIO_DAT) & (1 << XCL205_STATE_GPIO_PIN))
> -             gd->board_type = ODROID_TYPE_X2;
> -     else
> +     if (readl(XCL205_STATE_GPIO_DAT) & (1 << XCL205_STATE_GPIO_PIN)) {
> +             /* Check the SoC product information ID */
> +             if (readl(EXYNOS4_PRO_ID) == 0xE4412211)

you can use s5p_cpu_id and s5p_cpu_rev.

> +                     gd->board_type = ODROID_TYPE_X;
> +             else
> +                     gd->board_type = ODROID_TYPE_X2;
> +     } else {
>               gd->board_type = ODROID_TYPE_U3;
> +     }
>  }
>  
>  const char *get_board_type(void)
>  {
> -     const char *board_type[] = {"u3", "x2"};
> +     const char *board_type[] = {"u3", "x2", "x"};
>  
>       return board_type[gd->board_type];
>  }
> diff --git a/include/configs/odroid.h b/include/configs/odroid.h
> index 4c85e85..ae1b2b4 100644
> --- a/include/configs/odroid.h
> +++ b/include/configs/odroid.h
> @@ -22,9 +22,10 @@
>  
>  #define CONFIG_MACH_TYPE     4289
>  
> -#define CONFIG_NR_DRAM_BANKS 8
> +#define CONFIG_NR_DRAM_BANKS 1
>  #define CONFIG_SYS_SDRAM_BASE        0x40000000
> -#define SDRAM_BANK_SIZE              (256 << 20)     /* 256 MB */
> +#define SDRAM_BANK_SIZE              ((8 * 256) << 20)       /* 8 * 256 MB */
> +#define SDRAM_BANK_SIZE_ODROIDX      ((4 * 256) << 20)       /* 4 * 256 MB */

Sorry. I don't agree this code.
I think we can split config files to each boards.

>  #define PHYS_SDRAM_1         CONFIG_SYS_SDRAM_BASE
>  /* Reserve the last 1 MiB for the secure firmware */
>  #define CONFIG_SYS_MEM_TOP_HIDE              (1UL << 20UL)
> @@ -75,6 +76,7 @@
>       "uInitrd fat 0 1;" \
>       "exynos4412-odroidu3.dtb fat 0 1;" \
>       "exynos4412-odroidx2.dtb fat 0 1;" \
> +     "exynos4412-odroidx.dtb fat 0 1;" \
>       ""PARTS_BOOT" part 0 1;" \
>       ""PARTS_ROOT" part 0 2\0" \
>  
> @@ -209,8 +211,8 @@
>  #define CONFIG_USB_ETHER_SMSC95XX
>  
>  /*
> - * Supported Odroid boards: X3, U3
> - * TODO: Add Odroid X support
> + * Supported Odroid boards: X, X2, U3
> + * TODO: Add Odroid U2 support
>   */
>  #define CONFIG_MISC_COMMON
>  #define CONFIG_ENV_VARS_UBOOT_RUNTIME_CONFIG
> 

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

Reply via email to