[U-Boot] [PATCH] net: force PKTALIGN to ARCH_DMA_MINALIGN

Eric Nelson eric.nelson at boundarydevices.com
Fri Mar 16 04:36:34 CET 2012


On 03/15/2012 07:50 PM, Marek Vasut wrote:
> Dear Eric Nelson,
>
>> This will prevent the need for architectures whose DMA alignment
>> is greater than 32 to have bounce buffers.
>>
>> Signed-off-by: Eric Nelson<eric.nelson at boundarydevices.com>
>> ---
>>   include/net.h |    3 ++-
>>   1 files changed, 2 insertions(+), 1 deletions(-)
>>
>> diff --git a/include/net.h b/include/net.h
>> index e4d42c2..ff428d0 100644
>> --- a/include/net.h
>> +++ b/include/net.h
>> @@ -16,6 +16,7 @@
>>   #include<commproc.h>
>>   #endif	/* CONFIG_8xx */
>>
>> +#include<asm/cache.h>
>>   #include<asm/byteorder.h>	/* for nton* / ntoh* stuff */
>>
>>
>> @@ -31,7 +32,7 @@
>>   # define PKTBUFSRX	4
>>   #endif
>>
>> -#define PKTALIGN	32
>> +#define PKTALIGN	ARCH_DMA_MINALIGN
>>
>>   /* IPv4 addresses are always 32 bits in size */
>>   typedef u32		IPaddr_t;
>
> Won't this break retarded hardware that has ARCH_DMA_MINALIGN smaller than 32 ?
>

I can't see how it would.

This macro is only used for alignment and the PKTSIZE_ALIGN variable should be
safe on any architecture at 1536 (0x600) bytes.

I do see a potential problem with eth.c iff CONFIG_API is set, but I'm
unfamiliar with this API. It appears to me that this declaration
needs to be aligned, with or without the PKTALIGN change or it won't be
usable with DMA since PKTSIZE is unlikely to be cache line or DMA friendly
at 1518 (0x5EE) bytes.

	static struct {
		uchar data[PKTSIZE];
		int length;
	} eth_rcv_bufs[PKTBUFSRX];

It appears that the CONFIG_API macro is only defined for PMC440. Is this
supported for other machines?

Is there some test code available?

Please advise,


Eric


More information about the U-Boot mailing list