32 #define BITSTREAM_READER_LE
37 #define EA_PREAMBLE_SIZE 8
38 #define kVGT_TAG MKTAG('k', 'V', 'G', 'T')
66 unsigned char *dst_end = dst + width*
height;
67 int size, size1, size2, offset,
run;
68 unsigned char *dst_start = dst;
80 while(size>0 && src<src_end) {
84 if ( src[0] & 0x80 ) {
86 if ( src[0] & 0x20 ) {
88 size1 = (((src[0] & 31) + 1) << 2);
92 offset = ((src[0] & 0x10) << 12) +
AV_RB16(&src[1]) + 1;
93 size2 = ((src[0] & 0xC) << 6) + src[3] + 5;
97 size1 = ( ( src[1] & 0xC0) >> 6 );
98 offset = (
AV_RB16(&src[1]) & 0x3FFF) + 1;
99 size2 = (src[0] & 0x3F) + 4;
103 offset = ((src[0] & 0x60) << 3) + src[1] + 1;
104 size2 = ((src[0] & 0x1C) >> 2) + 3;
110 if (size1>src_end-src)
115 run =
FFMIN(size1, dst_end-dst);
116 memcpy(dst, src, run);
122 if (dst-dst_start<offset)
125 run =
FFMIN(size2, dst_end-dst);
141 int num_blocks_packed;
146 const unsigned char *blocks_raw;
152 num_blocks_raw =
AV_RL16(&buf[2]);
153 num_blocks_packed =
AV_RL16(&buf[4]);
154 vector_bits =
AV_RL16(&buf[6]);
159 "Invalid value for motion vector bits: %d\n", vector_bits);
175 mvbits = (num_mvs*2*10+31) & ~31;
177 if (buf+(mvbits>>3)+16*num_blocks_raw+8*num_blocks_packed>buf_end)
189 buf += num_blocks_raw*16;
193 for (i=0; i<num_blocks_packed; i++) {
208 unsigned int vector =
get_bits(&gb, vector_bits);
209 const unsigned char *src;
212 if (vector < num_mvs) {
224 if (offset<num_blocks_raw)
225 src = blocks_raw + 16*offset;
226 else if (offset-num_blocks_raw<num_blocks_packed)
236 src[j*src_stride + i];
252 void *
data,
int *got_frame,
256 int buf_size = avpkt->
size;
258 const uint8_t *buf_end = buf + buf_size;