* qatar/master: indeo3: add parens around some macro arguments h264: use proper PROLOGUE statement for a function using 8 registers. doc: Update sample Vim config with suitable (function) indentation settings. dv: Merge dvquant.h into dvdata.c where all other DV tables reside. dv: Move static tables only used in one place to where they are used. graphparser: set next to NULL on an entry extracted from inputs list doc/filters: update documentation. avconv: flush decoders immediately after an EOF. avconv: send EOF to vsrc_buffer. avconv: reindent. Conflicts: doc/filters.texi ffmpeg.c Merged-by: Michael Niedermayer <michaelni@gmx.at>tags/n0.11
| @@ -187,6 +187,8 @@ the following snippet into your @file{.vimrc}: | |||||
| set expandtab | set expandtab | ||||
| set shiftwidth=4 | set shiftwidth=4 | ||||
| set softtabstop=4 | set softtabstop=4 | ||||
| set cindent | |||||
| set cinoptions=(0 | |||||
| " allow tabs in Makefiles | " allow tabs in Makefiles | ||||
| autocmd FileType make set noexpandtab shiftwidth=8 softtabstop=8 | autocmd FileType make set noexpandtab shiftwidth=8 softtabstop=8 | ||||
| " Trailing whitespace and tabs are forbidden, so highlight them. | " Trailing whitespace and tabs are forbidden, so highlight them. | ||||
| @@ -17,9 +17,10 @@ output pads is called a "sink". | |||||
| @anchor{Filtergraph syntax} | @anchor{Filtergraph syntax} | ||||
| @section Filtergraph syntax | @section Filtergraph syntax | ||||
| A filtergraph can be represented using a textual representation, which | |||||
| is recognized by the @code{-vf} option of the ff* | |||||
| tools, and by the @code{avfilter_graph_parse()} function defined in | |||||
| A filtergraph can be represented using a textual representation, which is | |||||
| recognized by the @option{-filter}/@option{-vf} and @option{-filter_complex} | |||||
| options in @command{ffmpeg} and @option{-vf} in @command{ffplay}, and by the | |||||
| @code{avfilter_graph_parse()}/@code{avfilter_graph_parse2()} function defined in | |||||
| @file{libavfilter/avfiltergraph.h}. | @file{libavfilter/avfiltergraph.h}. | ||||
| A filterchain consists of a sequence of connected filters, each one | A filterchain consists of a sequence of connected filters, each one | ||||
| @@ -2114,15 +2115,12 @@ Follow some examples: | |||||
| overlay=main_w-overlay_w-10:main_h-overlay_h-10 | overlay=main_w-overlay_w-10:main_h-overlay_h-10 | ||||
| # insert a transparent PNG logo in the bottom left corner of the input | # insert a transparent PNG logo in the bottom left corner of the input | ||||
| movie=logo.png [logo]; | |||||
| [in][logo] overlay=10:main_h-overlay_h-10 [out] | |||||
| ffmpeg -i input -i logo -filter_complex 'overlay=10:main_h-overlay_h-10' output | |||||
| # insert 2 different transparent PNG logos (second logo on bottom | # insert 2 different transparent PNG logos (second logo on bottom | ||||
| # right corner): | # right corner): | ||||
| movie=logo1.png [logo1]; | |||||
| movie=logo2.png [logo2]; | |||||
| [in][logo1] overlay=10:H-h-10 [in+logo1]; | |||||
| [in+logo1][logo2] overlay=W-w-10:H-h-10 [out] | |||||
| ffmpeg -i input -i logo1 -i logo2 -filter_complex | |||||
| 'overlay=10:H-h-10,overlay=W-w-10:H-h-10' output | |||||
| # add a transparent color layer on top of the main video, | # add a transparent color layer on top of the main video, | ||||
| # WxH specifies the size of the main input to the overlay filter | # WxH specifies the size of the main input to the overlay filter | ||||
| @@ -2492,6 +2492,9 @@ static int transcode_video(InputStream *ist, AVPacket *pkt, int *got_output, int | |||||
| quality = same_quant ? decoded_frame->quality : 0; | quality = same_quant ? decoded_frame->quality : 0; | ||||
| if (!*got_output) { | if (!*got_output) { | ||||
| /* no picture yet */ | /* no picture yet */ | ||||
| if (!pkt->size) | |||||
| for (i = 0; i < ist->nb_filters; i++) | |||||
| av_buffersrc_buffer(ist->filters[i]->filter, NULL); | |||||
| return ret; | return ret; | ||||
| } | } | ||||
| @@ -3488,6 +3491,13 @@ static int transcode(void) | |||||
| } | } | ||||
| if (ret < 0) { | if (ret < 0) { | ||||
| input_files[file_index]->eof_reached = 1; | input_files[file_index]->eof_reached = 1; | ||||
| for (i = 0; i < input_files[file_index]->nb_streams; i++) { | |||||
| ist = input_streams[input_files[file_index]->ist_index + i]; | |||||
| if (ist->decoding_needed) | |||||
| output_packet(ist, NULL); | |||||
| } | |||||
| if (opt_shortest) | if (opt_shortest) | ||||
| break; | break; | ||||
| else | else | ||||
| @@ -3586,7 +3596,7 @@ static int transcode(void) | |||||
| /* at the end of stream, we must flush the decoder buffers */ | /* at the end of stream, we must flush the decoder buffers */ | ||||
| for (i = 0; i < nb_input_streams; i++) { | for (i = 0; i < nb_input_streams; i++) { | ||||
| ist = input_streams[i]; | ist = input_streams[i]; | ||||
| if (ist->decoding_needed) { | |||||
| if (!input_files[ist->file_index]->eof_reached && ist->decoding_needed) { | |||||
| output_packet(ist, NULL); | output_packet(ist, NULL); | ||||
| } | } | ||||
| } | } | ||||
| @@ -3746,41 +3756,41 @@ static int opt_map(OptionsContext *o, const char *opt, const char *arg) | |||||
| exit_program(1); | exit_program(1); | ||||
| } | } | ||||
| } else { | } else { | ||||
| file_idx = strtol(map, &p, 0); | |||||
| if (file_idx >= nb_input_files || file_idx < 0) { | |||||
| av_log(NULL, AV_LOG_FATAL, "Invalid input file index: %d.\n", file_idx); | |||||
| exit_program(1); | |||||
| } | |||||
| if (negative) | |||||
| /* disable some already defined maps */ | |||||
| for (i = 0; i < o->nb_stream_maps; i++) { | |||||
| m = &o->stream_maps[i]; | |||||
| if (file_idx == m->file_index && | |||||
| check_stream_specifier(input_files[m->file_index]->ctx, | |||||
| input_files[m->file_index]->ctx->streams[m->stream_index], | |||||
| *p == ':' ? p + 1 : p) > 0) | |||||
| m->disabled = 1; | |||||
| file_idx = strtol(map, &p, 0); | |||||
| if (file_idx >= nb_input_files || file_idx < 0) { | |||||
| av_log(NULL, AV_LOG_FATAL, "Invalid input file index: %d.\n", file_idx); | |||||
| exit_program(1); | |||||
| } | } | ||||
| else | |||||
| for (i = 0; i < input_files[file_idx]->nb_streams; i++) { | |||||
| if (check_stream_specifier(input_files[file_idx]->ctx, input_files[file_idx]->ctx->streams[i], | |||||
| *p == ':' ? p + 1 : p) <= 0) | |||||
| continue; | |||||
| o->stream_maps = grow_array(o->stream_maps, sizeof(*o->stream_maps), | |||||
| &o->nb_stream_maps, o->nb_stream_maps + 1); | |||||
| m = &o->stream_maps[o->nb_stream_maps - 1]; | |||||
| m->file_index = file_idx; | |||||
| m->stream_index = i; | |||||
| if (sync_file_idx >= 0) { | |||||
| m->sync_file_index = sync_file_idx; | |||||
| m->sync_stream_index = sync_stream_idx; | |||||
| } else { | |||||
| m->sync_file_index = file_idx; | |||||
| m->sync_stream_index = i; | |||||
| if (negative) | |||||
| /* disable some already defined maps */ | |||||
| for (i = 0; i < o->nb_stream_maps; i++) { | |||||
| m = &o->stream_maps[i]; | |||||
| if (file_idx == m->file_index && | |||||
| check_stream_specifier(input_files[m->file_index]->ctx, | |||||
| input_files[m->file_index]->ctx->streams[m->stream_index], | |||||
| *p == ':' ? p + 1 : p) > 0) | |||||
| m->disabled = 1; | |||||
| } | |||||
| else | |||||
| for (i = 0; i < input_files[file_idx]->nb_streams; i++) { | |||||
| if (check_stream_specifier(input_files[file_idx]->ctx, input_files[file_idx]->ctx->streams[i], | |||||
| *p == ':' ? p + 1 : p) <= 0) | |||||
| continue; | |||||
| o->stream_maps = grow_array(o->stream_maps, sizeof(*o->stream_maps), | |||||
| &o->nb_stream_maps, o->nb_stream_maps + 1); | |||||
| m = &o->stream_maps[o->nb_stream_maps - 1]; | |||||
| m->file_index = file_idx; | |||||
| m->stream_index = i; | |||||
| if (sync_file_idx >= 0) { | |||||
| m->sync_file_index = sync_file_idx; | |||||
| m->sync_stream_index = sync_stream_idx; | |||||
| } else { | |||||
| m->sync_file_index = file_idx; | |||||
| m->sync_stream_index = i; | |||||
| } | |||||
| } | } | ||||
| } | |||||
| } | } | ||||
| if (!m) { | if (!m) { | ||||
| @@ -4971,28 +4981,27 @@ loop_end: | |||||
| } | } | ||||
| init_output_filter(ofilter, o, oc); | init_output_filter(ofilter, o, oc); | ||||
| } else { | } else { | ||||
| ist = input_streams[input_files[map->file_index]->ist_index + map->stream_index]; | |||||
| if(o->subtitle_disable && ist->st->codec->codec_type == AVMEDIA_TYPE_SUBTITLE) | |||||
| continue; | |||||
| if(o-> audio_disable && ist->st->codec->codec_type == AVMEDIA_TYPE_AUDIO) | |||||
| continue; | |||||
| if(o-> video_disable && ist->st->codec->codec_type == AVMEDIA_TYPE_VIDEO) | |||||
| continue; | |||||
| if(o-> data_disable && ist->st->codec->codec_type == AVMEDIA_TYPE_DATA) | |||||
| continue; | |||||
| switch (ist->st->codec->codec_type) { | |||||
| case AVMEDIA_TYPE_VIDEO: ost = new_video_stream(o, oc, src_idx); break; | |||||
| case AVMEDIA_TYPE_AUDIO: ost = new_audio_stream(o, oc, src_idx); break; | |||||
| case AVMEDIA_TYPE_SUBTITLE: ost = new_subtitle_stream(o, oc, src_idx); break; | |||||
| case AVMEDIA_TYPE_DATA: ost = new_data_stream(o, oc, src_idx); break; | |||||
| case AVMEDIA_TYPE_ATTACHMENT: ost = new_attachment_stream(o, oc, src_idx); break; | |||||
| default: | |||||
| av_log(NULL, AV_LOG_FATAL, "Cannot map stream #%d:%d - unsupported type.\n", | |||||
| map->file_index, map->stream_index); | |||||
| exit_program(1); | |||||
| } | |||||
| ist = input_streams[input_files[map->file_index]->ist_index + map->stream_index]; | |||||
| if(o->subtitle_disable && ist->st->codec->codec_type == AVMEDIA_TYPE_SUBTITLE) | |||||
| continue; | |||||
| if(o-> audio_disable && ist->st->codec->codec_type == AVMEDIA_TYPE_AUDIO) | |||||
| continue; | |||||
| if(o-> video_disable && ist->st->codec->codec_type == AVMEDIA_TYPE_VIDEO) | |||||
| continue; | |||||
| if(o-> data_disable && ist->st->codec->codec_type == AVMEDIA_TYPE_DATA) | |||||
| continue; | |||||
| switch (ist->st->codec->codec_type) { | |||||
| case AVMEDIA_TYPE_VIDEO: ost = new_video_stream (o, oc, src_idx); break; | |||||
| case AVMEDIA_TYPE_AUDIO: ost = new_audio_stream (o, oc, src_idx); break; | |||||
| case AVMEDIA_TYPE_SUBTITLE: ost = new_subtitle_stream (o, oc, src_idx); break; | |||||
| case AVMEDIA_TYPE_DATA: ost = new_data_stream (o, oc, src_idx); break; | |||||
| case AVMEDIA_TYPE_ATTACHMENT: ost = new_attachment_stream(o, oc, src_idx); break; | |||||
| default: | |||||
| av_log(NULL, AV_LOG_FATAL, "Cannot map stream #%d:%d - unsupported type.\n", | |||||
| map->file_index, map->stream_index); | |||||
| exit_program(1); | |||||
| } | |||||
| } | } | ||||
| } | } | ||||
| } | } | ||||
| @@ -46,7 +46,6 @@ | |||||
| #include "put_bits.h" | #include "put_bits.h" | ||||
| #include "simple_idct.h" | #include "simple_idct.h" | ||||
| #include "dvdata.h" | #include "dvdata.h" | ||||
| #include "dvquant.h" | |||||
| #include "dv_tablegen.h" | #include "dv_tablegen.h" | ||||
| /* XXX: also include quantization */ | /* XXX: also include quantization */ | ||||
| @@ -167,6 +166,15 @@ static inline void dv_calc_mb_coordinates(const DVprofile *d, int chan, int seq, | |||||
| } | } | ||||
| } | } | ||||
| /* quantization quanta by QNO for DV100 */ | |||||
| static const uint8_t dv100_qstep[16] = { | |||||
| 1, /* QNO = 0 and 1 both have no quantization */ | |||||
| 1, | |||||
| 2, 3, 4, 5, 6, 7, 8, 16, 18, 20, 22, 24, 28, 52 | |||||
| }; | |||||
| static const uint8_t dv_quant_areas[4] = { 6, 21, 43, 64 }; | |||||
| int ff_dv_init_dynamic_tables(const DVprofile *d) | int ff_dv_init_dynamic_tables(const DVprofile *d) | ||||
| { | { | ||||
| int j,i,c,s,p; | int j,i,c,s,p; | ||||
| @@ -195,11 +203,11 @@ int ff_dv_init_dynamic_tables(const DVprofile *d) | |||||
| factor1 = &d->idct_factor[0]; | factor1 = &d->idct_factor[0]; | ||||
| factor2 = &d->idct_factor[DV_PROFILE_IS_HD(d)?4096:2816]; | factor2 = &d->idct_factor[DV_PROFILE_IS_HD(d)?4096:2816]; | ||||
| if (d->height == 720) { | if (d->height == 720) { | ||||
| iweight1 = &dv_iweight_720_y[0]; | |||||
| iweight2 = &dv_iweight_720_c[0]; | |||||
| iweight1 = &ff_dv_iweight_720_y[0]; | |||||
| iweight2 = &ff_dv_iweight_720_c[0]; | |||||
| } else { | } else { | ||||
| iweight1 = &dv_iweight_1080_y[0]; | |||||
| iweight2 = &dv_iweight_1080_c[0]; | |||||
| iweight1 = &ff_dv_iweight_1080_y[0]; | |||||
| iweight2 = &ff_dv_iweight_1080_c[0]; | |||||
| } | } | ||||
| if (DV_PROFILE_IS_HD(d)) { | if (DV_PROFILE_IS_HD(d)) { | ||||
| for (c = 0; c < 4; c++) { | for (c = 0; c < 4; c++) { | ||||
| @@ -211,12 +219,12 @@ int ff_dv_init_dynamic_tables(const DVprofile *d) | |||||
| } | } | ||||
| } | } | ||||
| } else { | } else { | ||||
| iweight1 = &dv_iweight_88[0]; | |||||
| for (j = 0; j < 2; j++, iweight1 = &dv_iweight_248[0]) { | |||||
| iweight1 = &ff_dv_iweight_88[0]; | |||||
| for (j = 0; j < 2; j++, iweight1 = &ff_dv_iweight_248[0]) { | |||||
| for (s = 0; s < 22; s++) { | for (s = 0; s < 22; s++) { | ||||
| for (i = c = 0; c < 4; c++) { | for (i = c = 0; c < 4; c++) { | ||||
| for (; i < dv_quant_areas[c]; i++) { | for (; i < dv_quant_areas[c]; i++) { | ||||
| *factor1 = iweight1[i] << (dv_quant_shifts[s][c] + 1); | |||||
| *factor1 = iweight1[i] << (ff_dv_quant_shifts[s][c] + 1); | |||||
| *factor2++ = (*factor1++) << 1; | *factor2++ = (*factor1++) << 1; | ||||
| } | } | ||||
| } | } | ||||
| @@ -467,6 +475,28 @@ static av_always_inline int dv_guess_dct_mode(DVVideoContext *s, uint8_t *data, | |||||
| return 0; | return 0; | ||||
| } | } | ||||
| static const int dv_weight_bits = 18; | |||||
| static const int dv_weight_88[64] = { | |||||
| 131072, 257107, 257107, 242189, 252167, 242189, 235923, 237536, | |||||
| 237536, 235923, 229376, 231390, 223754, 231390, 229376, 222935, | |||||
| 224969, 217965, 217965, 224969, 222935, 200636, 218652, 211916, | |||||
| 212325, 211916, 218652, 200636, 188995, 196781, 205965, 206433, | |||||
| 206433, 205965, 196781, 188995, 185364, 185364, 200636, 200704, | |||||
| 200636, 185364, 185364, 174609, 180568, 195068, 195068, 180568, | |||||
| 174609, 170091, 175557, 189591, 175557, 170091, 165371, 170627, | |||||
| 170627, 165371, 160727, 153560, 160727, 144651, 144651, 136258, | |||||
| }; | |||||
| static const int dv_weight_248[64] = { | |||||
| 131072, 242189, 257107, 237536, 229376, 200636, 242189, 223754, | |||||
| 224969, 196781, 262144, 242189, 229376, 200636, 257107, 237536, | |||||
| 211916, 185364, 235923, 217965, 229376, 211916, 206433, 180568, | |||||
| 242189, 223754, 224969, 196781, 211916, 185364, 235923, 217965, | |||||
| 200704, 175557, 222935, 205965, 200636, 185364, 195068, 170627, | |||||
| 229376, 211916, 206433, 180568, 200704, 175557, 222935, 205965, | |||||
| 175557, 153560, 188995, 174609, 165371, 144651, 200636, 185364, | |||||
| 195068, 170627, 175557, 153560, 188995, 174609, 165371, 144651, | |||||
| }; | |||||
| static av_always_inline int dv_init_enc_block(EncBlockInfo* bi, uint8_t *data, int linesize, DVVideoContext *s, int bias) | static av_always_inline int dv_init_enc_block(EncBlockInfo* bi, uint8_t *data, int linesize, DVVideoContext *s, int bias) | ||||
| { | { | ||||
| const int *weight; | const int *weight; | ||||
| @@ -578,7 +608,7 @@ static inline void dv_guess_qnos(EncBlockInfo* blks, int* qnos) | |||||
| size[i] = 0; | size[i] = 0; | ||||
| for (j = 0; j < 6; j++, b++) { | for (j = 0; j < 6; j++, b++) { | ||||
| for (a = 0; a < 4; a++) { | for (a = 0; a < 4; a++) { | ||||
| if (b->area_q[a] != dv_quant_shifts[qnos[i] + dv_quant_offset[b->cno]][a]) { | |||||
| if (b->area_q[a] != ff_dv_quant_shifts[qnos[i] + ff_dv_quant_offset[b->cno]][a]) { | |||||
| b->bit_size[a] = 1; // 4 areas 4 bits for EOB :) | b->bit_size[a] = 1; // 4 areas 4 bits for EOB :) | ||||
| b->area_q[a]++; | b->area_q[a]++; | ||||
| prev = b->prev[a]; | prev = b->prev[a]; | ||||
| @@ -30,6 +30,99 @@ | |||||
| #include "avcodec.h" | #include "avcodec.h" | ||||
| #include "dvdata.h" | #include "dvdata.h" | ||||
| /* unquant tables (not used directly) */ | |||||
| const uint8_t ff_dv_quant_shifts[22][4] = { | |||||
| { 3,3,4,4 }, | |||||
| { 3,3,4,4 }, | |||||
| { 2,3,3,4 }, | |||||
| { 2,3,3,4 }, | |||||
| { 2,2,3,3 }, | |||||
| { 2,2,3,3 }, | |||||
| { 1,2,2,3 }, | |||||
| { 1,2,2,3 }, | |||||
| { 1,1,2,2 }, | |||||
| { 1,1,2,2 }, | |||||
| { 0,1,1,2 }, | |||||
| { 0,1,1,2 }, | |||||
| { 0,0,1,1 }, | |||||
| { 0,0,1,1 }, | |||||
| { 0,0,0,1 }, | |||||
| { 0,0,0,0 }, | |||||
| { 0,0,0,0 }, | |||||
| { 0,0,0,0 }, | |||||
| { 0,0,0,0 }, | |||||
| { 0,0,0,0 }, | |||||
| { 0,0,0,0 }, | |||||
| { 0,0,0,0 }, | |||||
| }; | |||||
| const uint8_t ff_dv_quant_offset[4] = { 6, 3, 0, 1 }; | |||||
| const int ff_dv_iweight_88[64] = { | |||||
| 32768, 16710, 16710, 17735, 17015, 17735, 18197, 18079, | |||||
| 18079, 18197, 18725, 18559, 19196, 18559, 18725, 19284, | |||||
| 19108, 19692, 19692, 19108, 19284, 21400, 19645, 20262, | |||||
| 20214, 20262, 19645, 21400, 22733, 21845, 20867, 20815, | |||||
| 20815, 20867, 21845, 22733, 23173, 23173, 21400, 21400, | |||||
| 21400, 23173, 23173, 24600, 23764, 22017, 22017, 23764, | |||||
| 24600, 25267, 24457, 22672, 24457, 25267, 25971, 25191, | |||||
| 25191, 25971, 26715, 27962, 26715, 29642, 29642, 31536, | |||||
| }; | |||||
| const int ff_dv_iweight_248[64] = { | |||||
| 32768, 17735, 16710, 18079, 18725, 21400, 17735, 19196, | |||||
| 19108, 21845, 16384, 17735, 18725, 21400, 16710, 18079, | |||||
| 20262, 23173, 18197, 19692, 18725, 20262, 20815, 23764, | |||||
| 17735, 19196, 19108, 21845, 20262, 23173, 18197, 19692, | |||||
| 21400, 24457, 19284, 20867, 21400, 23173, 22017, 25191, | |||||
| 18725, 20262, 20815, 23764, 21400, 24457, 19284, 20867, | |||||
| 24457, 27962, 22733, 24600, 25971, 29642, 21400, 23173, | |||||
| 22017, 25191, 24457, 27962, 22733, 24600, 25971, 29642, | |||||
| }; | |||||
| /** | |||||
| * The "inverse" DV100 weights are actually just the spec weights (zig-zagged). | |||||
| */ | |||||
| const int ff_dv_iweight_1080_y[64] = { | |||||
| 128, 16, 16, 17, 17, 17, 18, 18, | |||||
| 18, 18, 18, 18, 19, 18, 18, 19, | |||||
| 19, 19, 19, 19, 19, 42, 38, 40, | |||||
| 40, 40, 38, 42, 44, 43, 41, 41, | |||||
| 41, 41, 43, 44, 45, 45, 42, 42, | |||||
| 42, 45, 45, 48, 46, 43, 43, 46, | |||||
| 48, 49, 48, 44, 48, 49, 101, 98, | |||||
| 98, 101, 104, 109, 104, 116, 116, 123, | |||||
| }; | |||||
| const int ff_dv_iweight_1080_c[64] = { | |||||
| 128, 16, 16, 17, 17, 17, 25, 25, | |||||
| 25, 25, 26, 25, 26, 25, 26, 26, | |||||
| 26, 27, 27, 26, 26, 42, 38, 40, | |||||
| 40, 40, 38, 42, 44, 43, 41, 41, | |||||
| 41, 41, 43, 44, 91, 91, 84, 84, | |||||
| 84, 91, 91, 96, 93, 86, 86, 93, | |||||
| 96, 197, 191, 177, 191, 197, 203, 197, | |||||
| 197, 203, 209, 219, 209, 232, 232, 246, | |||||
| }; | |||||
| const int ff_dv_iweight_720_y[64] = { | |||||
| 128, 16, 16, 17, 17, 17, 18, 18, | |||||
| 18, 18, 18, 18, 19, 18, 18, 19, | |||||
| 19, 19, 19, 19, 19, 42, 38, 40, | |||||
| 40, 40, 38, 42, 44, 43, 41, 41, | |||||
| 41, 41, 43, 44, 68, 68, 63, 63, | |||||
| 63, 68, 68, 96, 92, 86, 86, 92, | |||||
| 96, 98, 96, 88, 96, 98, 202, 196, | |||||
| 196, 202, 208, 218, 208, 232, 232, 246, | |||||
| }; | |||||
| const int ff_dv_iweight_720_c[64] = { | |||||
| 128, 24, 24, 26, 26, 26, 36, 36, | |||||
| 36, 36, 36, 36, 38, 36, 36, 38, | |||||
| 38, 38, 38, 38, 38, 84, 76, 80, | |||||
| 80, 80, 76, 84, 88, 86, 82, 82, | |||||
| 82, 82, 86, 88, 182, 182, 168, 168, | |||||
| 168, 182, 182, 192, 186, 192, 172, 186, | |||||
| 192, 394, 382, 354, 382, 394, 406, 394, | |||||
| 394, 406, 418, 438, 418, 464, 464, 492, | |||||
| }; | |||||
| static DVwork_chunk work_chunks_dv25pal [1*12*27]; | static DVwork_chunk work_chunks_dv25pal [1*12*27]; | ||||
| static DVwork_chunk work_chunks_dv25pal411[1*12*27]; | static DVwork_chunk work_chunks_dv25pal411[1*12*27]; | ||||
| static DVwork_chunk work_chunks_dv25ntsc [1*10*27]; | static DVwork_chunk work_chunks_dv25ntsc [1*10*27]; | ||||
| @@ -104,6 +104,16 @@ enum dv_pack_type { | |||||
| dv_unknown_pack = 0xff, | dv_unknown_pack = 0xff, | ||||
| }; | }; | ||||
| extern const uint8_t ff_dv_quant_shifts[22][4]; | |||||
| extern const uint8_t ff_dv_quant_offset[4]; | |||||
| extern const int ff_dv_iweight_88[64]; | |||||
| extern const int ff_dv_iweight_248[64]; | |||||
| extern const int ff_dv_iweight_1080_y[64]; | |||||
| extern const int ff_dv_iweight_1080_c[64]; | |||||
| extern const int ff_dv_iweight_720_y[64]; | |||||
| extern const int ff_dv_iweight_720_c[64]; | |||||
| #define DV_PROFILE_IS_HD(p) ((p)->video_stype & 0x10) | #define DV_PROFILE_IS_HD(p) ((p)->video_stype & 0x10) | ||||
| #define DV_PROFILE_IS_1080i50(p) (((p)->video_stype == 0x14) && ((p)->dsf == 1)) | #define DV_PROFILE_IS_1080i50(p) (((p)->video_stype == 0x14) && ((p)->dsf == 1)) | ||||
| #define DV_PROFILE_IS_720p50(p) (((p)->video_stype == 0x18) && ((p)->dsf == 1)) | #define DV_PROFILE_IS_720p50(p) (((p)->video_stype == 0x18) && ((p)->dsf == 1)) | ||||
| @@ -42,7 +42,6 @@ | |||||
| #include "put_bits.h" | #include "put_bits.h" | ||||
| #include "simple_idct.h" | #include "simple_idct.h" | ||||
| #include "dvdata.h" | #include "dvdata.h" | ||||
| #include "dvquant.h" | |||||
| typedef struct BlockInfo { | typedef struct BlockInfo { | ||||
| const uint32_t *factor_table; | const uint32_t *factor_table; | ||||
| @@ -54,6 +53,8 @@ typedef struct BlockInfo { | |||||
| int shift_offset; | int shift_offset; | ||||
| } BlockInfo; | } BlockInfo; | ||||
| static const int dv_iweight_bits = 14; | |||||
| /* decode AC coefficients */ | /* decode AC coefficients */ | ||||
| static void dv_decode_ac(GetBitContext *gb, BlockInfo *mb, DCTELEM *block) | static void dv_decode_ac(GetBitContext *gb, BlockInfo *mb, DCTELEM *block) | ||||
| { | { | ||||
| @@ -181,7 +182,7 @@ static int dv_decode_video_segment(AVCodecContext *avctx, void *arg) | |||||
| mb->idct_put = s->idct_put[dct_mode && log2_blocksize == 3]; | mb->idct_put = s->idct_put[dct_mode && log2_blocksize == 3]; | ||||
| mb->scan_table = s->dv_zigzag[dct_mode]; | mb->scan_table = s->dv_zigzag[dct_mode]; | ||||
| mb->factor_table = &s->sys->idct_factor[(class1 == 3)*2*22*64 + dct_mode*22*64 + | mb->factor_table = &s->sys->idct_factor[(class1 == 3)*2*22*64 + dct_mode*22*64 + | ||||
| (quant + dv_quant_offset[class1])*64]; | |||||
| (quant + ff_dv_quant_offset[class1])*64]; | |||||
| } | } | ||||
| dc = dc << 2; | dc = dc << 2; | ||||
| /* convert to unsigned because 128 is not added in the | /* convert to unsigned because 128 is not added in the | ||||
| @@ -1,157 +0,0 @@ | |||||
| /* | |||||
| * Quant and Weight for DV codec | |||||
| * Copyright (c) 2002 Fabrice Bellard | |||||
| * | |||||
| * 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 | |||||
| */ | |||||
| /** | |||||
| * @file | |||||
| * Constants for DV codec. | |||||
| */ | |||||
| #ifndef AVCODEC_DVQUANT_H | |||||
| #define AVCODEC_DVQUANT_H | |||||
| #include <stdint.h> | |||||
| /* unquant tables (not used directly) */ | |||||
| static const uint8_t dv_quant_shifts[22][4] = { | |||||
| { 3,3,4,4 }, | |||||
| { 3,3,4,4 }, | |||||
| { 2,3,3,4 }, | |||||
| { 2,3,3,4 }, | |||||
| { 2,2,3,3 }, | |||||
| { 2,2,3,3 }, | |||||
| { 1,2,2,3 }, | |||||
| { 1,2,2,3 }, | |||||
| { 1,1,2,2 }, | |||||
| { 1,1,2,2 }, | |||||
| { 0,1,1,2 }, | |||||
| { 0,1,1,2 }, | |||||
| { 0,0,1,1 }, | |||||
| { 0,0,1,1 }, | |||||
| { 0,0,0,1 }, | |||||
| { 0,0,0,0 }, | |||||
| { 0,0,0,0 }, | |||||
| { 0,0,0,0 }, | |||||
| { 0,0,0,0 }, | |||||
| { 0,0,0,0 }, | |||||
| { 0,0,0,0 }, | |||||
| { 0,0,0,0 }, | |||||
| }; | |||||
| static const uint8_t dv_quant_offset[4] = { 6, 3, 0, 1 }; | |||||
| static const uint8_t dv_quant_areas[4] = { 6, 21, 43, 64 }; | |||||
| /* quantization quanta by QNO for DV100 */ | |||||
| static const uint8_t dv100_qstep[16] = { | |||||
| 1, /* QNO = 0 and 1 both have no quantization */ | |||||
| 1, | |||||
| 2, 3, 4, 5, 6, 7, 8, 16, 18, 20, 22, 24, 28, 52 | |||||
| }; | |||||
| /* DV25/50 DCT coefficient weights and inverse weights */ | |||||
| /* created by dvtables.py */ | |||||
| static const int dv_weight_bits = 18; | |||||
| static const int dv_weight_88[64] = { | |||||
| 131072, 257107, 257107, 242189, 252167, 242189, 235923, 237536, | |||||
| 237536, 235923, 229376, 231390, 223754, 231390, 229376, 222935, | |||||
| 224969, 217965, 217965, 224969, 222935, 200636, 218652, 211916, | |||||
| 212325, 211916, 218652, 200636, 188995, 196781, 205965, 206433, | |||||
| 206433, 205965, 196781, 188995, 185364, 185364, 200636, 200704, | |||||
| 200636, 185364, 185364, 174609, 180568, 195068, 195068, 180568, | |||||
| 174609, 170091, 175557, 189591, 175557, 170091, 165371, 170627, | |||||
| 170627, 165371, 160727, 153560, 160727, 144651, 144651, 136258, | |||||
| }; | |||||
| static const int dv_weight_248[64] = { | |||||
| 131072, 242189, 257107, 237536, 229376, 200636, 242189, 223754, | |||||
| 224969, 196781, 262144, 242189, 229376, 200636, 257107, 237536, | |||||
| 211916, 185364, 235923, 217965, 229376, 211916, 206433, 180568, | |||||
| 242189, 223754, 224969, 196781, 211916, 185364, 235923, 217965, | |||||
| 200704, 175557, 222935, 205965, 200636, 185364, 195068, 170627, | |||||
| 229376, 211916, 206433, 180568, 200704, 175557, 222935, 205965, | |||||
| 175557, 153560, 188995, 174609, 165371, 144651, 200636, 185364, | |||||
| 195068, 170627, 175557, 153560, 188995, 174609, 165371, 144651, | |||||
| }; | |||||
| static const int dv_iweight_bits = 14; | |||||
| static const int dv_iweight_88[64] = { | |||||
| 32768, 16710, 16710, 17735, 17015, 17735, 18197, 18079, | |||||
| 18079, 18197, 18725, 18559, 19196, 18559, 18725, 19284, | |||||
| 19108, 19692, 19692, 19108, 19284, 21400, 19645, 20262, | |||||
| 20214, 20262, 19645, 21400, 22733, 21845, 20867, 20815, | |||||
| 20815, 20867, 21845, 22733, 23173, 23173, 21400, 21400, | |||||
| 21400, 23173, 23173, 24600, 23764, 22017, 22017, 23764, | |||||
| 24600, 25267, 24457, 22672, 24457, 25267, 25971, 25191, | |||||
| 25191, 25971, 26715, 27962, 26715, 29642, 29642, 31536, | |||||
| }; | |||||
| static const int dv_iweight_248[64] = { | |||||
| 32768, 17735, 16710, 18079, 18725, 21400, 17735, 19196, | |||||
| 19108, 21845, 16384, 17735, 18725, 21400, 16710, 18079, | |||||
| 20262, 23173, 18197, 19692, 18725, 20262, 20815, 23764, | |||||
| 17735, 19196, 19108, 21845, 20262, 23173, 18197, 19692, | |||||
| 21400, 24457, 19284, 20867, 21400, 23173, 22017, 25191, | |||||
| 18725, 20262, 20815, 23764, 21400, 24457, 19284, 20867, | |||||
| 24457, 27962, 22733, 24600, 25971, 29642, 21400, 23173, | |||||
| 22017, 25191, 24457, 27962, 22733, 24600, 25971, 29642, | |||||
| }; | |||||
| /** | |||||
| * The "inverse" DV100 weights are actually just the spec weights (zig-zagged). | |||||
| */ | |||||
| static const int dv_iweight_1080_y[64] = { | |||||
| 128, 16, 16, 17, 17, 17, 18, 18, | |||||
| 18, 18, 18, 18, 19, 18, 18, 19, | |||||
| 19, 19, 19, 19, 19, 42, 38, 40, | |||||
| 40, 40, 38, 42, 44, 43, 41, 41, | |||||
| 41, 41, 43, 44, 45, 45, 42, 42, | |||||
| 42, 45, 45, 48, 46, 43, 43, 46, | |||||
| 48, 49, 48, 44, 48, 49, 101, 98, | |||||
| 98, 101, 104, 109, 104, 116, 116, 123, | |||||
| }; | |||||
| static const int dv_iweight_1080_c[64] = { | |||||
| 128, 16, 16, 17, 17, 17, 25, 25, | |||||
| 25, 25, 26, 25, 26, 25, 26, 26, | |||||
| 26, 27, 27, 26, 26, 42, 38, 40, | |||||
| 40, 40, 38, 42, 44, 43, 41, 41, | |||||
| 41, 41, 43, 44, 91, 91, 84, 84, | |||||
| 84, 91, 91, 96, 93, 86, 86, 93, | |||||
| 96, 197, 191, 177, 191, 197, 203, 197, | |||||
| 197, 203, 209, 219, 209, 232, 232, 246, | |||||
| }; | |||||
| static const int dv_iweight_720_y[64] = { | |||||
| 128, 16, 16, 17, 17, 17, 18, 18, | |||||
| 18, 18, 18, 18, 19, 18, 18, 19, | |||||
| 19, 19, 19, 19, 19, 42, 38, 40, | |||||
| 40, 40, 38, 42, 44, 43, 41, 41, | |||||
| 41, 41, 43, 44, 68, 68, 63, 63, | |||||
| 63, 68, 68, 96, 92, 86, 86, 92, | |||||
| 96, 98, 96, 88, 96, 98, 202, 196, | |||||
| 196, 202, 208, 218, 208, 232, 232, 246, | |||||
| }; | |||||
| static const int dv_iweight_720_c[64] = { | |||||
| 128, 24, 24, 26, 26, 26, 36, 36, | |||||
| 36, 36, 36, 36, 38, 36, 36, 38, | |||||
| 38, 38, 38, 38, 38, 84, 76, 80, | |||||
| 80, 80, 76, 84, 88, 86, 82, 82, | |||||
| 82, 82, 86, 88, 182, 182, 168, 168, | |||||
| 168, 182, 182, 192, 186, 192, 172, 186, | |||||
| 192, 394, 382, 354, 382, 394, 406, 394, | |||||
| 394, 406, 418, 438, 418, 464, 464, 492, | |||||
| }; | |||||
| #endif /* AVCODEC_DVQUANT_H */ | |||||
| @@ -247,8 +247,8 @@ | |||||
| * Expand a pair of delta values (a,b) | * Expand a pair of delta values (a,b) | ||||
| * into two/four delta entries. | * into two/four delta entries. | ||||
| */ | */ | ||||
| #define E2(a, b) PD(a, b), PD(-a, -b) | |||||
| #define E4(a, b) PD(a, b), PD(-a, -b), PD(b, a), PD(-b, -a) | |||||
| #define E2(a, b) PD(a, b), PD(-(a), -(b)) | |||||
| #define E4(a, b) PD(a, b), PD(-(a), -(b)), PD(b, a), PD(-(b), -(a)) | |||||
| /* | /* | ||||
| * VQ tables for 4x4 block modes. | * VQ tables for 4x4 block modes. | ||||
| @@ -160,7 +160,7 @@ DECLARE_REG_TMP 7 | |||||
| %macro BIWEIGHT_PROLOGUE 0 | %macro BIWEIGHT_PROLOGUE 0 | ||||
| .prologue | .prologue | ||||
| PROLOGUE 0,7,8 | |||||
| PROLOGUE 0,8,8 | |||||
| movifnidn r0, r0mp | movifnidn r0, r0mp | ||||
| movifnidn r1, r1mp | movifnidn r1, r1mp | ||||
| movifnidn r2d, r2m | movifnidn r2d, r2m | ||||
| @@ -218,7 +218,7 @@ DECLARE_REG_TMP 7 | |||||
| %endmacro | %endmacro | ||||
| %macro BIWEIGHT_FUNC_DBL 1 | %macro BIWEIGHT_FUNC_DBL 1 | ||||
| cglobal h264_biweight_16_10_%1, 0, 8, 8 | |||||
| cglobal h264_biweight_16_10_%1 | |||||
| BIWEIGHT_PROLOGUE | BIWEIGHT_PROLOGUE | ||||
| BIWEIGHT_SETUP %1 | BIWEIGHT_SETUP %1 | ||||
| .nextrow | .nextrow | ||||
| @@ -238,7 +238,7 @@ BIWEIGHT_FUNC_DBL sse2 | |||||
| BIWEIGHT_FUNC_DBL sse4 | BIWEIGHT_FUNC_DBL sse4 | ||||
| %macro BIWEIGHT_FUNC 1 | %macro BIWEIGHT_FUNC 1 | ||||
| cglobal h264_biweight_8_10_%1, 0, 8, 8 | |||||
| cglobal h264_biweight_8_10_%1 | |||||
| BIWEIGHT_PROLOGUE | BIWEIGHT_PROLOGUE | ||||
| BIWEIGHT_SETUP %1 | BIWEIGHT_SETUP %1 | ||||
| .nextrow | .nextrow | ||||
| @@ -256,7 +256,7 @@ BIWEIGHT_FUNC sse2 | |||||
| BIWEIGHT_FUNC sse4 | BIWEIGHT_FUNC sse4 | ||||
| %macro BIWEIGHT_FUNC_HALF 1 | %macro BIWEIGHT_FUNC_HALF 1 | ||||
| cglobal h264_biweight_4_10_%1, 0, 8, 8 | |||||
| cglobal h264_biweight_4_10_%1 | |||||
| BIWEIGHT_PROLOGUE | BIWEIGHT_PROLOGUE | ||||
| BIWEIGHT_SETUP %1 | BIWEIGHT_SETUP %1 | ||||
| sar r3d, 1 | sar r3d, 1 | ||||
| @@ -229,9 +229,10 @@ static int link_filter_inouts(AVFilterContext *filt_ctx, | |||||
| for (pad = 0; pad < filt_ctx->input_count; pad++) { | for (pad = 0; pad < filt_ctx->input_count; pad++) { | ||||
| AVFilterInOut *p = *curr_inputs; | AVFilterInOut *p = *curr_inputs; | ||||
| if (p) | |||||
| if (p) { | |||||
| *curr_inputs = (*curr_inputs)->next; | *curr_inputs = (*curr_inputs)->next; | ||||
| else if (!(p = av_mallocz(sizeof(*p)))) | |||||
| p->next = NULL; | |||||
| } else if (!(p = av_mallocz(sizeof(*p)))) | |||||
| return AVERROR(ENOMEM); | return AVERROR(ENOMEM); | ||||
| if (p->filter_ctx) { | if (p->filter_ctx) { | ||||