nf_conntrack_core.h
来自「linux 内核源代码」· C头文件 代码 · 共 91 行
H
91 行
/* * This header is used to share core functionality between the * standalone connection tracking module, and the compatibility layer's use * of connection tracking. * * 16 Dec 2003: Yasuyuki Kozakai @USAGI <yasuyuki.kozakai@toshiba.co.jp> * - generalize L3 protocol dependent part. * * Derived from include/linux/netfiter_ipv4/ip_conntrack_core.h */#ifndef _NF_CONNTRACK_CORE_H#define _NF_CONNTRACK_CORE_H#include <linux/netfilter.h>#include <net/netfilter/nf_conntrack_l3proto.h>#include <net/netfilter/nf_conntrack_l4proto.h>#include <net/netfilter/nf_conntrack_ecache.h>/* This header is used to share core functionality between the standalone connection tracking module, and the compatibility layer's use of connection tracking. */extern unsigned int nf_conntrack_in(int pf, unsigned int hooknum, struct sk_buff *skb);extern int nf_conntrack_init(void);extern void nf_conntrack_cleanup(void);extern int nf_conntrack_proto_init(void);extern void nf_conntrack_proto_fini(void);extern int nf_conntrack_helper_init(void);extern void nf_conntrack_helper_fini(void);struct nf_conntrack_l3proto;extern struct nf_conntrack_l3proto *nf_ct_find_l3proto(u_int16_t pf);/* Like above, but you already have conntrack read lock. */extern struct nf_conntrack_l3proto *__nf_ct_find_l3proto(u_int16_t l3proto);struct nf_conntrack_l4proto;extern intnf_ct_get_tuple(const struct sk_buff *skb, unsigned int nhoff, unsigned int dataoff, u_int16_t l3num, u_int8_t protonum, struct nf_conntrack_tuple *tuple, const struct nf_conntrack_l3proto *l3proto, const struct nf_conntrack_l4proto *l4proto);extern intnf_ct_invert_tuple(struct nf_conntrack_tuple *inverse, const struct nf_conntrack_tuple *orig, const struct nf_conntrack_l3proto *l3proto, const struct nf_conntrack_l4proto *l4proto);/* Find a connection corresponding to a tuple. */extern struct nf_conntrack_tuple_hash *nf_conntrack_find_get(const struct nf_conntrack_tuple *tuple);extern int __nf_conntrack_confirm(struct sk_buff *skb);/* Confirm a connection: returns NF_DROP if packet must be dropped. */static inline int nf_conntrack_confirm(struct sk_buff *skb){ struct nf_conn *ct = (struct nf_conn *)skb->nfct; int ret = NF_ACCEPT; if (ct) { if (!nf_ct_is_confirmed(ct) && !nf_ct_is_dying(ct)) ret = __nf_conntrack_confirm(skb); nf_ct_deliver_cached_events(ct); } return ret;}extern void __nf_conntrack_attach(struct sk_buff *nskb, struct sk_buff *skb);intprint_tuple(struct seq_file *s, const struct nf_conntrack_tuple *tuple, struct nf_conntrack_l3proto *l3proto, struct nf_conntrack_l4proto *proto);extern struct hlist_head *nf_conntrack_hash;extern rwlock_t nf_conntrack_lock ;extern struct hlist_head unconfirmed;#endif /* _NF_CONNTRACK_CORE_H */
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?