mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-13 01:08:50 +00:00
[ARM] Fix potential MMCI bug
The MMCI driver might end up aborting the initial command and leaving the data part of the command sequence still in place. Avoid this problem by ensuring that any data sequence is properly cleared out when a command completes. Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
This commit is contained in:
parent
db6ccbb61c
commit
e47c222b22
@ -42,6 +42,8 @@ mmci_request_end(struct mmci_host *host, struct mmc_request *mrq)
|
|||||||
{
|
{
|
||||||
writel(0, host->base + MMCICOMMAND);
|
writel(0, host->base + MMCICOMMAND);
|
||||||
|
|
||||||
|
BUG_ON(host->data);
|
||||||
|
|
||||||
host->mrq = NULL;
|
host->mrq = NULL;
|
||||||
host->cmd = NULL;
|
host->cmd = NULL;
|
||||||
|
|
||||||
@ -198,6 +200,8 @@ mmci_cmd_irq(struct mmci_host *host, struct mmc_command *cmd,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!cmd->data || cmd->error != MMC_ERR_NONE) {
|
if (!cmd->data || cmd->error != MMC_ERR_NONE) {
|
||||||
|
if (host->data)
|
||||||
|
mmci_stop_data(host);
|
||||||
mmci_request_end(host, cmd->mrq);
|
mmci_request_end(host, cmd->mrq);
|
||||||
} else if (!(cmd->data->flags & MMC_DATA_READ)) {
|
} else if (!(cmd->data->flags & MMC_DATA_READ)) {
|
||||||
mmci_start_data(host, cmd->data);
|
mmci_start_data(host, cmd->data);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user