Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/pci Tidy up and make it look like the other drivers.
details: https://anonhg.NetBSD.org/src/rev/c0cefd113133
branches: trunk
changeset: 349566:c0cefd113133
user: christos <christos%NetBSD.org@localhost>
date: Wed Dec 14 22:21:13 2016 +0000
description:
Tidy up and make it look like the other drivers.
diffstat:
sys/dev/pci/if_sk.c | 82 +++++++++++++++++++++++++++-------------------------
1 files changed, 42 insertions(+), 40 deletions(-)
diffs (116 lines):
diff -r 1149dddfcbad -r c0cefd113133 sys/dev/pci/if_sk.c
--- a/sys/dev/pci/if_sk.c Wed Dec 14 21:52:43 2016 +0000
+++ b/sys/dev/pci/if_sk.c Wed Dec 14 22:21:13 2016 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: if_sk.c,v 1.83 2016/12/08 01:12:01 ozaki-r Exp $ */
+/* $NetBSD: if_sk.c,v 1.84 2016/12/14 22:21:13 christos Exp $ */
/*-
* Copyright (c) 2003 The NetBSD Foundation, Inc.
@@ -115,7 +115,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_sk.c,v 1.83 2016/12/08 01:12:01 ozaki-r Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_sk.c,v 1.84 2016/12/14 22:21:13 christos Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -985,11 +985,38 @@
return rc;
}
+static void
+sk_promisc(struct sk_if_softc *sc_if, int on)
+{
+ struct sk_softc *sc = sc_if->sk_softc;
+ switch (sc->sk_type) {
+ case SK_GENESIS:
+ if (on)
+ SK_XM_SETBIT_4(sc_if, XM_MODE, XM_MODE_RX_PROMISC);
+ else
+ SK_XM_CLRBIT_4(sc_if, XM_MODE, XM_MODE_RX_PROMISC);
+ break;
+ case SK_YUKON:
+ case SK_YUKON_LITE:
+ case SK_YUKON_LP:
+ if (on)
+ SK_YU_CLRBIT_2(sc_if, YUKON_RCR,
+ YU_RCR_UFLEN | YU_RCR_MUFLEN);
+ else
+ SK_YU_SETBIT_2(sc_if, YUKON_RCR,
+ YU_RCR_UFLEN | YU_RCR_MUFLEN);
+ break;
+ default:
+ aprint_error_dev(sc_if->sk_dev, "Can't set promisc for %d\n",
+ sc->sk_type);
+ break;
+ }
+}
+
int
sk_ioctl(struct ifnet *ifp, u_long command, void *data)
{
struct sk_if_softc *sc_if = ifp->if_softc;
- struct sk_softc *sc = sc_if->sk_softc;
int s, error = 0;
/* DPRINTFN(2, ("sk_ioctl\n")); */
@@ -1002,45 +1029,20 @@
DPRINTFN(2, ("sk_ioctl IFFLAGS\n"));
if ((error = ifioctl_common(ifp, command, data)) != 0)
break;
- if (ifp->if_flags & IFF_UP) {
- if (ifp->if_flags & IFF_RUNNING &&
- ifp->if_flags & IFF_PROMISC &&
- !(sc_if->sk_if_flags & IFF_PROMISC)) {
- switch (sc->sk_type) {
- case SK_GENESIS:
- SK_XM_SETBIT_4(sc_if, XM_MODE,
- XM_MODE_RX_PROMISC);
- break;
- case SK_YUKON:
- case SK_YUKON_LITE:
- case SK_YUKON_LP:
- SK_YU_CLRBIT_2(sc_if, YUKON_RCR,
- YU_RCR_UFLEN | YU_RCR_MUFLEN);
- break;
- }
- sk_setmulti(sc_if);
- } else if (ifp->if_flags & IFF_RUNNING &&
- !(ifp->if_flags & IFF_PROMISC) &&
- sc_if->sk_if_flags & IFF_PROMISC) {
- switch (sc->sk_type) {
- case SK_GENESIS:
- SK_XM_CLRBIT_4(sc_if, XM_MODE,
- XM_MODE_RX_PROMISC);
- break;
- case SK_YUKON:
- case SK_YUKON_LITE:
- case SK_YUKON_LP:
- SK_YU_SETBIT_2(sc_if, YUKON_RCR,
- YU_RCR_UFLEN | YU_RCR_MUFLEN);
- break;
- }
-
+ switch (ifp->if_flags & (IFF_UP | IFF_RUNNING)) {
+ case IFF_RUNNING:
+ sk_stop(ifp, 1);
+ break;
+ case IFF_UP:
+ sk_init(ifp);
+ break;
+ case IFF_UP | IFF_RUNNING:
+ if ((ifp->if_flags ^ sc_if->sk_if_flags) == IFF_PROMISC) {
+ sk_promisc(sc_if, ifp->if_flags & IFF_PROMISC);
sk_setmulti(sc_if);
} else
- (void) sk_init(ifp);
- } else {
- if (ifp->if_flags & IFF_RUNNING)
- sk_stop(ifp,0);
+ sk_init(ifp);
+ break;
}
sc_if->sk_if_flags = ifp->if_flags;
error = 0;
Home |
Main Index |
Thread Index |
Old Index