提交 b87cec38 编写于 作者: J Jarno Rajahalme 提交者: David S. Miller

openvswitch: Simplify labels length logic.

Since 23014011 ("netfilter: conntrack: support a fixed size of 128
distinct labels"), the size of conntrack labels extension has fixed to
128 bits, so we do not need to check for labels sizes shorter than 128
at run-time.  This patch simplifies labels length logic accordingly,
but allows the conntrack labels size to be increased in the future
without breaking the build.  In the event of conntrack labels
increasing in size OVS would still be able to deal with the 128 first
label bits.
Suggested-by: NJoe Stringer <joe@ovn.org>
Signed-off-by: NJarno Rajahalme <jarno@ovn.org>
Acked-by: NPravin B Shelar <pshelar@ovn.org>
Acked-by: NJoe Stringer <joe@ovn.org>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 cb80d58f
...@@ -129,22 +129,20 @@ static u32 ovs_ct_get_mark(const struct nf_conn *ct) ...@@ -129,22 +129,20 @@ static u32 ovs_ct_get_mark(const struct nf_conn *ct)
#endif #endif
} }
/* Guard against conntrack labels max size shrinking below 128 bits. */
#if NF_CT_LABELS_MAX_SIZE < 16
#error NF_CT_LABELS_MAX_SIZE must be at least 16 bytes
#endif
static void ovs_ct_get_labels(const struct nf_conn *ct, static void ovs_ct_get_labels(const struct nf_conn *ct,
struct ovs_key_ct_labels *labels) struct ovs_key_ct_labels *labels)
{ {
struct nf_conn_labels *cl = ct ? nf_ct_labels_find(ct) : NULL; struct nf_conn_labels *cl = ct ? nf_ct_labels_find(ct) : NULL;
if (cl) { if (cl)
size_t len = sizeof(cl->bits); memcpy(labels, cl->bits, OVS_CT_LABELS_LEN);
else
if (len > OVS_CT_LABELS_LEN)
len = OVS_CT_LABELS_LEN;
else if (len < OVS_CT_LABELS_LEN)
memset(labels, 0, OVS_CT_LABELS_LEN);
memcpy(labels, cl->bits, len);
} else {
memset(labels, 0, OVS_CT_LABELS_LEN); memset(labels, 0, OVS_CT_LABELS_LEN);
}
} }
static void __ovs_ct_update_key(struct sw_flow_key *key, u8 state, static void __ovs_ct_update_key(struct sw_flow_key *key, u8 state,
...@@ -274,7 +272,7 @@ static int ovs_ct_set_labels(struct sk_buff *skb, struct sw_flow_key *key, ...@@ -274,7 +272,7 @@ static int ovs_ct_set_labels(struct sk_buff *skb, struct sw_flow_key *key,
nf_ct_labels_ext_add(ct); nf_ct_labels_ext_add(ct);
cl = nf_ct_labels_find(ct); cl = nf_ct_labels_find(ct);
} }
if (!cl || sizeof(cl->bits) < OVS_CT_LABELS_LEN) if (!cl)
return -ENOSPC; return -ENOSPC;
if (nf_ct_is_confirmed(ct)) { if (nf_ct_is_confirmed(ct)) {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册