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_88E1112		0x01410c90
11#define MARVELL_PHY_ID_88E1111		0x01410cc0
12#define MARVELL_PHY_ID_88E1118		0x01410e10
13#define MARVELL_PHY_ID_88E1121R		0x01410cb0
14#define MARVELL_PHY_ID_88E1145		0x01410cd0
15#define MARVELL_PHY_ID_88E1149R		0x01410e50
16#define MARVELL_PHY_ID_88E1240		0x01410e30
17#define MARVELL_PHY_ID_88E1318S		0x01410e90
18#define MARVELL_PHY_ID_88E1340S		0x01410dc0
19#define MARVELL_PHY_ID_88E1116R		0x01410e40
20#define MARVELL_PHY_ID_88E1510		0x01410dd0
21#define MARVELL_PHY_ID_88E1540		0x01410eb0
22#define MARVELL_PHY_ID_88E1545		0x01410ea0
23#define MARVELL_PHY_ID_88E1548P		0x01410ec0
24#define MARVELL_PHY_ID_88E3016		0x01410e60
25#define MARVELL_PHY_ID_88X3310		0x002b09a0
26#define MARVELL_PHY_ID_88E2110		0x002b09b0
27#define MARVELL_PHY_ID_88X2222		0x01410f10
28#define MARVELL_PHY_ID_88Q2110		0x002b0980
29#define MARVELL_PHY_ID_88Q2220		0x002b0b20
30
31/* Marvel 88E1111 in Finisar SFP module with modified PHY ID */
32#define MARVELL_PHY_ID_88E1111_FINISAR	0x01ff0cc0
33
34/* These Ethernet switch families contain embedded PHYs, but they do
35 * not have a model ID. So the switch driver traps reads to the ID2
36 * register and returns the switch family ID
37 */
38#define MARVELL_PHY_ID_88E6341_FAMILY	0x01410f41
39#define MARVELL_PHY_ID_88E6390_FAMILY	0x01410f90
40#define MARVELL_PHY_ID_88E6393_FAMILY	0x002b0b9b
41
42#define MARVELL_PHY_FAMILY_ID(id)	((id) >> 4)
43
44/* struct phy_device dev_flags definitions */
45#define MARVELL_PHY_M1145_FLAGS_RESISTANCE	0x00000001
46#define MARVELL_PHY_M1118_DNS323_LEDS		0x00000002
47#define MARVELL_PHY_LED0_LINK_LED1_ACTIVE	0x00000004
48
49#endif /* _MARVELL_PHY_H */
50