[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <200904141627.26276.wolfgang.mues@auerswald.de>
Date: Tue, 14 Apr 2009 16:27:26 +0200
From: Wolfgang Mües <wolfgang.mues@...rswald.de>
To: Pierre Ossman <pierre@...man.eu>
Cc: "Andrew Morton" <akpm@...ux-foundation.org>,
"Matt Fleming" <matt@...sole-pimps.org>,
"David Brownell" <dbrownell@...rs.sourceforge.net>,
"Mike Frysinger" <vapier.adi@...il.com>,
linux-kernel@...r.kernel.org
Subject: Re: [PATCH] mmc_spi: do propper retry managment in the block layer
Hello Pierre,
Am Samstag, 11. April 2009 schrieb Pierre Ossman:
> NAK. Writes cannot be retried safely as upper layers rely on the fact
> that writes fail in a linear manner (a stupid assumption IMO, but
> that's the way things are).
Hmmm.... so this patch has to be improved. I think the (original) code in
mmc_blk_issue_rq() is somewhat questionable. As far as I understand the code,
in the case of an error, brq.data.bytes_xfered is not examined, so the code
starts over from the very first sector of the request, and rereads all
sectors (one after the another).
So if there is a non-recoverable write error, this code must stop and do not
continue to write, right?
But if there is a read error, it is OK and advisable to try to read the rest
of the sectors?
If there is a write error in the middle of a request, is it OK to do
__blk_end_request(req, 0, brq.data.bytes_xfered);
and try to retry from this point, and stop if there is a non-recoverable write
error?
> > + /* Invalid response. This is most likely a transmission
> > + * error from card to host.
> > + */
> > + case -EINVAL:
>
> EINVAL is actually "host controller driver/hardware does not support
> this type of request".
"Hardware" is including the hardware of the SD card. This should NEVER happen,
because block.c issues only valid requests, which are translated to mandatory
commands for the mmc/sd card.
So if there is an EINVAL result from the lower layers, it comes from
transmission errors (card has not understand the command, or host has not
understand the response).
If EINVAL is coming from the HOST CONTROLER, a retry will not harm anyone.
I have seen EINVAL results due to spikes on the SD lines.
Please correct me if I am wrong.
best regards
i. A. Wolfgang Mües
--
Auerswald GmbH & Co. KG
Hardware Development
Telefon: +49 (0)5306 9219 0
Telefax: +49 (0)5306 9219 94
E-Mail: Wolfgang.Mues@...rswald.de
Web: http://www.auerswald.de
--------------------------------------------------------------
Auerswald GmbH & Co. KG, Vor den Grashöfen 1, 38162 Cremlingen
Registriert beim AG Braunschweig HRA 13289
p.h.G Auerswald Geschäftsführungsges. mbH
Registriert beim AG Braunschweig HRB 7463
Geschäftsführer: Dipl-Ing. Gerhard Auerswald
--
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