mlxsw: Extend MRSR pack() function to support new commands
authorAmit Cohen <amcohen@nvidia.com>
Wed, 15 Nov 2023 12:17:18 +0000 (13:17 +0100)
committerDavid S. Miller <davem@davemloft.net>
Sat, 18 Nov 2023 17:38:51 +0000 (17:38 +0000)
Currently mlxsw_reg_mrsr_pack() always sets 'command=1'. As preparation for
support of new reset flow, pass the command as an argument to the
function and add an enum for this field.

For now, always pass 'command=1' to the pack() function.

Signed-off-by: Amit Cohen <amcohen@nvidia.com>
Reviewed-by: Petr Machata <petrm@nvidia.com>
Signed-off-by: Ido Schimmel <idosch@nvidia.com>
Signed-off-by: Petr Machata <petrm@nvidia.com>
Reviewed-by: Simon Horman <horms@kernel.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/mellanox/mlxsw/pci.c
drivers/net/ethernet/mellanox/mlxsw/reg.h

index e4b25e187467acb68fd5b46205ff0a3e95ce2678..7af37f78ed1a4294356a96e6a2c470cb1409790b 100644 (file)
@@ -1491,7 +1491,7 @@ static int mlxsw_pci_sw_reset(struct mlxsw_pci *mlxsw_pci,
                return err;
        }
 
-       mlxsw_reg_mrsr_pack(mrsr_pl);
+       mlxsw_reg_mrsr_pack(mrsr_pl, MLXSW_REG_MRSR_COMMAND_SOFTWARE_RESET);
        err = mlxsw_reg_write(mlxsw_pci->core, MLXSW_REG(mrsr), mrsr_pl);
        if (err)
                return err;
index 25b294fdeb3df9d120e2efb3afbc3560f4595bd4..13c0ff994537837e1fb7cbb561685299dc1a4c85 100644 (file)
@@ -10122,6 +10122,15 @@ mlxsw_reg_mgir_unpack(char *payload, u32 *hw_rev, char *fw_info_psid,
 
 MLXSW_REG_DEFINE(mrsr, MLXSW_REG_MRSR_ID, MLXSW_REG_MRSR_LEN);
 
+enum mlxsw_reg_mrsr_command {
+       /* Switch soft reset, does not reset PCI firmware. */
+       MLXSW_REG_MRSR_COMMAND_SOFTWARE_RESET = 1,
+       /* Reset will be done when PCI link will be disabled.
+        * This command will reset PCI firmware also.
+        */
+       MLXSW_REG_MRSR_COMMAND_RESET_AT_PCI_DISABLE = 6,
+};
+
 /* reg_mrsr_command
  * Reset/shutdown command
  * 0 - do nothing
@@ -10130,10 +10139,11 @@ MLXSW_REG_DEFINE(mrsr, MLXSW_REG_MRSR_ID, MLXSW_REG_MRSR_LEN);
  */
 MLXSW_ITEM32(reg, mrsr, command, 0x00, 0, 4);
 
-static inline void mlxsw_reg_mrsr_pack(char *payload)
+static inline void mlxsw_reg_mrsr_pack(char *payload,
+                                      enum mlxsw_reg_mrsr_command command)
 {
        MLXSW_REG_ZERO(mrsr, payload);
-       mlxsw_reg_mrsr_command_set(payload, 1);
+       mlxsw_reg_mrsr_command_set(payload, command);
 }
 
 /* MLCR - Management LED Control Register