Pablo Neira Ayuso <pablo@xxxxxxxxxxxxx> writes: > On Sat, Jun 20, 2015 at 09:08:20AM -0500, Eric W. Biederman wrote: >> Pablo Neira Ayuso <pablo@xxxxxxxxxxxxx> writes: >> >> > On Fri, Jun 19, 2015 at 05:23:37PM -0500, Eric W. Biederman wrote: >> >> >> >> If someone sends packets from one of the netdevice ingress hooks to >> >> the a userspace queue, and then userspace later accepts the packet, >> >> the netfilter code can enter an infinite loop as the list head will >> >> never be found. >> >> >> >> Pass in the saved list_head to avoid this. >> > >> > There is no userspace queueing for netdevice yet, so this can be route >> > through nf-next. Thanks. >> >> *scratches head* the netdevice queueing is in the netfilter core. >> >> netfilter_ingress calls nf_hook_slow. The queuing happens in >> nf_hook_slow if anything returns the verdict queue it. >> >> This patch applies to Linus's tree. >> >> So how in the world does this not need to be ported to 4.1? > > There is no nfnetlink_queue support for the netdev family at this > moment, so this can't be triggered unless you use an out of tree > module. > > I have a patch here to add a static key to disable userspace queueing > per family using a static key so that part would be basically > inactive. > > But if you really want to see this in 4.1, no problem, please just let > me know and I'll pass it to David, as I said it's basically not > resolving any urgent problem so this is not harming. So I have read through the code and I simply do not see anywhere that would prevent code in nft_queue to be called on a per netdevice chain, or where in nfqnl_enqueue_packet we would decided not to queue the packet. Could you please point me to what in the code makes this code path impossible to use? Right now it looks like something that is triggerable in 4.1. Eric -- To unsubscribe from this list: send the line "unsubscribe netfilter-devel" in