2000-04-21 01:45:58 +00:00
|
|
|
/* packet-rtp.h
|
|
|
|
*
|
2000-10-19 06:45:11 +00:00
|
|
|
* Routines for RTP dissection
|
|
|
|
* RTP = Real time Transport Protocol
|
2001-06-12 06:32:39 +00:00
|
|
|
*
|
2004-07-18 00:24:25 +00:00
|
|
|
* $Id$
|
2002-08-28 21:04:11 +00:00
|
|
|
*
|
2000-10-19 06:45:11 +00:00
|
|
|
* Copyright 2000, Philips Electronics N.V.
|
|
|
|
* Written by Andreas Sikkema <andreas.sikkema@philips.com>
|
2000-04-21 01:45:58 +00:00
|
|
|
*
|
2006-05-21 04:49:01 +00:00
|
|
|
* Wireshark - Network traffic analyzer
|
|
|
|
* By Gerald Combs <gerald@wireshark.org>
|
2000-04-21 01:45:58 +00:00
|
|
|
* Copyright 1998 Gerald Combs
|
2002-08-28 21:04:11 +00:00
|
|
|
*
|
2000-04-21 01:45:58 +00:00
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
2002-08-28 21:04:11 +00:00
|
|
|
*
|
2000-04-21 01:45:58 +00:00
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
2002-08-28 21:04:11 +00:00
|
|
|
*
|
2000-04-21 01:45:58 +00:00
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
|
|
*/
|
|
|
|
|
2003-03-06 20:35:12 +00:00
|
|
|
struct _rtp_info {
|
2004-10-17 22:14:47 +00:00
|
|
|
unsigned int info_version;
|
2003-11-20 23:34:31 +00:00
|
|
|
gboolean info_padding_set;
|
|
|
|
gboolean info_marker_set;
|
2009-05-19 18:42:33 +00:00
|
|
|
gboolean info_is_video;
|
2003-11-20 23:34:31 +00:00
|
|
|
unsigned int info_payload_type;
|
|
|
|
unsigned int info_padding_count;
|
|
|
|
guint16 info_seq_num;
|
|
|
|
guint32 info_timestamp;
|
|
|
|
guint32 info_sync_src;
|
|
|
|
guint info_data_len; /* length of raw rtp data as reported */
|
2004-01-31 09:48:26 +00:00
|
|
|
gboolean info_all_data_present; /* FALSE if data is cut off */
|
2003-11-20 23:34:31 +00:00
|
|
|
guint info_payload_offset; /* start of payload relative to info_data */
|
|
|
|
guint info_payload_len; /* length of payload (incl padding) */
|
2007-11-02 07:43:49 +00:00
|
|
|
gboolean info_is_srtp;
|
2005-02-05 11:08:24 +00:00
|
|
|
guint32 info_setup_frame_num; /* the frame num of the packet that set this RTP connection */
|
2003-11-20 23:34:31 +00:00
|
|
|
const guint8* info_data; /* pointer to raw rtp data */
|
2005-11-05 21:38:22 +00:00
|
|
|
gchar *info_payload_type_str;
|
2003-11-20 23:34:31 +00:00
|
|
|
/*
|
|
|
|
* info_data: pointer to raw rtp data = header + payload incl. padding.
|
|
|
|
* That should be safe because the "epan_dissect_t" constructed for the packet
|
|
|
|
* has not yet been freed when the taps are called.
|
|
|
|
* (destroying the "epan_dissect_t" will end up freeing all the tvbuffs
|
|
|
|
* and hence invalidating pointers to their data).
|
|
|
|
* See "add_packet_to_packet_list()" for details.
|
|
|
|
*/
|
2003-03-06 20:35:12 +00:00
|
|
|
};
|
|
|
|
|
2007-08-21 07:23:34 +00:00
|
|
|
/* definitions for SRTP dissection */
|
|
|
|
|
|
|
|
/* Encryption algorithms */
|
|
|
|
#define SRTP_ENC_ALG_NULL 0 /* non-encrypted SRTP payload - may still be authenticated */
|
|
|
|
#define SRTP_ENC_ALG_AES_CM 1 /* SRTP default algorithm */
|
|
|
|
#define SRTP_ENC_ALG_AES_F8 2
|
|
|
|
|
|
|
|
/* Authentication algorithms */
|
|
|
|
#define SRTP_AUTH_ALG_NONE 0 /* no auth tag in SRTP/RTP payload */
|
|
|
|
#define SRTP_AUTH_ALG_HMAC_SHA1 1 /* SRTP default algorithm */
|
|
|
|
|
|
|
|
|
|
|
|
#if 0 /* these are only needed once the dissector include the crypto functions to decrypt and/or authenticate */
|
|
|
|
struct srtp_key_info
|
|
|
|
{
|
|
|
|
guint8 *master_key; /* pointer to an se_alloc'ed master key */
|
|
|
|
guint8 *master_salt; /* pointer to an se_alloc'ed salt for this master key - NULL if no salt */
|
|
|
|
guint8 key_generation_rate; /* encoded as the power of 2, 0..24, or 255 (=zero rate) */
|
|
|
|
/* Either the MKI value is used (in which case from=to=0), or the <from,to> values are used (and MKI=0) */
|
|
|
|
guint32 from_roc; /* 32 MSBs of a 48 bit value - frame from which this key is valid (roll-over counter part) */
|
|
|
|
guint16 from_seq; /* 16 LSBs of a 48 bit value - frame from which this key is valid (sequence number part) */
|
|
|
|
guint32 to_roc; /* 32 MSBs of a 48 bit value - frame to which this key is valid (roll-over counter part) */
|
|
|
|
guint16 to_seq; /* 16 LSBs of a 48 bit value - frame to which this key is valid (sequence number part) */
|
|
|
|
guint32 mki; /* the MKI value associated with this key */
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
struct srtp_info
|
|
|
|
{
|
|
|
|
guint encryption_algorithm; /* at present only NULL vs non-NULL matter */
|
|
|
|
guint auth_algorithm; /* at present only NULL vs non-NULL matter */
|
|
|
|
guint mki_len; /* number of octets used for the MKI in the RTP payload */
|
|
|
|
guint auth_tag_len; /* number of octets used for the Auth Tag in the RTP payload */
|
|
|
|
#if 0 /* these are only needed once the dissector include the crypto functions to decrypt and/or authenticate */
|
|
|
|
struct srtp_key_info **master_keys; /* an array of pointers to master keys and their info, the array and each key struct being se_alloc'ed */
|
|
|
|
void *enc_alg_info, /* algorithm-dependent info struct - may be void for default alg with default params */
|
|
|
|
void *auth_alg_info /* algorithm-dependent info struct - void for default alg with default params */
|
|
|
|
#endif
|
|
|
|
};
|
|
|
|
|
2004-06-15 18:26:08 +00:00
|
|
|
/* Info to save in RTP conversation / packet-info */
|
2004-12-21 19:28:48 +00:00
|
|
|
#define MAX_RTP_SETUP_METHOD_SIZE 7
|
2004-06-15 18:26:08 +00:00
|
|
|
struct _rtp_conversation_info
|
|
|
|
{
|
2004-12-21 19:28:48 +00:00
|
|
|
gchar method[MAX_RTP_SETUP_METHOD_SIZE + 1];
|
2009-05-19 18:42:33 +00:00
|
|
|
guint32 frame_number; /* the frame where this conversation is started */
|
|
|
|
gboolean is_video;
|
|
|
|
GHashTable *rtp_dyn_payload; /* a hash table with the dynamic RTP payload */
|
2007-02-21 06:45:34 +00:00
|
|
|
|
2009-05-19 18:42:33 +00:00
|
|
|
guint32 extended_seqno; /* the sequence number, extended to a 32-bit
|
|
|
|
* int to guarantee it increasing monotonically
|
|
|
|
*/
|
2007-02-21 06:45:34 +00:00
|
|
|
|
|
|
|
struct _rtp_private_conv_info *rtp_conv_info; /* conversation info private
|
2009-05-19 18:42:33 +00:00
|
|
|
* to the rtp dissector
|
|
|
|
*/
|
2007-08-21 07:23:34 +00:00
|
|
|
struct srtp_info *srtp_info; /* SRTP context */
|
2004-06-15 18:26:08 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/* Add an RTP conversation with the given details */
|
|
|
|
void rtp_add_address(packet_info *pinfo,
|
2004-08-30 10:03:54 +00:00
|
|
|
address *addr, int port,
|
2004-06-15 18:26:08 +00:00
|
|
|
int other_port,
|
2005-07-30 01:01:02 +00:00
|
|
|
const gchar *setup_method,
|
2007-08-21 07:23:34 +00:00
|
|
|
guint32 setup_frame_number,
|
2009-05-19 18:42:33 +00:00
|
|
|
gboolean is_video,
|
2007-08-21 07:23:34 +00:00
|
|
|
GHashTable *rtp_dyn_payload);
|
|
|
|
|
|
|
|
/* Add an SRTP conversation with the given details */
|
|
|
|
void srtp_add_address(packet_info *pinfo,
|
|
|
|
address *addr, int port,
|
|
|
|
int other_port,
|
|
|
|
const gchar *setup_method,
|
|
|
|
guint32 setup_frame_number,
|
2009-05-19 18:42:33 +00:00
|
|
|
gboolean is_video,
|
2007-08-21 07:23:34 +00:00
|
|
|
GHashTable *rtp_dyn_payload,
|
|
|
|
struct srtp_info *srtp_info);
|
2005-03-27 21:14:48 +00:00
|
|
|
|
|
|
|
/* Free and destroy the dyn_payload hash table */
|
|
|
|
void rtp_free_hash_dyn_payload(GHashTable *rtp_dyn_payload);
|
|
|
|
|