Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 18 Nov 2009 14:55:21 -0800
From:      Pyun YongHyeon <pyunyh@gmail.com>
To:        Warren Block <wblock@wonkity.com>
Cc:        current@freebsd.org
Subject:   Re: sendmail aliases/Realtek 8111 problem (bin/139870)
Message-ID:  <20091118225521.GO1262@michelle.cdnetworks.com>
In-Reply-To: <alpine.BSF.2.00.0911171926340.98349@wonkity.com>
References:  <alpine.BSF.2.00.0911171926340.98349@wonkity.com>

next in thread | previous in thread | raw e-mail | index | archive | help

--Pk6IbRAofICFmK5e
Content-Type: text/plain; charset=us-ascii
Content-Disposition: inline

On Tue, Nov 17, 2009 at 07:55:43PM -0700, Warren Block wrote:
> sendmail was ignoring existing aliases on startup.  This is apparently 
> due to a network interface not being ready in time in combination with a 
> not-FQDN hostname.
> 
> With a hostname of "lightning" (no domain), re0 configured by DHCP, and 
> verbose sendmail logging:
> 
> 050 WARNING: interface re0 is UP with 0.0.0.0 address
> 050 WARNING: local host name (lightning) is not qualified; see cf/README: 
> WHO AM I
> 
> A restart of sendmail after startup works normally because re0 has 
> acquired an address by then.  Entering a FQDN as hostname 
> (hostname="lightning.wonkity.com") in rc.conf works also.
> 
> I would say that this is really a problem with re0 and not with sendmail 
> startup, but don't really know.
> 
> re0 does a DOWN/UP three times on startup.
> 

I'm not sure but this can happen on all systems that have to use
DHCP. The problem I can see here is unnecessary re(4) interface
reinitialization triggered by dhclient even if it can avoid most of
them. Would you try attached patch? It may reduce the number of
interface UP/DOWNs during getting an IP address via DHCP. I haven't
tested the patch though, I no longer have access to re(4)
hardwares.

> re0: <RealTek 
> 8168/8168B/8168C/8168CP/8168D/8168DP/8111B/8111C/8111CP/8111DP PCIe Gigabit 
> Ethernet> port 0xe800-0xe8ff mem 
> 0xfdfff000-0xfdffffff,0xfdfe0000-0xfdfeffff irq 17 at device 0.0 on pci4
> 
> re0@pci0:4:0:0:	class=0x020000 card=0x514c1462 chip=0x816810ec 
> rev=0x02 hdr=0x00
>     vendor     = 'Realtek Semiconductor'
>     device     = 'Gigabit Ethernet NIC(NDIS 6.0) (RTL8168/8111)'
>     class      = network
>     subclass   = ethernet
> 
> -Warren Block * Rapid City, South Dakota USA

--Pk6IbRAofICFmK5e
Content-Type: text/x-diff; charset=us-ascii
Content-Disposition: attachment; filename="re.init.patch"

Index: sys/dev/re/if_re.c
===================================================================
--- sys/dev/re/if_re.c	(revision 199490)
+++ sys/dev/re/if_re.c	(working copy)
@@ -753,6 +753,7 @@
 
 	ifp->if_flags |= IFF_PROMISC;
 	sc->rl_testmode = 1;
+	ifp->if_drv_flags &= ~IFF_DRV_RUNNING;
 	re_init_locked(sc);
 	sc->rl_flags |= RL_FLAG_LINK;
 	if (sc->rl_type == RL_8169)
@@ -2145,8 +2146,10 @@
 		 * XXX check behaviour on receiver stalls.
 		 */
 
-		if (status & RL_ISR_SYSTEM_ERR)
+		if (status & RL_ISR_SYSTEM_ERR) {
+			ifp->if_drv_flags &= ~IFF_DRV_RUNNING;
 			re_init_locked(sc);
+		}
 	}
 	return (rx_npkts);
 }
@@ -2222,8 +2225,10 @@
 	    RL_ISR_TX_ERR|RL_ISR_TX_DESC_UNAVAIL))
 		re_txeof(sc);
 
-	if (status & RL_ISR_SYSTEM_ERR)
+	if (status & RL_ISR_SYSTEM_ERR) {
+		ifp->if_drv_flags &= ~IFF_DRV_RUNNING;
 		re_init_locked(sc);
+	}
 
 	if (!IFQ_DRV_IS_EMPTY(&ifp->if_snd))
 		taskqueue_enqueue_fast(taskqueue_fast, &sc->rl_txtask);
@@ -2539,6 +2544,9 @@
 
 	mii = device_get_softc(sc->rl_miibus);
 
+	if ((ifp->if_drv_flags & IFF_DRV_RUNNING) != 0)
+		return;
+
 	/*
 	 * Cancel pending I/O and free all RX/TX buffers.
 	 */
@@ -2793,7 +2801,8 @@
 	case SIOCADDMULTI:
 	case SIOCDELMULTI:
 		RL_LOCK(sc);
-		re_set_rxmode(sc);
+		if ((ifp->if_drv_flags & IFF_DRV_RUNNING) != 0)
+			re_set_rxmode(sc);
 		RL_UNLOCK(sc);
 		break;
 	case SIOCGIFMEDIA:
@@ -2862,8 +2871,10 @@
 			if ((mask & IFCAP_WOL_MAGIC) != 0)
 				ifp->if_capenable ^= IFCAP_WOL_MAGIC;
 		}
-		if (reinit && ifp->if_drv_flags & IFF_DRV_RUNNING)
+		if (reinit && ifp->if_drv_flags & IFF_DRV_RUNNING) {
+			ifp->if_drv_flags &= ~IFF_DRV_RUNNING;
 			re_init(sc);
+		}
 		VLAN_CAPABILITIES(ifp);
 	    }
 		break;
@@ -2899,6 +2910,7 @@
 	ifp->if_oerrors++;
 
 	re_rxeof(sc, NULL);
+	ifp->if_drv_flags &= ~IFF_DRV_RUNNING;
 	re_init_locked(sc);
 	if (!IFQ_DRV_IS_EMPTY(&ifp->if_snd))
 		taskqueue_enqueue_fast(taskqueue_fast, &sc->rl_txtask);
@@ -3011,15 +3023,16 @@
 			    CSR_READ_1(sc, RL_GPIO) | 0x01);
 	}
 
-	/* reinitialize interface if necessary */
-	if (ifp->if_flags & IFF_UP)
-		re_init_locked(sc);
-
 	/*
 	 * Clear WOL matching such that normal Rx filtering
 	 * wouldn't interfere with WOL patterns.
 	 */
 	re_clrwol(sc);
+
+	/* reinitialize interface if necessary */
+	if (ifp->if_flags & IFF_UP)
+		re_init_locked(sc);
+
 	sc->suspended = 0;
 	RL_UNLOCK(sc);
 

--Pk6IbRAofICFmK5e--



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