public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* [RFC] MMC multiwrite capability removal
@ 2008-04-19  7:51 Pierre Ossman
  2008-04-20  2:34 ` Alex Dubov
  2008-04-21 19:05 ` David Brownell
  0 siblings, 2 replies; 5+ messages in thread
From: Pierre Ossman @ 2008-04-19  7:51 UTC (permalink / raw)
  To: David Brownell, Andrew Victor, Pavel Pisa, Carlos Aguiar,
	Anderson Briglia, Syed Mohammed, Khasim, Russell King, Alex Dubov
  Cc: LKML

Hi everyone,

I've been planning to remove the MMC multiwrite capability (making it
always on), but I need some help from all you driver maintainers first.

Ages ago, I had a chat with Axboe about the current situation and it
turns out that the MMC layer is a bit over-cautious. There are plenty
of other block devices that cannot report anything more than
success/failure for the whole request. So it's silly that we're
crippling the MMC layer when upper layers have to deal with that
scenario anyway.

What I need from you is and audit of your respective driver(s) and
check that they do not overestimate the number of successfully written
blocks. Please send a short reply even if your driver needs no changes.

Long version:

The data flow of a write is something like this:

1. Data starts moving from main memory to host memory (DMA or PIO)
2. Data finishes moving from main memory to host memory
3. A sector moves to the front of the device write queue
4. The sector starts being sent over the wire
5. The sector finishes being sent over the wire
6. The card acknowledges a successful transfer
7. The card finishes busy signalling
8. The sector moves to the front of the card write queue
9. The sector gets picked up by the FTL
10. The sector is written to media

In a perfect world we would report the number of sectors that made it
to 10. Unfortunately we have limited insight into what the card is up
to.

What your host drivers should report is sectors that have passed stage
6. If your controller doesn't give you enough information to determine
that, then you must report 0 for all failed transfers.

I'll be having a closer look at stages 7 through 10, but that's a core
issue that shouldn't involve your drivers.

Rgds

-- 
     -- Pierre Ossman

  Linux kernel, MMC maintainer        http://www.kernel.org
  PulseAudio, core developer          http://pulseaudio.org
  rdesktop, core developer          http://www.rdesktop.org

^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2008-04-21 19:11 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-04-19  7:51 [RFC] MMC multiwrite capability removal Pierre Ossman
2008-04-20  2:34 ` Alex Dubov
2008-04-20  8:30   ` Pierre Ossman
2008-04-20 14:54     ` Alex Dubov
2008-04-21 19:05 ` David Brownell

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox