diff --git a/vp9/encoder/vp9_firstpass.c b/vp9/encoder/vp9_firstpass.c index c51ce9f543b8cf675b5f3b887b17899dd575bee2..075f0a7d4c23ea388db0c0d09390895ba42d352a 100644 --- a/vp9/encoder/vp9_firstpass.c +++ b/vp9/encoder/vp9_firstpass.c @@ -2029,6 +2029,22 @@ void vp9_get_one_pass_params(VP9_COMP *cpi) { } } +void vp9_get_one_pass_cbr_params(VP9_COMP *cpi) { + VP9_COMMON *const cm = &cpi->common; + if ((cm->current_video_frame == 0 || + cm->frame_flags & FRAMEFLAGS_KEY || + cpi->rc.frames_to_key == 0 || + (cpi->oxcf.auto_key && test_for_kf_one_pass(cpi)))) { + cm->frame_type = KEY_FRAME; + cpi->rc.frames_to_key = cpi->key_frame_frequency; + } else { + cm->frame_type = INTER_FRAME; + } + // Don't use gf_update by default in CBR mode. + cpi->rc.frames_till_gf_update_due = INT_MAX; + cpi->rc.baseline_gf_interval = INT_MAX; +} + void vp9_get_first_pass_params(VP9_COMP *cpi) { VP9_COMMON *const cm = &cpi->common; if (!cpi->refresh_alt_ref_frame && diff --git a/vp9/encoder/vp9_firstpass.h b/vp9/encoder/vp9_firstpass.h index 43703c2c530bbed6877dae5cc30423f20f7c641a..f89e4cb1c3ff1145bdc498cce77318df66095cf1 100644 --- a/vp9/encoder/vp9_firstpass.h +++ b/vp9/encoder/vp9_firstpass.h @@ -22,6 +22,7 @@ void vp9_end_second_pass(VP9_COMP *cpi); void vp9_get_first_pass_params(VP9_COMP *cpi); void vp9_get_one_pass_params(VP9_COMP *cpi); +void vp9_get_one_pass_cbr_params(VP9_COMP *cpi); void vp9_get_svc_params(VP9_COMP *cpi); #endif // VP9_ENCODER_VP9_FIRSTPASS_H_ diff --git a/vp9/encoder/vp9_onyx_if.c b/vp9/encoder/vp9_onyx_if.c index 45fc13e694499d17dfe3fa13c2325f08fe2eefe4..e2c5cc495b1975ecf643487d64cd18ad66289c2c 100644 --- a/vp9/encoder/vp9_onyx_if.c +++ b/vp9/encoder/vp9_onyx_if.c @@ -3250,7 +3250,11 @@ static void SvcEncode(VP9_COMP *cpi, size_t *size, uint8_t *dest, static void Pass0Encode(VP9_COMP *cpi, size_t *size, uint8_t *dest, unsigned int *frame_flags) { - vp9_get_one_pass_params(cpi); + if (cpi->oxcf.end_usage == USAGE_STREAM_FROM_SERVER) { + vp9_get_one_pass_cbr_params(cpi); + } else { + vp9_get_one_pass_params(cpi); + } encode_frame_to_data_rate(cpi, size, dest, frame_flags); }