Generate graphs of broadcasts
[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
f10c27a8
BP
26
27enum Direction
28{
29 OUT,
30 IN,
31};
32
33enum EventType
34{
35 TCP,
36 UDP,
2bd4b3e4 37 TYPE_COUNT // This must be the last field
f10c27a8
BP
38};
39
10341d26
BP
40// Stage 1 to 2: These structures are passed from processing to matching modules
41// TCP events
42typedef struct
43{
44 uint32_t saddr, daddr;
45 uint16_t source, dest;
46} ConnectionKey;
47
48typedef struct
49{
50 ConnectionKey connectionKey;
51 uint8_t ihl;
52 uint16_t tot_len;
53 uint32_t seq, ack_seq;
54 uint8_t doff;
55 uint8_t ack, rst, syn, fin;
56} SegmentKey;
57
10341d26
BP
58typedef struct
59{
60 enum Direction direction;
61 SegmentKey* segmentKey;
62} TCPEvent;
63
64// UDP events
65typedef struct
66{
67 uint32_t saddr, daddr;
f6691532
BP
68 uint16_t source, dest;
69 uint16_t ulen;
10341d26
BP
70 uint8_t dataKey[8];
71} DatagramKey;
72
73typedef struct
74{
75 enum Direction direction;
76 DatagramKey* datagramKey;
77 bool unicast;
78} UDPEvent;
79
76be6fc2
BP
80typedef struct
81{
82 uint32_t seconds;
83 uint32_t nanosec;
84} WallTime;
85
10341d26
BP
86typedef struct _Event
87{
88 unsigned long traceNum;
76be6fc2
BP
89 uint64_t cpuTime;
90 WallTime wallTime;
10341d26
BP
91
92 // specific event structures and functions could be in separate files and
93 // type could be an int
f6691532 94 enum EventType type;
10341d26
BP
95 // event could be a void*, this union is to avoid having to cast
96 union {
97 TCPEvent* tcpEvent;
98 UDPEvent* udpEvent;
99 } event;
100
d4721e1a 101 void (*copy)(const struct _Event* const event, struct _Event** const newEvent);
10341d26
BP
102 void (*destroy)(struct _Event* const event);
103} Event;
104
105// Stage 2 to 3: These structures are passed from matching to analysis modules
106typedef struct _Message
107{
108 Event* inE, * outE;
109
110 void (*print)(const struct _Message* const message);
111} Message;
112
113typedef struct
114{
115 Message* message;
ffa21cfd 116 // Event* acks[]
10341d26
BP
117 GQueue* acks;
118} Exchange;
119
120typedef struct
121{
ffa21cfd 122 // Event* events[]
10341d26
BP
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.029267 seconds and 4 git commands to generate.