Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 8 Jun 2020 09:37:21 +0000 (UTC)
From:      Hans Petter Selasky <hselasky@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-stable@freebsd.org, svn-src-stable-12@freebsd.org
Subject:   svn commit: r361923 - in stable/12/sys/dev/mlx5: . mlx5_core
Message-ID:  <202006080937.0589bLLS036924@repo.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: hselasky
Date: Mon Jun  8 09:37:20 2020
New Revision: 361923
URL: https://svnweb.freebsd.org/changeset/base/361923

Log:
  MFC r361498:
  Sync with Linux packet pacing enhancements in mlx5en(4).
  
  Linux commit:
  05d3ac978ed25b753bfe34fe76c50c31ee506a82
  
  Sponsored by:	Mellanox Technologies

Modified:
  stable/12/sys/dev/mlx5/mlx5_core/mlx5_rl.c
  stable/12/sys/dev/mlx5/mlx5_ifc.h
Directory Properties:
  stable/12/   (props changed)

Modified: stable/12/sys/dev/mlx5/mlx5_core/mlx5_rl.c
==============================================================================
--- stable/12/sys/dev/mlx5/mlx5_core/mlx5_rl.c	Mon Jun  8 09:35:32 2020	(r361922)
+++ stable/12/sys/dev/mlx5/mlx5_core/mlx5_rl.c	Mon Jun  8 09:37:20 2020	(r361923)
@@ -58,16 +58,14 @@ static struct mlx5_rl_entry *find_rl_entry(struct mlx5
 static int mlx5_set_rate_limit_cmd(struct mlx5_core_dev *dev,
 				   u32 rate, u32 burst, u16 index)
 {
-	u32 in[MLX5_ST_SZ_DW(set_rate_limit_in)] = {0};
-	u32 out[MLX5_ST_SZ_DW(set_rate_limit_out)] = {0};
+	u32 in[MLX5_ST_SZ_DW(set_rate_limit_in)] = {};
+	u32 out[MLX5_ST_SZ_DW(set_rate_limit_out)] = {};
 
-	MLX5_SET(set_rate_limit_in, in, opcode,
-		 MLX5_CMD_OP_SET_RATE_LIMIT);
+	MLX5_SET(set_rate_limit_in, in, opcode, MLX5_CMD_OP_SET_RATE_LIMIT);
 	MLX5_SET(set_rate_limit_in, in, rate_limit_index, index);
 	MLX5_SET(set_rate_limit_in, in, rate_limit, rate);
-
-	if (MLX5_CAP_QOS(dev, packet_pacing_burst_bound))
-		MLX5_SET(set_rate_limit_in, in, burst_upper_bound, burst);
+	MLX5_SET(set_rate_limit_in, in, burst_upper_bound, burst);
+	MLX5_SET(set_rate_limit_in, in, typical_packet_size, 0 /* use MTU */);
 
 	return mlx5_cmd_exec(dev, in, sizeof(in), out, sizeof(out));
 }

Modified: stable/12/sys/dev/mlx5/mlx5_ifc.h
==============================================================================
--- stable/12/sys/dev/mlx5/mlx5_ifc.h	Mon Jun  8 09:35:32 2020	(r361922)
+++ stable/12/sys/dev/mlx5/mlx5_ifc.h	Mon Jun  8 09:37:20 2020	(r361923)
@@ -667,7 +667,8 @@ struct mlx5_ifc_qos_cap_bits {
 	u8         esw_rate_limit[0x1];
 	u8         hll[0x1];
 	u8         packet_pacing_burst_bound[0x1];
-	u8         reserved_at_6[0x1a];
+	u8         packet_pacing_typical_size[0x1];
+	u8         reserved_at_7[0x19];
 
 	u8         reserved_at_20[0x20];
 
@@ -7672,7 +7673,13 @@ struct mlx5_ifc_set_rate_limit_in_bits {
 	u8         reserved_at_60[0x20];
 
 	u8         rate_limit[0x20];
+
 	u8         burst_upper_bound[0x20];
+
+	u8         reserved_at_c0[0x10];
+	u8         typical_packet_size[0x10];
+
+	u8         reserved_at_e0[0x120];
 };
 
 struct mlx5_ifc_access_register_out_bits {



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?202006080937.0589bLLS036924>