source: lib/format_legacy.c @ bb75d10

4.0.1-hotfixescachetimestampsdevelopdpdk-ndagetsilivegetfragoffhelplibtrace4ndag_formatpfringrc-4.0.1rc-4.0.2rc-4.0.3rc-4.0.4ringdecrementfixringperformanceringtimestampfixes
Last change on this file since bb75d10 was bb75d10, checked in by Perry Lorier <perry@…>, 15 years ago
  • Support Demoting PoS traces
  • Ignore the (incorrect) ethertype field of the legacypos: traces
  • Correctly calculate the wire length for some of the legacy trace types
  • Support pausing and restarting legacy traces
  • Property mode set to 100644
File size: 8.9 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#include <sys/stat.h>
40#include <assert.h>
41#include <errno.h>
42#include <fcntl.h>
43#include <stdio.h>
44#include <string.h>
45#include <stdlib.h>
46
47#ifdef WIN32
48#  include <io.h>
49#  include <share.h>
50#  define snprintf sprintf_s
51#endif
52
53
54/* Catch undefined O_LARGEFILE on *BSD etc */
55#ifndef O_LARGEFILE
56#  define O_LARGEFILE 0
57#endif
58
59#define DATA(x) ((struct legacy_format_data_t *)x->format_data)
60
61#define INPUT DATA(libtrace)->input
62
63struct legacy_format_data_t {
64        union {
65                int fd;
66                libtrace_io_t *file;
67        } input;
68};
69
70static int legacyeth_get_framing_length(const libtrace_packet_t *packet UNUSED) 
71{
72        return sizeof(legacy_ether_t);
73}
74
75static int legacypos_get_framing_length(const libtrace_packet_t *packet UNUSED) 
76{
77        return sizeof(legacy_pos_t);
78}
79
80static int legacyatm_get_framing_length(const libtrace_packet_t *packet UNUSED) 
81{
82        return sizeof(legacy_cell_t);
83}
84
85static int erf_init_input(libtrace_t *libtrace) 
86{
87        libtrace->format_data = malloc(sizeof(struct legacy_format_data_t));
88
89        return 0;
90}
91
92static int erf_start_input(libtrace_t *libtrace)
93{
94        if (DATA(libtrace)->input.file)
95                return 0;
96
97        DATA(libtrace)->input.file = trace_open_file(libtrace);
98
99        if (DATA(libtrace)->input.file)
100                return 0;
101
102        return -1;
103}
104
105static int erf_fin_input(libtrace_t *libtrace) {
106        libtrace_io_close(INPUT.file);
107        free(libtrace->format_data);
108        return 0;
109}
110
111static int legacy_read_packet(libtrace_t *libtrace, libtrace_packet_t *packet) {
112        int numbytes;
113        void *buffer;
114
115        if (!packet->buffer || packet->buf_control == TRACE_CTRL_EXTERNAL) {
116                packet->buf_control = TRACE_CTRL_PACKET;
117                packet->buffer=malloc(LIBTRACE_PACKET_BUFSIZE);
118        }
119        buffer = packet->buffer;
120
121        switch(libtrace->format->type) {
122                case TRACE_FORMAT_LEGACY_ATM:
123                        packet->type = RT_DATA_LEGACY_ATM;
124                        break;
125                case TRACE_FORMAT_LEGACY_POS:
126                        packet->type = RT_DATA_LEGACY_POS;
127                        break;
128                case TRACE_FORMAT_LEGACY_ETH:
129                        packet->type = RT_DATA_LEGACY_ETH;
130                        break;
131                default:
132                        assert(0);
133        }
134       
135        if ((numbytes=libtrace_io_read(INPUT.file,
136                                        buffer,
137                                        64)) != 64) {
138                if (numbytes!=0) {
139                        trace_set_err(libtrace,errno,"read(%s)",libtrace->uridata);
140                }
141                return numbytes;
142        }
143       
144        packet->header = packet->buffer;
145        packet->payload = (void*)((char*)packet->buffer + 
146                libtrace->format->get_framing_length(packet));
147       
148        return 64;
149       
150}
151
152static libtrace_linktype_t legacypos_get_link_type(const libtrace_packet_t *packet UNUSED) {
153        return TRACE_TYPE_POS;
154}
155
156static libtrace_linktype_t legacyatm_get_link_type(const libtrace_packet_t *packet UNUSED) {
157        return TRACE_TYPE_ATM;
158}
159
160static libtrace_linktype_t legacyeth_get_link_type(const libtrace_packet_t *packet UNUSED) {
161        return TRACE_TYPE_ETH;
162}
163
164static int legacy_get_capture_length(const libtrace_packet_t *packet UNUSED) {
165        return 64;
166}
167
168static int legacypos_get_wire_length(const libtrace_packet_t *packet) {
169        legacy_pos_t *lpos = (legacy_pos_t *)packet->header;
170        assert(ntohl(lpos->wlen)>0);
171        return ntohl(lpos->wlen);
172}
173
174static int legacyatm_get_wire_length(const libtrace_packet_t *packet UNUSED) {
175        return 53;
176}
177
178static int legacyeth_get_wire_length(const libtrace_packet_t *packet) {
179        legacy_ether_t *leth = (legacy_ether_t *)packet->header;
180        return ntohs(leth->wlen);
181}
182
183static uint64_t legacy_get_erf_timestamp(const libtrace_packet_t *packet)
184{
185        legacy_ether_t *legacy = (legacy_ether_t*)packet->header;
186        return legacy->ts;
187} 
188
189static void legacypos_help() {
190        printf("legacypos format module: $Revision$\n");
191        printf("Supported input URIs:\n");
192        printf("\tlegacypos:/path/to/file\t(uncompressed)\n");
193        printf("\tlegacypos:/path/to/file.gz\t(gzip-compressed)\n");
194        printf("\tlegacypos:-\t(stdin, either compressed or not)\n");
195        printf("\n");
196        printf("\te.g.: legacypos:/tmp/trace.gz\n");
197        printf("\n");
198}
199
200static void legacyatm_help() {
201        printf("legacyatm format module: $Revision$\n");
202        printf("Supported input URIs:\n");
203        printf("\tlegacyatm:/path/to/file\t(uncompressed)\n");
204        printf("\tlegacyatm:/path/to/file.gz\t(gzip-compressed)\n");
205        printf("\tlegacyatm:-\t(stdin, either compressed or not)\n");
206        printf("\n");
207        printf("\te.g.: legacyatm:/tmp/trace.gz\n");
208        printf("\n");
209}
210
211static void legacyeth_help() {
212        printf("legacyeth format module: $Revision$\n");
213        printf("Supported input URIs:\n");
214        printf("\tlegacyeth:/path/to/file\t(uncompressed)\n");
215        printf("\tlegacyeth:/path/to/file.gz\t(gzip-compressed)\n");
216        printf("\tlegacyeth:-\t(stdin, either compressed or not)\n");
217        printf("\n");
218        printf("\te.g.: legacyeth:/tmp/trace.gz\n");
219        printf("\n");
220}
221
222static struct libtrace_format_t legacyatm = {
223        "legacyatm",
224        "$Id$",
225        TRACE_FORMAT_LEGACY_ATM,
226        erf_init_input,                 /* init_input */       
227        NULL,                           /* config_input */
228        erf_start_input,                /* start_input */
229        NULL,                           /* pause_input */
230        NULL,                           /* init_output */
231        NULL,                           /* config_output */
232        NULL,                           /* start_output */
233        erf_fin_input,                  /* fin_input */
234        NULL,                           /* fin_output */
235        legacy_read_packet,             /* read_packet */
236        NULL,                           /* fin_packet */
237        NULL,                           /* write_packet */
238        legacyatm_get_link_type,        /* get_link_type */
239        NULL,                           /* get_direction */
240        NULL,                           /* set_direction */
241        legacy_get_erf_timestamp,       /* get_erf_timestamp */
242        NULL,                           /* get_timeval */
243        NULL,                           /* get_seconds */
244        NULL,                           /* seek_erf */
245        NULL,                           /* seek_timeval */
246        NULL,                           /* seek_seconds */
247        legacy_get_capture_length,      /* get_capture_length */
248        legacyatm_get_wire_length,      /* get_wire_length */
249        legacyatm_get_framing_length,   /* get_framing_length */
250        NULL,                           /* set_capture_length */
251        NULL,                           /* get_fd */
252        trace_event_trace,              /* trace_event */
253        legacyatm_help,                 /* help */
254        NULL                            /* next pointer */
255};
256
257static struct libtrace_format_t legacyeth = {
258        "legacyeth",
259        "$Id$",
260        TRACE_FORMAT_LEGACY_ETH,
261        erf_init_input,                 /* init_input */       
262        NULL,                           /* config_input */
263        erf_start_input,                /* start_input */
264        NULL,                           /* pause_input */
265        NULL,                           /* init_output */
266        NULL,                           /* config_output */
267        NULL,                           /* start_output */
268        erf_fin_input,                  /* fin_input */
269        NULL,                           /* fin_output */
270        legacy_read_packet,             /* read_packet */
271        NULL,                           /* fin_packet */
272        NULL,                           /* write_packet */
273        legacyeth_get_link_type,        /* get_link_type */
274        NULL,                           /* get_direction */
275        NULL,                           /* set_direction */
276        legacy_get_erf_timestamp,       /* get_erf_timestamp */
277        NULL,                           /* get_timeval */
278        NULL,                           /* get_seconds */
279        NULL,                           /* seek_erf */
280        NULL,                           /* seek_timeval */
281        NULL,                           /* seek_seconds */
282        legacy_get_capture_length,      /* get_capture_length */
283        legacyeth_get_wire_length,      /* get_wire_length */
284        legacyeth_get_framing_length,   /* get_framing_length */
285        NULL,                           /* set_capture_length */
286        NULL,                           /* get_fd */
287        trace_event_trace,              /* trace_event */
288        legacyeth_help,                 /* help */
289        NULL                            /* next pointer */
290};
291
292static struct libtrace_format_t legacypos = {
293        "legacypos",
294        "$Id$",
295        TRACE_FORMAT_LEGACY_POS,
296        erf_init_input,                 /* init_input */       
297        NULL,                           /* config_input */
298        erf_start_input,                /* start_input */
299        NULL,                           /* pause_input */
300        NULL,                           /* init_output */
301        NULL,                           /* config_output */
302        NULL,                           /* start_output */
303        erf_fin_input,                  /* fin_input */
304        NULL,                           /* fin_output */
305        legacy_read_packet,             /* read_packet */
306        NULL,                           /* fin_packet */
307        NULL,                           /* write_packet */
308        legacypos_get_link_type,        /* get_link_type */
309        NULL,                           /* get_direction */
310        NULL,                           /* set_direction */
311        legacy_get_erf_timestamp,       /* get_erf_timestamp */
312        NULL,                           /* get_timeval */
313        NULL,                           /* get_seconds */
314        NULL,                           /* seek_erf */
315        NULL,                           /* seek_timeval */
316        NULL,                           /* seek_seconds */
317        legacy_get_capture_length,      /* get_capture_length */
318        legacypos_get_wire_length,      /* get_wire_length */
319        legacypos_get_framing_length,   /* get_framing_length */
320        NULL,                           /* set_capture_length */
321        NULL,                           /* get_fd */
322        trace_event_trace,              /* trace_event */
323        legacypos_help,                 /* help */
324        NULL,                           /* next pointer */
325};
326
327       
328void legacy_constructor() {
329        register_format(&legacypos);
330        register_format(&legacyeth);
331        register_format(&legacyatm);
332}
Note: See TracBrowser for help on using the repository browser.