blob: 4570ccafe59d3b02fbecf3a91864908e94a0e8bd [file] [log] [blame]
Jiri Pirko1bd758e2015-05-12 14:56:07 +02001#ifndef _NET_FLOW_DISSECTOR_H
2#define _NET_FLOW_DISSECTOR_H
Eric Dumazet0744dd02011-11-28 05:22:18 +00003
Govindarajulu Varadarajane0f31d82014-06-23 16:07:58 +05304/* struct flow_keys:
5 * @src: source ip address in case of IPv4
6 * For IPv6 it contains 32bit hash of src address
7 * @dst: destination ip address in case of IPv4
8 * For IPv6 it contains 32bit hash of dst address
9 * @ports: port numbers of Transport header
10 * port16[0]: src port number
11 * port16[1]: dst port number
12 * @thoff: Transport header offset
13 * @n_proto: Network header protocol (eg. IPv4/IPv6)
14 * @ip_proto: Transport header protocol (eg. TCP/UDP)
15 * All the members, except thoff, are in network byte order.
16 */
Eric Dumazet0744dd02011-11-28 05:22:18 +000017struct flow_keys {
Eric Dumazet4d77d2b2011-11-28 20:30:35 +000018 /* (src,dst) must be grouped, in the same way than in IP header */
Eric Dumazet0744dd02011-11-28 05:22:18 +000019 __be32 src;
20 __be32 dst;
21 union {
22 __be32 ports;
23 __be16 port16[2];
24 };
Eric Dumazetf4575d32015-02-04 13:31:54 -080025 u16 thoff;
26 __be16 n_proto;
27 u8 ip_proto;
Eric Dumazet0744dd02011-11-28 05:22:18 +000028};
29
David S. Miller690e36e2014-08-23 12:13:41 -070030bool __skb_flow_dissect(const struct sk_buff *skb, struct flow_keys *flow,
WANG Cong453a9402014-08-25 17:03:47 -070031 void *data, __be16 proto, int nhoff, int hlen);
Jiri Pirko1bd758e2015-05-12 14:56:07 +020032
33static inline bool skb_flow_dissect(const struct sk_buff *skb,
34 struct flow_keys *flow)
David S. Miller690e36e2014-08-23 12:13:41 -070035{
WANG Cong453a9402014-08-25 17:03:47 -070036 return __skb_flow_dissect(skb, flow, NULL, 0, 0, 0);
David S. Miller690e36e2014-08-23 12:13:41 -070037}
Jiri Pirko1bd758e2015-05-12 14:56:07 +020038
David S. Miller690e36e2014-08-23 12:13:41 -070039__be32 __skb_flow_get_ports(const struct sk_buff *skb, int thoff, u8 ip_proto,
40 void *data, int hlen_proto);
Jiri Pirko1bd758e2015-05-12 14:56:07 +020041
42static inline __be32 skb_flow_get_ports(const struct sk_buff *skb,
43 int thoff, u8 ip_proto)
David S. Miller690e36e2014-08-23 12:13:41 -070044{
45 return __skb_flow_get_ports(skb, thoff, ip_proto, NULL, 0);
46}
Jiri Pirko1bd758e2015-05-12 14:56:07 +020047
Tom Herbert5ed20a62014-07-01 21:32:05 -070048u32 flow_hash_from_keys(struct flow_keys *keys);
Jiri Pirko10b89ee42015-05-12 14:56:09 +020049u32 skb_get_poff(const struct sk_buff *skb);
50u32 __skb_get_poff(const struct sk_buff *skb, void *data,
51 const struct flow_keys *keys, int hlen);
Jiri Pirko1bd758e2015-05-12 14:56:07 +020052
Tom Herbert2f59e1e2015-05-01 11:30:17 -070053/* struct flow_keys_digest:
54 *
55 * This structure is used to hold a digest of the full flow keys. This is a
56 * larger "hash" of a flow to allow definitively matching specific flows where
57 * the 32 bit skb->hash is not large enough. The size is limited to 16 bytes so
58 * that it can by used in CB of skb (see sch_choke for an example).
59 */
60#define FLOW_KEYS_DIGEST_LEN 16
61struct flow_keys_digest {
62 u8 data[FLOW_KEYS_DIGEST_LEN];
63};
64
65void make_flow_keys_digest(struct flow_keys_digest *digest,
66 const struct flow_keys *flow);
67
Eric Dumazet0744dd02011-11-28 05:22:18 +000068#endif