twx-linux/include/linux/mlx5
Or Har-Toov f79ae071ba RDMA/mlx5: Use sq timestamp as QP timestamp when RoCE is disabled
[ Upstream commit 0c5275bf75ec3708d95654195ae4ed80d946d088 ]

When creating a QP, one of the attributes is TS format (timestamp).
In some devices, we have a limitation that all QPs should have the same
ts_format. The ts_format is chosen based on the device's capability.
The qp_ts_format cap resides under the RoCE caps table, and the
cap will be 0 when RoCE is disabled. So when RoCE is disabled, the
value that should be queried is sq_ts_format under HCA caps.

Consider the case when the system supports REAL_TIME_TS format (0x2),
some QPs are created with REAL_TIME_TS as ts_format, and afterwards
RoCE gets disabled. When trying to construct a new QP, we can't use
the qp_ts_format, that is queried from the RoCE caps table, Since it
leads to passing 0x0 (FREE_RUNNING_TS) as the value of the qp_ts_format,
which is different than the ts_format of the previously allocated
QPs REAL_TIME_TS format (0x2).

Thus, to resolve this, read the sq_ts_format, which also reflect
the supported ts format for the QP when RoCE is disabled.

Fixes: 4806f1e2fee8 ("net/mlx5: Set QP timestamp mode to default")
Signed-off-by: Maher Sanalla <msanalla@nvidia.com>
Signed-off-by: Or Har-Toov <ohartoov@nvidia.com>
Link: https://lore.kernel.org/r/32801966eb767c7fd62b8dea3b63991d5fbfe213.1718554199.git.leon@kernel.org
Reviewed-by: Simon Horman <horms@kernel.org>
Signed-off-by: Leon Romanovsky <leonro@nvidia.com>
Signed-off-by: Jason Gunthorpe <jgg@nvidia.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
2024-08-03 08:53:59 +02:00
..
cq.h
device.h RDMA/mlx5: Send events from IB driver about device affiliation state 2023-12-20 17:01:44 +01:00
doorbell.h
driver.h net/mlx5: Add a timeout to acquire the command queue semaphore 2024-06-12 11:11:53 +02:00
eq.h
eswitch.h
fs_helpers.h
fs.h net/mlx5: Bridge, fix multicast packets sent to uplink 2024-01-31 16:19:02 -08:00
macsec.h
mlx5_ifc_fpga.h
mlx5_ifc_vdpa.h
mlx5_ifc.h net/mlx5: Fix MTMP register capability offset in MCAM register 2024-06-12 11:12:54 +02:00
mpfs.h
port.h
qp.h RDMA/mlx5: Use sq timestamp as QP timestamp when RoCE is disabled 2024-08-03 08:53:59 +02:00
rsc_dump.h
transobj.h
vport.h