]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
i40e: add max boundary check for VF filters
authorLukasz Czapnik <lukasz.czapnik@intel.com>
Wed, 13 Aug 2025 10:45:16 +0000 (12:45 +0200)
committerTony Nguyen <anthony.l.nguyen@intel.com>
Thu, 18 Sep 2025 22:46:29 +0000 (15:46 -0700)
There is no check for max filters that VF can request. Add it.

Fixes: e284fc280473 ("i40e: Add and delete cloud filter")
Cc: stable@vger.kernel.org
Signed-off-by: Lukasz Czapnik <lukasz.czapnik@intel.com>
Reviewed-by: Aleksandr Loktionov <aleksandr.loktionov@intel.com>
Signed-off-by: Przemek Kitszel <przemyslaw.kitszel@intel.com>
Reviewed-by: Simon Horman <horms@kernel.org>
Tested-by: Rafal Romanowski <rafal.romanowski@intel.com>
Signed-off-by: Tony Nguyen <anthony.l.nguyen@intel.com>
drivers/net/ethernet/intel/i40e/i40e_virtchnl_pf.c

index 5ef3dc43a8a07ae9ab05062d5e948dbae0e0dd58..f29941c0034299ba8dc42d75e63ffb9505ea9644 100644 (file)
@@ -3905,6 +3905,8 @@ err:
                                       aq_ret);
 }
 
+#define I40E_MAX_VF_CLOUD_FILTER 0xFF00
+
 /**
  * i40e_vc_add_cloud_filter
  * @vf: pointer to the VF info
@@ -3944,6 +3946,14 @@ static int i40e_vc_add_cloud_filter(struct i40e_vf *vf, u8 *msg)
                goto err_out;
        }
 
+       if (vf->num_cloud_filters >= I40E_MAX_VF_CLOUD_FILTER) {
+               dev_warn(&pf->pdev->dev,
+                        "VF %d: Max number of filters reached, can't apply cloud filter\n",
+                        vf->vf_id);
+               aq_ret = -ENOSPC;
+               goto err_out;
+       }
+
        cfilter = kzalloc(sizeof(*cfilter), GFP_KERNEL);
        if (!cfilter) {
                aq_ret = -ENOMEM;