net: phy: marvell: add support for MV88E6250 family internal PHYs
[linux-2.6-block.git] / include / linux / marvell_phy.h
CommitLineData
b2441318 1/* SPDX-License-Identifier: GPL-2.0 */
2f495c39
BH
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
ada9841e 10#define MARVELL_PHY_ID_88E3082 0x01410c80
2f495c39
BH
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
90600732 16#define MARVELL_PHY_ID_88E1149R 0x01410e50
2f495c39 17#define MARVELL_PHY_ID_88E1240 0x01410e30
337ac9d5 18#define MARVELL_PHY_ID_88E1318S 0x01410e90
a602ea86 19#define MARVELL_PHY_ID_88E1340S 0x01410dc0
3da09a51 20#define MARVELL_PHY_ID_88E1116R 0x01410e40
10e24caa 21#define MARVELL_PHY_ID_88E1510 0x01410dd0
819ec8e1 22#define MARVELL_PHY_ID_88E1540 0x01410eb0
60f06fde 23#define MARVELL_PHY_ID_88E1545 0x01410ea0
f59babf9 24#define MARVELL_PHY_ID_88E1548P 0x01410ec0
6b358aed 25#define MARVELL_PHY_ID_88E3016 0x01410e60
a5de4be0 26#define MARVELL_PHY_ID_88X3310 0x002b09a0
62d01535 27#define MARVELL_PHY_ID_88E2110 0x002b09b0
6e3bac3e 28#define MARVELL_PHY_ID_88X2222 0x01410f10
00f11ac7 29#define MARVELL_PHY_ID_88Q2110 0x002b0980
e57e4c7f 30#define MARVELL_PHY_ID_88Q2220 0x002b0b20
2f495c39 31
1887023a
RH
32/* Marvel 88E1111 in Finisar SFP module with modified PHY ID */
33#define MARVELL_PHY_ID_88E1111_FINISAR 0x01ff0cc0
34
ecc2ae61
MS
35/* ID from 88E6020, assumed to be the same for the whole 6250 family */
36#define MARVELL_PHY_ID_88E6250_FAMILY 0x01410db0
1fe976d3 37/* These Ethernet switch families contain embedded PHYs, but they do
e4cf8a38
AL
38 * not have a model ID. So the switch driver traps reads to the ID2
39 * register and returns the switch family ID
40 */
1fe976d3
PR
41#define MARVELL_PHY_ID_88E6341_FAMILY 0x01410f41
42#define MARVELL_PHY_ID_88E6390_FAMILY 0x01410f90
a978f7c4 43#define MARVELL_PHY_ID_88E6393_FAMILY 0x002b0b9b
e4cf8a38 44
07777246
WD
45#define MARVELL_PHY_FAMILY_ID(id) ((id) >> 4)
46
2f495c39
BH
47/* struct phy_device dev_flags definitions */
48#define MARVELL_PHY_M1145_FLAGS_RESISTANCE 0x00000001
49#define MARVELL_PHY_M1118_DNS323_LEDS 0x00000002
a93f7fe1 50#define MARVELL_PHY_LED0_LINK_LED1_ACTIVE 0x00000004
2f495c39
BH
51
52#endif /* _MARVELL_PHY_H */