Skip to content

Commit 4d2a629

Browse files
edumazetbwhacks
authored andcommitted
l2tp: do not accept arbitrary sockets
commit 17cfe79 upstream. syzkaller found an issue caused by lack of sufficient checks in l2tp_tunnel_create() RAW sockets can not be considered as UDP ones for instance. In another patch, we shall replace all pr_err() by less intrusive pr_debug() so that syzkaller can find other bugs faster. Acked-by: Guillaume Nault <[email protected]> Acked-by: James Chapman <[email protected]> ================================================================== BUG: KASAN: slab-out-of-bounds in setup_udp_tunnel_sock+0x3ee/0x5f0 net/ipv4/udp_tunnel.c:69 dst_release: dst:00000000d53d0d0f refcnt:-1 Write of size 1 at addr ffff8801d013b798 by task syz-executor3/6242 CPU: 1 PID: 6242 Comm: syz-executor3 Not tainted 4.16.0-rc2+ torvalds#253 Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 01/01/2011 Call Trace: __dump_stack lib/dump_stack.c:17 [inline] dump_stack+0x194/0x24d lib/dump_stack.c:53 print_address_description+0x73/0x250 mm/kasan/report.c:256 kasan_report_error mm/kasan/report.c:354 [inline] kasan_report+0x23b/0x360 mm/kasan/report.c:412 __asan_report_store1_noabort+0x17/0x20 mm/kasan/report.c:435 setup_udp_tunnel_sock+0x3ee/0x5f0 net/ipv4/udp_tunnel.c:69 l2tp_tunnel_create+0x1354/0x17f0 net/l2tp/l2tp_core.c:1596 pppol2tp_connect+0x14b1/0x1dd0 net/l2tp/l2tp_ppp.c:707 SYSC_connect+0x213/0x4a0 net/socket.c:1640 SyS_connect+0x24/0x30 net/socket.c:1621 do_syscall_64+0x280/0x940 arch/x86/entry/common.c:287 entry_SYSCALL_64_after_hwframe+0x42/0xb7 Fixes: fd558d1 ("l2tp: Split pppol2tp patch into separate l2tp and ppp parts") Signed-off-by: Eric Dumazet <[email protected]> Reported-by: syzbot <[email protected]> Signed-off-by: David S. Miller <[email protected]> Signed-off-by: Ben Hutchings <[email protected]>
1 parent 8dfd783 commit 4d2a629

File tree

1 file changed

+6
-2
lines changed

1 file changed

+6
-2
lines changed

net/l2tp/l2tp_core.c

Lines changed: 6 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1505,17 +1505,21 @@ int l2tp_tunnel_create(struct net *net, int fd, int version, u32 tunnel_id, u32
15051505
encap = cfg->encap;
15061506

15071507
/* Quick sanity checks */
1508+
err = -EPROTONOSUPPORT;
1509+
if (sk->sk_type != SOCK_DGRAM) {
1510+
pr_debug("tunl %hu: fd %d wrong socket type\n",
1511+
tunnel_id, fd);
1512+
goto err;
1513+
}
15081514
switch (encap) {
15091515
case L2TP_ENCAPTYPE_UDP:
1510-
err = -EPROTONOSUPPORT;
15111516
if (sk->sk_protocol != IPPROTO_UDP) {
15121517
printk(KERN_ERR "tunl %hu: fd %d wrong protocol, got %d, expected %d\n",
15131518
tunnel_id, fd, sk->sk_protocol, IPPROTO_UDP);
15141519
goto err;
15151520
}
15161521
break;
15171522
case L2TP_ENCAPTYPE_IP:
1518-
err = -EPROTONOSUPPORT;
15191523
if (sk->sk_protocol != IPPROTO_L2TP) {
15201524
printk(KERN_ERR "tunl %hu: fd %d wrong protocol, got %d, expected %d\n",
15211525
tunnel_id, fd, sk->sk_protocol, IPPROTO_L2TP);

0 commit comments

Comments
 (0)