On 24 March 2015 at 21:56, NeilBrown <neil@xxxxxxxxxx> wrote: > From: NeilBrown <neilb@xxxxxxx> > > Every call to sdio_enable_4bit_bus is followed (on success) but a call > to mmc_set_bus_width(). > > To simplify the code, include those calls directly in > sdio_enable_4bit_bus(). > > Tested-by: Tony Lindgren <tony@xxxxxxxxxxx> > Signed-off-by: NeilBrown <neil@xxxxxxxxxx> This one is already applied. Thanks! Kind regards Uffe > --- > drivers/mmc/core/sdio.c | 32 ++++++++++++-------------------- > 1 file changed, 12 insertions(+), 20 deletions(-) > > diff --git a/drivers/mmc/core/sdio.c b/drivers/mmc/core/sdio.c > index ce6cc47206b0..5bc6c7dbbd60 100644 > --- a/drivers/mmc/core/sdio.c > +++ b/drivers/mmc/core/sdio.c > @@ -293,19 +293,22 @@ static int sdio_enable_4bit_bus(struct mmc_card *card) > int err; > > if (card->type == MMC_TYPE_SDIO) > - return sdio_enable_wide(card); > - > - if ((card->host->caps & MMC_CAP_4_BIT_DATA) && > - (card->scr.bus_widths & SD_SCR_BUS_WIDTH_4)) { > + err = sdio_enable_wide(card); > + else if ((card->host->caps & MMC_CAP_4_BIT_DATA) && > + (card->scr.bus_widths & SD_SCR_BUS_WIDTH_4)) { > err = mmc_app_set_bus_width(card, MMC_BUS_WIDTH_4); > if (err) > return err; > + err = sdio_enable_wide(card); > + if (err <= 0) > + mmc_app_set_bus_width(card, MMC_BUS_WIDTH_1); > } else > return 0; > > - err = sdio_enable_wide(card); > - if (err <= 0) > - mmc_app_set_bus_width(card, MMC_BUS_WIDTH_1); > + if (err > 0) { > + mmc_set_bus_width(card->host, MMC_BUS_WIDTH_4); > + err = 0; > + } > > return err; > } > @@ -547,13 +550,8 @@ static int mmc_sdio_init_uhs_card(struct mmc_card *card) > /* > * Switch to wider bus (if supported). > */ > - if (card->host->caps & MMC_CAP_4_BIT_DATA) { > + if (card->host->caps & MMC_CAP_4_BIT_DATA) > err = sdio_enable_4bit_bus(card); > - if (err > 0) { > - mmc_set_bus_width(card->host, MMC_BUS_WIDTH_4); > - err = 0; > - } > - } > > /* Set the driver strength for the card */ > sdio_select_driver_type(card); > @@ -803,9 +801,7 @@ try_again: > * Switch to wider bus (if supported). > */ > err = sdio_enable_4bit_bus(card); > - if (err > 0) > - mmc_set_bus_width(card->host, MMC_BUS_WIDTH_4); > - else if (err) > + if (err) > goto remove; > } > finish: > @@ -983,10 +979,6 @@ static int mmc_sdio_resume(struct mmc_host *host) > } else if (mmc_card_keep_power(host) && mmc_card_wake_sdio_irq(host)) { > /* We may have switched to 1-bit mode during suspend */ > err = sdio_enable_4bit_bus(host->card); > - if (err > 0) { > - mmc_set_bus_width(host, MMC_BUS_WIDTH_4); > - err = 0; > - } > } > > if (!err && host->sdio_irqs) { > > -- To unsubscribe from this list: send the line "unsubscribe linux-mmc" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html