1 /* SPDX-License-Identifier: GPL-2.0 */ 1 /* SPDX-License-Identifier: GPL-2.0 */ 2 #ifndef _MARVELL_PHY_H 2 #ifndef _MARVELL_PHY_H 3 #define _MARVELL_PHY_H 3 #define _MARVELL_PHY_H 4 4 5 /* Mask used for ID comparisons */ 5 /* Mask used for ID comparisons */ 6 #define MARVELL_PHY_ID_MASK 0xffff 6 #define MARVELL_PHY_ID_MASK 0xfffffff0 7 7 8 /* Known PHY IDs */ 8 /* Known PHY IDs */ 9 #define MARVELL_PHY_ID_88E1101 0x0141 9 #define MARVELL_PHY_ID_88E1101 0x01410c60 10 #define MARVELL_PHY_ID_88E3082 0x0141 << 11 #define MARVELL_PHY_ID_88E1112 0x0141 10 #define MARVELL_PHY_ID_88E1112 0x01410c90 12 #define MARVELL_PHY_ID_88E1111 0x0141 11 #define MARVELL_PHY_ID_88E1111 0x01410cc0 13 #define MARVELL_PHY_ID_88E1118 0x0141 12 #define MARVELL_PHY_ID_88E1118 0x01410e10 14 #define MARVELL_PHY_ID_88E1121R 0x0141 13 #define MARVELL_PHY_ID_88E1121R 0x01410cb0 15 #define MARVELL_PHY_ID_88E1145 0x0141 14 #define MARVELL_PHY_ID_88E1145 0x01410cd0 16 #define MARVELL_PHY_ID_88E1149R 0x0141 15 #define MARVELL_PHY_ID_88E1149R 0x01410e50 17 #define MARVELL_PHY_ID_88E1240 0x0141 16 #define MARVELL_PHY_ID_88E1240 0x01410e30 18 #define MARVELL_PHY_ID_88E1318S 0x0141 17 #define MARVELL_PHY_ID_88E1318S 0x01410e90 19 #define MARVELL_PHY_ID_88E1340S 0x0141 18 #define MARVELL_PHY_ID_88E1340S 0x01410dc0 20 #define MARVELL_PHY_ID_88E1116R 0x0141 19 #define MARVELL_PHY_ID_88E1116R 0x01410e40 21 #define MARVELL_PHY_ID_88E1510 0x0141 20 #define MARVELL_PHY_ID_88E1510 0x01410dd0 22 #define MARVELL_PHY_ID_88E1540 0x0141 21 #define MARVELL_PHY_ID_88E1540 0x01410eb0 23 #define MARVELL_PHY_ID_88E1545 0x0141 22 #define MARVELL_PHY_ID_88E1545 0x01410ea0 24 #define MARVELL_PHY_ID_88E1548P 0x0141 23 #define MARVELL_PHY_ID_88E1548P 0x01410ec0 25 #define MARVELL_PHY_ID_88E3016 0x0141 24 #define MARVELL_PHY_ID_88E3016 0x01410e60 26 #define MARVELL_PHY_ID_88X3310 0x002b 25 #define MARVELL_PHY_ID_88X3310 0x002b09a0 27 #define MARVELL_PHY_ID_88E2110 0x002b 26 #define MARVELL_PHY_ID_88E2110 0x002b09b0 28 #define MARVELL_PHY_ID_88X2222 0x0141 27 #define MARVELL_PHY_ID_88X2222 0x01410f10 29 #define MARVELL_PHY_ID_88Q2110 0x002b << 30 #define MARVELL_PHY_ID_88Q2220 0x002b << 31 28 32 /* Marvel 88E1111 in Finisar SFP module with m 29 /* Marvel 88E1111 in Finisar SFP module with modified PHY ID */ 33 #define MARVELL_PHY_ID_88E1111_FINISAR 0x01ff 30 #define MARVELL_PHY_ID_88E1111_FINISAR 0x01ff0cc0 34 31 35 /* ID from 88E6020, assumed to be the same for << 36 #define MARVELL_PHY_ID_88E6250_FAMILY 0x0141 << 37 /* These Ethernet switch families contain embe 32 /* These Ethernet switch families contain embedded PHYs, but they do 38 * not have a model ID. So the switch driver t 33 * not have a model ID. So the switch driver traps reads to the ID2 39 * register and returns the switch family ID 34 * register and returns the switch family ID 40 */ 35 */ 41 #define MARVELL_PHY_ID_88E6341_FAMILY 0x0141 36 #define MARVELL_PHY_ID_88E6341_FAMILY 0x01410f41 42 #define MARVELL_PHY_ID_88E6390_FAMILY 0x0141 37 #define MARVELL_PHY_ID_88E6390_FAMILY 0x01410f90 43 #define MARVELL_PHY_ID_88E6393_FAMILY 0x002b 38 #define MARVELL_PHY_ID_88E6393_FAMILY 0x002b0b9b 44 39 45 #define MARVELL_PHY_FAMILY_ID(id) ((id) 40 #define MARVELL_PHY_FAMILY_ID(id) ((id) >> 4) 46 41 47 /* struct phy_device dev_flags definitions */ 42 /* struct phy_device dev_flags definitions */ 48 #define MARVELL_PHY_M1145_FLAGS_RESISTANCE 43 #define MARVELL_PHY_M1145_FLAGS_RESISTANCE 0x00000001 49 #define MARVELL_PHY_M1118_DNS323_LEDS 44 #define MARVELL_PHY_M1118_DNS323_LEDS 0x00000002 50 #define MARVELL_PHY_LED0_LINK_LED1_ACTIVE 45 #define MARVELL_PHY_LED0_LINK_LED1_ACTIVE 0x00000004 51 46 52 #endif /* _MARVELL_PHY_H */ 47 #endif /* _MARVELL_PHY_H */ 53 48
Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.