diff options
author | Steffen Klassert <steffen.klassert@secunet.com> | 2018-06-12 06:44:26 -0400 |
---|---|---|
committer | Steffen Klassert <steffen.klassert@secunet.com> | 2018-06-23 10:06:57 -0400 |
commit | 9b42c1f179a614e11893ae4619f0304a38f481ae (patch) | |
tree | 000229dd4cc78f2dc45c5a97b8f8ec72a18ee0e9 /net/xfrm/xfrm_output.c | |
parent | dd55c4ea9e6ba957083f985f33f994c23b405e9e (diff) |
xfrm: Extend the output_mark to support input direction and masking.
We already support setting an output mark at the xfrm_state,
unfortunately this does not support the input direction and
masking the marks that will be applied to the skb. This change
adds support applying a masked value in both directions.
The existing XFRMA_OUTPUT_MARK number is reused for this purpose
and as it is now bi-directional, it is renamed to XFRMA_SET_MARK.
An additional XFRMA_SET_MARK_MASK attribute is added for setting the
mask. If the attribute mask not provided, it is set to 0xffffffff,
keeping the XFRMA_OUTPUT_MARK existing 'full mask' semantics.
Co-developed-by: Tobias Brunner <tobias@strongswan.org>
Co-developed-by: Eyal Birger <eyal.birger@gmail.com>
Co-developed-by: Lorenzo Colitti <lorenzo@google.com>
Signed-off-by: Steffen Klassert <steffen.klassert@secunet.com>
Signed-off-by: Tobias Brunner <tobias@strongswan.org>
Signed-off-by: Eyal Birger <eyal.birger@gmail.com>
Signed-off-by: Lorenzo Colitti <lorenzo@google.com>
Diffstat (limited to 'net/xfrm/xfrm_output.c')
-rw-r--r-- | net/xfrm/xfrm_output.c | 3 |
1 files changed, 1 insertions, 2 deletions
diff --git a/net/xfrm/xfrm_output.c b/net/xfrm/xfrm_output.c index 89b178a78dc7..45ba07ab3e4f 100644 --- a/net/xfrm/xfrm_output.c +++ b/net/xfrm/xfrm_output.c | |||
@@ -66,8 +66,7 @@ static int xfrm_output_one(struct sk_buff *skb, int err) | |||
66 | goto error_nolock; | 66 | goto error_nolock; |
67 | } | 67 | } |
68 | 68 | ||
69 | if (x->props.output_mark) | 69 | skb->mark = xfrm_smark_get(skb->mark, x); |
70 | skb->mark = x->props.output_mark; | ||
71 | 70 | ||
72 | err = x->outer_mode->output(x, skb); | 71 | err = x->outer_mode->output(x, skb); |
73 | if (err) { | 72 | if (err) { |