cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore/*
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * CDDL HEADER START
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore *
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * The contents of this file are subject to the terms of the
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * Common Development and Distribution License (the "License").
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * You may not use this file except in compliance with the License.
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore *
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * or http://www.opensolaris.org/os/licensing.
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * See the License for the specific language governing permissions
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * and limitations under the License.
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore *
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * When distributing Covered Code, include this CDDL HEADER in each
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * If applicable, add the following below this CDDL HEADER, with the
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * fields enclosed by brackets "[]" replaced with your own identifying
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * information: Portions Copyright [yyyy] [name of copyright owner]
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore *
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * CDDL HEADER END
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore/*
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * Copyright 2009 Sun Microsystems, Inc. All rights reserved.
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * Use is subject to license terms.
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore/*
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * MII overrides for Marvell PHYs.
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#include <sys/types.h>
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#include <sys/ddi.h>
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#include <sys/sunddi.h>
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#include <sys/mii.h>
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#include <sys/miiregs.h>
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#include "miipriv.h"
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MVPHY_PSC MII_VENDOR(0) /* PHY specific control */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_TXFIFO_DEPTH 0xc000
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_RXFIFO_DEPTH 0x3000
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_ASSERT_CRS_TX 0x0800 /* older PHYs */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_DOWNSHIFT_EN 0x0800 /* newer PHYs */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_FORCE_GOOD_LINK 0x0400
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_DIS_SCRAMBLER 0x0200
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_MII_5BIT_EN 0x0100
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_EN_DETECT_MASK 0x0300
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_EN_EXT_DISTANCE 0x0080
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_AUTO_X_MODE 0x0060
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_AUTO_X_1000T 0x0040
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_MDIX_MANUAL 0x0010
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_MDI_MANUAL 0x0000
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_RGMII_POWER_UP 0x0008 /* 88E1116, 88E1149 page 2 */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_POWER_DOWN 0x0004 /* 88E1116 page 0 */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_MODE_MASK 0x0380 /* 88E1112 page 2 */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_MODE_AUTO 0x0180
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_MODE_COPPER 0x0280
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_MODE_1000BASEX 0x0380
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_DIS_125CLK 0x0010
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_MAC_PDOWN 0x0008
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_SQE_TEST 0x0004
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_POL_REVERSE 0x0002
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_JABBER_DIS 0x0001
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore/* 88E3016 */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_AUTO_MDIX 0x0030
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_SIGDET_POLARITY 0x0040
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_EXT_DIST 0x0080
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_FEFI_DIS 0x0100
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_NLP_GEN_DIS 0x0800
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_LPNP 0x1000
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_NLP_CHK_DIS 0x2000
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_EN_DETECT 0x4000
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore/* LED control page 3, 88E1116, 88E1149 */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_LED_LOS_MASK 0xf000
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_LED_INIT_MASK 0x0f00
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_LED_STA1_MASK 0x00f0
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_LED_STA0_MASK 0x000f
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_LED_LOS_CTRL(x) (((x) << 12) & MV_PSC_LED_LOS_MASK)
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_LED_INIT_CTRL(x) (((x) << 8) & MV_PSC_LED_INIT_MASK)
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_LED_STA1_CTRL(x) (((x) << 4) & MV_PSC_LED_STA1_MASK)
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_PSC_LED_STA0_CTRL(x) (((x)) & MV_PSC_LED_STA0_MASK)
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MVPHY_INTEN MII_VENDOR(2) /* Interrupt enable */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_INTEN_PULSE_MASK 0x7000
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_INTEN_PULSE_NOSTR 0x0000
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_INTEN_PULSE_21MS 0x1000
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_INTEN_PULSE_42MS 0x2000
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_INTEN_PULSE_84MS 0x3000
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_INTEN_PULSE_170MS 0x4000
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_INTEN_PULSE_340MS 0x5000
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_INTEN_PULSE_670MS 0x6000
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_INTEN_PULSE_1300MS 0x7000
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_INTEN_BLINK_MASK 0x0700
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_INTEN_BLINK_42MS 0x0000
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_INTEN_BLINK_84MS 0x0100
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_INTEN_BLINK_170MS 0x0200
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_INTEN_BLINK_340MS 0x0300
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_INTEN_BLINK_670MS 0x0400
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MVPHY_INTST MII_VENDOR(3) /* Interrupt status */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MVPHY_EPSC MII_VENDOR(4) /* Ext. phy specific control */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_EPSC_DOWN_NO_IDLE 0x8000
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_EPSC_FIBER_LOOPBACK 0x4000
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_EPSC_TX_CLK_2_5 0x0060
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_EPSC_TX_CLK_25 0x0070
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_EPSC_TX_CLK_0 0x0000
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MVPHY_EADR MII_VENDOR(6) /* Extended address */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MVPHY_LED_PSEL MII_VENDOR(6) /* 88E3016 */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_LED_PSEL_COLX 0x00
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_LED_PSEL_ERROR 0x01
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_LED_PSEL_DUPLEX 0x02
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_LED_PSEL_DP_COL 0x03
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_LED_PSEL_SPEED 0x04
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_LED_PSEL_LINK 0x05
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_LED_PSEL_TX 0x06
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_LED_PSEL_RX 0x07
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_LED_PSEL_ACT 0x08
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_LED_PSEL_LNK_RX 0x09
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_LED_PSEL_LNK_ACT 0x0a
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_LED_PSEL_ACT_BL 0x0b
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_LED_PSEL_TX_BL 0x0c
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_LED_PSEL_RX_BL 0x0d
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_LED_PSEL_COLX_BL 0x0e
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_LED_PSEL_INACT 0x0f
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_LED_PSEL_LED2(x) (x << 8)
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_LED_PSEL_LED1(x) (x << 4)
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_LED_PSEL_LED0(x) (x << 0)
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MVPHY_PAGE_ADDR MII_VENDOR(13)
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MVPHY_PAGE_DATA MII_VENDOR(14)
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MVPHY_EPSS MII_VENDOR(11) /* Ext. phy specific status */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_EPSS_FCAUTOSEL 0x8000 /* fiber/copper autosel */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore#define MV_EPSS_FCRESOL 0x1000 /* fiber/copper resol */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amorestatic int
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amoremvphy_reset_88e3016(phy_handle_t *ph)
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore{
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore uint16_t reg;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore int rv;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore rv = phy_reset(ph);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg = phy_read(ph, MVPHY_PSC);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg |= MV_PSC_AUTO_MDIX;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg &= ~(MV_PSC_EN_DETECT | MV_PSC_DIS_SCRAMBLER);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg |= MV_PSC_LPNP;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore /* enable class A driver for Yukon FE+ A0. */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore PHY_SET(ph, MII_VENDOR(12), 0x0001);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_PSC, reg);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore /* LED2 = ACT blink, LED1 = LINK), LED0 = SPEED */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_LED_PSEL,
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore MV_LED_PSEL_LED2(MV_LED_PSEL_ACT_BL) |
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore MV_LED_PSEL_LED1(MV_LED_PSEL_LINK) |
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore MV_LED_PSEL_LED0(MV_LED_PSEL_SPEED));
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore /* calibration, values not documented */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_PAGE_ADDR, 17);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_PAGE_DATA, 0x3f60);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore /* Normal BMCR reset now */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore return (rv);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore}
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amorestatic int
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amoremvphy_loop_88e3016(phy_handle_t *ph)
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore{
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore uint16_t reg;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore int rv;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore rv = phy_loop(ph);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore /*
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * The PHY apparently needs a soft reset, but supposedly
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * retains most of the other critical state.
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg = phy_read(ph, MII_CONTROL);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg |= MII_CONTROL_RESET;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MII_CONTROL, reg);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg = phy_read(ph, MVPHY_PSC);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg &= ~(MV_PSC_AUTO_MDIX);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg &= ~(MV_PSC_EN_DETECT | MV_PSC_DIS_SCRAMBLER);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg |= MV_PSC_LPNP;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_PSC, reg);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore return (rv);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore}
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amorestatic int
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amoremvphy_reset_88e3082(phy_handle_t *ph)
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore{
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore uint16_t reg;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore int rv;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore rv = phy_reset(ph);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg = phy_read(ph, MVPHY_PSC);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg |= (MV_PSC_AUTO_X_MODE >> 1);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg |= MV_PSC_ASSERT_CRS_TX;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg &= ~MV_PSC_POL_REVERSE;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_PSC, reg);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore return (rv);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore}
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amorestatic int
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amoremvphy_reset_88e1149(phy_handle_t *ph)
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore{
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore uint16_t reg;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore int rv;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore /* make sure that this PHY uses page 0 (copper) */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_EADR, 0);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg = phy_read(ph, MVPHY_PSC);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore /* Disable energy detect mode */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg &= ~MV_PSC_EN_DETECT_MASK;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg |= MV_PSC_AUTO_X_MODE;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg |= MV_PSC_DOWNSHIFT_EN;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg &= ~MV_PSC_POL_REVERSE;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_PSC, reg);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore rv = phy_reset(ph);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_EADR, 2);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore PHY_SET(ph, MVPHY_PSC, MV_PSC_RGMII_POWER_UP);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore /*
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * Fix for signal amplitude in 10BASE-T, undocumented.
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * This is from the Marvell reference source code.
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_EADR, 255);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, 0x18, 0xaa99);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, 0x17, 0x2011);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore if (MII_PHY_REV(ph->phy_id) == 0) {
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore /*
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * EC_U: IEEE A/B 1000BASE-T symmetry failure
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore *
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * EC_U is rev 0, Ultra 2 is rev 1 (at least the
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * unit I have), so we trigger on revid.
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, 0x18, 0xa204);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, 0x17, 0x2002);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore }
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore /* page 3 is led control */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_EADR, 3);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_PSC,
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore MV_PSC_LED_LOS_CTRL(1) | /* link/act */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore MV_PSC_LED_INIT_CTRL(8) | /* 10 Mbps */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore MV_PSC_LED_STA1_CTRL(7) | /* 100 Mbps */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore MV_PSC_LED_STA0_CTRL(7)); /* 1000 Mbps */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_INTEN, 0);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_EADR, 0);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore /*
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * Weird... undocumented logic in the Intel e1000g driver.
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * I'm not sure what these values really do.
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_PAGE_ADDR, 3);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_PAGE_DATA, 0);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore return (rv);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore}
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amorestatic int
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amoremvphy_reset_88e1116(phy_handle_t *ph)
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore{
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore uint16_t reg;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore /* make sure that this PHY uses page 0 (copper) */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_EADR, 0);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg = phy_read(ph, MVPHY_PSC);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg &= ~MV_PSC_POWER_DOWN;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore /* Disable energy detect mode */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg &= ~MV_PSC_EN_DETECT_MASK;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg |= MV_PSC_AUTO_X_MODE;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg |= MV_PSC_ASSERT_CRS_TX;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg &= ~MV_PSC_POL_REVERSE;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_PSC, reg);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_EADR, 2);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore PHY_SET(ph, MVPHY_PSC, MV_PSC_RGMII_POWER_UP);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore /* page 3 is led control */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_EADR, 3);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_PSC,
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore MV_PSC_LED_LOS_CTRL(1) | /* link/act */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore MV_PSC_LED_INIT_CTRL(8) | /* 10 Mbps */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore MV_PSC_LED_STA1_CTRL(7) | /* 100 Mbps */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore MV_PSC_LED_STA0_CTRL(7)); /* 1000 Mbps */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_INTEN, 0);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_EADR, 0);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore return (phy_reset(ph));
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore}
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amorestatic int
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amoremvphy_reset_88e1118(phy_handle_t *ph)
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore{
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore uint16_t reg;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg = phy_read(ph, MVPHY_PSC);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore /* Disable energy detect mode */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg &= ~MV_PSC_EN_DETECT_MASK;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg |= MV_PSC_AUTO_X_MODE;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg |= MV_PSC_ASSERT_CRS_TX;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg &= ~MV_PSC_POL_REVERSE;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_PSC, reg);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore return (phy_reset(ph));
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore}
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amorestatic int
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amoremvphy_reset_88e1111(phy_handle_t *ph)
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore{
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore uint16_t reg;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg = phy_read(ph, MVPHY_PSC);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore /* Disable energy detect mode */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg &= ~MV_PSC_EN_DETECT_MASK;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg |= MV_PSC_AUTO_X_MODE;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg |= MV_PSC_ASSERT_CRS_TX;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg &= ~MV_PSC_POL_REVERSE;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_PSC, reg);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore /* force TX CLOCK to 25 MHz */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore PHY_SET(ph, MVPHY_EPSC, MV_EPSC_TX_CLK_25);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore return (phy_reset(ph));
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore}
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amorestatic int
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amoremvphy_reset_88e1112(phy_handle_t *ph)
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore{
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore uint16_t reg, page;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore if (phy_read(ph, MVPHY_EPSS) & MV_EPSS_FCRESOL) {
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore /* interface indicates fiber */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore PHY_CLR(ph, MVPHY_PSC, MV_PSC_AUTO_X_MODE);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore page = phy_read(ph, MVPHY_EADR);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore /* Go into locked 1000BASE-X mode */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore page = phy_read(ph, MVPHY_EADR);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_EADR, 2);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg = phy_read(ph, MVPHY_PSC);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg &= ~MV_PSC_MODE_MASK;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg |= MV_PSC_MODE_1000BASEX;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_PSC, reg);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_EADR, page);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore } else {
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg = phy_read(ph, MVPHY_PSC);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore /* Disable energy detect mode */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg &= ~MV_PSC_EN_DETECT_MASK;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg |= MV_PSC_AUTO_X_MODE;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg |= MV_PSC_ASSERT_CRS_TX;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg &= ~MV_PSC_POL_REVERSE;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_PSC, reg);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore }
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore return (phy_reset(ph));
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore}
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amorestatic int
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amoremvphy_reset_88e1011(phy_handle_t *ph)
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore{
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore uint16_t reg;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore if (phy_read(ph, MVPHY_EPSS) & MV_EPSS_FCRESOL) {
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore /* interface indicates fiber */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore PHY_CLR(ph, MVPHY_PSC, MV_PSC_AUTO_X_MODE);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore } else {
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg = phy_read(ph, MVPHY_PSC);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg &= ~MV_PSC_AUTO_X_MODE;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg |= MV_PSC_ASSERT_CRS_TX;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg &= ~MV_PSC_POL_REVERSE;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_PSC, reg);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore }
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore /* force TX CLOCK to 25 MHz */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore PHY_SET(ph, MVPHY_EPSC, MV_EPSC_TX_CLK_25);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore return (phy_reset(ph));
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore}
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amorestatic int
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amoremvphy_reset(phy_handle_t *ph)
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore{
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore uint16_t reg;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg = phy_read(ph, MVPHY_PSC);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg &= ~MV_PSC_AUTO_X_MODE;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg |= MV_PSC_ASSERT_CRS_TX;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore reg &= ~MV_PSC_POL_REVERSE;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore phy_write(ph, MVPHY_PSC, reg);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore PHY_SET(ph, MVPHY_EPSC, MV_EPSC_TX_CLK_25);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore /* Normal BMCR reset now */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore return (phy_reset(ph));
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore}
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amorestatic int
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amoremvphy_start(phy_handle_t *ph)
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore{
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore int rv;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore rv = phy_start(ph);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore /*
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * If not autonegotiating, then we need to reset the PHY according to
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * Marvell. I don't think this is according to the spec. Apparently
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore * the register states are not lost during this.
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore if ((rv == 0) && (!ph->phy_adv_aneg)) {
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore rv = ph->phy_reset(ph);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore }
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore return (rv);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore}
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amoreboolean_t
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amorephy_marvell_probe(phy_handle_t *ph)
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore{
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore switch (MII_PHY_MFG(ph->phy_id)) {
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore case MII_OUI_MARVELL:
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore ph->phy_vendor = "Marvell";
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore switch (MII_PHY_MODEL(ph->phy_id)) {
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore case MII_MODEL_MARVELL_88E1000:
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore case MII_MODEL_MARVELL_88E1000_2:
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore case MII_MODEL_MARVELL_88E1000_3:
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore ph->phy_model = "88E1000";
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore ph->phy_reset = mvphy_reset;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore break;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore case MII_MODEL_MARVELL_88E1011:
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore ph->phy_model = "88E1011";
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore ph->phy_reset = mvphy_reset_88e1011;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore break;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore case MII_MODEL_MARVELL_88E1111:
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore ph->phy_model = "88E1111";
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore ph->phy_reset = mvphy_reset_88e1111;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore break;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore case MII_MODEL_MARVELL_88E1112:
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore ph->phy_model = "88E1112";
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore ph->phy_reset = mvphy_reset_88e1112;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore break;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore case MII_MODEL_MARVELL_88E1116:
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore ph->phy_model = "88E1116";
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore ph->phy_reset = mvphy_reset_88e1116;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore break;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore case MII_MODEL_MARVELL_88E1116R:
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore ph->phy_model = "88E1116R";
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore ph->phy_reset = mvphy_reset;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore break;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore case MII_MODEL_MARVELL_88E1118:
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore ph->phy_model = "88E1118";
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore ph->phy_reset = mvphy_reset_88e1118;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore break;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore case MII_MODEL_MARVELL_88E1149:
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore ph->phy_model = "88E1149";
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore ph->phy_reset = mvphy_reset;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore ph->phy_reset = mvphy_reset_88e1149;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore break;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore case MII_MODEL_MARVELL_88E3016:
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore ph->phy_model = "88E3016";
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore ph->phy_reset = mvphy_reset_88e3016;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore ph->phy_loop = mvphy_loop_88e3016;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore break;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore case MII_MODEL_MARVELL_88E3082:
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore ph->phy_model = "88E3082";
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore ph->phy_reset = mvphy_reset_88e3082;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore break;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore default:
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore /* Unknown PHY model */
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore return (B_FALSE);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore }
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore break;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore default:
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore return (B_FALSE);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore }
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore ph->phy_start = mvphy_start;
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore return (B_TRUE);
cea606427170954e8cfcfa5417f3b60394180cb9Garrett D'Amore}