mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-17 02:38:22 +07:00
ice: Fix multiple static analyser warnings
This patch fixes the following smatch errors: 1) Fix "odd binop '0x0 & 0xc'" when performing the bitwise-and with a constant value of zero (ICE_AQC_GSET_RSS_LUT_TABLE_SIZE_128_FLAG). Remove a similar bitwise-and with 0 in ice_add_marker_act() and use the right mask ICE_LG_ACT_GENERIC_OFFSET_M in the expression. 2) Fix a similar issue "odd binop '0x0 & 0x1800' in ice_req_irq_msix_misc. 3) Fix "odd binop '0x380000 & 0x7fff8'" in ice_add_marker_act(). Also, use a new define ICE_LG_ACT_GENERIC_OFF_RX_DESC_PROF_IDX instead of magic number '7'. 4) Fix warn: odd binop '0x0 & 0x18' in ice_set_dflt_vsi_ctx() by removing unnecessary logic to explicitly unset bits 3 and 4 in port_vlan_bits. These bits are unset already by the memset on ctxt->info. Reported-by: Dan Carpenter <dan.carpenter@oracle.com> Signed-off-by: Anirudh Venkataramanan <anirudh.venkataramanan@intel.com> Tested-by: Tony Brelinski <tonyx.brelinski@intel.com> Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
This commit is contained in:
parent
0d092f06fa
commit
4381147df9
@ -594,6 +594,7 @@ struct ice_sw_rule_lg_act {
|
|||||||
#define ICE_LG_ACT_GENERIC_OFFSET_M (0x7 << ICE_LG_ACT_GENERIC_OFFSET_S)
|
#define ICE_LG_ACT_GENERIC_OFFSET_M (0x7 << ICE_LG_ACT_GENERIC_OFFSET_S)
|
||||||
#define ICE_LG_ACT_GENERIC_PRIORITY_S 22
|
#define ICE_LG_ACT_GENERIC_PRIORITY_S 22
|
||||||
#define ICE_LG_ACT_GENERIC_PRIORITY_M (0x7 << ICE_LG_ACT_GENERIC_PRIORITY_S)
|
#define ICE_LG_ACT_GENERIC_PRIORITY_M (0x7 << ICE_LG_ACT_GENERIC_PRIORITY_S)
|
||||||
|
#define ICE_LG_ACT_GENERIC_OFF_RX_DESC_PROF_IDX 7
|
||||||
|
|
||||||
/* Action = 7 - Set Stat count */
|
/* Action = 7 - Set Stat count */
|
||||||
#define ICE_LG_ACT_STAT_COUNT 0x7
|
#define ICE_LG_ACT_STAT_COUNT 0x7
|
||||||
|
@ -1619,20 +1619,23 @@ __ice_aq_get_set_rss_lut(struct ice_hw *hw, u16 vsi_id, u8 lut_type, u8 *lut,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* LUT size is only valid for Global and PF table types */
|
/* LUT size is only valid for Global and PF table types */
|
||||||
if (lut_size == ICE_AQC_GSET_RSS_LUT_TABLE_SIZE_128) {
|
switch (lut_size) {
|
||||||
flags |= (ICE_AQC_GSET_RSS_LUT_TABLE_SIZE_128_FLAG <<
|
case ICE_AQC_GSET_RSS_LUT_TABLE_SIZE_128:
|
||||||
ICE_AQC_GSET_RSS_LUT_TABLE_SIZE_S) &
|
break;
|
||||||
ICE_AQC_GSET_RSS_LUT_TABLE_SIZE_M;
|
case ICE_AQC_GSET_RSS_LUT_TABLE_SIZE_512:
|
||||||
} else if (lut_size == ICE_AQC_GSET_RSS_LUT_TABLE_SIZE_512) {
|
|
||||||
flags |= (ICE_AQC_GSET_RSS_LUT_TABLE_SIZE_512_FLAG <<
|
flags |= (ICE_AQC_GSET_RSS_LUT_TABLE_SIZE_512_FLAG <<
|
||||||
ICE_AQC_GSET_RSS_LUT_TABLE_SIZE_S) &
|
ICE_AQC_GSET_RSS_LUT_TABLE_SIZE_S) &
|
||||||
ICE_AQC_GSET_RSS_LUT_TABLE_SIZE_M;
|
ICE_AQC_GSET_RSS_LUT_TABLE_SIZE_M;
|
||||||
} else if ((lut_size == ICE_AQC_GSET_RSS_LUT_TABLE_SIZE_2K) &&
|
break;
|
||||||
(lut_type == ICE_AQC_GSET_RSS_LUT_TABLE_TYPE_PF)) {
|
case ICE_AQC_GSET_RSS_LUT_TABLE_SIZE_2K:
|
||||||
flags |= (ICE_AQC_GSET_RSS_LUT_TABLE_SIZE_2K_FLAG <<
|
if (lut_type == ICE_AQC_GSET_RSS_LUT_TABLE_TYPE_PF) {
|
||||||
ICE_AQC_GSET_RSS_LUT_TABLE_SIZE_S) &
|
flags |= (ICE_AQC_GSET_RSS_LUT_TABLE_SIZE_2K_FLAG <<
|
||||||
ICE_AQC_GSET_RSS_LUT_TABLE_SIZE_M;
|
ICE_AQC_GSET_RSS_LUT_TABLE_SIZE_S) &
|
||||||
} else {
|
ICE_AQC_GSET_RSS_LUT_TABLE_SIZE_M;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
/* fall-through */
|
||||||
|
default:
|
||||||
status = ICE_ERR_PARAM;
|
status = ICE_ERR_PARAM;
|
||||||
goto ice_aq_get_set_rss_lut_exit;
|
goto ice_aq_get_set_rss_lut_exit;
|
||||||
}
|
}
|
||||||
|
@ -1352,14 +1352,13 @@ static void ice_set_dflt_vsi_ctx(struct ice_vsi_ctx *ctxt)
|
|||||||
ctxt->info.sw_flags = ICE_AQ_VSI_SW_FLAG_SRC_PRUNE;
|
ctxt->info.sw_flags = ICE_AQ_VSI_SW_FLAG_SRC_PRUNE;
|
||||||
/* Traffic from VSI can be sent to LAN */
|
/* Traffic from VSI can be sent to LAN */
|
||||||
ctxt->info.sw_flags2 = ICE_AQ_VSI_SW_FLAG_LAN_ENA;
|
ctxt->info.sw_flags2 = ICE_AQ_VSI_SW_FLAG_LAN_ENA;
|
||||||
/* Allow all packets untagged/tagged */
|
/* By default bits 3 and 4 in port_vlan_flags are 0's which results in
|
||||||
|
* legacy behavior (show VLAN, DEI, and UP) in descriptor. Also, allow
|
||||||
|
* all packets untagged/tagged.
|
||||||
|
*/
|
||||||
ctxt->info.port_vlan_flags = ((ICE_AQ_VSI_PVLAN_MODE_ALL &
|
ctxt->info.port_vlan_flags = ((ICE_AQ_VSI_PVLAN_MODE_ALL &
|
||||||
ICE_AQ_VSI_PVLAN_MODE_M) >>
|
ICE_AQ_VSI_PVLAN_MODE_M) >>
|
||||||
ICE_AQ_VSI_PVLAN_MODE_S);
|
ICE_AQ_VSI_PVLAN_MODE_S);
|
||||||
/* Show VLAN/UP from packets in Rx descriptors */
|
|
||||||
ctxt->info.port_vlan_flags |= ((ICE_AQ_VSI_PVLAN_EMOD_STR_BOTH &
|
|
||||||
ICE_AQ_VSI_PVLAN_EMOD_M) >>
|
|
||||||
ICE_AQ_VSI_PVLAN_EMOD_S);
|
|
||||||
/* Have 1:1 UP mapping for both ingress/egress tables */
|
/* Have 1:1 UP mapping for both ingress/egress tables */
|
||||||
table |= ICE_UP_TABLE_TRANSLATE(0, 0);
|
table |= ICE_UP_TABLE_TRANSLATE(0, 0);
|
||||||
table |= ICE_UP_TABLE_TRANSLATE(1, 1);
|
table |= ICE_UP_TABLE_TRANSLATE(1, 1);
|
||||||
@ -2058,15 +2057,13 @@ static int ice_req_irq_msix_misc(struct ice_pf *pf)
|
|||||||
skip_req_irq:
|
skip_req_irq:
|
||||||
ice_ena_misc_vector(pf);
|
ice_ena_misc_vector(pf);
|
||||||
|
|
||||||
val = (pf->oicr_idx & PFINT_OICR_CTL_MSIX_INDX_M) |
|
val = ((pf->oicr_idx & PFINT_OICR_CTL_MSIX_INDX_M) |
|
||||||
(ICE_RX_ITR & PFINT_OICR_CTL_ITR_INDX_M) |
|
PFINT_OICR_CTL_CAUSE_ENA_M);
|
||||||
PFINT_OICR_CTL_CAUSE_ENA_M;
|
|
||||||
wr32(hw, PFINT_OICR_CTL, val);
|
wr32(hw, PFINT_OICR_CTL, val);
|
||||||
|
|
||||||
/* This enables Admin queue Interrupt causes */
|
/* This enables Admin queue Interrupt causes */
|
||||||
val = (pf->oicr_idx & PFINT_FW_CTL_MSIX_INDX_M) |
|
val = ((pf->oicr_idx & PFINT_FW_CTL_MSIX_INDX_M) |
|
||||||
(ICE_RX_ITR & PFINT_FW_CTL_ITR_INDX_M) |
|
PFINT_FW_CTL_CAUSE_ENA_M);
|
||||||
PFINT_FW_CTL_CAUSE_ENA_M;
|
|
||||||
wr32(hw, PFINT_FW_CTL, val);
|
wr32(hw, PFINT_FW_CTL, val);
|
||||||
|
|
||||||
itr_gran = hw->itr_gran_200;
|
itr_gran = hw->itr_gran_200;
|
||||||
|
@ -645,14 +645,14 @@ ice_add_marker_act(struct ice_hw *hw, struct ice_fltr_mgmt_list_entry *m_ent,
|
|||||||
act |= (1 << ICE_LG_ACT_GENERIC_VALUE_S) & ICE_LG_ACT_GENERIC_VALUE_M;
|
act |= (1 << ICE_LG_ACT_GENERIC_VALUE_S) & ICE_LG_ACT_GENERIC_VALUE_M;
|
||||||
lg_act->pdata.lg_act.act[1] = cpu_to_le32(act);
|
lg_act->pdata.lg_act.act[1] = cpu_to_le32(act);
|
||||||
|
|
||||||
act = (7 << ICE_LG_ACT_GENERIC_OFFSET_S) & ICE_LG_ACT_GENERIC_VALUE_M;
|
act = (ICE_LG_ACT_GENERIC_OFF_RX_DESC_PROF_IDX <<
|
||||||
|
ICE_LG_ACT_GENERIC_OFFSET_S) & ICE_LG_ACT_GENERIC_OFFSET_M;
|
||||||
|
|
||||||
/* Third action Marker value */
|
/* Third action Marker value */
|
||||||
act |= ICE_LG_ACT_GENERIC;
|
act |= ICE_LG_ACT_GENERIC;
|
||||||
act |= (sw_marker << ICE_LG_ACT_GENERIC_VALUE_S) &
|
act |= (sw_marker << ICE_LG_ACT_GENERIC_VALUE_S) &
|
||||||
ICE_LG_ACT_GENERIC_VALUE_M;
|
ICE_LG_ACT_GENERIC_VALUE_M;
|
||||||
|
|
||||||
act |= (0 << ICE_LG_ACT_GENERIC_OFFSET_S) & ICE_LG_ACT_GENERIC_VALUE_M;
|
|
||||||
lg_act->pdata.lg_act.act[2] = cpu_to_le32(act);
|
lg_act->pdata.lg_act.act[2] = cpu_to_le32(act);
|
||||||
|
|
||||||
/* call the fill switch rule to fill the lookup tx rx structure */
|
/* call the fill switch rule to fill the lookup tx rx structure */
|
||||||
|
Loading…
Reference in New Issue
Block a user