summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJonathan Gray <jsg@cvs.openbsd.org>2006-02-28 08:13:48 +0000
committerJonathan Gray <jsg@cvs.openbsd.org>2006-02-28 08:13:48 +0000
commitf4ca37f42e6888b337fcaea7e9b787c6462226ec (patch)
tree4266609a452b276ef539701d9cbd1cb5b6c67682
parentea472b4f76e64ed87fe427761671577bd731a79c (diff)
We need to special case ciphy to ask for RGMII interface at 2.5V for nfe.
This makes Cicada/Vitesse PHYs attached to nfe work. Many thanks to Bill Paul for diagnosing the problem and suggesting a solution. Tested by otto@, ok deraadt@
-rw-r--r--share/man/man4/nfe.47
-rw-r--r--sys/dev/mii/ciphy.c9
-rw-r--r--sys/dev/mii/ciphyreg.h12
3 files changed, 20 insertions, 8 deletions
diff --git a/share/man/man4/nfe.4 b/share/man/man4/nfe.4
index 9610baca7b8..9f6d112c906 100644
--- a/share/man/man4/nfe.4
+++ b/share/man/man4/nfe.4
@@ -1,4 +1,4 @@
-.\" $OpenBSD: nfe.4,v 1.6 2006/02/27 08:03:00 jsg Exp $
+.\" $OpenBSD: nfe.4,v 1.7 2006/02/28 08:13:47 jsg Exp $
.\"
.\" Copyright (c) 2006 Jonathan Gray <jsg@openbsd.org>
.\"
@@ -80,8 +80,3 @@ and
.Sh CAVEATS
NVIDIA refuse to release any documentation on their products
so the driver likely doesn't work as well as it otherwise could.
-.Sh BUGS
-Adapters that attach
-.Xr ciphy 4
-currently are unable to transmit and receive data, the cause of
-this is not yet known.
diff --git a/sys/dev/mii/ciphy.c b/sys/dev/mii/ciphy.c
index f95f041fa6d..642ad41cd05 100644
--- a/sys/dev/mii/ciphy.c
+++ b/sys/dev/mii/ciphy.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ciphy.c,v 1.9 2005/10/07 03:45:11 brad Exp $ */
+/* $OpenBSD: ciphy.c,v 1.10 2006/02/28 08:13:47 jsg Exp $ */
/* $FreeBSD: ciphy.c,v 1.1 2004/09/10 20:57:45 wpaul Exp $ */
/*
* Copyright (c) 2004
@@ -337,6 +337,13 @@ ciphy_fixup(struct mii_softc *sc)
status = PHY_READ(sc, CIPHY_MII_AUXCSR);
speed = status & CIPHY_AUXCSR_SPEED;
+ if (strcmp(sc->mii_dev.dv_parent->dv_cfdata->cf_driver->cd_name, "nfe") == 0) {
+ printf("ciphy nfe fixup called!\n");
+ /* need to set for 2.5V RGMII for NVIDIA adapters */
+ PHY_SETBIT(sc, CIPHY_MII_ECTL1, CIPHY_INTSEL_RGMII);
+ PHY_SETBIT(sc, CIPHY_MII_ECTL1, CIPHY_IOVOL_2500MV);
+ }
+
switch (model) {
case MII_MODEL_CICADA_CS8201:
diff --git a/sys/dev/mii/ciphyreg.h b/sys/dev/mii/ciphyreg.h
index 3b8bb8fc909..0b7175664a3 100644
--- a/sys/dev/mii/ciphyreg.h
+++ b/sys/dev/mii/ciphyreg.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: ciphyreg.h,v 1.1 2004/12/01 00:24:38 pvalchev Exp $ */
+/* $OpenBSD: ciphyreg.h,v 1.2 2006/02/28 08:13:47 jsg Exp $ */
/* $FreeBSD: ciphyreg.h,v 1.1 2004/09/10 20:57:45 wpaul Exp $ */
/*
* Copyright (c) 2004
@@ -251,6 +251,16 @@
/* Extended PHY control register #1 */
#define CIPHY_MII_ECTL1 0x17
#define CIPHY_ECTL1_ACTIPHY 0x0020 /* Enable ActiPHY power saving */
+#define CIPHY_ECTL1_IOVOL 0x0e00 /* MAC interface and I/O voltage select */
+#define CIPHY_ECTL1_INTSEL 0xf000 /* select MAC interface */
+
+#define CIPHY_IOVOL_3300MV 0x0000 /* 3.3V for I/O pins */
+#define CIPHY_IOVOL_2500MV 0x0200 /* 2.5V for I/O pins */
+
+#define CIPHY_INTSEL_GMII 0x0000 /* GMII/MII */
+#define CIPHY_INTSEL_RGMII 0x1000
+#define CIPHY_INTSEL_TBI 0x2000
+#define CIPHY_INTSEL_RTBI 0x3000
/* Extended PHY control register #2 */
#define CIPHY_MII_ECTL2 0x18