]> git.ipfire.org Git - thirdparty/iproute2.git/commitdiff
l2tp: fix L2TP_ATTR_UDP_CSUM handling
authorAsbjørn Sloth Tønnesen <asbjorn@asbjorn.st>
Wed, 16 Nov 2016 22:45:22 +0000 (22:45 +0000)
committerStephen Hemminger <sthemmin@microsoft.com>
Tue, 29 Nov 2016 21:31:30 +0000 (13:31 -0800)
L2TP_ATTR_UDP_CSUM is read by the kernel as a NLA_FLAG value,
but is validated as a NLA_U8, so we will write it as an u8,
but the value isn't actually being read by the kernel.

It is written by the kernel as a NLA_U8, so we will read as
such.

Signed-off-by: Asbjørn Sloth Tønnesen <asbjorn@asbjorn.st>
ip/ipl2tp.c

index a7cbd669bc2ab7aa11249a5e29ba3a3e184df472..03ca0cc45ba08666ce368785eed2e3a13aec2493 100644 (file)
@@ -120,7 +120,7 @@ static int create_tunnel(struct l2tp_parm *p)
                addattr16(&req.n, 1024, L2TP_ATTR_UDP_SPORT, p->local_udp_port);
                addattr16(&req.n, 1024, L2TP_ATTR_UDP_DPORT, p->peer_udp_port);
                if (p->udp_csum)
-                       addattr(&req.n, 1024, L2TP_ATTR_UDP_CSUM);
+                       addattr8(&req.n, 1024, L2TP_ATTR_UDP_CSUM, 1);
                if (!p->udp6_csum_tx)
                        addattr(&req.n, 1024, L2TP_ATTR_UDP_ZERO_CSUM6_TX);
                if (!p->udp6_csum_rx)
@@ -289,7 +289,9 @@ static int get_response(struct nlmsghdr *n, void *arg)
        if (attrs[L2TP_ATTR_L2SPEC_LEN])
                p->l2spec_len = rta_getattr_u8(attrs[L2TP_ATTR_L2SPEC_LEN]);
 
-       p->udp_csum = !!attrs[L2TP_ATTR_UDP_CSUM];
+       if (attrs[L2TP_ATTR_UDP_CSUM])
+               p->udp_csum = !!rta_getattr_u8(attrs[L2TP_ATTR_UDP_CSUM]);
+
        /*
         * Not fetching from L2TP_ATTR_UDP_ZERO_CSUM6_{T,R}X because the
         * kernel doesn't send it so just leave it as default value.