summaryrefslogtreecommitdiff
path: root/sys/dev/ic
diff options
context:
space:
mode:
authorChristian Weisgerber <naddy@cvs.openbsd.org>2009-07-15 19:50:05 +0000
committerChristian Weisgerber <naddy@cvs.openbsd.org>2009-07-15 19:50:05 +0000
commit12e3a4da1c068fbc83b1a41ab5fd05e9cb9e3403 (patch)
treeab3af5b2b7029047c4f536d02201df6c7d465dd1 /sys/dev/ic
parent4307238a43f4cb59003899cb5008d323b587e607 (diff)
Removes the magic bit from re_init() and moves the common
flag to the top. No change with the actual cplus mode register setting being used with the controllers. From brad@
Diffstat (limited to 'sys/dev/ic')
-rw-r--r--sys/dev/ic/re.c17
1 files changed, 9 insertions, 8 deletions
diff --git a/sys/dev/ic/re.c b/sys/dev/ic/re.c
index b5c095ee2f2..f134ffada1d 100644
--- a/sys/dev/ic/re.c
+++ b/sys/dev/ic/re.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: re.c,v 1.110 2009/07/11 16:51:58 sthen Exp $ */
+/* $OpenBSD: re.c,v 1.111 2009/07/15 19:50:04 naddy Exp $ */
/* $FreeBSD: if_re.c,v 1.31 2004/09/04 07:54:05 ru Exp $ */
/*
* Copyright (c) 1997, 1998-2003
@@ -1948,18 +1948,19 @@ re_init(struct ifnet *ifp)
* Enable C+ RX and TX mode, as well as RX checksum offload.
* We must configure the C+ register before all others.
*/
- cfg = RL_CPLUSCMD_PCI_MRW;
+ cfg = RL_CPLUSCMD_TXENB | RL_CPLUSCMD_PCI_MRW;
+
if (ifp->if_capabilities & IFCAP_CSUM_IPv4)
cfg |= RL_CPLUSCMD_RXCSUM_ENB;
+
if (ifp->if_capabilities & IFCAP_VLAN_HWTAGGING)
cfg |= RL_CPLUSCMD_VLANSTRIP;
- if (sc->rl_flags & RL_FLAG_MACSTAT) {
+
+ if (sc->rl_flags & RL_FLAG_MACSTAT)
cfg |= RL_CPLUSCMD_MACSTAT_DIS;
- /* XXX magic. */
- cfg |= 0x0001;
- } else {
- cfg |= RL_CPLUSCMD_RXENB | RL_CPLUSCMD_TXENB;
- }
+ else
+ cfg |= RL_CPLUSCMD_RXENB;
+
CSR_WRITE_2(sc, RL_CPLUS_CMD, cfg);
/*