lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Date:	Mon, 29 Jun 2009 15:58:36 -0500
From:	John Dykstra <john.dykstra1@...il.com>
To:	Eric Sesterhenn <eric.sesterhenn@...xperts.de>
Cc:	netdev@...r.kernel.org
Subject: Re: Soft lockup caused by icmpv6fuzz

On Mon, 2009-06-29 at 15:14 +0200, Eric Sesterhenn wrote:
> 
> with todays -git, my test box dies while running
> 
> icmpv6fuzz -r 29765
> 
> 
> [ 9461.816017] BUG: soft lockup - CPU#0 stuck for 61s!
> [icmpv6fuzz:29765]
> [ 9461.816017] Modules linked in: ip6table_filter ip6_tables af_packet
> nfsd exportfs nfs lockd nfs_acl auth_rpcgss sunrpc ipv6 fuse unix
> [last
> unloaded: rcutorture]
> [ 9461.816017] irq event stamp: 0
> [ 9461.816017] hardirqs last  enabled at (0): [<(null)>] (null)
> [ 9461.816017] hardirqs last disabled at (0): [<c0126996>]
> copy_process
> +0x256/0x1100
> [ 9461.816017] softirqs last  enabled at (0): [<c0126996>]
> copy_process
> +0x256/0x1100
> [ 9461.816017] softirqs last disabled at (0): [<(null)>] (null)
> [ 9461.816017] 
> [ 9461.816017] Pid: 29765, comm: icmpv6fuzz Not tainted (2.6.31-rc1
> #11) 
> [ 9461.816017] EIP: 0060:[<d08d7fe5>] EFLAGS: 00010246 CPU: 0
> [ 9461.816017] EIP is at __raw_v6_lookup+0x15/0x130 [ipv6]
> [ 9461.816017] EAX: caf81e20 EBX: 00000001 ECX: 0000003a EDX: 00000000
> [ 9461.816017] ESI: cf9f1ca0 EDI: caf5df38 EBP: c08c0e74 ESP: c08c0e54
> [ 9461.816017]  DS: 007b ES: 007b FS: 0000 GS: 00e0 SS: 0068
> [ 9461.816017] CR0: 8005003b CR2: caf81e20 CR3: 0e767000 CR4: 00000690
> [ 9461.816017] DR0: 00000000 DR1: 00000000 DR2: 00000000 DR3: 00000000
> [ 9461.816017] DR6: ffff0ff0 DR7: 00000400
> [ 9461.816017] Call Trace:
> [ 9461.816017]  [<d08d8684>] raw6_local_deliver+0x134/0x210 [ipv6]
> [ 9461.816017]  [<d08c3408>] ip6_input_finish+0xe8/0x370 [ipv6]
> [ 9461.816017]  [<d08c3320>] ? ip6_input_finish+0x0/0x370 [ipv6]
> [ 9461.816017]  [<d08c36e7>] ip6_input+0x57/0x60 [ipv6]
> [ 9461.816017]  [<d08c3320>] ? ip6_input_finish+0x0/0x370 [ipv6]
> [ 9461.816017]  [<d08c2f82>] ip6_rcv_finish+0x12/0x30 [ipv6]
> [ 9461.816017]  [<d08c32bf>] ipv6_rcv+0x31f/0x380 [ipv6]
> [ 9461.816017]  [<d08c2fbd>] ? ipv6_rcv+0x1d/0x380 [ipv6]
> [ 9461.816017]  [<c0519e14>] netif_receive_skb+0x314/0x420
> [ 9461.816017]  [<c0519c38>] ? netif_receive_skb+0x138/0x420
> [ 9461.816017]  [<c0519f7a>] process_backlog+0x5a/0xa0
> [ 9461.816017]  [<c051a77c>] net_rx_action+0x13c/0x1f0
> [ 9461.816017]  [<c051a70a>] ? net_rx_action+0xca/0x1f0
> [ 9461.816017]  [<c012d20f>] __do_softirq+0x7f/0x120
> [ 9461.816017]  [<c012d190>] ? __do_softirq+0x0/0x120
> [ 9461.816017]  <IRQ>  [<c051c2a2>] ? dev_queue_xmit+0x112/0x4d0
> [ 9461.816017]  [<c012d0e7>] ? local_bh_enable+0xa7/0xb0
> [ 9461.816017]  [<c051c2a2>] ? dev_queue_xmit+0x112/0x4d0
> [ 9461.816017]  [<c051c1c8>] ? dev_queue_xmit+0x38/0x4d0
> [ 9461.816017]  [<d08c0353>] ? ip6_output_finish+0x73/0xc0 [ipv6]
> [ 9461.816017]  [<d08c23d8>] ? ip6_output2+0x128/0x200 [ipv6]
> [ 9461.816017]  [<d08c29bd>] ? ip6_output+0x50d/0xac0 [ipv6]
> [ 9461.816017]  [<c053ed99>] ? nf_iterate+0x69/0x80
> [ 9461.816017]  [<c053f036>] ? nf_hook_slow+0xf6/0x110
> [ 9461.816017]  [<d08c00f0>] ? dst_output+0x0/0x10 [ipv6]
> [ 9461.816017]  [<d08c18b2>] ? __ip6_local_out+0x72/0x80 [ipv6]
> [ 9461.816017]  [<d08c18d8>] ? ip6_local_out+0x18/0x30 [ipv6]
> [ 9461.816017]  [<d08c1c35>] ? ip6_push_pending_frames+0x345/0x400
> [ipv6]
> [ 9461.816017]  [<d08d7a16>] ? rawv6_sendmsg+0xc26/0xc90 [ipv6]
> [ 9461.816017]  [<c02f676c>] ? copy_from_user+0x4c/0x130
> [ 9461.816017]  [<c011ac8b>] ? __bad_area_nosemaphore+0x5b/0x170
> [ 9461.816017]  [<c014ddcb>] ? trace_hardirqs_on+0xb/0x10
> [ 9461.816017]  [<c012d490>] ? local_bh_enable_ip+0x60/0xb0
> [ 9461.816017]  [<c05c9463>] ? i2o_pci_probe+0x4c3/0x6c0
> [ 9461.816017]  [<c013a2b7>] ? search_exception_tables+0x17/0x40
> [ 9461.816017]  [<c02f5e8d>] ? __get_user_4+0x11/0x17
> [ 9461.816017]  [<c0592764>] ? inet_sendmsg+0x34/0x60
> [ 9461.816017]  [<c050c499>] ? sock_sendmsg+0xe9/0x110
> [ 9461.816017]  [<c013c670>] ? autoremove_wake_function+0x0/0x50
> [ 9461.816017]  [<c0103177>] ? restore_all_notrace+0x0/0x18
> [ 9461.816017]  [<c0184751>] ? might_fault+0x91/0xa0
> [ 9461.816017]  [<c0184706>] ? might_fault+0x46/0xa0
> [ 9461.816017]  [<c02f6755>] ? copy_from_user+0x35/0x130
> [ 9461.816017]  [<c050c880>] ? sys_sendto+0xf0/0x130
> [ 9461.816017]  [<c050a8d0>] ? sock_ioctl+0x0/0x240
> [ 9461.816017]  [<c0184751>] ? might_fault+0x91/0xa0
> [ 9461.816017]  [<c0184706>] ? might_fault+0x46/0xa0
> [ 9461.816017]  [<c050cfbb>] ? sys_socketcall+0x18b/0x2a0
> [ 9461.816017]  [<c010305b>] ? sysenter_do_call+0x12/0x32
> 
> 
> 
> [  667.868016] BUG: soft lockup - CPU#0 stuck for 61s!
> [icmpv6fuzz:3995]
> [  667.868016] Modules linked in: nfsd exportfs nfs lockd nfs_acl
> auth_rpcgss sunrpc ipv6 fuse unix
> [  667.868016] irq event stamp: 0
> [  667.868016] hardirqs last  enabled at (0): [<(null)>] (null)
> [  667.868016] hardirqs last disabled at (0): [<c0126996>]
> copy_process
> +0x256/0x1100
> [  667.868016] softirqs last  enabled at (0): [<c0126996>]
> copy_process
> +0x256/0x1100
> [  667.868016] softirqs last disabled at (0): [<(null)>] (null)
> [  667.868016] 
> [  667.868016] Pid: 3995, comm: icmpv6fuzz Not tainted (2.6.31-rc1
> #11) 
> [  667.868016] EIP: 0060:[<d0851fe5>] EFLAGS: 00010246 CPU: 0
> [  667.868016] EIP is at __raw_v6_lookup+0x15/0x130 [ipv6]
> [  667.868016] EAX: c355de20 EBX: 00000001 ECX: 0000003a EDX: 00000000
> [  667.868016] ESI: c3557ca0 EDI: c355af38 EBP: c08c0e74 ESP: c08c0e54
> [  667.868016]  DS: 007b ES: 007b FS: 0000 GS: 00e0 SS: 0068
> [  667.868016] CR0: 8005003b CR2: c355de20 CR3: 03534000 CR4: 00000690
> [  667.868016] DR0: 00000000 DR1: 00000000 DR2: 00000000 DR3: 00000000
> [  667.868016] DR6: ffff0ff0 DR7: 00000400
> [  667.868016] Call Trace:
> [  667.868016]  [<d0852684>] raw6_local_deliver+0x134/0x210 [ipv6]
> [  667.868016]  [<d083d408>] ip6_input_finish+0xe8/0x370 [ipv6]
> [  667.868016]  [<d083d320>] ? ip6_input_finish+0x0/0x370 [ipv6]
> [  667.868016]  [<d083d6e7>] ip6_input+0x57/0x60 [ipv6]
> [  667.868016]  [<d083cf82>] ip6_rcv_finish+0x12/0x30 [ipv6]
> [  667.868016]  [<d083d2bf>] ipv6_rcv+0x31f/0x380 [ipv6]
> [  667.868016]  [<d083cfbd>] ? ipv6_rcv+0x1d/0x380 [ipv6]
> [  667.868016]  [<c0519e14>] netif_receive_skb+0x314/0x420
> [  667.868016]  [<c0519c38>] ? netif_receive_skb+0x138/0x420
> [  667.868016]  [<c0519f7a>] process_backlog+0x5a/0xa0
> [  667.868016]  [<c051a77c>] net_rx_action+0x13c/0x1f0
> [  667.868016]  [<c051a70a>] ? net_rx_action+0xca/0x1f0
> [  667.868016]  [<c012d20f>] __do_softirq+0x7f/0x120
> [  667.868016]  [<c012d190>] ? __do_softirq+0x0/0x120
> [  667.868016]  <IRQ>  [<c051c2a2>] ? dev_queue_xmit+0x112/0x4d0
> [  667.868016]  [<c012d0e7>] ? local_bh_enable+0xa7/0xb0
> [  667.868016]  [<c051c2a2>] ? dev_queue_xmit+0x112/0x4d0
> [  667.868016]  [<c051c1c8>] ? dev_queue_xmit+0x38/0x4d0
> [  667.868016]  [<d083a353>] ? ip6_output_finish+0x73/0xc0 [ipv6]
> [  667.868016]  [<d083c3d8>] ? ip6_output2+0x128/0x200 [ipv6]
> [  667.868016]  [<d083c9bd>] ? ip6_output+0x50d/0xac0 [ipv6]
> [  667.868016]  [<c056bf8e>] ? ip_generic_getfrag+0x3e/0xb0
> [  667.868016]  [<d083a6a1>] ? ip6_append_data+0x231/0xb10 [ipv6]
> [  667.868016]  [<c056bf50>] ? ip_generic_getfrag+0x0/0xb0
> [  667.868016]  [<d083b8d8>] ? ip6_local_out+0x18/0x30 [ipv6]
> [  667.868016]  [<d083bc35>] ? ip6_push_pending_frames+0x345/0x400
> [ipv6]
> [  667.868016]  [<d0851a16>] ? rawv6_sendmsg+0xc26/0xc90 [ipv6]
> [  667.868016]  [<c02f676c>] ? copy_from_user+0x4c/0x130
> [  667.868016]  [<c011ac8b>] ? __bad_area_nosemaphore+0x5b/0x170
> [  667.868016]  [<c014ddcb>] ? trace_hardirqs_on+0xb/0x10
> [  667.868016]  [<c012d490>] ? local_bh_enable_ip+0x60/0xb0
> [  667.868016]  [<c05ca394>] ? piix4_probe+0x574/0x68d
> [  667.868016]  [<c011b91e>] ? fixup_exception+0xe/0x50
> [  667.868016]  [<c0592764>] ? inet_sendmsg+0x34/0x60
> [  667.868016]  [<c050c499>] ? sock_sendmsg+0xe9/0x110
> [  667.868016]  [<c0184706>] ? might_fault+0x46/0xa0
> [  667.868016]  [<c013c670>] ? autoremove_wake_function+0x0/0x50
> [  667.868016]  [<c0184751>] ? might_fault+0x91/0xa0
> [  667.868016]  [<c0184706>] ? might_fault+0x46/0xa0
> [  667.868016]  [<c02f6755>] ? copy_from_user+0x35/0x130
> [  667.868016]  [<c050c880>] ? sys_sendto+0xf0/0x130
> [  667.868016]  [<c050a8d0>] ? sock_ioctl+0x0/0x240
> [  667.868016]  [<c0184751>] ? might_fault+0x91/0xa0
> [  667.868016]  [<c0184706>] ? might_fault+0x46/0xa0
> [  667.868016]  [<c050cfbb>] ? sys_socketcall+0x18b/0x2a0
> [  667.868016]  [<c010305b>] ? sysenter_do_call+0x12/0x32
> 
> 
> 
> (gdb) l *(ip6_input_finish+0xe8)
> 0x5408 is in ip6_input_finish (net/ipv6/ip6_input.c:184).
> 179             nexthdr = skb_network_header(skb)[nhoff];
> 180     
> 181             raw = raw6_local_deliver(skb, nexthdr);
> 182     
> 183             hash = nexthdr & (MAX_INET_PROTOS - 1);
> 184             if ((ipprot = rcu_dereference(inet6_protos[hash])) !=
> NULL) {
> 185                     int ret;
> 186     
> 187                     if (ipprot->flags & INET6_PROTO_FINAL) {
> 188                             struct ipv6hdr *hdr;
> (gdb) l *(raw6_local_deliver+0x134)
> 0x1a684 is in raw6_local_deliver (net/ipv6/raw.c:176).
> 171                     goto out;
> 172     
> 173             net = dev_net(skb->dev);
> 174             sk = __raw_v6_lookup(net, sk, nexthdr, daddr, saddr,
> IP6CB(skb)->iif);
> 175     
> 176             while (sk) {
> 177                     int filtered;
> 178     
> 179                     delivered = 1;
> 180                     switch (nexthdr) {
> 
> 
> The testcase itself is attached, please let me know if you
> need further information

.config, please?  When did you last run icmpv6fuzz before this?

  --  John

--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ