12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697 |
- /* $Id$ */
- /*
- * Copyright (c) 2001-2010 Aaron Turner <aturner at synfin dot net>
- * Copyright (c) 2013-2024 Fred Klassen <tcpreplay at appneta dot com> - 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 <http://www.gnu.org/licenses/>.
- */
- #pragma once
- /* line buffer stdout, read from stdin */
- #define TCPDUMP_ARGS " -n -l -r -"
- /* max number of tcpdump options; must be a multiple of 4 */
- #define OPTIONS_VEC_SIZE 32
- /* how long to wait (in ms) to write to tcpdump */
- #define TCPDUMP_POLL_TIMEOUT 500
- /* delim to be used for strtok() to process tcpdump args */
- #define OPT_DELIM " -"
- /* output file of data passed to tcpdump when debug level 5 is enabled */
- #define TCPDUMP_DEBUG "tcpdump.debug"
- /* taken from libpcap's savefile.c */
- #define TCPDUMP_MAGIC 0xa1b2c3d4
- #define PATCHED_TCPDUMP_MAGIC 0xa1b2cd34
- #define TCPDUMP_DECODE_LEN 65535
- /*
- * fork a copy of tcpdump so we can parse packets and print to the screen. We
- * don't allow tcpdump to write directly to the screen, otherwise there
- * will be a garbled up mess. Instead we pipe it back to this program and
- * print when we are ready to do so.
- *
- * parent: this program
- * child: tcpdump
- *
- * pipes are unidirectional, so we need to set up 2 pipes:
- *
- * 1. data from parent to child's STDIN
- * 2. child's STDOUT to this program
- */
- #define NUM_PIPES 2
- /* unidirectional rule for pipes: pipe[0] for read, pipe[1] for writes */
- enum {
- READ_FD,
- WRITE_FD,
- };
- enum {
- PARENT_READ_PIPE,
- PARENT_WRITE_PIPE,
- };
- #define PARENT_READ_FD (tcpdump->pipes[PARENT_READ_PIPE][READ_FD])
- #define PARENT_WRITE_FD (tcpdump->pipes[PARENT_WRITE_PIPE][WRITE_FD])
- #define CHILD_READ_FD (tcpdump->pipes[PARENT_WRITE_PIPE][READ_FD])
- #define CHILD_WRITE_FD (tcpdump->pipes[PARENT_READ_PIPE][WRITE_FD])
- typedef struct tcpdump_s {
- char *filename;
- char *args;
- struct pcap_file_header pfh;
- int pid;
- int pipes[NUM_PIPES][2];
- /* following vars are for figuring out exactly what we send to
- * tcpdump. See TCPDUMP_DEBUG
- */
- #ifdef DEBUG
- int debugfd;
- char debugfile[255];
- #endif
- } tcpdump_t;
- // int tcpdump_init(tcpdump_t *tcpdump);
- int tcpdump_open(tcpdump_t *tcpdump, pcap_t *pcap);
- // int tcpdump_open_live(tcpdump_t *tcpdump, pcap_t *pcap);
- int tcpdump_print(tcpdump_t *tcpdump, struct pcap_pkthdr *pkthdr, const u_char *data);
- void tcpdump_close(tcpdump_t *tcpdump);
|