/* $Id$ */ /* * Copyright (c) 2001-2010 Aaron Turner * Copyright (c) 2013-2017 Fred Klassen - AppNeta * * The Tcpreplay Suite of tools is free software: you can redistribute it * and/or modify it under the terms of the GNU General Public License as * published by the Free Software Foundation, either version 3 of the * License, or with the authors permission any later version. * * The Tcpreplay Suite is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with the Tcpreplay Suite. If not, see . */ #ifndef _DLT_radiotap_H_ #define _DLT_radiotap_H_ #include "plugins_types.h" int dlt_radiotap_register(tcpeditdlt_t *ctx); int dlt_radiotap_init(tcpeditdlt_t *ctx); int dlt_radiotap_cleanup(tcpeditdlt_t *ctx); int dlt_radiotap_parse_opts(tcpeditdlt_t *ctx); int dlt_radiotap_decode(tcpeditdlt_t *ctx, const u_char *packet, const int pktlen); int dlt_radiotap_encode(tcpeditdlt_t *ctx, u_char *packet, int pktlen, tcpr_dir_t dir); int dlt_radiotap_proto(tcpeditdlt_t *ctx, const u_char *packet, const int pktlen); u_char *dlt_radiotap_get_layer3(tcpeditdlt_t *ctx, u_char *packet, const int pktlen); u_char *dlt_radiotap_merge_layer3(tcpeditdlt_t *ctx, u_char *packet, const int pktlen, u_char *l3data); tcpeditdlt_l2addr_type_t dlt_radiotap_l2addr_type(void); int dlt_radiotap_l2len(tcpeditdlt_t *ctx, const u_char *packet, const int pktlen); int dlt_radiotap_80211_l2len(tcpeditdlt_t *ctx, const u_char *packet, const int pktlen); u_char *dlt_radiotap_get_mac(tcpeditdlt_t *ctx, tcpeditdlt_mac_type_t mac, const u_char *packet, const int pktlen); /* * FIXME: structure to hold any data parsed from the packet by the decoder. * Example: Ethernet VLAN tag info */ struct radiotap_extra_s { u_char packet[MAXPACKET]; }; typedef struct radiotap_extra_s radiotap_extra_t; /* * FIXME: structure to hold any data in the tcpeditdlt_plugin_t->config * Things like: * - Parsed user options * - State between packets * - Note, you should only use this for the encoder function, decoder functions should place * "extra" data parsed from the packet in the tcpeditdlt_t->decoded_extra buffer since that * is available to any encoder plugin. */ struct radiotap_config_s { /* dummy entry for SunPro compiler which doesn't like empty structs */ int dummy; }; typedef struct radiotap_config_s radiotap_config_t; /* note, all radiotap_hdr fields are in LITTLE endian! WTF??? */ struct radiotap_hdr_s { u_int8_t version; u_int8_t pad; u_int16_t length; /* total header length */ u_int32_t present; /* flags of present headers */ }; typedef struct radiotap_hdr_s radiotap_hdr_t; #endif