Signed-off-by: Paul B Mahol <onemda@gmail.com> Signed-off-by: Michael Niedermayer <michaelni@gmx.at>tags/n0.10
| @@ -18,7 +18,7 @@ version next: | |||||
| - Automatic thread count based on detection number of (available) CPU cores | - Automatic thread count based on detection number of (available) CPU cores | ||||
| - y41p Brooktree Uncompressed 4:1:1 12-bit encoder and decoder | - y41p Brooktree Uncompressed 4:1:1 12-bit encoder and decoder | ||||
| - ffprobe -show_error option | - ffprobe -show_error option | ||||
| - Avid 1:1 10-bit RGB Packer decoder | |||||
| - Avid 1:1 10-bit RGB Packer codec | |||||
| - v308 Quicktime Uncompressed 4:4:4 encoder and decoder | - v308 Quicktime Uncompressed 4:4:4 encoder and decoder | ||||
| - yuv4 libquicktime packed 4:2:0 encoder and decoder | - yuv4 libquicktime packed 4:2:0 encoder and decoder | ||||
| - ffprobe -show_frames option | - ffprobe -show_frames option | ||||
| @@ -28,6 +28,7 @@ version next: | |||||
| - optimized iMDCT transform on x86 using SSE for for mpegaudiodec | - optimized iMDCT transform on x86 using SSE for for mpegaudiodec | ||||
| - Improved PGS subtitle decoder | - Improved PGS subtitle decoder | ||||
| - dumpgraph option to lavfi device | - dumpgraph option to lavfi device | ||||
| - r210 and r10k encoders | |||||
| version 0.9: | version 0.9: | ||||
| @@ -440,7 +440,7 @@ following image formats are supported: | |||||
| @item Autodesk Animator Flic video @tab @tab X | @item Autodesk Animator Flic video @tab @tab X | ||||
| @item Autodesk RLE @tab @tab X | @item Autodesk RLE @tab @tab X | ||||
| @tab fourcc: AASC | @tab fourcc: AASC | ||||
| @item Avid 1:1 10-bit RGB Packer @tab @tab X | |||||
| @item Avid 1:1 10-bit RGB Packer @tab X @tab X | |||||
| @tab fourcc: AVrp | @tab fourcc: AVrp | ||||
| @item AVS (Audio Video Standard) video @tab @tab X | @item AVS (Audio Video Standard) video @tab @tab X | ||||
| @tab Video encoding used by the Creature Shock game. | @tab Video encoding used by the Creature Shock game. | ||||
| @@ -577,8 +577,8 @@ following image formats are supported: | |||||
| @tab fourcc: 'smc ' | @tab fourcc: 'smc ' | ||||
| @item QuickTime video (RPZA) @tab @tab X | @item QuickTime video (RPZA) @tab @tab X | ||||
| @tab fourcc: rpza | @tab fourcc: rpza | ||||
| @item R10K AJA Kona 10-bit RGB Codec @tab @tab X | |||||
| @item R210 Quicktime Uncompressed RGB 10-bit @tab @tab X | |||||
| @item R10K AJA Kona 10-bit RGB Codec @tab X @tab X | |||||
| @item R210 Quicktime Uncompressed RGB 10-bit @tab X @tab X | |||||
| @item Raw Video @tab X @tab X | @item Raw Video @tab X @tab X | ||||
| @item RealVideo 1.0 @tab X @tab X | @item RealVideo 1.0 @tab X @tab X | ||||
| @item RealVideo 2.0 @tab X @tab X | @item RealVideo 2.0 @tab X @tab X | ||||
| @@ -92,6 +92,7 @@ OBJS-$(CONFIG_ATRAC3_DECODER) += atrac3.o atrac.o | |||||
| OBJS-$(CONFIG_AURA_DECODER) += cyuv.o | OBJS-$(CONFIG_AURA_DECODER) += cyuv.o | ||||
| OBJS-$(CONFIG_AURA2_DECODER) += aura.o | OBJS-$(CONFIG_AURA2_DECODER) += aura.o | ||||
| OBJS-$(CONFIG_AVRP_DECODER) += r210dec.o | OBJS-$(CONFIG_AVRP_DECODER) += r210dec.o | ||||
| OBJS-$(CONFIG_AVRP_ENCODER) += r210enc.o | |||||
| OBJS-$(CONFIG_AVS_DECODER) += avs.o | OBJS-$(CONFIG_AVS_DECODER) += avs.o | ||||
| OBJS-$(CONFIG_BETHSOFTVID_DECODER) += bethsoftvideo.o | OBJS-$(CONFIG_BETHSOFTVID_DECODER) += bethsoftvideo.o | ||||
| OBJS-$(CONFIG_BFI_DECODER) += bfi.o | OBJS-$(CONFIG_BFI_DECODER) += bfi.o | ||||
| @@ -339,7 +340,9 @@ OBJS-$(CONFIG_QPEG_DECODER) += qpeg.o | |||||
| OBJS-$(CONFIG_QTRLE_DECODER) += qtrle.o | OBJS-$(CONFIG_QTRLE_DECODER) += qtrle.o | ||||
| OBJS-$(CONFIG_QTRLE_ENCODER) += qtrleenc.o | OBJS-$(CONFIG_QTRLE_ENCODER) += qtrleenc.o | ||||
| OBJS-$(CONFIG_R10K_DECODER) += r210dec.o | OBJS-$(CONFIG_R10K_DECODER) += r210dec.o | ||||
| OBJS-$(CONFIG_R10K_ENCODER) += r210enc.o | |||||
| OBJS-$(CONFIG_R210_DECODER) += r210dec.o | OBJS-$(CONFIG_R210_DECODER) += r210dec.o | ||||
| OBJS-$(CONFIG_R210_ENCODER) += r210enc.o | |||||
| OBJS-$(CONFIG_RA_144_DECODER) += ra144dec.o ra144.o celp_filters.o | OBJS-$(CONFIG_RA_144_DECODER) += ra144dec.o ra144.o celp_filters.o | ||||
| OBJS-$(CONFIG_RA_144_ENCODER) += ra144enc.o ra144.o celp_filters.o | OBJS-$(CONFIG_RA_144_ENCODER) += ra144enc.o ra144.o celp_filters.o | ||||
| OBJS-$(CONFIG_RA_288_DECODER) += ra288.o celp_math.o celp_filters.o | OBJS-$(CONFIG_RA_288_DECODER) += ra288.o celp_math.o celp_filters.o | ||||
| @@ -79,7 +79,7 @@ void avcodec_register_all(void) | |||||
| REGISTER_ENCDEC (ASV2, asv2); | REGISTER_ENCDEC (ASV2, asv2); | ||||
| REGISTER_DECODER (AURA, aura); | REGISTER_DECODER (AURA, aura); | ||||
| REGISTER_DECODER (AURA2, aura2); | REGISTER_DECODER (AURA2, aura2); | ||||
| REGISTER_DECODER (AVRP, avrp); | |||||
| REGISTER_ENCDEC (AVRP, avrp); | |||||
| REGISTER_DECODER (AVS, avs); | REGISTER_DECODER (AVS, avs); | ||||
| REGISTER_DECODER (BETHSOFTVID, bethsoftvid); | REGISTER_DECODER (BETHSOFTVID, bethsoftvid); | ||||
| REGISTER_DECODER (BFI, bfi); | REGISTER_DECODER (BFI, bfi); | ||||
| @@ -184,8 +184,8 @@ void avcodec_register_all(void) | |||||
| REGISTER_DECODER (QDRAW, qdraw); | REGISTER_DECODER (QDRAW, qdraw); | ||||
| REGISTER_DECODER (QPEG, qpeg); | REGISTER_DECODER (QPEG, qpeg); | ||||
| REGISTER_ENCDEC (QTRLE, qtrle); | REGISTER_ENCDEC (QTRLE, qtrle); | ||||
| REGISTER_DECODER (R10K, r10k); | |||||
| REGISTER_DECODER (R210, r210); | |||||
| REGISTER_ENCDEC (R10K, r10k); | |||||
| REGISTER_ENCDEC (R210, r210); | |||||
| REGISTER_ENCDEC (RAWVIDEO, rawvideo); | REGISTER_ENCDEC (RAWVIDEO, rawvideo); | ||||
| REGISTER_DECODER (RL2, rl2); | REGISTER_DECODER (RL2, rl2); | ||||
| REGISTER_ENCDEC (ROQ, roq); | REGISTER_ENCDEC (ROQ, roq); | ||||
| @@ -0,0 +1,120 @@ | |||||
| /* | |||||
| * R210 encoder | |||||
| * | |||||
| * Copyright (c) 2012 Paul B Mahol | |||||
| * | |||||
| * This file is part of FFmpeg. | |||||
| * | |||||
| * FFmpeg 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. | |||||
| * | |||||
| * FFmpeg 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 FFmpeg; if not, write to the Free Software | |||||
| * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | |||||
| */ | |||||
| #include "avcodec.h" | |||||
| #include "bytestream.h" | |||||
| static av_cold int encode_init(AVCodecContext *avctx) | |||||
| { | |||||
| avctx->coded_frame = avcodec_alloc_frame(); | |||||
| if (!avctx->coded_frame) | |||||
| return AVERROR(ENOMEM); | |||||
| return 0; | |||||
| } | |||||
| static int encode_frame(AVCodecContext *avctx, uint8_t *buf, | |||||
| int buf_size, void *data) | |||||
| { | |||||
| AVFrame *pic = data; | |||||
| int i, j; | |||||
| int aligned_width = FFALIGN(avctx->width, 64); | |||||
| uint8_t *src_line; | |||||
| uint8_t *dst = buf; | |||||
| if (buf_size < 4 * aligned_width * avctx->height) { | |||||
| av_log(avctx, AV_LOG_ERROR, "output buffer too small\n"); | |||||
| return AVERROR(ENOMEM); | |||||
| } | |||||
| avctx->coded_frame->reference = 0; | |||||
| avctx->coded_frame->key_frame = 1; | |||||
| avctx->coded_frame->pict_type = AV_PICTURE_TYPE_I; | |||||
| src_line = pic->data[0]; | |||||
| for (i = 0; i < avctx->height; i++) { | |||||
| uint16_t *src = (uint16_t *)src_line; | |||||
| for (j = 0; j < avctx->width; j++) { | |||||
| uint32_t pixel; | |||||
| uint16_t r = *src++ >> 6; | |||||
| uint16_t g = *src++ >> 6; | |||||
| uint16_t b = *src++ >> 4; | |||||
| if (avctx->codec_id == CODEC_ID_R210) | |||||
| pixel = (r << 20) | (g << 10) | b >> 2; | |||||
| else | |||||
| pixel = (r << 22) | (g << 12) | b; | |||||
| if (avctx->codec_id == CODEC_ID_AVRP) | |||||
| bytestream_put_le32(&dst, pixel); | |||||
| else | |||||
| bytestream_put_be32(&dst, pixel); | |||||
| } | |||||
| dst += aligned_width - avctx->width; | |||||
| src_line += pic->linesize[0]; | |||||
| } | |||||
| return 4 * aligned_width * avctx->height; | |||||
| } | |||||
| static av_cold int encode_close(AVCodecContext *avctx) | |||||
| { | |||||
| av_freep(&avctx->coded_frame); | |||||
| return 0; | |||||
| } | |||||
| #if CONFIG_R210_ENCODER | |||||
| AVCodec ff_r210_encoder = { | |||||
| .name = "r210", | |||||
| .type = AVMEDIA_TYPE_VIDEO, | |||||
| .id = CODEC_ID_R210, | |||||
| .init = encode_init, | |||||
| .encode = encode_frame, | |||||
| .close = encode_close, | |||||
| .pix_fmts = (const enum PixelFormat[]) { PIX_FMT_RGB48, PIX_FMT_NONE }, | |||||
| .long_name = NULL_IF_CONFIG_SMALL("Uncompressed RGB 10-bit"), | |||||
| }; | |||||
| #endif | |||||
| #if CONFIG_R10K_ENCODER | |||||
| AVCodec ff_r10k_encoder = { | |||||
| .name = "r10k", | |||||
| .type = AVMEDIA_TYPE_VIDEO, | |||||
| .id = CODEC_ID_R10K, | |||||
| .init = encode_init, | |||||
| .encode = encode_frame, | |||||
| .close = encode_close, | |||||
| .pix_fmts = (const enum PixelFormat[]) { PIX_FMT_RGB48, PIX_FMT_NONE }, | |||||
| .long_name = NULL_IF_CONFIG_SMALL("AJA Kona 10-bit RGB Codec"), | |||||
| }; | |||||
| #endif | |||||
| #if CONFIG_AVRP_ENCODER | |||||
| AVCodec ff_avrp_encoder = { | |||||
| .name = "avrp", | |||||
| .type = AVMEDIA_TYPE_VIDEO, | |||||
| .id = CODEC_ID_AVRP, | |||||
| .init = encode_init, | |||||
| .encode = encode_frame, | |||||
| .close = encode_close, | |||||
| .pix_fmts = (const enum PixelFormat[]) { PIX_FMT_RGB48, PIX_FMT_NONE }, | |||||
| .long_name = NULL_IF_CONFIG_SMALL("Avid 1:1 10-bit RGB Packer"), | |||||
| }; | |||||
| #endif | |||||
| @@ -21,7 +21,7 @@ | |||||
| #define AVCODEC_VERSION_H | #define AVCODEC_VERSION_H | ||||
| #define LIBAVCODEC_VERSION_MAJOR 53 | #define LIBAVCODEC_VERSION_MAJOR 53 | ||||
| #define LIBAVCODEC_VERSION_MINOR 59 | |||||
| #define LIBAVCODEC_VERSION_MINOR 60 | |||||
| #define LIBAVCODEC_VERSION_MICRO 100 | #define LIBAVCODEC_VERSION_MICRO 100 | ||||
| #define LIBAVCODEC_VERSION_INT AV_VERSION_INT(LIBAVCODEC_VERSION_MAJOR, \ | #define LIBAVCODEC_VERSION_INT AV_VERSION_INT(LIBAVCODEC_VERSION_MAJOR, \ | ||||