Lorenzo Bianconi
3e705251d9
net: netfilter: move nf flowtable bpf initialization in nf_flow_table_module_init()
Move nf flowtable bpf initialization in nf_flow_table module load
routine since nf_flow_table_bpf is part of nf_flow_table module and not
nf_flow_table_inet one. This patch allows to avoid the following kernel
warning running the reproducer below:
$modprobe nf_flow_table_inet
$rmmod nf_flow_table_inet
$modprobe nf_flow_table_inet
modprobe: ERROR: could not insert 'nf_flow_table_inet': Invalid argument
[ 184.081501] ------------[ cut here ]------------
[ 184.081527] WARNING: CPU: 0 PID: 1362 at kernel/bpf/btf.c:8206 btf_populate_kfunc_set+0x23c/0x330
[ 184.081550] CPU: 0 UID: 0 PID: 1362 Comm: modprobe Kdump: loaded Not tainted 6.11.0-0.rc5.22.el10.x86_64 #1
[ 184.081553] Hardware name: Red Hat OpenStack Compute, BIOS 1.14.0-1.module+el8.4.0+8855+a9e237a9 04/01/2014
[ 184.081554] RIP: 0010:btf_populate_kfunc_set+0x23c/0x330
[ 184.081558] RSP: 0018:ff22cfb38071fc90 EFLAGS: 00010202
[ 184.081559] RAX: 0000000000000001 RBX: 0000000000000001 RCX: 0000000000000000
[ 184.081560] RDX: 000000000000006e RSI: ffffffff95c00000 RDI: ff13805543436350
[ 184.081561] RBP: ffffffffc0e22180 R08: ff13805543410808 R09: 000000000001ec00
[ 184.081562] R10: ff13805541c8113c R11: 0000000000000010 R12: ff13805541b83c00
[ 184.081563] R13: ff13805543410800 R14: 0000000000000001 R15: ffffffffc0e2259a
[ 184.081564] FS: 00007fa436c46740(0000) GS:ff1380557ba00000(0000) knlGS:0000000000000000
[ 184.081569] CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033
[ 184.081570] CR2: 000055e7b3187000 CR3: 0000000100c48003 CR4: 0000000000771ef0
[ 184.081571] DR0: 0000000000000000 DR1: 0000000000000000 DR2: 0000000000000000
[ 184.081572] DR3: 0000000000000000 DR6: 00000000fffe0ff0 DR7: 0000000000000400
[ 184.081572] PKRU: 55555554
[ 184.081574] Call Trace:
[ 184.081575] <TASK>
[ 184.081578] ? show_trace_log_lvl+0x1b0/0x2f0
[ 184.081580] ? show_trace_log_lvl+0x1b0/0x2f0
[ 184.081582] ? __register_btf_kfunc_id_set+0x199/0x200
[ 184.081585] ? btf_populate_kfunc_set+0x23c/0x330
[ 184.081586] ? __warn.cold+0x93/0xed
[ 184.081590] ? btf_populate_kfunc_set+0x23c/0x330
[ 184.081592] ? report_bug+0xff/0x140
[ 184.081594] ? handle_bug+0x3a/0x70
[ 184.081596] ? exc_invalid_op+0x17/0x70
[ 184.081597] ? asm_exc_invalid_op+0x1a/0x20
[ 184.081601] ? btf_populate_kfunc_set+0x23c/0x330
[ 184.081602] __register_btf_kfunc_id_set+0x199/0x200
[ 184.081605] ? __pfx_nf_flow_inet_module_init+0x10/0x10 [nf_flow_table_inet]
[ 184.081607] do_one_initcall+0x58/0x300
[ 184.081611] do_init_module+0x60/0x230
[ 184.081614] __do_sys_init_module+0x17a/0x1b0
[ 184.081617] do_syscall_64+0x7d/0x160
[ 184.081620] ? __count_memcg_events+0x58/0xf0
[ 184.081623] ? handle_mm_fault+0x234/0x350
[ 184.081626] ? do_user_addr_fault+0x347/0x640
[ 184.081630] ? clear_bhb_loop+0x25/0x80
[ 184.081633] ? clear_bhb_loop+0x25/0x80
[ 184.081634] ? clear_bhb_loop+0x25/0x80
[ 184.081637] entry_SYSCALL_64_after_hwframe+0x76/0x7e
[ 184.081639] RIP: 0033:0x7fa43652e4ce
[ 184.081647] RSP: 002b:00007ffe8213be18 EFLAGS: 00000246 ORIG_RAX: 00000000000000af
[ 184.081649] RAX: ffffffffffffffda RBX: 000055e7b3176c20 RCX: 00007fa43652e4ce
[ 184.081650] RDX: 000055e7737fde79 RSI: 0000000000003990 RDI: 000055e7b3185380
[ 184.081651] RBP: 000055e7737fde79 R08: 0000000000000007 R09: 000055e7b3179bd0
[ 184.081651] R10: 0000000000000001 R11: 0000000000000246 R12: 0000000000040000
[ 184.081652] R13: 000055e7b3176fa0 R14: 0000000000000000 R15: 000055e7b3179b80
Fixes: 391bb6594f ("netfilter: Add bpf_xdp_flow_lookup kfunc")
Signed-off-by: Lorenzo Bianconi <lorenzo@kernel.org>
Acked-by: Florian Westphal <fw@strlen.de>
Acked-by: Pablo Neira Ayuso <pablo@netfilter.org>
Link: https://patch.msgid.link/20240911-nf-flowtable-bpf-modprob-fix-v1-1-f9fc075aafc3@kernel.org
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
2024-09-12 15:41:03 +02:00
..
2024-05-29 09:25:15 -07:00
2024-07-15 08:02:26 -07:00
2024-05-09 10:01:01 -07:00
2024-06-14 19:08:50 -07:00
2024-06-01 15:49:42 -07:00
2024-06-12 20:18:00 +02:00
2024-08-30 17:57:11 -04:00
2024-07-09 17:01:46 +02:00
2024-09-04 16:36:21 -07:00
2024-06-05 10:18:06 +01:00
2024-08-06 09:25:12 +02:00
2024-07-11 16:33:07 +02:00
2024-09-03 12:01:38 -07:00
2024-06-27 12:14:11 -07:00
2024-06-05 10:24:57 +01:00
2024-08-16 09:59:32 +01:00
2024-05-25 10:48:57 -07:00
2024-08-26 14:03:02 -07:00
2024-04-16 17:14:55 -07:00
2024-09-11 15:49:41 -07:00
2024-05-28 07:27:29 -07:00
2024-09-09 17:21:47 -07:00
2024-09-05 14:57:12 -07:00
2024-08-22 13:09:20 -07:00
2024-08-19 18:36:12 -07:00
2024-08-08 08:28:24 -07:00
2024-07-15 08:51:19 -07:00
2024-08-26 17:45:45 +02:00
2024-06-03 11:20:56 +02:00
2024-08-19 17:48:00 -07:00
2024-07-24 20:59:29 +02:00
2024-09-11 16:00:11 -07:00
2024-06-01 16:21:44 -07:00
2024-09-12 15:41:03 +02:00
2024-05-13 14:58:12 -07:00
2024-06-10 13:15:40 +01:00
2024-06-17 13:06:23 +01:00
2024-05-23 12:49:37 -07:00
2024-04-26 12:20:01 +02:00
2024-08-22 13:09:15 -07:00
2024-07-15 13:19:17 -07:00
2024-07-24 20:59:29 +02:00
2024-07-11 18:11:31 -07:00
2024-06-14 13:17:21 +02:00
2024-07-24 20:59:29 +02:00
2024-06-26 10:49:01 +02:00
2024-05-13 18:19:09 -06:00
2024-05-09 10:01:01 -07:00
2024-09-05 11:49:57 +02:00
2024-08-27 16:07:12 -07:00
2024-08-30 13:26:12 +01:00
2024-08-19 11:50:41 -04:00
2024-05-08 12:19:12 +01:00
2024-07-25 13:32:25 -07:00
2024-07-09 11:14:47 -07:00
2024-07-17 22:49:00 +02:00
2024-08-15 12:07:04 +02:00
2024-07-26 12:32:47 +02:00
2024-05-13 18:19:09 -06:00
2024-07-25 11:57:27 +02:00
2024-07-15 13:19:17 -07:00
2024-06-25 17:15:06 -07:00
2024-09-03 12:06:24 -07:00
2024-06-13 10:50:52 +02:00