summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPatrick McHardy <kaber@trash.net>2008-10-23 11:47:08 (GMT)
committerThomas Graf <tgr@plip.localdomain>2008-10-23 11:59:40 (GMT)
commit334f551c5994f7a5a2163fd73ca20d201c7e7bf0 (patch)
treeb82f7236085710dd5e8a733844f68f6d0367d39f
parentcfcfca070355b246028df60da79813f09ed65755 (diff)
downloadlibnl-334f551c5994f7a5a2163fd73ca20d201c7e7bf0.zip
libnl-334f551c5994f7a5a2163fd73ca20d201c7e7bf0.tar.gz
libnl-334f551c5994f7a5a2163fd73ca20d201c7e7bf0.tar.bz2
libnl: nfqueue: add nfqueue specific socket allocation function
commit e92539843a0c7e5116254382626cce226bf2135e Author: Patrick McHardy <kaber@trash.net> Date: Thu Oct 23 13:46:16 2008 +0200 libnl: nfqueue: add nfqueue specific socket allocation function nfqueue users usually send verdict messages from the receive callback. When waiting for ACKs, the receive callback might be called again recursively until the stack blows up. Add a nfqueue specific socket allocation function that automatically disables ACKing for the socket. Signed-off-by: Patrick McHardy <kaber@trash.net>
-rw-r--r--include/netlink/netfilter/queue.h2
-rw-r--r--lib/netfilter/queue.c10
-rw-r--r--src/nf-queue.c5
3 files changed, 16 insertions, 1 deletions
diff --git a/include/netlink/netfilter/queue.h b/include/netlink/netfilter/queue.h
index 491b361..664610d 100644
--- a/include/netlink/netfilter/queue.h
+++ b/include/netlink/netfilter/queue.h
@@ -31,6 +31,8 @@ enum nfnl_queue_copy_mode {
};
/* General */
+extern struct nl_sock * nfnl_queue_socket_alloc(void);
+
extern struct nfnl_queue * nfnl_queue_alloc(void);
extern void nfnl_queue_get(struct nfnl_queue *);
diff --git a/lib/netfilter/queue.c b/lib/netfilter/queue.c
index 8d3c7ce..ff1de0e 100644
--- a/lib/netfilter/queue.c
+++ b/lib/netfilter/queue.c
@@ -24,6 +24,16 @@
#include <netlink/netfilter/nfnl.h>
#include <netlink/netfilter/queue.h>
+struct nl_sock *nfnl_queue_socket_alloc(void)
+{
+ struct nl_sock *nlsk;
+
+ nlsk = nl_socket_alloc();
+ if (nlsk)
+ nl_socket_disable_auto_ack(nlsk);
+ return nlsk;
+}
+
static int send_queue_request(struct nl_sock *sk, struct nl_msg *msg)
{
int err;
diff --git a/src/nf-queue.c b/src/nf-queue.c
index 4e17f70..0ed9e69 100644
--- a/src/nf-queue.c
+++ b/src/nf-queue.c
@@ -47,7 +47,10 @@ int main(int argc, char *argv[])
int err = 1;
int family;
- nf_sock = nlt_alloc_socket();
+ nf_sock = nfnl_queue_socket_alloc();
+ if (nf_sock == NULL)
+ fatal(ENOBUFS, "Unable to allocate netlink socket");
+
nl_disable_sequence_check(nf_sock);
nl_socket_modify_cb(nf_sock, NL_CB_VALID, NL_CB_CUSTOM, event_input, NULL);