From: Alex Converse Date: Sat, 7 Dec 2013 05:43:05 +0000 (-0800) Subject: Have check_initial_width() take subsampling as arguments directly. X-Git-Tag: v1.4.0~2629^2 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=0428579b3dca3d501b3b048b0ecfb2a48f69e611;p=platform%2Fupstream%2Flibvpx.git Have check_initial_width() take subsampling as arguments directly. This way it doesn't need to derive subsampling differently for each caller. Change-Id: I186aa7a84d315b796dcf2fdde5468ec12b3a59e3 --- diff --git a/vp9/encoder/vp9_onyx_if.c b/vp9/encoder/vp9_onyx_if.c index 9d86dd0..efb7fd8 100644 --- a/vp9/encoder/vp9_onyx_if.c +++ b/vp9/encoder/vp9_onyx_if.c @@ -3266,12 +3266,12 @@ static void Pass2Encode(VP9_COMP *cpi, unsigned long *size, vp9_twopass_postencode_update(cpi, *size); } -static void check_initial_width(VP9_COMP *cpi, YV12_BUFFER_CONFIG *sd) { +static void check_initial_width(VP9_COMP *cpi, int subsampling_x, + int subsampling_y) { VP9_COMMON *const cm = &cpi->common; if (!cpi->initial_width) { - // TODO(agrange) Subsampling defaults to assuming sampled chroma. - cm->subsampling_x = sd != NULL ? (sd->uv_width < sd->y_width) : 1; - cm->subsampling_y = sd != NULL ? (sd->uv_height < sd->y_height) : 1; + cm->subsampling_x = subsampling_x; + cm->subsampling_y = subsampling_y; alloc_raw_frame_buffers(cpi); cpi->initial_width = cm->width; cpi->initial_height = cm->height; @@ -3285,8 +3285,10 @@ int vp9_receive_raw_frame(VP9_PTR ptr, unsigned int frame_flags, VP9_COMP *cpi = (VP9_COMP *) ptr; struct vpx_usec_timer timer; int res = 0; + const int subsampling_x = sd->uv_width < sd->y_width; + const int subsampling_y = sd->uv_height < sd->y_height; - check_initial_width(cpi, sd); + check_initial_width(cpi, subsampling_x, subsampling_y); vpx_usec_timer_start(&timer); if (vp9_lookahead_push(cpi->lookahead, sd, time_stamp, end_time, frame_flags, cpi->active_map_enabled ? cpi->active_map : NULL)) @@ -3836,7 +3838,7 @@ int vp9_set_size_literal(VP9_PTR comp, unsigned int width, VP9_COMP *cpi = (VP9_COMP *)comp; VP9_COMMON *cm = &cpi->common; - check_initial_width(cpi, NULL); + check_initial_width(cpi, 1, 1); if (width) { cm->width = width;