Hi On 23.01.2020 08:33, Minkyu Kang wrote: > On 23/01/2020 16:20, Marek Szyprowski wrote: >> On 23.01.2020 08:09, Minkyu Kang wrote: >>> On 17/01/2020 22:02, Marek Szyprowski wrote: >>>> XOM pins provide information for iROM bootloader about the boot device. >>>> Those pins are mapped to lower bits of OP_MODE register (0x10000008), >>>> which is common for all Exynos SoC variants. Set the default MMC device id >>>> to reflect the boot device selected by XOM[7:5] pins (2 for the SD or 0 for >>>> the eMMC). >>>> >>>> Signed-off-by: Marek Szyprowski <m.szyprow...@samsung.com> >>>> --- >>>> v2: >>>> - store mmc boot device to ${mmcbootdev} env >>>> - print information about boot mmc device >>>> --- >>>> arch/arm/mach-exynos/include/mach/cpu.h | 1 + >>>> board/samsung/common/board.c | 28 +++++++++++++++++++++++++ >>>> configs/odroid-xu3_defconfig | 1 + >>>> configs/odroid_defconfig | 1 + >>>> 4 files changed, 31 insertions(+) >>>> >>>> diff --git a/arch/arm/mach-exynos/include/mach/cpu.h >>>> b/arch/arm/mach-exynos/include/mach/cpu.h >>>> index 766edeeb29..fb5fdaf3ba 100644 >>>> --- a/arch/arm/mach-exynos/include/mach/cpu.h >>>> +++ b/arch/arm/mach-exynos/include/mach/cpu.h >>>> @@ -17,6 +17,7 @@ >>>> >>>> #define EXYNOS4_GPIO_PART3_BASE 0x03860000 >>>> #define EXYNOS4_PRO_ID 0x10000000 >>>> +#define EXYNOS4_OP_MODE 0x10000008 >>>> #define EXYNOS4_SYSREG_BASE 0x10010000 >>>> #define EXYNOS4_POWER_BASE 0x10020000 >>>> #define EXYNOS4_SWRESET 0x10020400 >>>> diff --git a/board/samsung/common/board.c b/board/samsung/common/board.c >>>> index ee2fc7971e..cb94ced54e 100644 >>>> --- a/board/samsung/common/board.c >>>> +++ b/board/samsung/common/board.c >>>> @@ -24,6 +24,8 @@ >>>> #include <asm/arch/sromc.h> >>>> #include <lcd.h> >>>> #include <i2c.h> >>>> +#include <mmc.h> >>>> +#include <stdio_dev.h> >>>> #include <usb.h> >>>> #include <dwc3-uboot.h> >>>> #include <samsung/misc.h> >>>> @@ -42,6 +44,20 @@ __weak int exynos_power_init(void) >>>> return 0; >>>> } >>>> >>>> +/** >>>> + * get_boot_mmc_dev() - read boot MMC device id from XOM[7:5] pins. >>>> + */ >>>> +static int get_boot_mmc_dev(void) >>>> +{ >>>> + u32 mode = readl(EXYNOS4_OP_MODE) & 0x1C; >>>> + >>>> + if (mode == 0x04) >>>> + return 2; /* MMC2: SD */ >>>> + >>>> + /* MMC0: eMMC or unknown */ >>>> + return 0; >>>> +} >>>> + >>>> #if defined CONFIG_EXYNOS_TMU >>>> /* Boot Time Thermal Analysis for SoC temperature threshold breach */ >>>> static void boot_temp_check(void) >>>> @@ -280,6 +296,8 @@ int board_late_init(void) >>>> { >>>> struct udevice *dev; >>>> int ret; >>>> + int mmcbootdev = get_boot_mmc_dev(); >>>> + char mmcbootdev_str[16]; >>>> >>>> stdio_print_current_devices(); >>>> ret = uclass_first_device_err(UCLASS_CROS_EC, &dev); >>>> @@ -292,6 +310,11 @@ int board_late_init(void) >>>> panic("Cannot init cros-ec device"); >>>> return -1; >>>> } >>>> + >>>> + printf("Boot device: MMC(%u)\n", mmcbootdev); >>>> + sprintf(mmcbootdev_str, "%u", mmcbootdev); >>>> + env_set("mmcbootdev", mmcbootdev_str); >>>> + >>>> return 0; >>>> } >>>> #endif >>>> @@ -359,3 +382,8 @@ int board_usb_cleanup(int index, enum usb_init_type >>>> init) >>>> #endif >>>> return 0; >>>> } >>>> + >>>> +int mmc_get_env_dev(void) >>>> +{ >>>> + return get_boot_mmc_dev(); >>>> +} >>>> diff --git a/configs/odroid-xu3_defconfig b/configs/odroid-xu3_defconfig >>>> index 20038d4197..2e982e1b53 100644 >>>> --- a/configs/odroid-xu3_defconfig >>>> +++ b/configs/odroid-xu3_defconfig >>>> @@ -14,6 +14,7 @@ CONFIG_FIT_BEST_MATCH=y >>>> CONFIG_SILENT_CONSOLE=y >>>> CONFIG_CONSOLE_MUX=y >>>> CONFIG_MISC_INIT_R=y >>>> +CONFIG_BOARD_LATE_INIT=y >>> Is it a related change? >> Yes, it is needed to enable the code added to board_late_init() function. > I mean, is your changes should located to board_late_init?
Setting mmcbootdev env is being done in board_late_init() (see the diff a few lines above), so to make it working, one has to enable CONFIG_BOARD_LATE_INIT. >>>> # CONFIG_DISPLAY_BOARDINFO is not set >>>> CONFIG_DISPLAY_BOARDINFO_LATE=y >>>> CONFIG_BOARD_TYPES=y >>>> diff --git a/configs/odroid_defconfig b/configs/odroid_defconfig >>>> index be914e4caf..e4392e477e 100644 >>>> --- a/configs/odroid_defconfig >>>> +++ b/configs/odroid_defconfig >>>> @@ -17,6 +17,7 @@ CONFIG_BOOTARGS="Please use defined boot" >>>> CONFIG_SYS_CONSOLE_IS_IN_ENV=y >>>> CONFIG_SYS_CONSOLE_INFO_QUIET=y >>>> CONFIG_MISC_INIT_R=y >>>> +CONFIG_BOARD_LATE_INIT=y >>>> CONFIG_BOARD_TYPES=y >>>> CONFIG_SYS_PROMPT="Odroid # " >>>> # CONFIG_CMD_XIMG is not set >>>> Best regards -- Marek Szyprowski, PhD Samsung R&D Institute Poland