diff options
author | Neil Armstrong <narmstrong@baylibre.com> | 2015-09-22 11:28:14 +0200 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2015-09-23 02:37:03 +0200 |
commit | fbd03513bf36c4e5c2942f436f05c8eb99a3cc9e (patch) | |
tree | a88bf203884c77423aaada7225424fa4545b58aa /net | |
parent | lib: fix data race in rhashtable_rehash_one (diff) | |
download | linux-fbd03513bf36c4e5c2942f436f05c8eb99a3cc9e.tar.xz linux-fbd03513bf36c4e5c2942f436f05c8eb99a3cc9e.zip |
net: dsa: Fix Marvell Egress Trailer check
The Marvell Egress rx trailer check must be fixed to
correctly detect bad bits in the third byte of the
Eggress trailer as described in the Table 28 of the
88E6060 datasheet.
The current code incorrectly omits to check the third
byte and checks the fourth byte twice.
Signed-off-by: Neil Armstrong <narmstrong@baylibre.com>
Acked-by: Guenter Roeck <linux@roeck-us.net>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net')
-rw-r--r-- | net/dsa/tag_trailer.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/net/dsa/tag_trailer.c b/net/dsa/tag_trailer.c index d25efc93d8f1..b6ca0890d018 100644 --- a/net/dsa/tag_trailer.c +++ b/net/dsa/tag_trailer.c @@ -78,7 +78,7 @@ static int trailer_rcv(struct sk_buff *skb, struct net_device *dev, trailer = skb_tail_pointer(skb) - 4; if (trailer[0] != 0x80 || (trailer[1] & 0xf8) != 0x00 || - (trailer[3] & 0xef) != 0x00 || trailer[3] != 0x00) + (trailer[2] & 0xef) != 0x00 || trailer[3] != 0x00) goto out_drop; source_port = trailer[1] & 7; |