public inbox for u-boot@lists.denx.de
 help / color / mirror / Atom feed
From: Nikolay Dimitrov <picmaster@mail.bg>
To: u-boot@lists.denx.de
Subject: [U-Boot] [PATCH 3/3] mx6boards: Fix error handling in board_mmc_init()
Date: Mon, 22 Dec 2014 18:32:58 +0200	[thread overview]
Message-ID: <549847BA.50707@mail.bg> (raw)
In-Reply-To: <1416595378-22255-3-git-send-email-festevam@gmail.com>

Hi Fabio,

On 11/21/2014 08:42 PM, Fabio Estevam wrote:
> From: Fabio Estevam <fabio.estevam@freescale.com>
>
> When an invalid USDHC port is passed we should return -EINVAL instead of 0.
>
> Also, return the error immediately on fsl_esdhc_initialize() failure.
>
> Cc: Eric Benard <eric@eukrea.com>
> Signed-off-by: Fabio Estevam <fabio.estevam@freescale.com>
> ---
>   board/embest/mx6boards/mx6boards.c | 10 ++++++----
>   1 file changed, 6 insertions(+), 4 deletions(-)
>
> diff --git a/board/embest/mx6boards/mx6boards.c b/board/embest/mx6boards/mx6boards.c
> index 02fb3fa..f8c7468 100644
> --- a/board/embest/mx6boards/mx6boards.c
> +++ b/board/embest/mx6boards/mx6boards.c
> @@ -216,7 +216,7 @@ int board_mmc_getcd(struct mmc *mmc)
>
>   int board_mmc_init(bd_t *bis)
>   {
> -	s32 status = 0;
> +	int ret;
>   	int i;
>
>   	/*
> @@ -268,13 +268,15 @@ int board_mmc_init(bd_t *bis)
>   			printf("Warning: you configured more USDHC controllers"
>   			       "(%d) then supported by the board (%d)\n",
>   			       i + 1, CONFIG_SYS_FSL_USDHC_NUM);
> -			return status;
> +			return -EINVAL;
>   		}
>
> -		status |= fsl_esdhc_initialize(bis, &usdhc_cfg[i]);
> +		ret = fsl_esdhc_initialize(bis, &usdhc_cfg[i]);
> +		if (ret)
> +			return ret;
>   	}
>
> -	return status;
> +	return 0;
>   }
>   #endif

Excuse me for the (very) late question, but just stumbled upon this
patch.

Isn't it possible to continue the initialization of the next ESDHC
module when the current one fails?

Even if there's a case of common initialization failure across all
ESDHC interfaces, isn't it better to continue the initialization and
preserve the interface abstraction, as if we don't know the
implementation details, e.g. pretend we don't know there's a common
failure mechanism across all ESDHCs and still try to init them 1 by 1.

Please don't consider this as NACK, I'm just sharing my thoughts.

Kind regards,
Nikolay

  parent reply	other threads:[~2014-12-22 16:32 UTC|newest]

Thread overview: 9+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2014-11-21 18:42 [U-Boot] [PATCH 1/3] ot1200: Fix error handling in board_mmc_init() Fabio Estevam
2014-11-21 18:42 ` [U-Boot] [PATCH 2/3] nitrogen6x: " Fabio Estevam
2014-11-24 11:06   ` Stefano Babic
2014-11-21 18:42 ` [U-Boot] [PATCH 3/3] mx6boards: " Fabio Estevam
2014-11-24 11:06   ` Stefano Babic
2014-12-22 16:32   ` Nikolay Dimitrov [this message]
2014-12-22 16:38     ` Fabio Estevam
2014-11-24 11:05 ` [U-Boot] [PATCH 1/3] ot1200: " Stefano Babic
2014-11-24 11:07   ` Christian Gmeiner

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=549847BA.50707@mail.bg \
    --to=picmaster@mail.bg \
    --cc=u-boot@lists.denx.de \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox