mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2024-12-22 07:20:45 +00:00
libswscale: avoid UB nullptr-with-offset.
Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
This commit is contained in:
parent
aea8d4061d
commit
29cef1bcd6
@ -158,14 +158,10 @@ int ff_init_slice_from_src(SwsSlice * s, uint8_t *src[4], int stride[4], int src
|
|||||||
chrY + chrH,
|
chrY + chrH,
|
||||||
lumY + lumH};
|
lumY + lumH};
|
||||||
|
|
||||||
uint8_t *const src_[4] = {src[0] + (relative ? 0 : start[0]) * stride[0],
|
|
||||||
src[1] + (relative ? 0 : start[1]) * stride[1],
|
|
||||||
src[2] + (relative ? 0 : start[2]) * stride[2],
|
|
||||||
src[3] + (relative ? 0 : start[3]) * stride[3]};
|
|
||||||
|
|
||||||
s->width = srcW;
|
s->width = srcW;
|
||||||
|
|
||||||
for (i = 0; i < 4; ++i) {
|
for (i = 0; i < 4 && src[i] != NULL; ++i) {
|
||||||
|
uint8_t *const src_i = src[i] + (relative ? 0 : start[i]) * stride[i];
|
||||||
int j;
|
int j;
|
||||||
int first = s->plane[i].sliceY;
|
int first = s->plane[i].sliceY;
|
||||||
int n = s->plane[i].available_lines;
|
int n = s->plane[i].available_lines;
|
||||||
@ -175,13 +171,13 @@ int ff_init_slice_from_src(SwsSlice * s, uint8_t *src[4], int stride[4], int src
|
|||||||
if (start[i] >= first && n >= tot_lines) {
|
if (start[i] >= first && n >= tot_lines) {
|
||||||
s->plane[i].sliceH = FFMAX(tot_lines, s->plane[i].sliceH);
|
s->plane[i].sliceH = FFMAX(tot_lines, s->plane[i].sliceH);
|
||||||
for (j = 0; j < lines; j+= 1)
|
for (j = 0; j < lines; j+= 1)
|
||||||
s->plane[i].line[start[i] - first + j] = src_[i] + j * stride[i];
|
s->plane[i].line[start[i] - first + j] = src_i + j * stride[i];
|
||||||
} else {
|
} else {
|
||||||
s->plane[i].sliceY = start[i];
|
s->plane[i].sliceY = start[i];
|
||||||
lines = lines > n ? n : lines;
|
lines = lines > n ? n : lines;
|
||||||
s->plane[i].sliceH = lines;
|
s->plane[i].sliceH = lines;
|
||||||
for (j = 0; j < lines; j+= 1)
|
for (j = 0; j < lines; j+= 1)
|
||||||
s->plane[i].line[j] = src_[i] + j * stride[i];
|
s->plane[i].line[j] = src_i + j * stride[i];
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1805,7 +1805,7 @@ static int planarCopyWrapper(SwsContext *c, const uint8_t *src[],
|
|||||||
const AVPixFmtDescriptor *desc_src = av_pix_fmt_desc_get(c->srcFormat);
|
const AVPixFmtDescriptor *desc_src = av_pix_fmt_desc_get(c->srcFormat);
|
||||||
const AVPixFmtDescriptor *desc_dst = av_pix_fmt_desc_get(c->dstFormat);
|
const AVPixFmtDescriptor *desc_dst = av_pix_fmt_desc_get(c->dstFormat);
|
||||||
int plane, i, j;
|
int plane, i, j;
|
||||||
for (plane = 0; plane < 4; plane++) {
|
for (plane = 0; plane < 4 && dst[plane] != NULL; plane++) {
|
||||||
int length = (plane == 0 || plane == 3) ? c->srcW : AV_CEIL_RSHIFT(c->srcW, c->chrDstHSubSample);
|
int length = (plane == 0 || plane == 3) ? c->srcW : AV_CEIL_RSHIFT(c->srcW, c->chrDstHSubSample);
|
||||||
int y = (plane == 0 || plane == 3) ? srcSliceY: AV_CEIL_RSHIFT(srcSliceY, c->chrDstVSubSample);
|
int y = (plane == 0 || plane == 3) ? srcSliceY: AV_CEIL_RSHIFT(srcSliceY, c->chrDstVSubSample);
|
||||||
int height = (plane == 0 || plane == 3) ? srcSliceH: AV_CEIL_RSHIFT(srcSliceH, c->chrDstVSubSample);
|
int height = (plane == 0 || plane == 3) ? srcSliceH: AV_CEIL_RSHIFT(srcSliceH, c->chrDstVSubSample);
|
||||||
@ -1813,8 +1813,6 @@ static int planarCopyWrapper(SwsContext *c, const uint8_t *src[],
|
|||||||
uint8_t *dstPtr = dst[plane] + dstStride[plane] * y;
|
uint8_t *dstPtr = dst[plane] + dstStride[plane] * y;
|
||||||
int shiftonly = plane == 1 || plane == 2 || (!c->srcRange && plane == 0);
|
int shiftonly = plane == 1 || plane == 2 || (!c->srcRange && plane == 0);
|
||||||
|
|
||||||
if (!dst[plane])
|
|
||||||
continue;
|
|
||||||
// ignore palette for GRAY8
|
// ignore palette for GRAY8
|
||||||
if (plane == 1 && !dst[2]) continue;
|
if (plane == 1 && !dst[2]) continue;
|
||||||
if (!src[plane] || (plane == 1 && !src[2])) {
|
if (!src[plane] || (plane == 1 && !src[2])) {
|
||||||
|
Loading…
Reference in New Issue
Block a user