summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarton Balint <cus@passwd.hu>2018-03-17 12:41:15 +0100
committerMarton Balint <cus@passwd.hu>2018-03-24 20:55:46 +0100
commit87455b78cc5191d59394f27751da85d588f05d07 (patch)
tree77b5b9987de03ea2623495b4a00926a745364f4c
parent5f6126ea7f31db38a796ea5533a06b6526e13ecf (diff)
downloadffmpeg-87455b78cc5191d59394f27751da85d588f05d07.tar.gz
avdevice/decklink: fix leak when listing devices and there is no memory
Fixes Coverity CID 1419523. Signed-off-by: Marton Balint <cus@passwd.hu>
-rw-r--r--libavdevice/decklink_common.cpp17
1 files changed, 5 insertions, 12 deletions
diff --git a/libavdevice/decklink_common.cpp b/libavdevice/decklink_common.cpp
index da414ed5f8..b889033cf8 100644
--- a/libavdevice/decklink_common.cpp
+++ b/libavdevice/decklink_common.cpp
@@ -322,21 +322,14 @@ int ff_decklink_list_devices(AVFormatContext *avctx,
ret = AVERROR(ENOMEM);
goto next;
}
- new_device->device_name = av_strdup(displayName);
- if (!new_device->device_name) {
- ret = AVERROR(ENOMEM);
- goto next;
- }
+ new_device->device_name = av_strdup(displayName);
new_device->device_description = av_strdup(displayName);
- if (!new_device->device_description) {
- av_freep(&new_device->device_name);
- ret = AVERROR(ENOMEM);
- goto next;
- }
- if ((ret = av_dynarray_add_nofree(&device_list->devices,
- &device_list->nb_devices, new_device)) < 0) {
+ if (!new_device->device_name ||
+ !new_device->device_description ||
+ av_dynarray_add_nofree(&device_list->devices, &device_list->nb_devices, new_device) < 0) {
+ ret = AVERROR(ENOMEM);
av_freep(&new_device->device_name);
av_freep(&new_device->device_description);
av_freep(&new_device);