[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-id: <alpine.LFD.0.99.0705121122440.24220@xanadu.home>
Date: Sat, 12 May 2007 11:38:32 -0400 (EDT)
From: Nicolas Pitre <nico@....org>
To: Pierre Ossman <drzeus-list@...eus.cx>
Cc: LKML <linux-kernel@...r.kernel.org>
Subject: Re: [GIT PULL] MMC updates
On Thu, 10 May 2007, Nicolas Pitre wrote:
> On Thu, 10 May 2007, Pierre Ossman wrote:
>
> > You seem to be the source of this workaround, and also the maintainer of
> > PXA.
>
> Well... I used to.
Actually, I'm not the author of this workaround. And looking at it
closer, the current workaround is utterly buggy as it completely inhibit
CRC error reporting for everything but the listed commands when the MSB
of the response is a zero.
> But the only MMC capable PXA hardware in working conditions I have
> access to at the moment is PXA255 based which doesn't suffer from this
> erratum.
>
> > Pierre Ossman wrote:
> > > I've read through the erratum, and to me it seems like the bug affects
> > > all long replies, not just these codes. So I think the code should be
> > > fixed to look at the response flag, not the opcode.
Indeed.
Please apply the following patch. It is compile tested only as I don't
have PXA27x hardware with MMC at the moment, but it just cannot be worse
than the current code even when it was compiling.
----- >8
Subject: fix PXA27x MMC workaround for bad CRC on R2 response erratum
... and make it depend on the response flag rather than the command type.
Signed-off-by: Nicolas Pitre <nico@....org>
---
diff --git a/drivers/mmc/host/pxamci.c b/drivers/mmc/host/pxamci.c
index d97d386..8240609 100644
--- a/drivers/mmc/host/pxamci.c
+++ b/drivers/mmc/host/pxamci.c
@@ -232,20 +232,15 @@ static int pxamci_cmd_done(struct pxamci_host *host, unsigned int stat)
/*
* workaround for erratum #42:
* Intel PXA27x Family Processor Specification Update Rev 001
+ * A bogus CRC error can appear if the msb of a R2 response
+ * is a one.
*/
- if (cmd->opcode == MMC_ALL_SEND_CID ||
- cmd->opcode == MMC_SEND_CSD ||
- cmd->opcode == MMC_SEND_CID) {
- /* a bogus CRC error can appear if the msb of
- the 15 byte response is a one */
- if ((cmd->resp[0] & 0x80000000) == 0)
- cmd->error = MMC_ERR_BADCRC;
- } else {
- pr_debug("ignoring CRC from command %d - *risky*\n",cmd->opcode);
- }
-#else
- cmd->error = MMC_ERR_BADCRC;
+ if (RSP_TYPE(mmc_resp_type(cmd)) == RSP_TYPE(MMC_RSP_R2) &&
+ (cmd->resp[0] & 0x80000000)) {
+ pr_debug("ignoring CRC from command %d - *risky*\n", cmd->opcode);
+ } else
#endif
+ cmd->error = MMC_ERR_BADCRC;
}
pxamci_disable_irq(host, END_CMD_RES);
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists