omap_hsmmc: SDIO IRQ on AM335x family
Daniel Mack
zonque at gmail.com
Sat Dec 1 05:57:35 EST 2012
Hi Tony,
Hi Andreas,
On 30.11.2012 18:40, Tony Lindgren wrote:
> * Andreas Fenkart <andreas.fenkart at streamunlimited.com> [121130 03:21]:
>>
>> The alternative was to configure dat1 line as a GPIO, while
>> waiting for an IRQ. Then configuring it back as dat1 when the
>> SDIO card is signalling an IRQ. Or the host starts a transfer. I
>> guess this will perform poorly, hence not considering it really.
>
> This might work for SDIO cards. It should be disabled for data
> cards naturally to avoid potential data corruption.
>
> The way to implement this is set named states in the .dts file
> for the pins using pinctrl-single.c, then have the MMC driver
> request states "default" "active" and "idle" during the probe,
> then toggle between active and idle during the runtime.
>
> As far as I remember the GPIO functionality does not need to
> be enabled, just muxing the pin to GPIO mode for the wake-up
> is enough.
Wouldn't that be racy, given that an interrupt which occurs at beween
the point in time when the driver decides to wait for IRQs again until
the mux has finished switching over, could potentially be lost?
If there is another way to solve that cleanly on at least some hardware
derivats, I'd say that should be preferred and be supported by the driver.
Daniel
More information about the devicetree-discuss
mailing list