From 2c350101393f7effcdce815f20d97f239bf2a78c Mon Sep 17 00:00:00 2001 From: Eric Sandeen Date: Tue, 20 May 2014 18:30:44 +1000 Subject: [PATCH] xfs_repair: don't let bplist index go negative in prefetch After: bbd3275 repair: don't unlock prefetch tree to read discontig buffers Coverity spotted that it's possible for us to arrive at the loop below with num == 1, and then we decrement it to 0, and try to index bplist[num-1]. I think this was possible before the change, i.e. it's probably not a regression. Fix this by not trying to shrink the window unless we have more than one buffer in the array. Signed-off-by: Eric Sandeen Reviewed-by: Dave Chinner Signed-off-by: Dave Chinner --- repair/prefetch.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/repair/prefetch.c b/repair/prefetch.c index 4595310a2..65f845661 100644 --- a/repair/prefetch.c +++ b/repair/prefetch.c @@ -505,7 +505,7 @@ pf_batch_read( first_off = LIBXFS_BBTOOFF64(XFS_BUF_ADDR(bplist[0])); last_off = LIBXFS_BBTOOFF64(XFS_BUF_ADDR(bplist[num-1])) + XFS_BUF_SIZE(bplist[num-1]); - while (last_off - first_off > pf_max_bytes) { + while (num > 1 && last_off - first_off > pf_max_bytes) { num--; last_off = LIBXFS_BBTOOFF64(XFS_BUF_ADDR(bplist[num-1])) + XFS_BUF_SIZE(bplist[num-1]); -- 2.47.2