bcee8d6764
At present if CONFIG_SPL_GPIO_SUPPORT is enabled then the GPIO uclass is included in SPL/TPL without any control for boards. Some boards may want to disable this to reduce code size where GPIOs are not needed in SPL or TPL. Add a new Kconfig option to permit this. Default it to 'y' so that existing boards work correctly. Change existing uses of CONFIG_DM_GPIO to CONFIG_IS_ENABLED(DM_GPIO) to preserve the current behaviour. Also update the 74x164 GPIO driver since it cannot build with SPL. This allows us to remove the hacks in config_uncmd_spl.h and Makefile.uncmd_spl (eventually those files should be removed). Signed-off-by: Simon Glass <sjg@chromium.org> Reviewed-by: Bin Meng <bmeng.cn@gmail.com>
75 lines
1.8 KiB
C
75 lines
1.8 KiB
C
/* SPDX-License-Identifier: GPL-2.0+ */
|
|
/*
|
|
* Common part of configuration settings for the AT91 SAMA5 board.
|
|
*
|
|
* Copyright (C) 2015 Atmel Corporation
|
|
* Josh Wu <josh.wu@atmel.com>
|
|
*/
|
|
|
|
#ifndef __AT91_SAMA5_COMMON_H
|
|
#define __AT91_SAMA5_COMMON_H
|
|
|
|
#include <linux/kconfig.h>
|
|
|
|
/* ARM asynchronous clock */
|
|
#define CONFIG_SYS_AT91_SLOW_CLOCK 32768
|
|
#define CONFIG_SYS_AT91_MAIN_CLOCK 12000000 /* from 12 MHz crystal */
|
|
|
|
#ifndef CONFIG_SPL_BUILD
|
|
#define CONFIG_SKIP_LOWLEVEL_INIT
|
|
#endif
|
|
|
|
/* general purpose I/O */
|
|
#if !CONFIG_IS_ENABLED(DM_GPIO)
|
|
#define CONFIG_AT91_GPIO
|
|
#endif
|
|
|
|
/*
|
|
* BOOTP options
|
|
*/
|
|
#define CONFIG_BOOTP_BOOTFILESIZE
|
|
|
|
/*
|
|
* Command line configuration.
|
|
*/
|
|
|
|
#ifdef CONFIG_SD_BOOT
|
|
|
|
#ifdef CONFIG_ENV_IS_IN_MMC
|
|
#define CONFIG_SYS_MMC_ENV_DEV 0
|
|
#endif
|
|
|
|
#define CONFIG_BOOTCOMMAND "if test ! -n ${dtb_name}; then " \
|
|
"setenv dtb_name at91-${board_name}.dtb; " \
|
|
"fi; " \
|
|
"fatload mmc 0:1 0x21000000 ${dtb_name}; " \
|
|
"fatload mmc 0:1 0x22000000 zImage; " \
|
|
"bootz 0x22000000 - 0x21000000"
|
|
|
|
#else
|
|
|
|
#ifdef CONFIG_NAND_BOOT
|
|
/* u-boot env in nand flash */
|
|
#define CONFIG_BOOTCOMMAND "nand read 0x21000000 0x180000 0x80000;" \
|
|
"nand read 0x22000000 0x200000 0x600000;" \
|
|
"bootz 0x22000000 - 0x21000000"
|
|
#elif CONFIG_SPI_BOOT
|
|
/* u-boot env in serial flash, by default is bus 0 and cs 0 */
|
|
#define CONFIG_BOOTCOMMAND "sf probe 0; " \
|
|
"sf read 0x21000000 0x60000 0xc000; " \
|
|
"sf read 0x22000000 0x6c000 0x394000; " \
|
|
"bootz 0x22000000 - 0x21000000"
|
|
#elif CONFIG_QSPI_BOOT
|
|
#define CONFIG_BOOTCOMMAND "sf probe 0; " \
|
|
"sf read 0x21000000 0x180000 0x80000; " \
|
|
"sf read 0x22000000 0x200000 0x600000; " \
|
|
"bootz 0x22000000 - 0x21000000"
|
|
#endif
|
|
|
|
#endif
|
|
|
|
/* Size of malloc() pool */
|
|
#define CONFIG_SYS_MALLOC_LEN (4 * 1024 * 1024)
|
|
|
|
#endif
|