ntb: use 64-bit arithmetic for the MSI doorbell mask
authorFedor Pchelkin <pchelkin@ispras.ru>
Wed, 15 Jan 2025 18:28:17 +0000 (21:28 +0300)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 25 Apr 2025 08:45:35 +0000 (10:45 +0200)
commit fd5625fc86922f36bedee5846fefd647b7e72751 upstream.

msi_db_mask is of type 'u64', still the standard 'int' arithmetic is
performed to compute its value.

While most of the ntb_hw drivers actually don't utilize the higher 32
bits of the doorbell mask now, this may be the case for Switchtec - see
switchtec_ntb_init_db().

Found by Linux Verification Center (linuxtesting.org) with SVACE static
analysis tool.

Fixes: 2b0569b3b7e6 ("NTB: Add MSI interrupt support to ntb_transport")
Cc: stable@vger.kernel.org
Signed-off-by: Fedor Pchelkin <pchelkin@ispras.ru>
Reviewed-by: Dave Jiang <dave.jiang@intel.com>
Signed-off-by: Jon Mason <jdmason@kudzu.us>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/ntb/ntb_transport.c

index c84fadfc63c52c20247517b840b7f6a77bae02d0..76cc5b49a5f1ee5cb1652036f8b7e65b7c88fa39 100644 (file)
@@ -1351,7 +1351,7 @@ static int ntb_transport_probe(struct ntb_client *self, struct ntb_dev *ndev)
        qp_count = ilog2(qp_bitmap);
        if (nt->use_msi) {
                qp_count -= 1;
-               nt->msi_db_mask = 1 << qp_count;
+               nt->msi_db_mask = BIT_ULL(qp_count);
                ntb_db_clear_mask(ndev, nt->msi_db_mask);
        }