From: Jeffy Chen Date: Thu, 14 Jan 2016 02:19:36 +0000 (+0800) Subject: ARM: bootm: Try to use relocated ramdisk X-Git-Tag: v2016.03-rc1~240 X-Git-Url: https://git.sur5r.net/?a=commitdiff_plain;h=f7ee071a22df69e919c9829bbd800cb5e9c1703c;p=u-boot ARM: bootm: Try to use relocated ramdisk After boot_ramdisk_high(), ramdisk would be relocated to initrd_start & initrd_end, so use them instead of rd_start & rd_end. Signed-off-by: Jeffy Chen Acked-by: Simon Glass Reviewed-by: Tom Rini --- diff --git a/arch/arm/lib/bootm.c b/arch/arm/lib/bootm.c index a477cae010..0838d89907 100644 --- a/arch/arm/lib/bootm.c +++ b/arch/arm/lib/bootm.c @@ -225,7 +225,17 @@ static void boot_prep_linux(bootm_headers_t *images) if (BOOTM_ENABLE_MEMORY_TAGS) setup_memory_tags(gd->bd); if (BOOTM_ENABLE_INITRD_TAG) { - if (images->rd_start && images->rd_end) { + /* + * In boot_ramdisk_high(), it may relocate ramdisk to + * a specified location. And set images->initrd_start & + * images->initrd_end to relocated ramdisk's start/end + * addresses. So use them instead of images->rd_start & + * images->rd_end when possible. + */ + if (images->initrd_start && images->initrd_end) { + setup_initrd_tag(gd->bd, images->initrd_start, + images->initrd_end); + } else if (images->rd_start && images->rd_end) { setup_initrd_tag(gd->bd, images->rd_start, images->rd_end); }