From 1443a08c53fb825cc0df5be7cc674d1c52c2a576 Mon Sep 17 00:00:00 2001 From: Kostya Shishkov Date: Thu, 6 Oct 2022 18:08:39 +0200 Subject: [PATCH] indeo: fix selecting reference tile --- nihav-indeo/src/codecs/ivibr.rs | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/nihav-indeo/src/codecs/ivibr.rs b/nihav-indeo/src/codecs/ivibr.rs index e023bdb..a333b3a 100644 --- a/nihav-indeo/src/codecs/ivibr.rs +++ b/nihav-indeo/src/codecs/ivibr.rs @@ -484,6 +484,7 @@ pub struct IVIDecoder { bref: Option, bands: Vec, + band_tiles: usize, tiles: Vec, num_tiles: [[usize; 4]; 4], tile_start: [[usize; 4]; 4], @@ -503,6 +504,7 @@ impl IVIDecoder { bref: None, bands, + band_tiles: 0, tiles: Vec::new(), tile_start: [[0; 4]; 4], num_tiles: [[0; 4]; 4], } } @@ -530,6 +532,9 @@ impl IVIDecoder { tile_h = (tile_h + 1) >> 1; } } + if plane == 0 { + self.band_tiles = ((band_w + tile_w - 1) / tile_w) * ((band_h + tile_h - 1) / tile_h); + } for band in 0..bands { self.tile_start[plane][band] = tstart; let band_xoff = if (band & 1) == 1 { band_w } else { 0 }; @@ -610,7 +615,7 @@ impl IVIDecoder { let (ref_tiles, cur_tiles) = self.tiles.split_at_mut(tile_no); let tile = &mut cur_tiles[0]; if plane_no != 0 || band_no != 0 { - let rtile = &ref_tiles[0]; + let rtile = &ref_tiles[tile_no % self.band_tiles]; if (tile.mb_w != rtile.mb_w) || (tile.mb_h != rtile.mb_h) { ref_tile = None; } else { -- 2.39.5