Commit 836ce905 authored by Anton Khirnov's avatar Anton Khirnov

avconv: move filtered_frame from InputStream to OutputStream.

It more properly belongs to output, not input.
parent 6c9eac19
...@@ -165,7 +165,6 @@ typedef struct InputStream { ...@@ -165,7 +165,6 @@ typedef struct InputStream {
int decoding_needed; /* true if the packets must be decoded in 'raw_fifo' */ int decoding_needed; /* true if the packets must be decoded in 'raw_fifo' */
AVCodec *dec; AVCodec *dec;
AVFrame *decoded_frame; AVFrame *decoded_frame;
AVFrame *filtered_frame;
int64_t start; /* time when read started */ int64_t start; /* time when read started */
/* predicted dts of the next packet read for this stream or (when there are /* predicted dts of the next packet read for this stream or (when there are
...@@ -217,6 +216,7 @@ typedef struct OutputStream { ...@@ -217,6 +216,7 @@ typedef struct OutputStream {
AVCodec *enc; AVCodec *enc;
int64_t max_frames; int64_t max_frames;
AVFrame *output_frame; AVFrame *output_frame;
AVFrame *filtered_frame;
/* video only */ /* video only */
AVRational frame_rate; AVRational frame_rate;
...@@ -700,6 +700,7 @@ void exit_program(int ret) ...@@ -700,6 +700,7 @@ void exit_program(int ret)
} }
av_freep(&output_streams[i]->avfilter); av_freep(&output_streams[i]->avfilter);
av_freep(&output_streams[i]->filtered_frame);
av_freep(&output_streams[i]); av_freep(&output_streams[i]);
} }
for (i = 0; i < nb_input_files; i++) { for (i = 0; i < nb_input_files; i++) {
...@@ -708,7 +709,6 @@ void exit_program(int ret) ...@@ -708,7 +709,6 @@ void exit_program(int ret)
} }
for (i = 0; i < nb_input_streams; i++) { for (i = 0; i < nb_input_streams; i++) {
av_freep(&input_streams[i]->decoded_frame); av_freep(&input_streams[i]->decoded_frame);
av_freep(&input_streams[i]->filtered_frame);
av_dict_free(&input_streams[i]->opts); av_dict_free(&input_streams[i]->opts);
free_buffer_pool(input_streams[i]); free_buffer_pool(input_streams[i]);
av_freep(&input_streams[i]); av_freep(&input_streams[i]);
...@@ -1950,12 +1950,12 @@ static int transcode_video(InputStream *ist, AVPacket *pkt, int *got_output, int ...@@ -1950,12 +1950,12 @@ static int transcode_video(InputStream *ist, AVPacket *pkt, int *got_output, int
av_vsrc_buffer_add_frame(ost->input_video_filter, decoded_frame, av_vsrc_buffer_add_frame(ost->input_video_filter, decoded_frame,
decoded_frame->pts, decoded_frame->sample_aspect_ratio); decoded_frame->pts, decoded_frame->sample_aspect_ratio);
if (!ist->filtered_frame && !(ist->filtered_frame = avcodec_alloc_frame())) { if (!ost->filtered_frame && !(ost->filtered_frame = avcodec_alloc_frame())) {
ret = AVERROR(ENOMEM); ret = AVERROR(ENOMEM);
goto fail; goto fail;
} else } else
avcodec_get_frame_defaults(ist->filtered_frame); avcodec_get_frame_defaults(ost->filtered_frame);
filtered_frame = ist->filtered_frame; filtered_frame = ost->filtered_frame;
frame_available = avfilter_poll_frame(ost->output_video_filter->inputs[0]); frame_available = avfilter_poll_frame(ost->output_video_filter->inputs[0]);
while (frame_available) { while (frame_available) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment