aboutsummaryrefslogtreecommitdiffstats
path: root/libavcodec/pictordec.c
diff options
context:
space:
mode:
authorAndreas Rheinhardt <andreas.rheinhardt@outlook.com>2021-10-03 10:10:49 +0200
committerAndreas Rheinhardt <andreas.rheinhardt@outlook.com>2021-10-04 17:27:50 +0200
commit2ee4077248dcd96e50efc0738e60519ffb9a4c7f (patch)
tree82b81f8333f697025c4a54af352081da3bd993ca /libavcodec/pictordec.c
parent806a91bd4c40ae8ed7c345dc320d6c111e8f3328 (diff)
downloadffmpeg-2ee4077248dcd96e50efc0738e60519ffb9a4c7f.tar.gz
avfilter/vf_morpho: Fix invalid frees on error
The current code used a pointer to an array (of arrays) that is offset relative to the start of the actually allocated buffer. Yet offsetting the pointer is only done on success, whereas the freeing code believes it to have happened even on error. So if any of the subarrays (or the subarrays' subarrays) can't be successfully allocated, one gets a bad free in free_lut(). Furthermore, said offsetting is only permissible in case the offsetted pointer points in the allocated buffer (here: in case the LUT's min_r is <= 0), as pointer arithmetic is undefined in case it exceeds the allocated object. Moreover, in case one of the subarrays couldn't be allocated, the code nevertheless tried to free the subarray's subarrays; and in case one of the subarray's subarrays could not be allocated successfully, there will be an invalid free, too, because the pointers for the subarrays' subarrays are also offset compared to the base pointer. This commit fixes all of this, by using the actually allocated pointer for freeing and by adding appropriate checks before freeing the subarrays. The former also allows to distinguish the cases in which the lut is currently only half-allocated due to an error in an earlier allocation attempt from the success case. Reviewed-by: Paul B Mahol <onemda@gmail.com> Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt@outlook.com>
Diffstat (limited to 'libavcodec/pictordec.c')
0 files changed, 0 insertions, 0 deletions