mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-03-28 12:32:17 +02:00
One more simplification for ipvideo_decode_block_opcode_0xA
Originally committed as revision 18282 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
parent
bcbd9a149e
commit
49a20ffabc
@ -399,23 +399,17 @@ static int ipvideo_decode_block_opcode_0x9(IpvideoContext *s)
|
|||||||
static int ipvideo_decode_block_opcode_0xA(IpvideoContext *s)
|
static int ipvideo_decode_block_opcode_0xA(IpvideoContext *s)
|
||||||
{
|
{
|
||||||
int x, y;
|
int x, y;
|
||||||
unsigned char P[8];
|
unsigned char P[4];
|
||||||
unsigned char B[16];
|
|
||||||
int flags = 0;
|
int flags = 0;
|
||||||
int split;
|
|
||||||
|
|
||||||
/* 4-color encoding for each 4x4 quadrant, or 4-color encoding on
|
/* 4-color encoding for each 4x4 quadrant, or 4-color encoding on
|
||||||
* either top and bottom or left and right halves */
|
* either top and bottom or left and right halves */
|
||||||
CHECK_STREAM_PTR(4);
|
CHECK_STREAM_PTR(24);
|
||||||
|
|
||||||
memcpy(P, s->stream_ptr, 4);
|
if (s->stream_ptr[0] <= s->stream_ptr[1]) {
|
||||||
s->stream_ptr += 4;
|
|
||||||
|
|
||||||
if (P[0] <= P[1]) {
|
/* 4-color encoding for each quadrant; need 32 bytes */
|
||||||
|
CHECK_STREAM_PTR(32);
|
||||||
/* 4-color encoding for each quadrant; need 28 more bytes */
|
|
||||||
CHECK_STREAM_PTR(28);
|
|
||||||
s->stream_ptr -= 4;
|
|
||||||
|
|
||||||
for (y = 0; y < 16; y++) {
|
for (y = 0; y < 16; y++) {
|
||||||
// new values for each 4x4 block
|
// new values for each 4x4 block
|
||||||
@ -435,50 +429,29 @@ static int ipvideo_decode_block_opcode_0xA(IpvideoContext *s)
|
|||||||
}
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
// vertical split?
|
||||||
|
int vert = s->stream_ptr[12] <= s->stream_ptr[13];
|
||||||
|
uint64_t flags = 0;
|
||||||
|
|
||||||
/* 4-color encoding for either left and right or top and bottom
|
/* 4-color encoding for either left and right or top and bottom
|
||||||
* halves; need 20 more bytes */
|
* halves */
|
||||||
CHECK_STREAM_PTR(20);
|
|
||||||
|
|
||||||
memcpy(B, s->stream_ptr, 8);
|
for (y = 0; y < 16; y++) {
|
||||||
s->stream_ptr += 8;
|
// load values for each half
|
||||||
memcpy(P + 4, s->stream_ptr, 4);
|
if (!(y & 7)) {
|
||||||
s->stream_ptr += 4;
|
memcpy(P, s->stream_ptr, 4);
|
||||||
memcpy(B + 8, s->stream_ptr, 8);
|
s->stream_ptr += 4;
|
||||||
s->stream_ptr += 8;
|
flags = bytestream_get_le64(&s->stream_ptr);
|
||||||
|
|
||||||
if (P[4] <= P[5]) {
|
|
||||||
|
|
||||||
/* block is divided into left and right halves */
|
|
||||||
for (y = 0; y < 8; y++) {
|
|
||||||
|
|
||||||
flags = (B[y + 8] << 8) | B[y];
|
|
||||||
split = 0;
|
|
||||||
|
|
||||||
for (x = 0; x < 8; x++, flags >>= 2) {
|
|
||||||
if (x == 4)
|
|
||||||
split = 4;
|
|
||||||
*s->pixel_ptr++ = P[split + (flags & 0x03)];
|
|
||||||
}
|
|
||||||
|
|
||||||
s->pixel_ptr += s->line_inc;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} else {
|
for (x = 0; x < 4; x++, flags >>= 2)
|
||||||
|
*s->pixel_ptr++ = P[flags & 0x03];
|
||||||
|
|
||||||
/* block is divided into top and bottom halves */
|
if (vert) {
|
||||||
split = 0;
|
s->pixel_ptr += s->stride - 4;
|
||||||
for (y = 0; y < 8; y++) {
|
// switch to right half
|
||||||
|
if (y == 7) s->pixel_ptr -= 8 * s->stride - 4;
|
||||||
flags = (B[y * 2 + 1] << 8) | B[y * 2];
|
} else if (y & 1) s->pixel_ptr += s->line_inc;
|
||||||
if (y == 4)
|
|
||||||
split = 4;
|
|
||||||
|
|
||||||
for (x = 0; x < 8; x++, flags >>= 2)
|
|
||||||
*s->pixel_ptr++ = P[split + (flags & 0x03)];
|
|
||||||
|
|
||||||
s->pixel_ptr += s->line_inc;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user