/* 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 /* 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) /* 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) /* 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__ */