diff options
author | Bart Van Assche <bvanassche@acm.org> | 2021-04-02 19:58:20 +0300 |
---|---|---|
committer | Christoph Hellwig <hch@lst.de> | 2021-04-06 09:34:39 +0300 |
commit | 8609c63fce58e94d82f6b6bf29c7806062e2e867 (patch) | |
tree | d911962d73d17a88110f4fbf7eb28b53563c2e35 /drivers/nvme | |
parent | 5befc7c26e5a98cd49789fb1beb52c62bd472dba (diff) | |
download | linux-8609c63fce58e94d82f6b6bf29c7806062e2e867.tar.xz |
nvme: fix handling of large MDTS values
Instead of triggering an integer overflow and undefined behavior if MDTS is
large, set max_hw_sectors to UINT_MAX.
Signed-off-by: Bart Van Assche <bvanassche@acm.org>
Reviewed-by: Keith Busch <kbusch@kernel.org>
[hch: rebased to account for the new nvme_mps_to_sectors helper]
Signed-off-by: Christoph Hellwig <hch@lst.de>
Diffstat (limited to 'drivers/nvme')
-rw-r--r-- | drivers/nvme/host/core.c | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/drivers/nvme/host/core.c b/drivers/nvme/host/core.c index e37e2ecd574c..314705da2c10 100644 --- a/drivers/nvme/host/core.c +++ b/drivers/nvme/host/core.c @@ -3049,9 +3049,11 @@ out: static inline u32 nvme_mps_to_sectors(struct nvme_ctrl *ctrl, u32 units) { - u32 page_shift = NVME_CAP_MPSMIN(ctrl->cap) + 12; + u32 page_shift = NVME_CAP_MPSMIN(ctrl->cap) + 12, val; - return 1 << (units + page_shift - 9); + if (check_shl_overflow(1U, units + page_shift - 9, &val)) + return UINT_MAX; + return val; } static int nvme_init_non_mdts_limits(struct nvme_ctrl *ctrl) |