Small fix to prefetch ranges aggregation

When after #16022 adding new range we aggregate more than two
existing ranges, that should be very rare, only if several streams
overlap, we may need to zero not the last range, but some earlier.

Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
Signed-off-by:	Alexander Motin <mav@FreeBSD.org>
Sponsored by:	iXsystems, Inc.
Closes #16072
This commit is contained in:
Alexander Motin 2024-04-09 19:14:04 -04:00 committed by Brian Behlendorf
parent 97d7228f42
commit f4ce02ae42

View File

@ -418,8 +418,8 @@ dmu_zfetch_future(zstream_t *zs, uint64_t blkid, uint64_t nblks)
zs->zs_ranges[f].start = zs->zs_ranges[l].start; zs->zs_ranges[f].start = zs->zs_ranges[l].start;
zs->zs_ranges[f].end = zs->zs_ranges[l].end; zs->zs_ranges[f].end = zs->zs_ranges[l].end;
} }
zs->zs_ranges[ZFETCH_RANGES - 1].start = 0; zs->zs_ranges[f].start = 0;
zs->zs_ranges[ZFETCH_RANGES - 1].end = 0; zs->zs_ranges[f].end = 0;
} }
} else if (i < ZFETCH_RANGES) { } else if (i < ZFETCH_RANGES) {
/* Got no intersecting ranges, insert new one. */ /* Got no intersecting ranges, insert new one. */