diff options
| author | Martin Blumenstingl <[email protected]> | 2020-04-16 20:35:13 +0200 | 
|---|---|---|
| committer | Ulf Hansson <[email protected]> | 2020-04-20 09:24:39 +0200 | 
| commit | ddca1092c4324c89cf692b5efe655aa251864b51 (patch) | |
| tree | 15a9bf6dbc99819ad5a002a53787a9b123d8a0dc /drivers/platform/chrome/cros_ec.h | |
| parent | e53b868b3cf5beeaa2f851ec6740112bf4d6a8cb (diff) | |
mmc: meson-mx-sdio: remove the broken ->card_busy() op
The recent commit 0d84c3e6a5b2 ("mmc: core: Convert to
mmc_poll_for_busy() for erase/trim/discard") makes use of the
->card_busy() op for SD cards. This uncovered that the ->card_busy() op
in the Meson SDIO driver was never working right:
while polling the busy status with ->card_busy()
meson_mx_mmc_card_busy() reads only one of the two MESON_MX_SDIO_IRQC
register values 0x1f001f10 or 0x1f003f10. This translates to "three out
of four DAT lines are HIGH" and "all four DAT lines are HIGH", which
is interpreted as "the card is busy".
It turns out that no situation can be observed where all four DAT lines
are LOW, meaning the card is not busy anymore. Upon further research the
3.10 vendor driver for this controller does not implement the
->card_busy() op.
Remove the ->card_busy() op from the meson-mx-sdio driver since it is
not working. At the time of writing this patch it is not clear what's
needed to make the ->card_busy() implementation work with this specific
controller hardware. For all use-cases which have previously worked the
MMC_CAP_WAIT_WHILE_BUSY flag is now taking over, even if we don't have
a ->card_busy() op anymore.
Fixes: ed80a13bb4c4c9 ("mmc: meson-mx-sdio: Add a driver for the Amlogic Meson8 and Meson8b SoCs")
Signed-off-by: Martin Blumenstingl <[email protected]>
Cc: [email protected]
Link: https://lore.kernel.org/r/[email protected]
Signed-off-by: Ulf Hansson <[email protected]>
Diffstat (limited to 'drivers/platform/chrome/cros_ec.h')
0 files changed, 0 insertions, 0 deletions