From 0f48820eccdce95047a3d5c025a660e79ad48239 Mon Sep 17 00:00:00 2001 From: wm4 Date: Mon, 30 Jul 2012 00:27:50 +0200 Subject: [PATCH] mplayer: remove benchmarking/CPU accounting code The code used for benchmarking and showing CPU stats in the status line was inaccurate, misleading and fragile. The final nail in the coffin is the fact that many libav decoders are multithreaded now, and mplayer couldn't possibly measure the CPU time consumed by them. Add the --untimed option. This makes the video untimed, just like --benchmark did (still requires disabling audio synchronization). --- cfg-mplayer.h | 2 +- libmpcodecs/dec_video.c | 19 +---------- mplayer.c | 70 ++--------------------------------------- options.h | 2 +- 4 files changed, 5 insertions(+), 88 deletions(-) diff --git a/cfg-mplayer.h b/cfg-mplayer.h index 1f937c1635..2d3b94ac47 100644 --- a/cfg-mplayer.h +++ b/cfg-mplayer.h @@ -834,7 +834,7 @@ const m_option_t mplayer_opts[]={ OPT_INTRANGE("autoq", auto_quality, 0, 0, 100), - OPT_FLAG_ON("benchmark", benchmark, 0), + OPT_FLAG_ON("untimed", untimed, 0), // dump some stream out instead of playing the file OPT_STRING("dumpfile", stream_dump_name, 0, OPTDEF_STR("stream.dump")), diff --git a/libmpcodecs/dec_video.c b/libmpcodecs/dec_video.c index 1f4ce7497e..a221a089b4 100644 --- a/libmpcodecs/dec_video.c +++ b/libmpcodecs/dec_video.c @@ -46,9 +46,6 @@ // =================================================================== -extern double video_time_usage; -extern double vout_time_usage; - #include "cpudetect.h" int field_dominance = -1; @@ -406,9 +403,6 @@ void *decode_video(sh_video_t *sh_video, struct demux_packet *packet, int drop_frame, double pts) { mp_image_t *mpi = NULL; - unsigned int t = GetTimer(); - unsigned int t2; - double tt; struct MPOpts *opts = sh_video->opts; if (opts->correct_pts && pts != MP_NOPTS_VALUE) { @@ -460,11 +454,6 @@ void *decode_video(sh_video_t *sh_video, struct demux_packet *packet, } #endif - t2 = GetTimer(); - t = t2 - t; - tt = t * 0.000001f; - video_time_usage += tt; - if (!mpi || drop_frame) return NULL; // error / skipped frame @@ -501,13 +490,7 @@ void *decode_video(sh_video_t *sh_video, struct demux_packet *packet, int filter_video(sh_video_t *sh_video, void *frame, double pts) { mp_image_t *mpi = frame; - unsigned int t2 = GetTimer(); vf_instance_t *vf = sh_video->vfilter; // apply video filters and call the leaf vo/ve - int ret = vf->put_image(vf, mpi, pts); - - t2 = GetTimer() - t2; - vout_time_usage += t2 * 0.000001; - - return ret; + return vf->put_image(vf, mpi, pts); } diff --git a/mplayer.c b/mplayer.c index a1b2f22378..bfa48c7879 100644 --- a/mplayer.c +++ b/mplayer.c @@ -233,12 +233,6 @@ static const char help_text[] = _( #include "mp_fifo.h" -// benchmark: -double video_time_usage; -double vout_time_usage; -static double audio_time_usage; -static int total_time_usage_start; -static int total_frame_cnt; static int drop_frame_cnt; // total number of dropped frames // options: @@ -1197,23 +1191,6 @@ static void print_status(struct MPContext *mpctx, double a_pos, bool at_frame) (int)sh_video->num_frames, (int)sh_video->num_frames_decoded); - // CPU usage - if (sh_video) { - if (sh_video->timer > 0.5) - saddf(line, &pos, width, "%2d%% %2d%% %4.1f%% ", - (int)(100.0 * video_time_usage * opts->playback_speed / (double)sh_video->timer), - (int)(100.0 * vout_time_usage * opts->playback_speed / (double)sh_video->timer), - (100.0 * audio_time_usage * opts->playback_speed / (double)sh_video->timer)); - else - saddf(line, &pos, width, "??%% ??%% ??,?%% "); - } else if (mpctx->sh_audio) { - if (mpctx->delay > 0.5) - saddf(line, &pos, width, "%4.1f%% ", - 100.0 * audio_time_usage / (double)mpctx->delay); - else - saddf(line, &pos, width, "??,?%% "); - } - // VO stats if (sh_video) saddf(line, &pos, width, "%d %d ", drop_frame_cnt, output_quality); @@ -2026,7 +2003,6 @@ static int check_framedrop(struct MPContext *mpctx, double frame_time) static int dropped_frames; float delay = opts->playback_speed * ao_get_delay(mpctx->ao); float d = delay - mpctx->delay; - ++total_frame_cnt; // we should avoid dropping too many frames in sequence unless we // are too late. and we allow 100ms A-V delay here: if (d < -dropped_frames * frame_time - 0.100 && !mpctx->paused @@ -2391,7 +2367,6 @@ static int fill_audio_out_buffers(struct MPContext *mpctx, double endpts) struct MPOpts *opts = &mpctx->opts; struct ao *ao = mpctx->ao; unsigned int t; - double tt; int playsize; int playflags = 0; bool audio_eof = false; @@ -2440,8 +2415,6 @@ static int fill_audio_out_buffers(struct MPContext *mpctx, double endpts) audio_eof = true; } t = GetTimer() - t; - tt = t * 0.000001f; - audio_time_usage += tt; if (endpts != MP_NOPTS_VALUE && modifiable_audio_format) { double bytes = (endpts - written_audio_pts(mpctx) + audio_delay) * ao->bps / opts->playback_speed; @@ -2929,9 +2902,6 @@ static void seek_reset(struct MPContext *mpctx, bool reset_ao, bool reset_ac) mpctx->hrseek_active = false; mpctx->hrseek_framedrop = false; mpctx->total_avsync_change = 0; - audio_time_usage = 0; - video_time_usage = 0; - vout_time_usage = 0; drop_frame_cnt = 0; } @@ -3382,10 +3352,10 @@ static void run_playloop(struct MPContext *mpctx) * position, don't try to speed up display of following * frames to catch up; continue with default speed from * the current frame instead. - * If benchmark is set always output frames immediately + * If untimed is set always output frames immediately * without sleeping. */ - if (mpctx->time_frame < -0.2 || opts->benchmark) + if (mpctx->time_frame < -0.2 || opts->untimed) mpctx->time_frame = 0; } @@ -3442,7 +3412,6 @@ static void run_playloop(struct MPContext *mpctx) vo_flip_page(vo, pts_us | 1, duration); mpctx->last_vo_flip_duration = (GetTimer() - t2) * 0.000001; - vout_time_usage += mpctx->last_vo_flip_duration; if (vo->driver->flip_page_timed) { // No need to adjust sync based on flip speed mpctx->last_vo_flip_duration = 0; @@ -4581,11 +4550,6 @@ goto_enable_cache: mp_tmsg(MSGT_CPLAYER, MSGL_V, "Starting playback...\n"); - total_time_usage_start = GetTimer(); - audio_time_usage = 0; - video_time_usage = 0; - vout_time_usage = 0; - total_frame_cnt = 0; drop_frame_cnt = 0; // fix for multifile fps benchmark play_n_frames = play_n_frames_mf; @@ -4663,36 +4627,6 @@ goto_next_file: // don't jump here after ao/vo/getch initialization! mp_msg(MSGT_CPLAYER, MSGL_INFO, "\n"); - if (opts->benchmark) { - double tot = video_time_usage + vout_time_usage + audio_time_usage; - double total_time_usage; - total_time_usage_start = GetTimer() - total_time_usage_start; - total_time_usage = (float)total_time_usage_start * 0.000001; - mp_msg(MSGT_CPLAYER, MSGL_INFO, "\nBENCHMARKs: VC:%8.3fs VO:%8.3fs " - "A:%8.3fs Sys:%8.3fs = %8.3fs\n", - video_time_usage, vout_time_usage, audio_time_usage, - total_time_usage - tot, total_time_usage); - if (total_time_usage > 0.0) - mp_msg(MSGT_CPLAYER, MSGL_INFO, "BENCHMARK%%: VC:%8.4f%% " - "VO:%8.4f%% A:%8.4f%% Sys:%8.4f%% = %8.4f%%\n", - 100.0 * video_time_usage / total_time_usage, - 100.0 * vout_time_usage / total_time_usage, - 100.0 * audio_time_usage / total_time_usage, - 100.0 * (total_time_usage - tot) / total_time_usage, - 100.0); - if (total_frame_cnt && frame_dropping) - mp_msg(MSGT_CPLAYER, MSGL_INFO, "BENCHMARKn: disp: %d (%3.2f fps)" - " drop: %d (%d%%) total: %d (%3.2f fps)\n", - total_frame_cnt - drop_frame_cnt, - (total_time_usage > 0.5) ? ((total_frame_cnt - - drop_frame_cnt) / total_time_usage) : 0, - drop_frame_cnt, - 100 * drop_frame_cnt / total_frame_cnt, - total_frame_cnt, - (total_time_usage > 0.5) ? - (total_frame_cnt / total_time_usage) : 0); - } - // time to uninit all, except global stuff: int uninitialize_parts = INITIALIZED_ALL; if (opts->fixed_vo) diff --git a/options.h b/options.h index 9cd4f04761..53afe4d805 100644 --- a/options.h +++ b/options.h @@ -42,7 +42,7 @@ typedef struct MPOpts { int osd_fractions; char *vobsub_name; int auto_quality; - int benchmark; + int untimed; char *stream_dump_name; int capture_dump; int loop_times;