Fix subsampling check for images 1 pixel wide/tall

Change-Id: I0e262ede7eb4a4ae0c86181922d744e542e93350
This commit is contained in:
Alex Converse 2014-10-01 11:23:57 -07:00 коммит произвёл Deb Mukherjee
Родитель 6a0976dc3c
Коммит a0befb93e7
5 изменённых файлов: 19 добавлений и 11 удалений

Просмотреть файл

@ -735,6 +735,8 @@ static void setup_frame_size(VP9_COMMON *cm, struct vp9_read_bit_buffer *rb) {
vpx_internal_error(&cm->error, VPX_CODEC_MEM_ERROR, vpx_internal_error(&cm->error, VPX_CODEC_MEM_ERROR,
"Failed to allocate frame buffer"); "Failed to allocate frame buffer");
} }
cm->frame_bufs[cm->new_fb_idx].buf.subsampling_x = cm->subsampling_x;
cm->frame_bufs[cm->new_fb_idx].buf.subsampling_y = cm->subsampling_y;
cm->frame_bufs[cm->new_fb_idx].buf.bit_depth = (unsigned int)cm->bit_depth; cm->frame_bufs[cm->new_fb_idx].buf.bit_depth = (unsigned int)cm->bit_depth;
} }
@ -787,8 +789,8 @@ static void setup_frame_size_with_refs(VP9_COMMON *cm,
RefBuffer *const ref_frame = &cm->frame_refs[i]; RefBuffer *const ref_frame = &cm->frame_refs[i];
if (!valid_ref_frame_img_fmt( if (!valid_ref_frame_img_fmt(
ref_frame->buf->bit_depth, ref_frame->buf->bit_depth,
ref_frame->buf->uv_crop_width < ref_frame->buf->y_crop_width, ref_frame->buf->subsampling_x,
ref_frame->buf->uv_crop_height < ref_frame->buf->y_crop_height, ref_frame->buf->subsampling_y,
cm->bit_depth, cm->bit_depth,
cm->subsampling_x, cm->subsampling_x,
cm->subsampling_y)) cm->subsampling_y))
@ -811,6 +813,8 @@ static void setup_frame_size_with_refs(VP9_COMMON *cm,
vpx_internal_error(&cm->error, VPX_CODEC_MEM_ERROR, vpx_internal_error(&cm->error, VPX_CODEC_MEM_ERROR,
"Failed to allocate frame buffer"); "Failed to allocate frame buffer");
} }
cm->frame_bufs[cm->new_fb_idx].buf.subsampling_x = cm->subsampling_x;
cm->frame_bufs[cm->new_fb_idx].buf.subsampling_y = cm->subsampling_y;
cm->frame_bufs[cm->new_fb_idx].buf.bit_depth = (unsigned int)cm->bit_depth; cm->frame_bufs[cm->new_fb_idx].buf.bit_depth = (unsigned int)cm->bit_depth;
} }

Просмотреть файл

@ -3276,8 +3276,8 @@ int vp9_receive_raw_frame(VP9_COMP *cpi, unsigned int frame_flags,
VP9_COMMON *cm = &cpi->common; VP9_COMMON *cm = &cpi->common;
struct vpx_usec_timer timer; struct vpx_usec_timer timer;
int res = 0; int res = 0;
const int subsampling_x = sd->uv_width < sd->y_width; const int subsampling_x = sd->subsampling_x;
const int subsampling_y = sd->uv_height < sd->y_height; const int subsampling_y = sd->subsampling_y;
#if CONFIG_VP9_HIGHBITDEPTH #if CONFIG_VP9_HIGHBITDEPTH
const int use_highbitdepth = sd->flags & YV12_FLAG_HIGHBITDEPTH; const int use_highbitdepth = sd->flags & YV12_FLAG_HIGHBITDEPTH;
check_initial_width(cpi, use_highbitdepth, subsampling_x, subsampling_y); check_initial_width(cpi, use_highbitdepth, subsampling_x, subsampling_y);

Просмотреть файл

@ -16,11 +16,9 @@ static void yuvconfig2image(vpx_image_t *img, const YV12_BUFFER_CONFIG *yv12,
* the Y, U, and V planes, nor other alignment adjustments that * the Y, U, and V planes, nor other alignment adjustments that
* might be representable by a YV12_BUFFER_CONFIG, so we just * might be representable by a YV12_BUFFER_CONFIG, so we just
* initialize all the fields.*/ * initialize all the fields.*/
const int ss_x = yv12->uv_crop_width < yv12->y_crop_width;
const int ss_y = yv12->uv_crop_height < yv12->y_crop_height;
int bps; int bps;
if (!ss_y) { if (!yv12->subsampling_y) {
if (!ss_x) { if (!yv12->subsampling_x) {
img->fmt = VPX_IMG_FMT_I444; img->fmt = VPX_IMG_FMT_I444;
bps = 24; bps = 24;
} else { } else {
@ -28,7 +26,7 @@ static void yuvconfig2image(vpx_image_t *img, const YV12_BUFFER_CONFIG *yv12,
bps = 16; bps = 16;
} }
} else { } else {
if (!ss_x) { if (!yv12->subsampling_x) {
img->fmt = VPX_IMG_FMT_I440; img->fmt = VPX_IMG_FMT_I440;
bps = 16; bps = 16;
} else { } else {
@ -41,8 +39,8 @@ static void yuvconfig2image(vpx_image_t *img, const YV12_BUFFER_CONFIG *yv12,
img->h = ALIGN_POWER_OF_TWO(yv12->y_height + 2 * VP9_ENC_BORDER_IN_PIXELS, 3); img->h = ALIGN_POWER_OF_TWO(yv12->y_height + 2 * VP9_ENC_BORDER_IN_PIXELS, 3);
img->d_w = yv12->y_crop_width; img->d_w = yv12->y_crop_width;
img->d_h = yv12->y_crop_height; img->d_h = yv12->y_crop_height;
img->x_chroma_shift = ss_x; img->x_chroma_shift = yv12->subsampling_x;
img->y_chroma_shift = ss_y; img->y_chroma_shift = yv12->subsampling_y;
img->planes[VPX_PLANE_Y] = yv12->y_buffer; img->planes[VPX_PLANE_Y] = yv12->y_buffer;
img->planes[VPX_PLANE_U] = yv12->u_buffer; img->planes[VPX_PLANE_U] = yv12->u_buffer;
img->planes[VPX_PLANE_V] = yv12->v_buffer; img->planes[VPX_PLANE_V] = yv12->v_buffer;
@ -118,6 +116,8 @@ static vpx_codec_err_t image2yuvconfig(const vpx_image_t *img,
#else #else
yv12->border = (img->stride[VPX_PLANE_Y] - img->w) / 2; yv12->border = (img->stride[VPX_PLANE_Y] - img->w) / 2;
#endif // CONFIG_VP9_HIGHBITDEPTH #endif // CONFIG_VP9_HIGHBITDEPTH
yv12->subsampling_x = img->x_chroma_shift;
yv12->subsampling_y = img->y_chroma_shift;
return VPX_CODEC_OK; return VPX_CODEC_OK;
} }

Просмотреть файл

@ -242,6 +242,8 @@ int vp9_realloc_frame_buffer(YV12_BUFFER_CONFIG *ybf,
ybf->border = border; ybf->border = border;
ybf->frame_size = (int)frame_size; ybf->frame_size = (int)frame_size;
ybf->subsampling_x = ss_x;
ybf->subsampling_y = ss_y;
#if CONFIG_VP9_HIGHBITDEPTH #if CONFIG_VP9_HIGHBITDEPTH
if (use_highbitdepth) { if (use_highbitdepth) {

Просмотреть файл

@ -51,6 +51,8 @@ typedef struct yv12_buffer_config {
int buffer_alloc_sz; int buffer_alloc_sz;
int border; int border;
int frame_size; int frame_size;
int subsampling_x;
int subsampling_y;
unsigned int bit_depth; unsigned int bit_depth;
int corrupted; int corrupted;