Generate graphs of broadcasts
[lttv.git] / lttv / lttv / sync / data_structures.h
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
27 enum Direction
28 {
29 OUT,
30 IN,
31 };
32
33 enum EventType
34 {
35 TCP,
36 UDP,
37 TYPE_COUNT // This must be the last field
38 };
39
40 // Stage 1 to 2: These structures are passed from processing to matching modules
41 // TCP events
42 typedef struct
43 {
44 uint32_t saddr, daddr;
45 uint16_t source, dest;
46 } ConnectionKey;
47
48 typedef 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
58 typedef struct
59 {
60 enum Direction direction;
61 SegmentKey* segmentKey;
62 } TCPEvent;
63
64 // UDP events
65 typedef struct
66 {
67 uint32_t saddr, daddr;
68 uint16_t source, dest;
69 uint16_t ulen;
70 uint8_t dataKey[8];
71 } DatagramKey;
72
73 typedef struct
74 {
75 enum Direction direction;
76 DatagramKey* datagramKey;
77 bool unicast;
78 } UDPEvent;
79
80 typedef struct
81 {
82 uint32_t seconds;
83 uint32_t nanosec;
84 } WallTime;
85
86 typedef struct _Event
87 {
88 unsigned long traceNum;
89 uint64_t cpuTime;
90 WallTime wallTime;
91
92 // specific event structures and functions could be in separate files and
93 // type could be an int
94 enum EventType type;
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
101 void (*copy)(const struct _Event* const event, struct _Event** const newEvent);
102 void (*destroy)(struct _Event* const event);
103 } Event;
104
105 // Stage 2 to 3: These structures are passed from matching to analysis modules
106 typedef struct _Message
107 {
108 Event* inE, * outE;
109
110 void (*print)(const struct _Message* const message);
111 } Message;
112
113 typedef struct
114 {
115 Message* message;
116 // Event* acks[]
117 GQueue* acks;
118 } Exchange;
119
120 typedef struct
121 {
122 // Event* events[]
123 GQueue* events;
124 } Broadcast;
125
126 // One set of factors for each trace, this is the result of synchronization
127 typedef struct
128 {
129 double drift, offset;
130 } Factors;
131
132
133 // ConnectionKey-related functions
134 guint ghfConnectionKeyHash(gconstpointer key);
135
136 gboolean gefConnectionKeyEqual(gconstpointer a, gconstpointer b);
137 bool connectionKeyEqual(const ConnectionKey* const a, const ConnectionKey*
138 const b);
139
140 void gdnConnectionKeyDestroy(gpointer data);
141
142 // SegmentKey-related functions
143 guint ghfSegmentKeyHash(gconstpointer key);
144 gboolean gefSegmentKeyEqual(gconstpointer a, gconstpointer b);
145
146 // DatagramKey-related functions
147 guint ghfDatagramKeyHash(gconstpointer key);
148 gboolean gefDatagramKeyEqual(gconstpointer a, gconstpointer b);
149 void gdnDestroyDatagramKey(gpointer data);
150
151 // Event-related functions
152 void gdnDestroyEvent(gpointer data);
153 void copyEvent(const Event* const event, Event** const newEvent);
154 void copyTCPEvent(const Event* const event, Event** const newEvent);
155 void copyUDPEvent(const Event* const event, Event** const newEvent);
156 void destroyEvent(Event* const event);
157 void destroyTCPEvent(Event* const event);
158 void destroyUDPEvent(Event* const event);
159 void gfDestroyEvent(gpointer data, gpointer user_data);
160 double wallTimeSub(const WallTime const* tA, const WallTime const* tB);
161
162 // Message-related functions
163 void printTCPSegment(const Message* const segment);
164 void convertIP(char* const str, const uint32_t addr);
165
166 gint gcfTCPSegmentAckCompare(gconstpointer a, gconstpointer b);
167 bool isAcking(const Message* const ackSegment, const Message* const ackedSegment);
168
169 void gdnTCPSegmentListDestroy(gpointer data);
170 void gfTCPSegmentDestroy(gpointer data, gpointer user_data);
171 void destroyTCPSegment(Message* const segment);
172
173 // Exchange-related functions
174 void destroyTCPExchange(Exchange* const exchange);
175
176 // Broadcast-related functions
177 void gdnDestroyBroadcast(gpointer data);
178 void destroyBroadcast(Broadcast* const broadcast);
179
180 #endif
This page took 0.036629 seconds and 4 git commands to generate.