[PATCH 4/4] arm/imx: fix imx6q mmc error when mounting rootfs

Jason Liu liu.h.jason at gmail.com
Thu Nov 10 10:07:12 EST 2011


2011/11/10 Shawn Guo <shawn.guo at linaro.org>:
> The following error is seen in some case when mounting rootfs from
> SD/MMC cards.
>
>  Waiting for root device /dev/mmcblk0p1...
>  mmc1: host does not support reading read-only switch. assuming write-enable.
>  mmc1: new high speed SDHC card at address b368
>  mmcblk0: mmc1:b368 SDC   3.74 GiB
>   mmcblk0: p1
>  mmc1: Timeout waiting for hardware interrupt.
>  mmcblk0: error -110 transferring data, sector 3678224, nr 40, cmd response 0x900, card status 0xc00
>  end_request: I/O error, dev mmcblk0, sector 3678225
>  Buffer I/O error on device mmcblk0p1, logical block 458754
>  lost page write due to I/O error on mmcblk0p1
>
> This patch fixes the problem by lowering the usdhc clock and correcting
> watermark configuration.
>
> Signed-off-by: Shawn Guo <shawn.guo at linaro.org>
> Cc: Chris Ball <cjb at laptop.org>
> Cc: Sascha Hauer <s.hauer at pengutronix.de>
> ---
>  arch/arm/mach-imx/clock-imx6q.c    |   17 ++++++++++++++++-
>  drivers/mmc/host/sdhci-esdhc-imx.c |    8 ++++++++
>  2 files changed, 24 insertions(+), 1 deletions(-)
>
> diff --git a/arch/arm/mach-imx/clock-imx6q.c b/arch/arm/mach-imx/clock-imx6q.c
> index e0b926d..613a1b9 100644
> --- a/arch/arm/mach-imx/clock-imx6q.c
> +++ b/arch/arm/mach-imx/clock-imx6q.c
> @@ -1139,7 +1139,7 @@ static int _clk_set_rate(struct clk *clk, unsigned long rate)
>                return -EINVAL;
>
>        max_div = ((d->bm_pred >> d->bp_pred) + 1) *
> -                 ((d->bm_pred >> d->bp_pred) + 1);
> +                 ((d->bm_podf >> d->bp_podf) + 1);
>
>        div = parent_rate / rate;
>        if (div == 0)
> @@ -2002,6 +2002,21 @@ int __init mx6q_clocks_init(void)
>        clk_set_rate(&asrc_serial_clk, 1500000);
>        clk_set_rate(&enfc_clk, 11000000);
>
> +       /*
> +        * Before pinctrl API is available, we have to rely on the pad
> +        * configuration set up by bootloader.  For usdhc example here,
> +        * u-boot sets up the pads for 49.5 MHz case, and we have to lower
> +        * the usdhc clock from 198 to 49.5 MHz to match the pad configuration.

The comments above is wrong. The pad configuration don't have the relationship
with the clock freq 49.5MHZ. I'm not sure you mean pinctrl API can
resolve the clock
configuration, do you mean common clock API?

> +        *
> +        * FIXME: This is should be removed after pinctrl API is available.
> +        * At that time, usdhc driver can call pinctrl API to change pad
> +        * configuration dynamically per different usdhc clock settings.
> +        */
> +       clk_set_rate(&usdhc1_clk, 49500000);
> +       clk_set_rate(&usdhc2_clk, 49500000);
> +       clk_set_rate(&usdhc3_clk, 49500000);
> +       clk_set_rate(&usdhc4_clk, 49500000);
> +
[]

Jason Liu
> --
> 1.7.4.1
>
>
> _______________________________________________
> linux-arm-kernel mailing list
> linux-arm-kernel at lists.infradead.org
> http://lists.infradead.org/mailman/listinfo/linux-arm-kernel
>



More information about the linux-arm-kernel mailing list