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