123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141 |
- /*
- * Copyright (c) 2016 Piotr Mienkowski
- *
- * SPDX-License-Identifier: Apache-2.0
- */
- /** @file
- * @brief Definitions for IEEE 802.3, Section 2 MII compatible PHY transceivers
- */
- #ifndef ZEPHYR_INCLUDE_NET_MII_H_
- #define ZEPHYR_INCLUDE_NET_MII_H_
- /**
- * @brief Ethernet MII (media independent interface) functions
- * @defgroup ethernet_mii Ethernet MII Support Functions
- * @ingroup ethernet
- * @{
- */
- /* MII management registers */
- /** Basic Mode Control Register */
- #define MII_BMCR 0x0
- /** Basic Mode Status Register */
- #define MII_BMSR 0x1
- /** PHY ID 1 Register */
- #define MII_PHYID1R 0x2
- /** PHY ID 2 Register */
- #define MII_PHYID2R 0x3
- /** Auto-Negotiation Advertisement Register */
- #define MII_ANAR 0x4
- /** Auto-Negotiation Link Partner Ability Reg */
- #define MII_ANLPAR 0x5
- /** Auto-Negotiation Expansion Register */
- #define MII_ANER 0x6
- /** Auto-Negotiation Next Page Transmit Register */
- #define MII_ANNPTR 0x7
- /** Auto-Negotiation Link Partner Received Next Page Reg */
- #define MII_ANLPRNPR 0x8
- /** MMD Access Control Register */
- #define MII_MMD_ACR 0xd
- /** MMD Access Address Data Register */
- #define MII_MMD_AADR 0xe
- /** Extended Status Register */
- #define MII_ESTAT 0xf
- /* Basic Mode Control Register (BMCR) bit definitions */
- /** PHY reset */
- #define MII_BMCR_RESET (1 << 15)
- /** enable loopback mode */
- #define MII_BMCR_LOOPBACK (1 << 14)
- /** 10=1000Mbps 01=100Mbps; 00=10Mbps */
- #define MII_BMCR_SPEED_LSB (1 << 13)
- /** Auto-Negotiation enable */
- #define MII_BMCR_AUTONEG_ENABLE (1 << 12)
- /** power down mode */
- #define MII_BMCR_POWER_DOWN (1 << 11)
- /** isolate electrically PHY from MII */
- #define MII_BMCR_ISOLATE (1 << 10)
- /** restart auto-negotiation */
- #define MII_BMCR_AUTONEG_RESTART (1 << 9)
- /** full duplex mode */
- #define MII_BMCR_DUPLEX_MODE (1 << 8)
- /** 10=1000Mbps 01=100Mbps; 00=10Mbps */
- #define MII_BMCR_SPEED_MSB (1 << 6)
- /** Link Speed Field */
- #define MII_BMCR_SPEED_MASK (1 << 6 | 1 << 13)
- /** select speed 10 Mb/s */
- #define MII_BMCR_SPEED_10 (0 << 6 | 0 << 13)
- /** select speed 100 Mb/s */
- #define MII_BMCR_SPEED_100 (0 << 6 | 1 << 13)
- /** select speed 1000 Mb/s */
- #define MII_BMCR_SPEED_1000 (1 << 6 | 0 << 13)
- /* Basic Mode Status Register (BMSR) bit definitions */
- /** 100BASE-T4 capable */
- #define MII_BMSR_100BASE_T4 (1 << 15)
- /** 100BASE-X full duplex capable */
- #define MII_BMSR_100BASE_X_FULL (1 << 14)
- /** 100BASE-X half duplex capable */
- #define MII_BMSR_100BASE_X_HALF (1 << 13)
- /** 10 Mb/s full duplex capable */
- #define MII_BMSR_10_FULL (1 << 12)
- /** 10 Mb/s half duplex capable */
- #define MII_BMSR_10_HALF (1 << 11)
- /** 100BASE-T2 full duplex capable */
- #define MII_BMSR_100BASE_T2_FULL (1 << 10)
- /** 100BASE-T2 half duplex capable */
- #define MII_BMSR_100BASE_T2_HALF (1 << 9)
- /** extend status information in reg 15 */
- #define MII_BMSR_EXTEND_STATUS (1 << 8)
- /** PHY accepts management frames with preamble suppressed */
- #define MII_BMSR_MF_PREAMB_SUPPR (1 << 6)
- /** Auto-negotiation process completed */
- #define MII_BMSR_AUTONEG_COMPLETE (1 << 5)
- /** remote fault detected */
- #define MII_BMSR_REMOTE_FAULT (1 << 4)
- /** PHY is able to perform Auto-Negotiation */
- #define MII_BMSR_AUTONEG_ABILITY (1 << 3)
- /** link is up */
- #define MII_BMSR_LINK_STATUS (1 << 2)
- /** jabber condition detected */
- #define MII_BMSR_JABBER_DETECT (1 << 1)
- /** extended register capabilities */
- #define MII_BMSR_EXTEND_CAPAB (1 << 0)
- /* Auto-negotiation Advertisement Register (ANAR) bit definitions */
- /* Auto-negotiation Link Partner Ability Register (ANLPAR) bit definitions */
- /** next page */
- #define MII_ADVERTISE_NEXT_PAGE (1 << 15)
- /** link partner acknowledge response */
- #define MII_ADVERTISE_LPACK (1 << 14)
- /** remote fault */
- #define MII_ADVERTISE_REMOTE_FAULT (1 << 13)
- /** try for asymmetric pause */
- #define MII_ADVERTISE_ASYM_PAUSE (1 << 11)
- /** try for pause */
- #define MII_ADVERTISE_PAUSE (1 << 10)
- /** try for 100BASE-T4 support */
- #define MII_ADVERTISE_100BASE_T4 (1 << 9)
- /** try for 100BASE-X full duplex support */
- #define MII_ADVERTISE_100_FULL (1 << 8)
- /** try for 100BASE-X support */
- #define MII_ADVERTISE_100_HALF (1 << 7)
- /** try for 10 Mb/s full duplex support */
- #define MII_ADVERTISE_10_FULL (1 << 6)
- /** try for 10 Mb/s half duplex support */
- #define MII_ADVERTISE_10_HALF (1 << 5)
- /** Selector Field */
- #define MII_ADVERTISE_SEL_MASK (0x1F << 0)
- #define MII_ADVERTISE_SEL_IEEE_802_3 0x01
- #define MII_ADVERTISE_ALL (MII_ADVERTISE_10_HALF | MII_ADVERTISE_10_FULL |\
- MII_ADVERTISE_100_HALF | MII_ADVERTISE_100_FULL |\
- MII_ADVERTISE_SEL_IEEE_802_3)
- /**
- * @}
- */
- #endif /* ZEPHYR_INCLUDE_NET_MII_H_ */
|