Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 49df7807 authored by Sujit Reddy Thumma's avatar Sujit Reddy Thumma Committed by Chris Ball
Browse files

mmc: core: Fix deadlock when the CONFIG_MMC_UNSAFE_RESUME is not defined



mmc_suspend_host() tries to claim host during suspend
and release it only when the bus suspend operation is
compeleted. If CONFIG_MMC_UNSAFE_RESUME is defined and
the host is flagged as removable, mmc_suspend_host()
tries to remove the card. In this process, the file system
sync can get blocked trying to acquire host which is already
claimed by mmc_suspend_host() causing deadlock.

Fix this deadlock by releasing host before ->remove() is called.

Signed-off-by: default avatarSujit Reddy Thumma <sthumma@codeaurora.org>
Acked-by: default avatarUlf Hansson <ulf.hansson@stericsson.com>
Acked-by: default avatarLinus Walleij <linus.walleij@linaro.org>
Signed-off-by: default avatarChris Ball <cjb@laptop.org>
parent 524bfca2
Loading
Loading
Loading
Loading
+2 −1
Original line number Diff line number Diff line
@@ -2333,6 +2333,8 @@ int mmc_suspend_host(struct mmc_host *host)
				mmc_poweroff_notify(host);
				err = host->bus_ops->suspend(host);
			}
			mmc_do_release_host(host);

			if (err == -ENOSYS || !host->bus_ops->resume) {
				/*
				 * We simply "remove" the card in this case.
@@ -2347,7 +2349,6 @@ int mmc_suspend_host(struct mmc_host *host)
				host->pm_flags = 0;
				err = 0;
			}
			mmc_do_release_host(host);
		} else {
			err = -EBUSY;
		}