11da177e4SLinus Torvalds /* 21da177e4SLinus Torvalds * 31da177e4SLinus Torvalds * Generic internet FLOW. 41da177e4SLinus Torvalds * 51da177e4SLinus Torvalds */ 61da177e4SLinus Torvalds 71da177e4SLinus Torvalds #ifndef _NET_FLOW_H 81da177e4SLinus Torvalds #define _NET_FLOW_H 91da177e4SLinus Torvalds 101da177e4SLinus Torvalds #include <linux/in6.h> 111da177e4SLinus Torvalds #include <asm/atomic.h> 121da177e4SLinus Torvalds 131da177e4SLinus Torvalds struct flowi { 141da177e4SLinus Torvalds int oif; 151da177e4SLinus Torvalds int iif; 1647dcf0cbSThomas Graf __u32 mark; 171da177e4SLinus Torvalds 181da177e4SLinus Torvalds union { 191da177e4SLinus Torvalds struct { 20f2c3fe24SAl Viro __be32 daddr; 21f2c3fe24SAl Viro __be32 saddr; 221da177e4SLinus Torvalds __u8 tos; 231da177e4SLinus Torvalds __u8 scope; 241da177e4SLinus Torvalds } ip4_u; 251da177e4SLinus Torvalds 261da177e4SLinus Torvalds struct { 271da177e4SLinus Torvalds struct in6_addr daddr; 281da177e4SLinus Torvalds struct in6_addr saddr; 2990bcaf7bSAl Viro __be32 flowlabel; 301da177e4SLinus Torvalds } ip6_u; 311da177e4SLinus Torvalds 321da177e4SLinus Torvalds struct { 33c4ea94abSSteven Whitehouse __le16 daddr; 34c4ea94abSSteven Whitehouse __le16 saddr; 351da177e4SLinus Torvalds __u8 scope; 361da177e4SLinus Torvalds } dn_u; 371da177e4SLinus Torvalds } nl_u; 381da177e4SLinus Torvalds #define fld_dst nl_u.dn_u.daddr 391da177e4SLinus Torvalds #define fld_src nl_u.dn_u.saddr 401da177e4SLinus Torvalds #define fld_scope nl_u.dn_u.scope 411da177e4SLinus Torvalds #define fl6_dst nl_u.ip6_u.daddr 421da177e4SLinus Torvalds #define fl6_src nl_u.ip6_u.saddr 431da177e4SLinus Torvalds #define fl6_flowlabel nl_u.ip6_u.flowlabel 441da177e4SLinus Torvalds #define fl4_dst nl_u.ip4_u.daddr 451da177e4SLinus Torvalds #define fl4_src nl_u.ip4_u.saddr 461da177e4SLinus Torvalds #define fl4_tos nl_u.ip4_u.tos 471da177e4SLinus Torvalds #define fl4_scope nl_u.ip4_u.scope 481da177e4SLinus Torvalds 491da177e4SLinus Torvalds __u8 proto; 50a210d01aSJulian Anastasov __u8 flags; 51a210d01aSJulian Anastasov #define FLOWI_FLAG_ANYSRC 0x01 521da177e4SLinus Torvalds union { 531da177e4SLinus Torvalds struct { 54cc939d37SAl Viro __be16 sport; 55cc939d37SAl Viro __be16 dport; 561da177e4SLinus Torvalds } ports; 571da177e4SLinus Torvalds 581da177e4SLinus Torvalds struct { 591da177e4SLinus Torvalds __u8 type; 601da177e4SLinus Torvalds __u8 code; 611da177e4SLinus Torvalds } icmpt; 621da177e4SLinus Torvalds 631da177e4SLinus Torvalds struct { 64c4ea94abSSteven Whitehouse __le16 sport; 65c4ea94abSSteven Whitehouse __le16 dport; 661da177e4SLinus Torvalds } dnports; 671da177e4SLinus Torvalds 684324a174SAl Viro __be32 spi; 692b741653SMasahide NAKAMURA 702b741653SMasahide NAKAMURA struct { 712b741653SMasahide NAKAMURA __u8 type; 722b741653SMasahide NAKAMURA } mht; 731da177e4SLinus Torvalds } uli_u; 741da177e4SLinus Torvalds #define fl_ip_sport uli_u.ports.sport 751da177e4SLinus Torvalds #define fl_ip_dport uli_u.ports.dport 761da177e4SLinus Torvalds #define fl_icmp_type uli_u.icmpt.type 771da177e4SLinus Torvalds #define fl_icmp_code uli_u.icmpt.code 781da177e4SLinus Torvalds #define fl_ipsec_spi uli_u.spi 792b741653SMasahide NAKAMURA #define fl_mh_type uli_u.mht.type 80b6340fcdSVenkat Yekkirala __u32 secid; /* used by xfrm; see secid.txt */ 811da177e4SLinus Torvalds } __attribute__((__aligned__(BITS_PER_LONG/8))); 821da177e4SLinus Torvalds 831da177e4SLinus Torvalds #define FLOW_DIR_IN 0 841da177e4SLinus Torvalds #define FLOW_DIR_OUT 1 851da177e4SLinus Torvalds #define FLOW_DIR_FWD 2 861da177e4SLinus Torvalds 8752479b62SAlexey Dobriyan struct net; 88df71837dSTrent Jaeger struct sock; 89fe1a5f03STimo Teräs struct flow_cache_ops; 901da177e4SLinus Torvalds 91fe1a5f03STimo Teräs struct flow_cache_object { 92fe1a5f03STimo Teräs const struct flow_cache_ops *ops; 93fe1a5f03STimo Teräs }; 94fe1a5f03STimo Teräs 95fe1a5f03STimo Teräs struct flow_cache_ops { 96fe1a5f03STimo Teräs struct flow_cache_object *(*get)(struct flow_cache_object *); 97fe1a5f03STimo Teräs int (*check)(struct flow_cache_object *); 98fe1a5f03STimo Teräs void (*delete)(struct flow_cache_object *); 99fe1a5f03STimo Teräs }; 100fe1a5f03STimo Teräs 101fe1a5f03STimo Teräs typedef struct flow_cache_object *(*flow_resolve_t)( 102fe1a5f03STimo Teräs struct net *net, struct flowi *key, u16 family, 103fe1a5f03STimo Teräs u8 dir, struct flow_cache_object *oldobj, void *ctx); 104fe1a5f03STimo Teräs 105fe1a5f03STimo Teräs extern struct flow_cache_object *flow_cache_lookup( 106fe1a5f03STimo Teräs struct net *net, struct flowi *key, u16 family, 107fe1a5f03STimo Teräs u8 dir, flow_resolve_t resolver, void *ctx); 108fe1a5f03STimo Teräs 1091da177e4SLinus Torvalds extern void flow_cache_flush(void); 1101da177e4SLinus Torvalds extern atomic_t flow_cache_genid; 1111da177e4SLinus Torvalds 112157bfc25SMasahide NAKAMURA static inline int flow_cache_uli_match(struct flowi *fl1, struct flowi *fl2) 113157bfc25SMasahide NAKAMURA { 114157bfc25SMasahide NAKAMURA return (fl1->proto == fl2->proto && 115157bfc25SMasahide NAKAMURA !memcmp(&fl1->uli_u, &fl2->uli_u, sizeof(fl1->uli_u))); 116157bfc25SMasahide NAKAMURA } 117157bfc25SMasahide NAKAMURA 1181da177e4SLinus Torvalds #endif 119