linux-spi.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: David Brownell <david-b-yBeKhBN/0LDR7s880joybQ@public.gmane.org>
To: Pierre Ossman <drzeus-mmc-p3sGCRWkH8CeZLLa646FqQ@public.gmane.org>
Cc: Hans-Peter Nilsson
	<hans-peter.nilsson-VrBV9hrLPhE@public.gmane.org>,
	Mikael Starvik <mikael.starvik-VrBV9hrLPhE@public.gmane.org>,
	Mike Lavender
	<mike-UTnDXsALFwNjMdQLN6DIHgC/G2K4zDHf@public.gmane.org>,
	spi-devel-general-5NWGOfrQmneRv+LV9MX5uipxlwaOVQ5f@public.gmane.org
Subject: Re: [patch 2.6.22-git5 3/4] MMC core learns about SPI
Date: Wed, 1 Aug 2007 10:02:28 -0700	[thread overview]
Message-ID: <200708011002.28801.david-b@pacbell.net> (raw)
In-Reply-To: <20070801170220.3c5ccff6-mgABNEgzgxm+PRNnhPf8W5YgPPQkE1Si@public.gmane.org>

On Wednesday 01 August 2007, Pierre Ossman wrote:
> On Thu, 26 Jul 2007 14:58:54 -0700
> David Brownell <david-b@pacbell.net> wrote:
> 
> > > This will fail to initialise a high capacity MMC card. From the MMC
> > > spec:
> > > 
> > > "Without the CMD58 with bits [30:29] set as "10b" in prior to the
> > > CMD1 a higher than 2GB of density of memory will remain in Idle
> > > state forever." 
> > 
> > The first thing mmc_attach_mmc() does is reset the card...
> > 
> > Are you sure that "forever" means that reset will fail?
> > That would be a very foolish thing to specify.  And while
> > I've seen strange things in specs, that would be one of
> > the worst that's not a vendor-specific part of a papering
> > over errata ...
> > 
> 
> Well, it's rather straight-forward if you think about it. As they've
> changed the addressing scheme,

Since I've not seen the MMC4 spec, I couldn't know.  :)

And the nearest approximation of MMC4 I've got (an early Samsung
spec) says CMD58 has argument "none" (== 0) ... while one of the
cards I've got rejected CMD58 before CMD1.  So "straightforward"
is not a word I could apply here...


> but retain the original commands, a host 
> that does not understand the new scheme would utterly destroy the data.
> So the card refuses to init unless the host can present some evidence
> that it understands the new scheme.

Right, but that doesn't answer my question:  whether the card
is specified to lock up "forever", or whether (as I'd expect)
reinitialization (starting with reset) works the normal way.


> > I'd be inclined to leave this alone unless someone gets
> > such a card and notices that it doesn't work.  After all,
> > lack of testing on those new (and-I-still-can't-find-one)
> > cards is a general disclaimer.
> > 
> 
> Too bad I have no SPI setup here. :(

My current setup uses a breadboard, so it can hook up to the
real SPI hardware ... I started out using bitbanged SPI to a
card which normally muxed to a "native" controller.  Maybe
one of those could work for you.


> Please add a comment that we know that MMC 4.2 is broken and can be
> fixed once someone is able to test.

Doesn't the general disclaimer that MMC4 cards haven't been
tested already cover that part?  If you like, just tweak the
patch comments to clarify.


> > > The *_ops.c only contain function wrappers of protocol commands, not
> > > policy. So I think this is better placed where mmc_spi_set_crc() is
> > > called. 
> > 
> > You mean, have separate module params for SD and for MMC?
> > It seems cleaner this way...
> > 
> 
> No, that would be silly. You'd probably have to stick it in core.c and
> reference it from mmc.c and sd.c.
> 
> The reason I complain is that seeing mmc_spi_set_crc() will look like
> it always activates CRC, as all other functions in *_ops.c are simple
> wrappers around protocol ops.

So, move the param and mmc_spi_set_crc() into core.c then, and
leave the calls where they are?

Can we do that as a separate patch?  You said below we can proceed,
which suggests to me that now's the time to convert to incrmentals.
I don't mind a few more update patches, but it'd be easier to do
them against say a git-mmc patch against 2.6.23-rc2 ...


> > > "Illegal command" refers to the previous command sent (and failed).
> > > So this can give false negatives. 
> > 
> > The immediately preceding command would be MMC_APP_CMD ... ?
> > I didn't see any language in the specs which could let me
> > interpret this as anything other than APP_CMD failure:
> > 
> >    When an error bit is detected in “R” mode the card will
> >    report the error in the response to the command that raised
> >    the exception. The command will not be executed and the
> >    associated state transition will not take place. 
> > 
> > What this does is to quickly abort retries of SD card ops
> > that were sent to MMC cards, and which always fail with
> > ILLEGAL_COMMAND.
> > 
> 
> I hate this part of the spec. The SD spec also claims:
> 
> "Clear condition B: Always related to the previous command"
> 
> But in the SPI section, they back out of that claim. So for SPI, things
> seems somewhat sane.

I don't have either of those specs.  "Previous command" isn't
particularly clear, though maybe in context it could be ... it
might mean the immediately preceding command, or the one before
that, depending on usage.


> (The MMC spec is even more hilarious. I lists clear condition A and B,
> but never explains what they mean. And looking at some older card
> specs, it seems that the MMC spec had the same conditions and
> definitions as SD *sigh*)

Yeech!

 
> We can proceed with your code, although I'm still a bit nervous about
> sticking that parsing in there.

I don't think you need to be nervous about that.  It clearly works,
and to those of us who've worked this driver and had to become one
with the docs we have, this hasn't raised flags.

It is however *much* better not to need to map the SPI status codes
into the "native" ones.  As you implicitly noted above, expecting
them to behave the same doesn't seem like a good idea!

- Dave


 
> Rgds
> -- 
>      -- Pierre Ossman
> 
>   Linux kernel, MMC maintainer        http://www.kernel.org
>   PulseAudio, core developer          http://pulseaudio.org
>   rdesktop, core developer          http://www.rdesktop.org
> 



-------------------------------------------------------------------------
This SF.net email is sponsored by: Splunk Inc.
Still grepping through log files to find problems?  Stop.
Now Search log events and configuration files using AJAX and a browser.
Download your FREE copy of Splunk now >>  http://get.splunk.com/
_______________________________________________
spi-devel-general mailing list
spi-devel-general@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/spi-devel-general

  parent reply	other threads:[~2007-08-01 17:02 UTC|newest]

Thread overview: 47+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2007-07-14 22:04 [patch 2.6.22-git5 0/4] MMC-over-SPI David Brownell
     [not found] ` <200707141504.51950.david-b-yBeKhBN/0LDR7s880joybQ@public.gmane.org>
2007-07-14 22:05   ` [patch 2.6.22-git5 1/4] MMC headers learn about SPI David Brownell
     [not found]     ` <200707141506.00262.david-b-yBeKhBN/0LDR7s880joybQ@public.gmane.org>
2007-07-26 16:31       ` Pierre Ossman
     [not found]         ` <20070726183150.024930aa-mgABNEgzgxm+PRNnhPf8W5YgPPQkE1Si@public.gmane.org>
2007-07-26 16:55           ` David Brownell
     [not found]             ` <200707260955.22967.david-b-yBeKhBN/0LDR7s880joybQ@public.gmane.org>
2007-07-26 18:05               ` Pierre Ossman
     [not found]                 ` <20070726200525.6a5b7d72-mgABNEgzgxm+PRNnhPf8W5YgPPQkE1Si@public.gmane.org>
2007-07-26 20:08                   ` David Brownell
2007-07-14 22:06   ` [patch 2.6.22-git5 2/4] MMC block learns " David Brownell
     [not found]     ` <200707141506.42880.david-b-yBeKhBN/0LDR7s880joybQ@public.gmane.org>
2007-07-26 16:33       ` Pierre Ossman
     [not found]         ` <20070726183339.6631243f-mgABNEgzgxm+PRNnhPf8W5YgPPQkE1Si@public.gmane.org>
2007-07-26 17:00           ` David Brownell
     [not found]             ` <200707261000.17339.david-b-yBeKhBN/0LDR7s880joybQ@public.gmane.org>
2007-07-26 18:06               ` Pierre Ossman
     [not found]                 ` <20070726200639.06242858-mgABNEgzgxm+PRNnhPf8W5YgPPQkE1Si@public.gmane.org>
2007-07-26 20:15                   ` David Brownell
2007-07-14 22:07   ` [patch 2.6.22-git5 3/4] MMC core " David Brownell
     [not found]     ` <200707141507.17484.david-b-yBeKhBN/0LDR7s880joybQ@public.gmane.org>
2007-07-26 17:18       ` Pierre Ossman
     [not found]         ` <20070726191824.569542fd-mgABNEgzgxm+PRNnhPf8W5YgPPQkE1Si@public.gmane.org>
2007-07-26 21:58           ` David Brownell
     [not found]             ` <200707261458.55558.david-b-yBeKhBN/0LDR7s880joybQ@public.gmane.org>
2007-07-26 22:22               ` David Brownell
2007-08-01 15:02               ` Pierre Ossman
     [not found]                 ` <20070801170220.3c5ccff6-mgABNEgzgxm+PRNnhPf8W5YgPPQkE1Si@public.gmane.org>
2007-08-01 17:02                   ` David Brownell [this message]
     [not found]                     ` <200708011002.28801.david-b-yBeKhBN/0LDR7s880joybQ@public.gmane.org>
2007-08-02 12:54                       ` Pierre Ossman
     [not found]                         ` <20070802145445.1118d1e7-mgABNEgzgxm+PRNnhPf8W5YgPPQkE1Si@public.gmane.org>
2007-08-02 19:23                           ` David Brownell
2007-07-14 22:08   ` [patch 2.6.22-git5 4/4] mmc_spi host driver David Brownell
     [not found]     ` <200707141508.07555.david-b-yBeKhBN/0LDR7s880joybQ@public.gmane.org>
2007-07-26 18:02       ` Pierre Ossman
     [not found]         ` <20070726200202.5e5dcf62-mgABNEgzgxm+PRNnhPf8W5YgPPQkE1Si@public.gmane.org>
2007-07-26 23:32           ` David Brownell
     [not found]             ` <200707261632.37011.david-b-yBeKhBN/0LDR7s880joybQ@public.gmane.org>
2007-08-01 15:12               ` Pierre Ossman
     [not found]                 ` <20070801171217.1478267b-mgABNEgzgxm+PRNnhPf8W5YgPPQkE1Si@public.gmane.org>
2007-08-01 18:17                   ` David Brownell
     [not found]                     ` <200708011117.24664.david-b-yBeKhBN/0LDR7s880joybQ@public.gmane.org>
2007-08-02 13:06                       ` Pierre Ossman
     [not found]                         ` <20070802150615.36e073c6-mgABNEgzgxm+PRNnhPf8W5YgPPQkE1Si@public.gmane.org>
2007-08-02 20:34                           ` David Brownell
     [not found]                             ` <200708021334.50670.david-b-yBeKhBN/0LDR7s880joybQ@public.gmane.org>
2007-08-04 13:14                               ` Pierre Ossman
     [not found]                                 ` <20070804151452.0efaa5a9-mgABNEgzgxm+PRNnhPf8W5YgPPQkE1Si@public.gmane.org>
2007-08-04 17:32                                   ` David Brownell
     [not found]                                     ` <200708041032.10001.david-b-yBeKhBN/0LDR7s880joybQ@public.gmane.org>
2007-08-04 21:32                                       ` Pierre Ossman
2007-08-07 12:35                               ` Pierre Ossman
2007-08-01 18:40                   ` David Brownell
2007-07-16 16:48   ` [patch 2.6.22-git5 0/4] MMC-over-SPI Anton Vorontsov
     [not found]     ` <20070716164837.GA18707-bi+AKbBUZKY6gyzm1THtWbp2dZbC/Bob@public.gmane.org>
2007-07-16 18:54       ` David Brownell
     [not found]         ` <200707161154.54728.david-b-yBeKhBN/0LDR7s880joybQ@public.gmane.org>
2007-07-17 15:13           ` Anton Vorontsov
     [not found]             ` <20070717151350.GA3752-bi+AKbBUZKY6gyzm1THtWbp2dZbC/Bob@public.gmane.org>
2007-07-17 16:11               ` David Brownell
     [not found]                 ` <200707170911.16715.david-b-yBeKhBN/0LDR7s880joybQ@public.gmane.org>
2007-07-18  7:35                   ` Jan Nikitenko
     [not found]                     ` <469DC2BC.5070305-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2007-07-18 17:06                       ` David Brownell
2007-07-18 10:00                   ` Anton Vorontsov
     [not found]                     ` <20070718100047.GA9544-bi+AKbBUZKY6gyzm1THtWbp2dZbC/Bob@public.gmane.org>
2007-07-18 14:05                       ` Anton Vorontsov
2007-07-18 14:44                   ` Pierre Ossman
     [not found]                     ` <20070718164409.56ca0019-mgABNEgzgxm+PRNnhPf8W5YgPPQkE1Si@public.gmane.org>
2007-07-18 17:27                       ` David Brownell
     [not found]                         ` <200707181027.17819.david-b-yBeKhBN/0LDR7s880joybQ@public.gmane.org>
2007-07-19 16:15                           ` Anton Vorontsov
     [not found]                             ` <20070719161553.GA15756-bi+AKbBUZKY6gyzm1THtWbp2dZbC/Bob@public.gmane.org>
2007-07-19 20:28                               ` David Brownell
     [not found]                                 ` <200707191328.18846.david-b-yBeKhBN/0LDR7s880joybQ@public.gmane.org>
2007-07-23 14:29                                   ` Anton Vorontsov
     [not found]                                     ` <20070723142923.GA28979-bi+AKbBUZKY6gyzm1THtWbp2dZbC/Bob@public.gmane.org>
2007-07-23 17:33                                       ` David Brownell
     [not found]                                         ` <200707231033.31717.david-b-yBeKhBN/0LDR7s880joybQ@public.gmane.org>
2007-07-24 10:23                                           ` Anton Vorontsov
2007-08-07  3:21                                           ` David Brownell

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=200708011002.28801.david-b@pacbell.net \
    --to=david-b-ybekhbn/0ldr7s880joybq@public.gmane.org \
    --cc=drzeus-mmc-p3sGCRWkH8CeZLLa646FqQ@public.gmane.org \
    --cc=hans-peter.nilsson-VrBV9hrLPhE@public.gmane.org \
    --cc=mikael.starvik-VrBV9hrLPhE@public.gmane.org \
    --cc=mike-UTnDXsALFwNjMdQLN6DIHgC/G2K4zDHf@public.gmane.org \
    --cc=spi-devel-general-5NWGOfrQmneRv+LV9MX5uipxlwaOVQ5f@public.gmane.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).