mlxsw: core: Move basic trap group initialization from spectrum.c
authorJiri Pirko <jiri@nvidia.com>
Thu, 27 Jan 2022 09:02:22 +0000 (11:02 +0200)
committerJakub Kicinski <kuba@kernel.org>
Fri, 28 Jan 2022 03:19:58 +0000 (19:19 -0800)
Instead of initializing the trap groups used by core in spectrum.c
over op, do it directly in core.c

Signed-off-by: Jiri Pirko <jiri@nvidia.com>
Reviewed-by: Petr Machata <petrm@nvidia.com>
Signed-off-by: Ido Schimmel <idosch@nvidia.com>
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/ethernet/mellanox/mlxsw/core.c
drivers/net/ethernet/mellanox/mlxsw/core.h
drivers/net/ethernet/mellanox/mlxsw/spectrum.c

index c9fb7425866c794595007602c3e27ba52a1da911..20133daa54f5f795072a4afa479ced148071b9e5 100644 (file)
@@ -212,9 +212,29 @@ struct mlxsw_event_listener_item {
        void *priv;
 };
 
+static const u8 mlxsw_core_trap_groups[] = {
+       MLXSW_REG_HTGT_TRAP_GROUP_EMAD,
+       MLXSW_REG_HTGT_TRAP_GROUP_MFDE,
+       MLXSW_REG_HTGT_TRAP_GROUP_MTWE,
+       MLXSW_REG_HTGT_TRAP_GROUP_PMPE,
+};
+
 static int mlxsw_core_trap_groups_set(struct mlxsw_core *mlxsw_core)
 {
-       return mlxsw_core->driver->basic_trap_groups_set(mlxsw_core);
+       char htgt_pl[MLXSW_REG_HTGT_LEN];
+       int err;
+       int i;
+
+       for (i = 0; i < ARRAY_SIZE(mlxsw_core_trap_groups); i++) {
+               mlxsw_reg_htgt_pack(htgt_pl, mlxsw_core_trap_groups[i],
+                                   MLXSW_REG_HTGT_INVALID_POLICER,
+                                   MLXSW_REG_HTGT_DEFAULT_PRIORITY,
+                                   MLXSW_REG_HTGT_DEFAULT_TC);
+               err = mlxsw_reg_write(mlxsw_core, MLXSW_REG(htgt), htgt_pl);
+               if (err)
+                       return err;
+       }
+       return 0;
 }
 
 /******************
index f30bb8614e69f35ec536f1e5624acad7f0a2694d..42e8d669be0a711a868f7cc3edac9aaea3bec46b 100644 (file)
@@ -315,7 +315,6 @@ struct mlxsw_driver {
                    const struct mlxsw_bus_info *mlxsw_bus_info,
                    struct netlink_ext_ack *extack);
        void (*fini)(struct mlxsw_core *mlxsw_core);
-       int (*basic_trap_groups_set)(struct mlxsw_core *mlxsw_core);
        int (*port_type_set)(struct mlxsw_core *mlxsw_core, u16 local_port,
                             enum devlink_port_type new_type);
        int (*port_split)(struct mlxsw_core *mlxsw_core, u16 local_port,
index 4c6497753912a20d2e6599db95512909177eff42..0dc32c23394ed713bfafa9f2e46328be0931c76b 100644 (file)
@@ -2528,31 +2528,6 @@ static void mlxsw_sp_lag_fini(struct mlxsw_sp *mlxsw_sp)
        kfree(mlxsw_sp->lags);
 }
 
-static const u8 mlxsw_sp_basic_trap_groups[] = {
-       MLXSW_REG_HTGT_TRAP_GROUP_EMAD,
-       MLXSW_REG_HTGT_TRAP_GROUP_MFDE,
-       MLXSW_REG_HTGT_TRAP_GROUP_MTWE,
-       MLXSW_REG_HTGT_TRAP_GROUP_PMPE,
-};
-
-static int mlxsw_sp_basic_trap_groups_set(struct mlxsw_core *mlxsw_core)
-{
-       char htgt_pl[MLXSW_REG_HTGT_LEN];
-       int err;
-       int i;
-
-       for (i = 0; i < ARRAY_SIZE(mlxsw_sp_basic_trap_groups); i++) {
-               mlxsw_reg_htgt_pack(htgt_pl, mlxsw_sp_basic_trap_groups[i],
-                                   MLXSW_REG_HTGT_INVALID_POLICER,
-                                   MLXSW_REG_HTGT_DEFAULT_PRIORITY,
-                                   MLXSW_REG_HTGT_DEFAULT_TC);
-               err = mlxsw_reg_write(mlxsw_core, MLXSW_REG(htgt), htgt_pl);
-               if (err)
-                       return err;
-       }
-       return 0;
-}
-
 static const struct mlxsw_sp_ptp_ops mlxsw_sp1_ptp_ops = {
        .clock_init     = mlxsw_sp1_ptp_clock_init,
        .clock_fini     = mlxsw_sp1_ptp_clock_fini,
@@ -3666,7 +3641,6 @@ static struct mlxsw_driver mlxsw_sp1_driver = {
        .fw_filename                    = MLXSW_SP1_FW_FILENAME,
        .init                           = mlxsw_sp1_init,
        .fini                           = mlxsw_sp_fini,
-       .basic_trap_groups_set          = mlxsw_sp_basic_trap_groups_set,
        .port_split                     = mlxsw_sp_port_split,
        .port_unsplit                   = mlxsw_sp_port_unsplit,
        .sb_pool_get                    = mlxsw_sp_sb_pool_get,
@@ -3706,7 +3680,6 @@ static struct mlxsw_driver mlxsw_sp2_driver = {
        .fw_filename                    = MLXSW_SP2_FW_FILENAME,
        .init                           = mlxsw_sp2_init,
        .fini                           = mlxsw_sp_fini,
-       .basic_trap_groups_set          = mlxsw_sp_basic_trap_groups_set,
        .port_split                     = mlxsw_sp_port_split,
        .port_unsplit                   = mlxsw_sp_port_unsplit,
        .sb_pool_get                    = mlxsw_sp_sb_pool_get,
@@ -3747,7 +3720,6 @@ static struct mlxsw_driver mlxsw_sp3_driver = {
        .fw_filename                    = MLXSW_SP3_FW_FILENAME,
        .init                           = mlxsw_sp3_init,
        .fini                           = mlxsw_sp_fini,
-       .basic_trap_groups_set          = mlxsw_sp_basic_trap_groups_set,
        .port_split                     = mlxsw_sp_port_split,
        .port_unsplit                   = mlxsw_sp_port_unsplit,
        .sb_pool_get                    = mlxsw_sp_sb_pool_get,
@@ -3786,7 +3758,6 @@ static struct mlxsw_driver mlxsw_sp4_driver = {
        .priv_size                      = sizeof(struct mlxsw_sp),
        .init                           = mlxsw_sp4_init,
        .fini                           = mlxsw_sp_fini,
-       .basic_trap_groups_set          = mlxsw_sp_basic_trap_groups_set,
        .port_split                     = mlxsw_sp_port_split,
        .port_unsplit                   = mlxsw_sp_port_unsplit,
        .sb_pool_get                    = mlxsw_sp_sb_pool_get,