source: lib/format_legacy.c @ c1db742

4.0.1-hotfixescachetimestampsdevelopdpdk-ndagetsilivegetfragoffhelplibtrace4ndag_formatpfringrc-4.0.1rc-4.0.2rc-4.0.3rc-4.0.4ringdecrementfixringperformanceringtimestampfixes
Last change on this file since c1db742 was c1db742, checked in by Perry Lorier <perry@…>, 15 years ago

rename PACKET/EXTERNAL to TRACE_CTRL_ to avoid symbol clashes on windows.
fix some c++ style comments that have snuck in somewhere along the lines

  • Property mode set to 100644
File size: 9.5 KB
Line 
1/*
2 * This file is part of libtrace
3 *
4 * Copyright (c) 2004 The University of Waikato, Hamilton, New Zealand.
5 * Authors: Daniel Lawson
6 *          Perry Lorier
7 *         
8 * All rights reserved.
9 *
10 * This code has been developed by the University of Waikato WAND
11 * research group. For further information please see http://www.wand.net.nz/
12 *
13 * libtrace is free software; you can redistribute it and/or modify
14 * it under the terms of the GNU General Public License as published by
15 * the Free Software Foundation; either version 2 of the License, or
16 * (at your option) any later version.
17 *
18 * libtrace is distributed in the hope that it will be useful,
19 * but WITHOUT ANY WARRANTY; without even the implied warranty of
20 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
21 * GNU General Public License for more details.
22 *
23 * You should have received a copy of the GNU General Public License
24 * along with libtrace; if not, write to the Free Software
25 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
26 *
27 * $Id$
28 *
29 */
30#define _GNU_SOURCE
31
32#include "config.h"
33#include "common.h"
34#include "libtrace.h"
35#include "libtrace_int.h"
36#include "format_helper.h"
37#include "parse_cmd.h"
38
39#ifdef HAVE_INTTYPES_H
40#  include <inttypes.h>
41#else
42#  error "Can't find inttypes.h - this needs to be fixed"
43#endif
44
45#ifdef HAVE_STDDEF_H
46#  include <stddef.h>
47#else
48# error "Can't find stddef.h - do you define ptrdiff_t elsewhere?"
49#endif
50#include <sys/types.h>
51#include <sys/socket.h>
52#include <sys/un.h>
53#include <sys/mman.h>
54#include <sys/stat.h>
55#include <unistd.h>
56#include <assert.h>
57#include <errno.h>
58#include <netdb.h>
59#include <fcntl.h>
60#include <getopt.h>
61#include <stdio.h>
62#include <string.h>
63#include <stdlib.h>
64
65
66#define COLLECTOR_PORT 3435
67
68/* Catch undefined O_LARGEFILE on *BSD etc */
69#ifndef O_LARGEFILE
70#  define O_LARGEFILE 0
71#endif
72
73static struct libtrace_format_t legacypos;
74static struct libtrace_format_t legacyeth;
75static struct libtrace_format_t legacyatm;
76
77#define INPUT libtrace->format_data->input
78#define OUTPUT libtrace->format_data->output
79#if HAVE_DAG
80#define DAG libtrace->format_data->dag
81#endif
82#define OPTIONS libtrace->format_data->options
83struct libtrace_format_data_t {
84        union {
85                struct {
86                        char *hostname;
87                        short port;
88                } rt;
89                char *path;             
90        } conn_info;
91        union {
92                int fd;
93#if HAVE_ZLIB
94                gzFile *file;
95#else   
96                /*FILE  *file; */
97                int file;
98#endif
99        } input;
100};
101
102struct libtrace_format_data_out_t {
103        union {
104                struct {
105                        char *hostname;
106                        short port;
107                } rt;
108                char *path;
109        } conn_info;
110};
111
112
113static int legacyeth_get_framing_length(const struct libtrace_packet_t *packet UNUSED) 
114{
115        return sizeof(legacy_ether_t);
116}
117
118static int legacypos_get_framing_length(const struct libtrace_packet_t *packet UNUSED) 
119{
120        return sizeof(legacy_pos_t);
121}
122
123static int legacyatm_get_framing_length(const struct libtrace_packet_t *packet UNUSED) 
124{
125        return sizeof(legacy_cell_t);
126}
127
128static int erf_init_input(struct libtrace_t *libtrace) 
129{
130        libtrace->format_data = (struct libtrace_format_data_t *)
131                malloc(sizeof(struct libtrace_format_data_t));
132
133        libtrace->format_data->input.file = trace_open_file(libtrace);
134
135        if (libtrace->format_data->input.file)
136                return 1;
137
138        return 0;
139
140}
141
142static int erf_fin_input(struct libtrace_t *libtrace) {
143        LIBTRACE_CLOSE(INPUT.file);
144        free(libtrace->format_data);
145        return 0;
146}
147
148static int legacy_read_packet(struct libtrace_t *libtrace, struct libtrace_packet_t *packet) {
149        int numbytes;
150        void *buffer;
151
152        if (!packet->buffer || packet->buf_control == TRACE_CTRL_EXTERNAL) {
153                packet->buf_control = TRACE_CTRL_PACKET;
154                packet->buffer=malloc(LIBTRACE_PACKET_BUFSIZE);
155        }
156        buffer = packet->buffer;
157       
158        if ((numbytes=LIBTRACE_READ(INPUT.file,
159                                        buffer,
160                                        64)) == -1) {
161                trace_set_err(errno,"read(%s)",libtrace->uridata);
162                return -1;
163        }
164        packet->size = 64;
165       
166        packet->header = packet->buffer;
167        packet->payload = (void*)((char*)packet->buffer + 
168                packet->trace->format->get_framing_length(packet));
169       
170        return 64;
171       
172}
173
174static libtrace_linktype_t legacypos_get_link_type(const struct libtrace_packet_t *packet UNUSED) {
175        return TRACE_TYPE_LEGACY_POS;
176}
177
178static libtrace_linktype_t legacyatm_get_link_type(const struct libtrace_packet_t *packet UNUSED) {
179        return TRACE_TYPE_LEGACY_ATM;
180}
181
182static libtrace_linktype_t legacyeth_get_link_type(const struct libtrace_packet_t *packet UNUSED) {
183        return TRACE_TYPE_LEGACY_ETH;
184}
185
186static int legacy_get_capture_length(const struct libtrace_packet_t *packet __attribute__((unused))) {
187        return 64;
188}
189
190static int legacypos_get_wire_length(const struct libtrace_packet_t *packet) {
191        legacy_pos_t *lpos = (legacy_pos_t *)packet->header;
192        return ntohs(lpos->wlen);
193}
194
195static int legacyatm_get_wire_length(const struct libtrace_packet_t *packet UNUSED) {
196        return 53;
197}
198
199static int legacyeth_get_wire_length(const struct libtrace_packet_t *packet) {
200        legacy_ether_t *leth = (legacy_ether_t *)packet->header;
201        return ntohs(leth->wlen);
202}
203
204static uint64_t legacy_get_erf_timestamp(const struct libtrace_packet_t *packet)
205{
206        legacy_ether_t *legacy = (legacy_ether_t*)packet->header;
207        return legacy->ts;
208} 
209
210static void legacypos_help() {
211        printf("legacypos format module: $Revision$\n");
212        printf("Supported input URIs:\n");
213        printf("\tlegacypos:/path/to/file\t(uncompressed)\n");
214        printf("\tlegacypos:/path/to/file.gz\t(gzip-compressed)\n");
215        printf("\tlegacypos:-\t(stdin, either compressed or not)\n");
216        printf("\n");
217        printf("\te.g.: legacypos:/tmp/trace.gz\n");
218        printf("\n");
219}
220
221static void legacyatm_help() {
222        printf("legacyatm format module: $Revision$\n");
223        printf("Supported input URIs:\n");
224        printf("\tlegacyatm:/path/to/file\t(uncompressed)\n");
225        printf("\tlegacyatm:/path/to/file.gz\t(gzip-compressed)\n");
226        printf("\tlegacyatm:-\t(stdin, either compressed or not)\n");
227        printf("\n");
228        printf("\te.g.: legacyatm:/tmp/trace.gz\n");
229        printf("\n");
230}
231
232static void legacyeth_help() {
233        printf("legacyeth format module: $Revision$\n");
234        printf("Supported input URIs:\n");
235        printf("\tlegacyeth:/path/to/file\t(uncompressed)\n");
236        printf("\tlegacyeth:/path/to/file.gz\t(gzip-compressed)\n");
237        printf("\tlegacyeth:-\t(stdin, either compressed or not)\n");
238        printf("\n");
239        printf("\te.g.: legacyeth:/tmp/trace.gz\n");
240        printf("\n");
241}
242
243static struct libtrace_format_t legacyatm = {
244        "legacyatm",
245        "$Id$",
246        TRACE_FORMAT_LEGACY_ATM,
247        erf_init_input,                 /* init_input */       
248        NULL,                           /* config_input */
249        NULL,                           /* start_input */
250        NULL,                           /* pause_input */
251        NULL,                           /* init_output */
252        NULL,                           /* config_output */
253        NULL,                           /* start_output */
254        erf_fin_input,                  /* fin_input */
255        NULL,                           /* fin_output */
256        legacy_read_packet,             /* read_packet */
257        NULL,                           /* write_packet */
258        legacyatm_get_link_type,        /* get_link_type */
259        NULL,                           /* get_direction */
260        NULL,                           /* set_direction */
261        legacy_get_erf_timestamp,       /* get_erf_timestamp */
262        NULL,                           /* get_timeval */
263        NULL,                           /* get_seconds */
264        NULL,                           /* seek_erf */
265        NULL,                           /* seek_timeval */
266        NULL,                           /* seek_seconds */
267        legacy_get_capture_length,      /* get_capture_length */
268        legacyatm_get_wire_length,      /* get_wire_length */
269        legacyatm_get_framing_length,   /* get_framing_length */
270        NULL,                           /* set_capture_length */
271        NULL,                           /* get_fd */
272        trace_event_trace,              /* trace_event */
273        legacyatm_help                  /* help */
274};
275
276static struct libtrace_format_t legacyeth = {
277        "legacyeth",
278        "$Id$",
279        TRACE_FORMAT_LEGACY_ETH,
280        erf_init_input,                 /* init_input */       
281        NULL,                           /* config_input */
282        NULL,                           /* start_input */
283        NULL,                           /* pause_input */
284        NULL,                           /* init_output */
285        NULL,                           /* config_output */
286        NULL,                           /* start_output */
287        erf_fin_input,                  /* fin_input */
288        NULL,                           /* fin_output */
289        legacy_read_packet,             /* read_packet */
290        NULL,                           /* write_packet */
291        legacyeth_get_link_type,        /* get_link_type */
292        NULL,                           /* get_direction */
293        NULL,                           /* set_direction */
294        legacy_get_erf_timestamp,       /* get_erf_timestamp */
295        NULL,                           /* get_timeval */
296        NULL,                           /* get_seconds */
297        NULL,                           /* seek_erf */
298        NULL,                           /* seek_timeval */
299        NULL,                           /* seek_seconds */
300        legacy_get_capture_length,      /* get_capture_length */
301        legacyeth_get_wire_length,      /* get_wire_length */
302        legacyeth_get_framing_length,   /* get_framing_length */
303        NULL,                           /* set_capture_length */
304        NULL,                           /* get_fd */
305        trace_event_trace,              /* trace_event */
306        legacyeth_help                  /* help */
307};
308
309static struct libtrace_format_t legacypos = {
310        "legacypos",
311        "$Id$",
312        TRACE_FORMAT_LEGACY_POS,
313        erf_init_input,                 /* init_input */       
314        NULL,                           /* config_input */
315        NULL,                           /* start_input */
316        NULL,                           /* pause_input */
317        NULL,                           /* init_output */
318        NULL,                           /* config_output */
319        NULL,                           /* start_output */
320        erf_fin_input,                  /* fin_input */
321        NULL,                           /* fin_output */
322        legacy_read_packet,             /* read_packet */
323        NULL,                           /* write_packet */
324        legacypos_get_link_type,        /* get_link_type */
325        NULL,                           /* get_direction */
326        NULL,                           /* set_direction */
327        legacy_get_erf_timestamp,       /* get_erf_timestamp */
328        NULL,                           /* get_timeval */
329        NULL,                           /* get_seconds */
330        NULL,                           /* seek_erf */
331        NULL,                           /* seek_timeval */
332        NULL,                           /* seek_seconds */
333        legacy_get_capture_length,      /* get_capture_length */
334        legacypos_get_wire_length,      /* get_wire_length */
335        legacypos_get_framing_length,   /* get_framing_length */
336        NULL,                           /* set_capture_length */
337        NULL,                           /* get_fd */
338        trace_event_trace,              /* trace_event */
339        legacypos_help                  /* help */
340};
341
342       
343static void __attribute__((constructor)) legacy_constructor() {
344        register_format(&legacypos);
345        register_format(&legacyeth);
346        register_format(&legacyatm);
347}
Note: See TracBrowser for help on using the repository browser.