mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-24 13:56:33 +02:00
Revert "Avoid overflows when reading pgm files with maxval != 255 and != 65535."
The patch worked on little endian because pgm decoding was broken but it was not correct in any way. This reverts commit 7651c0e49b1f6e66120ef32570a87e3f09224574.
This commit is contained in:
parent
768e40b451
commit
2c046c718a
@ -35,7 +35,6 @@ static int pnm_decode_frame(AVCodecContext *avctx, void *data,
|
|||||||
int i, j, n, linesize, h, upgrade = 0, is_mono = 0;
|
int i, j, n, linesize, h, upgrade = 0, is_mono = 0;
|
||||||
unsigned char *ptr;
|
unsigned char *ptr;
|
||||||
int components, sample_len, ret;
|
int components, sample_len, ret;
|
||||||
unsigned int maskval = 0;
|
|
||||||
|
|
||||||
s->bytestream_start =
|
s->bytestream_start =
|
||||||
s->bytestream = (uint8_t *)buf;
|
s->bytestream = (uint8_t *)buf;
|
||||||
@ -76,10 +75,8 @@ static int pnm_decode_frame(AVCodecContext *avctx, void *data,
|
|||||||
n = avctx->width;
|
n = avctx->width;
|
||||||
components=1;
|
components=1;
|
||||||
sample_len=8;
|
sample_len=8;
|
||||||
if (s->maxval < 255) {
|
if (s->maxval < 255)
|
||||||
upgrade = 1;
|
upgrade = 1;
|
||||||
maskval = (2 << av_log2(s->maxval)) - 1;
|
|
||||||
}
|
|
||||||
goto do_read;
|
goto do_read;
|
||||||
case AV_PIX_FMT_GRAY8A:
|
case AV_PIX_FMT_GRAY8A:
|
||||||
n = avctx->width * 2;
|
n = avctx->width * 2;
|
||||||
@ -91,10 +88,8 @@ static int pnm_decode_frame(AVCodecContext *avctx, void *data,
|
|||||||
n = avctx->width * 2;
|
n = avctx->width * 2;
|
||||||
components=1;
|
components=1;
|
||||||
sample_len=16;
|
sample_len=16;
|
||||||
if (s->maxval < 65535) {
|
if (s->maxval < 65535)
|
||||||
upgrade = 2;
|
upgrade = 2;
|
||||||
maskval = (2 << av_log2(s->maxval)) - 1;
|
|
||||||
}
|
|
||||||
goto do_read;
|
goto do_read;
|
||||||
case AV_PIX_FMT_MONOWHITE:
|
case AV_PIX_FMT_MONOWHITE:
|
||||||
case AV_PIX_FMT_MONOBLACK:
|
case AV_PIX_FMT_MONOBLACK:
|
||||||
@ -141,11 +136,11 @@ static int pnm_decode_frame(AVCodecContext *avctx, void *data,
|
|||||||
else if (upgrade == 1) {
|
else if (upgrade == 1) {
|
||||||
unsigned int j, f = (255 * 128 + s->maxval / 2) / s->maxval;
|
unsigned int j, f = (255 * 128 + s->maxval / 2) / s->maxval;
|
||||||
for (j = 0; j < n; j++)
|
for (j = 0; j < n; j++)
|
||||||
ptr[j] = ((s->bytestream[j] & maskval) * f + 64) >> 7;
|
ptr[j] = (s->bytestream[j] * f + 64) >> 7;
|
||||||
} else if (upgrade == 2) {
|
} else if (upgrade == 2) {
|
||||||
unsigned int j, v, f = (65535 * 32768 + s->maxval / 2) / s->maxval;
|
unsigned int j, v, f = (65535 * 32768 + s->maxval / 2) / s->maxval;
|
||||||
for (j = 0; j < n / 2; j++) {
|
for (j = 0; j < n / 2; j++) {
|
||||||
v = av_be2ne16(((uint16_t *)s->bytestream)[j]) & maskval;
|
v = av_be2ne16(((uint16_t *)s->bytestream)[j]);
|
||||||
((uint16_t *)ptr)[j] = (v * f + 16384) >> 15;
|
((uint16_t *)ptr)[j] = (v * f + 16384) >> 15;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user