diff options
author | Marton Balint <cus@passwd.hu> | 2018-03-17 12:41:15 +0100 |
---|---|---|
committer | Marton Balint <cus@passwd.hu> | 2018-03-24 20:55:46 +0100 |
commit | 87455b78cc5191d59394f27751da85d588f05d07 (patch) | |
tree | 77b5b9987de03ea2623495b4a00926a745364f4c | |
parent | 5f6126ea7f31db38a796ea5533a06b6526e13ecf (diff) | |
download | ffmpeg-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.cpp | 17 |
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); |