On Tue, 28 Apr 2026 15:42:04 -0700 Bobby Eshleman wrote:
>       shinfo = skb_shinfo(skb);
> +     if (shinfo->nr_frags == 0)
> +             goto out;

Feels tempting to cover the NETMEM_TX_NO_DMA / NETMEM_TX_NONE
cases here before we even look at the frags?

> -     if (shinfo->nr_frags > 0) {
> -             niov = netmem_to_net_iov(skb_frag_netmem(&shinfo->frags[0]));
> -             if (net_is_devmem_iov(niov) &&
> -                 READ_ONCE(net_devmem_iov_binding(niov)->dev) != dev)
> +     niov = netmem_to_net_iov(skb_frag_netmem(&shinfo->frags[0]));
> +     if (!net_is_devmem_iov(niov))
> +             goto out;
> +
> +     binding = net_devmem_iov_binding(niov);
> +
> +     switch (dev->netmem_tx) {
> +     case NETMEM_TX_DMA:
> +             if (READ_ONCE(binding->dev) != dev)
>                       goto out_free;
> +             break;
> +     case NETMEM_TX_NO_DMA:
> +             break;
> +     default: /* NETMEM_TX_NONE */
> +             goto out_free;
>       }

Reply via email to