On Mon, Feb 02, 2015 at 03:57:37PM +0100, Ulf Hansson wrote: > On 30 January 2015 at 23:27, NeilBrown <neilb@xxxxxxx> wrote: > > Shortly before this call is > > > > host->ios.power_mode = MMC_POWER_ON; > > mmc_set_ios(host); > > > > and omap_hsmmc_set_ios() contains: > > > > switch (ios->power_mode) { > > .... > > case MMC_POWER_ON: > > do_send_init_stream = 1; > > break; > > > > > > if (do_send_init_stream) > > send_init_stream(host); > > > > Which sends the "init stream" to the card. > > If the card is still being reset at this time, the stream may not > > be effective. > > > > I find that about 10%-20% of the time when I release the reset line > > *after* the sequence is sent, my card fails to initialised. When I > > release *before* the sequence is sent, it never fails. > > Okay, thanks for providing these details. The right thing to do then is to pulse the reset line at the pre-power-up stage. > > I note that other drivers handle the init stream differently. > > atmel-mci just sets a flag in set_ios, and the actually sends the stream in > > atmci_start_request() > > > > dw_mmc, jz4740_mmc, mxcmmc, pxamci do much the same Yes. PXAMCI is one of those dumb "inteligent" controllers that takes some of the protocol handing away from the host software implementation. The result of that is things happen at different times. For PXAMCI, it's not possible to send the initialisation clocks on their own; you have to queue up a command first. > Well, the problem is that there are host drivers that don't consider > MMC_POWER_UP and delays initialization/power_up to MMC_POWER_ON. So we > might fix the issue for some, but breaks it for another. > > I had a discussion around inconsistent host driver behaviours from > ->set_ios() callbacks with Russell, for the first version of this > patchset. Yes, as I've said a few times now, I regard my original design of this stuff (which was to separate MMC_POWER_UP and MMC_POWER_ON) to be a big design mistake, and we should really kill MMC_POWER_UP ASAP, combining both into a /single/ call into the host driver. -- FTTC broadband for 0.8mile line: currently at 10.5Mbps down 400kbps up according to speedtest.net. -- 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