提交 0046af38 编写于 作者: L Ludovic Barre 提交者: Greg Kroah-Hartman

mmc: mmci: expand startbiterr to irqmask and error check

[ Upstream commit daf9713c5ef8c3ffb0bdf7de11b53b2b2756c4f1 ]

All variants don't pretend to have a startbiterr.
-While data error check, if status register return an error
(like  MCI_DATACRCFAIL) we must avoid to check MCI_STARTBITERR
(if not desired).
-expand start_err to MCI_IRQENABLE to avoid to set this bit by default.
Signed-off-by: NLudovic Barre <ludovic.barre@st.com>
Signed-off-by: NUlf Hansson <ulf.hansson@linaro.org>
Signed-off-by: NSasha Levin <sashal@kernel.org>
上级 322f530f
...@@ -895,14 +895,18 @@ static void ...@@ -895,14 +895,18 @@ static void
mmci_data_irq(struct mmci_host *host, struct mmc_data *data, mmci_data_irq(struct mmci_host *host, struct mmc_data *data,
unsigned int status) unsigned int status)
{ {
unsigned int status_err;
/* Make sure we have data to handle */ /* Make sure we have data to handle */
if (!data) if (!data)
return; return;
/* First check for errors */ /* First check for errors */
if (status & (MCI_DATACRCFAIL | MCI_DATATIMEOUT | status_err = status & (host->variant->start_err |
host->variant->start_err | MCI_DATACRCFAIL | MCI_DATATIMEOUT |
MCI_TXUNDERRUN | MCI_RXOVERRUN)) { MCI_TXUNDERRUN | MCI_RXOVERRUN);
if (status_err) {
u32 remain, success; u32 remain, success;
/* Terminate the DMA transfer */ /* Terminate the DMA transfer */
...@@ -922,18 +926,18 @@ mmci_data_irq(struct mmci_host *host, struct mmc_data *data, ...@@ -922,18 +926,18 @@ mmci_data_irq(struct mmci_host *host, struct mmc_data *data,
success = data->blksz * data->blocks - remain; success = data->blksz * data->blocks - remain;
dev_dbg(mmc_dev(host->mmc), "MCI ERROR IRQ, status 0x%08x at 0x%08x\n", dev_dbg(mmc_dev(host->mmc), "MCI ERROR IRQ, status 0x%08x at 0x%08x\n",
status, success); status_err, success);
if (status & MCI_DATACRCFAIL) { if (status_err & MCI_DATACRCFAIL) {
/* Last block was not successful */ /* Last block was not successful */
success -= 1; success -= 1;
data->error = -EILSEQ; data->error = -EILSEQ;
} else if (status & MCI_DATATIMEOUT) { } else if (status_err & MCI_DATATIMEOUT) {
data->error = -ETIMEDOUT; data->error = -ETIMEDOUT;
} else if (status & MCI_STARTBITERR) { } else if (status_err & MCI_STARTBITERR) {
data->error = -ECOMM; data->error = -ECOMM;
} else if (status & MCI_TXUNDERRUN) { } else if (status_err & MCI_TXUNDERRUN) {
data->error = -EIO; data->error = -EIO;
} else if (status & MCI_RXOVERRUN) { } else if (status_err & MCI_RXOVERRUN) {
if (success > host->variant->fifosize) if (success > host->variant->fifosize)
success -= host->variant->fifosize; success -= host->variant->fifosize;
else else
...@@ -1790,7 +1794,7 @@ static int mmci_probe(struct amba_device *dev, ...@@ -1790,7 +1794,7 @@ static int mmci_probe(struct amba_device *dev,
goto clk_disable; goto clk_disable;
} }
writel(MCI_IRQENABLE, host->base + MMCIMASK0); writel(MCI_IRQENABLE | variant->start_err, host->base + MMCIMASK0);
amba_set_drvdata(dev, mmc); amba_set_drvdata(dev, mmc);
...@@ -1877,7 +1881,8 @@ static void mmci_restore(struct mmci_host *host) ...@@ -1877,7 +1881,8 @@ static void mmci_restore(struct mmci_host *host)
writel(host->datactrl_reg, host->base + MMCIDATACTRL); writel(host->datactrl_reg, host->base + MMCIDATACTRL);
writel(host->pwr_reg, host->base + MMCIPOWER); writel(host->pwr_reg, host->base + MMCIPOWER);
} }
writel(MCI_IRQENABLE, host->base + MMCIMASK0); writel(MCI_IRQENABLE | host->variant->start_err,
host->base + MMCIMASK0);
mmci_reg_delay(host); mmci_reg_delay(host);
spin_unlock_irqrestore(&host->lock, flags); spin_unlock_irqrestore(&host->lock, flags);
......
...@@ -181,9 +181,9 @@ ...@@ -181,9 +181,9 @@
#define MMCIFIFO 0x080 /* to 0x0bc */ #define MMCIFIFO 0x080 /* to 0x0bc */
#define MCI_IRQENABLE \ #define MCI_IRQENABLE \
(MCI_CMDCRCFAILMASK|MCI_DATACRCFAILMASK|MCI_CMDTIMEOUTMASK| \ (MCI_CMDCRCFAILMASK | MCI_DATACRCFAILMASK | MCI_CMDTIMEOUTMASK | \
MCI_DATATIMEOUTMASK|MCI_TXUNDERRUNMASK|MCI_RXOVERRUNMASK| \ MCI_DATATIMEOUTMASK | MCI_TXUNDERRUNMASK | MCI_RXOVERRUNMASK | \
MCI_CMDRESPENDMASK|MCI_CMDSENTMASK|MCI_STARTBITERRMASK) MCI_CMDRESPENDMASK | MCI_CMDSENTMASK)
/* These interrupts are directed to IRQ1 when two IRQ lines are available */ /* These interrupts are directed to IRQ1 when two IRQ lines are available */
#define MCI_IRQ1MASK \ #define MCI_IRQ1MASK \
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册