[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <1349954899.21172.8728.camel@edumazet-glaptop>
Date: Thu, 11 Oct 2012 13:28:19 +0200
From: Eric Dumazet <eric.dumazet@...il.com>
To: mbizon@...ebox.fr
Cc: Russell King - ARM Linux <linux@....linux.org.uk>,
Måns Rullgård <mans@...sr.com>,
Jon Masters <jonathan@...masters.org>, netdev@...r.kernel.org,
David Laight <David.Laight@...LAB.COM>,
linux-arm-kernel@...ts.infradead.org
Subject: Re: alignment faults in 3.6
On Thu, 2012-10-11 at 12:56 +0200, Maxime Bizon wrote:
> On Thu, 2012-10-11 at 12:49 +0200, Eric Dumazet wrote:
>
>
> > So if you have an alignment fault, thats because IP header is not
> > aligned on 4 bytes ?
> >
> > If so a driver is buggy and must be fixed.
>
> So a driver that does not align the ip header is buggy ?
>
exactly.
> I always thought it was ok not to do so (with a potential performance
> penalty).
>
Apparently not for some arches.
> I have some MIPS hardware that is not able to DMA on anything but 32bits
> aligned addresses (bcm63xx). I tried once to add a memcpy instead of
> taking unaligned faults and the result was *much slower* on a ipv4
> forwarding test (which is what the hardware is used for).
>
You probably are aware that a driver can use :
- a fragment to hold the frame given by the hardware, with whatever
alignment is needed by the hardware.
Then allocate an skb with enough room (128 bytes) to pull the headers as
needed later.
skb = netdev_alloc_skb_ip_align(dev, 128);
Attach the fragment to the skb, and feed stack with this skb.
(pull the ethernet header before calling eth_type_trans()
Most modern drivers exactly use this strategy and get nice performance.
Of course, if hardware doesnt need a strange alignment, we can avoid the
fragment and directly use
skb = netdev_alloc_skb_ip_align(dev, 1536);
So all drivers can be fixed if needed.
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists