1 // Copyright 2012 Google Inc. All Rights Reserved. 2 // 3 // Use of this source code is governed by a BSD-style license 4 // that can be found in the COPYING file in the root of the source 5 // tree. An additional intellectual property rights grant can be found 6 // in the file PATENTS. All contributing project authors may 7 // be found in the AUTHORS file in the root of the source tree. 8 // ----------------------------------------------------------------------------- 9 // 10 // Lossless decoder: internal header. 11 // 12 // Author: Skal (pascal.massimino@gmail.com) 13 // Vikas Arora(vikaas.arora@gmail.com) 14 15 #ifndef WEBP_DEC_VP8LI_H_ 16 #define WEBP_DEC_VP8LI_H_ 17 18 #include <string.h> // for memcpy() 19 #include "./webpi.h" 20 #include "../utils/bit_reader.h" 21 #include "../utils/color_cache.h" 22 #include "../utils/huffman.h" 23 24 #ifdef __cplusplus 25 extern "C" { 26 #endif 27 28 typedef enum { 29 READ_DATA = 0, 30 READ_HDR = 1, 31 READ_DIM = 2 32 } VP8LDecodeState; 33 34 typedef struct VP8LTransform VP8LTransform; 35 struct VP8LTransform { 36 VP8LImageTransformType type_; // transform type. 37 int bits_; // subsampling bits defining transform window. 38 int xsize_; // transform window X index. 39 int ysize_; // transform window Y index. 40 uint32_t *data_; // transform data. 41 }; 42 43 typedef struct { 44 int color_cache_size_; 45 VP8LColorCache color_cache_; 46 VP8LColorCache saved_color_cache_; // for incremental 47 48 int huffman_mask_; 49 int huffman_subsample_bits_; 50 int huffman_xsize_; 51 uint32_t *huffman_image_; 52 int num_htree_groups_; 53 HTreeGroup *htree_groups_; 54 HuffmanCode *huffman_tables_; 55 } VP8LMetadata; 56 57 typedef struct VP8LDecoder VP8LDecoder; 58 struct VP8LDecoder { 59 VP8StatusCode status_; 60 VP8LDecodeState state_; 61 VP8Io *io_; 62 63 const WebPDecBuffer *output_; // shortcut to io->opaque->output 64 65 uint32_t *pixels_; // Internal data: either uint8_t* for alpha 66 // or uint32_t* for BGRA. 67 uint32_t *argb_cache_; // Scratch buffer for temporary BGRA storage. 68 69 VP8LBitReader br_; 70 int incremental_; // if true, incremental decoding is expected 71 VP8LBitReader saved_br_; // note: could be local variables too 72 int saved_last_pixel_; 73 74 int width_; 75 int height_; 76 int last_row_; // last input row decoded so far. 77 int last_pixel_; // last pixel decoded so far. However, it may 78 // not be transformed, scaled and 79 // color-converted yet. 80 int last_out_row_; // last row output so far. 81 82 VP8LMetadata hdr_; 83 84 int next_transform_; 85 VP8LTransform transforms_[NUM_TRANSFORMS]; 86 // or'd bitset storing the transforms types. 87 uint32_t transforms_seen_; 88 89 uint8_t *rescaler_memory; // Working memory for rescaling work. 90 WebPRescaler *rescaler; // Common rescaler for all channels. 91 }; 92 93 //------------------------------------------------------------------------------ 94 // internal functions. Not public. 95 96 struct ALPHDecoder; // Defined in dec/alphai.h. 97 98 // in vp8l.c 99 100 // Decodes image header for alpha data stored using lossless compression. 101 // Returns false in case of error. 102 int VP8LDecodeAlphaHeader(struct ALPHDecoder* const alph_dec, 103 const uint8_t* const data, size_t data_size, 104 uint8_t* const output); 105 106 // Decodes *at least* 'last_row' rows of alpha. If some of the initial rows are 107 // already decoded in previous call(s), it will resume decoding from where it 108 // was paused. 109 // Returns false in case of bitstream error. 110 int VP8LDecodeAlphaImageStream(struct ALPHDecoder* const alph_dec, 111 int last_row); 112 113 // Allocates and initialize a new lossless decoder instance. 114 VP8LDecoder* VP8LNew(void); 115 116 // Decodes the image header. Returns false in case of error. 117 int VP8LDecodeHeader(VP8LDecoder* const dec, VP8Io* const io); 118 119 // Decodes an image. It's required to decode the lossless header before calling 120 // this function. Returns false in case of error, with updated dec->status_. 121 int VP8LDecodeImage(VP8LDecoder* const dec); 122 123 // Resets the decoder in its initial state, reclaiming memory. 124 // Preserves the dec->status_ value. 125 void VP8LClear(VP8LDecoder* const dec); 126 127 // Clears and deallocate a lossless decoder instance. 128 void VP8LDelete(VP8LDecoder* const dec); 129 130 //------------------------------------------------------------------------------ 131 132 #ifdef __cplusplus 133 } // extern "C" 134 #endif 135 136 #endif /* WEBP_DEC_VP8LI_H_ */ 137