From owner-freebsd-bugs@FreeBSD.ORG Tue Jul 5 10:10:11 2011 Return-Path: Delivered-To: freebsd-bugs@hub.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id E4FA71065674 for ; Tue, 5 Jul 2011 10:10:11 +0000 (UTC) (envelope-from gnats@FreeBSD.org) Received: from freefall.freebsd.org (freefall.freebsd.org [IPv6:2001:4f8:fff6::28]) by mx1.freebsd.org (Postfix) with ESMTP id A9CFD8FC18 for ; Tue, 5 Jul 2011 10:10:11 +0000 (UTC) Received: from freefall.freebsd.org (localhost [127.0.0.1]) by freefall.freebsd.org (8.14.4/8.14.4) with ESMTP id p65AABeG043378 for ; Tue, 5 Jul 2011 10:10:11 GMT (envelope-from gnats@freefall.freebsd.org) Received: (from gnats@localhost) by freefall.freebsd.org (8.14.4/8.14.4/Submit) id p65AABTG043377; Tue, 5 Jul 2011 10:10:11 GMT (envelope-from gnats) Resent-Date: Tue, 5 Jul 2011 10:10:11 GMT Resent-Message-Id: <201107051010.p65AABTG043377@freefall.freebsd.org> Resent-From: FreeBSD-gnats-submit@FreeBSD.org (GNATS Filer) Resent-To: freebsd-bugs@FreeBSD.org Resent-Reply-To: FreeBSD-gnats-submit@FreeBSD.org, Mike Cui Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 629B0106564A for ; Tue, 5 Jul 2011 10:09:00 +0000 (UTC) (envelope-from nobody@FreeBSD.org) Received: from red.freebsd.org (red.freebsd.org [IPv6:2001:4f8:fff6::22]) by mx1.freebsd.org (Postfix) with ESMTP id 533E68FC1E for ; Tue, 5 Jul 2011 10:09:00 +0000 (UTC) Received: from red.freebsd.org (localhost [127.0.0.1]) by red.freebsd.org (8.14.4/8.14.4) with ESMTP id p65A90hG004853 for ; Tue, 5 Jul 2011 10:09:00 GMT (envelope-from nobody@red.freebsd.org) Received: (from nobody@localhost) by red.freebsd.org (8.14.4/8.14.4/Submit) id p65A90Zd004852; Tue, 5 Jul 2011 10:09:00 GMT (envelope-from nobody) Message-Id: <201107051009.p65A90Zd004852@red.freebsd.org> Date: Tue, 5 Jul 2011 10:09:00 GMT From: Mike Cui To: freebsd-gnats-submit@FreeBSD.org X-Send-Pr-Version: www-3.1 Cc: Subject: kern/158665: kernel pagefault in in6_setscope() X-BeenThere: freebsd-bugs@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Bug reports List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 05 Jul 2011 10:10:12 -0000 >Number: 158665 >Category: kern >Synopsis: kernel pagefault in in6_setscope() >Confidential: no >Severity: critical >Priority: medium >Responsible: freebsd-bugs >State: open >Quarter: >Keywords: >Date-Required: >Class: sw-bug >Submitter-Id: current-users >Arrival-Date: Tue Jul 05 10:10:11 UTC 2011 >Closed-Date: >Last-Modified: >Originator: Mike Cui >Release: 8.2RELEASE >Organization: >Environment: FreeBSD router 8.2-RELEASE FreeBSD 8.2-RELEASE #3 >Description: When I set up a 6to4 tunnel device (stf0) and put it in output only mode according to man stf(4): # ifconfig ne0 inet 133.4.5.6 netmask 0xffffff00 # ifconfig stf0 inet6 2002:8504:0506:0000:a00:5aff:fe38:6f86 \ prefixlen 16 alias deprecated link0 # route add -inet6 2002:: -prefixlen 16 ::1 # route change -inet6 2002:: -prefixlen 16 ::1 -ifp stf0 The kernel often crashes sending traffic to other other 2002::/16 hosts. I think the problem is the "deprecated" address that's causing problems when trying to resolve ipv6 scope. The instruction causing the fault is: c069cee8: 0f b1 96 18 02 00 00 cmpxchg %edx,0x218(%esi) which I think corresponds to this line in the source: int in6_setscope(struct in6_addr *in6, struct ifnet *ifp, u_int32_t *ret_id) { int scope; u_int32_t zoneid = 0; struct scope6_id *sid; IF_AFDATA_LOCK(ifp); <----- HERE The fault virtual address is 0x218, which seems to suggest that ifp passed into this function is NULL. >How-To-Repeat: 1. On a machine with both a public IPv6 address (not 6to4 address) as well as IPv4, create a stf0 device and put it in "output only" mode according to man stf(4). 2. Ping another host using its 6to4 address (2002::/16). >Fix: >Release-Note: >Audit-Trail: >Unformatted: