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