Skip to content

Commit a56b8f8

Browse files
kaberdavem330
authored andcommitted
netfilter: nf_conntrack_h323: fix module unload crash
The H.245 helper is not registered/unregistered, but assigned to connections manually from the Q.931 helper. This means on unload existing expectations and connections using the helper are not cleaned up, leading to the following oops on module unload: CPU 0 Unable to handle kernel paging request at virtual address c00a6828, epc == 802224dc, ra == 801d4e7c Oops[#1]: Cpu 0 $ 0 : 00000000 00000000 00000004 c00a67f0 $ 4 : 802a5ad0 81657e00 00000000 00000000 $ 8 : 00000008 801461c8 00000000 80570050 $12 : 819b0280 819b04b0 00000006 00000000 $16 : 802a5a60 80000000 80b46000 80321010 $20 : 00000000 00000004 802a5ad0 00000001 $24 : 00000000 802257a8 $28 : 802a4000 802a59e8 00000004 801d4e7c Hi : 0000000b Lo : 00506320 epc : 802224dc ip_conntrack_help+0x38/0x74 Tainted: P ra : 801d4e7c nf_iterate+0xbc/0x130 Status: 1000f403 KERNEL EXL IE Cause : 00800008 BadVA : c00a6828 PrId : 00019374 Modules linked in: ip_nat_pptp ip_conntrack_pptp ath_pktlog wlan_acl wlan_wep wlan_tkip wlan_ccmp wlan_xauth ath_pci ath_dev ath_dfs ath_rate_atheros wlan ath_hal ip_nat_tftp ip_conntrack_tftp ip_nat_ftp ip_conntrack_ftp pppoe ppp_async ppp_deflate ppp_mppe pppox ppp_generic slhc Process swapper (pid: 0, threadinfo=802a4000, task=802a6000) Stack : 801e7d98 00000004 802a5a60 80000000 801d4e7c 801d4e7c 802a5ad0 00000004 00000000 00000000 801e7d98 00000000 00000004 802a5ad0 00000000 00000010 801e7d98 80b46000 802a5a60 80320000 80000000 801d4f8c 802a5b00 00000002 80063834 00000000 80b46000 802a5a60 801e7d98 80000000 802ba854 00000000 81a02180 80b7e260 81a021b0 819b0000 819b0000 80570056 00000000 00000001 ... Call Trace: [<801e7d98>] ip_finish_output+0x0/0x23c [<801d4e7c>] nf_iterate+0xbc/0x130 [<801d4e7c>] nf_iterate+0xbc/0x130 [<801e7d98>] ip_finish_output+0x0/0x23c [<801e7d98>] ip_finish_output+0x0/0x23c [<801d4f8c>] nf_hook_slow+0x9c/0x1a4 One way to fix this would be to split helper cleanup from the unregistration function and invoke it for the H.245 helper, but since ctnetlink needs to be able to find the helper for synchonization purposes, a better fix is to register it normally and make sure its not assigned to connections during helper lookup. The missing l3num initialization is enough for this, this patch changes it to use AF_UNSPEC to make it more explicit though. Reported-by: liannan <[email protected]> Signed-off-by: Patrick McHardy <[email protected]> Signed-off-by: David S. Miller <[email protected]>
1 parent 8a54886 commit a56b8f8

File tree

1 file changed

+14
-7
lines changed

1 file changed

+14
-7
lines changed

net/netfilter/nf_conntrack_h323_main.c

Lines changed: 14 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -619,6 +619,7 @@ static const struct nf_conntrack_expect_policy h245_exp_policy = {
619619
static struct nf_conntrack_helper nf_conntrack_helper_h245 __read_mostly = {
620620
.name = "H.245",
621621
.me = THIS_MODULE,
622+
.tuple.src.l3num = AF_UNSPEC,
622623
.tuple.dst.protonum = IPPROTO_UDP,
623624
.help = h245_help,
624625
.expect_policy = &h245_exp_policy,
@@ -1765,6 +1766,7 @@ static void __exit nf_conntrack_h323_fini(void)
17651766
nf_conntrack_helper_unregister(&nf_conntrack_helper_ras[0]);
17661767
nf_conntrack_helper_unregister(&nf_conntrack_helper_q931[1]);
17671768
nf_conntrack_helper_unregister(&nf_conntrack_helper_q931[0]);
1769+
nf_conntrack_helper_unregister(&nf_conntrack_helper_h245);
17681770
kfree(h323_buffer);
17691771
pr_debug("nf_ct_h323: fini\n");
17701772
}
@@ -1777,27 +1779,32 @@ static int __init nf_conntrack_h323_init(void)
17771779
h323_buffer = kmalloc(65536, GFP_KERNEL);
17781780
if (!h323_buffer)
17791781
return -ENOMEM;
1780-
ret = nf_conntrack_helper_register(&nf_conntrack_helper_q931[0]);
1782+
ret = nf_conntrack_helper_register(&nf_conntrack_helper_h245);
17811783
if (ret < 0)
17821784
goto err1;
1783-
ret = nf_conntrack_helper_register(&nf_conntrack_helper_q931[1]);
1785+
ret = nf_conntrack_helper_register(&nf_conntrack_helper_q931[0]);
17841786
if (ret < 0)
17851787
goto err2;
1786-
ret = nf_conntrack_helper_register(&nf_conntrack_helper_ras[0]);
1788+
ret = nf_conntrack_helper_register(&nf_conntrack_helper_q931[1]);
17871789
if (ret < 0)
17881790
goto err3;
1789-
ret = nf_conntrack_helper_register(&nf_conntrack_helper_ras[1]);
1791+
ret = nf_conntrack_helper_register(&nf_conntrack_helper_ras[0]);
17901792
if (ret < 0)
17911793
goto err4;
1794+
ret = nf_conntrack_helper_register(&nf_conntrack_helper_ras[1]);
1795+
if (ret < 0)
1796+
goto err5;
17921797
pr_debug("nf_ct_h323: init success\n");
17931798
return 0;
17941799

1795-
err4:
1800+
err5:
17961801
nf_conntrack_helper_unregister(&nf_conntrack_helper_ras[0]);
1797-
err3:
1802+
err4:
17981803
nf_conntrack_helper_unregister(&nf_conntrack_helper_q931[1]);
1799-
err2:
1804+
err3:
18001805
nf_conntrack_helper_unregister(&nf_conntrack_helper_q931[0]);
1806+
err2:
1807+
nf_conntrack_helper_unregister(&nf_conntrack_helper_h245);
18011808
err1:
18021809
kfree(h323_buffer);
18031810
return ret;

0 commit comments

Comments
 (0)