76 #define PALETTE_COUNT 256 
   77 #define VQA_HEADER_SIZE 0x2A 
   81 #define MAX_CODEBOOK_VECTORS 0xFF00 
   82 #define SOLID_PIXEL_VECTORS 0x100 
   83 #define MAX_VECTORS (MAX_CODEBOOK_VECTORS + SOLID_PIXEL_VECTORS) 
   84 #define MAX_CODEBOOK_SIZE (MAX_VECTORS * 4 * 4) 
   86 #define CBF0_TAG MKBETAG('C', 'B', 'F', '0') 
   87 #define CBFZ_TAG MKBETAG('C', 'B', 'F', 'Z') 
   88 #define CBP0_TAG MKBETAG('C', 'B', 'P', '0') 
   89 #define CBPZ_TAG MKBETAG('C', 'B', 'P', 'Z') 
   90 #define CPL0_TAG MKBETAG('C', 'P', 'L', '0') 
   91 #define CPLZ_TAG MKBETAG('C', 'P', 'L', 'Z') 
   92 #define VPTZ_TAG MKBETAG('V', 'P', 'T', 'Z') 
  124     int i, j, codebook_index, 
ret;
 
  188         codebook_index = 0xFF00 * 16;
 
  189         for (i = 0; i < 256; i++)
 
  190             for (j = 0; j < 16; j++)
 
  193         codebook_index = 0xF00 * 8;
 
  194         for (i = 0; i < 256; i++)
 
  195             for (j = 0; j < 8; j++)
 
  208 #define CHECK_COUNT() \ 
  209     if (dest_index + count > dest_size) { \ 
  210         av_log(s->avctx, AV_LOG_ERROR, "decode_format80 problem: next op would overflow dest_index\n"); \ 
  211         av_log(s->avctx, AV_LOG_ERROR, "current dest_index = %d, count = %d, dest_size = %d\n", \ 
  212             dest_index, count, dest_size); \ 
  213         return AVERROR_INVALIDDATA; \ 
  216 #define CHECK_COPY(idx) \ 
  217     if (idx < 0 || idx + count > dest_size) { \ 
  218         av_log(s->avctx, AV_LOG_ERROR, "decode_format80 problem: next op would overflow dest_index\n"); \ 
  219         av_log(s->avctx, AV_LOG_ERROR, "current src_pos = %d, count = %d, dest_size = %d\n", \ 
  220             src_pos, count, dest_size); \ 
  221         return AVERROR_INVALIDDATA; \ 
  226     unsigned char *dest, 
int dest_size, 
int check_size) {
 
  236         opcode = bytestream2_get_byte(&s->
gb);
 
  243         if (dest_index >= dest_size) {
 
  245                 dest_index, dest_size);
 
  249         if (opcode == 0xFF) {
 
  251             count   = bytestream2_get_le16(&s->
gb);
 
  252             src_pos = bytestream2_get_le16(&s->
gb);
 
  253             av_dlog(s->
avctx, 
"(1) copy %X bytes from absolute pos %X\n", count, src_pos);
 
  256             for (i = 0; i < 
count; i++)
 
  257                 dest[dest_index + i] = dest[src_pos + i];
 
  260         } 
else if (opcode == 0xFE) {
 
  262             count = bytestream2_get_le16(&s->
gb);
 
  263             color = bytestream2_get_byte(&s->
gb);
 
  264             av_dlog(s->
avctx, 
"(2) set %X bytes to %02X\n", count, color);
 
  266             memset(&dest[dest_index], color, count);
 
  269         } 
else if ((opcode & 0xC0) == 0xC0) {
 
  271             count = (opcode & 0x3F) + 3;
 
  272             src_pos = bytestream2_get_le16(&s->
gb);
 
  273             av_dlog(s->
avctx, 
"(3) copy %X bytes from absolute pos %X\n", count, src_pos);
 
  276             for (i = 0; i < 
count; i++)
 
  277                 dest[dest_index + i] = dest[src_pos + i];
 
  280         } 
else if (opcode > 0x80) {
 
  282             count = opcode & 0x3F;
 
  283             av_dlog(s->
avctx, 
"(4) copy %X bytes from source to dest\n", count);
 
  290             count = ((opcode & 0x70) >> 4) + 3;
 
  291             src_pos = bytestream2_get_byte(&s->
gb) | ((opcode & 0x0F) << 8);
 
  292             av_dlog(s->
avctx, 
"(5) copy %X bytes from relpos %X\n", count, src_pos);
 
  295             for (i = 0; i < 
count; i++)
 
  296                 dest[dest_index + i] = dest[dest_index - src_pos + i];
 
  306         if (dest_index < dest_size)
 
  307             av_log(s->
avctx, 
AV_LOG_ERROR, 
"decode_format80 problem: decode finished with dest_index (%d) < dest_size (%d)\n",
 
  308                 dest_index, dest_size);
 
  315     unsigned int chunk_type;
 
  316     unsigned int chunk_size;
 
  318     unsigned int index = 0;
 
  320     unsigned char r, 
g, 
b;
 
  335     int vector_index = 0;
 
  344         chunk_type = bytestream2_get_be32u(&s->
gb);
 
  346         chunk_size = bytestream2_get_be32u(&s->
gb);
 
  348         switch (chunk_type) {
 
  380             (chunk_type >> 24) & 0xFF,
 
  381             (chunk_type >> 16) & 0xFF,
 
  382             (chunk_type >>  8) & 0xFF,
 
  383             (chunk_type >>  0) & 0xFF,
 
  388         byte_skip = chunk_size & 0x01;
 
  393     if ((cpl0_chunk != -1) && (cplz_chunk != -1)) {
 
  401     if (cplz_chunk != -1) {
 
  408     if (cpl0_chunk != -1) {
 
  411         chunk_size = bytestream2_get_be32(&s->
gb);
 
  418         for (i = 0; i < chunk_size / 3; i++) {
 
  420             r = bytestream2_get_byteu(&s->
gb) * 4;
 
  421             g = bytestream2_get_byteu(&s->
gb) * 4;
 
  422             b = bytestream2_get_byteu(&s->
gb) * 4;
 
  423             s->
palette[i] = 0xFF
U << 24 | r << 16 | g << 8 | 
b;
 
  429     if ((cbf0_chunk != -1) && (cbfz_chunk != -1)) {
 
  437     if (cbfz_chunk != -1) {
 
  440         chunk_size = bytestream2_get_be32(&s->
gb);
 
  447     if (cbf0_chunk != -1) {
 
  450         chunk_size = bytestream2_get_be32(&s->
gb);
 
  462     if (vptz_chunk == -1) {
 
  470     chunk_size = bytestream2_get_be32(&s->
gb);
 
  481         for (x = 0; x < s->
width; x += 4, lobytes++, hibytes++) {
 
  482             pixel_ptr = y * frame->
linesize[0] + x;
 
  491                 vector_index = ((hibyte << 8) | lobyte) >> 3;
 
  492                 vector_index <<= index_shift;
 
  495                 if (hibyte == 0xFF) {
 
  497                         frame->
data[0][pixel_ptr + 0] = 255 - lobyte;
 
  498                         frame->
data[0][pixel_ptr + 1] = 255 - lobyte;
 
  499                         frame->
data[0][pixel_ptr + 2] = 255 - lobyte;
 
  500                         frame->
data[0][pixel_ptr + 3] = 255 - lobyte;
 
  510                 vector_index = (hibyte << 8) | lobyte;
 
  511                 vector_index <<= index_shift;
 
  522                 frame->
data[0][pixel_ptr + 0] = s->
codebook[vector_index++];
 
  523                 frame->
data[0][pixel_ptr + 1] = s->
codebook[vector_index++];
 
  524                 frame->
data[0][pixel_ptr + 2] = s->
codebook[vector_index++];
 
  525                 frame->
data[0][pixel_ptr + 3] = s->
codebook[vector_index++];
 
  532     if ((cbp0_chunk != -1) && (cbpz_chunk != -1)) {
 
  538     if (cbp0_chunk != -1) {
 
  541         chunk_size = bytestream2_get_be32(&s->
gb);
 
  567     if (cbpz_chunk != -1) {
 
  570         chunk_size = bytestream2_get_be32(&s->
gb);
 
  601                             void *
data, 
int *got_frame,