summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRichard Mudgett <rmudgett@digium.com>2017-05-02 18:05:01 -0500
committerRichard Mudgett <rmudgett@digium.com>2017-05-05 18:49:19 -0500
commit56c5c51076ac75e25130083d1358160cd27b0b8f (patch)
tree3d271882e9fd1a0122ab1a1dafee0bfd79a8a370
parent924628812b68e01cf7506b44b292e6057716f77a (diff)
stream: ast_stream_clone() cannot copy the opaque user data.
ast_stream_clone() cannot copy the opaque user data stored on a stream. We don't know how to clone the data so it isn't copied into the clone. Change-Id: Ia51321bf38ecbfdcc53787ca77ea5fd2cabdf367
-rw-r--r--include/asterisk/stream.h2
-rw-r--r--main/stream.c7
2 files changed, 8 insertions, 1 deletions
diff --git a/include/asterisk/stream.h b/include/asterisk/stream.h
index 1bb34b72a..821ecec03 100644
--- a/include/asterisk/stream.h
+++ b/include/asterisk/stream.h
@@ -126,7 +126,7 @@ void ast_stream_free(struct ast_stream *stream);
* \retval NULL failure
*
* \note Opaque data pointers set with ast_stream_set_data() are not part
- * of the deep clone. The pointers are simply copied.
+ * of the deep clone. We have no way to clone the data.
*
* \since 15
*/
diff --git a/main/stream.c b/main/stream.c
index 0f2393359..804a0b8ee 100644
--- a/main/stream.c
+++ b/main/stream.c
@@ -99,6 +99,7 @@ struct ast_stream *ast_stream_clone(const struct ast_stream *stream)
{
struct ast_stream *new_stream;
size_t stream_size;
+ int idx;
if (!stream) {
return NULL;
@@ -115,6 +116,12 @@ struct ast_stream *ast_stream_clone(const struct ast_stream *stream)
ao2_ref(new_stream->formats, +1);
}
+ /* We cannot clone the opaque data because we don't know how. */
+ for (idx = 0; idx < AST_STREAM_DATA_SLOT_MAX; ++idx) {
+ new_stream->data[idx] = NULL;
+ new_stream->data_free_fn[idx] = NULL;
+ }
+
return new_stream;
}