skbuff: align sk_buff::cb to 64 bit and close some potential holes
commit7992f7313286abb36c49b65ad90a8b0c824e3a66
authorFelix Fietkau <nbd@openwrt.org>
Tue, 23 Feb 2010 11:45:51 +0000 (23 11:45 +0000)
committerGreg Kroah-Hartman <gregkh@suse.de>
Mon, 15 Mar 2010 16:06:34 +0000 (15 09:06 -0700)
tree6b703b89e55207acb89e3c83c59f9f762f13782e
parent709a1e560b23235706a504323aafc9f1a9a05eb6
skbuff: align sk_buff::cb to 64 bit and close some potential holes

commit da3f5cf1f8ebb0fab5c5fd09adb189166594ad6c upstream.

The alignment requirement for 64-bit load/store instructions on ARM is
implementation defined. Some CPUs (such as Marvell Feroceon) do not
generate an exception, if such an instruction is executed with an
address that is not 64 bit aligned. In such a case, the Feroceon
corrupts adjacent memory, which showed up in my tests as a crash in the
rx path of ath9k that only occured with CONFIG_XFRM set.

This crash happened, because the first field of the mac80211 rx status
info in the cb is an u64, and changing it corrupted the skb->sp field.

This patch also closes some potential pre-existing holes in the sk_buff
struct surrounding the cb[] area.

Signed-off-by: Felix Fietkau <nbd@openwrt.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
include/linux/skbuff.h