On Sat May 23, 2026 at 10:58 PM EDT, Suchit Karunakaran wrote:
> Simplify fq_flows_is_empty() by replacing the pop/push based emptiness
> check with a direct call to bpf_list_empty().
> This avoids unnecessary list mutation and simplifies the code while
> preserving correctness.
>
> Signed-off-by: Suchit Karunakaran <[email protected]>
>
> Changes since v1:
> - Removed unused variable node

Saw v1 before v2:

Reviewed-by: Emil Tsalapatis <[email protected]>

> ---
>  tools/testing/selftests/bpf/progs/bpf_qdisc_fq.c | 11 +++--------
>  1 file changed, 3 insertions(+), 8 deletions(-)
>
> diff --git a/tools/testing/selftests/bpf/progs/bpf_qdisc_fq.c 
> b/tools/testing/selftests/bpf/progs/bpf_qdisc_fq.c
> index 1a3233a275c7..8107f5934d2d 100644
> --- a/tools/testing/selftests/bpf/progs/bpf_qdisc_fq.c
> +++ b/tools/testing/selftests/bpf/progs/bpf_qdisc_fq.c
> @@ -196,18 +196,13 @@ fq_flows_remove_front(struct bpf_list_head *head, 
> struct bpf_spin_lock *lock,
>  static bool
>  fq_flows_is_empty(struct bpf_list_head *head, struct bpf_spin_lock *lock)
>  {
> -     struct bpf_list_node *node;
> +     bool empty;
>  
>       bpf_spin_lock(lock);
> -     node = bpf_list_pop_front(head);
> -     if (node) {
> -             bpf_list_push_front(head, node);
> -             bpf_spin_unlock(lock);
> -             return false;
> -     }
> +     empty = bpf_list_empty(head);
>       bpf_spin_unlock(lock);
>  
> -     return true;
> +     return empty;
>  }
>  
>  /* flow->age is used to denote the state of the flow (not-detached, 
> detached, throttled)


Reply via email to