Mercurial > libavcodec.hg
annotate rl.h @ 4667:b3f099adfb36 libavcodec
move RLTable stuff to its own header
| author | michael |
|---|---|
| date | Wed, 14 Mar 2007 12:29:32 +0000 |
| parents | mpegvideo.h@a9f4d5c92218 |
| children | 1f1a0e67b961 |
| rev | line source |
|---|---|
| 1106 | 1 /** |
| 4667 | 2 * @file rl.h |
| 3 * rl header. | |
| 1106 | 4 */ |
| 2967 | 5 |
| 4667 | 6 #ifndef AVCODEC_RL_H |
| 7 #define AVCODEC_RL_H | |
|
745
25d7fb7c89be
better/cleaner error resilience (done in a 2nd pass after decoding)
michaelni
parents:
726
diff
changeset
|
8 |
| 1110 | 9 /** RLTable. */ |
| 0 | 10 typedef struct RLTable { |
| 2967 | 11 int n; ///< number of entries of table_vlc minus 1 |
| 12 int last; ///< number of values for last = 0 | |
| 1064 | 13 const uint16_t (*table_vlc)[2]; |
| 14 const int8_t *table_run; | |
| 15 const int8_t *table_level; | |
| 2967 | 16 uint8_t *index_run[2]; ///< encoding only |
| 17 int8_t *max_level[2]; ///< encoding & decoding | |
| 18 int8_t *max_run[2]; ///< encoding & decoding | |
| 1110 | 19 VLC vlc; ///< decoding only deprected FIXME remove |
| 2967 | 20 RL_VLC_ELEM *rl_vlc[32]; ///< decoding only |
| 0 | 21 } RLTable; |
| 22 | |
|
2370
26560d4fdb1f
Memory leak fix patch by (Burkhard Plaum <plaum >at< ipf.uni-stuttgart )dot( de>)
michael
parents:
2327
diff
changeset
|
23 void init_rl(RLTable *rl, int use_static); |
|
26560d4fdb1f
Memory leak fix patch by (Burkhard Plaum <plaum >at< ipf.uni-stuttgart )dot( de>)
michael
parents:
2327
diff
changeset
|
24 void init_vlc_rl(RLTable *rl, int use_static); |
| 0 | 25 |
| 243 | 26 static inline int get_rl_index(const RLTable *rl, int last, int run, int level) |
| 0 | 27 { |
| 28 int index; | |
| 29 index = rl->index_run[last][run]; | |
| 30 if (index >= rl->n) | |
| 31 return rl->n; | |
| 32 if (level > rl->max_level[last][run]) | |
| 33 return rl->n; | |
| 34 return index + level - 1; | |
| 35 } | |
| 36 | |
|
3582
6310389a9688
Compile fix (for GCC<3.3) when encoders are disabled
gpoirier
parents:
3312
diff
changeset
|
37 #endif |
