Anton, I think the option described below is intended to cause the adapter
to "get off on a cache line boundary" so when it restarts the DMA it will
be aligned. This is for cases when the adapter has to get off, for exampe
due to FIFO full, etc.
Some adapters would get off on any boundary and that then causes perf
issues when the DMA is restarted.
This is a good option, but I don't think it addresses what we need here as
the host needs to ensure a DMA starts on a cache line.
Different adapter anyway, but I am just pointing out that even if e1000
had this it would not be the solution.
Anton Blanchard <anton@xxxxxxxxx> on 06/13/2003 07:03:42 PM
To: "Feldman, Scott" <scott.feldman@xxxxxxxxx>
cc: "David S. Miller" <davem@xxxxxxxxxx>,
haveblue@xxxxxxxxxxxxxxxxxxxxxxx, Herman Dierks/Austin/IBM@IBMUS,
dwg@xxxxxxxxxxx, linux-kernel@xxxxxxxxxxxxxxx, Nancy J
Milliner/Austin/IBM@IBMUS, Ricardo C Gonzalez/Austin/IBM@ibmus,
Brian Twichell/Austin/IBM@IBMUS, netdev@xxxxxxxxxxx
Subject: Re: e1000 performance hack for ppc64 (Power4)
> I thought the answer was no, so I double checked with a couple of
> hardware guys, and the answer is still no.
Thats a pity, the e100 docs on sourceforge show it can do what we want,
it would be nice if e1000 had this feature too :)
4.2.2 Read Align
The Read Align feature is aimed to enhance performance in cache line
oriented systems. Starting a PCI transaction in these systems on a
non-cache line aligned address may result in low performance. To solve
this performance problem, the controller can be configured to terminate
Transmit DMA cycles on a cache line boundary, and start the next
transaction on a cache line aligned address. This feature is enabled
when the Read Align Enable bit is set in device Configure command
(Section 22.214.171.124, "Configure (010b)").
If this bit is set, the device operates as follows:
* When the device is close to running out of resources on the Transmit
* DMA (in other words, the Transmit FIFO is almost full), it attempts to
* terminate the read transaction on the nearest cache line boundary when
* When the arbitration counters feature is enabled (maximum Transmit DMA
* byte count value is set in configuration space), the device switches
* to other pending DMAs on cache line boundary only.