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;
 
 
 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
  */
 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