blob: 8b7d97bc6f18615337f6a7b1c0db3a925ba16bcf [file] [log] [blame]
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef OPEN_ALLIANCE_HELPERS_H
#define OPEN_ALLIANCE_HELPERS_H
/*
* These defines reflect the TDR (Time Delay Reflection) diagnostic feature
* for 1000BASE-T1 automotive Ethernet PHYs as specified by the OPEN Alliance.
*
* The register values are part of the HDD.TDR register, which provides
* information about the cable status and faults. The exact register offset
* is device-specific and should be provided by the driver.
*/
#define OA_1000BT1_HDD_TDR_ACTIVATION_MASK GENMASK(1, 0)
#define OA_1000BT1_HDD_TDR_ACTIVATION_OFF 1
#define OA_1000BT1_HDD_TDR_ACTIVATION_ON 2
#define OA_1000BT1_HDD_TDR_STATUS_MASK GENMASK(7, 4)
#define OA_1000BT1_HDD_TDR_STATUS_SHORT 3
#define OA_1000BT1_HDD_TDR_STATUS_OPEN 6
#define OA_1000BT1_HDD_TDR_STATUS_NOISE 5
#define OA_1000BT1_HDD_TDR_STATUS_CABLE_OK 7
#define OA_1000BT1_HDD_TDR_STATUS_TEST_IN_PROGRESS 8
#define OA_1000BT1_HDD_TDR_STATUS_TEST_NOT_POSSIBLE 13
/*
* OA_1000BT1_HDD_TDR_DISTANCE_MASK:
* This mask is used to extract the distance to the first/main fault
* detected by the TDR feature. Each bit represents an approximate distance
* of 1 meter, ranging from 0 to 31 meters. The exact interpretation of the
* bits may vary, but generally:
* 000000 = no error
* 000001 = error about 0-1m away
* 000010 = error between 1-2m away
* ...
* 011111 = error about 30-31m away
* 111111 = resolution not possible / out of distance
*/
#define OA_1000BT1_HDD_TDR_DISTANCE_MASK GENMASK(13, 8)
#define OA_1000BT1_HDD_TDR_DISTANCE_NO_ERROR 0
#define OA_1000BT1_HDD_TDR_DISTANCE_RESOLUTION_NOT_POSSIBLE 0x3f
int oa_1000bt1_get_ethtool_cable_result_code(u16 reg_value);
int oa_1000bt1_get_tdr_distance(u16 reg_value);
#endif /* OPEN_ALLIANCE_HELPERS_H */