net/i40e/base: support minimum rollback revision
Add support for minimum rollback revision. Signed-off-by: Przemyslaw Ciesielski <przemyslaw.ciesielski@intel.com> Signed-off-by: Guinan Sun <guinanx.sun@intel.com> Acked-by: Qi Zhang <qi.z.zhang@intel.com>
This commit is contained in:
parent
36fcba1ff5
commit
73cd23dd87
@ -241,6 +241,7 @@ enum i40e_admin_queue_opc {
|
||||
i40e_aqc_opc_nvm_config_read = 0x0704,
|
||||
i40e_aqc_opc_nvm_config_write = 0x0705,
|
||||
i40e_aqc_opc_nvm_update_in_process = 0x0706,
|
||||
i40e_aqc_opc_rollback_revision_update = 0x0707,
|
||||
i40e_aqc_opc_oem_post_update = 0x0720,
|
||||
i40e_aqc_opc_thermal_sensor = 0x0721,
|
||||
|
||||
@ -2419,6 +2420,23 @@ struct i40e_aqc_nvm_config_data_immediate_field {
|
||||
|
||||
I40E_CHECK_STRUCT_LEN(0xc, i40e_aqc_nvm_config_data_immediate_field);
|
||||
|
||||
/* Minimal Rollback Revision Update (direct 0x0707) */
|
||||
struct i40e_aqc_rollback_revision_update {
|
||||
u8 optin_mode; /* bool */
|
||||
#define I40E_AQ_RREV_OPTION_MODE 0x01
|
||||
u8 module_selected;
|
||||
#define I40E_AQ_RREV_MODULE_PCIE_ANALOG 0
|
||||
#define I40E_AQ_RREV_MODULE_PHY_ANALOG 1
|
||||
#define I40E_AQ_RREV_MODULE_OPTION_ROM 2
|
||||
#define I40E_AQ_RREV_MODULE_EMP_IMAGE 3
|
||||
#define I40E_AQ_RREV_MODULE_PE_IMAGE 4
|
||||
u8 reserved1[2];
|
||||
u32 min_rrev;
|
||||
u8 reserved2[8];
|
||||
};
|
||||
|
||||
I40E_CHECK_CMD_LENGTH(i40e_aqc_rollback_revision_update);
|
||||
|
||||
/* OEM Post Update (indirect 0x0720)
|
||||
* no command data struct used
|
||||
*/
|
||||
|
@ -3717,6 +3717,35 @@ i40e_aq_nvm_update_in_process(struct i40e_hw *hw,
|
||||
return status;
|
||||
}
|
||||
|
||||
/**
|
||||
* i40e_aq_min_rollback_rev_update - triggers an ow after update
|
||||
* @hw: pointer to the hw struct
|
||||
* @mode: opt-in mode, 1b for single module update, 0b for bulk update
|
||||
* @module: module to be updated. Ignored if mode is 0b
|
||||
* @min_rrev: value of the new minimal version. Ignored if mode is 0b
|
||||
* @cmd_details: pointer to command details structure or NULL
|
||||
**/
|
||||
enum i40e_status_code
|
||||
i40e_aq_min_rollback_rev_update(struct i40e_hw *hw, u8 mode, u8 module,
|
||||
u32 min_rrev,
|
||||
struct i40e_asq_cmd_details *cmd_details)
|
||||
{
|
||||
struct i40e_aq_desc desc;
|
||||
struct i40e_aqc_rollback_revision_update *cmd =
|
||||
(struct i40e_aqc_rollback_revision_update *)&desc.params.raw;
|
||||
enum i40e_status_code status;
|
||||
|
||||
i40e_fill_default_direct_cmd_desc(&desc,
|
||||
i40e_aqc_opc_rollback_revision_update);
|
||||
cmd->optin_mode = mode;
|
||||
cmd->module_selected = module;
|
||||
cmd->min_rrev = min_rrev;
|
||||
|
||||
status = i40e_asq_send_command(hw, &desc, NULL, 0, cmd_details);
|
||||
|
||||
return status;
|
||||
}
|
||||
|
||||
/**
|
||||
* i40e_aq_oem_post_update - triggers an OEM specific flow after update
|
||||
* @hw: pointer to the hw struct
|
||||
|
@ -240,6 +240,10 @@ enum i40e_status_code i40e_aq_write_nvm_config(struct i40e_hw *hw,
|
||||
u8 cmd_flags, void *data, u16 buf_size,
|
||||
u16 element_count,
|
||||
struct i40e_asq_cmd_details *cmd_details);
|
||||
enum i40e_status_code
|
||||
i40e_aq_min_rollback_rev_update(struct i40e_hw *hw, u8 mode, u8 module,
|
||||
u32 min_rrev,
|
||||
struct i40e_asq_cmd_details *cmd_details);
|
||||
enum i40e_status_code i40e_aq_oem_post_update(struct i40e_hw *hw,
|
||||
void *buff, u16 buff_size,
|
||||
struct i40e_asq_cmd_details *cmd_details);
|
||||
|
Loading…
x
Reference in New Issue
Block a user