Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 8 Aug 2011 05:25:51 +0000 (UTC)
From:      Kevin Lo <kevlo@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org
Subject:   svn commit: r224703 - head/sys/net
Message-ID:  <201108080525.p785Pplq032505@svn.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: kevlo
Date: Mon Aug  8 05:25:51 2011
New Revision: 224703
URL: http://svn.freebsd.org/changeset/base/224703

Log:
  In rtinit1(), before rtrequest1_fib() is called, info.rti_flags is
  initialized by flags (function argument) or-ed with ifa->ifa_flags.
  If both NIC has a loopback route to itself, so IFA_RTSELF is set on ifa(s).
  As IFA_RTSELF is defined by RTF_HOST, rtrequest1_fib() is called with
  RTF_HOST flag even if netmask is not NULL. Consequently, netmask is set
  to zero in rtrequest1_fib(), and request to add network route is changed
  under hands to request to add host route.
  
  Tested by:	Andrew Boyer <aboyer at averesystems.com>
  Submitted by:	Svatopluk Kraus <onwahe at gmail dot com>
  Approved by:	re (hrs)

Modified:
  head/sys/net/route.c

Modified: head/sys/net/route.c
==============================================================================
--- head/sys/net/route.c	Mon Aug  8 05:22:09 2011	(r224702)
+++ head/sys/net/route.c	Mon Aug  8 05:25:51 2011	(r224703)
@@ -1478,7 +1478,7 @@ rtinit1(struct ifaddr *ifa, int cmd, int
 		 */
 		bzero((caddr_t)&info, sizeof(info));
 		info.rti_ifa = ifa;
-		info.rti_flags = flags | ifa->ifa_flags;
+		info.rti_flags = flags | (ifa->ifa_flags & ~IFA_RTSELF);
 		info.rti_info[RTAX_DST] = dst;
 		/* 
 		 * doing this for compatibility reasons



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201108080525.p785Pplq032505>