public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
[parent not found: <fa.QF1nJvJhMpLvtquNDa6sbADHwhs@ifi.uio.no>]
* PCI Bursting with PIO
@ 2008-02-15  3:28 Dan Gora
  2008-02-15 10:54 ` Andi Kleen
  2008-02-15 13:02 ` Alan Cox
  0 siblings, 2 replies; 10+ messages in thread
From: Dan Gora @ 2008-02-15  3:28 UTC (permalink / raw)
  To: linux-kernel

Hi,

I am trying to optimize a driver for a slave only PCI device and am
having a lot of trouble getting any kind of PCI burst transactions in
either the read or the write direction.  Using bcopy/memcpy or even a
hand-crafted while (len) { *pdst++ = *psrc++} (with pdst and psrc
unsigned long*) I can only get writes to burst and even in that case
only for 2 data phases (8 bytes) and only on 64 bit machines.  The
best that I have managed is to use a hand crafted asm function which
copies the data through mmx registers on i386 machines, but that still
only bursts a maximum of 16 bytes in the write direction and not at
all in the read direction.  The source and destination pointers are
both aligned to 8 byte boundaries, so I don't think that it's an
alignment issue.

Is there any way to get PIO to burst over the PCI bus in the read and
write direction?  My device has 4 BAR registers, but the area where I
am transferring data is marked 'prefetchable' (although the others are
not).  I read here: http://lkml.org/lkml/2004/9/23/393 that this was a
prerequisite, but it is apparently not sufficient.  He also mentioned
that the area had to be marked as write-back, but it's not clear how
you can tell (no /proc/mtrr doesn't tell you) or that it has anything
to do with bursting reads.

Any ideas would be really appreciated,

thanks-
dan

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

end of thread, other threads:[~2008-02-17 19:06 UTC | newest]

Thread overview: 10+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
     [not found] <fa.Mbzb1/2dWnp5V/5ElzijlkAstZU@ifi.uio.no>
2008-02-16  6:00 ` PCI Bursting with PIO Robert Hancock
2008-02-17  4:53   ` Dan Gora
     [not found] <fa.QF1nJvJhMpLvtquNDa6sbADHwhs@ifi.uio.no>
     [not found] ` <fa.LrKLA2l3F3abMpHk4aDjFfwzFVI@ifi.uio.no>
     [not found]   ` <fa.kFanAY/O5VMnSf6YXqEyxmsR62U@ifi.uio.no>
2008-02-17 19:06     ` Robert Hancock
2008-02-15  3:28 Dan Gora
2008-02-15 10:54 ` Andi Kleen
2008-02-15 17:55   ` Dan Gora
2008-02-15 13:02 ` Alan Cox
2008-02-15 18:00   ` Dan Gora
2008-02-15 18:41     ` H. Peter Anvin
2008-02-15 19:00     ` Alan Cox

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