From 2d92e43da2984d6d2a7bb9eaa9a79560358ce5c0 Mon Sep 17 00:00:00 2001 From: pr3y Date: Sun, 4 Aug 2024 13:41:44 -0300 Subject: [PATCH] Fixed malformed packed on sniffer pcap --- src/modules/wifi/sniffer.cpp | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) diff --git a/src/modules/wifi/sniffer.cpp b/src/modules/wifi/sniffer.cpp index 56247b55..ea4caf87 100644 --- a/src/modules/wifi/sniffer.cpp +++ b/src/modules/wifi/sniffer.cpp @@ -77,13 +77,19 @@ bool openFile(FS &Fs){ /* will be executed on every packet the ESP32 gets while beeing in promiscuous mode */ void sniffer(void *buf, wifi_promiscuous_pkt_type_t type){ - if(fileOpen){ + if(fileOpen){ wifi_promiscuous_pkt_t* pkt = (wifi_promiscuous_pkt_t*)buf; wifi_pkt_rx_ctrl_t ctrl = (wifi_pkt_rx_ctrl_t)pkt->rx_ctrl; - uint32_t timestamp = now(); //current timestamp - uint32_t microseconds = (unsigned int)(micros() - millis() * 1000); //micro seconds offset (0 - 999) - newPacketSD(timestamp, microseconds, ctrl.sig_len, pkt->payload); //write packet to file + uint32_t timestamp = now(); // current timestamp + uint32_t microseconds = (unsigned int)(micros() - millis() * 1000); // microseconds offset (0 - 999) + + uint32_t len = ctrl.sig_len; + if(type == WIFI_PKT_MGMT) { + len -= 4; // Need to remove last 4 bits (for checksum) or packet gets malformed # https://github.com/espressif/esp-idf/issues/886 + } + + newPacketSD(timestamp, microseconds, len, pkt->payload); // write packet to file } @@ -227,4 +233,4 @@ void sniffer_loop(FS &Fs) { } Exit: delay(1); // just to Exit Work -} \ No newline at end of file +}