Dmitry Vyukov
723bcdcfdb
mm/kmemleak.c: fix check for softirq context
...
[ Upstream commit 6ef9056952532c3b746de46aa10d45b4d7797bd8 ]
in_softirq() is a wrong predicate to check if we are in a softirq
context. It also returns true if we have BH disabled, so objects are
falsely stamped with "softirq" comm. The correct predicate is
in_serving_softirq().
If user does cat from /sys/kernel/debug/kmemleak previously they would
see this, which is clearly wrong, this is system call context (see the
comm):
unreferenced object 0xffff88805bd661c0 (size 64):
comm "softirq", pid 0, jiffies 4294942959 (age 12.400s)
hex dump (first 32 bytes):
00 00 00 00 00 00 00 00 ff ff ff ff 00 00 00 00 ................
00 00 00 00 00 00 00 00 01 00 00 00 00 00 00 00 ................
backtrace:
[<0000000007dcb30c>] kmemleak_alloc_recursive include/linux/kmemleak.h:55 [inline]
[<0000000007dcb30c>] slab_post_alloc_hook mm/slab.h:439 [inline]
[<0000000007dcb30c>] slab_alloc mm/slab.c:3326 [inline]
[<0000000007dcb30c>] kmem_cache_alloc_trace+0x13d/0x280 mm/slab.c:3553
[<00000000969722b7>] kmalloc include/linux/slab.h:547 [inline]
[<00000000969722b7>] kzalloc include/linux/slab.h:742 [inline]
[<00000000969722b7>] ip_mc_add1_src net/ipv4/igmp.c:1961 [inline]
[<00000000969722b7>] ip_mc_add_src+0x36b/0x400 net/ipv4/igmp.c:2085
[<00000000a4134b5f>] ip_mc_msfilter+0x22d/0x310 net/ipv4/igmp.c:2475
[<00000000d20248ad>] do_ip_setsockopt.isra.0+0x19fe/0x1c00 net/ipv4/ip_sockglue.c:957
[<000000003d367be7>] ip_setsockopt+0x3b/0xb0 net/ipv4/ip_sockglue.c:1246
[<000000003c7c76af>] udp_setsockopt+0x4e/0x90 net/ipv4/udp.c:2616
[<000000000c1aeb23>] sock_common_setsockopt+0x3e/0x50 net/core/sock.c:3130
[<000000000157b92b>] __sys_setsockopt+0x9e/0x120 net/socket.c:2078
[<00000000a9f3d058>] __do_sys_setsockopt net/socket.c:2089 [inline]
[<00000000a9f3d058>] __se_sys_setsockopt net/socket.c:2086 [inline]
[<00000000a9f3d058>] __x64_sys_setsockopt+0x26/0x30 net/socket.c:2086
[<000000001b8da885>] do_syscall_64+0x7c/0x1a0 arch/x86/entry/common.c:301
[<00000000ba770c62>] entry_SYSCALL_64_after_hwframe+0x44/0xa9
now they will see this:
unreferenced object 0xffff88805413c800 (size 64):
comm "syz-executor.4", pid 8960, jiffies 4294994003 (age 14.350s)
hex dump (first 32 bytes):
00 7a 8a 57 80 88 ff ff e0 00 00 01 00 00 00 00 .z.W............
00 00 00 00 00 00 00 00 01 00 00 00 00 00 00 00 ................
backtrace:
[<00000000c5d3be64>] kmemleak_alloc_recursive include/linux/kmemleak.h:55 [inline]
[<00000000c5d3be64>] slab_post_alloc_hook mm/slab.h:439 [inline]
[<00000000c5d3be64>] slab_alloc mm/slab.c:3326 [inline]
[<00000000c5d3be64>] kmem_cache_alloc_trace+0x13d/0x280 mm/slab.c:3553
[<0000000023865be2>] kmalloc include/linux/slab.h:547 [inline]
[<0000000023865be2>] kzalloc include/linux/slab.h:742 [inline]
[<0000000023865be2>] ip_mc_add1_src net/ipv4/igmp.c:1961 [inline]
[<0000000023865be2>] ip_mc_add_src+0x36b/0x400 net/ipv4/igmp.c:2085
[<000000003029a9d4>] ip_mc_msfilter+0x22d/0x310 net/ipv4/igmp.c:2475
[<00000000ccd0a87c>] do_ip_setsockopt.isra.0+0x19fe/0x1c00 net/ipv4/ip_sockglue.c:957
[<00000000a85a3785>] ip_setsockopt+0x3b/0xb0 net/ipv4/ip_sockglue.c:1246
[<00000000ec13c18d>] udp_setsockopt+0x4e/0x90 net/ipv4/udp.c:2616
[<0000000052d748e3>] sock_common_setsockopt+0x3e/0x50 net/core/sock.c:3130
[<00000000512f1014>] __sys_setsockopt+0x9e/0x120 net/socket.c:2078
[<00000000181758bc>] __do_sys_setsockopt net/socket.c:2089 [inline]
[<00000000181758bc>] __se_sys_setsockopt net/socket.c:2086 [inline]
[<00000000181758bc>] __x64_sys_setsockopt+0x26/0x30 net/socket.c:2086
[<00000000d4b73623>] do_syscall_64+0x7c/0x1a0 arch/x86/entry/common.c:301
[<00000000c1098bec>] entry_SYSCALL_64_after_hwframe+0x44/0xa9
Link: http://lkml.kernel.org/r/20190517171507.96046-1-dvyukov@gmail.com
Signed-off-by: Dmitry Vyukov <dvyukov@google.com>
Acked-by: Catalin Marinas <catalin.marinas@arm.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
2019-08-04 09:34:59 +02:00
..
2018-08-24 13:26:58 +02:00
2019-06-11 12:23:41 +02:00
2016-03-03 15:07:18 -08:00
2015-09-08 15:35:28 -07:00
2015-04-14 16:49:03 -07:00
2019-06-22 08:18:18 +02:00
2019-06-22 08:18:17 +02:00
2015-08-14 15:56:32 -07:00
2018-01-17 09:35:26 +01:00
2017-11-24 11:26:29 +01:00
2018-09-19 22:49:00 +02:00
2015-11-06 17:50:42 -08:00
2018-02-25 11:03:41 +01:00
2018-09-15 09:40:38 +02:00
2015-11-06 17:50:42 -08:00
2018-05-26 08:48:54 +02:00
2018-12-17 21:55:16 +01:00
2015-06-24 17:49:45 -07:00
2018-12-17 21:55:17 +01:00
2014-08-06 18:01:22 -07:00
2018-11-10 07:41:42 -08:00
2015-11-06 17:50:42 -08:00
2019-06-22 08:18:17 +02:00
2015-09-10 13:29:01 -07:00
2017-01-06 11:16:11 +01:00
2017-08-11 09:08:50 -07:00
2015-02-10 14:30:31 -08:00
2018-05-26 08:48:55 +02:00
2015-01-08 15:10:52 -08:00
2014-10-09 22:25:50 -04:00
2019-08-04 09:34:59 +02:00
2018-05-30 07:49:08 +02:00
2019-06-22 08:18:22 +02:00
2015-11-05 19:34:48 -08:00
2018-10-10 08:52:11 +02:00
2015-09-11 16:42:39 -07:00
2017-06-14 13:16:26 +02:00
2018-07-25 10:18:16 +02:00
2019-03-23 08:44:26 +01:00
2018-01-31 12:06:09 +01:00
2018-12-17 21:55:17 +01:00
2019-04-27 09:33:47 +02:00
2017-08-12 19:29:09 -07:00
2015-09-08 15:35:28 -07:00
2019-03-23 08:44:23 +01:00
2019-06-11 12:23:36 +02:00
2018-12-13 09:21:33 +01:00
2015-06-30 19:44:56 -07:00
2019-06-22 08:18:27 +02:00
2017-12-25 14:22:09 +01:00
2015-09-10 13:29:01 -07:00
2015-02-11 17:06:02 -08:00
2018-08-15 17:42:10 +02:00
2018-11-10 07:41:42 -08:00
2015-11-05 19:34:48 -08:00
2015-06-30 19:44:55 -07:00
2018-12-17 21:55:17 +01:00
2019-02-06 19:43:07 +01:00
2018-07-11 16:03:51 +02:00
2015-11-05 19:34:48 -08:00
2019-04-27 09:33:48 +02:00
2019-07-10 09:56:30 +02:00
2015-08-13 12:32:00 -06:00
2016-04-20 15:41:53 +09:00
2017-11-24 08:32:25 +01:00
2019-01-26 09:42:55 +01:00
2017-11-24 08:32:25 +01:00
2014-09-02 14:46:05 -04:00
2014-09-02 14:46:02 -04:00
2018-05-16 10:06:46 +02:00
2016-02-25 12:01:23 -08:00
2018-12-17 21:55:16 +01:00
2015-11-06 17:50:42 -08:00
2019-04-03 06:23:18 +02:00
2019-03-23 08:44:34 +01:00
2017-10-21 17:09:05 +02:00
2019-04-27 09:33:48 +02:00
2015-11-22 11:58:44 -08:00
2015-11-22 11:58:44 -08:00
2018-10-10 08:52:08 +02:00
2017-07-05 14:37:15 +02:00
2015-09-08 15:35:28 -07:00
2015-11-06 17:50:42 -08:00
2018-08-15 17:42:10 +02:00
2018-12-13 09:21:33 +01:00
2015-09-04 16:54:41 -07:00
2018-12-17 21:55:16 +01:00
2018-09-19 22:49:00 +02:00
2019-04-27 09:33:48 +02:00
2017-03-12 06:37:25 +01:00
2018-06-06 16:46:23 +02:00
2019-04-27 09:34:02 +02:00
2016-10-28 03:01:34 -04:00
2015-11-06 17:50:42 -08:00
2015-11-06 17:50:42 -08:00
2016-05-18 17:06:44 -07:00
2018-09-05 09:18:36 +02:00