aboutsummaryrefslogtreecommitdiffstats
path: root/libavutil
diff options
context:
space:
mode:
authorAndreas Rheinhardt <andreas.rheinhardt@gmail.com>2019-09-18 02:03:58 +0200
committerMichael Niedermayer <michael@niedermayer.cc>2019-09-20 23:26:34 +0200
commite6018fda14d7cfe2c890fb336c9264c4ea0b6c5c (patch)
tree6a154ba9f0e1728e38c21f4ce8c7cfd56d50a5de /libavutil
parent87a7fc692d8bff99879dc4a27d89e70272b5a79f (diff)
downloadffmpeg-e6018fda14d7cfe2c890fb336c9264c4ea0b6c5c.tar.gz
avutil/encryption_info: Don't pass NULL to memcpy
The pointer arguments to memcpy (and several other functions of the C standard library) are not allowed to be NULL, not even when the number of bytes to copy is zero. An AVEncryptionInitInfo's data pointer is explicitly allowed to be NULL and yet av_encryption_init_info_add_side_data unconditionally used it as a source pointer to copy from. This commit changes this so that copying is only done if the number of bytes to copy is > 0. Fixes ticket #8141 as well as a part of ticket #8150. Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt@gmail.com> Reviewed-by: Tomas Härdin <tjoppen@acc.umu.se> Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
Diffstat (limited to 'libavutil')
-rw-r--r--libavutil/encryption_info.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/libavutil/encryption_info.c b/libavutil/encryption_info.c
index 812c704776..dd3fa71a44 100644
--- a/libavutil/encryption_info.c
+++ b/libavutil/encryption_info.c
@@ -331,8 +331,10 @@ uint8_t *av_encryption_init_info_add_side_data(const AVEncryptionInitInfo *info,
memcpy(cur_buffer, cur_info->key_ids[i], cur_info->key_id_size);
cur_buffer += cur_info->key_id_size;
}
- memcpy(cur_buffer, cur_info->data, cur_info->data_size);
- cur_buffer += cur_info->data_size;
+ if (cur_info->data_size > 0) {
+ memcpy(cur_buffer, cur_info->data, cur_info->data_size);
+ cur_buffer += cur_info->data_size;
+ }
}
return buffer;