This reduces inter-library dependencies.tags/n2.4
| @@ -27,35 +27,11 @@ | |||||
| #include "h264chroma.h" | #include "h264chroma.h" | ||||
| #include "mpegvideo.h" | #include "mpegvideo.h" | ||||
| #include "intrax8.h" | #include "intrax8.h" | ||||
| #include "vc1_common.h" | |||||
| #include "vc1dsp.h" | #include "vc1dsp.h" | ||||
| #define AC_VLC_BITS 9 | #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 */ | /** Sequence quantizer mode */ | ||||
| //@{ | //@{ | ||||
| enum QuantMode { | enum QuantMode { | ||||
| @@ -404,43 +380,6 @@ typedef struct VC1Context{ | |||||
| int resync_marker; ///< could this stream contain resync markers | int resync_marker; ///< could this stream contain resync markers | ||||
| } VC1Context; | } 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 | * Decode Simple/Main Profiles sequence header | ||||
| * @see Figure 7-8, p16-17 | * @see Figure 7-8, p16-17 | ||||
| @@ -0,0 +1,92 @@ | |||||
| /* | |||||
| * VC-1 and WMV3 decoder | |||||
| * Copyright (c) 2006-2007 Konstantin Shishkov | |||||
| * Partly based on vc9.c (c) 2005 Anonymous, Alex Beregszaszi, Michael Niedermayer | |||||
| * | |||||
| * This file is part of Libav. | |||||
| * | |||||
| * Libav is free software; you can redistribute it and/or | |||||
| * modify it under the terms of the GNU Lesser General Public | |||||
| * License as published by the Free Software Foundation; either | |||||
| * version 2.1 of the License, or (at your option) any later version. | |||||
| * | |||||
| * Libav is distributed in the hope that it will be useful, | |||||
| * but WITHOUT ANY WARRANTY; without even the implied warranty of | |||||
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |||||
| * Lesser General Public License for more details. | |||||
| * | |||||
| * You should have received a copy of the GNU Lesser General Public | |||||
| * License along with Libav; if not, write to the Free Software | |||||
| * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | |||||
| */ | |||||
| #ifndef AVCODEC_VC1_COMMON_H | |||||
| #define AVCODEC_VC1_COMMON_H | |||||
| #include <stdint.h> | |||||
| #include "libavutil/attributes.h" | |||||
| /** 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 | |||||
| }; | |||||
| //@} | |||||
| /** 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; | |||||
| } | |||||
| #endif /* AVCODEC_VC1_COMMON_H */ | |||||
| @@ -33,7 +33,7 @@ | |||||
| #include "avc.h" | #include "avc.h" | ||||
| #include "libavcodec/get_bits.h" | #include "libavcodec/get_bits.h" | ||||
| #include "libavcodec/put_bits.h" | #include "libavcodec/put_bits.h" | ||||
| #include "libavcodec/vc1.h" | |||||
| #include "libavcodec/vc1_common.h" | |||||
| #include "internal.h" | #include "internal.h" | ||||
| #include "libavutil/avstring.h" | #include "libavutil/avstring.h" | ||||
| #include "libavutil/intfloat.h" | #include "libavutil/intfloat.h" | ||||