On Mon, 30 Mar 2020 11:11:49 -0500 Christian Deacon wrote: > Hey everyone, > > > I am fairly new to XDP and AF_XDP programming. Therefore, I apologize if > this question sounds silly. > > > To my understanding, an XDP program cannot process outgoing packets > since it doesn't support the TX path. However, I read that AF_XDP > sockets support both receiving and transmitting packets inside the user > space while achieving zero-copy. I am trying to create a C program that > modifies outgoing packets on an interface and trying to do this the > fastest way possible. Unfortunately, I cannot use IPTables for this. > > > I wanted to know if there is any way to use AF_XDP sockets to modify > outgoing packets on an interface. I wasn't sure if the AF_XDP sockets > only support receiving traffic from the XDP program when using the > redirect function or not. > > > If this isn't possible, are there any plans to add TX path support into > XDP in the future? I'm also not sure what else I can do to achieve fast > packet processing for this. I looked into using standard AF_PACKET > sockets. However, since that makes a copy of the packet from the kernel, > I'd assume that's pretty slow and I'd have to find a way to block the > original packets (probably doing something with IPTables). I might also > look into DPDK, but I want to see if using AF_XDP sockets for outgoing > packet processing is possible first because it looks like it's going to > take a while to learn DPDK. > > > Any help is highly appreciated and thank you for your time! Could you give us some more info on the use case? Where do the packets originate? The main advantage of XDP is that it processes packets before the metadata needed by the networking stack is allocated (skb). This is only possible for RX or when packets are redirected from another interface with XDP. All packets which pass through the stack anyway can be efficiently modified using cls_bpf.