diff mbox

[U-Boot] spl: mmc: Fix raw boot mode (related to commit 4c5bbc2328a24f5e1ee990c9a9527e48e5fb3b5f)

Message ID 1418727644-12897-1-git-send-email-guillaume.gardet@free.fr
State Accepted
Delegated to: Pantelis Antoniou
Headers show

Commit Message

Guillaume GARDET Dec. 16, 2014, 11 a.m. UTC
As reported by Robert Nelson, commit 4c5bbc2328a24f5e1ee990c9a9527e48e5fb3b5f 
may break MMC RAW boot mode.
This patch fixes the check path to fix MMC Raw boot mode.

Tested raw boot mode and FS boot mode on a pandaboard (rev. A3).

Reported-by: Robert Nelson <robertcnelson@gmail.com>
Signed-off-by: Guillaume GARDET <guillaume.gardet@free.fr>

Cc: Tom Rini <trini@ti.com>
Cc: Robert Nelson <robertcnelson@gmail.com>

---
 common/spl/spl_mmc.c | 19 ++++++++++++++++---
 1 file changed, 16 insertions(+), 3 deletions(-)

Comments

Robert Nelson Dec. 16, 2014, 5:16 p.m. UTC | #1
On Tue, Dec 16, 2014 at 5:00 AM, Guillaume GARDET
<guillaume.gardet@free.fr> wrote:
> As reported by Robert Nelson, commit 4c5bbc2328a24f5e1ee990c9a9527e48e5fb3b5f
> may break MMC RAW boot mode.
> This patch fixes the check path to fix MMC Raw boot mode.
>
> Tested raw boot mode and FS boot mode on a pandaboard (rev. A3).
>
> Reported-by: Robert Nelson <robertcnelson@gmail.com>
> Signed-off-by: Guillaume GARDET <guillaume.gardet@free.fr>
>
> Cc: Tom Rini <trini@ti.com>
> Cc: Robert Nelson <robertcnelson@gmail.com>

Thanks Guillaume!

Tested in raw & fs mode on a beaglebone black (microSD & eMMC)

Regards,
Guillaume GARDET Dec. 16, 2014, 5:43 p.m. UTC | #2
Le 16/12/2014 18:16, Robert Nelson a écrit :
> On Tue, Dec 16, 2014 at 5:00 AM, Guillaume GARDET
> <guillaume.gardet@free.fr> wrote:
>> As reported by Robert Nelson, commit 4c5bbc2328a24f5e1ee990c9a9527e48e5fb3b5f
>> may break MMC RAW boot mode.
>> This patch fixes the check path to fix MMC Raw boot mode.
>>
>> Tested raw boot mode and FS boot mode on a pandaboard (rev. A3).
>>
>> Reported-by: Robert Nelson <robertcnelson@gmail.com>
>> Signed-off-by: Guillaume GARDET <guillaume.gardet@free.fr>
>>
>> Cc: Tom Rini <trini@ti.com>
>> Cc: Robert Nelson <robertcnelson@gmail.com>
> Thanks Guillaume!
>
> Tested in raw & fs mode on a beaglebone black (microSD & eMMC)

Thanks for testing it. :) You could add your "tested by" tag.


Guillaume
Robert Nelson Dec. 16, 2014, 8:52 p.m. UTC | #3
On Tue, Dec 16, 2014 at 11:43 AM, Guillaume Gardet
<guillaume.gardet@free.fr> wrote:
>
> Le 16/12/2014 18:16, Robert Nelson a écrit :
>
>> On Tue, Dec 16, 2014 at 5:00 AM, Guillaume GARDET
>> <guillaume.gardet@free.fr> wrote:
>>>
>>> As reported by Robert Nelson, commit
>>> 4c5bbc2328a24f5e1ee990c9a9527e48e5fb3b5f
>>> may break MMC RAW boot mode.
>>> This patch fixes the check path to fix MMC Raw boot mode.
>>>
>>> Tested raw boot mode and FS boot mode on a pandaboard (rev. A3).
>>>
>>> Reported-by: Robert Nelson <robertcnelson@gmail.com>
>>> Signed-off-by: Guillaume GARDET <guillaume.gardet@free.fr>

Tested-by: Robert Nelson <robertcnelson@gmail.com>

>>>
>>> Cc: Tom Rini <trini@ti.com>
>>> Cc: Robert Nelson <robertcnelson@gmail.com>
>>
>> Thanks Guillaume!
>>
>> Tested in raw & fs mode on a beaglebone black (microSD & eMMC)
>
>
> Thanks for testing it. :) You could add your "tested by" tag.
>

I always forget. ;)

Regards,
Guillaume GARDET Dec. 27, 2014, 9:53 a.m. UTC | #4
Ping.

This patch is needed for the release. Otherwise, raw boot mode is broken if FAT/SPL support is also enabled.


Guillaume


Le 16/12/2014 12:00, Guillaume GARDET a écrit :
> As reported by Robert Nelson, commit 4c5bbc2328a24f5e1ee990c9a9527e48e5fb3b5f
> may break MMC RAW boot mode.
> This patch fixes the check path to fix MMC Raw boot mode.
>
> Tested raw boot mode and FS boot mode on a pandaboard (rev. A3).
>
> Reported-by: Robert Nelson <robertcnelson@gmail.com>
> Signed-off-by: Guillaume GARDET <guillaume.gardet@free.fr>
>
> Cc: Tom Rini <trini@ti.com>
> Cc: Robert Nelson <robertcnelson@gmail.com>
>
> ---
>   common/spl/spl_mmc.c | 19 ++++++++++++++++---
>   1 file changed, 16 insertions(+), 3 deletions(-)
>
> diff --git a/common/spl/spl_mmc.c b/common/spl/spl_mmc.c
> index 7bae16b..c2e596b 100644
> --- a/common/spl/spl_mmc.c
> +++ b/common/spl/spl_mmc.c
> @@ -172,11 +172,24 @@ void spl_mmc_load_image(void)
>   		err = mmc_load_image_raw_sector(mmc,
>   			CONFIG_SYS_MMCSD_RAW_MODE_U_BOOT_SECTOR);
>   #endif
> -	} else {
> +	}
> +
> +	switch(boot_mode){
> +		case MMCSD_MODE_RAW:
> +#if defined(CONFIG_SPL_FAT_SUPPORT) || defined(CONFIG_SPL_EXT_SUPPORT)
> +		case MMCSD_MODE_FS:
> +#endif
> +#ifdef CONFIG_SUPPORT_EMMC_BOOT
> +		case MMCSD_MODE_EMMCBOOT:
> +#endif
> +			/* Boot mode is ok. Nothing to do. */
> +			break;
> +		case MMCSD_MODE_UNDEFINED:
> +		default:
>   #ifdef CONFIG_SPL_LIBCOMMON_SUPPORT
> -		puts("spl: wrong MMC boot mode\n");
> +			puts("spl: wrong MMC boot mode\n");
>   #endif
> -		hang();
> +			hang();
>   	}
>   
>   	if (err)
Pantelis Antoniou Jan. 5, 2015, 6:49 p.m. UTC | #5
Hi Guillaume,

> On Dec 16, 2014, at 13:00 , Guillaume GARDET <guillaume.gardet@free.fr> wrote:
> 
> As reported by Robert Nelson, commit 4c5bbc2328a24f5e1ee990c9a9527e48e5fb3b5f 
> may break MMC RAW boot mode.
> This patch fixes the check path to fix MMC Raw boot mode.
> 
> Tested raw boot mode and FS boot mode on a pandaboard (rev. A3).
> 
> Reported-by: Robert Nelson <robertcnelson@gmail.com>
> Signed-off-by: Guillaume GARDET <guillaume.gardet@free.fr>
> 
> Cc: Tom Rini <trini@ti.com>
> Cc: Robert Nelson <robertcnelson@gmail.com>
> 
> ---
> common/spl/spl_mmc.c | 19 ++++++++++++++++---
> 1 file changed, 16 insertions(+), 3 deletions(-)
> 
> diff --git a/common/spl/spl_mmc.c b/common/spl/spl_mmc.c
> index 7bae16b..c2e596b 100644
> --- a/common/spl/spl_mmc.c
> +++ b/common/spl/spl_mmc.c
> @@ -172,11 +172,24 @@ void spl_mmc_load_image(void)
> 		err = mmc_load_image_raw_sector(mmc,
> 			CONFIG_SYS_MMCSD_RAW_MODE_U_BOOT_SECTOR);
> #endif
> -	} else {
> +	}
> +
> +	switch(boot_mode){
> +		case MMCSD_MODE_RAW:
> +#if defined(CONFIG_SPL_FAT_SUPPORT) || defined(CONFIG_SPL_EXT_SUPPORT)
> +		case MMCSD_MODE_FS:
> +#endif
> +#ifdef CONFIG_SUPPORT_EMMC_BOOT
> +		case MMCSD_MODE_EMMCBOOT:
> +#endif
> +			/* Boot mode is ok. Nothing to do. */
> +			break;
> +		case MMCSD_MODE_UNDEFINED:
> +		default:
> #ifdef CONFIG_SPL_LIBCOMMON_SUPPORT
> -		puts("spl: wrong MMC boot mode\n");
> +			puts("spl: wrong MMC boot mode\n");
> #endif
> -		hang();
> +			hang();
> 	}
> 
> 	if (err)
> -- 
> 1.8.4.5

Applied, thanks

— Pantelis
diff mbox

Patch

diff --git a/common/spl/spl_mmc.c b/common/spl/spl_mmc.c
index 7bae16b..c2e596b 100644
--- a/common/spl/spl_mmc.c
+++ b/common/spl/spl_mmc.c
@@ -172,11 +172,24 @@  void spl_mmc_load_image(void)
 		err = mmc_load_image_raw_sector(mmc,
 			CONFIG_SYS_MMCSD_RAW_MODE_U_BOOT_SECTOR);
 #endif
-	} else {
+	}
+
+	switch(boot_mode){
+		case MMCSD_MODE_RAW:
+#if defined(CONFIG_SPL_FAT_SUPPORT) || defined(CONFIG_SPL_EXT_SUPPORT)
+		case MMCSD_MODE_FS:
+#endif
+#ifdef CONFIG_SUPPORT_EMMC_BOOT
+		case MMCSD_MODE_EMMCBOOT:
+#endif
+			/* Boot mode is ok. Nothing to do. */
+			break;
+		case MMCSD_MODE_UNDEFINED:
+		default:
 #ifdef CONFIG_SPL_LIBCOMMON_SUPPORT
-		puts("spl: wrong MMC boot mode\n");
+			puts("spl: wrong MMC boot mode\n");
 #endif
-		hang();
+			hang();
 	}
 
 	if (err)