mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-12-23 12:43:46 +02:00
libavcodec/exr : cosmetics, rename variable in b44_uncompress func
Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
This commit is contained in:
parent
acca56d962
commit
f2b08a0702
@ -944,74 +944,74 @@ static void unpack_3(const uint8_t b[3], uint16_t s[16])
|
||||
static int b44_uncompress(EXRContext *s, const uint8_t *src, int compressed_size,
|
||||
int uncompressed_size, EXRThreadData *td) {
|
||||
const int8_t *sr = src;
|
||||
int stayToUncompress = compressed_size;
|
||||
int nbB44BlockW, nbB44BlockH;
|
||||
int indexHgX, indexHgY, indexOut, indexTmp;
|
||||
uint16_t tmpBuffer[16]; /* B44 use 4x4 half float pixel */
|
||||
int stay_to_uncompress = compressed_size;
|
||||
int nb_b44_block_w, nb_b44_block_h;
|
||||
int index_tl_x, index_tl_y, index_out, index_tmp;
|
||||
uint16_t tmp_buffer[16]; /* B44 use 4x4 half float pixel */
|
||||
int c, iY, iX, y, x;
|
||||
int target_channel_offset = 0;
|
||||
|
||||
/* calc B44 block count */
|
||||
nbB44BlockW = td->xsize / 4;
|
||||
nb_b44_block_w = td->xsize / 4;
|
||||
if ((td->xsize % 4) != 0)
|
||||
nbB44BlockW++;
|
||||
nb_b44_block_w++;
|
||||
|
||||
nbB44BlockH = td->ysize / 4;
|
||||
nb_b44_block_h = td->ysize / 4;
|
||||
if ((td->ysize % 4) != 0)
|
||||
nbB44BlockH++;
|
||||
nb_b44_block_h++;
|
||||
|
||||
for (c = 0; c < s->nb_channels; c++) {
|
||||
if (s->channels[c].pixel_type == EXR_HALF) {/* B44 only compress half float data */
|
||||
for (iY = 0; iY < nbB44BlockH; iY++) {
|
||||
for (iX = 0; iX < nbB44BlockW; iX++) {/* For each B44 block */
|
||||
if (stayToUncompress < 3) {
|
||||
av_log(s, AV_LOG_ERROR, "Not enough data for B44A block: %d", stayToUncompress);
|
||||
for (iY = 0; iY < nb_b44_block_h; iY++) {
|
||||
for (iX = 0; iX < nb_b44_block_w; iX++) {/* For each B44 block */
|
||||
if (stay_to_uncompress < 3) {
|
||||
av_log(s, AV_LOG_ERROR, "Not enough data for B44A block: %d", stay_to_uncompress);
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
|
||||
if (src[compressed_size - stayToUncompress + 2] == 0xfc) { /* B44A block */
|
||||
unpack_3(sr, tmpBuffer);
|
||||
if (src[compressed_size - stay_to_uncompress + 2] == 0xfc) { /* B44A block */
|
||||
unpack_3(sr, tmp_buffer);
|
||||
sr += 3;
|
||||
stayToUncompress -= 3;
|
||||
stay_to_uncompress -= 3;
|
||||
} else {/* B44 Block */
|
||||
if (stayToUncompress < 14) {
|
||||
av_log(s, AV_LOG_ERROR, "Not enough data for B44 block: %d", stayToUncompress);
|
||||
if (stay_to_uncompress < 14) {
|
||||
av_log(s, AV_LOG_ERROR, "Not enough data for B44 block: %d", stay_to_uncompress);
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
unpack_14(sr, tmpBuffer);
|
||||
unpack_14(sr, tmp_buffer);
|
||||
sr += 14;
|
||||
stayToUncompress -= 14;
|
||||
stay_to_uncompress -= 14;
|
||||
}
|
||||
|
||||
/* copy data to uncompress buffer (B44 block can exceed target resolution)*/
|
||||
indexHgX = iX * 4;
|
||||
indexHgY = iY * 4;
|
||||
index_tl_x = iX * 4;
|
||||
index_tl_y = iY * 4;
|
||||
|
||||
for (y = indexHgY; y < FFMIN(indexHgY + 4, td->ysize); y++) {
|
||||
for (x = indexHgX; x < FFMIN(indexHgX + 4, td->xsize); x++) {
|
||||
indexOut = target_channel_offset * td->xsize + y * td->channel_line_size + 2 * x;
|
||||
indexTmp = (y-indexHgY) * 4 + (x-indexHgX);
|
||||
td->uncompressed_data[indexOut] = tmpBuffer[indexTmp] & 0xff;
|
||||
td->uncompressed_data[indexOut + 1] = tmpBuffer[indexTmp] >> 8;
|
||||
for (y = index_tl_y; y < FFMIN(index_tl_y + 4, td->ysize); y++) {
|
||||
for (x = index_tl_x; x < FFMIN(index_tl_x + 4, td->xsize); x++) {
|
||||
index_out = target_channel_offset * td->xsize + y * td->channel_line_size + 2 * x;
|
||||
index_tmp = (y-index_tl_y) * 4 + (x-index_tl_x);
|
||||
td->uncompressed_data[index_out] = tmp_buffer[index_tmp] & 0xff;
|
||||
td->uncompressed_data[index_out + 1] = tmp_buffer[index_tmp] >> 8;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
target_channel_offset += 2;
|
||||
} else {/* Float or UINT 32 channel */
|
||||
if (stayToUncompress < td->ysize * td->xsize * 4) {
|
||||
av_log(s, AV_LOG_ERROR, "Not enough data for uncompress channel: %d", stayToUncompress);
|
||||
if (stay_to_uncompress < td->ysize * td->xsize * 4) {
|
||||
av_log(s, AV_LOG_ERROR, "Not enough data for uncompress channel: %d", stay_to_uncompress);
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
|
||||
for (y = 0; y < td->ysize; y++) {
|
||||
indexOut = target_channel_offset * td->xsize + y * td->channel_line_size;
|
||||
memcpy(&td->uncompressed_data[indexOut], sr, td->xsize * 4);
|
||||
index_out = target_channel_offset * td->xsize + y * td->channel_line_size;
|
||||
memcpy(&td->uncompressed_data[index_out], sr, td->xsize * 4);
|
||||
sr += td->xsize * 4;
|
||||
}
|
||||
target_channel_offset += 4;
|
||||
|
||||
stayToUncompress -= td->ysize * td->xsize * 4;
|
||||
stay_to_uncompress -= td->ysize * td->xsize * 4;
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user