diff options
Diffstat (limited to 'include/net/vxlan.h')
-rw-r--r-- | include/net/vxlan.h | 105 |
1 files changed, 100 insertions, 5 deletions
diff --git a/include/net/vxlan.h b/include/net/vxlan.h index 903461aa5644..eabd3a038674 100644 --- a/include/net/vxlan.h +++ b/include/net/vxlan.h | |||
@@ -11,14 +11,96 @@ | |||
11 | #define VNI_HASH_BITS 10 | 11 | #define VNI_HASH_BITS 10 |
12 | #define VNI_HASH_SIZE (1<<VNI_HASH_BITS) | 12 | #define VNI_HASH_SIZE (1<<VNI_HASH_BITS) |
13 | 13 | ||
14 | /* VXLAN protocol header */ | 14 | /* |
15 | * VXLAN Group Based Policy Extension: | ||
16 | * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | ||
17 | * |1|-|-|-|1|-|-|-|R|D|R|R|A|R|R|R| Group Policy ID | | ||
18 | * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | ||
19 | * | VXLAN Network Identifier (VNI) | Reserved | | ||
20 | * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | ||
21 | * | ||
22 | * D = Don't Learn bit. When set, this bit indicates that the egress | ||
23 | * VTEP MUST NOT learn the source address of the encapsulated frame. | ||
24 | * | ||
25 | * A = Indicates that the group policy has already been applied to | ||
26 | * this packet. Policies MUST NOT be applied by devices when the | ||
27 | * A bit is set. | ||
28 | * | ||
29 | * [0] https://tools.ietf.org/html/draft-smith-vxlan-group-policy | ||
30 | */ | ||
31 | struct vxlanhdr_gbp { | ||
32 | __u8 vx_flags; | ||
33 | #ifdef __LITTLE_ENDIAN_BITFIELD | ||
34 | __u8 reserved_flags1:3, | ||
35 | policy_applied:1, | ||
36 | reserved_flags2:2, | ||
37 | dont_learn:1, | ||
38 | reserved_flags3:1; | ||
39 | #elif defined(__BIG_ENDIAN_BITFIELD) | ||
40 | __u8 reserved_flags1:1, | ||
41 | dont_learn:1, | ||
42 | reserved_flags2:2, | ||
43 | policy_applied:1, | ||
44 | reserved_flags3:3; | ||
45 | #else | ||
46 | #error "Please fix <asm/byteorder.h>" | ||
47 | #endif | ||
48 | __be16 policy_id; | ||
49 | __be32 vx_vni; | ||
50 | }; | ||
51 | |||
52 | #define VXLAN_GBP_USED_BITS (VXLAN_HF_GBP | 0xFFFFFF) | ||
53 | |||
54 | /* skb->mark mapping | ||
55 | * | ||
56 | * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | ||
57 | * |R|R|R|R|R|R|R|R|R|D|R|R|A|R|R|R| Group Policy ID | | ||
58 | * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | ||
59 | */ | ||
60 | #define VXLAN_GBP_DONT_LEARN (BIT(6) << 16) | ||
61 | #define VXLAN_GBP_POLICY_APPLIED (BIT(3) << 16) | ||
62 | #define VXLAN_GBP_ID_MASK (0xFFFF) | ||
63 | |||
64 | /* VXLAN protocol header: | ||
65 | * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | ||
66 | * |G|R|R|R|I|R|R|C| Reserved | | ||
67 | * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | ||
68 | * | VXLAN Network Identifier (VNI) | Reserved | | ||
69 | * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | ||
70 | * | ||
71 | * G = 1 Group Policy (VXLAN-GBP) | ||
72 | * I = 1 VXLAN Network Identifier (VNI) present | ||
73 | * C = 1 Remote checksum offload (RCO) | ||
74 | */ | ||
15 | struct vxlanhdr { | 75 | struct vxlanhdr { |
16 | __be32 vx_flags; | 76 | __be32 vx_flags; |
17 | __be32 vx_vni; | 77 | __be32 vx_vni; |
18 | }; | 78 | }; |
19 | 79 | ||
80 | /* VXLAN header flags. */ | ||
81 | #define VXLAN_HF_RCO BIT(24) | ||
82 | #define VXLAN_HF_VNI BIT(27) | ||
83 | #define VXLAN_HF_GBP BIT(31) | ||
84 | |||
85 | /* Remote checksum offload header option */ | ||
86 | #define VXLAN_RCO_MASK 0x7f /* Last byte of vni field */ | ||
87 | #define VXLAN_RCO_UDP 0x80 /* Indicate UDP RCO (TCP when not set *) */ | ||
88 | #define VXLAN_RCO_SHIFT 1 /* Left shift of start */ | ||
89 | #define VXLAN_RCO_SHIFT_MASK ((1 << VXLAN_RCO_SHIFT) - 1) | ||
90 | #define VXLAN_MAX_REMCSUM_START (VXLAN_RCO_MASK << VXLAN_RCO_SHIFT) | ||
91 | |||
92 | #define VXLAN_N_VID (1u << 24) | ||
93 | #define VXLAN_VID_MASK (VXLAN_N_VID - 1) | ||
94 | #define VXLAN_HLEN (sizeof(struct udphdr) + sizeof(struct vxlanhdr)) | ||
95 | |||
96 | struct vxlan_metadata { | ||
97 | __be32 vni; | ||
98 | u32 gbp; | ||
99 | }; | ||
100 | |||
20 | struct vxlan_sock; | 101 | struct vxlan_sock; |
21 | typedef void (vxlan_rcv_t)(struct vxlan_sock *vh, struct sk_buff *skb, __be32 key); | 102 | typedef void (vxlan_rcv_t)(struct vxlan_sock *vh, struct sk_buff *skb, |
103 | struct vxlan_metadata *md); | ||
22 | 104 | ||
23 | /* per UDP socket information */ | 105 | /* per UDP socket information */ |
24 | struct vxlan_sock { | 106 | struct vxlan_sock { |
@@ -31,6 +113,7 @@ struct vxlan_sock { | |||
31 | struct hlist_head vni_list[VNI_HASH_SIZE]; | 113 | struct hlist_head vni_list[VNI_HASH_SIZE]; |
32 | atomic_t refcnt; | 114 | atomic_t refcnt; |
33 | struct udp_offload udp_offloads; | 115 | struct udp_offload udp_offloads; |
116 | u32 flags; | ||
34 | }; | 117 | }; |
35 | 118 | ||
36 | #define VXLAN_F_LEARN 0x01 | 119 | #define VXLAN_F_LEARN 0x01 |
@@ -42,6 +125,18 @@ struct vxlan_sock { | |||
42 | #define VXLAN_F_UDP_CSUM 0x40 | 125 | #define VXLAN_F_UDP_CSUM 0x40 |
43 | #define VXLAN_F_UDP_ZERO_CSUM6_TX 0x80 | 126 | #define VXLAN_F_UDP_ZERO_CSUM6_TX 0x80 |
44 | #define VXLAN_F_UDP_ZERO_CSUM6_RX 0x100 | 127 | #define VXLAN_F_UDP_ZERO_CSUM6_RX 0x100 |
128 | #define VXLAN_F_REMCSUM_TX 0x200 | ||
129 | #define VXLAN_F_REMCSUM_RX 0x400 | ||
130 | #define VXLAN_F_GBP 0x800 | ||
131 | #define VXLAN_F_REMCSUM_NOPARTIAL 0x1000 | ||
132 | |||
133 | /* Flags that are used in the receive patch. These flags must match in | ||
134 | * order for a socket to be shareable | ||
135 | */ | ||
136 | #define VXLAN_F_RCV_FLAGS (VXLAN_F_GBP | \ | ||
137 | VXLAN_F_UDP_ZERO_CSUM6_RX | \ | ||
138 | VXLAN_F_REMCSUM_RX | \ | ||
139 | VXLAN_F_REMCSUM_NOPARTIAL) | ||
45 | 140 | ||
46 | struct vxlan_sock *vxlan_sock_add(struct net *net, __be16 port, | 141 | struct vxlan_sock *vxlan_sock_add(struct net *net, __be16 port, |
47 | vxlan_rcv_t *rcv, void *data, | 142 | vxlan_rcv_t *rcv, void *data, |
@@ -49,10 +144,10 @@ struct vxlan_sock *vxlan_sock_add(struct net *net, __be16 port, | |||
49 | 144 | ||
50 | void vxlan_sock_release(struct vxlan_sock *vs); | 145 | void vxlan_sock_release(struct vxlan_sock *vs); |
51 | 146 | ||
52 | int vxlan_xmit_skb(struct vxlan_sock *vs, | 147 | int vxlan_xmit_skb(struct rtable *rt, struct sk_buff *skb, |
53 | struct rtable *rt, struct sk_buff *skb, | ||
54 | __be32 src, __be32 dst, __u8 tos, __u8 ttl, __be16 df, | 148 | __be32 src, __be32 dst, __u8 tos, __u8 ttl, __be16 df, |
55 | __be16 src_port, __be16 dst_port, __be32 vni, bool xnet); | 149 | __be16 src_port, __be16 dst_port, struct vxlan_metadata *md, |
150 | bool xnet, u32 vxflags); | ||
56 | 151 | ||
57 | static inline netdev_features_t vxlan_features_check(struct sk_buff *skb, | 152 | static inline netdev_features_t vxlan_features_check(struct sk_buff *skb, |
58 | netdev_features_t features) | 153 | netdev_features_t features) |