aboutsummaryrefslogtreecommitdiffstats
path: root/libavcodec/vc1.h
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2014-09-04 20:00:01 +0200
committerMichael Niedermayer <michaelni@gmx.at>2014-09-04 20:09:01 +0200
commitddc6adaa280aecd973cc3cc1661f8bafe28738c8 (patch)
treec22b0d45a9e930bf1d7d52f77d13d6dcf64d7695 /libavcodec/vc1.h
parent5a20f1885d3b521afc8c63734cff724da0a87815 (diff)
parent4d55e9de27894ddfb337b28cd7aa6d14a12666d2 (diff)
downloadffmpeg-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.h63
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