Fix subsampling check for images 1 pixel wide/tall
Change-Id: I0e262ede7eb4a4ae0c86181922d744e542e93350
This commit is contained in:
		
				
					committed by
					
						
						Deb Mukherjee
					
				
			
			
				
	
			
			
			
						parent
						
							6a0976dc3c
						
					
				
				
					commit
					a0befb93e7
				
			@@ -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;
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user