Commit df7cd417 authored by Martin Vignali's avatar Martin Vignali Committed by Paul B Mahol

avcodec/exr: move channel_line_size to thread data

In order to be used by b44 uncompress.
parent 03152e74
...@@ -105,6 +105,8 @@ typedef struct EXRThreadData { ...@@ -105,6 +105,8 @@ typedef struct EXRThreadData {
uint16_t *lut; uint16_t *lut;
int ysize, xsize; int ysize, xsize;
int channel_line_size;
} EXRThreadData; } EXRThreadData;
typedef struct EXRContext { typedef struct EXRContext {
...@@ -992,7 +994,6 @@ static int decode_block(AVCodecContext *avctx, void *tdata, ...@@ -992,7 +994,6 @@ static int decode_block(AVCodecContext *avctx, void *tdata,
uint8_t *ptr; uint8_t *ptr;
uint32_t data_size, line, col = 0; uint32_t data_size, line, col = 0;
uint32_t tileX, tileY, tileLevelX, tileLevelY; uint32_t tileX, tileY, tileLevelX, tileLevelY;
int channel_line_size;
const uint8_t *src; const uint8_t *src;
int axmax = (avctx->width - (s->xmax + 1)) * 2 * s->desc->nb_components; /* nb pixel to add at the right of the datawindow */ int axmax = (avctx->width - (s->xmax + 1)) * 2 * s->desc->nb_components; /* nb pixel to add at the right of the datawindow */
int bxmin = s->xmin * 2 * s->desc->nb_components; /* nb pixel to add at the left of the datawindow */ int bxmin = s->xmin * 2 * s->desc->nb_components; /* nb pixel to add at the left of the datawindow */
...@@ -1036,8 +1037,8 @@ static int decode_block(AVCodecContext *avctx, void *tdata, ...@@ -1036,8 +1037,8 @@ static int decode_block(AVCodecContext *avctx, void *tdata,
if ((col + td->xsize) != s->xdelta)/* not the last tile of the line */ if ((col + td->xsize) != s->xdelta)/* not the last tile of the line */
axmax = 0; /* doesn't add pixel at the right of the datawindow */ axmax = 0; /* doesn't add pixel at the right of the datawindow */
channel_line_size = td->xsize * s->current_channel_offset;/* uncompress size of one line */ td->channel_line_size = td->xsize * s->current_channel_offset;/* uncompress size of one line */
uncompressed_size = channel_line_size * (uint64_t)td->ysize;/* uncompress size of the block */ uncompressed_size = td->channel_line_size * (uint64_t)td->ysize;/* uncompress size of the block */
} else { } else {
if (line_offset > buf_size - 8) if (line_offset > buf_size - 8)
return AVERROR_INVALIDDATA; return AVERROR_INVALIDDATA;
...@@ -1055,8 +1056,8 @@ static int decode_block(AVCodecContext *avctx, void *tdata, ...@@ -1055,8 +1056,8 @@ static int decode_block(AVCodecContext *avctx, void *tdata,
td->ysize = FFMIN(s->scan_lines_per_block, s->ymax - line + 1); /* s->ydelta - line ?? */ td->ysize = FFMIN(s->scan_lines_per_block, s->ymax - line + 1); /* s->ydelta - line ?? */
td->xsize = s->xdelta; td->xsize = s->xdelta;
channel_line_size = td->xsize * s->current_channel_offset;/* uncompress size of one line */ td->channel_line_size = td->xsize * s->current_channel_offset;/* uncompress size of one line */
uncompressed_size = channel_line_size * (uint64_t)td->ysize;/* uncompress size of the block */ uncompressed_size = td->channel_line_size * (uint64_t)td->ysize;/* uncompress size of the block */
if ((s->compression == EXR_RAW && (data_size != uncompressed_size || if ((s->compression == EXR_RAW && (data_size != uncompressed_size ||
line_offset > buf_size - uncompressed_size)) || line_offset > buf_size - uncompressed_size)) ||
...@@ -1185,11 +1186,11 @@ static int decode_block(AVCodecContext *avctx, void *tdata, ...@@ -1185,11 +1186,11 @@ static int decode_block(AVCodecContext *avctx, void *tdata,
// Zero out the end if xmax+1 is not w // Zero out the end if xmax+1 is not w
memset(ptr_x, 0, axmax); memset(ptr_x, 0, axmax);
channel_buffer[0] += channel_line_size; channel_buffer[0] += td->channel_line_size;
channel_buffer[1] += channel_line_size; channel_buffer[1] += td->channel_line_size;
channel_buffer[2] += channel_line_size; channel_buffer[2] += td->channel_line_size;
if (channel_buffer[3]) if (channel_buffer[3])
channel_buffer[3] += channel_line_size; channel_buffer[3] += td->channel_line_size;
} }
return 0; return 0;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment