ice: Fix FW version formatting in dmesg
The FW build id is currently being displayed as an int which doesn't make sense. Instead display FW build id as a hex value. Also add other useful information to the output such as NVM version, API patch info, and FW build hash. Signed-off-by: Lukasz Czapnik <lukasz.czapnik@intel.com> Signed-off-by: Tony Nguyen <anthony.l.nguyen@intel.com> Tested-by: Andrew Bowers <andrewx.bowers@intel.com> Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
This commit is contained in:
parent
e3710a01a8
commit
870f805e97
@ -53,7 +53,6 @@ extern const char ice_drv_ver[];
|
||||
|
||||
#define ICE_DFLT_TRAFFIC_CLASS BIT(0)
|
||||
#define ICE_INT_NAME_STR_LEN (IFNAMSIZ + 16)
|
||||
#define ICE_ETHTOOL_FWVER_LEN 32
|
||||
#define ICE_AQ_LEN 64
|
||||
#define ICE_MBXSQ_LEN 64
|
||||
#define ICE_MBXRQ_LEN 512
|
||||
|
@ -728,6 +728,29 @@ static void ice_get_itr_intrl_gran(struct ice_hw *hw)
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* ice_get_nvm_version - get cached NVM version data
|
||||
* @hw: pointer to the hardware structure
|
||||
* @oem_ver: 8 bit NVM version
|
||||
* @oem_build: 16 bit NVM build number
|
||||
* @oem_patch: 8 NVM patch number
|
||||
* @ver_hi: high 16 bits of the NVM version
|
||||
* @ver_lo: low 16 bits of the NVM version
|
||||
*/
|
||||
void
|
||||
ice_get_nvm_version(struct ice_hw *hw, u8 *oem_ver, u16 *oem_build,
|
||||
u8 *oem_patch, u8 *ver_hi, u8 *ver_lo)
|
||||
{
|
||||
struct ice_nvm_info *nvm = &hw->nvm;
|
||||
|
||||
*oem_ver = (u8)((nvm->oem_ver & ICE_OEM_VER_MASK) >> ICE_OEM_VER_SHIFT);
|
||||
*oem_patch = (u8)(nvm->oem_ver & ICE_OEM_VER_PATCH_MASK);
|
||||
*oem_build = (u16)((nvm->oem_ver & ICE_OEM_VER_BUILD_MASK) >>
|
||||
ICE_OEM_VER_BUILD_SHIFT);
|
||||
*ver_hi = (nvm->ver & ICE_NVM_VER_HI_MASK) >> ICE_NVM_VER_HI_SHIFT;
|
||||
*ver_lo = (nvm->ver & ICE_NVM_VER_LO_MASK) >> ICE_NVM_VER_LO_SHIFT;
|
||||
}
|
||||
|
||||
/**
|
||||
* ice_init_hw - main hardware initialization routine
|
||||
* @hw: pointer to the hardware structure
|
||||
|
@ -133,6 +133,9 @@ ice_stat_update40(struct ice_hw *hw, u32 reg, bool prev_stat_loaded,
|
||||
void
|
||||
ice_stat_update32(struct ice_hw *hw, u32 reg, bool prev_stat_loaded,
|
||||
u64 *prev_stat, u64 *cur_stat);
|
||||
void
|
||||
ice_get_nvm_version(struct ice_hw *hw, u8 *oem_ver, u16 *oem_build,
|
||||
u8 *oem_patch, u8 *ver_hi, u8 *ver_lo);
|
||||
enum ice_status
|
||||
ice_sched_query_elem(struct ice_hw *hw, u32 node_teid,
|
||||
struct ice_aqc_get_elem *buf);
|
||||
|
@ -160,31 +160,6 @@ static const struct ice_priv_flag ice_gstrings_priv_flags[] = {
|
||||
|
||||
#define ICE_PRIV_FLAG_ARRAY_SIZE ARRAY_SIZE(ice_gstrings_priv_flags)
|
||||
|
||||
/**
|
||||
* ice_nvm_version_str - format the NVM version strings
|
||||
* @hw: ptr to the hardware info
|
||||
*/
|
||||
static char *ice_nvm_version_str(struct ice_hw *hw)
|
||||
{
|
||||
static char buf[ICE_ETHTOOL_FWVER_LEN];
|
||||
u8 ver, patch;
|
||||
u32 full_ver;
|
||||
u16 build;
|
||||
|
||||
full_ver = hw->nvm.oem_ver;
|
||||
ver = (u8)((full_ver & ICE_OEM_VER_MASK) >> ICE_OEM_VER_SHIFT);
|
||||
build = (u16)((full_ver & ICE_OEM_VER_BUILD_MASK) >>
|
||||
ICE_OEM_VER_BUILD_SHIFT);
|
||||
patch = (u8)(full_ver & ICE_OEM_VER_PATCH_MASK);
|
||||
|
||||
snprintf(buf, sizeof(buf), "%x.%02x 0x%x %d.%d.%d",
|
||||
(hw->nvm.ver & ICE_NVM_VER_HI_MASK) >> ICE_NVM_VER_HI_SHIFT,
|
||||
(hw->nvm.ver & ICE_NVM_VER_LO_MASK) >> ICE_NVM_VER_LO_SHIFT,
|
||||
hw->nvm.eetrack, ver, build, patch);
|
||||
|
||||
return buf;
|
||||
}
|
||||
|
||||
static void
|
||||
ice_get_drvinfo(struct net_device *netdev, struct ethtool_drvinfo *drvinfo)
|
||||
{
|
||||
|
@ -3275,6 +3275,25 @@ out:
|
||||
}
|
||||
#endif /* CONFIG_DCB */
|
||||
|
||||
/**
|
||||
* ice_nvm_version_str - format the NVM version strings
|
||||
* @hw: ptr to the hardware info
|
||||
*/
|
||||
char *ice_nvm_version_str(struct ice_hw *hw)
|
||||
{
|
||||
u8 oem_ver, oem_patch, ver_hi, ver_lo;
|
||||
static char buf[ICE_NVM_VER_LEN];
|
||||
u16 oem_build;
|
||||
|
||||
ice_get_nvm_version(hw, &oem_ver, &oem_build, &oem_patch, &ver_hi,
|
||||
&ver_lo);
|
||||
|
||||
snprintf(buf, sizeof(buf), "%x.%02x 0x%x %d.%d.%d", ver_hi, ver_lo,
|
||||
hw->nvm.eetrack, oem_ver, oem_build, oem_patch);
|
||||
|
||||
return buf;
|
||||
}
|
||||
|
||||
/**
|
||||
* ice_vsi_cfg_mac_fltr - Add or remove a MAC address filter for a VSI
|
||||
* @vsi: the VSI being configured MAC filter
|
||||
|
@ -120,6 +120,8 @@ int ice_vsi_manage_rss_lut(struct ice_vsi *vsi, bool ena);
|
||||
|
||||
u32 ice_intrl_usec_to_reg(u8 intrl, u8 gran);
|
||||
|
||||
char *ice_nvm_version_str(struct ice_hw *hw);
|
||||
|
||||
enum ice_status
|
||||
ice_vsi_cfg_mac_fltr(struct ice_vsi *vsi, const u8 *macaddr, bool set);
|
||||
|
||||
|
@ -2558,9 +2558,10 @@ ice_probe(struct pci_dev *pdev, const struct pci_device_id __always_unused *ent)
|
||||
goto err_exit_unroll;
|
||||
}
|
||||
|
||||
dev_info(dev, "firmware %d.%d.%05d api %d.%d\n",
|
||||
hw->fw_maj_ver, hw->fw_min_ver, hw->fw_build,
|
||||
hw->api_maj_ver, hw->api_min_ver);
|
||||
dev_info(dev, "firmware %d.%d.%d api %d.%d.%d nvm %s build 0x%08x\n",
|
||||
hw->fw_maj_ver, hw->fw_min_ver, hw->fw_patch,
|
||||
hw->api_maj_ver, hw->api_min_ver, hw->api_patch,
|
||||
ice_nvm_version_str(hw), hw->fw_build);
|
||||
|
||||
err = ice_init_pf(pf);
|
||||
if (err) {
|
||||
|
@ -230,6 +230,8 @@ struct ice_nvm_info {
|
||||
u8 blank_nvm_mode; /* is NVM empty (no FW present) */
|
||||
};
|
||||
|
||||
#define ICE_NVM_VER_LEN 32
|
||||
|
||||
/* Max number of port to queue branches w.r.t topology */
|
||||
#define ICE_MAX_TRAFFIC_CLASS 8
|
||||
#define ICE_TXSCHED_MAX_BRANCHES ICE_MAX_TRAFFIC_CLASS
|
||||
|
Loading…
Reference in New Issue
Block a user