2 * PCAP capture file reader
3 * Copyright (c) 2010, Jouni Malinen <j@w1.fi>
5 * This software may be distributed under the terms of the BSD license.
6 * See README for more details.
9 #include "utils/includes.h"
12 #include "utils/common.h"
16 int read_cap_file(struct wlantest *wt, const char *fname)
18 char errbuf[PCAP_ERRBUF_SIZE];
20 unsigned int count = 0;
21 struct pcap_pkthdr *hdr;
26 pcap = pcap_open_offline(fname, errbuf);
28 wpa_printf(MSG_ERROR, "Failed to read pcap file '%s': %s",
32 dlt = pcap_datalink(pcap);
33 if (dlt != DLT_IEEE802_11_RADIO && dlt != DLT_PRISM_HEADER &&
34 dlt != DLT_IEEE802_11) {
35 wpa_printf(MSG_ERROR, "Unsupported pcap datalink type: %d",
40 wpa_printf(MSG_DEBUG, "pcap datalink type: %d", dlt);
43 res = pcap_next_ex(pcap, &hdr, &data);
45 break; /* No more packets */
47 wpa_printf(MSG_INFO, "pcap_next_ex failure: %s",
52 wpa_printf(MSG_INFO, "Unexpected pcap_next_ex return "
57 /* Packet was read without problems */
58 wpa_printf(MSG_EXCESSIVE, "pcap hdr: ts=%d.%06d "
60 (int) hdr->ts.tv_sec, (int) hdr->ts.tv_usec,
61 hdr->caplen, hdr->len);
62 if (wt->write_pcap_dumper) {
63 wt->write_pcap_time = hdr->ts;
64 pcap_dump(wt->write_pcap_dumper, hdr, data);
66 if (hdr->caplen < hdr->len) {
67 wpa_printf(MSG_DEBUG, "pcap: Dropped incomplete frame "
69 hdr->caplen, hdr->len);
74 case DLT_IEEE802_11_RADIO:
75 wlantest_process(wt, data, hdr->caplen);
77 case DLT_PRISM_HEADER:
78 wlantest_process_prism(wt, data, hdr->caplen);
81 wlantest_process_80211(wt, data, hdr->caplen);
87 wpa_printf(MSG_DEBUG, "Read %s: %u packets", fname, count);
93 int read_wired_cap_file(struct wlantest *wt, const char *fname)
95 char errbuf[PCAP_ERRBUF_SIZE];
97 unsigned int count = 0;
98 struct pcap_pkthdr *hdr;
102 pcap = pcap_open_offline(fname, errbuf);
104 wpa_printf(MSG_ERROR, "Failed to read pcap file '%s': %s",
110 res = pcap_next_ex(pcap, &hdr, &data);
112 break; /* No more packets */
114 wpa_printf(MSG_INFO, "pcap_next_ex failure: %s",
119 wpa_printf(MSG_INFO, "Unexpected pcap_next_ex return "
124 /* Packet was read without problems */
125 wpa_printf(MSG_EXCESSIVE, "pcap hdr: ts=%d.%06d "
127 (int) hdr->ts.tv_sec, (int) hdr->ts.tv_usec,
128 hdr->caplen, hdr->len);
129 if (hdr->caplen < hdr->len) {
130 wpa_printf(MSG_DEBUG, "pcap: Dropped incomplete frame "
132 hdr->caplen, hdr->len);
136 wlantest_process_wired(wt, data, hdr->caplen);
141 wpa_printf(MSG_DEBUG, "Read %s: %u packets", fname, count);