blob: f5cf19d1977633703d02d7bdf05def3dc32e85c2 [file] [log] [blame]
Andrew Scullb4b6d4a2019-01-02 15:54:55 +00001/* 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
Olivier Deprez157378f2022-04-04 15:47:50 +020018#define MARVELL_PHY_ID_88E1340S 0x01410dc0
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000019#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
Olivier Deprez157378f2022-04-04 15:47:50 +020023#define MARVELL_PHY_ID_88E1548P 0x01410ec0
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000024#define MARVELL_PHY_ID_88E3016 0x01410e60
David Brazdil0f672f62019-12-10 10:32:29 +000025#define MARVELL_PHY_ID_88X3310 0x002b09a0
26#define MARVELL_PHY_ID_88E2110 0x002b09b0
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000027
Olivier Deprez0e641232021-09-23 10:07:05 +020028/* These Ethernet switch families contain embedded PHYs, but they do
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000029 * not have a model ID. So the switch driver traps reads to the ID2
30 * register and returns the switch family ID
31 */
Olivier Deprez0e641232021-09-23 10:07:05 +020032#define MARVELL_PHY_ID_88E6341_FAMILY 0x01410f41
33#define MARVELL_PHY_ID_88E6390_FAMILY 0x01410f90
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000034
35#define MARVELL_PHY_FAMILY_ID(id) ((id) >> 4)
36
37/* struct phy_device dev_flags definitions */
38#define MARVELL_PHY_M1145_FLAGS_RESISTANCE 0x00000001
39#define MARVELL_PHY_M1118_DNS323_LEDS 0x00000002
David Brazdil0f672f62019-12-10 10:32:29 +000040#define MARVELL_PHY_LED0_LINK_LED1_ACTIVE 0x00000004
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000041
42#endif /* _MARVELL_PHY_H */