| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495 |
- /* SPDX-License-Identifier: GPL-2.0 */
- /*
- * mdio-open-alliance.h - definition of OPEN Alliance SIG standard registers
- */
- #ifndef __MDIO_OPEN_ALLIANCE__
- #define __MDIO_OPEN_ALLIANCE__
- #include <linux/mdio.h>
- /* NOTE: all OATC14 registers are located in MDIO_MMD_VEND2 */
- /* Open Alliance TC14 (10BASE-T1S) registers */
- #define MDIO_OATC14_PLCA_IDVER 0xca00 /* PLCA ID and version */
- #define MDIO_OATC14_PLCA_CTRL0 0xca01 /* PLCA Control register 0 */
- #define MDIO_OATC14_PLCA_CTRL1 0xca02 /* PLCA Control register 1 */
- #define MDIO_OATC14_PLCA_STATUS 0xca03 /* PLCA Status register */
- #define MDIO_OATC14_PLCA_TOTMR 0xca04 /* PLCA TO Timer register */
- #define MDIO_OATC14_PLCA_BURST 0xca05 /* PLCA BURST mode register */
- /* Open Alliance TC14 PLCA IDVER register */
- #define MDIO_OATC14_PLCA_IDM 0xff00 /* PLCA MAP ID */
- #define MDIO_OATC14_PLCA_VER 0x00ff /* PLCA MAP version */
- /* Open Alliance TC14 PLCA CTRL0 register */
- #define MDIO_OATC14_PLCA_EN BIT(15) /* PLCA enable */
- #define MDIO_OATC14_PLCA_RST BIT(14) /* PLCA reset */
- /* Open Alliance TC14 PLCA CTRL1 register */
- #define MDIO_OATC14_PLCA_NCNT 0xff00 /* PLCA node count */
- #define MDIO_OATC14_PLCA_ID 0x00ff /* PLCA local node ID */
- /* Open Alliance TC14 PLCA STATUS register */
- #define MDIO_OATC14_PLCA_PST BIT(15) /* PLCA status indication */
- /* Open Alliance TC14 PLCA TOTMR register */
- #define MDIO_OATC14_PLCA_TOT 0x00ff
- /* Open Alliance TC14 PLCA BURST register */
- #define MDIO_OATC14_PLCA_MAXBC 0xff00
- #define MDIO_OATC14_PLCA_BTMR 0x00ff
- /* Version Identifiers */
- #define OATC14_IDM 0x0a00
- /*
- * Open Alliance TC14 (10BASE-T1S) - Advanced Diagnostic Features Registers
- *
- * Refer to the OPEN Alliance documentation:
- * https://opensig.org/automotive-ethernet-specifications/
- *
- * Specification:
- * "10BASE-T1S Advanced Diagnostic PHY Features"
- * https://opensig.org/wp-content/uploads/2025/06/OPEN_Alliance_10BASE-T1S_Advanced_PHY_features_for-automotive_Ethernet_V2.1b.pdf
- */
- /* Advanced Diagnostic Features Capability Register*/
- #define MDIO_OATC14_ADFCAP 0xcc00
- #define OATC14_ADFCAP_HDD_CAPABILITY GENMASK(10, 8)
- #define OATC14_ADFCAP_SQIPLUS_CAPABILITY GENMASK(4, 1)
- #define OATC14_ADFCAP_SQI_CAPABILITY BIT(0)
- /* Harness Defect Detection Register */
- #define MDIO_OATC14_HDD 0xcc01
- #define OATC14_HDD_CONTROL BIT(15)
- #define OATC14_HDD_READY BIT(14)
- #define OATC14_HDD_START_CONTROL BIT(13)
- #define OATC14_HDD_VALID BIT(2)
- #define OATC14_HDD_SHORT_OPEN_STATUS GENMASK(1, 0)
- /* Dynamic Channel Quality SQI Register */
- #define MDIO_OATC14_DCQ_SQI 0xcc03
- #define OATC14_DCQ_SQI_VALUE GENMASK(2, 0)
- /* Dynamic Channel Quality SQI Plus Register */
- #define MDIO_OATC14_DCQ_SQIPLUS 0xcc04
- #define OATC14_DCQ_SQIPLUS_VALUE GENMASK(7, 0)
- /* SQI is supported using 3 bits means 8 levels (0-7) */
- #define OATC14_SQI_MAX_LEVEL 7
- /* Bus Short/Open Status:
- * 0 0 - no fault; everything is ok. (Default)
- * 0 1 - detected as an open or missing termination(s)
- * 1 0 - detected as a short or extra termination(s)
- * 1 1 - fault but fault type not detectable. More details can be available by
- * vender specific register if supported.
- */
- enum oatc14_hdd_status {
- OATC14_HDD_STATUS_CABLE_OK = 0,
- OATC14_HDD_STATUS_OPEN,
- OATC14_HDD_STATUS_SHORT,
- OATC14_HDD_STATUS_NOT_DETECTABLE,
- };
- #endif /* __MDIO_OPEN_ALLIANCE__ */
|