Troy Kisky | 80b6b09 | 2012-02-07 14:08:48 +0000 | [diff] [blame] | 1 | #ifndef _MICREL_H |
| 2 | |
| 3 | #define MII_KSZ9021_EXT_COMMON_CTRL 0x100 |
| 4 | #define MII_KSZ9021_EXT_STRAP_STATUS 0x101 |
| 5 | #define MII_KSZ9021_EXT_OP_STRAP_OVERRIDE 0x102 |
| 6 | #define MII_KSZ9021_EXT_OP_STRAP_STATUS 0x103 |
| 7 | #define MII_KSZ9021_EXT_RGMII_CLOCK_SKEW 0x104 |
| 8 | #define MII_KSZ9021_EXT_RGMII_RX_DATA_SKEW 0x105 |
| 9 | #define MII_KSZ9021_EXT_RGMII_TX_DATA_SKEW 0x106 |
| 10 | #define MII_KSZ9021_EXT_ANALOG_TEST 0x107 |
SARTRE Leo | eaf68ac | 2013-04-30 16:57:25 +0200 | [diff] [blame] | 11 | /* Register operations */ |
| 12 | #define MII_KSZ9031_MOD_REG 0x0000 |
| 13 | /* Data operations */ |
| 14 | #define MII_KSZ9031_MOD_DATA_NO_POST_INC 0x4000 |
| 15 | #define MII_KSZ9031_MOD_DATA_POST_INC_RW 0x8000 |
| 16 | #define MII_KSZ9031_MOD_DATA_POST_INC_W 0xC000 |
Troy Kisky | 80b6b09 | 2012-02-07 14:08:48 +0000 | [diff] [blame] | 17 | |
Stefano Babic | 66875d5 | 2013-09-02 15:42:28 +0200 | [diff] [blame] | 18 | #define MII_KSZ9031_EXT_RGMII_CTRL_SIG_SKEW 0x4 |
| 19 | #define MII_KSZ9031_EXT_RGMII_RX_DATA_SKEW 0x5 |
| 20 | #define MII_KSZ9031_EXT_RGMII_TX_DATA_SKEW 0x6 |
| 21 | #define MII_KSZ9031_EXT_RGMII_CLOCK_SKEW 0x8 |
| 22 | |
Ash Charles | 3f55bb6 | 2016-10-21 17:31:33 -0400 | [diff] [blame] | 23 | #define MII_KSZ9031_FLP_BURST_TX_LO 0x3 |
| 24 | #define MII_KSZ9031_FLP_BURST_TX_HI 0x4 |
| 25 | |
Philippe Schenker | be98837 | 2020-03-11 11:59:22 +0100 | [diff] [blame] | 26 | #define MII_KSZ9x31_SILICON_REV_MASK 0xfffff0 |
| 27 | |
Philippe Schenker | 2242ad5 | 2020-03-11 11:59:26 +0100 | [diff] [blame] | 28 | #define MII_KSZ9131_RXTXDLL_BYPASS BIT(12) |
| 29 | #define MII_KSZ9131_EXT_RGMII_2NS_SKEW_RXDLL 0x4c |
| 30 | #define MII_KSZ9131_EXT_RGMII_2NS_SKEW_TXDLL 0x4d |
| 31 | |
Philippe Schenker | be98837 | 2020-03-11 11:59:22 +0100 | [diff] [blame] | 32 | #define PHY_ID_KSZ9031 0x00221620 |
Philippe Schenker | 3060ecc | 2020-03-11 11:59:23 +0100 | [diff] [blame] | 33 | #define PHY_ID_KSZ9131 0x00221640 |
Philippe Schenker | be98837 | 2020-03-11 11:59:22 +0100 | [diff] [blame] | 34 | |
Otavio Salvador | e6b4782 | 2015-07-28 20:24:41 -0300 | [diff] [blame] | 35 | /* Registers */ |
| 36 | #define MMD_ACCESS_CONTROL 0xd |
| 37 | #define MMD_ACCESS_REG_DATA 0xe |
| 38 | |
Troy Kisky | 80b6b09 | 2012-02-07 14:08:48 +0000 | [diff] [blame] | 39 | struct phy_device; |
| 40 | int ksz9021_phy_extended_write(struct phy_device *phydev, int regnum, u16 val); |
| 41 | int ksz9021_phy_extended_read(struct phy_device *phydev, int regnum); |
| 42 | |
SARTRE Leo | eaf68ac | 2013-04-30 16:57:25 +0200 | [diff] [blame] | 43 | int ksz9031_phy_extended_write(struct phy_device *phydev, int devaddr, |
| 44 | int regnum, u16 mode, u16 val); |
| 45 | int ksz9031_phy_extended_read(struct phy_device *phydev, int devaddr, |
| 46 | int regnum, u16 mode); |
Philippe Schenker | 3060ecc | 2020-03-11 11:59:23 +0100 | [diff] [blame] | 47 | int ksz9xx1_phy_get_id(struct phy_device *phydev); |
SARTRE Leo | eaf68ac | 2013-04-30 16:57:25 +0200 | [diff] [blame] | 48 | |
Troy Kisky | 80b6b09 | 2012-02-07 14:08:48 +0000 | [diff] [blame] | 49 | #endif |