|
@@ -2138,6 +2138,18 @@ MLXSW_ITEM32(reg, ptys, local_port, 0x00, 16, 8);
|
|
|
*/
|
|
|
MLXSW_ITEM32(reg, ptys, proto_mask, 0x00, 0, 3);
|
|
|
|
|
|
+enum {
|
|
|
+ MLXSW_REG_PTYS_AN_STATUS_NA,
|
|
|
+ MLXSW_REG_PTYS_AN_STATUS_OK,
|
|
|
+ MLXSW_REG_PTYS_AN_STATUS_FAIL,
|
|
|
+};
|
|
|
+
|
|
|
+/* reg_ptys_an_status
|
|
|
+ * Autonegotiation status.
|
|
|
+ * Access: RO
|
|
|
+ */
|
|
|
+MLXSW_ITEM32(reg, ptys, an_status, 0x04, 28, 4);
|
|
|
+
|
|
|
#define MLXSW_REG_PTYS_ETH_SPEED_SGMII BIT(0)
|
|
|
#define MLXSW_REG_PTYS_ETH_SPEED_1000BASE_KX BIT(1)
|
|
|
#define MLXSW_REG_PTYS_ETH_SPEED_10GBASE_CX4 BIT(2)
|
|
@@ -2184,6 +2196,13 @@ MLXSW_ITEM32(reg, ptys, eth_proto_admin, 0x18, 0, 32);
|
|
|
*/
|
|
|
MLXSW_ITEM32(reg, ptys, eth_proto_oper, 0x24, 0, 32);
|
|
|
|
|
|
+/* reg_ptys_eth_proto_lp_advertise
|
|
|
+ * The protocols that were advertised by the link partner during
|
|
|
+ * autonegotiation.
|
|
|
+ * Access: RO
|
|
|
+ */
|
|
|
+MLXSW_ITEM32(reg, ptys, eth_proto_lp_advertise, 0x30, 0, 32);
|
|
|
+
|
|
|
static inline void mlxsw_reg_ptys_pack(char *payload, u8 local_port,
|
|
|
u32 proto_admin)
|
|
|
{
|