summaryrefslogtreecommitdiff
path: root/vp8
diff options
context:
space:
mode:
authorYunqing Wang <yunqingwang@google.com>2013-12-27 15:25:54 -0800
committerYunqing Wang <yunqingwang@google.com>2014-01-31 14:44:53 -0800
commit903801f1ef7ac8d13d4f57571d048b604e8aaafd (patch)
tree23567c0947d8492ea9333ff924ed02e0d505c8bb /vp8
parente78c174e540117dcfcdff505d38478d4ac6df844 (diff)
downloadlibvpx-903801f1ef7ac8d13d4f57571d048b604e8aaafd.tar
libvpx-903801f1ef7ac8d13d4f57571d048b604e8aaafd.tar.gz
libvpx-903801f1ef7ac8d13d4f57571d048b604e8aaafd.tar.bz2
libvpx-903801f1ef7ac8d13d4f57571d048b604e8aaafd.zip
vp9 decoder: row-based multi-threaded loopfilter
Implemented parallel loopfiltering, which uses existing tile- decoding threads. Each thread works on one row, and when that row is loopfiltered, it moves to next unattended row. To ensure the correct filtering order, threads are synchronized and one superblock is filtered only if the superblocks it depends on are filtered already. To reduce synchronization overhead and speed up the decoder, we use nsync > 1 for high resolution. Performance tests: 1. on desktop: 8-tile 4k video using 8 threads, speedup: 70% - 80% 4-tile HD video using 4 threads, speedup: ~35% 2. on mobile device(Nexus 7): 4-tile 1080p video using 4 threads, speedup: 18% - 25% 4-tile 1080p video using 2 threads, speedup: 10% - 15% Change-Id: If54b4a11960dd706c22d5ad145ad94156031f36a
Diffstat (limited to 'vp8')
0 files changed, 0 insertions, 0 deletions