ref: ce3780251cd9cab3b9495fb78b7f8d2773f45acf
parent: 3fedf4a59bbe8e879e611012fdd0dd3de7cad1af
author: Ronald S. Bultje <[email protected]>
date: Wed Sep 30 17:57:26 EDT 2015
vp10: make render_width/height referenceable through ref frames. See issue 1079. Change-Id: I754a61ec011c3508bbb26826cf8e11dbdfdd8379
--- a/vp10/decoder/decodeframe.c
+++ b/vp10/decoder/decodeframe.c
@@ -1276,13 +1276,21 @@
YV12_BUFFER_CONFIG *const buf = cm->frame_refs[i].buf;
width = buf->y_crop_width;
height = buf->y_crop_height;
+#if CONFIG_MISC_FIXES
+ cm->render_width = buf->render_width;
+ cm->render_height = buf->render_height;
+#endif
found = 1;
break;
}
}
- if (!found)
+ if (!found) {
vp10_read_frame_size(rb, &width, &height);
+#if CONFIG_MISC_FIXES
+ setup_render_size(cm, rb);
+#endif
+ }
if (width <= 0 || height <= 0)
vpx_internal_error(&cm->error, VPX_CODEC_CORRUPT_FRAME,
@@ -1313,7 +1321,9 @@
}
resize_context_buffers(cm, width, height);
+#if !CONFIG_MISC_FIXES
setup_render_size(cm, rb);
+#endif
lock_buffer_pool(pool);
if (vpx_realloc_frame_buffer(
--- a/vp10/encoder/bitstream.c
+++ b/vp10/encoder/bitstream.c
@@ -1013,6 +1013,10 @@
if (cfg != NULL) {
found = cm->width == cfg->y_crop_width &&
cm->height == cfg->y_crop_height;
+#if CONFIG_MISC_FIXES
+ found &= cm->render_width == cfg->render_width &&
+ cm->render_height == cfg->render_height;
+#endif
}
vpx_wb_write_bit(wb, found);
if (found) {
@@ -1023,9 +1027,15 @@
if (!found) {
vpx_wb_write_literal(wb, cm->width - 1, 16);
vpx_wb_write_literal(wb, cm->height - 1, 16);
+
+#if CONFIG_MISC_FIXES
+ write_render_size(cm, wb);
+#endif
}
+#if !CONFIG_MISC_FIXES
write_render_size(cm, wb);
+#endif
}
static void write_sync_code(struct vpx_write_bit_buffer *wb) {