summaryrefslogtreecommitdiff
path: root/include/external.h
diff options
context:
space:
mode:
authorAlexander Wirt <formorer@debian.org>2012-06-03 08:49:55 +0200
committerAlexander Wirt <formorer@debian.org>2012-06-03 08:49:55 +0200
commitceecc8855af313c14e8a164f1cd0399716174398 (patch)
tree0d58f5cf7075dea5ff7ddeff6f9a3c89d9eb6352 /include/external.h
parent10f2c00aa6ef875e7998838c200681c6ea5eeebe (diff)
parentea27bb406e3d8fe9466ba274af38e6f540ff5bfc (diff)
downloadconntrack-tools-ceecc8855af313c14e8a164f1cd0399716174398.tar.gz
conntrack-tools-ceecc8855af313c14e8a164f1cd0399716174398.zip
Merge tag 'upstream/1.2.1'
Upstream version 1.2.1
Diffstat (limited to 'include/external.h')
-rw-r--r--include/external.h37
1 files changed, 37 insertions, 0 deletions
diff --git a/include/external.h b/include/external.h
new file mode 100644
index 0000000..70f0c5c
--- /dev/null
+++ b/include/external.h
@@ -0,0 +1,37 @@
+#ifndef _EXTERNAL_H_
+#define _EXTERNAL_H_
+
+struct nf_conntrack;
+
+struct external_handler {
+ int (*init)(void);
+ void (*close)(void);
+
+ struct {
+ void (*new)(struct nf_conntrack *ct);
+ void (*upd)(struct nf_conntrack *ct);
+ void (*del)(struct nf_conntrack *ct);
+
+ void (*dump)(int fd, int type);
+ void (*flush)(void);
+ int (*commit)(struct nfct_handle *h, int fd);
+ void (*stats)(int fd);
+ void (*stats_ext)(int fd);
+ } ct;
+ struct {
+ void (*new)(struct nf_expect *exp);
+ void (*upd)(struct nf_expect *exp);
+ void (*del)(struct nf_expect *exp);
+
+ void (*dump)(int fd, int type);
+ void (*flush)(void);
+ int (*commit)(struct nfct_handle *h, int fd);
+ void (*stats)(int fd);
+ void (*stats_ext)(int fd);
+ } exp;
+};
+
+extern struct external_handler external_cache;
+extern struct external_handler external_inject;
+
+#endif