• Mina Almasry's avatar
    netdev: support binding dma-buf to netdevice · 170aafe3
    Mina Almasry authored
    Add a netdev_dmabuf_binding struct which represents the
    dma-buf-to-netdevice binding. The netlink API will bind the dma-buf to
    rx queues on the netdevice. On the binding, the dma_buf_attach
    & dma_buf_map_attachment will occur. The entries in the sg_table from
    mapping will be inserted into a genpool to make it ready
    for allocation.
    
    The chunks in the genpool are owned by a dmabuf_chunk_owner struct which
    holds the dma-buf offset of the base of the chunk and the dma_addr of
    the chunk. Both are needed to use allocations that come from this chunk.
    
    We create a new type that represents an allocation from the genpool:
    net_iov. We setup the net_iov allocation size in the
    genpool to PAGE_SIZE for simplicity: to match the PAGE_SIZE normally
    allocated by the page pool and given to the drivers.
    
    The user can unbind the dmabuf from the netdevice by closing the netlink
    socket that established the binding. We do this so that the binding is
    automatically unbound even if the userspace process crashes.
    
    The binding and unbinding leaves an indicator in struct netdev_rx_queue
    that the given queue is bound, and the binding is actuated by resetting
    the rx queue using the queue API.
    
    The netdev_dmabuf_binding struct is refcounted, and releases its
    resources only when all the refs are released.
    Signed-off-by: default avatarWillem de Bruijn <willemb@google.com>
    Signed-off-by: default avatarKaiyuan Zhang <kaiyuanz@google.com>
    Signed-off-by: default avatarMina Almasry <almasrymina@google.com>
    Reviewed-by: Pavel Begunkov <asml.silence@gmail.com> # excluding netlink
    Acked-by: default avatarDaniel Vetter <daniel.vetter@ffwll.ch>
    Reviewed-by: default avatarJakub Kicinski <kuba@kernel.org>
    Link: https://patch.msgid.link/20240910171458.219195-4-almasrymina@google.comSigned-off-by: default avatarJakub Kicinski <kuba@kernel.org>
    170aafe3
xsk_buff_pool.c 15.2 KB