Blame SOURCES/0008-Vlan-tpid-handling.patch

52e97a
diff --git a/pcap-linux.c b/pcap-linux.c
52e97a
index 0bfc77a..8cf531b 100644
52e97a
--- a/pcap-linux.c
52e97a
+++ b/pcap-linux.c
52e97a
@@ -368,6 +368,12 @@ static void pcap_oneshot_mmap(u_char *user, const struct pcap_pkthdr *h,
52e97a
     const u_char *bytes);
52e97a
 #endif
52e97a
 
52e97a
+#ifdef TP_STATUS_VLAN_TPID_VALID
52e97a
+#define VLAN_TPID(hdr, hv)	(((hv)->tp_vlan_tpid || ((hdr)->tp_status & TP_STATUS_VLAN_TPID_VALID)) ? (hv)->tp_vlan_tpid : ETH_P_8021Q)
52e97a
+#else
52e97a
+#define VLAN_TPID(hdr, hv)	ETH_P_8021Q
52e97a
+#endif
52e97a
+
52e97a
 /*
52e97a
  * Wrap some ioctl calls
52e97a
  */
52e97a
@@ -1656,7 +1662,7 @@ pcap_read_packet(pcap_t *handle, pcap_handler callback, u_char *userdata)
52e97a
 			memmove(bp, bp + VLAN_TAG_LEN, handlep->vlan_offset);
52e97a
 
52e97a
 			tag = (struct vlan_tag *)(bp + handlep->vlan_offset);
52e97a
-			tag->vlan_tpid = htons(ETH_P_8021Q);
52e97a
+			tag->vlan_tpid = htons(VLAN_TPID(aux, aux));
52e97a
 			tag->vlan_tci = htons(aux->tp_vlan_tci);
52e97a
 
52e97a
                         /* store vlan tci to bpf_aux_data struct for userland bpf filter */
52e97a
@@ -4242,7 +4248,8 @@ static int pcap_handle_packet_mmap(
52e97a
 		unsigned int tp_sec,
52e97a
 		unsigned int tp_usec,
52e97a
 		int tp_vlan_tci_valid,
52e97a
-		__u16 tp_vlan_tci)
52e97a
+		__u16 tp_vlan_tci,
52e97a
+		__u16 tp_vlan_tpid)
52e97a
 {
52e97a
 	struct pcap_linux *handlep = handle->priv;
52e97a
 	unsigned char *bp;
52e97a
@@ -4350,7 +4357,7 @@ static int pcap_handle_packet_mmap(
52e97a
 		memmove(bp, bp + VLAN_TAG_LEN, handlep->vlan_offset);
52e97a
 
52e97a
 		tag = (struct vlan_tag *)(bp + handlep->vlan_offset);
52e97a
-		tag->vlan_tpid = htons(ETH_P_8021Q);
52e97a
+		tag->vlan_tpid = htons(tp_vlan_tpid);
52e97a
 		tag->vlan_tci = htons(tp_vlan_tci);
52e97a
 
52e97a
 		pcaphdr.caplen += VLAN_TAG_LEN;
52e97a
@@ -4410,6 +4417,7 @@ pcap_read_linux_mmap_v1(pcap_t *handle, int max_packets, pcap_handler callback,
52e97a
 				h.h1->tp_sec,
52e97a
 				h.h1->tp_usec,
52e97a
 				0,
52e97a
+				0,
52e97a
 				0);
52e97a
 		if (ret == 1) {
52e97a
 			pkts++;
52e97a
@@ -4488,7 +4496,8 @@ pcap_read_linux_mmap_v2(pcap_t *handle, int max_packets, pcap_handler callback,
52e97a
 #else
52e97a
 				h.h2->tp_vlan_tci != 0,
52e97a
 #endif
52e97a
-				h.h2->tp_vlan_tci);
52e97a
+				h.h2->tp_vlan_tci,
52e97a
+				VLAN_TPID(h.h2, h.h2));
52e97a
 		if (ret == 1) {
52e97a
 			pkts++;
52e97a
 			handlep->packets_read++;
52e97a
@@ -4583,7 +4592,8 @@ pcap_read_linux_mmap_v3(pcap_t *handle, int max_packets, pcap_handler callback,
52e97a
 #else
52e97a
 					tp3_hdr->hv1.tp_vlan_tci != 0,
52e97a
 #endif
52e97a
-					tp3_hdr->hv1.tp_vlan_tci);
52e97a
+					tp3_hdr->hv1.tp_vlan_tci,
52e97a
+					VLAN_TPID(tp3_hdr, &tp3_hdr->hv1));
52e97a
 			if (ret == 1) {
52e97a
 				pkts++;
52e97a
 				handlep->packets_read++;