root/sys/dev/mii/inphyreg.h
/*      $OpenBSD: inphyreg.h,v 1.6 2024/09/06 10:54:08 jsg Exp $        */
/*      $NetBSD: inphyreg.h,v 1.1 1998/08/11 00:00:28 thorpej Exp $     */

/*-
 * Copyright (c) 1998 The NetBSD Foundation, Inc.
 * All rights reserved.
 *
 * This code is derived from software contributed to The NetBSD Foundation
 * by Jason R. Thorpe of the Numerical Aerospace Simulation Facility,
 * NASA Ames Research Center.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 * 1. Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer.
 * 2. Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in the
 *    documentation and/or other materials provided with the distribution.
 *
 * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
 * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 * POSSIBILITY OF SUCH DAMAGE.
 */

#ifndef _DEV_MII_INPHYREG_H_
#define _DEV_MII_INPHYREG_H_

/*
 * Intel 82555, 82562EM, and 82562ET registers.
 * Note that the 82562 chips are basically 82555 with a few extra registers
 * and all of the 100baseT4 support removed.  Bits in the SCR register do
 * overlap however.
 */

#define MII_INPHY_SCR           0x10    /* Status and Control */
#define SCR_FLOWCTL             0x8000  /* PHY Base flow control enabled */
#define SCR_CSDC                0x2000  /* Carrier sense disconnect control */
#define SCR_TFCD                0x1000  /* Transmit flow control disable */
#define SCR_RDSI                0x0800  /* Receive deserializer in-sync */
#define SCR_100TXPD             0x0400  /* 100baseTX is powered down */
#define SCR_10TPD               0x0200  /* 10baseT is powered down */
#define SCR_POLARITY            0x0100  /* reverse 10baseT polarity */
#define SCR_T4                  0x0004  /* autoneg resulted in 100baseT4 */
#define SCR_S100                0x0002  /* autoneg resulted in 100baseTX */
#define SCR_FDX                 0x0001  /* autoneg resulted in full-duplex */
/* 82562E[MT] only */
#define SCR_PHYADDR_M           0x007c  /* phy address mask */
#define SCR_PHYADDR_S           2       /* shift to normalize */

#define MII_INPHY_SCTRL         0x11    /* Special Control Bit */
#define SCTRL_SCRBYPASS         0x8000  /* scrambler bypass */
#define SCTRL_4B5BNYPASS        0x4000  /* 4bit to 5bit bypass */
#define SCTRL_FTHP              0x2000  /* force transmit H-pattern */
#define SCTRL_F34TP             0x1000  /* force 34 transmit pattern */
#define SCTRL_GOODLINK          0x0800  /* 100baseTX link good */
#define SCTRL_TCSD              0x0200  /* transmit carrier sense disable */
#define SCTRL_DDPD              0x0100  /* disable dynamic power-down */
#define SCTRL_ANEGLOOP          0x0080  /* autonegotiation loopback */
#define SCTRL_MDITRISTATE       0x0040  /* MDI Tri-state */
#define SCTRL_FILTERBYPASS      0x0020  /* Filter bypass */
#define SCTRL_AUTOPOLDIS        0x0010  /* auto-polarity disable */
#define SCTRL_SQUELCHDIS        0x0008  /* squlch test disable */
#define SCTRL_EXTSQUELCH        0x0004  /* extended sequelch enable */
#define SCTRL_LINKINTDIS        0x0002  /* link integrity disable */
#define SCTRL_JABBERDIS         0x0001  /* jabber disabled */
/* 82562E[MT] only */
#define SCTRL_SRE               0x0400  /* symbol error enable */
#define SCTRL_FORCEPOL          0x0020  /* force polarity, 0 = normal */

/* 82562E[MT] only */
#define MII_INPHY_PHYADDR       0x12    /* phy address register, 82562 only */

/* 82562E[MT] only */
#define MII_INPHY_100TXFCC      0x13    /* false carrier counter */

#define MII_INPHY_100TXRDC      0x14    /* 100baseTX Receive Disconnect Cntr */

#define MII_INPHY_100TXREFC     0x15    /* 100baseTX Receive Error Frame Ctr */

#define MII_INPHY_RSEC          0x16    /* Receive Symbol Error Counter */

#define MII_INPHY_100TXRPEOFC   0x17    /* 100baseTX Rcv Premature EOF Ctr */

#define MII_INPHY_10TREOFC      0x18    /* 10baseT Rcv EOF Ctr */

#define MII_INPHY_10TTJDC       0x19    /* 10baseT Tx Jabber Detect Ctr */

#define MII_INPHY_SCTRL2        0x1b    /* 82555 Special Control */
#define SCTRL2_LEDMASK          0x0007  /* mask of LEDs control: see below */

#define LEDMASK_ACTLINK         0x0000  /* A = Activity, L = Link */
#define LEDMASK_SPDCOLL         0x0001  /* A = Speed, L = Collision */
#define LEDMASK_SPDLINK         0x0002  /* A = Speed, L = Link */
#define LEDMASK_ACTCOLL         0x0003  /* A = Activity, L = Collision */
#define LEDMASK_OFFOFF          0x0004  /* A = off, L = off */
#define LEDMASK_OFFON           0x0005  /* A = off, L = on */
#define LEDMASK_ONOFF           0x0006  /* A = on, L = off */
#define LESMASK_ONON            0x0007  /* A = on, L = on */

#endif /* _DEV_MII_INPHYREG_H_ */