Add a module to distribute messages to many analysis modules
[lttv.git] / lttv / lttv / sync / data_structures.h
CommitLineData
10341d26
BP
1/* This file is part of the Linux Trace Toolkit viewer
2 * Copyright (C) 2009 Benjamin Poirier <benjamin.poirier@polymtl.ca>
3 *
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License Version 2 as
6 * published by the Free Software Foundation;
7 *
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 *
13 * You should have received a copy of the GNU General Public License
14 * along with this program; if not, write to the Free Software
15 * Foundation, Inc., 59 Temple Place - Suite 330, Boston,
16 * MA 02111-1307, USA.
17 */
18
19#ifndef DATA_STRUCTURES_H
20#define DATA_STRUCTURES_H
21
22#include <glib.h>
23#include <stdbool.h>
24#include <stdint.h>
25
26#include <ltt/ltt.h>
27
f10c27a8
BP
28
29enum Direction
30{
31 OUT,
32 IN,
33};
34
35enum EventType
36{
37 TCP,
38 UDP,
2bd4b3e4 39 TYPE_COUNT // This must be the last field
f10c27a8
BP
40};
41
10341d26
BP
42// Stage 1 to 2: These structures are passed from processing to matching modules
43// TCP events
44typedef struct
45{
46 uint32_t saddr, daddr;
47 uint16_t source, dest;
48} ConnectionKey;
49
50typedef struct
51{
52 ConnectionKey connectionKey;
53 uint8_t ihl;
54 uint16_t tot_len;
55 uint32_t seq, ack_seq;
56 uint8_t doff;
57 uint8_t ack, rst, syn, fin;
58} SegmentKey;
59
10341d26
BP
60typedef struct
61{
62 enum Direction direction;
63 SegmentKey* segmentKey;
64} TCPEvent;
65
66// UDP events
67typedef struct
68{
69 uint32_t saddr, daddr;
f6691532
BP
70 uint16_t source, dest;
71 uint16_t ulen;
10341d26
BP
72 uint8_t dataKey[8];
73} DatagramKey;
74
75typedef struct
76{
77 enum Direction direction;
78 DatagramKey* datagramKey;
79 bool unicast;
80} UDPEvent;
81
76be6fc2
BP
82typedef struct
83{
84 uint32_t seconds;
85 uint32_t nanosec;
86} WallTime;
87
10341d26
BP
88typedef struct _Event
89{
90 unsigned long traceNum;
76be6fc2
BP
91 uint64_t cpuTime;
92 WallTime wallTime;
10341d26
BP
93
94 // specific event structures and functions could be in separate files and
95 // type could be an int
f6691532 96 enum EventType type;
10341d26
BP
97 // event could be a void*, this union is to avoid having to cast
98 union {
99 TCPEvent* tcpEvent;
100 UDPEvent* udpEvent;
101 } event;
102
d4721e1a 103 void (*copy)(const struct _Event* const event, struct _Event** const newEvent);
10341d26
BP
104 void (*destroy)(struct _Event* const event);
105} Event;
106
107// Stage 2 to 3: These structures are passed from matching to analysis modules
108typedef struct _Message
109{
110 Event* inE, * outE;
111
112 void (*print)(const struct _Message* const message);
113} Message;
114
115typedef struct
116{
117 Message* message;
118 GQueue* acks;
119} Exchange;
120
121typedef struct
122{
123 GQueue* events;
124} Broadcast;
125
126// One set of factors for each trace, this is the result of synchronization
127typedef struct
128{
129 double drift, offset;
130} Factors;
131
132
133// ConnectionKey-related functions
134guint ghfConnectionKeyHash(gconstpointer key);
135
136gboolean gefConnectionKeyEqual(gconstpointer a, gconstpointer b);
137bool connectionKeyEqual(const ConnectionKey* const a, const ConnectionKey*
138 const b);
139
140void gdnConnectionKeyDestroy(gpointer data);
141
142// SegmentKey-related functions
143guint ghfSegmentKeyHash(gconstpointer key);
144gboolean gefSegmentKeyEqual(gconstpointer a, gconstpointer b);
145
f10c27a8
BP
146// DatagramKey-related functions
147guint ghfDatagramKeyHash(gconstpointer key);
148gboolean gefDatagramKeyEqual(gconstpointer a, gconstpointer b);
149void gdnDestroyDatagramKey(gpointer data);
150
10341d26
BP
151// Event-related functions
152void gdnDestroyEvent(gpointer data);
d4721e1a
BP
153void copyEvent(const Event* const event, Event** const newEvent);
154void copyTCPEvent(const Event* const event, Event** const newEvent);
155void copyUDPEvent(const Event* const event, Event** const newEvent);
10341d26
BP
156void destroyEvent(Event* const event);
157void destroyTCPEvent(Event* const event);
158void destroyUDPEvent(Event* const event);
f6691532 159void gfDestroyEvent(gpointer data, gpointer user_data);
76be6fc2 160double wallTimeSub(const WallTime const* tA, const WallTime const* tB);
10341d26
BP
161
162// Message-related functions
163void printTCPSegment(const Message* const segment);
164void convertIP(char* const str, const uint32_t addr);
165
166gint gcfTCPSegmentAckCompare(gconstpointer a, gconstpointer b);
167bool isAcking(const Message* const ackSegment, const Message* const ackedSegment);
168
169void gdnTCPSegmentListDestroy(gpointer data);
170void gfTCPSegmentDestroy(gpointer data, gpointer user_data);
171void destroyTCPSegment(Message* const segment);
172
173// Exchange-related functions
174void destroyTCPExchange(Exchange* const exchange);
f6691532
BP
175
176// Broadcast-related functions
177void gdnDestroyBroadcast(gpointer data);
178void destroyBroadcast(Broadcast* const broadcast);
179
10341d26 180#endif
This page took 0.030082 seconds and 4 git commands to generate.