45 #define DECOMP_BUF_PADDING 16
50 static const int shift1[6] = { 0, 8, 8, 8, 4, 4 };
51 static const int shift2[6] = { 0, 0, 8, 4, 0, 4 };
57 uint8_t *src_end = src + srcsize;
59 int type, x,
y, d, d2;
66 data = code + ((avctx->
width * avctx->
height) >> 4);
70 for(j = 0; j < avctx->
height; j += 4){
71 for(i = 0; i < avctx->
width; i += 4){
72 if (data > src_end || mv > src_end || msk > src_end)
79 x = (*mv) >> 4;
if(x & 8) x = 8 - x;
80 y = (*mv++) & 0xF;
if(y & 8) y = 8 -
y;
81 if (i < -x || avctx->
width - i - 4 < x ||
82 j < -y || avctx->
height - j - 4 < y) {
89 for(y = 0; y < 4; y++){
107 mask = ((msk[0] & 0xF0) <<
shift1[type]) | ((msk[0] & 0xF) <<
shift2[type]);
110 for(y = 0; y < 4; y++){
111 for(x = 0; x < 4; x++){
112 tmp[x] = (mask & 0x8000) ? *data++ : tmp2[x];
120 for(y = 0; y < 4; y++){
121 memset(tmp, data[0], 4);
127 for(y = 0; y < 4; y++){
128 memcpy(tmp, data, 4);
135 for(k = 0; k < 4; k++){
136 d = ((k & 1) << 1) + ((k & 2) * stride);
137 d2 = ((k & 1) << 1) + ((k & 2) * stride);
141 x = (*mv) >> 4;
if(x & 8) x = 8 - x;
142 y = (*mv++) & 0xF;
if(y & 8) y = 8 -
y;
143 if (i + 2*(k & 1) < -x || avctx->
width - i - 2*(k & 1) - 2 < x ||
144 j + (k & 2) < -y || avctx->
height - j - (k & 2) - 2 < y) {
148 tmp2 += x + y*stride;
150 tmp[d + 0 ] = tmp2[0];
151 tmp[d + 1 ] = tmp2[1];
152 tmp[d + 0 + stride] = tmp2[0 + stride];
153 tmp[d + 1 + stride] = tmp2[1 + stride];
156 tmp[d + 0 ] = data[0];
157 tmp[d + 1 ] = data[0];
158 tmp[d + 0 + stride] = data[0];
159 tmp[d + 1 + stride] = data[0];
163 tmp[d + 0 ] = *data++;
164 tmp[d + 1 ] = *data++;
165 tmp[d + 0 + stride] = *data++;
166 tmp[d + 1 + stride] = *data++;
175 for(y = 0; y < 4; y++){
176 for(x = 0; x < 4; x++){
177 tmp[x] = data[mask & 1];
189 for(y = 0; y < 4; y++){
190 for(x = 0; x < 4; x++){
191 tmp[x] = data[mask & 3];
214 uint8_t *outptr, *srcptr, *tmpptr;
216 int i, j, compr,
ret;
224 if (bytestream2_peek_le32(&gb) ==
MKTAG(
'C',
'M',
'A',
'P')) {
226 for(i = 0; i < 256; i++){
227 c->
pal[i] = 0xFF
U << 24 | bytestream2_get_be24(&gb);
237 outptr = frame->
data[0];
242 if (bytestream2_get_le32(&gb) ==
MKTAG(
'N',
'U',
'L',
'L'))
245 compr = bytestream2_get_byte(&gb);
248 if (compr != 4 && compr != -1) {
277 for (j = 0; j < avctx->
height; j++) {
278 memcpy(outptr, srcptr, avctx->
width);
280 srcptr += avctx->
width;
292 for (j = 0; j < avctx->
height; j++) {
294 for(i = 0; i < avctx->
width; i++)
295 outptr[i] = srcptr[i] ^ tmpptr[i];
298 memcpy(outptr, srcptr, avctx->
width);
300 srcptr += avctx->
width;