> -----Original Message-----
> From: Intel-wired-lan <[email protected]> On Behalf
> Of Alok Tiwari
> Sent: Friday, November 7, 2025 5:10 PM
> To: Kitszel, Przemyslaw <[email protected]>; Lobakin,
> Aleksander <[email protected]>; Nguyen, Anthony L
> <[email protected]>; [email protected]; [email protected];
> [email protected]; [email protected]; [email protected];
> [email protected]; [email protected];
> [email protected]
> Cc: [email protected]; [email protected]
> Subject: [Intel-wired-lan] [PATCH net] i40e: fix incorrect src_ip
> checks and memcpy sizes in cloud filter
>
If you let me, I'd propose the title:
i40e: fix src IP mask checks and memcpy argument names in cloud filter
> Fix following issues in the IPv4 and IPv6 cloud filter handling logic
> in both the add and delete paths:
>
> - The source-IP mask check incorrectly compares mask.src_ip[0] against
> tcf.dst_ip[0]. Update it to compare against tcf.src_ip[0]. This
> likely
> goes unnoticed because the check is in an "else if" path that only
> executes when dst_ip is not set, most cloud filter use cases focus
> on
> destination-IP matching, and the buggy condition can accidentally
> evaluate true in some cases.
>
> - memcpy() for the IPv4 source address incorrectly uses
> ARRAY_SIZE(tcf.dst_ip) instead of ARRAY_SIZE(tcf.src_ip), although
> both arrays are the same size.
>
> - In the IPv6 delete path, memcmp() uses sizeof(src_ip6) when
> comparing
> dst_ip6 fields. Replace this with sizeof(dst_ip6) to make the intent
> explicit, even though both fields are struct in6_addr.
>
> Fixes: e284fc280473 ("i40e: Add and delete cloud filter")
> Signed-off-by: Alok Tiwari <[email protected]>
> ---
> drivers/net/ethernet/intel/i40e/i40e_virtchnl_pf.c | 10 +++++-----
> 1 file changed, 5 insertions(+), 5 deletions(-)
>
> diff --git a/drivers/net/ethernet/intel/i40e/i40e_virtchnl_pf.c
> b/drivers/net/ethernet/intel/i40e/i40e_virtchnl_pf.c
> index 081a4526a2f0..c90cc0139986 100644
> --- a/drivers/net/ethernet/intel/i40e/i40e_virtchnl_pf.c
> +++ b/drivers/net/ethernet/intel/i40e/i40e_virtchnl_pf.c
> @@ -3819,9 +3819,9 @@ static int i40e_vc_del_cloud_filter(struct
> i40e_vf *vf, u8 *msg)
> if (mask.dst_ip[0] & tcf.dst_ip[0])
> memcpy(&cfilter.ip.v4.dst_ip, tcf.dst_ip,
> ARRAY_SIZE(tcf.dst_ip));
> - else if (mask.src_ip[0] & tcf.dst_ip[0])
> + else if (mask.src_ip[0] & tcf.src_ip[0])
> memcpy(&cfilter.ip.v4.src_ip, tcf.src_ip,
> - ARRAY_SIZE(tcf.dst_ip));
> + ARRAY_SIZE(tcf.src_ip));
Please consider the sizeof(field) tweak for memcpy to preempt review nits.
- memcpy(&cfilter.ip.v4.dst_ip, tcf.dst_ip, ARRAY_SIZE(tcf.dst_ip));
+ memcpy(&cfilter.ip.v4.dst_ip, tcf.dst_ip, sizeof(cfilter.ip.v4.dst_ip));
- memcpy(&cfilter.ip.v4.src_ip, tcf.src_ip, ARRAY_SIZE(tcf.src_ip));
+ memcpy(&cfilter.ip.v4.src_ip, tcf.src_ip, sizeof(cfilter.ip.v4.src_ip));
You have my RB:
Reviewed-by: Aleksandr Loktionov <[email protected]>
> break;
> case VIRTCHNL_TCP_V6_FLOW:
> cfilter.n_proto = ETH_P_IPV6;
> @@ -3876,7 +3876,7 @@ static int i40e_vc_del_cloud_filter(struct
> i40e_vf *vf, u8 *msg)
> /* for ipv6, mask is set for all sixteen bytes (4 words)
> */
> if (cfilter.n_proto == ETH_P_IPV6 && mask.dst_ip[3])
> if (memcmp(&cfilter.ip.v6.dst_ip6, &cf-
> >ip.v6.dst_ip6,
> - sizeof(cfilter.ip.v6.src_ip6)))
> + sizeof(cfilter.ip.v6.dst_ip6)))
> continue;
> if (mask.vlan_id)
> if (cfilter.vlan_id != cf->vlan_id)
> @@ -3965,9 +3965,9 @@ static int i40e_vc_add_cloud_filter(struct
> i40e_vf *vf, u8 *msg)
> if (mask.dst_ip[0] & tcf.dst_ip[0])
> memcpy(&cfilter->ip.v4.dst_ip, tcf.dst_ip,
> ARRAY_SIZE(tcf.dst_ip));
> - else if (mask.src_ip[0] & tcf.dst_ip[0])
> + else if (mask.src_ip[0] & tcf.src_ip[0])
> memcpy(&cfilter->ip.v4.src_ip, tcf.src_ip,
> - ARRAY_SIZE(tcf.dst_ip));
> + ARRAY_SIZE(tcf.src_ip));
> break;
> case VIRTCHNL_TCP_V6_FLOW:
> cfilter->n_proto = ETH_P_IPV6;
> --
> 2.50.1