26 #define VPX_CODEC_DISABLE_COMPAT 1
27 #include <vpx/vpx_decoder.h>
28 #include <vpx/vp8dx.h>
36 typedef struct VP8DecoderContext {
41 const struct vpx_codec_iface *iface)
44 struct vpx_codec_dec_cfg deccfg = {
52 if (vpx_codec_dec_init(&ctx->
decoder, iface, &deccfg, 0) != VPX_CODEC_OK) {
53 const char *error = vpx_codec_error(&ctx->
decoder);
65 #if VPX_IMAGE_ABI_VERSION >= 3
75 case VPX_IMG_FMT_I420:
80 #if CONFIG_LIBVPX_VP9_DECODER
81 case VPX_IMG_FMT_I422:
85 #if VPX_IMAGE_ABI_VERSION >= 3
86 case VPX_IMG_FMT_I440:
91 case VPX_IMG_FMT_I444:
93 #if VPX_IMAGE_ABI_VERSION >= 3
100 #ifdef VPX_IMG_FMT_HIGHBITDEPTH
101 case VPX_IMG_FMT_I42016:
103 if (img->bit_depth == 10) {
106 }
else if (img->bit_depth == 12) {
112 case VPX_IMG_FMT_I42216:
114 if (img->bit_depth == 10) {
115 #if VPX_IMAGE_ABI_VERSION >= 3
122 }
else if (img->bit_depth == 12) {
123 #if VPX_IMAGE_ABI_VERSION >= 3
133 #if VPX_IMAGE_ABI_VERSION >= 3
134 case VPX_IMG_FMT_I44016:
136 if (img->bit_depth == 10) {
139 }
else if (img->bit_depth == 12) {
146 case VPX_IMG_FMT_I44416:
148 if (img->bit_depth == 10) {
151 }
else if (img->bit_depth == 12) {
169 const void *iter =
NULL;
170 struct vpx_image *
img;
175 const char *error = vpx_codec_error(&ctx->
decoder);
176 const char *detail = vpx_codec_error_detail(&ctx->
decoder);
185 if ((img = vpx_codec_get_frame(&ctx->
decoder, &iter))) {
187 #ifdef VPX_IMG_FMT_HIGHBITDEPTH
189 img->fmt, img->bit_depth);
197 if ((
int) img->d_w != avctx->
width || (
int) img->d_h != avctx->
height) {
207 img->stride, avctx->
pix_fmt, img->d_w, img->d_h);
216 vpx_codec_destroy(&ctx->
decoder);
220 #if CONFIG_LIBVPX_VP8_DECODER
223 return vpx_init(avctx, &vpx_codec_vp8_dx_algo);
226 AVCodec ff_libvpx_vp8_decoder = {
239 #if CONFIG_LIBVPX_VP9_DECODER
242 return vpx_init(avctx, &vpx_codec_vp9_dx_algo);
253 AVCodec ff_libvpx_vp9_decoder = {
254 .
name =
"libvpx-vp9",
also ITU-R BT1361 / IEC 61966-2-4 xvYCC709 / SMPTE RP177 Annex B
planar YUV 4:4:0,20bpp, (1 Cr & Cb sample per 1x2 Y samples), little-endian
#define AVERROR_INVALIDDATA
Invalid data found when processing input.
This structure describes decoded (raw) audio or video data.
ptrdiff_t const GLvoid * data
planar YUV 4:2:0, 15bpp, (1 Cr & Cb sample per 2x2 Y samples), little-endian
planar YUV 4:4:4, 24bpp, (1 Cr & Cb sample per 1x1 Y samples)
int ff_set_dimensions(AVCodecContext *s, int width, int height)
Check that the provided frame dimensions are valid and set them on the codec context.
struct vpx_codec_ctx decoder
static av_cold int init(AVCodecContext *avctx)
also ITU-R BT601-6 625 / ITU-R BT1358 625 / ITU-R BT1700 625 PAL & SECAM / IEC 61966-2-4 xvYCC601 ...
also ITU-R BT601-6 525 / ITU-R BT1358 525 / ITU-R BT1700 NTSC / functionally identical to above ...
enum AVPixelFormat pix_fmt
Pixel format, see AV_PIX_FMT_xxx.
planar GBR 4:4:4 36bpp, little-endian
#define AV_CODEC_CAP_AUTO_THREADS
Codec supports avctx->thread_count == 0 (auto).
order of coefficients is actually GBR, also IEC 61966-2-1 (sRGB)
AVColorSpace
YUV colorspace type.
planar YUV 4:4:4,36bpp, (1 Cr & Cb sample per 1x1 Y samples), little-endian
#define FF_PROFILE_UNKNOWN
static av_cold void init_static_data(void)
#define AV_LOG_VERBOSE
Detailed information.
planar YUV 4:4:4, 30bpp, (1 Cr & Cb sample per 1x1 Y samples), little-endian
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
planar YUV 4:2:2, 20bpp, (1 Cr & Cb sample per 2x1 Y samples), little-endian
const char * name
Name of the codec implementation.
Libavcodec external API header.
void av_image_copy(uint8_t *dst_data[4], int dst_linesizes[4], const uint8_t *src_data[4], const int src_linesizes[4], enum AVPixelFormat pix_fmt, int width, int height)
Copy image in src_data to dst_data.
planar YUV 4:2:2, 16bpp, (1 Cr & Cb sample per 2x1 Y samples)
static av_cold int vp8_free(AVCodecContext *avctx)
static const chunk_decoder decoder[8]
int width
picture width / height.
ITU-R BT2020 non-constant luminance system.
static av_cold int vpx_init(AVCodecContext *avctx, const struct vpx_codec_iface *iface)
static int vp8_decode(AVCodecContext *avctx, void *data, int *got_frame, AVPacket *avpkt)
planar YUV 4:2:0,18bpp, (1 Cr & Cb sample per 2x2 Y samples), little-endian
int thread_count
thread count is used to decide how many independent tasks should be passed to execute() ...
#define AV_LOG_INFO
Standard information.
static const AVProfile profiles[]
av_cold void ff_vp9_init_static(AVCodec *codec)
int linesize[AV_NUM_DATA_POINTERS]
For video, size in bytes of each picture line.
static av_cold int vp9_init(AVFormatContext *ctx, int st_index, PayloadContext *data)
main external API structure.
int ff_get_buffer(AVCodecContext *avctx, AVFrame *frame, int flags)
Get a buffer for a frame.
planar YUV 4:4:0,24bpp, (1 Cr & Cb sample per 1x2 Y samples), little-endian
enum AVColorSpace colorspace
YUV colorspace type.
static int set_pix_fmt(AVCodecContext *avctx, struct vpx_image *img)
uint8_t * data[AV_NUM_DATA_POINTERS]
pointer to the picture/channel planes.
static int decode(AVCodecContext *avctx, void *data, int *got_sub, AVPacket *avpkt)
static av_cold int vp8_init(AVFormatContext *s, int st_index, PayloadContext *vp8)
planar YUV 4:2:0, 12bpp, (1 Cr & Cb sample per 2x2 Y samples)
planar YUV 4:2:2,24bpp, (1 Cr & Cb sample per 2x1 Y samples), little-endian
common internal api header.
common internal and external API header
planar YUV 4:4:0 (1 Cr & Cb sample per 1x2 Y samples)
This structure stores compressed data.
#define AV_CODEC_CAP_DR1
Codec uses get_buffer() for allocating buffers and supports custom allocators.
planar GBR 4:4:4 30bpp, little-endian