|
@@ -1812,6 +1812,13 @@ static int tpacket_rcv(struct sk_buff *skb, struct net_device *dev,
|
|
|
struct timespec ts;
|
|
struct timespec ts;
|
|
|
__u32 ts_status;
|
|
__u32 ts_status;
|
|
|
|
|
|
|
|
|
|
+ /* struct tpacket{2,3}_hdr is aligned to a multiple of TPACKET_ALIGNMENT.
|
|
|
|
|
+ * We may add members to them until current aligned size without forcing
|
|
|
|
|
+ * userspace to call getsockopt(..., PACKET_HDRLEN, ...).
|
|
|
|
|
+ */
|
|
|
|
|
+ BUILD_BUG_ON(TPACKET_ALIGN(sizeof(*h.h2)) != 32);
|
|
|
|
|
+ BUILD_BUG_ON(TPACKET_ALIGN(sizeof(*h.h3)) != 48);
|
|
|
|
|
+
|
|
|
if (skb->pkt_type == PACKET_LOOPBACK)
|
|
if (skb->pkt_type == PACKET_LOOPBACK)
|
|
|
goto drop;
|
|
goto drop;
|
|
|
|
|
|