mbox series

[0/5] mmc: core: Add support for graceful host removal for eMMC/SD

Message ID 20250320140040.162416-1-ulf.hansson@linaro.org (mailing list archive)
Headers show
Series mmc: core: Add support for graceful host removal for eMMC/SD | expand

Message

Ulf Hansson March 20, 2025, 2 p.m. UTC
As pointed out by Wolfram Sang and already discussed at LKML [1] - an mmc host
driver may allow to unbind from its corresponding host device. If there is and
eMMC/SD card attached to the host, the mmc core will just try to cut the power
for it, without trying to make a graceful power-off, thus potentially we could
damage the card.

This series intends to fix this problem for eMMC/SD cards.

Please help to test and review!

Kind regards
Ulf Hansson

[1]
https://lore.kernel.org/all/20241007093447.33084-2-wsa+renesas@sang-engineering.com/

Ulf Hansson (5):
  mmc: core: Convert mmc_can_poweroff_notify() into a bool
  mmc: core: Further avoid re-storing power to the eMMC before a
    shutdown
  mmc: core: Convert into an enum for the poweroff-type for eMMC
  mmc: core: Add support for graceful host removal for eMMC
  mmc: core: Add support for graceful host removal for SD

 drivers/mmc/core/mmc.c | 66 +++++++++++++++++++++++++++++-------------
 drivers/mmc/core/sd.c  | 25 +++++++++-------
 2 files changed, 61 insertions(+), 30 deletions(-)

Comments

Wolfram Sang March 20, 2025, 3:50 p.m. UTC | #1
On Thu, Mar 20, 2025 at 03:00:31PM +0100, Ulf Hansson wrote:
> As pointed out by Wolfram Sang and already discussed at LKML [1] - an mmc host
> driver may allow to unbind from its corresponding host device. If there is and
> eMMC/SD card attached to the host, the mmc core will just try to cut the power
> for it, without trying to make a graceful power-off, thus potentially we could
> damage the card.
> 
> This series intends to fix this problem for eMMC/SD cards.
> 
> Please help to test and review!

Awesome! Thank you. Will surely check it out. Not before next week I am
afraid. But already looking forward to testing it!