Greg Kroah-Hartman | b244131 | 2017-11-01 15:07:57 +0100 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0 */ |
Benjamin Herrenschmidt | 2f495c3 | 2010-06-21 13:20:46 +1000 | [diff] [blame] | 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 |
David Daney | 9060073 | 2010-11-19 11:58:53 +0000 | [diff] [blame] | 15 | #define MARVELL_PHY_ID_88E1149R 0x01410e50 |
Benjamin Herrenschmidt | 2f495c3 | 2010-06-21 13:20:46 +1000 | [diff] [blame] | 16 | #define MARVELL_PHY_ID_88E1240 0x01410e30 |
Cyril Chemparathy | 337ac9d | 2010-10-29 13:50:25 -0700 | [diff] [blame] | 17 | #define MARVELL_PHY_ID_88E1318S 0x01410e90 |
Michal Simek | 3da09a5 | 2013-05-30 20:08:26 +0000 | [diff] [blame] | 18 | #define MARVELL_PHY_ID_88E1116R 0x01410e40 |
Michal Simek | 10e24caa | 2013-05-30 20:08:27 +0000 | [diff] [blame] | 19 | #define MARVELL_PHY_ID_88E1510 0x01410dd0 |
Andrew Lunn | 819ec8e | 2015-11-16 23:34:41 +0100 | [diff] [blame] | 20 | #define MARVELL_PHY_ID_88E1540 0x01410eb0 |
Andrew Lunn | 60f06fd | 2017-02-02 00:35:03 +0100 | [diff] [blame] | 21 | #define MARVELL_PHY_ID_88E1545 0x01410ea0 |
Sebastian Hesselbarth | 6b358ae | 2014-10-22 20:26:44 +0200 | [diff] [blame] | 22 | #define MARVELL_PHY_ID_88E3016 0x01410e60 |
Maxime Chevallier | 631ba90 | 2019-02-23 00:37:41 +0100 | [diff] [blame] | 23 | #define MARVELL_PHY_ID_88X3310 0x002b09a0 |
Maxime Chevallier | 62d0153 | 2019-02-23 00:37:44 +0100 | [diff] [blame] | 24 | #define MARVELL_PHY_ID_88E2110 0x002b09b0 |
Benjamin Herrenschmidt | 2f495c3 | 2010-06-21 13:20:46 +1000 | [diff] [blame] | 25 | |
Andrew Lunn | e4cf8a3 | 2017-02-01 03:40:06 +0100 | [diff] [blame] | 26 | /* The MV88e6390 Ethernet switch contains embedded PHYs. These PHYs do |
| 27 | * not have a model ID. So the switch driver traps reads to the ID2 |
| 28 | * register and returns the switch family ID |
| 29 | */ |
| 30 | #define MARVELL_PHY_ID_88E6390 0x01410f90 |
| 31 | |
Wang Dongsheng | 0777724 | 2018-07-01 23:15:46 -0700 | [diff] [blame] | 32 | #define MARVELL_PHY_FAMILY_ID(id) ((id) >> 4) |
| 33 | |
Benjamin Herrenschmidt | 2f495c3 | 2010-06-21 13:20:46 +1000 | [diff] [blame] | 34 | /* struct phy_device dev_flags definitions */ |
| 35 | #define MARVELL_PHY_M1145_FLAGS_RESISTANCE 0x00000001 |
| 36 | #define MARVELL_PHY_M1118_DNS323_LEDS 0x00000002 |
Jian Shen | a93f7fe | 2019-04-22 21:52:23 +0800 | [diff] [blame] | 37 | #define MARVELL_PHY_LED0_LINK_LED1_ACTIVE 0x00000004 |
Benjamin Herrenschmidt | 2f495c3 | 2010-06-21 13:20:46 +1000 | [diff] [blame] | 38 | |
| 39 | #endif /* _MARVELL_PHY_H */ |