Skip to content

Commit 42a7f1d

Browse files
jpirkodavem330
authored andcommitted
mlxsw: reg: Extend SBPM register for occupancy control
Since it is not possible to get and clear Port-Pool occupancy data using SBSR register, there's a need to implement that using SBPM. Extend pack helper and add unpack helper to get occupancy values. Signed-off-by: Jiri Pirko <[email protected]> Reviewed-by: Ido Schimmel <[email protected]> Signed-off-by: David S. Miller <[email protected]>
1 parent 26176de commit 42a7f1d

File tree

2 files changed

+32
-2
lines changed

2 files changed

+32
-2
lines changed

drivers/net/ethernet/mellanox/mlxsw/reg.h

Lines changed: 30 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -3636,6 +3636,27 @@ MLXSW_ITEM32(reg, sbpm, pool, 0x00, 8, 4);
36363636
*/
36373637
MLXSW_ITEM32(reg, sbpm, dir, 0x00, 0, 2);
36383638

3639+
/* reg_sbpm_buff_occupancy
3640+
* Current buffer occupancy in cells.
3641+
* Access: RO
3642+
*/
3643+
MLXSW_ITEM32(reg, sbpm, buff_occupancy, 0x10, 0, 24);
3644+
3645+
/* reg_sbpm_clr
3646+
* Clear Max Buffer Occupancy
3647+
* When this bit is set, max_buff_occupancy field is cleared (and a
3648+
* new max value is tracked from the time the clear was performed).
3649+
* Access: OP
3650+
*/
3651+
MLXSW_ITEM32(reg, sbpm, clr, 0x14, 31, 1);
3652+
3653+
/* reg_sbpm_max_buff_occupancy
3654+
* Maximum value of buffer occupancy in cells monitored. Cleared by
3655+
* writing to the clr field.
3656+
* Access: RO
3657+
*/
3658+
MLXSW_ITEM32(reg, sbpm, max_buff_occupancy, 0x14, 0, 24);
3659+
36393660
/* reg_sbpm_min_buff
36403661
* Minimum buffer size for the limiter, in cells.
36413662
* Access: RW
@@ -3656,17 +3677,25 @@ MLXSW_ITEM32(reg, sbpm, min_buff, 0x18, 0, 24);
36563677
MLXSW_ITEM32(reg, sbpm, max_buff, 0x1C, 0, 24);
36573678

36583679
static inline void mlxsw_reg_sbpm_pack(char *payload, u8 local_port, u8 pool,
3659-
enum mlxsw_reg_sbxx_dir dir,
3680+
enum mlxsw_reg_sbxx_dir dir, bool clr,
36603681
u32 min_buff, u32 max_buff)
36613682
{
36623683
MLXSW_REG_ZERO(sbpm, payload);
36633684
mlxsw_reg_sbpm_local_port_set(payload, local_port);
36643685
mlxsw_reg_sbpm_pool_set(payload, pool);
36653686
mlxsw_reg_sbpm_dir_set(payload, dir);
3687+
mlxsw_reg_sbpm_clr_set(payload, clr);
36663688
mlxsw_reg_sbpm_min_buff_set(payload, min_buff);
36673689
mlxsw_reg_sbpm_max_buff_set(payload, max_buff);
36683690
}
36693691

3692+
static inline void mlxsw_reg_sbpm_unpack(char *payload, u32 *p_buff_occupancy,
3693+
u32 *p_max_buff_occupancy)
3694+
{
3695+
*p_buff_occupancy = mlxsw_reg_sbpm_buff_occupancy_get(payload);
3696+
*p_max_buff_occupancy = mlxsw_reg_sbpm_max_buff_occupancy_get(payload);
3697+
}
3698+
36703699
/* SBMM - Shared Buffer Multicast Management Register
36713700
* --------------------------------------------------
36723701
* The SBMM register configures and retrieves the shared buffer allocation

drivers/net/ethernet/mellanox/mlxsw/spectrum_buffers.c

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -113,7 +113,8 @@ static int mlxsw_sp_sb_pm_write(struct mlxsw_sp *mlxsw_sp, u8 local_port,
113113
struct mlxsw_sp_sb_pm *pm;
114114
int err;
115115

116-
mlxsw_reg_sbpm_pack(sbpm_pl, local_port, pool, dir, min_buff, max_buff);
116+
mlxsw_reg_sbpm_pack(sbpm_pl, local_port, pool, dir, false,
117+
min_buff, max_buff);
117118
err = mlxsw_reg_write(mlxsw_sp->core, MLXSW_REG(sbpm), sbpm_pl);
118119
if (err)
119120
return err;

0 commit comments

Comments
 (0)