IB/cm: Avoid a loop when device has 255 ports
authorParav Pandit <parav@nvidia.com>
Wed, 27 Jan 2021 15:00:08 +0000 (17:00 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 4 Mar 2021 10:38:03 +0000 (11:38 +0100)
commitedcaf7a3b8bce233bffb567c69d5a82cf83e4ac6
tree230703d035a62bc02a960f437e0aa5de58d03dbe
parent0d19c3e61668d2166a215583004eb83ff8fcfa2b
IB/cm: Avoid a loop when device has 255 ports

[ Upstream commit 131be26750379592f0dd6244b2a90bbb504a10bb ]

When RDMA device has 255 ports, loop iterator i overflows.  Due to which
cm_add_one() port iterator loops infinitely.  Use core provided port
iterator to avoid the infinite loop.

Fixes: a977049dacde ("[PATCH] IB: Add the kernel CM implementation")
Link: https://lore.kernel.org/r/20210127150010.1876121-9-leon@kernel.org
Signed-off-by: Mark Bloch <mbloch@nvidia.com>
Signed-off-by: Parav Pandit <parav@nvidia.com>
Signed-off-by: Leon Romanovsky <leonro@nvidia.com>
Signed-off-by: Jason Gunthorpe <jgg@nvidia.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/infiniband/core/cm.c