diff options
author | Michael Niedermayer <michaelni@gmx.at> | 2014-09-04 20:00:01 +0200 |
---|---|---|
committer | Michael Niedermayer <michaelni@gmx.at> | 2014-09-04 20:09:01 +0200 |
commit | ddc6adaa280aecd973cc3cc1661f8bafe28738c8 (patch) | |
tree | c22b0d45a9e930bf1d7d52f77d13d6dcf64d7695 /libavcodec/vc1.h | |
parent | 5a20f1885d3b521afc8c63734cff724da0a87815 (diff) | |
parent | 4d55e9de27894ddfb337b28cd7aa6d14a12666d2 (diff) | |
download | ffmpeg-ddc6adaa280aecd973cc3cc1661f8bafe28738c8.tar.gz |
Merge commit '4d55e9de27894ddfb337b28cd7aa6d14a12666d2'
* commit '4d55e9de27894ddfb337b28cd7aa6d14a12666d2':
vc1: Split bits used in libavformat into a separate header
Conflicts:
libavformat/movenc.c
Merged-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavcodec/vc1.h')
-rw-r--r-- | libavcodec/vc1.h | 63 |
1 files changed, 1 insertions, 62 deletions
diff --git a/libavcodec/vc1.h b/libavcodec/vc1.h index 662b58b4d9..9a684ba823 100644 --- a/libavcodec/vc1.h +++ b/libavcodec/vc1.h @@ -27,35 +27,11 @@ #include "h264chroma.h" #include "mpegvideo.h" #include "intrax8.h" +#include "vc1_common.h" #include "vc1dsp.h" #define AC_VLC_BITS 9 -/** Markers used in VC-1 AP frame data */ -//@{ -enum VC1Code { - VC1_CODE_RES0 = 0x00000100, - VC1_CODE_ENDOFSEQ = 0x0000010A, - VC1_CODE_SLICE, - VC1_CODE_FIELD, - VC1_CODE_FRAME, - VC1_CODE_ENTRYPOINT, - VC1_CODE_SEQHDR, -}; -//@} - -#define IS_MARKER(x) (((x) & ~0xFF) == VC1_CODE_RES0) - -/** Available Profiles */ -//@{ -enum Profile { - PROFILE_SIMPLE, - PROFILE_MAIN, - PROFILE_COMPLEX, ///< TODO: WMV9 specific - PROFILE_ADVANCED -}; -//@} - /** Sequence quantizer mode */ //@{ enum QuantMode { @@ -417,43 +393,6 @@ typedef struct VC1Context{ int resync_marker; ///< could this stream contain resync markers } VC1Context; -/** Find VC-1 marker in buffer - * @return position where next marker starts or end of buffer if no marker found - */ -static av_always_inline const uint8_t* find_next_marker(const uint8_t *src, const uint8_t *end) -{ - uint32_t mrk = 0xFFFFFFFF; - - if (end-src < 4) - return end; - while (src < end) { - mrk = (mrk << 8) | *src++; - if (IS_MARKER(mrk)) - return src - 4; - } - return end; -} - -static av_always_inline int vc1_unescape_buffer(const uint8_t *src, int size, uint8_t *dst) -{ - int dsize = 0, i; - - if (size < 4) { - for (dsize = 0; dsize < size; dsize++) - *dst++ = *src++; - return size; - } - for (i = 0; i < size; i++, src++) { - if (src[0] == 3 && i >= 2 && !src[-1] && !src[-2] && i < size-1 && src[1] < 4) { - dst[dsize++] = src[1]; - src++; - i++; - } else - dst[dsize++] = *src; - } - return dsize; -} - /** * Decode Simple/Main Profiles sequence header * @see Figure 7-8, p16-17 |