Commit 8cd8a6b1 authored by Jacob Keller's avatar Jacob Keller Committed by Tony Nguyen

ice: move VF overflow message count into struct ice_mbx_vf_info

The ice driver has some logic in ice_vf_mbx.c used to detect potentially
malicious VF behavior with regards to overflowing the PF mailbox. This
logic currently stores message counts in struct ice_mbx_vf_counter.vf_cntr
as an array. This array is allocated during initialization with
ice_mbx_init_snapshot.

This logic makes sense for SR-IOV where all VFs are allocated at once up
front. However, in the future with Scalable IOV this logic will not work.
VFs can be added and removed dynamically. We could try to keep the vf_cntr
array for the maximum possible number of VFs, but this is a waste of
memory.

Use the recently introduced struct ice_mbx_vf_info structure to store the
message count. Pass a pointer to the mbx_info for a VF instead of using its
VF ID. Replace the array of VF message counts with a linked list that
tracks all currently active mailbox tracking info structures.
Signed-off-by: default avatarJacob Keller <jacob.e.keller@intel.com>
Reviewed-by: default avatarMichal Swiatkowski <michal.swiatkowski@linux.intel.com>
Tested-by: default avatarMarek Szlosek <marek.szlosek@intel.com>
Signed-off-by: default avatarTony Nguyen <anthony.l.nguyen@intel.com>
parent e4eaf893
...@@ -204,8 +204,7 @@ void ice_free_vfs(struct ice_pf *pf) ...@@ -204,8 +204,7 @@ void ice_free_vfs(struct ice_pf *pf)
} }
/* clear malicious info since the VF is getting released */ /* clear malicious info since the VF is getting released */
ice_mbx_clear_malvf(&hw->mbx_snapshot, vf->vf_id, list_del(&vf->mbx_info.list_entry);
&vf->mbx_info);
mutex_unlock(&vf->cfg_lock); mutex_unlock(&vf->cfg_lock);
} }
...@@ -1025,9 +1024,7 @@ int ice_sriov_configure(struct pci_dev *pdev, int num_vfs) ...@@ -1025,9 +1024,7 @@ int ice_sriov_configure(struct pci_dev *pdev, int num_vfs)
return -EBUSY; return -EBUSY;
} }
err = ice_mbx_init_snapshot(&pf->hw, num_vfs); ice_mbx_init_snapshot(&pf->hw);
if (err)
return err;
err = ice_pci_sriov_ena(pf, num_vfs); err = ice_pci_sriov_ena(pf, num_vfs);
if (err) { if (err) {
...@@ -1818,7 +1815,7 @@ ice_is_malicious_vf(struct ice_pf *pf, struct ice_rq_event_info *event, ...@@ -1818,7 +1815,7 @@ ice_is_malicious_vf(struct ice_pf *pf, struct ice_rq_event_info *event,
mbxdata.async_watermark_val = ICE_MBX_OVERFLOW_WATERMARK; mbxdata.async_watermark_val = ICE_MBX_OVERFLOW_WATERMARK;
/* check to see if we have a malicious VF */ /* check to see if we have a malicious VF */
status = ice_mbx_vf_state_handler(&pf->hw, &mbxdata, vf_id, &malvf); status = ice_mbx_vf_state_handler(&pf->hw, &mbxdata, &vf->mbx_info, &malvf);
if (status) if (status)
goto out_put_vf; goto out_put_vf;
......
...@@ -784,20 +784,14 @@ struct ice_mbx_snap_buffer_data { ...@@ -784,20 +784,14 @@ struct ice_mbx_snap_buffer_data {
u16 max_num_msgs_mbx; u16 max_num_msgs_mbx;
}; };
/* Structure to track messages sent by VFs on mailbox:
* 1. vf_cntr: a counter array of VFs to track the number of
* asynchronous messages sent by each VF
* 2. vfcntr_len: number of entries in VF counter array
*/
struct ice_mbx_vf_counter {
u32 *vf_cntr;
u32 vfcntr_len;
};
/* Structure used to track a single VF's messages on the mailbox: /* Structure used to track a single VF's messages on the mailbox:
* 1. malicious: whether this VF has been detected as malicious before * 1. list_entry: linked list entry node
* 2. msg_count: the number of asynchronous messages sent by this VF
* 3. malicious: whether this VF has been detected as malicious before
*/ */
struct ice_mbx_vf_info { struct ice_mbx_vf_info {
struct list_head list_entry;
u32 msg_count;
u8 malicious : 1; u8 malicious : 1;
}; };
...@@ -806,7 +800,7 @@ struct ice_mbx_vf_info { ...@@ -806,7 +800,7 @@ struct ice_mbx_vf_info {
*/ */
struct ice_mbx_snapshot { struct ice_mbx_snapshot {
struct ice_mbx_snap_buffer_data mbx_buf; struct ice_mbx_snap_buffer_data mbx_buf;
struct ice_mbx_vf_counter mbx_vf; struct list_head mbx_vf;
}; };
/* Structure to hold data to be used for capturing or updating a /* Structure to hold data to be used for capturing or updating a
......
...@@ -496,8 +496,7 @@ void ice_reset_all_vfs(struct ice_pf *pf) ...@@ -496,8 +496,7 @@ void ice_reset_all_vfs(struct ice_pf *pf)
/* clear all malicious info if the VFs are getting reset */ /* clear all malicious info if the VFs are getting reset */
ice_for_each_vf(pf, bkt, vf) ice_for_each_vf(pf, bkt, vf)
ice_mbx_clear_malvf(&hw->mbx_snapshot, vf->vf_id, ice_mbx_clear_malvf(&vf->mbx_info);
&vf->mbx_info);
/* If VFs have been disabled, there is no need to reset */ /* If VFs have been disabled, there is no need to reset */
if (test_and_set_bit(ICE_VF_DIS, pf->state)) { if (test_and_set_bit(ICE_VF_DIS, pf->state)) {
...@@ -599,12 +598,10 @@ int ice_reset_vf(struct ice_vf *vf, u32 flags) ...@@ -599,12 +598,10 @@ int ice_reset_vf(struct ice_vf *vf, u32 flags)
struct ice_pf *pf = vf->pf; struct ice_pf *pf = vf->pf;
struct ice_vsi *vsi; struct ice_vsi *vsi;
struct device *dev; struct device *dev;
struct ice_hw *hw;
int err = 0; int err = 0;
bool rsd; bool rsd;
dev = ice_pf_to_dev(pf); dev = ice_pf_to_dev(pf);
hw = &pf->hw;
if (flags & ICE_VF_RESET_NOTIFY) if (flags & ICE_VF_RESET_NOTIFY)
ice_notify_vf_reset(vf); ice_notify_vf_reset(vf);
...@@ -703,7 +700,7 @@ int ice_reset_vf(struct ice_vf *vf, u32 flags) ...@@ -703,7 +700,7 @@ int ice_reset_vf(struct ice_vf *vf, u32 flags)
ice_eswitch_replay_vf_mac_rule(vf); ice_eswitch_replay_vf_mac_rule(vf);
/* if the VF has been reset allow it to come up again */ /* if the VF has been reset allow it to come up again */
ice_mbx_clear_malvf(&hw->mbx_snapshot, vf->vf_id, &vf->mbx_info); ice_mbx_clear_malvf(&vf->mbx_info);
out_unlock: out_unlock:
if (flags & ICE_VF_RESET_LOCK) if (flags & ICE_VF_RESET_LOCK)
......
This diff is collapsed.
...@@ -21,12 +21,10 @@ ice_aq_send_msg_to_vf(struct ice_hw *hw, u16 vfid, u32 v_opcode, u32 v_retval, ...@@ -21,12 +21,10 @@ ice_aq_send_msg_to_vf(struct ice_hw *hw, u16 vfid, u32 v_opcode, u32 v_retval,
u32 ice_conv_link_speed_to_virtchnl(bool adv_link_support, u16 link_speed); u32 ice_conv_link_speed_to_virtchnl(bool adv_link_support, u16 link_speed);
int int
ice_mbx_vf_state_handler(struct ice_hw *hw, struct ice_mbx_data *mbx_data, ice_mbx_vf_state_handler(struct ice_hw *hw, struct ice_mbx_data *mbx_data,
u16 vf_id, bool *is_mal_vf); struct ice_mbx_vf_info *vf_info, bool *is_mal_vf);
void void ice_mbx_clear_malvf(struct ice_mbx_vf_info *vf_info);
ice_mbx_clear_malvf(struct ice_mbx_snapshot *snap, u16 vf_id,
struct ice_mbx_vf_info *vf_info);
void ice_mbx_init_vf_info(struct ice_hw *hw, struct ice_mbx_vf_info *vf_info); void ice_mbx_init_vf_info(struct ice_hw *hw, struct ice_mbx_vf_info *vf_info);
int ice_mbx_init_snapshot(struct ice_hw *hw, u16 vf_count); void ice_mbx_init_snapshot(struct ice_hw *hw);
void ice_mbx_deinit_snapshot(struct ice_hw *hw); void ice_mbx_deinit_snapshot(struct ice_hw *hw);
int int
ice_mbx_report_malvf(struct ice_hw *hw, struct ice_mbx_vf_info *vf_info, ice_mbx_report_malvf(struct ice_hw *hw, struct ice_mbx_vf_info *vf_info,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment