mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-07 13:43:51 +00:00
net/mlx5e: Reduce the size of icosq_str
icosq_str size is unnecessarily too long, and it causes a build warning
-Wformat-truncation with W=1. Looking closely, It doesn't need to be 255B,
hence this patch reduces the size to 32B which should be more than enough
to host the string: "ICOSQ: 0x%x, ".
While here, add a missing space in the formatted string.
This fixes the following build warning:
$ KCFLAGS='-Wall -Werror'
$ make O=/tmp/kbuild/linux W=1 -s -j12 drivers/net/ethernet/mellanox/mlx5/core/
drivers/net/ethernet/mellanox/mlx5/core/en/reporter_rx.c: In function 'mlx5e_reporter_rx_timeout':
drivers/net/ethernet/mellanox/mlx5/core/en/reporter_rx.c:718:56:
error: ', CQ: 0x' directive output may be truncated writing 8 bytes into a region of size between 0 and 255 [-Werror=format-truncation=]
718 | "RX timeout on channel: %d, %sRQ: 0x%x, CQ: 0x%x",
| ^~~~~~~~
drivers/net/ethernet/mellanox/mlx5/core/en/reporter_rx.c:717:9: note: 'snprintf' output between 43 and 322 bytes into a destination of size 288
717 | snprintf(err_str, sizeof(err_str),
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
718 | "RX timeout on channel: %d, %sRQ: 0x%x, CQ: 0x%x",
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
719 | rq->ix, icosq_str, rq->rqn, rq->cq.mcq.cqn);
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Fixes: 521f31af00
("net/mlx5e: Allow RQ outside of channel context")
Link: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=6d4ab2e97dcfbcd748ae71761a9d8e5e41cc732c
Signed-off-by: Saeed Mahameed <saeedm@nvidia.com>
Link: https://lore.kernel.org/r/20231114215846.5902-14-saeed@kernel.org
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
This commit is contained in:
parent
3338bebfc2
commit
dce9414284
@ -492,11 +492,11 @@ static int mlx5e_rx_reporter_dump(struct devlink_health_reporter *reporter,
|
|||||||
|
|
||||||
void mlx5e_reporter_rx_timeout(struct mlx5e_rq *rq)
|
void mlx5e_reporter_rx_timeout(struct mlx5e_rq *rq)
|
||||||
{
|
{
|
||||||
char icosq_str[MLX5E_REPORTER_PER_Q_MAX_LEN] = {};
|
|
||||||
char err_str[MLX5E_REPORTER_PER_Q_MAX_LEN];
|
char err_str[MLX5E_REPORTER_PER_Q_MAX_LEN];
|
||||||
struct mlx5e_icosq *icosq = rq->icosq;
|
struct mlx5e_icosq *icosq = rq->icosq;
|
||||||
struct mlx5e_priv *priv = rq->priv;
|
struct mlx5e_priv *priv = rq->priv;
|
||||||
struct mlx5e_err_ctx err_ctx = {};
|
struct mlx5e_err_ctx err_ctx = {};
|
||||||
|
char icosq_str[32] = {};
|
||||||
|
|
||||||
err_ctx.ctx = rq;
|
err_ctx.ctx = rq;
|
||||||
err_ctx.recover = mlx5e_rx_reporter_timeout_recover;
|
err_ctx.recover = mlx5e_rx_reporter_timeout_recover;
|
||||||
@ -505,7 +505,7 @@ void mlx5e_reporter_rx_timeout(struct mlx5e_rq *rq)
|
|||||||
if (icosq)
|
if (icosq)
|
||||||
snprintf(icosq_str, sizeof(icosq_str), "ICOSQ: 0x%x, ", icosq->sqn);
|
snprintf(icosq_str, sizeof(icosq_str), "ICOSQ: 0x%x, ", icosq->sqn);
|
||||||
snprintf(err_str, sizeof(err_str),
|
snprintf(err_str, sizeof(err_str),
|
||||||
"RX timeout on channel: %d, %sRQ: 0x%x, CQ: 0x%x",
|
"RX timeout on channel: %d, %s RQ: 0x%x, CQ: 0x%x",
|
||||||
rq->ix, icosq_str, rq->rqn, rq->cq.mcq.cqn);
|
rq->ix, icosq_str, rq->rqn, rq->cq.mcq.cqn);
|
||||||
|
|
||||||
mlx5e_health_report(priv, priv->rx_reporter, err_str, &err_ctx);
|
mlx5e_health_report(priv, priv->rx_reporter, err_str, &err_ctx);
|
||||||
|
Loading…
Reference in New Issue
Block a user