Home | History | Annotate | Download | only in netfilter
      1 /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
      2 #ifndef _NFNETLINK_COMPAT_H
      3 #define _NFNETLINK_COMPAT_H
      4 
      5 #include <linux/types.h>
      6 
      7 #ifndef __KERNEL__
      8 /* Old nfnetlink macros for userspace */
      9 
     10 /* nfnetlink groups: Up to 32 maximum */
     11 #define NF_NETLINK_CONNTRACK_NEW 		0x00000001
     12 #define NF_NETLINK_CONNTRACK_UPDATE		0x00000002
     13 #define NF_NETLINK_CONNTRACK_DESTROY		0x00000004
     14 #define NF_NETLINK_CONNTRACK_EXP_NEW		0x00000008
     15 #define NF_NETLINK_CONNTRACK_EXP_UPDATE		0x00000010
     16 #define NF_NETLINK_CONNTRACK_EXP_DESTROY	0x00000020
     17 
     18 /* Generic structure for encapsulation optional netfilter information.
     19  * It is reminiscent of sockaddr, but with sa_family replaced
     20  * with attribute type.
     21  * ! This should someday be put somewhere generic as now rtnetlink and
     22  * ! nfnetlink use the same attributes methods. - J. Schulist.
     23  */
     24 
     25 struct nfattr {
     26 	__u16 nfa_len;
     27 	__u16 nfa_type;	/* we use 15 bits for the type, and the highest
     28 				 * bit to indicate whether the payload is nested */
     29 };
     30 
     31 /* FIXME: Apart from NFNL_NFA_NESTED shamelessly copy and pasted from
     32  * rtnetlink.h, it's time to put this in a generic file */
     33 
     34 #define NFNL_NFA_NEST	0x8000
     35 #define NFA_TYPE(attr) 	((attr)->nfa_type & 0x7fff)
     36 
     37 #define NFA_ALIGNTO     4
     38 #define NFA_ALIGN(len)	(((len) + NFA_ALIGNTO - 1) & ~(NFA_ALIGNTO - 1))
     39 #define NFA_OK(nfa,len)	((len) > 0 && (nfa)->nfa_len >= sizeof(struct nfattr) \
     40 	&& (nfa)->nfa_len <= (len))
     41 #define NFA_NEXT(nfa,attrlen)	((attrlen) -= NFA_ALIGN((nfa)->nfa_len), \
     42 	(struct nfattr *)(((char *)(nfa)) + NFA_ALIGN((nfa)->nfa_len)))
     43 #define NFA_LENGTH(len)	(NFA_ALIGN(sizeof(struct nfattr)) + (len))
     44 #define NFA_SPACE(len)	NFA_ALIGN(NFA_LENGTH(len))
     45 #define NFA_DATA(nfa)   ((void *)(((char *)(nfa)) + NFA_LENGTH(0)))
     46 #define NFA_PAYLOAD(nfa) ((int)((nfa)->nfa_len) - NFA_LENGTH(0))
     47 #define NFA_NEST(skb, type) \
     48 ({	struct nfattr *__start = (struct nfattr *)skb_tail_pointer(skb); \
     49 	NFA_PUT(skb, (NFNL_NFA_NEST | type), 0, NULL); \
     50 	__start;  })
     51 #define NFA_NEST_END(skb, start) \
     52 ({      (start)->nfa_len = skb_tail_pointer(skb) - (unsigned char *)(start); \
     53         (skb)->len; })
     54 #define NFA_NEST_CANCEL(skb, start) \
     55 ({      if (start) \
     56                 skb_trim(skb, (unsigned char *) (start) - (skb)->data); \
     57         -1; })
     58 
     59 #define NFM_NFA(n)      ((struct nfattr *)(((char *)(n)) \
     60         + NLMSG_ALIGN(sizeof(struct nfgenmsg))))
     61 #define NFM_PAYLOAD(n)  NLMSG_PAYLOAD(n, sizeof(struct nfgenmsg))
     62 
     63 #endif /* ! __KERNEL__ */
     64 #endif /* _NFNETLINK_COMPAT_H */
     65