Subject: port-macppc/7028: macppc, src/sys/dev/pci/if_de.c Endian problem
To: None <gnats-bugs@gnats.netbsd.org>
From: None <makoto@ki.nu>
List: netbsd-bugs
Date: 02/21/1999 23:52:50
>Number:         7028
>Category:       port-macppc
>Synopsis:       macppc, src/sys/dev/pci/if_de.c Endian problem
>Confidential:   no
>Severity:       serious
>Priority:       medium
>Responsible:    port-macppc-maintainer (NetBSD/macppc Portmaster)
>State:          open
>Class:          sw-bug
>Submitter-Id:   net
>Arrival-Date:   Sun Feb 21 07:05:01 1999
>Last-Modified:
>Originator:     
>Organization:
	Fujiwara Family at Nagazu	
	
>Release:        NetBSD-current source 1999/02/20
>Environment:
	
System: NetBSD harry 1.3I NetBSD 1.3I (DE) #3: Sun Feb 21 23:14:05 JST 1999 root@harry:/usr/src/sys/arch/macppc/compile/DE macppc
         PowerMac clone, actually StarMax 3000/240

>Description:
	
	(1) GENERIC kernel does not have de device activated. (It may be OK)
        (2) My Ethernet/pci card is Sonic made, using DEC 21041 chip. 
            Once de device enabled at config for macppc, endian problem arises.
            No network activities go well, no response at all for network.
        (2-a) I also have found typo at src/sys/dev/pci/if_devar.h  arround line
            1069.
            TULUP_RESTORESPL
               |
               v
            TULIP_RESTORESPL
        (3) ifconfig looks OK, but actually nothing works.
-------------------
root@harry  22:27:38/990221(~)# ifconfig -a
de0: flags=8c63<UP,BROADCAST,NOTRAILERS,RUNNING,OACTIVE,SIMPLEX,MULTICAST> mtu 1500
        address: 00:40:10:09:77:f1
        media: Ethernet autoselect (10baseT)
        status: active
        inet 210.145.40.xxx netmask 0xfffffff0 broadcast 210.145.40.xxx
lo0: flags=8009<UP,LOOPBACK,MULTICAST> mtu 32976
        inet 127.0.0.1 netmask 0xff000000 
ppp0: flags=8010<POINTOPOINT,MULTICAST> mtu 1500
ppp1: flags=8010<POINTOPOINT,MULTICAST> mtu 1500
sl0: flags=c010<POINTOPOINT,LINK2,MULTICAST> mtu 296
sl1: flags=c010<POINTOPOINT,LINK2,MULTICAST> mtu 296
tun0: flags=10<POINTOPOINT> mtu 1500
tun1: flags=10<POINTOPOINT> mtu 1500
tun2: flags=10<POINTOPOINT> mtu 1500
tun3: flags=10<POINTOPOINT> mtu 1500
-------------------

        (4) at booting it pauses at ypbind starting, and Control-C get 
            proceed further, amd starting needs to timeout to proceed. 
        (5) for ping,
	root@harry  22:28:16/990221(~)# ping 210.145.40.yyy
	PING 210.145.40.yyy (210.145.40.yyy): 56 data bytes
	ping: sendto: Host is down
	..... (repeat)...
	ping: sendto: Host is down
	^C
	----210.145.40.yyy PING Statistics----
	10 packets transmitted, 0 packets received, 100.0% packet loss

>How-To-Repeat:
	
	Get following line in GENERIC, and use DEC card.
	de* at pci? dev ? function ?        # DEC 21x4x-based Ethernet
>Fix:

	
        Use following patch,

--- src/sys/dev/pci/if_de.c.orig	Tue Nov 10 21:18:11 1998
+++ src/sys/dev/pci/if_de.c	Sun Feb 21 22:40:07 1999
@@ -3094,7 +3094,11 @@
 	while (enm != NULL) {
 		if (bcmp(enm->enm_addrlo, enm->enm_addrhi, 6) == 0) {
 		    hash = tulip_mchash(enm->enm_addrlo);
+#if BYTE_ORDER == BIG_ENDIAN
+		    sp[hash >> 4] |= (1 << (hash & 0xF)) << 16;
+#else
 		    sp[hash >> 4] |= 1 << (hash & 0xF);
+#endif
 		} else {
 		    sc->tulip_flags |= TULIP_ALLMULTI;
 		    sc->tulip_flags &= ~(TULIP_WANTHASHONLY|TULIP_WANTHASHPERFECT);
@@ -3108,14 +3112,28 @@
 	 */
 	if ((sc->tulip_flags & TULIP_ALLMULTI) == 0) {
 	    hash = tulip_mchash(etherbroadcastaddr);
+#if BYTE_ORDER == BIG_ENDIAN
+	    sp[hash >> 4] |= (1 << (hash & 0xF)) << 16;
+#else
 	    sp[hash >> 4] |= 1 << (hash & 0xF);
+#endif
 	    if (sc->tulip_flags & TULIP_WANTHASHONLY) {
 		hash = tulip_mchash(sc->tulip_enaddr);
+#if BYTE_ORDER == BIG_ENDIAN
+		sp[hash >> 4] |= (1 << (hash & 0xF)) << 16;
+#else
 		sp[hash >> 4] |= 1 << (hash & 0xF);
+#endif
 	    } else {
+#if BYTE_ORDER == BIG_ENDIAN
+		sp[39] = ((u_int16_t *) sc->tulip_enaddr)[0] << 16;
+		sp[40] = ((u_int16_t *) sc->tulip_enaddr)[1] << 16;
+		sp[41] = ((u_int16_t *) sc->tulip_enaddr)[2] << 16;
+#else
 		sp[39] = ((u_int16_t *) sc->tulip_enaddr)[0]; 
 		sp[40] = ((u_int16_t *) sc->tulip_enaddr)[1]; 
 		sp[41] = ((u_int16_t *) sc->tulip_enaddr)[2];
+#endif
 	    }
 	}
     }
@@ -3129,9 +3147,15 @@
 	    ETHER_FIRST_MULTI(step, TULIP_ETHERCOM(sc), enm);
 	    for (; enm != NULL; idx++) {
 		if (bcmp(enm->enm_addrlo, enm->enm_addrhi, 6) == 0) {
+#if BYTE_ORDER == BIG_ENDIAN
+		    *sp++ = ((u_int16_t *) enm->enm_addrlo)[0] << 16;
+		    *sp++ = ((u_int16_t *) enm->enm_addrlo)[1] << 16;
+		    *sp++ = ((u_int16_t *) enm->enm_addrlo)[2] << 16;
+#else
 		    *sp++ = ((u_int16_t *) enm->enm_addrlo)[0]; 
 		    *sp++ = ((u_int16_t *) enm->enm_addrlo)[1]; 
 		    *sp++ = ((u_int16_t *) enm->enm_addrlo)[2];
+#endif
 		} else {
 		    sc->tulip_flags |= TULIP_ALLMULTI;
 		    break;
@@ -3142,17 +3166,29 @@
 	     * Add the broadcast address.
 	     */
 	    idx++;
+#if BYTE_ORDER == BIG_ENDIAN
+	    *sp++ = 0xFFFF << 16;
+	    *sp++ = 0xFFFF << 16;
+	    *sp++ = 0xFFFF << 16;
+#else
 	    *sp++ = 0xFFFF;
 	    *sp++ = 0xFFFF;
 	    *sp++ = 0xFFFF;
+#endif
 	}
 	/*
 	 * Pad the rest with our hardware address
 	 */
 	for (; idx < 16; idx++) {
+#if BYTE_ORDER == BIG_ENDIAN
+	    *sp++ = ((u_int16_t *) sc->tulip_enaddr)[0] << 16;
+	    *sp++ = ((u_int16_t *) sc->tulip_enaddr)[1] << 16;
+	    *sp++ = ((u_int16_t *) sc->tulip_enaddr)[2] << 16;
+#else
 	    *sp++ = ((u_int16_t *) sc->tulip_enaddr)[0]; 
 	    *sp++ = ((u_int16_t *) sc->tulip_enaddr)[1]; 
 	    *sp++ = ((u_int16_t *) sc->tulip_enaddr)[2];
+#endif
 	}
     }
 #if defined(IFF_ALLMULTI)
@@ -3202,11 +3238,19 @@
 #else
     TULIP_CSR_WRITE(sc, csr_rxlist, TULIP_KVATOPHYS(sc, &sc->tulip_rxinfo.ri_first[0]));
 #endif
+#ifdef macppc	/* XXX only macppc? */
+    TULIP_CSR_WRITE(sc, csr_busmode,
+		    (1 << (TULIP_BURSTSIZE(sc->tulip_unit) + 8))
+		    |TULIP_BUSMODE_CACHE_ALIGN8
+		    |TULIP_BUSMODE_READMULTIPLE
+		    |TULIP_BUSMODE_DESC_BIGENDIAN);
+#else
     TULIP_CSR_WRITE(sc, csr_busmode,
 		    (1 << (TULIP_BURSTSIZE(sc->tulip_unit) + 8))
 		    |TULIP_BUSMODE_CACHE_ALIGN8
 		    |TULIP_BUSMODE_READMULTIPLE
 		    |(BYTE_ORDER != LITTLE_ENDIAN ? TULIP_BUSMODE_BIGENDIAN : 0));
+#endif
 
     sc->tulip_txtimer = 0;
     sc->tulip_txq.ifq_maxlen = TULIP_TXDESCS;
@@ -3823,7 +3867,11 @@
     const char * const *msgp = tulip_status_bits;
     const char *sep;
     u_int32_t mask;
+#ifdef macppc
+    const char thrsh[] = "72|128\0\0\0" "00096|256\0\0\0" "000128|512\0\0" "000160|1024";
+#else
     const char thrsh[] = "72|128\0\0\0" "96|256\0\0\0" "128|512\0\0" "160|1024";
+#endif
 
     csr &= (1 << (sizeof(tulip_status_bits)/sizeof(tulip_status_bits[0]))) - 1;
     printf(TULIP_PRINTF_FMT ": abnormal interrupt:", TULIP_PRINTF_ARGS);
--- src/sys/dev/pci/if_devar.h-ooo	Sun Feb 21 22:46:21 1999
+++ src/sys/dev/pci/if_devar.h	Sun Feb 21 22:45:22 1999
@@ -1060,7 +1060,7 @@
 #ifndef TULIP_RAISESOFTSPL
 #define	TULIP_RAISESOFTSPL()		splnet()
 #endif
-#ifndef TULUP_RESTORESPL
+#ifndef TULIP_RESTORESPL
 #define	TULIP_RESTORESPL(s)		splx(s)
 #endif
 
>Audit-Trail:
>Unformatted: