mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-02-04 06:08:26 +02:00
Fix ipvideo_decode_block_opcode_0xD again.
Originally committed as revision 18289 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
parent
9b34899ecf
commit
8514f8427f
@ -493,18 +493,19 @@ static int ipvideo_decode_block_opcode_0xC(IpvideoContext *s)
|
||||
static int ipvideo_decode_block_opcode_0xD(IpvideoContext *s)
|
||||
{
|
||||
int y;
|
||||
unsigned char P;
|
||||
unsigned char P[2];
|
||||
|
||||
/* 4-color block encoding: each 4x4 block is a different color */
|
||||
CHECK_STREAM_PTR(4);
|
||||
|
||||
for (y = 0; y < 16; y++) {
|
||||
if (!(y & 3)) // start of block
|
||||
P = *s->stream_ptr++;
|
||||
memset(s->pixel_ptr, P, 4);
|
||||
for (y = 0; y < 8; y++) {
|
||||
if (!(y & 3)) {
|
||||
P[0] = *s->stream_ptr++;
|
||||
P[1] = *s->stream_ptr++;
|
||||
}
|
||||
memset(s->pixel_ptr, P[0], 4);
|
||||
memset(s->pixel_ptr + 4, P[1], 4);
|
||||
s->pixel_ptr += s->stride;
|
||||
// switch to right half
|
||||
if (y == 7) s->pixel_ptr -= 8 * s->stride - 4;
|
||||
}
|
||||
|
||||
/* report success */
|
||||
|
Loading…
x
Reference in New Issue
Block a user