From owner-svn-src-user@FreeBSD.ORG Thu Feb 7 15:22:51 2013 Return-Path: Delivered-To: svn-src-user@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:1900:2254:206a::19:1]) by hub.freebsd.org (Postfix) with ESMTP id B213AA0E; Thu, 7 Feb 2013 15:22:51 +0000 (UTC) (envelope-from ae@FreeBSD.org) Received: from svn.freebsd.org (svn.freebsd.org [IPv6:2001:1900:2254:2068::e6a:0]) by mx1.freebsd.org (Postfix) with ESMTP id 8E11F7FD; Thu, 7 Feb 2013 15:22:51 +0000 (UTC) Received: from svn.freebsd.org ([127.0.1.70]) by svn.freebsd.org (8.14.5/8.14.5) with ESMTP id r17FMpDc001037; Thu, 7 Feb 2013 15:22:51 GMT (envelope-from ae@svn.freebsd.org) Received: (from ae@localhost) by svn.freebsd.org (8.14.5/8.14.5/Submit) id r17FMpj3001036; Thu, 7 Feb 2013 15:22:51 GMT (envelope-from ae@svn.freebsd.org) Message-Id: <201302071522.r17FMpj3001036@svn.freebsd.org> From: "Andrey V. Elsukov" Date: Thu, 7 Feb 2013 15:22:51 +0000 (UTC) To: src-committers@freebsd.org, svn-src-user@freebsd.org Subject: svn commit: r246483 - user/ae/inet6/sys/netinet6 X-SVN-Group: user MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-BeenThere: svn-src-user@freebsd.org X-Mailman-Version: 2.1.14 Precedence: list List-Id: "SVN commit messages for the experimental " user" src tree" List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Thu, 07 Feb 2013 15:22:51 -0000 Author: ae Date: Thu Feb 7 15:22:50 2013 New Revision: 246483 URL: http://svnweb.freebsd.org/changeset/base/246483 Log: Move the multicast check into first place. Modified: user/ae/inet6/sys/netinet6/ip6_input.c Modified: user/ae/inet6/sys/netinet6/ip6_input.c ============================================================================== --- user/ae/inet6/sys/netinet6/ip6_input.c Thu Feb 7 15:20:54 2013 (r246482) +++ user/ae/inet6/sys/netinet6/ip6_input.c Thu Feb 7 15:22:50 2013 (r246483) @@ -652,6 +652,17 @@ ip6_input(struct mbuf *m) passin: /* + * Multicast check. Assume packet is for us to avoid + * prematurely taking locks. + */ + if (IN6_IS_ADDR_MULTICAST(&ip6->ip6_dst)) { + ours = 1; + in6_ifstat_inc(m->m_pkthdr.rcvif, ifs6_in_mcast); + deliverifp = m->m_pkthdr.rcvif; + goto hbhcheck; + } + + /* * Disambiguate address scope zones (if there is ambiguity). * in6_setscope() then also checks and rejects the cases where src or * dst are the loopback address and the receiving interface @@ -664,17 +675,6 @@ passin: } /* - * Multicast check. Assume packet is for us to avoid - * prematurely taking locks. - */ - if (IN6_IS_ADDR_MULTICAST(&ip6->ip6_dst)) { - ours = 1; - in6_ifstat_inc(m->m_pkthdr.rcvif, ifs6_in_mcast); - deliverifp = m->m_pkthdr.rcvif; - goto hbhcheck; - } - - /* * Unicast check */