Commit 18fc270f authored by reimar's avatar reimar

Avoid "reloading" code by using a 64 bit type for the flags and loading all at once.


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@18266 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent c6651dde
...@@ -379,7 +379,6 @@ static int ipvideo_decode_block_opcode_0x9(IpvideoContext *s) ...@@ -379,7 +379,6 @@ static int ipvideo_decode_block_opcode_0x9(IpvideoContext *s)
{ {
int x, y; int x, y;
unsigned char P[4]; unsigned char P[4];
unsigned int flags = 0;
/* 4-color encoding */ /* 4-color encoding */
CHECK_STREAM_PTR(4); CHECK_STREAM_PTR(4);
...@@ -394,7 +393,7 @@ static int ipvideo_decode_block_opcode_0x9(IpvideoContext *s) ...@@ -394,7 +393,7 @@ static int ipvideo_decode_block_opcode_0x9(IpvideoContext *s)
for (y = 0; y < 8; y++) { for (y = 0; y < 8; y++) {
/* get the next set of 8 2-bit flags */ /* get the next set of 8 2-bit flags */
flags = bytestream_get_le16(&s->stream_ptr); int flags = bytestream_get_le16(&s->stream_ptr);
for (x = 0; x < 8; x++, flags >>= 2) { for (x = 0; x < 8; x++, flags >>= 2) {
*s->pixel_ptr++ = P[flags & 0x03]; *s->pixel_ptr++ = P[flags & 0x03];
} }
...@@ -402,6 +401,7 @@ static int ipvideo_decode_block_opcode_0x9(IpvideoContext *s) ...@@ -402,6 +401,7 @@ static int ipvideo_decode_block_opcode_0x9(IpvideoContext *s)
} }
} else if ((P[0] <= P[1]) && (P[2] > P[3])) { } else if ((P[0] <= P[1]) && (P[2] > P[3])) {
uint32_t flags;
/* 1 of 4 colors for each 2x2 block, need 4 more bytes */ /* 1 of 4 colors for each 2x2 block, need 4 more bytes */
CHECK_STREAM_PTR(4); CHECK_STREAM_PTR(4);
...@@ -419,15 +419,13 @@ static int ipvideo_decode_block_opcode_0x9(IpvideoContext *s) ...@@ -419,15 +419,13 @@ static int ipvideo_decode_block_opcode_0x9(IpvideoContext *s)
} }
} else if ((P[0] > P[1]) && (P[2] <= P[3])) { } else if ((P[0] > P[1]) && (P[2] <= P[3])) {
uint64_t flags;
/* 1 of 4 colors for each 2x1 block, need 8 more bytes */ /* 1 of 4 colors for each 2x1 block, need 8 more bytes */
CHECK_STREAM_PTR(8); CHECK_STREAM_PTR(8);
flags = bytestream_get_le64(&s->stream_ptr);
for (y = 0; y < 8; y++) { for (y = 0; y < 8; y++) {
/* time to reload flags? */
if ((y == 0) || (y == 4)) {
flags = bytestream_get_le32(&s->stream_ptr);
}
for (x = 0; x < 8; x += 2, flags >>= 2) { for (x = 0; x < 8; x += 2, flags >>= 2) {
s->pixel_ptr[x ] = s->pixel_ptr[x ] =
s->pixel_ptr[x + 1] = P[flags & 0x03]; s->pixel_ptr[x + 1] = P[flags & 0x03];
...@@ -436,15 +434,13 @@ static int ipvideo_decode_block_opcode_0x9(IpvideoContext *s) ...@@ -436,15 +434,13 @@ static int ipvideo_decode_block_opcode_0x9(IpvideoContext *s)
} }
} else { } else {
uint64_t flags;
/* 1 of 4 colors for each 1x2 block, need 8 more bytes */ /* 1 of 4 colors for each 1x2 block, need 8 more bytes */
CHECK_STREAM_PTR(8); CHECK_STREAM_PTR(8);
flags = bytestream_get_le64(&s->stream_ptr);
for (y = 0; y < 8; y += 2) { for (y = 0; y < 8; y += 2) {
/* time to reload flags? */
if ((y == 0) || (y == 4)) {
flags = bytestream_get_le32(&s->stream_ptr);
}
for (x = 0; x < 8; x++, flags >>= 2) { for (x = 0; x < 8; x++, flags >>= 2) {
s->pixel_ptr[x ] = s->pixel_ptr[x ] =
s->pixel_ptr[x + s->stride] = P[flags & 0x03]; s->pixel_ptr[x + s->stride] = P[flags & 0x03];
......
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