Fedor Pchelkin
d6938c1c76
ipvs: avoid stat macros calls from preemptible context
...
Inside decrement_ttl() upon discovering that the packet ttl has exceeded,
__IP_INC_STATS and __IP6_INC_STATS macros can be called from preemptible
context having the following backtrace:
check_preemption_disabled: 48 callbacks suppressed
BUG: using __this_cpu_add() in preemptible [00000000] code: curl/1177
caller is decrement_ttl+0x217/0x830
CPU: 5 PID: 1177 Comm: curl Not tainted 6.7.0+ #34
Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS 04/01/2014
Call Trace:
<TASK>
dump_stack_lvl+0xbd/0xe0
check_preemption_disabled+0xd1/0xe0
decrement_ttl+0x217/0x830
__ip_vs_get_out_rt+0x4e0/0x1ef0
ip_vs_nat_xmit+0x205/0xcd0
ip_vs_in_hook+0x9b1/0x26a0
nf_hook_slow+0xc2/0x210
nf_hook+0x1fb/0x770
__ip_local_out+0x33b/0x640
ip_local_out+0x2a/0x490
__ip_queue_xmit+0x990/0x1d10
__tcp_transmit_skb+0x288b/0x3d10
tcp_connect+0x3466/0x5180
tcp_v4_connect+0x1535/0x1bb0
__inet_stream_connect+0x40d/0x1040
inet_stream_connect+0x57/0xa0
__sys_connect_file+0x162/0x1a0
__sys_connect+0x137/0x160
__x64_sys_connect+0x72/0xb0
do_syscall_64+0x6f/0x140
entry_SYSCALL_64_after_hwframe+0x6e/0x76
RIP: 0033:0x7fe6dbbc34e0
Use the corresponding preemption-aware variants: IP_INC_STATS and
IP6_INC_STATS.
Found by Linux Verification Center (linuxtesting.org).
Fixes: 8d8e20e2d7 ("ipvs: Decrement ttl")
Signed-off-by: Fedor Pchelkin <pchelkin@ispras.ru >
Acked-by: Julian Anastasov <ja@ssi.bg >
Acked-by: Simon Horman <horms@kernel.org >
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org >
2024-01-17 12:02:51 +01:00
..
2024-01-17 12:02:48 +01:00
2024-01-17 12:02:51 +01:00
2023-10-18 10:26:43 +02:00
2023-04-21 11:34:14 -07:00
2023-04-21 11:34:14 -07:00
2023-12-19 08:23:03 -08:00
2022-05-16 13:05:40 +02:00
2022-02-04 06:30:28 +01:00
2019-07-16 13:16:59 +02:00
2023-11-01 22:33:53 -07:00
2023-11-08 13:52:32 +01:00
2023-10-18 10:26:43 +02:00
2023-02-22 00:28:47 +01:00
2023-07-20 10:06:36 +02:00
2023-09-13 21:57:50 +02:00
2022-09-20 23:50:03 +02:00
2020-07-22 01:18:05 +02:00
2022-08-11 16:50:49 +02:00
2019-06-19 17:09:52 +02:00
2023-10-10 16:34:28 +02:00
2022-09-07 15:55:23 +02:00
2023-10-24 13:16:30 +02:00
2022-01-11 10:41:44 +01:00
2023-12-22 12:15:20 +01:00
2023-03-08 14:25:41 +01:00
2022-07-11 16:25:15 +02:00
2023-07-27 13:45:51 +02:00
2019-06-19 17:09:55 +02:00
2023-07-05 14:42:15 +02:00
2021-06-18 14:47:43 +02:00
2022-11-30 23:01:20 +01:00
2023-10-04 14:12:01 +02:00
2023-10-10 16:34:28 +02:00
2023-02-01 12:18:51 +01:00
2023-11-08 13:52:32 +01:00
2022-08-11 16:50:25 +02:00
2022-02-04 06:30:28 +01:00
2023-06-26 17:18:48 +02:00
2019-05-30 11:26:32 -07:00
2023-08-15 15:26:17 -07:00
2019-07-16 13:16:59 +02:00
2022-07-11 16:25:15 +02:00
2022-02-04 06:30:28 +01:00
2022-06-21 10:50:41 +02:00
2023-10-25 11:35:46 +02:00
2023-02-03 09:31:24 +00:00
2023-06-15 22:19:41 -07:00
2023-07-31 09:11:24 +01:00
2022-07-11 16:25:14 +02:00
2021-08-30 01:51:36 +02:00
2020-05-27 22:20:34 +02:00
2024-01-17 12:02:48 +01:00
2023-08-15 15:26:17 -07:00
2022-09-07 16:46:04 +02:00
2023-11-01 22:33:53 -07:00
2023-11-08 13:52:32 +01:00
2022-09-07 16:46:04 +02:00
2022-11-18 02:15:15 +01:00
2022-09-07 16:46:04 +02:00
2022-05-13 18:56:27 +02:00
2024-01-03 11:17:17 +01:00
2023-10-30 14:36:57 -07:00
2023-11-08 16:40:30 +01:00
2022-09-07 16:46:04 +02:00
2019-07-16 13:16:59 +02:00
2024-01-17 12:02:48 +01:00
2020-07-24 15:41:54 -07:00
2023-11-29 20:16:19 -08:00
2024-01-17 12:02:51 +01:00
2023-12-20 10:43:21 +01:00
2023-07-31 09:11:24 +01:00
2023-10-18 10:26:43 +02:00
2021-05-29 01:04:53 +02:00
2022-07-11 16:25:15 +02:00
2022-06-17 23:31:20 +02:00
2023-04-21 11:34:14 -07:00
2024-01-17 12:02:47 +01:00
2023-11-08 13:52:32 +01:00
2023-10-18 10:26:43 +02:00
2023-06-08 04:00:02 +02:00
2023-06-26 12:59:18 -07:00
2023-11-14 16:16:21 +01:00
2023-05-10 08:50:18 +02:00
2023-11-08 13:52:32 +01:00
2021-05-29 01:04:54 +02:00
2023-07-31 09:11:24 +01:00
2022-11-15 10:46:34 +01:00
2022-11-15 10:46:34 +01:00
2022-11-15 10:53:17 +01:00
2023-05-03 13:49:08 +02:00
2023-08-22 15:13:21 +02:00
2022-11-15 10:46:34 +01:00
2023-12-06 17:15:43 +01:00
2023-12-06 17:15:42 +01:00
2022-03-20 00:29:47 +01:00
2022-03-20 00:29:47 +01:00
2023-12-06 17:15:42 +01:00
2023-07-05 14:42:15 +02:00
2023-11-08 13:52:32 +01:00
2023-06-26 08:05:57 +02:00
2024-01-03 11:17:17 +01:00
2023-10-12 10:28:45 +02:00
2023-03-01 17:23:23 +01:00
2024-01-17 12:02:47 +01:00
2022-11-15 10:46:34 +01:00
2023-07-27 13:45:51 +02:00
2023-07-27 13:45:51 +02:00
2023-11-14 16:16:21 +01:00
2023-07-27 13:45:51 +02:00
2022-11-15 10:46:34 +01:00
2023-07-05 14:42:15 +02:00
2023-08-22 15:13:21 +02:00
2023-10-12 10:28:45 +02:00
2022-11-15 10:46:34 +01:00
2023-03-01 17:23:23 +01:00
2023-06-26 08:05:57 +02:00
2023-07-27 13:45:51 +02:00
2022-03-20 00:29:46 +01:00
2022-03-20 00:29:46 +01:00
2023-06-26 08:05:57 +02:00
2023-06-26 08:05:57 +02:00
2023-10-24 13:37:46 +02:00
2023-10-24 13:37:46 +02:00
2021-12-24 16:58:17 +01:00
2021-05-29 01:04:27 +02:00
2023-12-22 12:08:38 +01:00
2023-10-24 13:16:30 +02:00
2023-11-14 16:10:20 +01:00
2023-07-29 18:13:41 +01:00
2022-11-15 10:46:34 +01:00
2023-06-26 08:05:57 +02:00
2023-06-26 08:05:57 +02:00
2023-06-26 08:05:57 +02:00
2023-03-08 14:25:40 +01:00
2023-08-22 15:13:21 +02:00
2019-06-19 17:09:55 +02:00
2021-06-01 23:53:51 +02:00
2021-08-17 00:45:07 +02:00
2019-06-19 17:09:55 +02:00
2019-06-19 17:09:55 +02:00
2019-06-19 17:09:55 +02:00
2019-06-19 17:09:55 +02:00
2019-05-21 10:50:45 +02:00
2018-02-14 21:05:38 +01:00
2019-06-19 17:09:55 +02:00
2022-07-11 16:40:45 +02:00
2022-11-18 15:21:00 +01:00
2020-07-29 20:09:18 +02:00
2019-06-19 17:09:55 +02:00
2019-06-19 17:09:55 +02:00
2022-07-11 16:25:15 +02:00
2019-06-19 17:09:55 +02:00
2019-06-19 17:09:55 +02:00
2019-06-19 17:09:55 +02:00
2022-07-11 16:40:45 +02:00
2019-06-19 17:09:55 +02:00
2019-06-19 17:09:55 +02:00
2022-01-22 08:33:37 +02:00
2019-06-19 17:09:55 +02:00
2019-06-19 17:09:55 +02:00
2019-06-22 08:59:24 -04:00
2020-08-28 19:55:51 +02:00
2023-03-17 15:16:33 +01:00
2019-05-30 11:26:32 -07:00
2019-06-25 01:32:59 +02:00
2019-05-21 10:50:45 +02:00
2019-06-19 17:09:55 +02:00
2023-05-25 12:16:27 +01:00
2023-02-22 21:25:23 -08:00
2021-05-29 01:04:52 +02:00
2021-09-21 03:46:56 +02:00
2019-06-19 17:09:55 +02:00
2019-06-19 17:09:55 +02:00
2019-06-19 17:09:55 +02:00
2019-06-19 17:09:55 +02:00
2020-06-25 00:50:31 +02:00
2019-06-19 17:09:55 +02:00
2020-12-01 09:45:29 +01:00
2021-09-21 03:46:56 +02:00
2019-06-19 17:09:55 +02:00
2023-06-20 22:43:42 +02:00
2023-12-06 17:52:15 +01:00
2024-01-17 12:02:48 +01:00
2019-06-19 17:09:55 +02:00
2019-06-19 17:09:55 +02:00
2019-05-21 10:50:45 +02:00
2019-06-19 17:09:55 +02:00
2022-09-07 16:46:03 +02:00
2019-06-19 17:09:55 +02:00
2023-11-08 13:53:36 +01:00
2023-03-22 21:48:59 +01:00
2023-08-22 15:13:21 +02:00
2023-08-30 17:34:01 +02:00
2021-05-03 23:02:44 +02:00
2019-08-13 12:14:26 +02:00
2023-07-29 18:13:41 +01:00
2019-06-19 17:09:55 +02:00
2022-10-11 17:42:58 -06:00
2019-06-19 17:09:55 +02:00
2019-06-19 17:09:55 +02:00
2022-07-11 16:40:45 +02:00
2019-06-22 08:59:24 -04:00
2023-03-22 21:48:59 +01:00
2019-05-21 11:28:40 +02:00
2020-07-29 20:09:18 +02:00
2022-07-21 00:56:00 +02:00
2021-03-31 22:34:10 +02:00
2023-08-30 17:34:01 +02:00