Blame SOURCES/wireshark-0025-drop-count.patch

d03213
diff --git a/wiretap/pcapng.c b/wiretap/pcapng.c
d03213
index 7b398cf..91fd9b8 100644
d03213
--- a/wiretap/pcapng.c
d03213
+++ b/wiretap/pcapng.c
d03213
@@ -3230,6 +3230,10 @@ pcapng_write_enhanced_packet_block(wtap_dumper *wdh, const wtap_rec *rec,
d03213
         have_options = TRUE;
d03213
         options_total_length = options_total_length + 8;
d03213
     }
d03213
+    if (rec->presence_flags & WTAP_HAS_DROP_COUNT) {
d03213
+        have_options = TRUE;
d03213
+        options_total_length = options_total_length + 12;
d03213
+    }
d03213
     if (have_options) {
d03213
         /* End-of options tag */
d03213
         options_total_length += 4;
d03213
@@ -3353,6 +3357,17 @@ pcapng_write_enhanced_packet_block(wtap_dumper *wdh, const wtap_rec *rec,
d03213
         wdh->bytes_dumped += 4;
d03213
         pcapng_debug("pcapng_write_enhanced_packet_block: Wrote Options packet flags: %x", rec->rec_header.packet_header.pack_flags);
d03213
     }
d03213
+    if (rec->presence_flags & WTAP_HAS_DROP_COUNT) {
d03213
+        option_hdr.type         = OPT_EPB_DROPCOUNT;
d03213
+        option_hdr.value_length = 8;
d03213
+        if (!wtap_dump_file_write(wdh, &option_hdr, 4, err))
d03213
+            return FALSE;
d03213
+        wdh->bytes_dumped += 4;
d03213
+        if (!wtap_dump_file_write(wdh, &rec->rec_header.packet_header.drop_count, 8, err))
d03213
+            return FALSE;
d03213
+        wdh->bytes_dumped += 8;
d03213
+        pcapng_debug("pcapng_write_enhanced_packet_block: Wrote Options drop count: %" G_GINT64_MODIFIER "u", rec->rec_header.packet_header.drop_count);
d03213
+    }
d03213
     /* Write end of options if we have options */
d03213
     if (have_options) {
d03213
         if (!wtap_dump_file_write(wdh, &zero_pad, 4, err))