blob: 6fd1f0d07e64436a25863880e5d4ba239bc54bb5 [file] [log] [blame]
Harald Weltef9e815b2005-08-09 19:30:24 -07001#ifndef _NFNETLINK_H
2#define _NFNETLINK_H
3#include <linux/types.h>
Patrick McHardydf6fb862007-09-28 14:37:03 -07004#include <linux/netfilter/nfnetlink_compat.h>
Patrick McHardyac6d4392005-08-14 19:29:52 -07005
6enum nfnetlink_groups {
7 NFNLGRP_NONE,
8#define NFNLGRP_NONE NFNLGRP_NONE
9 NFNLGRP_CONNTRACK_NEW,
10#define NFNLGRP_CONNTRACK_NEW NFNLGRP_CONNTRACK_NEW
11 NFNLGRP_CONNTRACK_UPDATE,
12#define NFNLGRP_CONNTRACK_UPDATE NFNLGRP_CONNTRACK_UPDATE
13 NFNLGRP_CONNTRACK_DESTROY,
14#define NFNLGRP_CONNTRACK_DESTROY NFNLGRP_CONNTRACK_DESTROY
15 NFNLGRP_CONNTRACK_EXP_NEW,
16#define NFNLGRP_CONNTRACK_EXP_NEW NFNLGRP_CONNTRACK_EXP_NEW
17 NFNLGRP_CONNTRACK_EXP_UPDATE,
18#define NFNLGRP_CONNTRACK_EXP_UPDATE NFNLGRP_CONNTRACK_EXP_UPDATE
19 NFNLGRP_CONNTRACK_EXP_DESTROY,
20#define NFNLGRP_CONNTRACK_EXP_DESTROY NFNLGRP_CONNTRACK_EXP_DESTROY
21 __NFNLGRP_MAX,
22};
23#define NFNLGRP_MAX (__NFNLGRP_MAX - 1)
Harald Weltef9e815b2005-08-09 19:30:24 -070024
Harald Weltef9e815b2005-08-09 19:30:24 -070025/* General form of address family dependent message.
26 */
27struct nfgenmsg {
Arnd Bergmann60c195c2009-02-26 00:51:43 +010028 __u8 nfgen_family; /* AF_xxx */
29 __u8 version; /* nfnetlink version */
Al Viro98a4a862006-11-08 00:26:51 -080030 __be16 res_id; /* resource id */
Patrick McHardy53e26652006-08-22 00:43:20 -070031};
Harald Weltef9e815b2005-08-09 19:30:24 -070032
Harald Welte080774a2005-08-09 19:32:58 -070033#define NFNETLINK_V0 0
Harald Weltef9e815b2005-08-09 19:30:24 -070034
Harald Weltef9e815b2005-08-09 19:30:24 -070035/* netfilter netlink message types are split in two pieces:
36 * 8 bit subsystem, 8bit operation.
37 */
38
39#define NFNL_SUBSYS_ID(x) ((x & 0xff00) >> 8)
40#define NFNL_MSG_TYPE(x) (x & 0x00ff)
41
Harald Welte0ab43f82005-08-09 19:43:44 -070042/* No enum here, otherwise __stringify() trick of MODULE_ALIAS_NFNL_SUBSYS()
43 * won't work anymore */
44#define NFNL_SUBSYS_NONE 0
45#define NFNL_SUBSYS_CTNETLINK 1
46#define NFNL_SUBSYS_CTNETLINK_EXP 2
47#define NFNL_SUBSYS_QUEUE 3
48#define NFNL_SUBSYS_ULOG 4
Evgeniy Polyakov11eeef42009-06-08 17:01:51 +020049#define NFNL_SUBSYS_OSF 5
Jozsef Kadlecsikf7036512011-02-01 15:20:14 +010050#define NFNL_SUBSYS_IPSET 6
Pablo Neira Ayuso94139022011-12-23 14:19:50 +010051#define NFNL_SUBSYS_ACCT 7
Pablo Neira Ayuso50978462012-02-28 19:13:48 +010052#define NFNL_SUBSYS_CTNETLINK_TIMEOUT 8
53#define NFNL_SUBSYS_COUNT 9
Harald Weltef9e815b2005-08-09 19:30:24 -070054
55#ifdef __KERNEL__
56
Harald Welte080774a2005-08-09 19:32:58 -070057#include <linux/netlink.h>
Harald Weltef9e815b2005-08-09 19:30:24 -070058#include <linux/capability.h>
Patrick McHardydf6fb862007-09-28 14:37:03 -070059#include <net/netlink.h>
Harald Weltef9e815b2005-08-09 19:30:24 -070060
Eric Dumazetd94d9fe2009-11-04 09:50:58 -080061struct nfnl_callback {
Harald Weltef9e815b2005-08-09 19:30:24 -070062 int (*call)(struct sock *nl, struct sk_buff *skb,
Patrick McHardy39938322009-08-25 16:07:58 +020063 const struct nlmsghdr *nlh,
64 const struct nlattr * const cda[]);
Eric Dumazet6b75e3e2011-07-18 16:08:07 +020065 int (*call_rcu)(struct sock *nl, struct sk_buff *skb,
66 const struct nlmsghdr *nlh,
67 const struct nlattr * const cda[]);
Patrick McHardye3730572007-09-28 14:38:52 -070068 const struct nla_policy *policy; /* netlink attribute policy */
69 const u_int16_t attr_count; /* number of nlattr's */
Harald Weltef9e815b2005-08-09 19:30:24 -070070};
71
Eric Dumazetd94d9fe2009-11-04 09:50:58 -080072struct nfnetlink_subsystem {
Harald Weltef9e815b2005-08-09 19:30:24 -070073 const char *name;
Patrick McHardy7c8d4cb2007-09-28 14:15:45 -070074 __u8 subsys_id; /* nfnetlink subsystem ID */
75 __u8 cb_count; /* number of callbacks */
76 const struct nfnl_callback *cb; /* callback for individual types */
Harald Weltef9e815b2005-08-09 19:30:24 -070077};
78
Patrick McHardy7c8d4cb2007-09-28 14:15:45 -070079extern int nfnetlink_subsys_register(const struct nfnetlink_subsystem *n);
80extern int nfnetlink_subsys_unregister(const struct nfnetlink_subsystem *n);
Harald Weltef9e815b2005-08-09 19:30:24 -070081
Alexey Dobriyancd8c20b2010-01-13 16:02:14 +010082extern int nfnetlink_has_listeners(struct net *net, unsigned int group);
83extern int nfnetlink_send(struct sk_buff *skb, struct net *net, u32 pid, unsigned group,
Pablo Neira Ayusoe34d5c12009-06-03 10:32:06 +020084 int echo, gfp_t flags);
Pablo Neira Ayuso37b7ef72010-03-16 13:30:21 +000085extern int nfnetlink_set_err(struct net *net, u32 pid, u32 group, int error);
Alexey Dobriyancd8c20b2010-01-13 16:02:14 +010086extern int nfnetlink_unicast(struct sk_buff *skb, struct net *net, u_int32_t pid, int flags);
Harald Weltef9e815b2005-08-09 19:30:24 -070087
Pablo Neira Ayusoe6a7d3c2008-10-14 11:58:31 -070088extern void nfnl_lock(void);
89extern void nfnl_unlock(void);
90
Harald Welte0ab43f82005-08-09 19:43:44 -070091#define MODULE_ALIAS_NFNL_SUBSYS(subsys) \
92 MODULE_ALIAS("nfnetlink-subsys-" __stringify(subsys))
93
Harald Weltef9e815b2005-08-09 19:30:24 -070094#endif /* __KERNEL__ */
95#endif /* _NFNETLINK_H */