flow_dissector.h 2.1 KB
Newer Older
1 2
#ifndef _NET_FLOW_DISSECTOR_H
#define _NET_FLOW_DISSECTOR_H
E
Eric Dumazet 已提交
3

4 5 6 7 8 9 10 11 12 13 14 15 16
/* struct flow_keys:
 *	@src: source ip address in case of IPv4
 *	      For IPv6 it contains 32bit hash of src address
 *	@dst: destination ip address in case of IPv4
 *	      For IPv6 it contains 32bit hash of dst address
 *	@ports: port numbers of Transport header
 *		port16[0]: src port number
 *		port16[1]: dst port number
 *	@thoff: Transport header offset
 *	@n_proto: Network header protocol (eg. IPv4/IPv6)
 *	@ip_proto: Transport header protocol (eg. TCP/UDP)
 * All the members, except thoff, are in network byte order.
 */
E
Eric Dumazet 已提交
17
struct flow_keys {
18
	/* (src,dst) must be grouped, in the same way than in IP header */
E
Eric Dumazet 已提交
19 20 21 22 23 24
	__be32 src;
	__be32 dst;
	union {
		__be32 ports;
		__be16 port16[2];
	};
25 26 27
	u16	thoff;
	__be16	n_proto;
	u8	ip_proto;
E
Eric Dumazet 已提交
28 29
};

30
bool __skb_flow_dissect(const struct sk_buff *skb, struct flow_keys *flow,
31
			void *data, __be16 proto, int nhoff, int hlen);
32 33 34

static inline bool skb_flow_dissect(const struct sk_buff *skb,
				    struct flow_keys *flow)
35
{
36
	return __skb_flow_dissect(skb, flow, NULL, 0, 0, 0);
37
}
38

39 40
__be32 __skb_flow_get_ports(const struct sk_buff *skb, int thoff, u8 ip_proto,
			    void *data, int hlen_proto);
41 42 43

static inline __be32 skb_flow_get_ports(const struct sk_buff *skb,
					int thoff, u8 ip_proto)
44 45 46
{
	return __skb_flow_get_ports(skb, thoff, ip_proto, NULL, 0);
}
47

48
u32 flow_hash_from_keys(struct flow_keys *keys);
49
void __skb_get_hash(struct sk_buff *skb);
50 51 52
u32 skb_get_poff(const struct sk_buff *skb);
u32 __skb_get_poff(const struct sk_buff *skb, void *data,
		   const struct flow_keys *keys, int hlen);
53

T
Tom Herbert 已提交
54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
/* struct flow_keys_digest:
 *
 * This structure is used to hold a digest of the full flow keys. This is a
 * larger "hash" of a flow to allow definitively matching specific flows where
 * the 32 bit skb->hash is not large enough. The size is limited to 16 bytes so
 * that it can by used in CB of skb (see sch_choke for an example).
 */
#define FLOW_KEYS_DIGEST_LEN	16
struct flow_keys_digest {
	u8	data[FLOW_KEYS_DIGEST_LEN];
};

void make_flow_keys_digest(struct flow_keys_digest *digest,
			   const struct flow_keys *flow);

E
Eric Dumazet 已提交
69
#endif