srtpenc: Set the SRTP key as a shared key for all SSRCs

This is already how it was used.
This commit is contained in:
Olivier Crête 2014-05-02 17:07:21 -04:00
parent a73a42b10f
commit 5a38ae5a83
2 changed files with 15 additions and 34 deletions

View file

@ -319,8 +319,6 @@ gst_srtp_enc_init (GstSrtpEnc * filter)
filter->rtp_auth = DEFAULT_RTP_AUTH; filter->rtp_auth = DEFAULT_RTP_AUTH;
filter->rtcp_cipher = DEFAULT_RTCP_CIPHER; filter->rtcp_cipher = DEFAULT_RTCP_CIPHER;
filter->rtcp_auth = DEFAULT_RTCP_AUTH; filter->rtcp_auth = DEFAULT_RTCP_AUTH;
filter->ssrcs_set = g_hash_table_new (g_direct_hash, g_direct_equal);
} }
static guint static guint
@ -336,8 +334,8 @@ max_cipher_key_size (GstSrtpEnc * filter)
/* Create stream /* Create stream
*/ */
static gboolean static err_status_t
check_new_stream_locked (GstSrtpEnc * filter, guint32 ssrc) gst_srtp_enc_create_session (GstSrtpEnc * filter)
{ {
err_status_t ret; err_status_t ret;
srtp_policy_t policy; srtp_policy_t policy;
@ -346,10 +344,6 @@ check_new_stream_locked (GstSrtpEnc * filter, guint32 ssrc)
memset (&policy, 0, sizeof (srtp_policy_t)); memset (&policy, 0, sizeof (srtp_policy_t));
/* check if we already have that stream */
if (g_hash_table_lookup (filter->ssrcs_set, GUINT_TO_POINTER (ssrc)))
return TRUE;
GST_OBJECT_LOCK (filter); GST_OBJECT_LOCK (filter);
if (HAS_CRYPTO (filter)) { if (HAS_CRYPTO (filter)) {
@ -391,29 +385,22 @@ check_new_stream_locked (GstSrtpEnc * filter, guint32 ssrc)
policy.key = tmp; policy.key = tmp;
} }
policy.ssrc.value = ssrc; policy.ssrc.value = 0;
policy.ssrc.type = ssrc_specific; policy.ssrc.type = ssrc_any_outbound;
policy.next = NULL; policy.next = NULL;
/* If it is the first stream, create the session /* If it is the first stream, create the session
* If not, add the stream to the session * If not, add the stream to the session
*/ */
if (filter->first_session)
ret = srtp_create (&filter->session, &policy); ret = srtp_create (&filter->session, &policy);
else
ret = srtp_add_stream (filter->session, &policy);
filter->first_session = FALSE; filter->first_session = FALSE;
if (HAS_CRYPTO (filter)) if (HAS_CRYPTO (filter))
gst_buffer_unmap (filter->key, &map); gst_buffer_unmap (filter->key, &map);
g_hash_table_insert (filter->ssrcs_set, GUINT_TO_POINTER (ssrc),
GUINT_TO_POINTER (1));
GST_OBJECT_UNLOCK (filter); GST_OBJECT_UNLOCK (filter);
return ret == err_status_ok; return ret;
} }
/* Release ressources and set default values /* Release ressources and set default values
@ -429,8 +416,6 @@ gst_srtp_enc_reset (GstSrtpEnc * filter)
filter->first_session = TRUE; filter->first_session = TRUE;
filter->key_changed = FALSE; filter->key_changed = FALSE;
g_hash_table_remove_all (filter->ssrcs_set);
GST_OBJECT_UNLOCK (filter); GST_OBJECT_UNLOCK (filter);
} }
@ -576,10 +561,6 @@ gst_srtp_enc_dispose (GObject * object)
gst_buffer_unref (filter->key); gst_buffer_unref (filter->key);
filter->key = NULL; filter->key = NULL;
if (filter->ssrcs_set)
g_hash_table_unref (filter->ssrcs_set);
filter->ssrcs_set = NULL;
G_OBJECT_CLASS (gst_srtp_enc_parent_class)->dispose (object); G_OBJECT_CLASS (gst_srtp_enc_parent_class)->dispose (object);
} }
@ -956,14 +937,16 @@ gst_srtp_enc_chain (GstPad * pad, GstObject * parent, GstBuffer * buf,
do_setcaps = filter->key_changed; do_setcaps = filter->key_changed;
if (filter->key_changed) if (filter->key_changed)
gst_srtp_enc_reset (filter); gst_srtp_enc_reset (filter);
if (filter->first_session) {
if (!check_new_stream_locked (filter, ssrc)) { err_status_t status = gst_srtp_enc_create_session (filter);
if (status != err_status_ok) {
GST_ELEMENT_ERROR (filter, LIBRARY, INIT, GST_ELEMENT_ERROR (filter, LIBRARY, INIT,
("Could not initialize SRTP encoder"), ("Could not initialize SRTP encoder"),
("Failed to add stream to SRTP encoder")); ("Failed to add stream to SRTP encoder (err: %d)", status));
ret = GST_FLOW_ERROR; ret = GST_FLOW_ERROR;
goto out; goto out;
} }
}
priv->ssrc = ssrc; priv->ssrc = ssrc;
GST_OBJECT_LOCK (filter); GST_OBJECT_LOCK (filter);

View file

@ -85,8 +85,6 @@ struct _GstSrtpEnc
gboolean hard_limit_reached; gboolean hard_limit_reached;
gboolean soft_limit_reached; gboolean soft_limit_reached;
GHashTable *ssrcs_set;
GType key_type; GType key_type;
}; };