Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/dev/qbus Make if_il.c compilable again.



details:   https://anonhg.NetBSD.org/src/rev/e5dbd8161f47
branches:  trunk
changeset: 999196:e5dbd8161f47
user:      msaitoh <msaitoh%NetBSD.org@localhost>
date:      Fri May 24 08:29:17 2019 +0000

description:
Make if_il.c compilable again.

diffstat:

 sys/dev/qbus/if_il.c |  51 ++++++++++++++++++++++++---------------------------
 1 files changed, 24 insertions(+), 27 deletions(-)

diffs (127 lines):

diff -r 9d866c065efe -r e5dbd8161f47 sys/dev/qbus/if_il.c
--- a/sys/dev/qbus/if_il.c      Fri May 24 08:27:44 2019 +0000
+++ b/sys/dev/qbus/if_il.c      Fri May 24 08:29:17 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_il.c,v 1.33 2019/05/24 08:27:44 msaitoh Exp $       */
+/*     $NetBSD: if_il.c,v 1.34 2019/05/24 08:29:17 msaitoh Exp $       */
 /*
  * Copyright (c) 1982, 1986 Regents of the University of California.
  * All rights reserved.
@@ -35,7 +35,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_il.c,v 1.33 2019/05/24 08:27:44 msaitoh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_il.c,v 1.34 2019/05/24 08:29:17 msaitoh Exp $");
 
 #include "opt_inet.h"
 
@@ -116,7 +116,7 @@
 static void ilcint(void *);
 static void ilrint(void *);
 static void ilreset(device_t);
-static int ilwait(struct il_softc *, char *);
+static int ilwait(struct il_softc *, const char *);
 static int ilinit(struct ifnet *);
 static void ilstart(struct ifnet *);
 static void ilwatch(struct ifnet *);
@@ -137,12 +137,11 @@
 ilmatch(device_t parent, cfdata_t cf, void *aux)
 {
        struct uba_attach_args *ua = aux;
-       volatile int i;
 
        bus_space_write_2(ua->ua_iot, ua->ua_ioh, IL_CSR,
            ILC_OFFLINE | IL_CIE);
        DELAY(100000);
-       i = bus_space_read_2(ua->ua_iot, ua->ua_ioh, IL_CSR); /* clear CDONE */
+       bus_space_read_2(ua->ua_iot, ua->ua_ioh, IL_CSR); /* clear CDONE */
 
        return 1;
 }
@@ -202,7 +201,7 @@
 
        strlcpy(ifp->if_xname, device_xname(sc->sc_dev), IFNAMSIZ);
        ifp->if_softc = sc;
-       ifp->if_flags = IFF_BROADCAST;
+       ifp->if_flags = IFF_BROADCAST | IFF_SIMPLEX | IFF_MULTICAST;
        ifp->if_init = ilinit;
        ifp->if_stop = ilstop;
        ifp->if_ioctl = ether_ioctl;
@@ -224,7 +223,7 @@
 
 
 int
-ilwait(struct il_softc *sc, char *op)
+ilwait(struct il_softc *sc, const char *op)
 {
 
        while ((IL_RCSR(IL_CSR)&IL_CDONE) == 0)
@@ -325,19 +324,18 @@
                        goto out;
                }
        }
-#ifdef MULTICAST
-       if (is->is_if.if_flags & IFF_PROMISC) {
-               addr->il_csr = ILC_PRMSC;
-               if (ilwait(ui, "all multi"))
+       if (sc->sc_if.if_flags & IFF_PROMISC) {
+               IL_WCSR(IL_CSR, ILC_PRMSC);
+               if (ilwait(sc, "all multi"))
                        goto out;
-       } else if (is->is_if.if_flags & IFF_ALLMULTI) {
-       too_many_multis:
-               addr->il_csr = ILC_ALLMC;
-               if (ilwait(ui, "all multi"))
+       } else if (sc->sc_if.if_flags & IFF_ALLMULTI) {
+too_many_multis:
+               IL_WCSR(IL_CSR, ILC_ALLMC);
+               if (ilwait(sc, "all multi"))
                        goto out;
        } else {
                int i;
-               register struct ether_addr *ep = is->is_maddrs;
+               register struct ether_addr *ep = sc->sc_maddrs;
                struct ether_multi *enm;
                struct ether_multistep step;
                /*
@@ -347,29 +345,28 @@
                 * multicasts.
                 */
                i = 0;
-               ETHER_FIRST_MULTI(step, &is->is_ac, enm);
+               ETHER_FIRST_MULTI(step, &sc->sc_ec, enm);
                while (enm != NULL) {
-                       if (++i > 63 && k != 0) {
+                       if (++i > 63 /* && k != 0 */) {
                                break;
                        }
                        *ep++ = *(struct ether_addr *)enm->enm_addrlo;
                        ETHER_NEXT_MULTI(step, enm);
                }
-               if (i = 0) {
+               if (i == 0) {
                        /* no multicasts! */
                } else if (i <= 63) {
-                       addr->il_bar = is->is_ubaddr & 0xffff;
-                       addr->il_bcr = i * sizeof (struct ether_addr);
-                       addr->il_csr = ((is->is_ubaddr >> 2) & IL_EUA)|
-                                               LC_LDGRPS;
-                       if (ilwait(ui, "load multi"))
+                       IL_WCSR(IL_BAR, sc->sc_ubaddr & 0xffff);
+                       IL_WCSR(IL_BCR, i * sizeof(struct ether_addr));
+                       IL_WCSR(IL_CSR,
+                           ((sc->sc_ubaddr >> 2) & IL_EUA) | ILC_LDGRPS);
+                       if (ilwait(sc, "load multi"))
                                goto out;
                } else {
-                   is->is_if.if_flags |= IFF_ALLMULTI;
-                   goto too_many_multis;
+                       sc->sc_if.if_flags |= IFF_ALLMULTI;
+                       goto too_many_multis;
                }
        }
-#endif /* MULTICAST */
        /*
         * Set board online.
         * Hang receive buffer and start any pending



Home | Main Index | Thread Index | Old Index