]> www.infradead.org Git - users/hch/dma-mapping.git/commitdiff
netfilter: nfnetlink: Handle ACK flags for batch messages
authorDonald Hunter <donald.hunter@gmail.com>
Thu, 18 Apr 2024 10:47:37 +0000 (11:47 +0100)
committerJakub Kicinski <kuba@kernel.org>
Tue, 23 Apr 2024 00:20:42 +0000 (17:20 -0700)
The NLM_F_ACK flag is ignored for nfnetlink batch begin and end
messages. This is a problem for ynl which wants to receive an ack for
every message it sends, not just the commands in between the begin/end
messages.

Add processing for ACKs for begin/end messages and provide responses
when requested.

I have checked that iproute2, pyroute2 and systemd are unaffected by
this change since none of them use NLM_F_ACK for batch begin/end.

Signed-off-by: Donald Hunter <donald.hunter@gmail.com>
Link: https://lore.kernel.org/r/20240418104737.77914-5-donald.hunter@gmail.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
net/netfilter/nfnetlink.c

index c9fbe0f707b5f9b2f84f717ee5e513af9621243c..4abf660c7baff01a361edaa8392edf2fac48f340 100644 (file)
@@ -427,6 +427,9 @@ replay_abort:
 
        nfnl_unlock(subsys_id);
 
+       if (nlh->nlmsg_flags & NLM_F_ACK)
+               nfnl_err_add(&err_list, nlh, 0, &extack);
+
        while (skb->len >= nlmsg_total_size(0)) {
                int msglen, type;
 
@@ -573,6 +576,8 @@ done:
                } else if (err) {
                        ss->abort(net, oskb, NFNL_ABORT_NONE);
                        netlink_ack(oskb, nlmsg_hdr(oskb), err, NULL);
+               } else if (nlh->nlmsg_flags & NLM_F_ACK) {
+                       nfnl_err_add(&err_list, nlh, 0, &extack);
                }
        } else {
                enum nfnl_abort_action abort_action;