mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-24 13:56:33 +02:00
Merge remote-tracking branch 'qatar/master'
* qatar/master: x86: dsputil: Only compile motion_est code when encoders are enabled mem: fix typo in check for __ICC fate: mp3: drop redundant CMP setting rtp: Depacketization of JPEG (RFC 2435) Rename ff_put_string to avpriv_put_string mjpeg: Rename some symbols to avpriv_* instead of ff_* yadif: cosmetics Conflicts: Changelog libavcodec/mjpegenc.c libavcodec/x86/Makefile libavfilter/vf_yadif.c libavformat/version.h libavutil/mem.h Merged-by: Michael Niedermayer <michaelni@gmx.at>
This commit is contained in:
commit
bff2afb3e9
@ -59,6 +59,7 @@ version next:
|
|||||||
- smartblur filter ported from MPlayer
|
- smartblur filter ported from MPlayer
|
||||||
- CPiA decoder
|
- CPiA decoder
|
||||||
- decimate filter ported from MPlayer
|
- decimate filter ported from MPlayer
|
||||||
|
- RTP depacketization of JPEG
|
||||||
|
|
||||||
|
|
||||||
version 0.11:
|
version 0.11:
|
||||||
|
@ -628,6 +628,7 @@ OBJS-$(CONFIG_OGG_DEMUXER) += xiph.o flac.o flacdata.o \
|
|||||||
OBJS-$(CONFIG_OGG_MUXER) += xiph.o flac.o flacdata.o \
|
OBJS-$(CONFIG_OGG_MUXER) += xiph.o flac.o flacdata.o \
|
||||||
vorbis_data.o
|
vorbis_data.o
|
||||||
OBJS-$(CONFIG_RTP_MUXER) += mpeg4audio.o xiph.o
|
OBJS-$(CONFIG_RTP_MUXER) += mpeg4audio.o xiph.o
|
||||||
|
OBJS-$(CONFIG_RTPDEC) += mjpeg.o
|
||||||
OBJS-$(CONFIG_SPDIF_DEMUXER) += aacadtsdec.o mpeg4audio.o
|
OBJS-$(CONFIG_SPDIF_DEMUXER) += aacadtsdec.o mpeg4audio.o
|
||||||
OBJS-$(CONFIG_SPDIF_MUXER) += dca.o
|
OBJS-$(CONFIG_SPDIF_MUXER) += dca.o
|
||||||
OBJS-$(CONFIG_WEBM_MUXER) += mpeg4audio.o mpegaudiodata.o \
|
OBJS-$(CONFIG_WEBM_MUXER) += mpeg4audio.o mpegaudiodata.o \
|
||||||
|
@ -47,7 +47,7 @@ void avpriv_align_put_bits(PutBitContext *s)
|
|||||||
put_bits(s,s->bit_left & 7,0);
|
put_bits(s,s->bit_left & 7,0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ff_put_string(PutBitContext *pb, const char *string, int terminate_string)
|
void avpriv_put_string(PutBitContext *pb, const char *string, int terminate_string)
|
||||||
{
|
{
|
||||||
while(*string){
|
while(*string){
|
||||||
put_bits(pb, 8, *string);
|
put_bits(pb, 8, *string);
|
||||||
|
@ -62,17 +62,17 @@ const unsigned char std_chrominance_quant_tbl[64] = {
|
|||||||
|
|
||||||
/* Set up the standard Huffman tables (cf. JPEG standard section K.3) */
|
/* Set up the standard Huffman tables (cf. JPEG standard section K.3) */
|
||||||
/* IMPORTANT: these are only valid for 8-bit data precision! */
|
/* IMPORTANT: these are only valid for 8-bit data precision! */
|
||||||
const uint8_t ff_mjpeg_bits_dc_luminance[17] =
|
const uint8_t avpriv_mjpeg_bits_dc_luminance[17] =
|
||||||
{ /* 0-base */ 0, 0, 1, 5, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0 };
|
{ /* 0-base */ 0, 0, 1, 5, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0 };
|
||||||
const uint8_t ff_mjpeg_val_dc[12] =
|
const uint8_t avpriv_mjpeg_val_dc[12] =
|
||||||
{ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11 };
|
{ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11 };
|
||||||
|
|
||||||
const uint8_t ff_mjpeg_bits_dc_chrominance[17] =
|
const uint8_t avpriv_mjpeg_bits_dc_chrominance[17] =
|
||||||
{ /* 0-base */ 0, 0, 3, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0 };
|
{ /* 0-base */ 0, 0, 3, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0 };
|
||||||
|
|
||||||
const uint8_t ff_mjpeg_bits_ac_luminance[17] =
|
const uint8_t avpriv_mjpeg_bits_ac_luminance[17] =
|
||||||
{ /* 0-base */ 0, 0, 2, 1, 3, 3, 2, 4, 3, 5, 5, 4, 4, 0, 0, 1, 0x7d };
|
{ /* 0-base */ 0, 0, 2, 1, 3, 3, 2, 4, 3, 5, 5, 4, 4, 0, 0, 1, 0x7d };
|
||||||
const uint8_t ff_mjpeg_val_ac_luminance[] =
|
const uint8_t avpriv_mjpeg_val_ac_luminance[] =
|
||||||
{ 0x01, 0x02, 0x03, 0x00, 0x04, 0x11, 0x05, 0x12,
|
{ 0x01, 0x02, 0x03, 0x00, 0x04, 0x11, 0x05, 0x12,
|
||||||
0x21, 0x31, 0x41, 0x06, 0x13, 0x51, 0x61, 0x07,
|
0x21, 0x31, 0x41, 0x06, 0x13, 0x51, 0x61, 0x07,
|
||||||
0x22, 0x71, 0x14, 0x32, 0x81, 0x91, 0xa1, 0x08,
|
0x22, 0x71, 0x14, 0x32, 0x81, 0x91, 0xa1, 0x08,
|
||||||
@ -96,10 +96,10 @@ const uint8_t ff_mjpeg_val_ac_luminance[] =
|
|||||||
0xf9, 0xfa
|
0xf9, 0xfa
|
||||||
};
|
};
|
||||||
|
|
||||||
const uint8_t ff_mjpeg_bits_ac_chrominance[17] =
|
const uint8_t avpriv_mjpeg_bits_ac_chrominance[17] =
|
||||||
{ /* 0-base */ 0, 0, 2, 1, 2, 4, 4, 3, 4, 7, 5, 4, 4, 0, 1, 2, 0x77 };
|
{ /* 0-base */ 0, 0, 2, 1, 2, 4, 4, 3, 4, 7, 5, 4, 4, 0, 1, 2, 0x77 };
|
||||||
|
|
||||||
const uint8_t ff_mjpeg_val_ac_chrominance[] =
|
const uint8_t avpriv_mjpeg_val_ac_chrominance[] =
|
||||||
{ 0x00, 0x01, 0x02, 0x03, 0x11, 0x04, 0x05, 0x21,
|
{ 0x00, 0x01, 0x02, 0x03, 0x11, 0x04, 0x05, 0x21,
|
||||||
0x31, 0x06, 0x12, 0x41, 0x51, 0x07, 0x61, 0x71,
|
0x31, 0x06, 0x12, 0x41, 0x51, 0x07, 0x61, 0x71,
|
||||||
0x13, 0x22, 0x32, 0x81, 0x08, 0x14, 0x42, 0x91,
|
0x13, 0x22, 0x32, 0x81, 0x08, 0x14, 0x42, 0x91,
|
||||||
|
@ -138,16 +138,16 @@ static inline void put_marker(PutBitContext *p, int code)
|
|||||||
case 7: ret= (left + top)>>1; break;\
|
case 7: ret= (left + top)>>1; break;\
|
||||||
}
|
}
|
||||||
|
|
||||||
extern const uint8_t ff_mjpeg_bits_dc_luminance[];
|
extern const uint8_t avpriv_mjpeg_bits_dc_luminance[];
|
||||||
extern const uint8_t ff_mjpeg_val_dc[];
|
extern const uint8_t avpriv_mjpeg_val_dc[];
|
||||||
|
|
||||||
extern const uint8_t ff_mjpeg_bits_dc_chrominance[];
|
extern const uint8_t avpriv_mjpeg_bits_dc_chrominance[];
|
||||||
|
|
||||||
extern const uint8_t ff_mjpeg_bits_ac_luminance[];
|
extern const uint8_t avpriv_mjpeg_bits_ac_luminance[];
|
||||||
extern const uint8_t ff_mjpeg_val_ac_luminance[];
|
extern const uint8_t avpriv_mjpeg_val_ac_luminance[];
|
||||||
|
|
||||||
extern const uint8_t ff_mjpeg_bits_ac_chrominance[];
|
extern const uint8_t avpriv_mjpeg_bits_ac_chrominance[];
|
||||||
extern const uint8_t ff_mjpeg_val_ac_chrominance[];
|
extern const uint8_t avpriv_mjpeg_val_ac_chrominance[];
|
||||||
|
|
||||||
void ff_mjpeg_build_huffman_codes(uint8_t *huff_size, uint16_t *huff_code,
|
void ff_mjpeg_build_huffman_codes(uint8_t *huff_size, uint16_t *huff_code,
|
||||||
const uint8_t *bits_table,
|
const uint8_t *bits_table,
|
||||||
|
@ -59,15 +59,15 @@ static uint8_t *append(uint8_t *buf, const uint8_t *src, int size)
|
|||||||
static uint8_t *append_dht_segment(uint8_t *buf)
|
static uint8_t *append_dht_segment(uint8_t *buf)
|
||||||
{
|
{
|
||||||
buf = append(buf, dht_segment_head, sizeof(dht_segment_head));
|
buf = append(buf, dht_segment_head, sizeof(dht_segment_head));
|
||||||
buf = append(buf, ff_mjpeg_bits_dc_luminance + 1, 16);
|
buf = append(buf, avpriv_mjpeg_bits_dc_luminance + 1, 16);
|
||||||
buf = append(buf, dht_segment_frag, sizeof(dht_segment_frag));
|
buf = append(buf, dht_segment_frag, sizeof(dht_segment_frag));
|
||||||
buf = append(buf, ff_mjpeg_val_dc, 12);
|
buf = append(buf, avpriv_mjpeg_val_dc, 12);
|
||||||
*(buf++) = 0x10;
|
*(buf++) = 0x10;
|
||||||
buf = append(buf, ff_mjpeg_bits_ac_luminance + 1, 16);
|
buf = append(buf, avpriv_mjpeg_bits_ac_luminance + 1, 16);
|
||||||
buf = append(buf, ff_mjpeg_val_ac_luminance, 162);
|
buf = append(buf, avpriv_mjpeg_val_ac_luminance, 162);
|
||||||
*(buf++) = 0x11;
|
*(buf++) = 0x11;
|
||||||
buf = append(buf, ff_mjpeg_bits_ac_chrominance + 1, 16);
|
buf = append(buf, avpriv_mjpeg_bits_ac_chrominance + 1, 16);
|
||||||
buf = append(buf, ff_mjpeg_val_ac_chrominance, 162);
|
buf = append(buf, avpriv_mjpeg_val_ac_chrominance, 162);
|
||||||
return buf;
|
return buf;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -65,18 +65,18 @@ static int build_vlc(VLC *vlc, const uint8_t *bits_table,
|
|||||||
|
|
||||||
static void build_basic_mjpeg_vlc(MJpegDecodeContext *s)
|
static void build_basic_mjpeg_vlc(MJpegDecodeContext *s)
|
||||||
{
|
{
|
||||||
build_vlc(&s->vlcs[0][0], ff_mjpeg_bits_dc_luminance,
|
build_vlc(&s->vlcs[0][0], avpriv_mjpeg_bits_dc_luminance,
|
||||||
ff_mjpeg_val_dc, 12, 0, 0);
|
avpriv_mjpeg_val_dc, 12, 0, 0);
|
||||||
build_vlc(&s->vlcs[0][1], ff_mjpeg_bits_dc_chrominance,
|
build_vlc(&s->vlcs[0][1], avpriv_mjpeg_bits_dc_chrominance,
|
||||||
ff_mjpeg_val_dc, 12, 0, 0);
|
avpriv_mjpeg_val_dc, 12, 0, 0);
|
||||||
build_vlc(&s->vlcs[1][0], ff_mjpeg_bits_ac_luminance,
|
build_vlc(&s->vlcs[1][0], avpriv_mjpeg_bits_ac_luminance,
|
||||||
ff_mjpeg_val_ac_luminance, 251, 0, 1);
|
avpriv_mjpeg_val_ac_luminance, 251, 0, 1);
|
||||||
build_vlc(&s->vlcs[1][1], ff_mjpeg_bits_ac_chrominance,
|
build_vlc(&s->vlcs[1][1], avpriv_mjpeg_bits_ac_chrominance,
|
||||||
ff_mjpeg_val_ac_chrominance, 251, 0, 1);
|
avpriv_mjpeg_val_ac_chrominance, 251, 0, 1);
|
||||||
build_vlc(&s->vlcs[2][0], ff_mjpeg_bits_ac_luminance,
|
build_vlc(&s->vlcs[2][0], avpriv_mjpeg_bits_ac_luminance,
|
||||||
ff_mjpeg_val_ac_luminance, 251, 0, 0);
|
avpriv_mjpeg_val_ac_luminance, 251, 0, 0);
|
||||||
build_vlc(&s->vlcs[2][1], ff_mjpeg_bits_ac_chrominance,
|
build_vlc(&s->vlcs[2][1], avpriv_mjpeg_bits_ac_chrominance,
|
||||||
ff_mjpeg_val_ac_chrominance, 251, 0, 0);
|
avpriv_mjpeg_val_ac_chrominance, 251, 0, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
av_cold int ff_mjpeg_decode_init(AVCodecContext *avctx)
|
av_cold int ff_mjpeg_decode_init(AVCodecContext *avctx)
|
||||||
|
@ -60,20 +60,20 @@ av_cold int ff_mjpeg_encode_init(MpegEncContext *s)
|
|||||||
/* build all the huffman tables */
|
/* build all the huffman tables */
|
||||||
ff_mjpeg_build_huffman_codes(m->huff_size_dc_luminance,
|
ff_mjpeg_build_huffman_codes(m->huff_size_dc_luminance,
|
||||||
m->huff_code_dc_luminance,
|
m->huff_code_dc_luminance,
|
||||||
ff_mjpeg_bits_dc_luminance,
|
avpriv_mjpeg_bits_dc_luminance,
|
||||||
ff_mjpeg_val_dc);
|
avpriv_mjpeg_val_dc);
|
||||||
ff_mjpeg_build_huffman_codes(m->huff_size_dc_chrominance,
|
ff_mjpeg_build_huffman_codes(m->huff_size_dc_chrominance,
|
||||||
m->huff_code_dc_chrominance,
|
m->huff_code_dc_chrominance,
|
||||||
ff_mjpeg_bits_dc_chrominance,
|
avpriv_mjpeg_bits_dc_chrominance,
|
||||||
ff_mjpeg_val_dc);
|
avpriv_mjpeg_val_dc);
|
||||||
ff_mjpeg_build_huffman_codes(m->huff_size_ac_luminance,
|
ff_mjpeg_build_huffman_codes(m->huff_size_ac_luminance,
|
||||||
m->huff_code_ac_luminance,
|
m->huff_code_ac_luminance,
|
||||||
ff_mjpeg_bits_ac_luminance,
|
avpriv_mjpeg_bits_ac_luminance,
|
||||||
ff_mjpeg_val_ac_luminance);
|
avpriv_mjpeg_val_ac_luminance);
|
||||||
ff_mjpeg_build_huffman_codes(m->huff_size_ac_chrominance,
|
ff_mjpeg_build_huffman_codes(m->huff_size_ac_chrominance,
|
||||||
m->huff_code_ac_chrominance,
|
m->huff_code_ac_chrominance,
|
||||||
ff_mjpeg_bits_ac_chrominance,
|
avpriv_mjpeg_bits_ac_chrominance,
|
||||||
ff_mjpeg_val_ac_chrominance);
|
avpriv_mjpeg_val_ac_chrominance);
|
||||||
|
|
||||||
s->mjpeg_ctx = m;
|
s->mjpeg_ctx = m;
|
||||||
return 0;
|
return 0;
|
||||||
@ -146,15 +146,15 @@ static void jpeg_table_header(MpegEncContext *s)
|
|||||||
ptr = put_bits_ptr(p);
|
ptr = put_bits_ptr(p);
|
||||||
put_bits(p, 16, 0); /* patched later */
|
put_bits(p, 16, 0); /* patched later */
|
||||||
size = 2;
|
size = 2;
|
||||||
size += put_huffman_table(s, 0, 0, ff_mjpeg_bits_dc_luminance,
|
size += put_huffman_table(s, 0, 0, avpriv_mjpeg_bits_dc_luminance,
|
||||||
ff_mjpeg_val_dc);
|
avpriv_mjpeg_val_dc);
|
||||||
size += put_huffman_table(s, 0, 1, ff_mjpeg_bits_dc_chrominance,
|
size += put_huffman_table(s, 0, 1, avpriv_mjpeg_bits_dc_chrominance,
|
||||||
ff_mjpeg_val_dc);
|
avpriv_mjpeg_val_dc);
|
||||||
|
|
||||||
size += put_huffman_table(s, 1, 0, ff_mjpeg_bits_ac_luminance,
|
size += put_huffman_table(s, 1, 0, avpriv_mjpeg_bits_ac_luminance,
|
||||||
ff_mjpeg_val_ac_luminance);
|
avpriv_mjpeg_val_ac_luminance);
|
||||||
size += put_huffman_table(s, 1, 1, ff_mjpeg_bits_ac_chrominance,
|
size += put_huffman_table(s, 1, 1, avpriv_mjpeg_bits_ac_chrominance,
|
||||||
ff_mjpeg_val_ac_chrominance);
|
avpriv_mjpeg_val_ac_chrominance);
|
||||||
AV_WB16(ptr, size);
|
AV_WB16(ptr, size);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -169,7 +169,7 @@ static void jpeg_put_comments(MpegEncContext *s)
|
|||||||
/* JFIF header */
|
/* JFIF header */
|
||||||
put_marker(p, APP0);
|
put_marker(p, APP0);
|
||||||
put_bits(p, 16, 16);
|
put_bits(p, 16, 16);
|
||||||
ff_put_string(p, "JFIF", 1); /* this puts the trailing zero-byte too */
|
avpriv_put_string(p, "JFIF", 1); /* this puts the trailing zero-byte too */
|
||||||
put_bits(p, 16, 0x0102); /* v 1.02 */
|
put_bits(p, 16, 0x0102); /* v 1.02 */
|
||||||
put_bits(p, 8, 0); /* units type: 0 - aspect ratio */
|
put_bits(p, 8, 0); /* units type: 0 - aspect ratio */
|
||||||
put_bits(p, 16, s->avctx->sample_aspect_ratio.num);
|
put_bits(p, 16, s->avctx->sample_aspect_ratio.num);
|
||||||
@ -184,7 +184,7 @@ static void jpeg_put_comments(MpegEncContext *s)
|
|||||||
flush_put_bits(p);
|
flush_put_bits(p);
|
||||||
ptr = put_bits_ptr(p);
|
ptr = put_bits_ptr(p);
|
||||||
put_bits(p, 16, 0); /* patched later */
|
put_bits(p, 16, 0); /* patched later */
|
||||||
ff_put_string(p, LIBAVCODEC_IDENT, 1);
|
avpriv_put_string(p, LIBAVCODEC_IDENT, 1);
|
||||||
size = strlen(LIBAVCODEC_IDENT)+3;
|
size = strlen(LIBAVCODEC_IDENT)+3;
|
||||||
AV_WB16(ptr, size);
|
AV_WB16(ptr, size);
|
||||||
}
|
}
|
||||||
@ -196,7 +196,7 @@ static void jpeg_put_comments(MpegEncContext *s)
|
|||||||
flush_put_bits(p);
|
flush_put_bits(p);
|
||||||
ptr = put_bits_ptr(p);
|
ptr = put_bits_ptr(p);
|
||||||
put_bits(p, 16, 0); /* patched later */
|
put_bits(p, 16, 0); /* patched later */
|
||||||
ff_put_string(p, "CS=ITU601", 1);
|
avpriv_put_string(p, "CS=ITU601", 1);
|
||||||
size = strlen("CS=ITU601")+3;
|
size = strlen("CS=ITU601")+3;
|
||||||
AV_WB16(ptr, size);
|
AV_WB16(ptr, size);
|
||||||
}
|
}
|
||||||
|
@ -1035,7 +1035,7 @@ static void mpeg4_encode_vol_header(MpegEncContext * s, int vo_number, int vol_n
|
|||||||
if(!(s->flags & CODEC_FLAG_BITEXACT)){
|
if(!(s->flags & CODEC_FLAG_BITEXACT)){
|
||||||
put_bits(&s->pb, 16, 0);
|
put_bits(&s->pb, 16, 0);
|
||||||
put_bits(&s->pb, 16, 0x1B2); /* user_data */
|
put_bits(&s->pb, 16, 0x1B2); /* user_data */
|
||||||
ff_put_string(&s->pb, LIBAVCODEC_IDENT, 0);
|
avpriv_put_string(&s->pb, LIBAVCODEC_IDENT, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -99,7 +99,7 @@ static inline void flush_put_bits(PutBitContext *s)
|
|||||||
|
|
||||||
#ifdef BITSTREAM_WRITER_LE
|
#ifdef BITSTREAM_WRITER_LE
|
||||||
#define avpriv_align_put_bits align_put_bits_unsupported_here
|
#define avpriv_align_put_bits align_put_bits_unsupported_here
|
||||||
#define ff_put_string ff_put_string_unsupported_here
|
#define avpriv_put_string ff_put_string_unsupported_here
|
||||||
#define avpriv_copy_bits avpriv_copy_bits_unsupported_here
|
#define avpriv_copy_bits avpriv_copy_bits_unsupported_here
|
||||||
#else
|
#else
|
||||||
/**
|
/**
|
||||||
@ -112,7 +112,7 @@ void avpriv_align_put_bits(PutBitContext *s);
|
|||||||
*
|
*
|
||||||
* @param terminate_string 0-terminates the written string if value is 1
|
* @param terminate_string 0-terminates the written string if value is 1
|
||||||
*/
|
*/
|
||||||
void ff_put_string(PutBitContext *pb, const char *string, int terminate_string);
|
void avpriv_put_string(PutBitContext *pb, const char *string, int terminate_string);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Copy the content of src to the bitstream.
|
* Copy the content of src to the bitstream.
|
||||||
|
@ -11,7 +11,6 @@ MMX-OBJS += x86/dsputil_mmx.o \
|
|||||||
x86/fmtconvert_init.o \
|
x86/fmtconvert_init.o \
|
||||||
x86/idct_mmx_xvid.o \
|
x86/idct_mmx_xvid.o \
|
||||||
x86/idct_sse2_xvid.o \
|
x86/idct_sse2_xvid.o \
|
||||||
x86/motion_est.o \
|
|
||||||
x86/simple_idct.o \
|
x86/simple_idct.o \
|
||||||
|
|
||||||
MMX-OBJS-$(CONFIG_AAC_DECODER) += x86/sbrdsp_init.o
|
MMX-OBJS-$(CONFIG_AAC_DECODER) += x86/sbrdsp_init.o
|
||||||
@ -19,7 +18,8 @@ MMX-OBJS-$(CONFIG_AC3DSP) += x86/ac3dsp_init.o
|
|||||||
MMX-OBJS-$(CONFIG_CAVS_DECODER) += x86/cavsdsp.o
|
MMX-OBJS-$(CONFIG_CAVS_DECODER) += x86/cavsdsp.o
|
||||||
MMX-OBJS-$(CONFIG_DWT) += x86/snowdsp.o \
|
MMX-OBJS-$(CONFIG_DWT) += x86/snowdsp.o \
|
||||||
x86/dwt.o
|
x86/dwt.o
|
||||||
MMX-OBJS-$(CONFIG_ENCODERS) += x86/dsputilenc_mmx.o
|
MMX-OBJS-$(CONFIG_ENCODERS) += x86/dsputilenc_mmx.o \
|
||||||
|
x86/motion_est.o
|
||||||
MMX-OBJS-$(CONFIG_FFT) += x86/fft_init.o
|
MMX-OBJS-$(CONFIG_FFT) += x86/fft_init.o
|
||||||
MMX-OBJS-$(CONFIG_GPL) += x86/idct_mmx.o
|
MMX-OBJS-$(CONFIG_GPL) += x86/idct_mmx.o
|
||||||
MMX-OBJS-$(CONFIG_H264DSP) += x86/h264dsp_init.o
|
MMX-OBJS-$(CONFIG_H264DSP) += x86/h264dsp_init.o
|
||||||
|
@ -30,6 +30,8 @@
|
|||||||
#undef NDEBUG
|
#undef NDEBUG
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
|
||||||
|
#define PERM_RWP AV_PERM_WRITE | AV_PERM_PRESERVE | AV_PERM_REUSE
|
||||||
|
|
||||||
#define CHECK(j)\
|
#define CHECK(j)\
|
||||||
{ int score = FFABS(cur[mrefs-1+(j)] - cur[prefs-1-(j)])\
|
{ int score = FFABS(cur[mrefs-1+(j)] - cur[prefs-1-(j)])\
|
||||||
+ FFABS(cur[mrefs +(j)] - cur[prefs -(j)])\
|
+ FFABS(cur[mrefs +(j)] - cur[prefs -(j)])\
|
||||||
@ -46,19 +48,19 @@
|
|||||||
int temporal_diff0 = FFABS(prev2[0] - next2[0]); \
|
int temporal_diff0 = FFABS(prev2[0] - next2[0]); \
|
||||||
int temporal_diff1 =(FFABS(prev[mrefs] - c) + FFABS(prev[prefs] - e) )>>1; \
|
int temporal_diff1 =(FFABS(prev[mrefs] - c) + FFABS(prev[prefs] - e) )>>1; \
|
||||||
int temporal_diff2 =(FFABS(next[mrefs] - c) + FFABS(next[prefs] - e) )>>1; \
|
int temporal_diff2 =(FFABS(next[mrefs] - c) + FFABS(next[prefs] - e) )>>1; \
|
||||||
int diff = FFMAX3(temporal_diff0>>1, temporal_diff1, temporal_diff2); \
|
int diff = FFMAX3(temporal_diff0 >> 1, temporal_diff1, temporal_diff2); \
|
||||||
int spatial_pred = (c+e)>>1; \
|
int spatial_pred = (c+e) >> 1; \
|
||||||
int spatial_score = FFABS(cur[mrefs-1] - cur[prefs-1]) + FFABS(c-e) \
|
int spatial_score = FFABS(cur[mrefs - 1] - cur[prefs - 1]) + FFABS(c-e) \
|
||||||
+ FFABS(cur[mrefs+1] - cur[prefs+1]) - 1; \
|
+ FFABS(cur[mrefs + 1] - cur[prefs + 1]) - 1; \
|
||||||
\
|
\
|
||||||
CHECK(-1) CHECK(-2) }} }} \
|
CHECK(-1) CHECK(-2) }} }} \
|
||||||
CHECK( 1) CHECK( 2) }} }} \
|
CHECK( 1) CHECK( 2) }} }} \
|
||||||
\
|
\
|
||||||
if (mode < 2) { \
|
if (mode < 2) { \
|
||||||
int b = (prev2[2*mrefs] + next2[2*mrefs])>>1; \
|
int b = (prev2[2 * mrefs] + next2[2 * mrefs])>>1; \
|
||||||
int f = (prev2[2*prefs] + next2[2*prefs])>>1; \
|
int f = (prev2[2 * prefs] + next2[2 * prefs])>>1; \
|
||||||
int max = FFMAX3(d-e, d-c, FFMIN(b-c, f-e)); \
|
int max = FFMAX3(d - e, d - c, FFMIN(b - c, f - e)); \
|
||||||
int min = FFMIN3(d-e, d-c, FFMAX(b-c, f-e)); \
|
int min = FFMIN3(d - e, d - c, FFMAX(b - c, f - e)); \
|
||||||
\
|
\
|
||||||
diff = FFMAX3(diff, min, -max); \
|
diff = FFMAX3(diff, min, -max); \
|
||||||
} \
|
} \
|
||||||
@ -91,7 +93,8 @@ static void filter_line_c(uint8_t *dst,
|
|||||||
|
|
||||||
static void filter_line_c_16bit(uint16_t *dst,
|
static void filter_line_c_16bit(uint16_t *dst,
|
||||||
uint16_t *prev, uint16_t *cur, uint16_t *next,
|
uint16_t *prev, uint16_t *cur, uint16_t *next,
|
||||||
int w, int prefs, int mrefs, int parity, int mode)
|
int w, int prefs, int mrefs, int parity,
|
||||||
|
int mode)
|
||||||
{
|
{
|
||||||
int x;
|
int x;
|
||||||
uint16_t *prev2 = parity ? prev : cur ;
|
uint16_t *prev2 = parity ? prev : cur ;
|
||||||
@ -129,11 +132,11 @@ static void filter(AVFilterContext *ctx, AVFilterBufferRef *dstpic,
|
|||||||
|
|
||||||
for (y = 0; y < h; y++) {
|
for (y = 0; y < h; y++) {
|
||||||
if ((y ^ parity) & 1) {
|
if ((y ^ parity) & 1) {
|
||||||
uint8_t *prev = &yadif->prev->data[i][y*refs];
|
uint8_t *prev = &yadif->prev->data[i][y * refs];
|
||||||
uint8_t *cur = &yadif->cur ->data[i][y*refs];
|
uint8_t *cur = &yadif->cur ->data[i][y * refs];
|
||||||
uint8_t *next = &yadif->next->data[i][y*refs];
|
uint8_t *next = &yadif->next->data[i][y * refs];
|
||||||
uint8_t *dst = &dstpic->data[i][y*dstpic->linesize[i]];
|
uint8_t *dst = &dstpic->data[i][y * dstpic->linesize[i]];
|
||||||
int mode = y==1 || y+2==h ? 2 : yadif->mode;
|
int mode = y == 1 || y + 2 == h ? 2 : yadif->mode;
|
||||||
int prefs = y+1<h ? refs : -refs;
|
int prefs = y+1<h ? refs : -refs;
|
||||||
int mrefs = y ?-refs : refs;
|
int mrefs = y ?-refs : refs;
|
||||||
|
|
||||||
@ -151,10 +154,12 @@ static void filter(AVFilterContext *ctx, AVFilterBufferRef *dstpic,
|
|||||||
cur = tmp;
|
cur = tmp;
|
||||||
}
|
}
|
||||||
|
|
||||||
yadif->filter_line(dst, prev, cur, next, w, prefs, mrefs, parity ^ tff, mode);
|
yadif->filter_line(dst, prev, cur, next, w,
|
||||||
|
prefs, mrefs,
|
||||||
|
parity ^ tff, mode);
|
||||||
} else {
|
} else {
|
||||||
memcpy(&dstpic->data[i][y*dstpic->linesize[i]],
|
memcpy(&dstpic->data[i][y * dstpic->linesize[i]],
|
||||||
&yadif->cur->data[i][y*refs], w*df);
|
&yadif->cur->data[i][y * refs], w * df);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -165,19 +170,18 @@ static void filter(AVFilterContext *ctx, AVFilterBufferRef *dstpic,
|
|||||||
static int return_frame(AVFilterContext *ctx, int is_second)
|
static int return_frame(AVFilterContext *ctx, int is_second)
|
||||||
{
|
{
|
||||||
YADIFContext *yadif = ctx->priv;
|
YADIFContext *yadif = ctx->priv;
|
||||||
AVFilterLink *link= ctx->outputs[0];
|
AVFilterLink *link = ctx->outputs[0];
|
||||||
int tff, ret;
|
int tff, ret;
|
||||||
|
|
||||||
if (yadif->parity == -1) {
|
if (yadif->parity == -1) {
|
||||||
tff = yadif->cur->video->interlaced ?
|
tff = yadif->cur->video->interlaced ?
|
||||||
yadif->cur->video->top_field_first : 1;
|
yadif->cur->video->top_field_first : 1;
|
||||||
} else {
|
} else {
|
||||||
tff = yadif->parity^1;
|
tff = yadif->parity ^ 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (is_second) {
|
if (is_second) {
|
||||||
yadif->out = ff_get_video_buffer(link, AV_PERM_WRITE | AV_PERM_PRESERVE |
|
yadif->out = ff_get_video_buffer(link, PERM_RWP, link->w, link->h);
|
||||||
AV_PERM_REUSE, link->w, link->h);
|
|
||||||
if (!yadif->out)
|
if (!yadif->out)
|
||||||
return AVERROR(ENOMEM);
|
return AVERROR(ENOMEM);
|
||||||
|
|
||||||
@ -253,15 +257,17 @@ static int start_frame(AVFilterLink *link, AVFilterBufferRef *picref)
|
|||||||
!(yadif->prev = avfilter_ref_buffer(yadif->cur, ~AV_PERM_WRITE)))
|
!(yadif->prev = avfilter_ref_buffer(yadif->cur, ~AV_PERM_WRITE)))
|
||||||
return AVERROR(ENOMEM);
|
return AVERROR(ENOMEM);
|
||||||
|
|
||||||
yadif->out = ff_get_video_buffer(ctx->outputs[0], AV_PERM_WRITE | AV_PERM_PRESERVE |
|
yadif->out = ff_get_video_buffer(ctx->outputs[0], PERM_RWP,
|
||||||
AV_PERM_REUSE, link->w, link->h);
|
link->w, link->h);
|
||||||
if (!yadif->out)
|
if (!yadif->out)
|
||||||
return AVERROR(ENOMEM);
|
return AVERROR(ENOMEM);
|
||||||
|
|
||||||
avfilter_copy_buffer_ref_props(yadif->out, yadif->cur);
|
avfilter_copy_buffer_ref_props(yadif->out, yadif->cur);
|
||||||
yadif->out->video->interlaced = 0;
|
yadif->out->video->interlaced = 0;
|
||||||
|
|
||||||
if (yadif->out->pts != AV_NOPTS_VALUE)
|
if (yadif->out->pts != AV_NOPTS_VALUE)
|
||||||
yadif->out->pts *= 2;
|
yadif->out->pts *= 2;
|
||||||
|
|
||||||
return ff_start_frame(ctx->outputs[0], yadif->out);
|
return ff_start_frame(ctx->outputs[0], yadif->out);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -304,6 +310,7 @@ static int request_frame(AVFilterLink *link)
|
|||||||
|
|
||||||
if (ret == AVERROR_EOF && yadif->cur) {
|
if (ret == AVERROR_EOF && yadif->cur) {
|
||||||
AVFilterBufferRef *next = avfilter_ref_buffer(yadif->next, ~AV_PERM_WRITE);
|
AVFilterBufferRef *next = avfilter_ref_buffer(yadif->next, ~AV_PERM_WRITE);
|
||||||
|
|
||||||
if (!next)
|
if (!next)
|
||||||
return AVERROR(ENOMEM);
|
return AVERROR(ENOMEM);
|
||||||
|
|
||||||
@ -332,7 +339,8 @@ static int poll_frame(AVFilterLink *link)
|
|||||||
if (val <= 0)
|
if (val <= 0)
|
||||||
return val;
|
return val;
|
||||||
|
|
||||||
if (val >= 1 && !yadif->next) { //FIXME change API to not requre this red tape
|
//FIXME change API to not requre this red tape
|
||||||
|
if (val >= 1 && !yadif->next) {
|
||||||
if ((ret = ff_request_frame(link->src->inputs[0])) < 0)
|
if ((ret = ff_request_frame(link->src->inputs[0])) < 0)
|
||||||
return ret;
|
return ret;
|
||||||
val = ff_poll_frame(link->src->inputs[0]);
|
val = ff_poll_frame(link->src->inputs[0]);
|
||||||
@ -398,14 +406,17 @@ static av_cold int init(AVFilterContext *ctx, const char *args)
|
|||||||
yadif->auto_enable = 0;
|
yadif->auto_enable = 0;
|
||||||
yadif->csp = NULL;
|
yadif->csp = NULL;
|
||||||
|
|
||||||
if (args) sscanf(args, "%d:%d:%d", &yadif->mode, &yadif->parity, &yadif->auto_enable);
|
if (args)
|
||||||
|
sscanf(args, "%d:%d:%d",
|
||||||
|
&yadif->mode, &yadif->parity, &yadif->auto_enable);
|
||||||
|
|
||||||
yadif->filter_line = filter_line_c;
|
yadif->filter_line = filter_line_c;
|
||||||
|
|
||||||
if (HAVE_MMX)
|
if (HAVE_MMX)
|
||||||
ff_yadif_init_x86(yadif);
|
ff_yadif_init_x86(yadif);
|
||||||
|
|
||||||
av_log(ctx, AV_LOG_VERBOSE, "mode:%d parity:%d auto_enable:%d\n", yadif->mode, yadif->parity, yadif->auto_enable);
|
av_log(ctx, AV_LOG_VERBOSE, "mode:%d parity:%d auto_enable:%d\n",
|
||||||
|
yadif->mode, yadif->parity, yadif->auto_enable);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -293,6 +293,7 @@ OBJS-$(CONFIG_RTPDEC) += rdt.o \
|
|||||||
rtpdec_h263_rfc2190.o \
|
rtpdec_h263_rfc2190.o \
|
||||||
rtpdec_h264.o \
|
rtpdec_h264.o \
|
||||||
rtpdec_ilbc.o \
|
rtpdec_ilbc.o \
|
||||||
|
rtpdec_jpeg.o \
|
||||||
rtpdec_latm.o \
|
rtpdec_latm.o \
|
||||||
rtpdec_mpeg4.o \
|
rtpdec_mpeg4.o \
|
||||||
rtpdec_qcelp.o \
|
rtpdec_qcelp.o \
|
||||||
|
@ -69,6 +69,7 @@ void av_register_rtp_dynamic_payload_handlers(void)
|
|||||||
ff_register_dynamic_payload_handler(&ff_h263_rfc2190_dynamic_handler);
|
ff_register_dynamic_payload_handler(&ff_h263_rfc2190_dynamic_handler);
|
||||||
ff_register_dynamic_payload_handler(&ff_h264_dynamic_handler);
|
ff_register_dynamic_payload_handler(&ff_h264_dynamic_handler);
|
||||||
ff_register_dynamic_payload_handler(&ff_ilbc_dynamic_handler);
|
ff_register_dynamic_payload_handler(&ff_ilbc_dynamic_handler);
|
||||||
|
ff_register_dynamic_payload_handler(&ff_jpeg_dynamic_handler);
|
||||||
ff_register_dynamic_payload_handler(&ff_vorbis_dynamic_handler);
|
ff_register_dynamic_payload_handler(&ff_vorbis_dynamic_handler);
|
||||||
ff_register_dynamic_payload_handler(&ff_theora_dynamic_handler);
|
ff_register_dynamic_payload_handler(&ff_theora_dynamic_handler);
|
||||||
ff_register_dynamic_payload_handler(&ff_qdm2_dynamic_handler);
|
ff_register_dynamic_payload_handler(&ff_qdm2_dynamic_handler);
|
||||||
|
@ -46,6 +46,7 @@ extern RTPDynamicProtocolHandler ff_h263_2000_dynamic_handler;
|
|||||||
extern RTPDynamicProtocolHandler ff_h263_rfc2190_dynamic_handler;
|
extern RTPDynamicProtocolHandler ff_h263_rfc2190_dynamic_handler;
|
||||||
extern RTPDynamicProtocolHandler ff_h264_dynamic_handler;
|
extern RTPDynamicProtocolHandler ff_h264_dynamic_handler;
|
||||||
extern RTPDynamicProtocolHandler ff_ilbc_dynamic_handler;
|
extern RTPDynamicProtocolHandler ff_ilbc_dynamic_handler;
|
||||||
|
extern RTPDynamicProtocolHandler ff_jpeg_dynamic_handler;
|
||||||
extern RTPDynamicProtocolHandler ff_mp4a_latm_dynamic_handler;
|
extern RTPDynamicProtocolHandler ff_mp4a_latm_dynamic_handler;
|
||||||
extern RTPDynamicProtocolHandler ff_mp4v_es_dynamic_handler;
|
extern RTPDynamicProtocolHandler ff_mp4v_es_dynamic_handler;
|
||||||
extern RTPDynamicProtocolHandler ff_mpeg4_generic_dynamic_handler;
|
extern RTPDynamicProtocolHandler ff_mpeg4_generic_dynamic_handler;
|
||||||
|
331
libavformat/rtpdec_jpeg.c
Normal file
331
libavformat/rtpdec_jpeg.c
Normal file
@ -0,0 +1,331 @@
|
|||||||
|
/*
|
||||||
|
* RTP JPEG-compressed Video Depacketizer, RFC 2435
|
||||||
|
* Copyright (c) 2012 Samuel Pitoiset
|
||||||
|
*
|
||||||
|
* 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 "avformat.h"
|
||||||
|
#include "rtpdec_formats.h"
|
||||||
|
#include "libavutil/intreadwrite.h"
|
||||||
|
#include "libavcodec/mjpeg.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* RTP/JPEG specific private data.
|
||||||
|
*/
|
||||||
|
struct PayloadContext {
|
||||||
|
AVIOContext *frame; ///< current frame buffer
|
||||||
|
uint32_t timestamp; ///< current frame timestamp
|
||||||
|
int hdr_size; ///< size of the current frame header
|
||||||
|
};
|
||||||
|
|
||||||
|
static PayloadContext *jpeg_new_context(void)
|
||||||
|
{
|
||||||
|
return av_mallocz(sizeof(PayloadContext));
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void free_frame_if_needed(PayloadContext *jpeg)
|
||||||
|
{
|
||||||
|
if (jpeg->frame) {
|
||||||
|
uint8_t *p;
|
||||||
|
avio_close_dyn_buf(jpeg->frame, &p);
|
||||||
|
av_free(p);
|
||||||
|
jpeg->frame = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void jpeg_free_context(PayloadContext *jpeg)
|
||||||
|
{
|
||||||
|
free_frame_if_needed(jpeg);
|
||||||
|
av_free(jpeg);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void jpeg_create_huffman_table(PutBitContext *p, int table_class,
|
||||||
|
int table_id, const uint8_t *bits_table,
|
||||||
|
const uint8_t *value_table)
|
||||||
|
{
|
||||||
|
int i, n = 0;
|
||||||
|
|
||||||
|
put_bits(p, 8, 0);
|
||||||
|
put_bits(p, 4, table_class);
|
||||||
|
put_bits(p, 4, table_id);
|
||||||
|
|
||||||
|
for (i = 1; i <= 16; i++) {
|
||||||
|
n += bits_table[i];
|
||||||
|
put_bits(p, 8, bits_table[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = 0; i < n; i++) {
|
||||||
|
put_bits(p, 8, value_table[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static int jpeg_create_header(uint8_t *buf, int size, uint32_t type, uint32_t w,
|
||||||
|
uint32_t h, const uint8_t *qtable, int nb_qtable)
|
||||||
|
{
|
||||||
|
PutBitContext pbc;
|
||||||
|
|
||||||
|
init_put_bits(&pbc, buf, size);
|
||||||
|
|
||||||
|
/* Convert from blocks to pixels. */
|
||||||
|
w <<= 3;
|
||||||
|
h <<= 3;
|
||||||
|
|
||||||
|
/* SOI */
|
||||||
|
put_marker(&pbc, SOI);
|
||||||
|
|
||||||
|
/* JFIF header */
|
||||||
|
put_marker(&pbc, APP0);
|
||||||
|
put_bits(&pbc, 16, 16);
|
||||||
|
avpriv_put_string(&pbc, "JFIF", 1);
|
||||||
|
put_bits(&pbc, 16, 0x0201);
|
||||||
|
put_bits(&pbc, 8, 0);
|
||||||
|
put_bits(&pbc, 16, 1);
|
||||||
|
put_bits(&pbc, 16, 1);
|
||||||
|
put_bits(&pbc, 8, 0);
|
||||||
|
put_bits(&pbc, 8, 0);
|
||||||
|
|
||||||
|
/* DQT */
|
||||||
|
put_marker(&pbc, DQT);
|
||||||
|
if (nb_qtable == 2) {
|
||||||
|
put_bits(&pbc, 16, 2 + 2 * (1 + 64));
|
||||||
|
} else {
|
||||||
|
put_bits(&pbc, 16, 2 + 1 * (1 + 64));
|
||||||
|
}
|
||||||
|
put_bits(&pbc, 8, 0);
|
||||||
|
|
||||||
|
/* Each table is an array of 64 values given in zig-zag
|
||||||
|
* order, identical to the format used in a JFIF DQT
|
||||||
|
* marker segment. */
|
||||||
|
avpriv_copy_bits(&pbc, qtable, 64 * 8);
|
||||||
|
|
||||||
|
if (nb_qtable == 2) {
|
||||||
|
put_bits(&pbc, 8, 1);
|
||||||
|
avpriv_copy_bits(&pbc, qtable + 64, 64 * 8);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* DHT */
|
||||||
|
put_marker(&pbc, DHT);
|
||||||
|
|
||||||
|
jpeg_create_huffman_table(&pbc, 0, 0, avpriv_mjpeg_bits_dc_luminance,
|
||||||
|
avpriv_mjpeg_val_dc);
|
||||||
|
jpeg_create_huffman_table(&pbc, 0, 1, avpriv_mjpeg_bits_dc_chrominance,
|
||||||
|
avpriv_mjpeg_val_dc);
|
||||||
|
jpeg_create_huffman_table(&pbc, 1, 0, avpriv_mjpeg_bits_ac_luminance,
|
||||||
|
avpriv_mjpeg_val_ac_luminance);
|
||||||
|
jpeg_create_huffman_table(&pbc, 1, 1, avpriv_mjpeg_bits_ac_chrominance,
|
||||||
|
avpriv_mjpeg_val_ac_chrominance);
|
||||||
|
|
||||||
|
/* SOF0 */
|
||||||
|
put_marker(&pbc, SOF0);
|
||||||
|
put_bits(&pbc, 16, 17);
|
||||||
|
put_bits(&pbc, 8, 8);
|
||||||
|
put_bits(&pbc, 8, h >> 8);
|
||||||
|
put_bits(&pbc, 8, h);
|
||||||
|
put_bits(&pbc, 8, w >> 8);
|
||||||
|
put_bits(&pbc, 8, w);
|
||||||
|
put_bits(&pbc, 8, 3);
|
||||||
|
put_bits(&pbc, 8, 1);
|
||||||
|
put_bits(&pbc, 8, type ? 34 : 33);
|
||||||
|
put_bits(&pbc, 8, 0);
|
||||||
|
put_bits(&pbc, 8, 2);
|
||||||
|
put_bits(&pbc, 8, 17);
|
||||||
|
put_bits(&pbc, 8, nb_qtable == 2 ? 1 : 0);
|
||||||
|
put_bits(&pbc, 8, 3);
|
||||||
|
put_bits(&pbc, 8, 17);
|
||||||
|
put_bits(&pbc, 8, nb_qtable == 2 ? 1 : 0);
|
||||||
|
|
||||||
|
/* SOS */
|
||||||
|
put_marker(&pbc, SOS);
|
||||||
|
put_bits(&pbc, 16, 12);
|
||||||
|
put_bits(&pbc, 8, 3);
|
||||||
|
put_bits(&pbc, 8, 1);
|
||||||
|
put_bits(&pbc, 8, 0);
|
||||||
|
put_bits(&pbc, 8, 2);
|
||||||
|
put_bits(&pbc, 8, 17);
|
||||||
|
put_bits(&pbc, 8, 3);
|
||||||
|
put_bits(&pbc, 8, 17);
|
||||||
|
put_bits(&pbc, 8, 0);
|
||||||
|
put_bits(&pbc, 8, 63);
|
||||||
|
put_bits(&pbc, 8, 0);
|
||||||
|
|
||||||
|
/* Fill the buffer. */
|
||||||
|
flush_put_bits(&pbc);
|
||||||
|
|
||||||
|
/* Return the length in bytes of the JPEG header. */
|
||||||
|
return put_bits_count(&pbc) / 8;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int jpeg_parse_packet(AVFormatContext *ctx, PayloadContext *jpeg,
|
||||||
|
AVStream *st, AVPacket *pkt, uint32_t *timestamp,
|
||||||
|
const uint8_t *buf, int len, int flags)
|
||||||
|
{
|
||||||
|
uint8_t type, q, width, height;
|
||||||
|
const uint8_t *qtables = NULL;
|
||||||
|
uint16_t qtable_len;
|
||||||
|
uint32_t off;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
if (len < 8) {
|
||||||
|
av_log(ctx, AV_LOG_ERROR, "Too short RTP/JPEG packet.\n");
|
||||||
|
return AVERROR_INVALIDDATA;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Parse the main JPEG header. */
|
||||||
|
off = AV_RB24(buf + 1); /* fragment byte offset */
|
||||||
|
type = AV_RB8(buf + 4); /* id of jpeg decoder params */
|
||||||
|
q = AV_RB8(buf + 5); /* quantization factor (or table id) */
|
||||||
|
width = AV_RB8(buf + 6); /* frame width in 8 pixel blocks */
|
||||||
|
height = AV_RB8(buf + 7); /* frame height in 8 pixel blocks */
|
||||||
|
buf += 8;
|
||||||
|
len -= 8;
|
||||||
|
|
||||||
|
/* Parse the restart marker header. */
|
||||||
|
if (type > 63) {
|
||||||
|
av_log(ctx, AV_LOG_ERROR,
|
||||||
|
"Unimplemented RTP/JPEG restart marker header.\n");
|
||||||
|
return AVERROR_PATCHWELCOME;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Parse the quantization table header. */
|
||||||
|
if (q > 127 && off == 0) {
|
||||||
|
uint8_t precision;
|
||||||
|
|
||||||
|
if (len < 4) {
|
||||||
|
av_log(ctx, AV_LOG_ERROR, "Too short RTP/JPEG packet.\n");
|
||||||
|
return AVERROR_INVALIDDATA;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* The first byte is reserved for future use. */
|
||||||
|
precision = AV_RB8(buf + 1); /* size of coefficients */
|
||||||
|
qtable_len = AV_RB16(buf + 2); /* length in bytes */
|
||||||
|
buf += 4;
|
||||||
|
len -= 4;
|
||||||
|
|
||||||
|
if (precision)
|
||||||
|
av_log(ctx, AV_LOG_WARNING, "Only 8-bit precision is supported.\n");
|
||||||
|
|
||||||
|
if (q == 255 && qtable_len == 0) {
|
||||||
|
av_log(ctx, AV_LOG_ERROR,
|
||||||
|
"Invalid RTP/JPEG packet. Quantization tables not found.\n");
|
||||||
|
return AVERROR_INVALIDDATA;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (qtable_len > 0) {
|
||||||
|
if (len < qtable_len) {
|
||||||
|
av_log(ctx, AV_LOG_ERROR, "Too short RTP/JPEG packet.\n");
|
||||||
|
return AVERROR_INVALIDDATA;
|
||||||
|
}
|
||||||
|
qtables = buf;
|
||||||
|
buf += qtable_len;
|
||||||
|
len -= qtable_len;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (off == 0) {
|
||||||
|
/* Start of JPEG data packet. */
|
||||||
|
uint8_t hdr[1024];
|
||||||
|
|
||||||
|
/* Skip the current frame in case of the end packet
|
||||||
|
* has been lost somewhere. */
|
||||||
|
free_frame_if_needed(jpeg);
|
||||||
|
|
||||||
|
if ((ret = avio_open_dyn_buf(&jpeg->frame)) < 0)
|
||||||
|
return ret;
|
||||||
|
jpeg->timestamp = *timestamp;
|
||||||
|
|
||||||
|
if (!qtables) {
|
||||||
|
av_log(ctx, AV_LOG_ERROR,
|
||||||
|
"Unimplemented default quantization tables.\n");
|
||||||
|
return AVERROR_PATCHWELCOME;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Generate a frame and scan headers that can be prepended to the
|
||||||
|
* RTP/JPEG data payload to produce a JPEG compressed image in
|
||||||
|
* interchange format. */
|
||||||
|
jpeg->hdr_size = jpeg_create_header(hdr, sizeof(hdr), type, width,
|
||||||
|
height, qtables,
|
||||||
|
qtable_len > 64 ? 2 : 1);
|
||||||
|
|
||||||
|
/* Copy JPEG header to frame buffer. */
|
||||||
|
avio_write(jpeg->frame, hdr, jpeg->hdr_size);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!jpeg->frame) {
|
||||||
|
av_log(ctx, AV_LOG_ERROR,
|
||||||
|
"Received packet without a start chunk; dropping frame.\n");
|
||||||
|
return AVERROR(EAGAIN);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (jpeg->timestamp != *timestamp) {
|
||||||
|
/* Skip the current frame if timestamp is incorrect.
|
||||||
|
* A start packet has been lost somewhere. */
|
||||||
|
free_frame_if_needed(jpeg);
|
||||||
|
av_log(ctx, AV_LOG_ERROR, "RTP timestamps don't match.\n");
|
||||||
|
return AVERROR_INVALIDDATA;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (off != avio_tell(jpeg->frame) - jpeg->hdr_size) {
|
||||||
|
av_log(ctx, AV_LOG_ERROR,
|
||||||
|
"Missing packets; dropping frame.\n");
|
||||||
|
return AVERROR(EAGAIN);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Copy data to frame buffer. */
|
||||||
|
avio_write(jpeg->frame, buf, len);
|
||||||
|
|
||||||
|
if (flags & RTP_FLAG_MARKER) {
|
||||||
|
/* End of JPEG data packet. */
|
||||||
|
PutBitContext pbc;
|
||||||
|
uint8_t buf[2];
|
||||||
|
|
||||||
|
/* Put EOI marker. */
|
||||||
|
init_put_bits(&pbc, buf, sizeof(buf));
|
||||||
|
put_marker(&pbc, EOI);
|
||||||
|
flush_put_bits(&pbc);
|
||||||
|
avio_write(jpeg->frame, buf, sizeof(buf));
|
||||||
|
|
||||||
|
/* Prepare the JPEG packet. */
|
||||||
|
av_init_packet(pkt);
|
||||||
|
pkt->size = avio_close_dyn_buf(jpeg->frame, &pkt->data);
|
||||||
|
if (pkt->size < 0) {
|
||||||
|
av_log(ctx, AV_LOG_ERROR,
|
||||||
|
"Error occured when getting frame buffer.\n");
|
||||||
|
jpeg->frame = NULL;
|
||||||
|
return pkt->size;
|
||||||
|
}
|
||||||
|
pkt->stream_index = st->index;
|
||||||
|
pkt->destruct = av_destruct_packet;
|
||||||
|
|
||||||
|
/* Re-init the frame buffer. */
|
||||||
|
jpeg->frame = NULL;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
return AVERROR(EAGAIN);
|
||||||
|
}
|
||||||
|
|
||||||
|
RTPDynamicProtocolHandler ff_jpeg_dynamic_handler = {
|
||||||
|
.enc_name = "JPEG",
|
||||||
|
.codec_type = AVMEDIA_TYPE_VIDEO,
|
||||||
|
.codec_id = AV_CODEC_ID_MJPEG,
|
||||||
|
.alloc = jpeg_new_context,
|
||||||
|
.free = jpeg_free_context,
|
||||||
|
.parse_packet = jpeg_parse_packet,
|
||||||
|
.static_payload_id = 26,
|
||||||
|
};
|
@ -30,8 +30,8 @@
|
|||||||
#include "libavutil/avutil.h"
|
#include "libavutil/avutil.h"
|
||||||
|
|
||||||
#define LIBAVFORMAT_VERSION_MAJOR 54
|
#define LIBAVFORMAT_VERSION_MAJOR 54
|
||||||
#define LIBAVFORMAT_VERSION_MINOR 25
|
#define LIBAVFORMAT_VERSION_MINOR 26
|
||||||
#define LIBAVFORMAT_VERSION_MICRO 105
|
#define LIBAVFORMAT_VERSION_MICRO 100
|
||||||
|
|
||||||
#define LIBAVFORMAT_VERSION_INT AV_VERSION_INT(LIBAVFORMAT_VERSION_MAJOR, \
|
#define LIBAVFORMAT_VERSION_INT AV_VERSION_INT(LIBAVFORMAT_VERSION_MAJOR, \
|
||||||
LIBAVFORMAT_VERSION_MINOR, \
|
LIBAVFORMAT_VERSION_MINOR, \
|
||||||
|
@ -1,41 +1,33 @@
|
|||||||
FATE_MP3 += fate-mp3-float-conf-compl
|
FATE_MP3 += fate-mp3-float-conf-compl
|
||||||
fate-mp3-float-conf-compl: CMD = pcm -acodec mp3float -i $(SAMPLES)/mp3-conformance/compl.bit
|
fate-mp3-float-conf-compl: CMD = pcm -acodec mp3float -i $(SAMPLES)/mp3-conformance/compl.bit
|
||||||
fate-mp3-float-conf-compl: CMP = stddev
|
|
||||||
fate-mp3-float-conf-compl: REF = $(SAMPLES)/mp3-conformance/compl.pcm
|
fate-mp3-float-conf-compl: REF = $(SAMPLES)/mp3-conformance/compl.pcm
|
||||||
|
|
||||||
FATE_MP3 += fate-mp3-float-conf-he_32khz
|
FATE_MP3 += fate-mp3-float-conf-he_32khz
|
||||||
fate-mp3-float-conf-he_32khz: CMD = pcm -acodec mp3float -i $(SAMPLES)/mp3-conformance/he_32khz.bit -fs 343296
|
fate-mp3-float-conf-he_32khz: CMD = pcm -acodec mp3float -i $(SAMPLES)/mp3-conformance/he_32khz.bit -fs 343296
|
||||||
fate-mp3-float-conf-he_32khz: CMP = stddev
|
|
||||||
fate-mp3-float-conf-he_32khz: REF = $(SAMPLES)/mp3-conformance/he_32khz.pcm
|
fate-mp3-float-conf-he_32khz: REF = $(SAMPLES)/mp3-conformance/he_32khz.pcm
|
||||||
|
|
||||||
FATE_MP3 += fate-mp3-float-conf-he_44khz
|
FATE_MP3 += fate-mp3-float-conf-he_44khz
|
||||||
fate-mp3-float-conf-he_44khz: CMD = pcm -acodec mp3float -i $(SAMPLES)/mp3-conformance/he_44khz.bit -fs 942336
|
fate-mp3-float-conf-he_44khz: CMD = pcm -acodec mp3float -i $(SAMPLES)/mp3-conformance/he_44khz.bit -fs 942336
|
||||||
fate-mp3-float-conf-he_44khz: CMP = stddev
|
|
||||||
fate-mp3-float-conf-he_44khz: REF = $(SAMPLES)/mp3-conformance/he_44khz.pcm
|
fate-mp3-float-conf-he_44khz: REF = $(SAMPLES)/mp3-conformance/he_44khz.pcm
|
||||||
|
|
||||||
FATE_MP3 += fate-mp3-float-conf-he_48khz
|
FATE_MP3 += fate-mp3-float-conf-he_48khz
|
||||||
fate-mp3-float-conf-he_48khz: CMD = pcm -acodec mp3float -i $(SAMPLES)/mp3-conformance/he_48khz.bit -fs 343296
|
fate-mp3-float-conf-he_48khz: CMD = pcm -acodec mp3float -i $(SAMPLES)/mp3-conformance/he_48khz.bit -fs 343296
|
||||||
fate-mp3-float-conf-he_48khz: CMP = stddev
|
|
||||||
fate-mp3-float-conf-he_48khz: REF = $(SAMPLES)/mp3-conformance/he_48khz.pcm
|
fate-mp3-float-conf-he_48khz: REF = $(SAMPLES)/mp3-conformance/he_48khz.pcm
|
||||||
|
|
||||||
FATE_MP3 += fate-mp3-float-conf-hecommon
|
FATE_MP3 += fate-mp3-float-conf-hecommon
|
||||||
fate-mp3-float-conf-hecommon: CMD = pcm -acodec mp3float -i $(SAMPLES)/mp3-conformance/hecommon.bit -fs 133632
|
fate-mp3-float-conf-hecommon: CMD = pcm -acodec mp3float -i $(SAMPLES)/mp3-conformance/hecommon.bit -fs 133632
|
||||||
fate-mp3-float-conf-hecommon: CMP = stddev
|
|
||||||
fate-mp3-float-conf-hecommon: REF = $(SAMPLES)/mp3-conformance/hecommon.pcm
|
fate-mp3-float-conf-hecommon: REF = $(SAMPLES)/mp3-conformance/hecommon.pcm
|
||||||
|
|
||||||
FATE_MP3 += fate-mp3-float-conf-si
|
FATE_MP3 += fate-mp3-float-conf-si
|
||||||
fate-mp3-float-conf-si: CMD = pcm -acodec mp3float -i $(SAMPLES)/mp3-conformance/si.bit -fs 269568
|
fate-mp3-float-conf-si: CMD = pcm -acodec mp3float -i $(SAMPLES)/mp3-conformance/si.bit -fs 269568
|
||||||
fate-mp3-float-conf-si: CMP = stddev
|
|
||||||
fate-mp3-float-conf-si: REF = $(SAMPLES)/mp3-conformance/si.pcm
|
fate-mp3-float-conf-si: REF = $(SAMPLES)/mp3-conformance/si.pcm
|
||||||
|
|
||||||
FATE_MP3 += fate-mp3-float-conf-si_block
|
FATE_MP3 += fate-mp3-float-conf-si_block
|
||||||
fate-mp3-float-conf-si_block: CMD = pcm -acodec mp3float -i $(SAMPLES)/mp3-conformance/si_block.bit -fs 145152
|
fate-mp3-float-conf-si_block: CMD = pcm -acodec mp3float -i $(SAMPLES)/mp3-conformance/si_block.bit -fs 145152
|
||||||
fate-mp3-float-conf-si_block: CMP = stddev
|
|
||||||
fate-mp3-float-conf-si_block: REF = $(SAMPLES)/mp3-conformance/si_block.pcm
|
fate-mp3-float-conf-si_block: REF = $(SAMPLES)/mp3-conformance/si_block.pcm
|
||||||
|
|
||||||
FATE_MP3 += fate-mp3-float-extra_overread
|
FATE_MP3 += fate-mp3-float-extra_overread
|
||||||
fate-mp3-float-extra_overread: CMD = pcm -c:a mp3float -i $(SAMPLES)/mpegaudio/extra_overread.mp3
|
fate-mp3-float-extra_overread: CMD = pcm -c:a mp3float -i $(SAMPLES)/mpegaudio/extra_overread.mp3
|
||||||
fate-mp3-float-extra_overread: CMP = stddev
|
|
||||||
fate-mp3-float-extra_overread: REF = $(SAMPLES)/mpegaudio/extra_overread.pcm
|
fate-mp3-float-extra_overread: REF = $(SAMPLES)/mpegaudio/extra_overread.pcm
|
||||||
|
|
||||||
FATE_SAMPLES_AVCONV += $(FATE_MP3)
|
FATE_SAMPLES_AVCONV += $(FATE_MP3)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user