Implement Loop restoration multi-threading
Row-based multi-threading of loop-restoration has been added.
Change-Id: I26f96ded4b7b48d5513da1725828043703cd5c00
diff --git a/av1/decoder/decodeframe.c b/av1/decoder/decodeframe.c
index de96409..0f6685c 100644
--- a/av1/decoder/decodeframe.c
+++ b/av1/decoder/decodeframe.c
@@ -4029,17 +4029,32 @@
if (do_loop_restoration) {
av1_loop_restoration_save_boundary_lines(&pbi->cur_buf->buf, cm, 1);
- av1_loop_restoration_filter_frame((YV12_BUFFER_CONFIG *)xd->cur_buf, cm,
- optimized_loop_restoration,
- &pbi->lr_ctxt);
+ if (pbi->num_workers > 1) {
+ av1_loop_restoration_filter_frame_mt(
+ (YV12_BUFFER_CONFIG *)xd->cur_buf, cm, optimized_loop_restoration,
+ pbi->tile_workers, pbi->num_workers, &pbi->lr_row_sync,
+ &pbi->lr_ctxt);
+ } else {
+ av1_loop_restoration_filter_frame((YV12_BUFFER_CONFIG *)xd->cur_buf,
+ cm, optimized_loop_restoration,
+ &pbi->lr_ctxt);
+ }
}
} else {
// In no cdef and no superres case. Provide an optimized version of
// loop_restoration_filter.
- if (do_loop_restoration)
- av1_loop_restoration_filter_frame((YV12_BUFFER_CONFIG *)xd->cur_buf, cm,
- optimized_loop_restoration,
- &pbi->lr_ctxt);
+ if (do_loop_restoration) {
+ if (pbi->num_workers > 1) {
+ av1_loop_restoration_filter_frame_mt(
+ (YV12_BUFFER_CONFIG *)xd->cur_buf, cm, optimized_loop_restoration,
+ pbi->tile_workers, pbi->num_workers, &pbi->lr_row_sync,
+ &pbi->lr_ctxt);
+ } else {
+ av1_loop_restoration_filter_frame((YV12_BUFFER_CONFIG *)xd->cur_buf,
+ cm, optimized_loop_restoration,
+ &pbi->lr_ctxt);
+ }
+ }
}
}
diff --git a/av1/decoder/decoder.c b/av1/decoder/decoder.c
index 6a4907d..066d416 100644
--- a/av1/decoder/decoder.c
+++ b/av1/decoder/decoder.c
@@ -156,6 +156,7 @@
if (pbi->num_workers > 0) {
av1_loop_filter_dealloc(&pbi->lf_row_sync);
+ av1_loop_restoration_dealloc(&pbi->lr_row_sync, pbi->num_workers);
}
#if CONFIG_ACCOUNTING
diff --git a/av1/decoder/decoder.h b/av1/decoder/decoder.h
index a854ccb..e6e61f7 100644
--- a/av1/decoder/decoder.h
+++ b/av1/decoder/decoder.h
@@ -68,6 +68,7 @@
AVxWorker *frame_worker_owner; // frame_worker that owns this pbi.
AVxWorker lf_worker;
AV1LfSync lf_row_sync;
+ AV1LrSync lr_row_sync;
AV1LrStruct lr_ctxt;
AVxWorker *tile_workers;
int num_workers;