summaryrefslogtreecommitdiffstats
path: root/lib/crc-t10dif.c
diff options
context:
space:
mode:
authorYishai Hadas <yishaih@nvidia.com>2023-01-11 12:10:54 +0200
committerJason Gunthorpe <jgg@nvidia.com>2023-01-16 12:08:31 -0400
commit0f097f08c9b3c1fdb6cc9f2dd423abc17d13f1a2 (patch)
tree294019f8b70ca1542e50bf0ccff1ccc605f28726 /lib/crc-t10dif.c
parentb3deec25847bda34e34d5d7be02f633caf000bd8 (diff)
downloadlinux-0f097f08c9b3c1fdb6cc9f2dd423abc17d13f1a2.tar.bz2
lib/scatterlist: Fix to calculate the last_pg properly
The last_pg is wrong, it is actually the first page of the last scatterlist element. To get the last page of the last scatterlist element we have to add prv->length. So it is checking mergability against the wrong page, Further, a SG element is not guaranteed to end on a page boundary, so we have to check the sub page location also for merge eligibility. Fix the above by checking physical contiguity based on PFNs, compute the actual last page and then call pages_are_mergable(). Fixes: 1567b49d1a40 ("lib/scatterlist: add check when merging zone device pages") Link: https://lore.kernel.org/r/20230111101054.188136-1-yishaih@nvidia.com Reported-by: Jason Gunthorpe <jgg@nvidia.com> Signed-off-by: Yishai Hadas <yishaih@nvidia.com> Reviewed-by: Chaitanya Kulkarni <kch@nvidia.com> Signed-off-by: Jason Gunthorpe <jgg@nvidia.com>
Diffstat (limited to 'lib/crc-t10dif.c')
0 files changed, 0 insertions, 0 deletions