![Arnd Bergmann](/assets/img/avatar_default.png)
Netfilter traditionally uses BSD integer types in its interface headers. This changes it to use the Linux strict integer types, like everyone else. Cc: netfilter-devel@vger.kernel.org Signed-off-by: Arnd Bergmann <arnd@arndb.de> Acked-by: David S. Miller <davem@davemloft.net> Signed-off-by: H. Peter Anvin <hpa@linux.intel.com> Signed-off-by: Ingo Molnar <mingo@elte.hu>
76 lines
1.1 KiB
C
76 lines
1.1 KiB
C
#ifndef _XT_POLICY_H
|
|
#define _XT_POLICY_H
|
|
|
|
#include <linux/types.h>
|
|
|
|
#define XT_POLICY_MAX_ELEM 4
|
|
|
|
enum xt_policy_flags
|
|
{
|
|
XT_POLICY_MATCH_IN = 0x1,
|
|
XT_POLICY_MATCH_OUT = 0x2,
|
|
XT_POLICY_MATCH_NONE = 0x4,
|
|
XT_POLICY_MATCH_STRICT = 0x8,
|
|
};
|
|
|
|
enum xt_policy_modes
|
|
{
|
|
XT_POLICY_MODE_TRANSPORT,
|
|
XT_POLICY_MODE_TUNNEL
|
|
};
|
|
|
|
struct xt_policy_spec
|
|
{
|
|
__u8 saddr:1,
|
|
daddr:1,
|
|
proto:1,
|
|
mode:1,
|
|
spi:1,
|
|
reqid:1;
|
|
};
|
|
|
|
#ifndef __KERNEL__
|
|
union xt_policy_addr
|
|
{
|
|
struct in_addr a4;
|
|
struct in6_addr a6;
|
|
};
|
|
#endif
|
|
|
|
struct xt_policy_elem
|
|
{
|
|
union {
|
|
#ifdef __KERNEL__
|
|
struct {
|
|
union nf_inet_addr saddr;
|
|
union nf_inet_addr smask;
|
|
union nf_inet_addr daddr;
|
|
union nf_inet_addr dmask;
|
|
};
|
|
#else
|
|
struct {
|
|
union xt_policy_addr saddr;
|
|
union xt_policy_addr smask;
|
|
union xt_policy_addr daddr;
|
|
union xt_policy_addr dmask;
|
|
};
|
|
#endif
|
|
};
|
|
__be32 spi;
|
|
__u32 reqid;
|
|
__u8 proto;
|
|
__u8 mode;
|
|
|
|
struct xt_policy_spec match;
|
|
struct xt_policy_spec invert;
|
|
};
|
|
|
|
struct xt_policy_info
|
|
{
|
|
struct xt_policy_elem pol[XT_POLICY_MAX_ELEM];
|
|
__u16 flags;
|
|
__u16 len;
|
|
};
|
|
|
|
#endif /* _XT_POLICY_H */
|