Yasuyuki Kozakai | ecfab2c | 2007-07-07 22:23:21 -0700 | [diff] [blame] | 1 | #ifndef _NF_CONNTRACK_EXTEND_H |
| 2 | #define _NF_CONNTRACK_EXTEND_H |
| 3 | |
Tejun Heo | 5a0e3ad | 2010-03-24 17:04:11 +0900 | [diff] [blame] | 4 | #include <linux/slab.h> |
| 5 | |
Yasuyuki Kozakai | ecfab2c | 2007-07-07 22:23:21 -0700 | [diff] [blame] | 6 | #include <net/netfilter/nf_conntrack.h> |
| 7 | |
Eric Dumazet | fd2c3ef | 2009-11-03 03:26:03 +0000 | [diff] [blame] | 8 | enum nf_ct_ext_id { |
Yasuyuki Kozakai | ceceae1 | 2007-07-07 22:23:42 -0700 | [diff] [blame] | 9 | NF_CT_EXT_HELPER, |
Changli Gao | e0e76c8 | 2010-11-15 12:23:24 +0100 | [diff] [blame] | 10 | #if defined(CONFIG_NF_NAT) || defined(CONFIG_NF_NAT_MODULE) |
Yasuyuki Kozakai | 2d59e5c | 2007-07-07 22:24:28 -0700 | [diff] [blame] | 11 | NF_CT_EXT_NAT, |
Changli Gao | e0e76c8 | 2010-11-15 12:23:24 +0100 | [diff] [blame] | 12 | #endif |
Patrick McHardy | 48b1de4 | 2013-08-27 08:50:14 +0200 | [diff] [blame] | 13 | NF_CT_EXT_SEQADJ, |
Krzysztof Piotr Oledzki | 5840157 | 2008-07-21 10:01:34 -0700 | [diff] [blame] | 14 | NF_CT_EXT_ACCT, |
Changli Gao | e0e76c8 | 2010-11-15 12:23:24 +0100 | [diff] [blame] | 15 | #ifdef CONFIG_NF_CONNTRACK_EVENTS |
Pablo Neira Ayuso | a0891aa | 2009-06-13 12:26:29 +0200 | [diff] [blame] | 16 | NF_CT_EXT_ECACHE, |
Changli Gao | e0e76c8 | 2010-11-15 12:23:24 +0100 | [diff] [blame] | 17 | #endif |
| 18 | #ifdef CONFIG_NF_CONNTRACK_ZONES |
Patrick McHardy | 5d0aa2c | 2010-02-15 18:13:33 +0100 | [diff] [blame] | 19 | NF_CT_EXT_ZONE, |
Changli Gao | e0e76c8 | 2010-11-15 12:23:24 +0100 | [diff] [blame] | 20 | #endif |
Pablo Neira Ayuso | a992ca2 | 2011-01-19 16:00:07 +0100 | [diff] [blame] | 21 | #ifdef CONFIG_NF_CONNTRACK_TIMESTAMP |
| 22 | NF_CT_EXT_TSTAMP, |
| 23 | #endif |
Pablo Neira Ayuso | dd70507 | 2012-02-28 23:36:48 +0100 | [diff] [blame] | 24 | #ifdef CONFIG_NF_CONNTRACK_TIMEOUT |
| 25 | NF_CT_EXT_TIMEOUT, |
| 26 | #endif |
Florian Westphal | c539f01 | 2013-01-11 06:30:44 +0000 | [diff] [blame] | 27 | #ifdef CONFIG_NF_CONNTRACK_LABELS |
| 28 | NF_CT_EXT_LABELS, |
| 29 | #endif |
Patrick McHardy | 48b1de4 | 2013-08-27 08:50:14 +0200 | [diff] [blame] | 30 | #if IS_ENABLED(CONFIG_NETFILTER_SYNPROXY) |
| 31 | NF_CT_EXT_SYNPROXY, |
| 32 | #endif |
Yasuyuki Kozakai | ecfab2c | 2007-07-07 22:23:21 -0700 | [diff] [blame] | 33 | NF_CT_EXT_NUM, |
| 34 | }; |
| 35 | |
Yasuyuki Kozakai | ceceae1 | 2007-07-07 22:23:42 -0700 | [diff] [blame] | 36 | #define NF_CT_EXT_HELPER_TYPE struct nf_conn_help |
Yasuyuki Kozakai | 2d59e5c | 2007-07-07 22:24:28 -0700 | [diff] [blame] | 37 | #define NF_CT_EXT_NAT_TYPE struct nf_conn_nat |
Patrick McHardy | 41d73ec | 2013-08-27 08:50:12 +0200 | [diff] [blame] | 38 | #define NF_CT_EXT_SEQADJ_TYPE struct nf_conn_seqadj |
Krzysztof Piotr Oledzki | 5840157 | 2008-07-21 10:01:34 -0700 | [diff] [blame] | 39 | #define NF_CT_EXT_ACCT_TYPE struct nf_conn_counter |
Pablo Neira Ayuso | a0891aa | 2009-06-13 12:26:29 +0200 | [diff] [blame] | 40 | #define NF_CT_EXT_ECACHE_TYPE struct nf_conntrack_ecache |
Patrick McHardy | 5d0aa2c | 2010-02-15 18:13:33 +0100 | [diff] [blame] | 41 | #define NF_CT_EXT_ZONE_TYPE struct nf_conntrack_zone |
Pablo Neira Ayuso | a992ca2 | 2011-01-19 16:00:07 +0100 | [diff] [blame] | 42 | #define NF_CT_EXT_TSTAMP_TYPE struct nf_conn_tstamp |
Pablo Neira Ayuso | dd70507 | 2012-02-28 23:36:48 +0100 | [diff] [blame] | 43 | #define NF_CT_EXT_TIMEOUT_TYPE struct nf_conn_timeout |
Florian Westphal | c539f01 | 2013-01-11 06:30:44 +0000 | [diff] [blame] | 44 | #define NF_CT_EXT_LABELS_TYPE struct nf_conn_labels |
Patrick McHardy | 48b1de4 | 2013-08-27 08:50:14 +0200 | [diff] [blame] | 45 | #define NF_CT_EXT_SYNPROXY_TYPE struct nf_conn_synproxy |
Yasuyuki Kozakai | ceceae1 | 2007-07-07 22:23:42 -0700 | [diff] [blame] | 46 | |
Yasuyuki Kozakai | ecfab2c | 2007-07-07 22:23:21 -0700 | [diff] [blame] | 47 | /* Extensions: optional stuff which isn't permanently in struct. */ |
| 48 | struct nf_ct_ext { |
Patrick McHardy | 68b80f1 | 2008-06-17 15:51:47 -0700 | [diff] [blame] | 49 | struct rcu_head rcu; |
Yasuyuki Kozakai | ecfab2c | 2007-07-07 22:23:21 -0700 | [diff] [blame] | 50 | u8 offset[NF_CT_EXT_NUM]; |
| 51 | u8 len; |
Yasuyuki Kozakai | ecfab2c | 2007-07-07 22:23:21 -0700 | [diff] [blame] | 52 | char data[0]; |
| 53 | }; |
| 54 | |
Changli Gao | ee92d37 | 2010-08-02 17:06:19 +0200 | [diff] [blame] | 55 | static inline bool __nf_ct_ext_exist(const struct nf_ct_ext *ext, u8 id) |
Yasuyuki Kozakai | ecfab2c | 2007-07-07 22:23:21 -0700 | [diff] [blame] | 56 | { |
Changli Gao | ee92d37 | 2010-08-02 17:06:19 +0200 | [diff] [blame] | 57 | return !!ext->offset[id]; |
| 58 | } |
| 59 | |
| 60 | static inline bool nf_ct_ext_exist(const struct nf_conn *ct, u8 id) |
| 61 | { |
| 62 | return (ct->ext && __nf_ct_ext_exist(ct->ext, id)); |
Yasuyuki Kozakai | ecfab2c | 2007-07-07 22:23:21 -0700 | [diff] [blame] | 63 | } |
| 64 | |
| 65 | static inline void *__nf_ct_ext_find(const struct nf_conn *ct, u8 id) |
| 66 | { |
| 67 | if (!nf_ct_ext_exist(ct, id)) |
| 68 | return NULL; |
| 69 | |
| 70 | return (void *)ct->ext + ct->ext->offset[id]; |
| 71 | } |
| 72 | #define nf_ct_ext_find(ext, id) \ |
| 73 | ((id##_TYPE *)__nf_ct_ext_find((ext), (id))) |
| 74 | |
| 75 | /* Destroy all relationships */ |
| 76 | extern void __nf_ct_ext_destroy(struct nf_conn *ct); |
| 77 | static inline void nf_ct_ext_destroy(struct nf_conn *ct) |
| 78 | { |
| 79 | if (ct->ext) |
| 80 | __nf_ct_ext_destroy(ct); |
| 81 | } |
| 82 | |
| 83 | /* Free operation. If you want to free a object referred from private area, |
| 84 | * please implement __nf_ct_ext_free() and call it. |
| 85 | */ |
| 86 | static inline void nf_ct_ext_free(struct nf_conn *ct) |
| 87 | { |
| 88 | if (ct->ext) |
Michal Kubeček | c13a84a | 2013-09-11 10:17:27 +0200 | [diff] [blame^] | 89 | kfree_rcu(ct->ext, rcu); |
Yasuyuki Kozakai | ecfab2c | 2007-07-07 22:23:21 -0700 | [diff] [blame] | 90 | } |
| 91 | |
| 92 | /* Add this type, returns pointer to data or NULL. */ |
Pablo Neira Ayuso | 3cf4c7e | 2012-02-01 16:18:31 +0100 | [diff] [blame] | 93 | void *__nf_ct_ext_add_length(struct nf_conn *ct, enum nf_ct_ext_id id, |
| 94 | size_t var_alloc_len, gfp_t gfp); |
| 95 | |
Yasuyuki Kozakai | ecfab2c | 2007-07-07 22:23:21 -0700 | [diff] [blame] | 96 | #define nf_ct_ext_add(ct, id, gfp) \ |
Pablo Neira Ayuso | 3cf4c7e | 2012-02-01 16:18:31 +0100 | [diff] [blame] | 97 | ((id##_TYPE *)__nf_ct_ext_add_length((ct), (id), 0, (gfp))) |
| 98 | #define nf_ct_ext_add_length(ct, id, len, gfp) \ |
| 99 | ((id##_TYPE *)__nf_ct_ext_add_length((ct), (id), (len), (gfp))) |
Yasuyuki Kozakai | ecfab2c | 2007-07-07 22:23:21 -0700 | [diff] [blame] | 100 | |
| 101 | #define NF_CT_EXT_F_PREALLOC 0x0001 |
| 102 | |
Eric Dumazet | fd2c3ef | 2009-11-03 03:26:03 +0000 | [diff] [blame] | 103 | struct nf_ct_ext_type { |
Yasuyuki Kozakai | ecfab2c | 2007-07-07 22:23:21 -0700 | [diff] [blame] | 104 | /* Destroys relationships (can be NULL). */ |
| 105 | void (*destroy)(struct nf_conn *ct); |
| 106 | /* Called when realloacted (can be NULL). |
| 107 | Contents has already been moved. */ |
Patrick McHardy | 86577c6 | 2008-02-07 17:56:34 -0800 | [diff] [blame] | 108 | void (*move)(void *new, void *old); |
Yasuyuki Kozakai | ecfab2c | 2007-07-07 22:23:21 -0700 | [diff] [blame] | 109 | |
| 110 | enum nf_ct_ext_id id; |
| 111 | |
| 112 | unsigned int flags; |
| 113 | |
| 114 | /* Length and min alignment. */ |
| 115 | u8 len; |
| 116 | u8 align; |
| 117 | /* initial size of nf_ct_ext. */ |
| 118 | u8 alloc_size; |
| 119 | }; |
| 120 | |
| 121 | int nf_ct_extend_register(struct nf_ct_ext_type *type); |
| 122 | void nf_ct_extend_unregister(struct nf_ct_ext_type *type); |
| 123 | #endif /* _NF_CONNTRACK_EXTEND_H */ |