On 02.03, Pablo Neira Ayuso wrote: > On Mon, Mar 02, 2015 at 12:08:05PM +0000, Patrick McHardy wrote: > > On 02.03, Pablo Neira Ayuso wrote: > > > On Mon, Mar 02, 2015 at 11:51:41AM +0000, Patrick McHardy wrote: > > > > I'm looking at the nftables transaction code and wondering about the > > > > semantics of GET operations intermixed with ADD/DEL operations: > > > > > > > > AFAIK there are currently some inconsistencies: > > > > > > > > - new sets get marked as inactive and invisible to GET until the > > > > transaction is supported. So > > > > > > > > ADD set > > > > GET set > > > > > > > > will return ENOENT. > > > > > > These two follow different paths. > > > > > > The ADD is included in the batch, the GET doesn't. So we won't see the > > > object until we have finish processing a full batch. > > > > That's on the userspace side? I didn't notice anything in the kernel > > not handling GET inside a batch. > > [NFT_MSG_NEWRULE] = { > .call_batch = nf_tables_newrule, > ... > [NFT_MSG_GETRULE] = { > .call = nf_tables_getrule, > > Add/del uses .call_batch, get uses .call. Right, I missed that part, thanks. I think it might still make sense to at some point also handle GET inside a transaction, from a nftables user perspective I think its not unreasonable to expect a file containing a list command inside to still be handled atomically. But for now this puts my concerns to rest, thanks :) > > > ADD set > > > --------> batch OK, commit > > > GET set > > > > > > > - Rule GET operations OTOH don't care about the activeness of the rule > > > > at all, so > > > > > > > > DEL rule > > > > GET rule > > > > > > > > will return the rule even though it is actually deleted. > > > > > > > > ADD rule > > > > GET rule > > > > transaction fail > > > > > > > > Will equally return the rule even though it will afterwards not be > > > > present. > > > > > > > > So the general question is how to properly handle this. GET operations > > > > should obviously take activeness into account and not return deleted > > > > objects. > > > > > > You have DUMP_INTR if a get happens while updating any of the lists. > > > > Yeah, I meant the case of non-dump GET operations. > > I see, in this case I think we can signal the process so it knows it's > been fetching an object while an update it happening, but that code is > missing. > > We can probably simplify the existing code by setting the INTR flag if > a commit is happening, both for dump and get. Seems to be fine since normal GET is under the nfnl. As long as GET is not handled within the transaction, things look fine the way they are. -- To unsubscribe from this list: send the line "unsubscribe netfilter-devel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html