net/ice/base: move functions from common to NVM module
The ice_get_pfa_module_tlv and ice_read_pba_string functions primarily deal with reading from the Shadow RAM portion of the NVM contents. As these functions are NVM focused, move them into the ice_nvm.c file. Signed-off-by: Jacob Keller <jacob.e.keller@intel.com> Signed-off-by: Paul M Stillwell Jr <paul.m.stillwell.jr@intel.com> Signed-off-by: Qi Zhang <qi.z.zhang@intel.com> Acked-by: Qiming Yang <qiming.yang@intel.com>
This commit is contained in:
parent
ed56a562af
commit
77a6499990
@ -916,72 +916,6 @@ enum ice_status ice_reset(struct ice_hw *hw, enum ice_reset_req req)
|
||||
return ice_check_reset(hw);
|
||||
}
|
||||
|
||||
/**
|
||||
* ice_get_pfa_module_tlv - Reads sub module TLV from NVM PFA
|
||||
* @hw: pointer to hardware structure
|
||||
* @module_tlv: pointer to module TLV to return
|
||||
* @module_tlv_len: pointer to module TLV length to return
|
||||
* @module_type: module type requested
|
||||
*
|
||||
* Finds the requested sub module TLV type from the Preserved Field
|
||||
* Area (PFA) and returns the TLV pointer and length. The caller can
|
||||
* use these to read the variable length TLV value.
|
||||
*/
|
||||
enum ice_status
|
||||
ice_get_pfa_module_tlv(struct ice_hw *hw, u16 *module_tlv, u16 *module_tlv_len,
|
||||
u16 module_type)
|
||||
{
|
||||
enum ice_status status;
|
||||
u16 pfa_len, pfa_ptr;
|
||||
u16 next_tlv;
|
||||
|
||||
status = ice_read_sr_word(hw, ICE_SR_PFA_PTR, &pfa_ptr);
|
||||
if (status != ICE_SUCCESS) {
|
||||
ice_debug(hw, ICE_DBG_INIT, "Preserved Field Array pointer.\n");
|
||||
return status;
|
||||
}
|
||||
status = ice_read_sr_word(hw, pfa_ptr, &pfa_len);
|
||||
if (status != ICE_SUCCESS) {
|
||||
ice_debug(hw, ICE_DBG_INIT, "Failed to read PFA length.\n");
|
||||
return status;
|
||||
}
|
||||
/* Starting with first TLV after PFA length, iterate through the list
|
||||
* of TLVs to find the requested one.
|
||||
*/
|
||||
next_tlv = pfa_ptr + 1;
|
||||
while (next_tlv < pfa_ptr + pfa_len) {
|
||||
u16 tlv_sub_module_type;
|
||||
u16 tlv_len;
|
||||
|
||||
/* Read TLV type */
|
||||
status = ice_read_sr_word(hw, next_tlv, &tlv_sub_module_type);
|
||||
if (status != ICE_SUCCESS) {
|
||||
ice_debug(hw, ICE_DBG_INIT, "Failed to read TLV type.\n");
|
||||
break;
|
||||
}
|
||||
/* Read TLV length */
|
||||
status = ice_read_sr_word(hw, next_tlv + 1, &tlv_len);
|
||||
if (status != ICE_SUCCESS) {
|
||||
ice_debug(hw, ICE_DBG_INIT, "Failed to read TLV length.\n");
|
||||
break;
|
||||
}
|
||||
if (tlv_sub_module_type == module_type) {
|
||||
if (tlv_len) {
|
||||
*module_tlv = next_tlv;
|
||||
*module_tlv_len = tlv_len;
|
||||
return ICE_SUCCESS;
|
||||
}
|
||||
return ICE_ERR_INVAL_SIZE;
|
||||
}
|
||||
/* Check next TLV, i.e. current TLV pointer + length + 2 words
|
||||
* (for current TLV's type and length)
|
||||
*/
|
||||
next_tlv = next_tlv + tlv_len + 2;
|
||||
}
|
||||
/* Module does not exist */
|
||||
return ICE_ERR_DOES_NOT_EXIST;
|
||||
}
|
||||
|
||||
/**
|
||||
* ice_copy_rxq_ctx_to_hw
|
||||
* @hw: pointer to the hardware structure
|
||||
|
@ -23,9 +23,6 @@ enum ice_status ice_init_fltr_mgmt_struct(struct ice_hw *hw);
|
||||
void ice_cleanup_fltr_mgmt_struct(struct ice_hw *hw);
|
||||
enum ice_status ice_init_hw(struct ice_hw *hw);
|
||||
void ice_deinit_hw(struct ice_hw *hw);
|
||||
enum ice_status
|
||||
ice_get_pfa_module_tlv(struct ice_hw *hw, u16 *module_tlv, u16 *module_tlv_len,
|
||||
u16 module_type);
|
||||
enum ice_status ice_check_reset(struct ice_hw *hw);
|
||||
enum ice_status ice_reset(struct ice_hw *hw, enum ice_reset_req req);
|
||||
|
||||
|
@ -234,6 +234,72 @@ enum ice_status ice_read_sr_word(struct ice_hw *hw, u16 offset, u16 *data)
|
||||
return status;
|
||||
}
|
||||
|
||||
/**
|
||||
* ice_get_pfa_module_tlv - Reads sub module TLV from NVM PFA
|
||||
* @hw: pointer to hardware structure
|
||||
* @module_tlv: pointer to module TLV to return
|
||||
* @module_tlv_len: pointer to module TLV length to return
|
||||
* @module_type: module type requested
|
||||
*
|
||||
* Finds the requested sub module TLV type from the Preserved Field
|
||||
* Area (PFA) and returns the TLV pointer and length. The caller can
|
||||
* use these to read the variable length TLV value.
|
||||
*/
|
||||
enum ice_status
|
||||
ice_get_pfa_module_tlv(struct ice_hw *hw, u16 *module_tlv, u16 *module_tlv_len,
|
||||
u16 module_type)
|
||||
{
|
||||
enum ice_status status;
|
||||
u16 pfa_len, pfa_ptr;
|
||||
u16 next_tlv;
|
||||
|
||||
status = ice_read_sr_word(hw, ICE_SR_PFA_PTR, &pfa_ptr);
|
||||
if (status != ICE_SUCCESS) {
|
||||
ice_debug(hw, ICE_DBG_INIT, "Preserved Field Array pointer.\n");
|
||||
return status;
|
||||
}
|
||||
status = ice_read_sr_word(hw, pfa_ptr, &pfa_len);
|
||||
if (status != ICE_SUCCESS) {
|
||||
ice_debug(hw, ICE_DBG_INIT, "Failed to read PFA length.\n");
|
||||
return status;
|
||||
}
|
||||
/* Starting with first TLV after PFA length, iterate through the list
|
||||
* of TLVs to find the requested one.
|
||||
*/
|
||||
next_tlv = pfa_ptr + 1;
|
||||
while (next_tlv < pfa_ptr + pfa_len) {
|
||||
u16 tlv_sub_module_type;
|
||||
u16 tlv_len;
|
||||
|
||||
/* Read TLV type */
|
||||
status = ice_read_sr_word(hw, next_tlv, &tlv_sub_module_type);
|
||||
if (status != ICE_SUCCESS) {
|
||||
ice_debug(hw, ICE_DBG_INIT, "Failed to read TLV type.\n");
|
||||
break;
|
||||
}
|
||||
/* Read TLV length */
|
||||
status = ice_read_sr_word(hw, next_tlv + 1, &tlv_len);
|
||||
if (status != ICE_SUCCESS) {
|
||||
ice_debug(hw, ICE_DBG_INIT, "Failed to read TLV length.\n");
|
||||
break;
|
||||
}
|
||||
if (tlv_sub_module_type == module_type) {
|
||||
if (tlv_len) {
|
||||
*module_tlv = next_tlv;
|
||||
*module_tlv_len = tlv_len;
|
||||
return ICE_SUCCESS;
|
||||
}
|
||||
return ICE_ERR_INVAL_SIZE;
|
||||
}
|
||||
/* Check next TLV, i.e. current TLV pointer + length + 2 words
|
||||
* (for current TLV's type and length)
|
||||
*/
|
||||
next_tlv = next_tlv + tlv_len + 2;
|
||||
}
|
||||
/* Module does not exist */
|
||||
return ICE_ERR_DOES_NOT_EXIST;
|
||||
}
|
||||
|
||||
/**
|
||||
* ice_get_orom_ver_info - Read Option ROM version information
|
||||
* @hw: pointer to the HW struct
|
||||
|
@ -87,6 +87,9 @@ ice_handle_nvm_access(struct ice_hw *hw, struct ice_nvm_access_cmd *cmd,
|
||||
enum ice_status
|
||||
ice_read_flat_nvm(struct ice_hw *hw, u32 offset, u32 *length, u8 *data,
|
||||
bool read_shadow_ram);
|
||||
enum ice_status
|
||||
ice_get_pfa_module_tlv(struct ice_hw *hw, u16 *module_tlv, u16 *module_tlv_len,
|
||||
u16 module_type);
|
||||
enum ice_status ice_init_nvm(struct ice_hw *hw);
|
||||
enum ice_status ice_read_sr_word(struct ice_hw *hw, u16 offset, u16 *data);
|
||||
enum ice_status
|
||||
|
Loading…
x
Reference in New Issue
Block a user