syzbot


KASAN: use-after-free Write in tls_push_record

Status: fixed on 2018/07/09 18:05
Subsystems: net
[Documentation on labels]
Reported-by: syzbot+709f2810a6a05f11d4d3@syzkaller.appspotmail.com
Fix commit: a447da7d0041 tls: fix use-after-free in tls_push_record
First crash: 2156d, last: 2110d
Discussions (8)
Title Replies (including bot) Last reply
[PATCH 4.17 000/101] 4.17.9-stable review 100 (101) 2018/07/22 11:42
[PATCH 4.14 00/92] 4.14.57-stable review 91 (92) 2018/07/21 13:41
[PATCH net] tls: Stricter error checking in zerocopy sendmsg path 2 (2) 2018/07/16 20:32
[PATCH 4.17 00/70] 4.17.3-stable review 75 (75) 2018/06/25 23:48
[PATCH 4.16 00/64] 4.16.18-stable review 66 (66) 2018/06/25 17:20
[PATCH 4.14 00/52] 4.14.52-stable review 54 (54) 2018/06/25 17:19
[PATCH net 0/2] Two tls fixes 4 (4) 2018/06/15 16:15
KASAN: use-after-free Write in tls_push_record 0 (1) 2018/05/25 14:16
Similar bugs (2)
Kernel Title Repro Cause bisect Fix bisect Count Last Reported Patched Status
linux-4.19 KASAN: use-after-free Write in tls_push_record C error 120 439d 1824d 0/1 upstream: reported C repro on 2019/04/21 15:31
upstream KASAN: use-after-free Write in tls_push_record (2) net C 64 2005d 2108d 11/26 fixed on 2019/02/26 22:09

Sample crash report:
RDX: 00000000fffffdef RSI: 00000000200005c0 RDI: 0000000000000003
RBP: 00000000006cb018 R08: 0000000020000000 R09: 000000000000001c
R10: 0000000000000040 R11: 0000000000000216 R12: 0000000000000004
R13: ffffffffffffffff R14: 0000000000000000 R15: 0000000000000000
==================================================================
BUG: KASAN: use-after-free in tls_fill_prepend include/net/tls.h:339 [inline]
BUG: KASAN: use-after-free in tls_push_record+0x1091/0x1400 net/tls/tls_sw.c:239
Write of size 1 at addr ffff8801d9378000 by task syz-executor545/4544

CPU: 0 PID: 4544 Comm: syz-executor545 Not tainted 4.18.0-rc3+ #137
Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 01/01/2011
Call Trace:
 __dump_stack lib/dump_stack.c:77 [inline]
 dump_stack+0x1c9/0x2b4 lib/dump_stack.c:113
 print_address_description+0x6c/0x20b mm/kasan/report.c:256
 kasan_report_error mm/kasan/report.c:354 [inline]
 kasan_report.cold.7+0x242/0x2fe mm/kasan/report.c:412
 __asan_report_store1_noabort+0x17/0x20 mm/kasan/report.c:435
 tls_fill_prepend include/net/tls.h:339 [inline]
 tls_push_record+0x1091/0x1400 net/tls/tls_sw.c:239
 tls_sw_push_pending_record+0x22/0x30 net/tls/tls_sw.c:276
 tls_handle_open_record net/tls/tls_main.c:164 [inline]
 tls_sk_proto_close+0x74c/0xae0 net/tls/tls_main.c:264
 inet_release+0x104/0x1f0 net/ipv4/af_inet.c:427
 inet6_release+0x50/0x70 net/ipv6/af_inet6.c:459
 __sock_release+0xd7/0x260 net/socket.c:599
 sock_close+0x19/0x20 net/socket.c:1150
 __fput+0x355/0x8b0 fs/file_table.c:209
 ____fput+0x15/0x20 fs/file_table.c:243
 task_work_run+0x1ec/0x2a0 kernel/task_work.c:113
 exit_task_work include/linux/task_work.h:22 [inline]
 do_exit+0x1b08/0x2750 kernel/exit.c:865
 do_group_exit+0x177/0x440 kernel/exit.c:968
 __do_sys_exit_group kernel/exit.c:979 [inline]
 __se_sys_exit_group kernel/exit.c:977 [inline]
 __x64_sys_exit_group+0x3e/0x50 kernel/exit.c:977
 do_syscall_64+0x1b9/0x820 arch/x86/entry/common.c:290
 entry_SYSCALL_64_after_hwframe+0x49/0xbe
RIP: 0033:0x43f308
Code: Bad RIP value.
RSP: 002b:00007fff875a1148 EFLAGS: 00000246 ORIG_RAX: 00000000000000e7
RAX: ffffffffffffffda RBX: 0000000000000000 RCX: 000000000043f308
RDX: 0000000000000000 RSI: 000000000000003c RDI: 0000000000000000
RBP: 00000000004bf3e8 R08: 00000000000000e7 R09: ffffffffffffffd0
R10: 0000000000000040 R11: 0000000000000246 R12: 0000000000000001
R13: 00000000006d1180 R14: 0000000000000000 R15: 0000000000000000

The buggy address belongs to the page:
page:ffffea000764de00 count:0 mapcount:-128 mapping:0000000000000000 index:0x0
flags: 0x2fffc0000000000()
raw: 02fffc0000000000 ffffea0007641208 ffff88021fffac18 0000000000000000
raw: 0000000000000000 0000000000000003 00000000ffffff7f 0000000000000000
page dumped because: kasan: bad access detected

Memory state around the buggy address:
 ffff8801d9377f00: fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc
 ffff8801d9377f80: fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc
>ffff8801d9378000: ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff
                   ^
 ffff8801d9378080: ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff
 ffff8801d9378100: ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff
==================================================================

Crashes (24):
Time Kernel Commit Syzkaller Config Log Report Syz repro C repro VM info Assets (help?) Manager Title
2018/07/09 04:53 upstream ca04b3cca11a f25e5770 .config console log report syz C ci-upstream-kasan-gce
2018/06/20 02:28 upstream ba4dbdedd3ed 095ef806 .config console log report syz C ci-upstream-kasan-gce
2018/06/14 03:30 upstream be779f03d563 27c5f59f .config console log report syz C ci-upstream-kasan-gce
2018/06/09 06:21 upstream 410feb75de24 866118af .config console log report syz C ci-upstream-kasan-gce-root
2018/07/07 19:04 net-old 843789f6dd6a ab89aea9 .config console log report syz C ci-upstream-net-this-kasan-gce
2018/07/07 18:07 net-next-old 005c1c0eac82 ab89aea9 .config console log report syz C ci-upstream-net-kasan-gce
2018/06/09 06:32 net-next-old 3a979e8c07e3 866118af .config console log report syz C ci-upstream-net-kasan-gce
2018/05/24 20:38 net-next-old 13405468f49d f48c20b8 .config console log report syz C ci-upstream-net-kasan-gce
2018/07/07 10:05 linux-next 526674536360 6c0c0099 .config console log report syz C ci-upstream-linux-next-kasan-gce-root
2018/07/03 05:21 upstream d0fbad0aec1d 317fc8ea .config console log report ci-upstream-kasan-gce
2018/06/30 07:52 upstream 1904148a361a dba0b50e .config console log report ci-upstream-kasan-gce-root
2018/06/28 15:47 upstream f57494321cbf dba0b50e .config console log report ci-upstream-kasan-gce
2018/06/21 12:15 upstream 1abd8a8f39cd 095ef806 .config console log report ci-upstream-kasan-gce-root
2018/06/20 01:13 upstream ba4dbdedd3ed 095ef806 .config console log report ci-upstream-kasan-gce-root
2018/06/09 05:00 upstream 410feb75de24 866118af .config console log report ci-upstream-kasan-gce
2018/05/31 21:11 upstream dd52cb879063 2f93b54f .config console log report ci-upstream-kasan-gce
2018/07/07 08:42 net-old 70ba5b6db96f 6c0c0099 .config console log report ci-upstream-net-this-kasan-gce
2018/06/04 22:40 net-next-old 4cd328f83916 a50d873b .config console log report ci-upstream-net-kasan-gce
2018/06/03 14:12 net-next-old eaf47b17a77f 2f93b54f .config console log report ci-upstream-net-kasan-gce
2018/06/02 23:41 net-next-old 1ffdd8e1643f 2f93b54f .config console log report ci-upstream-net-kasan-gce
2018/06/02 11:22 net-next-old 21ad1173589e 2f93b54f .config console log report ci-upstream-net-kasan-gce
2018/06/02 05:00 net-next-old 21ad1173589e 2f93b54f .config console log report ci-upstream-net-kasan-gce
2018/05/25 22:51 net-next-old 9c5904904b88 f48c20b8 .config console log report ci-upstream-net-kasan-gce
2018/05/24 19:23 net-next-old 13405468f49d f48c20b8 .config console log report ci-upstream-net-kasan-gce
* Struck through repros no longer work on HEAD.