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