Skip to content

Commit ade67d5

Browse files
skorpion17kuba-moo
authored andcommitted
seg6: fix seg6 lwtunnel output redirect for L2 reduced encap mode
When SEG6_IPTUN_MODE_L2ENCAP_RED (L2ENCAP_RED) was introduced, the condition in seg6_build_state() that excludes L2 encap modes from setting LWTUNNEL_STATE_OUTPUT_REDIRECT was not updated to account for the new mode. As a consequence, L2ENCAP_RED routes incorrectly trigger seg6_output() on the output path, where the packet is silently dropped because skb_mac_header_was_set() fails on L3 packets. Extend the check to also exclude L2ENCAP_RED, consistent with L2ENCAP. Fixes: 13f0296 ("seg6: add support for SRv6 H.L2Encaps.Red behavior") Cc: stable@vger.kernel.org Signed-off-by: Andrea Mayer <andrea.mayer@uniroma2.it> Reviewed-by: Justin Iurman <justin.iurman@gmail.com> Link: https://patch.msgid.link/20260418162838.31979-1-andrea.mayer@uniroma2.it Signed-off-by: Jakub Kicinski <kuba@kernel.org>
1 parent 7c9b012 commit ade67d5

1 file changed

Lines changed: 2 additions & 1 deletion

File tree

net/ipv6/seg6_iptunnel.c

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -746,7 +746,8 @@ static int seg6_build_state(struct net *net, struct nlattr *nla,
746746
newts->type = LWTUNNEL_ENCAP_SEG6;
747747
newts->flags |= LWTUNNEL_STATE_INPUT_REDIRECT;
748748

749-
if (tuninfo->mode != SEG6_IPTUN_MODE_L2ENCAP)
749+
if (tuninfo->mode != SEG6_IPTUN_MODE_L2ENCAP &&
750+
tuninfo->mode != SEG6_IPTUN_MODE_L2ENCAP_RED)
750751
newts->flags |= LWTUNNEL_STATE_OUTPUT_REDIRECT;
751752

752753
newts->headroom = seg6_lwt_headroom(tuninfo);

0 commit comments

Comments
 (0)