Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1761815AbZCPTiR (ORCPT ); Mon, 16 Mar 2009 15:38:17 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1760942AbZCPThl (ORCPT ); Mon, 16 Mar 2009 15:37:41 -0400 Received: from n17.bullet.mail.mud.yahoo.com ([68.142.206.144]:48292 "HELO n17.bullet.mail.mud.yahoo.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with SMTP id S1761788AbZCPThk (ORCPT ); Mon, 16 Mar 2009 15:37:40 -0400 X-Yahoo-Newman-Id: 145784.71834.bm@omp404.mail.mud.yahoo.com DomainKey-Signature: a=rsa-sha1; q=dns; c=nofws; s=s1024; d=pacbell.net; h=Received:X-YMail-OSG:X-Yahoo-Newman-Property:From:To:Subject:Date:User-Agent:Cc:References:In-Reply-To:MIME-Version:Content-Type:Content-Transfer-Encoding:Content-Disposition:Message-Id; b=v/uYRW1OOutkQ55DktGrjJsyQDZi1MQbuJuomL5AGt/gFyHdmUytElr41LFjAOkeC/Uj8Ikod7UrxJesWkyraB179aZ1BA57U9x++SC6cztTFemzJrlCjqWsMd0QL99G6eAO2gA5rhacvxlEZJ1k1ikfrmrrObNsYFSXZKKBAPk= ; X-YMail-OSG: S9LUr9wVM1nUmZuSiD76QB4g3LVu02gDyWRawmp2fxC1AcNXW2t1VylKSjM74V5psHiY3f0Duk6ZzwMFS6ntHw0UDqWqDMzwRNpNGQ3UjIUMxEiuCQJPRX2zb9mtfKtUIc5CFEaG66Lc2WYSsfIDsZzyk7RKymO9F7bUagW6C9HqjX86Mp3H5u4Re9R4Y.rUnA-- X-Yahoo-Newman-Property: ymail-3 From: David Brownell To: Wolfgang =?iso-8859-1?q?M=FCes?= Subject: Re: [PATCH 3/7 revised] mmc_spi: adjust for delayed data token response Date: Mon, 16 Mar 2009 12:37:36 -0700 User-Agent: KMail/1.9.10 Cc: Pierre Ossman , "Andrew Morton" , "Matt Fleming" , "Mike Frysinger" , linux-kernel@vger.kernel.org References: <200903161223.03402.wolfgang.mues@auerswald.de> In-Reply-To: <200903161223.03402.wolfgang.mues@auerswald.de> MIME-Version: 1.0 Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: 8bit Content-Disposition: inline Message-Id: <200903161237.36301.david-b@pacbell.net> Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 3448 Lines: 100 On Monday 16 March 2009, Wolfgang M?es wrote: > From: Wolfgang Muees > > o some cards are not able to send the data token in time, but > miss the time frame for some bits(!). So synchronize to the > start of the token. > > Signed-off-by: Wolfgang Muees Acked-by: David Brownell > --- > > This is the revised patch #3, to apply after the already accepted > patches #1,2 and #5. It contains the bugfix and a better explanation > of what is going on here. > > diff -uprN 2_6_29_rc7_patch125/drivers/mmc/host/mmc_spi.c 2_6_29_rc7_patch1253/drivers/mmc/host/mmc_spi.c > --- 2_6_29_rc7_patch125/drivers/mmc/host/mmc_spi.c 2009-03-11 13:00:06.000000000 +0100 > +++ 2_6_29_rc7_patch1253/drivers/mmc/host/mmc_spi.c 2009-03-16 12:15:36.000000000 +0100 > @@ -612,6 +612,7 @@ mmc_spi_writeblock(struct mmc_spi_host * > struct spi_device *spi = host->spi; > int status, i; > struct scratch *scratch = host->data; > + u32 pattern; > > if (host->mmc->use_spi_crc) > scratch->crc_val = cpu_to_be16( > @@ -639,8 +640,27 @@ mmc_spi_writeblock(struct mmc_spi_host * > * doesn't necessarily tell whether the write operation succeeded; > * it just says if the transmission was ok and whether *earlier* > * writes succeeded; see the standard. > - */ > - switch (SPI_MMC_RESPONSE_CODE(scratch->status[0])) { > + * > + * In practice, there are (even modern SDHC-)cards which are late > + * in sending the response, and miss the time frame by a few bits, > + * so we have to cope with this situation and check the response > + * bit-by-bit. Arggh!!! > + */ > + pattern = scratch->status[0] << 24; > + pattern |= scratch->status[1] << 16; > + pattern |= scratch->status[2] << 8; > + pattern |= scratch->status[3]; > + > + /* First 3 bit of pattern are undefined */ > + pattern |= 0xE0000000; > + > + /* left-adjust to leading 0 bit */ > + while (pattern & 0x80000000) > + pattern <<= 1; > + /* right-adjust for pattern matching. Code is in bit 4..0 now. */ > + pattern >>= 27; > + > + switch (pattern) { > case SPI_RESPONSE_ACCEPTED: > status = 0; > break; > @@ -671,8 +691,9 @@ mmc_spi_writeblock(struct mmc_spi_host * > /* Return when not busy. If we didn't collect that status yet, > * we'll need some more I/O. > */ > - for (i = 1; i < sizeof(scratch->status); i++) { > - if (scratch->status[i] != 0) > + for (i = 4; i < sizeof(scratch->status); i++) { > + /* card is non-busy if the most recent bit is 1 */ > + if (scratch->status[i] & 0x01) > return 0; > } > return mmc_spi_wait_unbusy(host, timeout); > > --- > 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@Auerswald.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@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/