2 * VoIP calls summary addition for Wireshark
4 * Copyright 2004, Ericsson , Spain
5 * By Francisco Alcoba <francisco.alcoba@ericsson.com>
7 * based on h323_calls.h
8 * Copyright 2004, Iskratel, Ltd, Kranj
9 * By Miha Jemec <m.jemec@iskratel.si>
11 * H323, RTP and Graph Support
12 * By Alejandro Vaquero, alejandro.vaquero@verso.com
13 * Copyright 2005, Verso Technologies Inc.
15 * Wireshark - Network traffic analyzer
16 * By Gerald Combs <gerald@wireshark.org>
17 * Copyright 1998 Gerald Combs
19 * SPDX-License-Identifier: GPL-2.0-or-later
22 #ifndef __VOIP_CALLS_H__
23 #define __VOIP_CALLS_H__
29 #include "epan/address.h"
30 #include "epan/packet.h"
31 #include "epan/guid-utils.h"
33 #include "epan/tap-voip.h"
34 #include "epan/sequence_analysis.h"
37 * "VoIP Calls" dialog box common routines.
38 * @ingroup main_ui_group
43 #endif /* __cplusplus */
45 /****************************************************************************/
46 extern const char *voip_call_state_name[8];
48 typedef enum _voip_protocol {
66 typedef enum _hash_indexes {
70 extern const char *voip_protocol_name[];
72 typedef enum _flow_show_options
78 /** defines specific SIP data */
80 typedef enum _sip_call_state {
86 typedef struct _sip_calls_info {
87 gchar *call_identifier;
89 sip_call_state sip_state;
92 /** defines specific ISUP data */
93 typedef struct _isup_calls_info {
99 /* defines specific H245 data */
100 typedef struct _h245_address {
101 address h245_address;
105 /** defines specific H323 data */
106 typedef struct _h323_calls_info {
107 e_guid_t *guid; /* Call ID to identify a H225 */
108 GList* h245_list; /**< list of H245 Address and ports for tunneling off calls*/
109 address h225SetupAddr; /**< we use the SETUP H225 IP to determine if packets are forward or reverse */
111 gboolean is_faststart_Setup; /**< if faststart field is included in Setup*/
112 gboolean is_faststart_Proc; /**< if faststart field is included in Proce, Alerting, Progress or Connect*/
113 gboolean is_h245Tunneling;
119 /**< defines specific MGCP data */
120 typedef struct _mgcp_calls_info {
122 gboolean fromEndpoint; /**< true if the call was originated from the Endpoint, false for calls from MGC */
125 /** defines specific ACTRACE ISDN data */
126 typedef struct _actrace_isdn_calls_info {
129 } actrace_isdn_calls_info_t;
131 /** defines specific ACTRACE CAS data */
132 typedef struct _actrace_cas_calls_info {
135 } actrace_cas_calls_info_t;
137 /** defines specific SKINNY data */
138 typedef struct _skinny_calls_info {
140 } skinny_calls_info_t;
142 /** defines info types for graph analysis additional information */
143 typedef enum _ga_info_type {
148 /** defines a voip call */
149 typedef struct _voip_calls_info {
150 voip_call_state call_state;
151 voip_call_active_state call_active_state;
153 gchar *from_identity;
156 void (*free_prot_info)(gpointer);
157 address initial_speaker;
159 voip_protocol protocol;
160 gchar *protocol_name;
163 /**> The frame_data struct holds the frame number and timing information needed. */
164 frame_data *start_fd;
165 nstime_t start_rel_ts;
167 nstime_t stop_rel_ts;
171 * structure that holds the information about all detected calls */
172 /* struct holding all information of the tap */
174 * XXX Most of these are private to voip_calls.c. We might want to
178 typedef struct _voip_calls_tapinfo {
179 tap_reset_cb tap_reset; /**< tap reset callback */
180 tap_packet_cb tap_packet; /**< tap per-packet callback */
181 tap_draw_cb tap_draw; /**< tap draw callback */
182 void *tap_data; /**< data for tap callbacks */
183 int ncalls; /**< number of call */
184 GQueue* callsinfos; /**< queue with all calls (voip_calls_info_t) */
185 GHashTable* callsinfo_hashtable[1]; /**< array of hashes per voip protocol (voip_calls_info_t); currently only the one for SIP is used */
186 int npackets; /**< total number of packets of all calls */
187 voip_calls_info_t *filter_calls_fwd; /**< used as filter in some tap modes */
191 seq_analysis_info_t *graph_analysis;
192 epan_t *session; /**< epan session */
193 int nrtpstreams; /**< number of rtp streams */
194 GList* rtpstream_list; /**< list of rtpstream_info_t */
195 guint32 rtp_evt_frame_num;
197 gboolean rtp_evt_end;
199 guint32 sdp_frame_num;
203 guint32 mtp3_frame_num;
204 struct _h245_labels *h245_labels; /**< H.245 labels */
205 gchar *q931_calling_number;
206 gchar *q931_called_number;
207 guint8 q931_cause_value;
209 guint32 q931_frame_num;
210 guint32 h225_frame_num;
211 guint16 h225_call_num;
212 int h225_cstype; /* XXX actually an enum */
213 gboolean h225_is_faststart;
214 guint32 sip_frame_num;
215 guint32 actrace_frame_num;
216 gint32 actrace_trunk;
217 gint32 actrace_direction;
218 flow_show_options fs_option;
220 gboolean apply_display_filter;
221 } voip_calls_tapinfo_t;
224 #define VOIP_CALLS_DEBUG(...) { \
225 char *VOIP_CALLS_DEBUG_MSG = g_strdup_printf(__VA_ARGS__); \
226 ws_warning("voip_calls: %s:%d %s", G_STRFUNC, __LINE__, VOIP_CALLS_DEBUG_MSG); \
227 g_free(VOIP_CALLS_DEBUG_MSG); \
230 #define VOIP_CALLS_DEBUG(...)
233 /****************************************************************************/
237 * Registers the voip_calls tap listeners (if not already done).
238 * From that point on, the calls list will be updated with every redissection.
239 * This function is also the entry point for the initialization routine of the tap system.
240 * So whenever voip_calls.c is added to the list of WIRESHARK_TAP_SRCs, the tap will be registered on startup.
241 * If not, it will be registered on demand by the voip_calls functions that need it.
243 void voip_calls_init_all_taps(voip_calls_tapinfo_t *tap_id_base);
246 * Removes the voip_calls tap listener (if not already done)
247 * From that point on, the voip calls list won't be updated any more.
249 void voip_calls_remove_all_tap_listeners(voip_calls_tapinfo_t *tap_id_base);
252 * Cleans up memory of voip calls tap.
254 void voip_calls_reset_all_taps(voip_calls_tapinfo_t *tapinfo);
257 * Frees one callsinfo
260 voip_calls_free_callsinfo(voip_calls_info_t *callsinfo);
264 #endif /* __cplusplus */
266 #endif /* __VOIP_CALLS_H__ */