Re: [PATCH net-next v7 03/10] net: psample: skip packet copy if no listeners
From: Aaron Conole
Date: Mon Jul 01 2024 - 14:07:58 EST
Adrian Moreno <amorenoz@xxxxxxxxxx> writes:
> If nobody is listening on the multicast group, generating the sample,
> which involves copying packet data, seems completely unnecessary.
>
> Return fast in this case.
>
> Acked-by: Eelco Chaudron <echaudro@xxxxxxxxxx>
> Reviewed-by: Ido Schimmel <idosch@xxxxxxxxxx>
> Reviewed-by: Simon Horman <horms@xxxxxxxxxx>
> Signed-off-by: Adrian Moreno <amorenoz@xxxxxxxxxx>
> ---
Reviewed-by: Aaron Conole <aconole@xxxxxxxxxx>
> net/psample/psample.c | 4 ++++
> 1 file changed, 4 insertions(+)
>
> diff --git a/net/psample/psample.c b/net/psample/psample.c
> index b37488f426bc..1c76f3e48dcd 100644
> --- a/net/psample/psample.c
> +++ b/net/psample/psample.c
> @@ -376,6 +376,10 @@ void psample_sample_packet(struct psample_group *group, struct sk_buff *skb,
> void *data;
> int ret;
>
> + if (!genl_has_listeners(&psample_nl_family, group->net,
> + PSAMPLE_NL_MCGRP_SAMPLE))
> + return;
> +
> meta_len = (in_ifindex ? nla_total_size(sizeof(u16)) : 0) +
> (out_ifindex ? nla_total_size(sizeof(u16)) : 0) +
> (md->out_tc_valid ? nla_total_size(sizeof(u16)) : 0) +