ref: 69f11d2b9d2d3870378f34a47e0e85bda3435060
parent: eb3fdfba0932bc4f563c71106f7645c1b43d7d39
author: James Zern <jzern@google.com>
date: Sun Aug 31 08:36:34 EDT 2014
vp9_loop_filter_frame_mt: pass planes directly one less dependency on pbi Change-Id: I3f3a392416d3523f4aea6682c3965885baf85197
--- a/vp9/decoder/vp9_decodeframe.c
+++ b/vp9/decoder/vp9_decodeframe.c
@@ -1563,8 +1563,8 @@
if (!xd->corrupted) {
// If multiple threads are used to decode tiles, then we use those threads
// to do parallel loopfiltering.
- vp9_loop_filter_frame_mt(&pbi->lf_row_sync, new_fb, pbi, cm,
- cm->lf.filter_level, 0);
+ vp9_loop_filter_frame_mt(&pbi->lf_row_sync, new_fb, pbi->mb.plane, pbi,
+ cm, cm->lf.filter_level, 0);
}
} else {
*p_data_end = decode_tiles(pbi, data + first_partition_size, data_end);
--- a/vp9/decoder/vp9_dthread.c
+++ b/vp9/decoder/vp9_dthread.c
@@ -135,6 +135,7 @@
// threads.
void vp9_loop_filter_frame_mt(VP9LfSync *lf_sync,
YV12_BUFFER_CONFIG *frame,
+ struct macroblockd_plane planes[MAX_MB_PLANE],
VP9Decoder *pbi, VP9_COMMON *cm,
int frame_filter_level,
int y_only) {
@@ -177,7 +178,7 @@
// Loopfilter data
lf_data->frame_buffer = frame;
lf_data->cm = cm;
- vp9_copy(lf_data->planes, pbi->mb.plane);
+ vpx_memcpy(lf_data->planes, planes, sizeof(lf_data->planes));
lf_data->start = i;
lf_data->stop = sb_rows;
lf_data->y_only = y_only; // always do all planes in decoder
--- a/vp9/decoder/vp9_dthread.h
+++ b/vp9/decoder/vp9_dthread.h
@@ -51,6 +51,7 @@
// Multi-threaded loopfilter that uses the tile threads.
void vp9_loop_filter_frame_mt(VP9LfSync *lf_sync,
YV12_BUFFER_CONFIG *frame,
+ struct macroblockd_plane planes[MAX_MB_PLANE],
struct VP9Decoder *pbi,
struct VP9Common *cm,
int frame_filter_level,