* commit '3f111804eb5c603a344706b84b7164cbf7b4e0df': libvpx: make vp8 and vp9 selectable libvpx: support vp9 nut: support vp9 tag mkv: support vp9 tag rtpdec: Make variables that should wrap unsigned Conflicts: configure libavcodec/Makefile libavcodec/allcodecs.c libavcodec/avcodec.h Merged-by: Michael Niedermayer <michaelni@gmx.at>tags/n1.2
| @@ -225,7 +225,7 @@ External library support: | |||||
| --enable-libvo-amrwbenc enable AMR-WB encoding via libvo-amrwbenc [no] | --enable-libvo-amrwbenc enable AMR-WB encoding via libvo-amrwbenc [no] | ||||
| --enable-libvorbis enable Vorbis en/decoding via libvorbis, | --enable-libvorbis enable Vorbis en/decoding via libvorbis, | ||||
| native implementation exists [no] | native implementation exists [no] | ||||
| --enable-libvpx enable VP8 de/encoding via libvpx [no] | |||||
| --enable-libvpx enable VP8 and VP9 de/encoding via libvpx [no] | |||||
| --enable-libx264 enable H.264 encoding via x264 [no] | --enable-libx264 enable H.264 encoding via x264 [no] | ||||
| --enable-libxavs enable AVS encoding via xavs [no] | --enable-libxavs enable AVS encoding via xavs [no] | ||||
| --enable-libxvid enable Xvid encoding via xvidcore, | --enable-libxvid enable Xvid encoding via xvidcore, | ||||
| @@ -1856,8 +1856,10 @@ libvo_aacenc_encoder_deps="libvo_aacenc" | |||||
| libvo_amrwbenc_encoder_deps="libvo_amrwbenc" | libvo_amrwbenc_encoder_deps="libvo_amrwbenc" | ||||
| libvorbis_decoder_deps="libvorbis" | libvorbis_decoder_deps="libvorbis" | ||||
| libvorbis_encoder_deps="libvorbis" | libvorbis_encoder_deps="libvorbis" | ||||
| libvpx_decoder_deps="libvpx" | |||||
| libvpx_encoder_deps="libvpx" | |||||
| libvpx_vp8_decoder_deps="libvpx" | |||||
| libvpx_vp8_encoder_deps="libvpx" | |||||
| libvpx_vp9_decoder_deps="libvpx" | |||||
| libvpx_vp9_encoder_deps="libvpx" | |||||
| libx264_encoder_deps="libx264" | libx264_encoder_deps="libx264" | ||||
| libx264rgb_encoder_deps="libx264" | libx264rgb_encoder_deps="libx264" | ||||
| libxavs_encoder_deps="libxavs" | libxavs_encoder_deps="libxavs" | ||||
| @@ -3863,10 +3865,12 @@ enabled libvo_aacenc && require libvo_aacenc vo-aacenc/voAAC.h voGetAACEncAPI -l | |||||
| enabled libvo_amrwbenc && require libvo_amrwbenc vo-amrwbenc/enc_if.h E_IF_init -lvo-amrwbenc | enabled libvo_amrwbenc && require libvo_amrwbenc vo-amrwbenc/enc_if.h E_IF_init -lvo-amrwbenc | ||||
| enabled libvorbis && require libvorbis vorbis/vorbisenc.h vorbis_info_init -lvorbisenc -lvorbis -logg | enabled libvorbis && require libvorbis vorbis/vorbisenc.h vorbis_info_init -lvorbisenc -lvorbis -logg | ||||
| enabled libvpx && { | enabled libvpx && { | ||||
| enabled libvpx_decoder && { check_lib2 "vpx/vpx_decoder.h vpx/vp8dx.h" vpx_codec_dec_init_ver -lvpx || | |||||
| die "ERROR: libvpx decoder must be installed and version must be >=0.9.1"; } | |||||
| enabled libvpx_encoder && { check_lib2 "vpx/vpx_encoder.h vpx/vp8cx.h" "vpx_codec_enc_init_ver VP8E_SET_MAX_INTRA_BITRATE_PCT" -lvpx || | |||||
| die "ERROR: libvpx encoder version must be >=0.9.7"; } } | |||||
| enabled libvpx_vp8_decoder && { check_lib2 "vpx/vpx_decoder.h vpx/vp8dx.h" vpx_codec_dec_init_ver -lvpx || | |||||
| die "ERROR: libvpx decoder version must be >=0.9.1"; } | |||||
| enabled libvpx_vp8_encoder && { check_lib2 "vpx/vpx_encoder.h vpx/vp8cx.h" "vpx_codec_enc_init_ver VP8E_SET_MAX_INTRA_BITRATE_PCT" -lvpx || | |||||
| die "ERROR: libvpx encoder version must be >=0.9.7"; } | |||||
| enabled libvpx_vp9_decoder && { check_lib2 "vpx/vpx_decoder.h vpx/vp8dx.h" "vpx_codec_vp9_dx" -lvpx || disable libvpx_vp9_decoder; } | |||||
| enabled libvpx_vp9_encoder && { check_lib2 "vpx/vpx_encoder.h vpx/vp8cx.h" "vpx_codec_vp9_cx" -lvpx || disable libvpx_vp9_encoder; } } | |||||
| enabled libx264 && require libx264 x264.h x264_encoder_encode -lx264 && | enabled libx264 && require libx264 x264.h x264_encoder_encode -lx264 && | ||||
| { check_cpp_condition x264.h "X264_BUILD >= 118" || | { check_cpp_condition x264.h "X264_BUILD >= 118" || | ||||
| die "ERROR: libx264 must be installed and version must be >= 0.118."; } | die "ERROR: libx264 must be installed and version must be >= 0.118."; } | ||||
| @@ -702,8 +702,10 @@ OBJS-$(CONFIG_LIBVO_AMRWBENC_ENCODER) += libvo-amrwbenc.o | |||||
| OBJS-$(CONFIG_LIBVORBIS_DECODER) += libvorbisdec.o | OBJS-$(CONFIG_LIBVORBIS_DECODER) += libvorbisdec.o | ||||
| OBJS-$(CONFIG_LIBVORBIS_ENCODER) += libvorbisenc.o audio_frame_queue.o \ | OBJS-$(CONFIG_LIBVORBIS_ENCODER) += libvorbisenc.o audio_frame_queue.o \ | ||||
| vorbis_data.o vorbis_parser.o xiph.o | vorbis_data.o vorbis_parser.o xiph.o | ||||
| OBJS-$(CONFIG_LIBVPX_DECODER) += libvpxdec.o | |||||
| OBJS-$(CONFIG_LIBVPX_ENCODER) += libvpxenc.o | |||||
| OBJS-$(CONFIG_LIBVPX_VP8_DECODER) += libvpxdec.o | |||||
| OBJS-$(CONFIG_LIBVPX_VP8_ENCODER) += libvpxenc.o | |||||
| OBJS-$(CONFIG_LIBVPX_VP9_DECODER) += libvpxdec.o | |||||
| OBJS-$(CONFIG_LIBVPX_VP9_ENCODER) += libvpxenc.o | |||||
| OBJS-$(CONFIG_LIBX264_ENCODER) += libx264.o | OBJS-$(CONFIG_LIBX264_ENCODER) += libx264.o | ||||
| OBJS-$(CONFIG_LIBXAVS_ENCODER) += libxavs.o | OBJS-$(CONFIG_LIBXAVS_ENCODER) += libxavs.o | ||||
| OBJS-$(CONFIG_LIBXVID_ENCODER) += libxvid.o | OBJS-$(CONFIG_LIBXVID_ENCODER) += libxvid.o | ||||
| @@ -488,7 +488,8 @@ void avcodec_register_all(void) | |||||
| REGISTER_ENCODER(LIBVO_AACENC, libvo_aacenc); | REGISTER_ENCODER(LIBVO_AACENC, libvo_aacenc); | ||||
| REGISTER_ENCODER(LIBVO_AMRWBENC, libvo_amrwbenc); | REGISTER_ENCODER(LIBVO_AMRWBENC, libvo_amrwbenc); | ||||
| REGISTER_ENCDEC (LIBVORBIS, libvorbis); | REGISTER_ENCDEC (LIBVORBIS, libvorbis); | ||||
| REGISTER_ENCDEC (LIBVPX, libvpx); | |||||
| REGISTER_ENCDEC (LIBVPX_VP8, libvpx_vp8); | |||||
| REGISTER_ENCDEC (LIBVPX_VP9, libvpx_vp9); | |||||
| REGISTER_ENCODER(LIBX264, libx264); | REGISTER_ENCODER(LIBX264, libx264); | ||||
| REGISTER_ENCODER(LIBX264RGB, libx264rgb); | REGISTER_ENCODER(LIBX264RGB, libx264rgb); | ||||
| REGISTER_ENCODER(LIBXAVS, libxavs); | REGISTER_ENCODER(LIBXAVS, libxavs); | ||||
| @@ -267,6 +267,7 @@ enum AVCodecID { | |||||
| AV_CODEC_ID_MTS2, | AV_CODEC_ID_MTS2, | ||||
| AV_CODEC_ID_CLLC, | AV_CODEC_ID_CLLC, | ||||
| AV_CODEC_ID_MSS2, | AV_CODEC_ID_MSS2, | ||||
| AV_CODEC_ID_VP9, | |||||
| AV_CODEC_ID_BRENDER_PIX= MKBETAG('B','P','I','X'), | AV_CODEC_ID_BRENDER_PIX= MKBETAG('B','P','I','X'), | ||||
| AV_CODEC_ID_Y41P = MKBETAG('Y','4','1','P'), | AV_CODEC_ID_Y41P = MKBETAG('Y','4','1','P'), | ||||
| AV_CODEC_ID_ESCAPE130 = MKBETAG('E','1','3','0'), | AV_CODEC_ID_ESCAPE130 = MKBETAG('E','1','3','0'), | ||||
| @@ -1030,6 +1030,13 @@ static const AVCodecDescriptor codec_descriptors[] = { | |||||
| .long_name = NULL_IF_CONFIG_SMALL("On2 VP8"), | .long_name = NULL_IF_CONFIG_SMALL("On2 VP8"), | ||||
| .props = AV_CODEC_PROP_LOSSY, | .props = AV_CODEC_PROP_LOSSY, | ||||
| }, | }, | ||||
| { | |||||
| .id = AV_CODEC_ID_VP9, | |||||
| .type = AVMEDIA_TYPE_VIDEO, | |||||
| .name = "vp9", | |||||
| .long_name = NULL_IF_CONFIG_SMALL("Google VP9"), | |||||
| .props = AV_CODEC_PROP_LOSSY, | |||||
| }, | |||||
| { | { | ||||
| .id = AV_CODEC_ID_PICTOR, | .id = AV_CODEC_ID_PICTOR, | ||||
| .type = AVMEDIA_TYPE_VIDEO, | .type = AVMEDIA_TYPE_VIDEO, | ||||
| @@ -35,10 +35,10 @@ typedef struct VP8DecoderContext { | |||||
| struct vpx_codec_ctx decoder; | struct vpx_codec_ctx decoder; | ||||
| } VP8Context; | } VP8Context; | ||||
| static av_cold int vp8_init(AVCodecContext *avctx) | |||||
| static av_cold int vpx_init(AVCodecContext *avctx, | |||||
| const struct vpx_codec_iface *iface) | |||||
| { | { | ||||
| VP8Context *ctx = avctx->priv_data; | VP8Context *ctx = avctx->priv_data; | ||||
| const struct vpx_codec_iface *iface = &vpx_codec_vp8_dx_algo; | |||||
| struct vpx_codec_dec_cfg deccfg = { | struct vpx_codec_dec_cfg deccfg = { | ||||
| /* token partitions+1 would be a decent choice */ | /* token partitions+1 would be a decent choice */ | ||||
| .threads = FFMIN(avctx->thread_count, 16) | .threads = FFMIN(avctx->thread_count, 16) | ||||
| @@ -112,7 +112,13 @@ static av_cold int vp8_free(AVCodecContext *avctx) | |||||
| return 0; | return 0; | ||||
| } | } | ||||
| AVCodec ff_libvpx_decoder = { | |||||
| #if CONFIG_LIBVPX_VP8_DECODER | |||||
| static av_cold int vp8_init(AVCodecContext *avctx) | |||||
| { | |||||
| return vpx_init(avctx, &vpx_codec_vp8_dx_algo); | |||||
| } | |||||
| AVCodec ff_libvpx_vp8_decoder = { | |||||
| .name = "libvpx", | .name = "libvpx", | ||||
| .type = AVMEDIA_TYPE_VIDEO, | .type = AVMEDIA_TYPE_VIDEO, | ||||
| .id = AV_CODEC_ID_VP8, | .id = AV_CODEC_ID_VP8, | ||||
| @@ -123,3 +129,23 @@ AVCodec ff_libvpx_decoder = { | |||||
| .capabilities = CODEC_CAP_AUTO_THREADS, | .capabilities = CODEC_CAP_AUTO_THREADS, | ||||
| .long_name = NULL_IF_CONFIG_SMALL("libvpx VP8"), | .long_name = NULL_IF_CONFIG_SMALL("libvpx VP8"), | ||||
| }; | }; | ||||
| #endif /* CONFIG_LIBVPX_VP8_DECODER */ | |||||
| #if CONFIG_LIBVPX_VP9_DECODER | |||||
| static av_cold int vp9_init(AVCodecContext *avctx) | |||||
| { | |||||
| return vpx_init(avctx, &vpx_codec_vp9_dx_algo); | |||||
| } | |||||
| AVCodec ff_libvpx_vp9_decoder = { | |||||
| .name = "libvpx-vp9", | |||||
| .type = AVMEDIA_TYPE_VIDEO, | |||||
| .id = AV_CODEC_ID_VP9, | |||||
| .priv_data_size = sizeof(VP8Context), | |||||
| .init = vp9_init, | |||||
| .close = vp8_free, | |||||
| .decode = vp8_decode, | |||||
| .capabilities = CODEC_CAP_AUTO_THREADS | CODEC_CAP_EXPERIMENTAL, | |||||
| .long_name = NULL_IF_CONFIG_SMALL("libvpx VP9"), | |||||
| }; | |||||
| #endif /* CONFIG_LIBVPX_VP9_DECODER */ | |||||
| @@ -227,10 +227,10 @@ static av_cold int vp8_free(AVCodecContext *avctx) | |||||
| return 0; | return 0; | ||||
| } | } | ||||
| static av_cold int vp8_init(AVCodecContext *avctx) | |||||
| static av_cold int vpx_init(AVCodecContext *avctx, | |||||
| const struct vpx_codec_iface *iface) | |||||
| { | { | ||||
| VP8Context *ctx = avctx->priv_data; | VP8Context *ctx = avctx->priv_data; | ||||
| const struct vpx_codec_iface *iface = &vpx_codec_vp8_cx_algo; | |||||
| struct vpx_codec_enc_cfg enccfg; | struct vpx_codec_enc_cfg enccfg; | ||||
| int res; | int res; | ||||
| @@ -608,13 +608,6 @@ static const AVOption options[] = { | |||||
| { NULL } | { NULL } | ||||
| }; | }; | ||||
| static const AVClass class = { | |||||
| .class_name = "libvpx encoder", | |||||
| .item_name = av_default_item_name, | |||||
| .option = options, | |||||
| .version = LIBAVUTIL_VERSION_INT, | |||||
| }; | |||||
| static const AVCodecDefault defaults[] = { | static const AVCodecDefault defaults[] = { | ||||
| { "qmin", "-1" }, | { "qmin", "-1" }, | ||||
| { "qmax", "-1" }, | { "qmax", "-1" }, | ||||
| @@ -623,7 +616,20 @@ static const AVCodecDefault defaults[] = { | |||||
| { NULL }, | { NULL }, | ||||
| }; | }; | ||||
| AVCodec ff_libvpx_encoder = { | |||||
| #if CONFIG_LIBVPX_VP8_ENCODER | |||||
| static av_cold int vp8_init(AVCodecContext *avctx) | |||||
| { | |||||
| return vpx_init(avctx, &vpx_codec_vp8_cx_algo); | |||||
| } | |||||
| static const AVClass class_vp8 = { | |||||
| .class_name = "libvpx encoder", | |||||
| .item_name = av_default_item_name, | |||||
| .option = options, | |||||
| .version = LIBAVUTIL_VERSION_INT, | |||||
| }; | |||||
| AVCodec ff_libvpx_vp8_encoder = { | |||||
| .name = "libvpx", | .name = "libvpx", | ||||
| .type = AVMEDIA_TYPE_VIDEO, | .type = AVMEDIA_TYPE_VIDEO, | ||||
| .id = AV_CODEC_ID_VP8, | .id = AV_CODEC_ID_VP8, | ||||
| @@ -634,6 +640,36 @@ AVCodec ff_libvpx_encoder = { | |||||
| .capabilities = CODEC_CAP_DELAY | CODEC_CAP_AUTO_THREADS, | .capabilities = CODEC_CAP_DELAY | CODEC_CAP_AUTO_THREADS, | ||||
| .pix_fmts = (const enum AVPixelFormat[]){ AV_PIX_FMT_YUV420P, AV_PIX_FMT_NONE }, | .pix_fmts = (const enum AVPixelFormat[]){ AV_PIX_FMT_YUV420P, AV_PIX_FMT_NONE }, | ||||
| .long_name = NULL_IF_CONFIG_SMALL("libvpx VP8"), | .long_name = NULL_IF_CONFIG_SMALL("libvpx VP8"), | ||||
| .priv_class = &class, | |||||
| .priv_class = &class_vp8, | |||||
| .defaults = defaults, | |||||
| }; | |||||
| #endif /* CONFIG_LIBVPX_VP8_ENCODER */ | |||||
| #if CONFIG_LIBVPX_VP9_ENCODER | |||||
| static av_cold int vp9_init(AVCodecContext *avctx) | |||||
| { | |||||
| return vpx_init(avctx, &vpx_codec_vp9_cx_algo); | |||||
| } | |||||
| static const AVClass class_vp9 = { | |||||
| .class_name = "libvpx encoder", | |||||
| .item_name = av_default_item_name, | |||||
| .option = options, | |||||
| .version = LIBAVUTIL_VERSION_INT, | |||||
| }; | |||||
| AVCodec ff_libvpx_vp9_encoder = { | |||||
| .name = "libvpx-vp9", | |||||
| .type = AVMEDIA_TYPE_VIDEO, | |||||
| .id = AV_CODEC_ID_VP9, | |||||
| .priv_data_size = sizeof(VP8Context), | |||||
| .init = vp9_init, | |||||
| .encode2 = vp8_encode, | |||||
| .close = vp8_free, | |||||
| .capabilities = CODEC_CAP_DELAY | CODEC_CAP_AUTO_THREADS | CODEC_CAP_EXPERIMENTAL, | |||||
| .pix_fmts = (const enum AVPixelFormat[]){ AV_PIX_FMT_YUV420P, AV_PIX_FMT_NONE }, | |||||
| .long_name = NULL_IF_CONFIG_SMALL("libvpx VP9"), | |||||
| .priv_class = &class_vp9, | |||||
| .defaults = defaults, | .defaults = defaults, | ||||
| }; | }; | ||||
| #endif /* CONFIG_LIBVPX_VP9_ENCODER */ | |||||
| @@ -82,6 +82,7 @@ const CodecTags ff_mkv_codec_tags[]={ | |||||
| {"V_THEORA" , AV_CODEC_ID_THEORA}, | {"V_THEORA" , AV_CODEC_ID_THEORA}, | ||||
| {"V_UNCOMPRESSED" , AV_CODEC_ID_RAWVIDEO}, | {"V_UNCOMPRESSED" , AV_CODEC_ID_RAWVIDEO}, | ||||
| {"V_VP8" , AV_CODEC_ID_VP8}, | {"V_VP8" , AV_CODEC_ID_VP8}, | ||||
| {"V_VP9" , AV_CODEC_ID_VP9}, | |||||
| {"" , AV_CODEC_ID_NONE} | {"" , AV_CODEC_ID_NONE} | ||||
| }; | }; | ||||
| @@ -40,6 +40,7 @@ const AVCodecTag ff_nut_data_tags[] = { | |||||
| }; | }; | ||||
| const AVCodecTag ff_nut_video_tags[] = { | const AVCodecTag ff_nut_video_tags[] = { | ||||
| { AV_CODEC_ID_VP9, MKTAG('V', 'P', '9', '0') }, | |||||
| { AV_CODEC_ID_RAWVIDEO, MKTAG('R', 'G', 'B', 15 ) }, | { AV_CODEC_ID_RAWVIDEO, MKTAG('R', 'G', 'B', 15 ) }, | ||||
| { AV_CODEC_ID_RAWVIDEO, MKTAG('B', 'G', 'R', 15 ) }, | { AV_CODEC_ID_RAWVIDEO, MKTAG('B', 'G', 'R', 15 ) }, | ||||
| { AV_CODEC_ID_RAWVIDEO, MKTAG('R', 'G', 'B', 16 ) }, | { AV_CODEC_ID_RAWVIDEO, MKTAG('R', 'G', 'B', 16 ) }, | ||||
| @@ -83,9 +83,9 @@ typedef struct RTPStatistics { | |||||
| uint32_t base_seq; ///< base sequence number | uint32_t base_seq; ///< base sequence number | ||||
| uint32_t bad_seq; ///< last bad sequence number + 1 | uint32_t bad_seq; ///< last bad sequence number + 1 | ||||
| int probation; ///< sequence packets till source is valid | int probation; ///< sequence packets till source is valid | ||||
| int received; ///< packets received | |||||
| int expected_prior; ///< packets expected in last interval | |||||
| int received_prior; ///< packets received in last interval | |||||
| uint32_t received; ///< packets received | |||||
| uint32_t expected_prior; ///< packets expected in last interval | |||||
| uint32_t received_prior; ///< packets received in last interval | |||||
| uint32_t transit; ///< relative transit time for previous packet | uint32_t transit; ///< relative transit time for previous packet | ||||
| uint32_t jitter; ///< estimated jitter. | uint32_t jitter; ///< estimated jitter. | ||||
| } RTPStatistics; | } RTPStatistics; | ||||