1 // SPDX-License-Identifier: GPL-2.0+ 2 /* 3 * drivers/net/phy/micrel.c 4 * 5 * Driver for Micrel PHYs 6 * 7 * Author: David J. Choi 8 * 9 * Copyright (c) 2010-2013 Micrel, Inc. 10 * Copyright (c) 2014 Johan Hovold <johan@kernel.org> 11 * 12 * Support : Micrel Phys: 13 * Giga phys: ksz9021, ksz9031, ksz9131, lan8841, lan8814 14 * 100/10 Phys : ksz8001, ksz8721, ksz8737, ksz8041 15 * ksz8021, ksz8031, ksz8051, 16 * ksz8081, ksz8091, 17 * ksz8061, 18 * Switch : ksz8873, ksz886x 19 * ksz9477, lan8804 20 */ 21 22 #include <linux/bitfield.h> 23 #include <linux/ethtool_netlink.h> 24 #include <linux/kernel.h> 25 #include <linux/module.h> 26 #include <linux/phy.h> 27 #include <linux/micrel_phy.h> 28 #include <linux/of.h> 29 #include <linux/clk.h> 30 #include <linux/delay.h> 31 #include <linux/ptp_clock_kernel.h> 32 #include <linux/ptp_clock.h> 33 #include <linux/ptp_classify.h> 34 #include <linux/net_tstamp.h> 35 #include <linux/gpio/consumer.h> 36 37 /* Operation Mode Strap Override */ 38 #define MII_KSZPHY_OMSO 0x16 39 #define KSZPHY_OMSO_FACTORY_TEST BIT(15) 40 #define KSZPHY_OMSO_B_CAST_OFF BIT(9) 41 #define KSZPHY_OMSO_NAND_TREE_ON BIT(5) 42 #define KSZPHY_OMSO_RMII_OVERRIDE BIT(1) 43 #define KSZPHY_OMSO_MII_OVERRIDE BIT(0) 44 45 /* general Interrupt control/status reg in vendor specific block. */ 46 #define MII_KSZPHY_INTCS 0x1B 47 #define KSZPHY_INTCS_JABBER BIT(15) 48 #define KSZPHY_INTCS_RECEIVE_ERR BIT(14) 49 #define KSZPHY_INTCS_PAGE_RECEIVE BIT(13) 50 #define KSZPHY_INTCS_PARELLEL BIT(12) 51 #define KSZPHY_INTCS_LINK_PARTNER_ACK BIT(11) 52 #define KSZPHY_INTCS_LINK_DOWN BIT(10) 53 #define KSZPHY_INTCS_REMOTE_FAULT BIT(9) 54 #define KSZPHY_INTCS_LINK_UP BIT(8) 55 #define KSZPHY_INTCS_ALL (KSZPHY_INTCS_LINK_UP |\ 56 KSZPHY_INTCS_LINK_DOWN) 57 #define KSZPHY_INTCS_LINK_DOWN_STATUS BIT(2) 58 #define KSZPHY_INTCS_LINK_UP_STATUS BIT(0) 59 #define KSZPHY_INTCS_STATUS (KSZPHY_INTCS_LINK_DOWN_STATUS |\ 60 KSZPHY_INTCS_LINK_UP_STATUS) 61 62 /* LinkMD Control/Status */ 63 #define KSZ8081_LMD 0x1d 64 #define KSZ8081_LMD_ENABLE_TEST BIT(15) 65 #define KSZ8081_LMD_STAT_NORMAL 0 66 #define KSZ8081_LMD_STAT_OPEN 1 67 #define KSZ8081_LMD_STAT_SHORT 2 68 #define KSZ8081_LMD_STAT_FAIL 3 69 #define KSZ8081_LMD_STAT_MASK GENMASK(14, 13) 70 /* Short cable (<10 meter) has been detected by LinkMD */ 71 #define KSZ8081_LMD_SHORT_INDICATOR BIT(12) 72 #define KSZ8081_LMD_DELTA_TIME_MASK GENMASK(8, 0) 73 74 #define KSZ9x31_LMD 0x12 75 #define KSZ9x31_LMD_VCT_EN BIT(15) 76 #define KSZ9x31_LMD_VCT_DIS_TX BIT(14) 77 #define KSZ9x31_LMD_VCT_PAIR(n) (((n) & 0x3) << 12) 78 #define KSZ9x31_LMD_VCT_SEL_RESULT 0 79 #define KSZ9x31_LMD_VCT_SEL_THRES_HI BIT(10) 80 #define KSZ9x31_LMD_VCT_SEL_THRES_LO BIT(11) 81 #define KSZ9x31_LMD_VCT_SEL_MASK GENMASK(11, 10) 82 #define KSZ9x31_LMD_VCT_ST_NORMAL 0 83 #define KSZ9x31_LMD_VCT_ST_OPEN 1 84 #define KSZ9x31_LMD_VCT_ST_SHORT 2 85 #define KSZ9x31_LMD_VCT_ST_FAIL 3 86 #define KSZ9x31_LMD_VCT_ST_MASK GENMASK(9, 8) 87 #define KSZ9x31_LMD_VCT_DATA_REFLECTED_INVALID BIT(7) 88 #define KSZ9x31_LMD_VCT_DATA_SIG_WAIT_TOO_LONG BIT(6) 89 #define KSZ9x31_LMD_VCT_DATA_MASK100 BIT(5) 90 #define KSZ9x31_LMD_VCT_DATA_NLP_FLP BIT(4) 91 #define KSZ9x31_LMD_VCT_DATA_LO_PULSE_MASK GENMASK(3, 2) 92 #define KSZ9x31_LMD_VCT_DATA_HI_PULSE_MASK GENMASK(1, 0) 93 #define KSZ9x31_LMD_VCT_DATA_MASK GENMASK(7, 0) 94 95 #define KSZPHY_WIRE_PAIR_MASK 0x3 96 97 #define LAN8814_CABLE_DIAG 0x12 98 #define LAN8814_CABLE_DIAG_STAT_MASK GENMASK(9, 8) 99 #define LAN8814_CABLE_DIAG_VCT_DATA_MASK GENMASK(7, 0) 100 #define LAN8814_PAIR_BIT_SHIFT 12 101 102 #define LAN8814_WIRE_PAIR_MASK 0xF 103 104 /* Lan8814 general Interrupt control/status reg in GPHY specific block. */ 105 #define LAN8814_INTC 0x18 106 #define LAN8814_INTS 0x1B 107 108 #define LAN8814_INT_LINK_DOWN BIT(2) 109 #define LAN8814_INT_LINK_UP BIT(0) 110 #define LAN8814_INT_LINK (LAN8814_INT_LINK_UP |\ 111 LAN8814_INT_LINK_DOWN) 112 113 #define LAN8814_INTR_CTRL_REG 0x34 114 #define LAN8814_INTR_CTRL_REG_POLARITY BIT(1) 115 #define LAN8814_INTR_CTRL_REG_INTR_ENABLE BIT(0) 116 117 #define LAN8814_EEE_STATE 0x38 118 #define LAN8814_EEE_STATE_MASK2P5P BIT(10) 119 120 #define LAN8814_PD_CONTROLS 0x9d 121 #define LAN8814_PD_CONTROLS_PD_MEAS_TIME_MASK GENMASK(3, 0) 122 #define LAN8814_PD_CONTROLS_PD_MEAS_TIME_VAL 0xb 123 124 /* Represents 1ppm adjustment in 2^32 format with 125 * each nsec contains 4 clock cycles. 126 * The value is calculated as following: (1/1000000)/((2^-32)/4) 127 */ 128 #define LAN8814_1PPM_FORMAT 17179 129 130 /* Represents 1ppm adjustment in 2^32 format with 131 * each nsec contains 8 clock cycles. 132 * The value is calculated as following: (1/1000000)/((2^-32)/8) 133 */ 134 #define LAN8841_1PPM_FORMAT 34360 135 136 #define PTP_RX_VERSION 0x0248 137 #define PTP_TX_VERSION 0x0288 138 #define PTP_MAX_VERSION(x) (((x) & GENMASK(7, 0)) << 8) 139 #define PTP_MIN_VERSION(x) ((x) & GENMASK(7, 0)) 140 141 #define PTP_RX_MOD 0x024F 142 #define PTP_RX_MOD_BAD_UDPV4_CHKSUM_FORCE_FCS_DIS_ BIT(3) 143 #define PTP_RX_TIMESTAMP_EN 0x024D 144 #define PTP_TX_TIMESTAMP_EN 0x028D 145 146 #define PTP_TIMESTAMP_EN_SYNC_ BIT(0) 147 #define PTP_TIMESTAMP_EN_DREQ_ BIT(1) 148 #define PTP_TIMESTAMP_EN_PDREQ_ BIT(2) 149 #define PTP_TIMESTAMP_EN_PDRES_ BIT(3) 150 151 #define PTP_TX_PARSE_L2_ADDR_EN 0x0284 152 #define PTP_RX_PARSE_L2_ADDR_EN 0x0244 153 154 #define PTP_TX_PARSE_IP_ADDR_EN 0x0285 155 #define PTP_RX_PARSE_IP_ADDR_EN 0x0245 156 #define LTC_HARD_RESET 0x023F 157 #define LTC_HARD_RESET_ BIT(0) 158 159 #define TSU_HARD_RESET 0x02C1 160 #define TSU_HARD_RESET_ BIT(0) 161 162 #define PTP_CMD_CTL 0x0200 163 #define PTP_CMD_CTL_PTP_DISABLE_ BIT(0) 164 #define PTP_CMD_CTL_PTP_ENABLE_ BIT(1) 165 #define PTP_CMD_CTL_PTP_CLOCK_READ_ BIT(3) 166 #define PTP_CMD_CTL_PTP_CLOCK_LOAD_ BIT(4) 167 #define PTP_CMD_CTL_PTP_LTC_STEP_SEC_ BIT(5) 168 #define PTP_CMD_CTL_PTP_LTC_STEP_NSEC_ BIT(6) 169 170 #define PTP_COMMON_INT_ENA 0x0204 171 #define PTP_COMMON_INT_ENA_GPIO_CAP_EN BIT(2) 172 173 #define PTP_CLOCK_SET_SEC_HI 0x0205 174 #define PTP_CLOCK_SET_SEC_MID 0x0206 175 #define PTP_CLOCK_SET_SEC_LO 0x0207 176 #define PTP_CLOCK_SET_NS_HI 0x0208 177 #define PTP_CLOCK_SET_NS_LO 0x0209 178 179 #define PTP_CLOCK_READ_SEC_HI 0x0229 180 #define PTP_CLOCK_READ_SEC_MID 0x022A 181 #define PTP_CLOCK_READ_SEC_LO 0x022B 182 #define PTP_CLOCK_READ_NS_HI 0x022C 183 #define PTP_CLOCK_READ_NS_LO 0x022D 184 185 #define PTP_GPIO_SEL 0x0230 186 #define PTP_GPIO_SEL_GPIO_SEL(pin) ((pin) << 8) 187 #define PTP_GPIO_CAP_MAP_LO 0x0232 188 189 #define PTP_GPIO_CAP_EN 0x0233 190 #define PTP_GPIO_CAP_EN_GPIO_RE_CAPTURE_ENABLE(gpio) BIT(gpio) 191 #define PTP_GPIO_CAP_EN_GPIO_FE_CAPTURE_ENABLE(gpio) (BIT(gpio) << 8) 192 193 #define PTP_GPIO_RE_LTC_SEC_HI_CAP 0x0235 194 #define PTP_GPIO_RE_LTC_SEC_LO_CAP 0x0236 195 #define PTP_GPIO_RE_LTC_NS_HI_CAP 0x0237 196 #define PTP_GPIO_RE_LTC_NS_LO_CAP 0x0238 197 #define PTP_GPIO_FE_LTC_SEC_HI_CAP 0x0239 198 #define PTP_GPIO_FE_LTC_SEC_LO_CAP 0x023A 199 #define PTP_GPIO_FE_LTC_NS_HI_CAP 0x023B 200 #define PTP_GPIO_FE_LTC_NS_LO_CAP 0x023C 201 202 #define PTP_GPIO_CAP_STS 0x023D 203 #define PTP_GPIO_CAP_STS_PTP_GPIO_RE_STS(gpio) BIT(gpio) 204 #define PTP_GPIO_CAP_STS_PTP_GPIO_FE_STS(gpio) (BIT(gpio) << 8) 205 206 #define PTP_OPERATING_MODE 0x0241 207 #define PTP_OPERATING_MODE_STANDALONE_ BIT(0) 208 209 #define PTP_TX_MOD 0x028F 210 #define PTP_TX_MOD_TX_PTP_SYNC_TS_INSERT_ BIT(12) 211 #define PTP_TX_MOD_BAD_UDPV4_CHKSUM_FORCE_FCS_DIS_ BIT(3) 212 213 #define PTP_RX_PARSE_CONFIG 0x0242 214 #define PTP_RX_PARSE_CONFIG_LAYER2_EN_ BIT(0) 215 #define PTP_RX_PARSE_CONFIG_IPV4_EN_ BIT(1) 216 #define PTP_RX_PARSE_CONFIG_IPV6_EN_ BIT(2) 217 218 #define PTP_TX_PARSE_CONFIG 0x0282 219 #define PTP_TX_PARSE_CONFIG_LAYER2_EN_ BIT(0) 220 #define PTP_TX_PARSE_CONFIG_IPV4_EN_ BIT(1) 221 #define PTP_TX_PARSE_CONFIG_IPV6_EN_ BIT(2) 222 223 #define PTP_CLOCK_RATE_ADJ_HI 0x020C 224 #define PTP_CLOCK_RATE_ADJ_LO 0x020D 225 #define PTP_CLOCK_RATE_ADJ_DIR_ BIT(15) 226 227 #define PTP_LTC_STEP_ADJ_HI 0x0212 228 #define PTP_LTC_STEP_ADJ_LO 0x0213 229 #define PTP_LTC_STEP_ADJ_DIR_ BIT(15) 230 231 #define LAN8814_INTR_STS_REG 0x0033 232 #define LAN8814_INTR_STS_REG_1588_TSU0_ BIT(0) 233 #define LAN8814_INTR_STS_REG_1588_TSU1_ BIT(1) 234 #define LAN8814_INTR_STS_REG_1588_TSU2_ BIT(2) 235 #define LAN8814_INTR_STS_REG_1588_TSU3_ BIT(3) 236 237 #define PTP_CAP_INFO 0x022A 238 #define PTP_CAP_INFO_TX_TS_CNT_GET_(reg_val) (((reg_val) & 0x0f00) >> 8) 239 #define PTP_CAP_INFO_RX_TS_CNT_GET_(reg_val) ((reg_val) & 0x000f) 240 241 #define PTP_TX_EGRESS_SEC_HI 0x0296 242 #define PTP_TX_EGRESS_SEC_LO 0x0297 243 #define PTP_TX_EGRESS_NS_HI 0x0294 244 #define PTP_TX_EGRESS_NS_LO 0x0295 245 #define PTP_TX_MSG_HEADER2 0x0299 246 247 #define PTP_RX_INGRESS_SEC_HI 0x0256 248 #define PTP_RX_INGRESS_SEC_LO 0x0257 249 #define PTP_RX_INGRESS_NS_HI 0x0254 250 #define PTP_RX_INGRESS_NS_LO 0x0255 251 #define PTP_RX_MSG_HEADER2 0x0259 252 253 #define PTP_TSU_INT_EN 0x0200 254 #define PTP_TSU_INT_EN_PTP_TX_TS_OVRFL_EN_ BIT(3) 255 #define PTP_TSU_INT_EN_PTP_TX_TS_EN_ BIT(2) 256 #define PTP_TSU_INT_EN_PTP_RX_TS_OVRFL_EN_ BIT(1) 257 #define PTP_TSU_INT_EN_PTP_RX_TS_EN_ BIT(0) 258 259 #define PTP_TSU_INT_STS 0x0201 260 #define PTP_TSU_INT_STS_PTP_TX_TS_OVRFL_INT_ BIT(3) 261 #define PTP_TSU_INT_STS_PTP_TX_TS_EN_ BIT(2) 262 #define PTP_TSU_INT_STS_PTP_RX_TS_OVRFL_INT_ BIT(1) 263 #define PTP_TSU_INT_STS_PTP_RX_TS_EN_ BIT(0) 264 265 #define LAN8814_LED_CTRL_1 0x0 266 #define LAN8814_LED_CTRL_1_KSZ9031_LED_MODE_ BIT(6) 267 268 /* PHY Control 1 */ 269 #define MII_KSZPHY_CTRL_1 0x1e 270 #define KSZ8081_CTRL1_MDIX_STAT BIT(4) 271 272 /* PHY Control 2 / PHY Control (if no PHY Control 1) */ 273 #define MII_KSZPHY_CTRL_2 0x1f 274 #define MII_KSZPHY_CTRL MII_KSZPHY_CTRL_2 275 /* bitmap of PHY register to set interrupt mode */ 276 #define KSZ8081_CTRL2_HP_MDIX BIT(15) 277 #define KSZ8081_CTRL2_MDI_MDI_X_SELECT BIT(14) 278 #define KSZ8081_CTRL2_DISABLE_AUTO_MDIX BIT(13) 279 #define KSZ8081_CTRL2_FORCE_LINK BIT(11) 280 #define KSZ8081_CTRL2_POWER_SAVING BIT(10) 281 #define KSZPHY_CTRL_INT_ACTIVE_HIGH BIT(9) 282 #define KSZPHY_RMII_REF_CLK_SEL BIT(7) 283 284 /* Write/read to/from extended registers */ 285 #define MII_KSZPHY_EXTREG 0x0b 286 #define KSZPHY_EXTREG_WRITE 0x8000 287 288 #define MII_KSZPHY_EXTREG_WRITE 0x0c 289 #define MII_KSZPHY_EXTREG_READ 0x0d 290 291 /* Extended registers */ 292 #define MII_KSZPHY_CLK_CONTROL_PAD_SKEW 0x104 293 #define MII_KSZPHY_RX_DATA_PAD_SKEW 0x105 294 #define MII_KSZPHY_TX_DATA_PAD_SKEW 0x106 295 296 #define PS_TO_REG 200 297 #define FIFO_SIZE 8 298 299 #define LAN8814_PTP_GPIO_NUM 24 300 #define LAN8814_PTP_PEROUT_NUM 2 301 #define LAN8814_PTP_EXTTS_NUM 3 302 303 #define LAN8814_BUFFER_TIME 2 304 305 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_200MS 13 306 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_100MS 12 307 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_50MS 11 308 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_10MS 10 309 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_5MS 9 310 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_1MS 8 311 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_500US 7 312 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_100US 6 313 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_50US 5 314 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_10US 4 315 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_5US 3 316 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_1US 2 317 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_500NS 1 318 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_100NS 0 319 320 #define LAN8814_GPIO_EN1 0x20 321 #define LAN8814_GPIO_EN2 0x21 322 #define LAN8814_GPIO_DIR1 0x22 323 #define LAN8814_GPIO_DIR2 0x23 324 #define LAN8814_GPIO_BUF1 0x24 325 #define LAN8814_GPIO_BUF2 0x25 326 327 #define LAN8814_GPIO_EN_ADDR(pin) \ 328 ((pin) > 15 ? LAN8814_GPIO_EN1 : LAN8814_GPIO_EN2) 329 #define LAN8814_GPIO_EN_BIT(pin) BIT(pin) 330 #define LAN8814_GPIO_DIR_ADDR(pin) \ 331 ((pin) > 15 ? LAN8814_GPIO_DIR1 : LAN8814_GPIO_DIR2) 332 #define LAN8814_GPIO_DIR_BIT(pin) BIT(pin) 333 #define LAN8814_GPIO_BUF_ADDR(pin) \ 334 ((pin) > 15 ? LAN8814_GPIO_BUF1 : LAN8814_GPIO_BUF2) 335 #define LAN8814_GPIO_BUF_BIT(pin) BIT(pin) 336 337 #define LAN8814_EVENT_A 0 338 #define LAN8814_EVENT_B 1 339 340 #define LAN8814_PTP_GENERAL_CONFIG 0x0201 341 #define LAN8814_PTP_GENERAL_CONFIG_LTC_EVENT_MASK(event) \ 342 ((event) ? GENMASK(11, 8) : GENMASK(7, 4)) 343 #define LAN8814_PTP_GENERAL_CONFIG_LTC_EVENT_SET(event, value) \ 344 (((value) & GENMASK(3, 0)) << (4 + ((event) << 2))) 345 #define LAN8814_PTP_GENERAL_CONFIG_RELOAD_ADD_X(event) \ 346 ((event) ? BIT(2) : BIT(0)) 347 #define LAN8814_PTP_GENERAL_CONFIG_POLARITY_X(event) \ 348 ((event) ? BIT(3) : BIT(1)) 349 350 #define LAN8814_PTP_CLOCK_TARGET_SEC_HI(event) ((event) ? 0x21F : 0x215) 351 #define LAN8814_PTP_CLOCK_TARGET_SEC_LO(event) ((event) ? 0x220 : 0x216) 352 #define LAN8814_PTP_CLOCK_TARGET_NS_HI(event) ((event) ? 0x221 : 0x217) 353 #define LAN8814_PTP_CLOCK_TARGET_NS_LO(event) ((event) ? 0x222 : 0x218) 354 355 #define LAN8814_PTP_CLOCK_TARGET_RELOAD_SEC_HI(event) ((event) ? 0x223 : 0x219) 356 #define LAN8814_PTP_CLOCK_TARGET_RELOAD_SEC_LO(event) ((event) ? 0x224 : 0x21A) 357 #define LAN8814_PTP_CLOCK_TARGET_RELOAD_NS_HI(event) ((event) ? 0x225 : 0x21B) 358 #define LAN8814_PTP_CLOCK_TARGET_RELOAD_NS_LO(event) ((event) ? 0x226 : 0x21C) 359 360 /* Delay used to get the second part from the LTC */ 361 #define LAN8841_GET_SEC_LTC_DELAY (500 * NSEC_PER_MSEC) 362 363 struct kszphy_hw_stat { 364 const char *string; 365 u8 reg; 366 u8 bits; 367 }; 368 369 static struct kszphy_hw_stat kszphy_hw_stats[] = { 370 { "phy_receive_errors", 21, 16}, 371 { "phy_idle_errors", 10, 8 }, 372 }; 373 374 struct kszphy_type { 375 u32 led_mode_reg; 376 u16 interrupt_level_mask; 377 u16 cable_diag_reg; 378 unsigned long pair_mask; 379 u16 disable_dll_tx_bit; 380 u16 disable_dll_rx_bit; 381 u16 disable_dll_mask; 382 bool has_broadcast_disable; 383 bool has_nand_tree_disable; 384 bool has_rmii_ref_clk_sel; 385 }; 386 387 /* Shared structure between the PHYs of the same package. */ 388 struct lan8814_shared_priv { 389 struct phy_device *phydev; 390 struct ptp_clock *ptp_clock; 391 struct ptp_clock_info ptp_clock_info; 392 struct ptp_pin_desc *pin_config; 393 394 /* Lock for ptp_clock */ 395 struct mutex shared_lock; 396 }; 397 398 struct lan8814_ptp_rx_ts { 399 struct list_head list; 400 u32 seconds; 401 u32 nsec; 402 u16 seq_id; 403 }; 404 405 struct kszphy_ptp_priv { 406 struct mii_timestamper mii_ts; 407 struct phy_device *phydev; 408 409 struct sk_buff_head tx_queue; 410 struct sk_buff_head rx_queue; 411 412 struct list_head rx_ts_list; 413 /* Lock for Rx ts fifo */ 414 spinlock_t rx_ts_lock; 415 416 int hwts_tx_type; 417 enum hwtstamp_rx_filters rx_filter; 418 int layer; 419 int version; 420 421 struct ptp_clock *ptp_clock; 422 struct ptp_clock_info ptp_clock_info; 423 /* Lock for ptp_clock */ 424 struct mutex ptp_lock; 425 struct ptp_pin_desc *pin_config; 426 427 s64 seconds; 428 /* Lock for accessing seconds */ 429 spinlock_t seconds_lock; 430 }; 431 432 struct kszphy_priv { 433 struct kszphy_ptp_priv ptp_priv; 434 const struct kszphy_type *type; 435 int led_mode; 436 u16 vct_ctrl1000; 437 bool rmii_ref_clk_sel; 438 bool rmii_ref_clk_sel_val; 439 u64 stats[ARRAY_SIZE(kszphy_hw_stats)]; 440 }; 441 442 static const struct kszphy_type lan8814_type = { 443 .led_mode_reg = ~LAN8814_LED_CTRL_1, 444 .cable_diag_reg = LAN8814_CABLE_DIAG, 445 .pair_mask = LAN8814_WIRE_PAIR_MASK, 446 }; 447 448 static const struct kszphy_type ksz886x_type = { 449 .cable_diag_reg = KSZ8081_LMD, 450 .pair_mask = KSZPHY_WIRE_PAIR_MASK, 451 }; 452 453 static const struct kszphy_type ksz8021_type = { 454 .led_mode_reg = MII_KSZPHY_CTRL_2, 455 .has_broadcast_disable = true, 456 .has_nand_tree_disable = true, 457 .has_rmii_ref_clk_sel = true, 458 }; 459 460 static const struct kszphy_type ksz8041_type = { 461 .led_mode_reg = MII_KSZPHY_CTRL_1, 462 }; 463 464 static const struct kszphy_type ksz8051_type = { 465 .led_mode_reg = MII_KSZPHY_CTRL_2, 466 .has_nand_tree_disable = true, 467 }; 468 469 static const struct kszphy_type ksz8081_type = { 470 .led_mode_reg = MII_KSZPHY_CTRL_2, 471 .has_broadcast_disable = true, 472 .has_nand_tree_disable = true, 473 .has_rmii_ref_clk_sel = true, 474 }; 475 476 static const struct kszphy_type ks8737_type = { 477 .interrupt_level_mask = BIT(14), 478 }; 479 480 static const struct kszphy_type ksz9021_type = { 481 .interrupt_level_mask = BIT(14), 482 }; 483 484 static const struct kszphy_type ksz9131_type = { 485 .interrupt_level_mask = BIT(14), 486 .disable_dll_tx_bit = BIT(12), 487 .disable_dll_rx_bit = BIT(12), 488 .disable_dll_mask = BIT_MASK(12), 489 }; 490 491 static const struct kszphy_type lan8841_type = { 492 .disable_dll_tx_bit = BIT(14), 493 .disable_dll_rx_bit = BIT(14), 494 .disable_dll_mask = BIT_MASK(14), 495 .cable_diag_reg = LAN8814_CABLE_DIAG, 496 .pair_mask = LAN8814_WIRE_PAIR_MASK, 497 }; 498 499 static int kszphy_extended_write(struct phy_device *phydev, 500 u32 regnum, u16 val) 501 { 502 phy_write(phydev, MII_KSZPHY_EXTREG, KSZPHY_EXTREG_WRITE | regnum); 503 return phy_write(phydev, MII_KSZPHY_EXTREG_WRITE, val); 504 } 505 506 static int kszphy_extended_read(struct phy_device *phydev, 507 u32 regnum) 508 { 509 phy_write(phydev, MII_KSZPHY_EXTREG, regnum); 510 return phy_read(phydev, MII_KSZPHY_EXTREG_READ); 511 } 512 513 static int kszphy_ack_interrupt(struct phy_device *phydev) 514 { 515 /* bit[7..0] int status, which is a read and clear register. */ 516 int rc; 517 518 rc = phy_read(phydev, MII_KSZPHY_INTCS); 519 520 return (rc < 0) ? rc : 0; 521 } 522 523 static int kszphy_config_intr(struct phy_device *phydev) 524 { 525 const struct kszphy_type *type = phydev->drv->driver_data; 526 int temp, err; 527 u16 mask; 528 529 if (type && type->interrupt_level_mask) 530 mask = type->interrupt_level_mask; 531 else 532 mask = KSZPHY_CTRL_INT_ACTIVE_HIGH; 533 534 /* set the interrupt pin active low */ 535 temp = phy_read(phydev, MII_KSZPHY_CTRL); 536 if (temp < 0) 537 return temp; 538 temp &= ~mask; 539 phy_write(phydev, MII_KSZPHY_CTRL, temp); 540 541 /* enable / disable interrupts */ 542 if (phydev->interrupts == PHY_INTERRUPT_ENABLED) { 543 err = kszphy_ack_interrupt(phydev); 544 if (err) 545 return err; 546 547 err = phy_write(phydev, MII_KSZPHY_INTCS, KSZPHY_INTCS_ALL); 548 } else { 549 err = phy_write(phydev, MII_KSZPHY_INTCS, 0); 550 if (err) 551 return err; 552 553 err = kszphy_ack_interrupt(phydev); 554 } 555 556 return err; 557 } 558 559 static irqreturn_t kszphy_handle_interrupt(struct phy_device *phydev) 560 { 561 int irq_status; 562 563 irq_status = phy_read(phydev, MII_KSZPHY_INTCS); 564 if (irq_status < 0) { 565 phy_error(phydev); 566 return IRQ_NONE; 567 } 568 569 if (!(irq_status & KSZPHY_INTCS_STATUS)) 570 return IRQ_NONE; 571 572 phy_trigger_machine(phydev); 573 574 return IRQ_HANDLED; 575 } 576 577 static int kszphy_rmii_clk_sel(struct phy_device *phydev, bool val) 578 { 579 int ctrl; 580 581 ctrl = phy_read(phydev, MII_KSZPHY_CTRL); 582 if (ctrl < 0) 583 return ctrl; 584 585 if (val) 586 ctrl |= KSZPHY_RMII_REF_CLK_SEL; 587 else 588 ctrl &= ~KSZPHY_RMII_REF_CLK_SEL; 589 590 return phy_write(phydev, MII_KSZPHY_CTRL, ctrl); 591 } 592 593 static int kszphy_setup_led(struct phy_device *phydev, u32 reg, int val) 594 { 595 int rc, temp, shift; 596 597 switch (reg) { 598 case MII_KSZPHY_CTRL_1: 599 shift = 14; 600 break; 601 case MII_KSZPHY_CTRL_2: 602 shift = 4; 603 break; 604 default: 605 return -EINVAL; 606 } 607 608 temp = phy_read(phydev, reg); 609 if (temp < 0) { 610 rc = temp; 611 goto out; 612 } 613 614 temp &= ~(3 << shift); 615 temp |= val << shift; 616 rc = phy_write(phydev, reg, temp); 617 out: 618 if (rc < 0) 619 phydev_err(phydev, "failed to set led mode\n"); 620 621 return rc; 622 } 623 624 /* Disable PHY address 0 as the broadcast address, so that it can be used as a 625 * unique (non-broadcast) address on a shared bus. 626 */ 627 static int kszphy_broadcast_disable(struct phy_device *phydev) 628 { 629 int ret; 630 631 ret = phy_read(phydev, MII_KSZPHY_OMSO); 632 if (ret < 0) 633 goto out; 634 635 ret = phy_write(phydev, MII_KSZPHY_OMSO, ret | KSZPHY_OMSO_B_CAST_OFF); 636 out: 637 if (ret) 638 phydev_err(phydev, "failed to disable broadcast address\n"); 639 640 return ret; 641 } 642 643 static int kszphy_nand_tree_disable(struct phy_device *phydev) 644 { 645 int ret; 646 647 ret = phy_read(phydev, MII_KSZPHY_OMSO); 648 if (ret < 0) 649 goto out; 650 651 if (!(ret & KSZPHY_OMSO_NAND_TREE_ON)) 652 return 0; 653 654 ret = phy_write(phydev, MII_KSZPHY_OMSO, 655 ret & ~KSZPHY_OMSO_NAND_TREE_ON); 656 out: 657 if (ret) 658 phydev_err(phydev, "failed to disable NAND tree mode\n"); 659 660 return ret; 661 } 662 663 /* Some config bits need to be set again on resume, handle them here. */ 664 static int kszphy_config_reset(struct phy_device *phydev) 665 { 666 struct kszphy_priv *priv = phydev->priv; 667 int ret; 668 669 if (priv->rmii_ref_clk_sel) { 670 ret = kszphy_rmii_clk_sel(phydev, priv->rmii_ref_clk_sel_val); 671 if (ret) { 672 phydev_err(phydev, 673 "failed to set rmii reference clock\n"); 674 return ret; 675 } 676 } 677 678 if (priv->type && priv->led_mode >= 0) 679 kszphy_setup_led(phydev, priv->type->led_mode_reg, priv->led_mode); 680 681 return 0; 682 } 683 684 static int kszphy_config_init(struct phy_device *phydev) 685 { 686 struct kszphy_priv *priv = phydev->priv; 687 const struct kszphy_type *type; 688 689 if (!priv) 690 return 0; 691 692 type = priv->type; 693 694 if (type && type->has_broadcast_disable) 695 kszphy_broadcast_disable(phydev); 696 697 if (type && type->has_nand_tree_disable) 698 kszphy_nand_tree_disable(phydev); 699 700 return kszphy_config_reset(phydev); 701 } 702 703 static int ksz8041_fiber_mode(struct phy_device *phydev) 704 { 705 struct device_node *of_node = phydev->mdio.dev.of_node; 706 707 return of_property_read_bool(of_node, "micrel,fiber-mode"); 708 } 709 710 static int ksz8041_config_init(struct phy_device *phydev) 711 { 712 __ETHTOOL_DECLARE_LINK_MODE_MASK(mask) = { 0, }; 713 714 /* Limit supported and advertised modes in fiber mode */ 715 if (ksz8041_fiber_mode(phydev)) { 716 phydev->dev_flags |= MICREL_PHY_FXEN; 717 linkmode_set_bit(ETHTOOL_LINK_MODE_100baseT_Full_BIT, mask); 718 linkmode_set_bit(ETHTOOL_LINK_MODE_100baseT_Half_BIT, mask); 719 720 linkmode_and(phydev->supported, phydev->supported, mask); 721 linkmode_set_bit(ETHTOOL_LINK_MODE_FIBRE_BIT, 722 phydev->supported); 723 linkmode_and(phydev->advertising, phydev->advertising, mask); 724 linkmode_set_bit(ETHTOOL_LINK_MODE_FIBRE_BIT, 725 phydev->advertising); 726 phydev->autoneg = AUTONEG_DISABLE; 727 } 728 729 return kszphy_config_init(phydev); 730 } 731 732 static int ksz8041_config_aneg(struct phy_device *phydev) 733 { 734 /* Skip auto-negotiation in fiber mode */ 735 if (phydev->dev_flags & MICREL_PHY_FXEN) { 736 phydev->speed = SPEED_100; 737 return 0; 738 } 739 740 return genphy_config_aneg(phydev); 741 } 742 743 static int ksz8051_ksz8795_match_phy_device(struct phy_device *phydev, 744 const bool ksz_8051) 745 { 746 int ret; 747 748 if (!phy_id_compare(phydev->phy_id, PHY_ID_KSZ8051, MICREL_PHY_ID_MASK)) 749 return 0; 750 751 ret = phy_read(phydev, MII_BMSR); 752 if (ret < 0) 753 return ret; 754 755 /* KSZ8051 PHY and KSZ8794/KSZ8795/KSZ8765 switch share the same 756 * exact PHY ID. However, they can be told apart by the extended 757 * capability registers presence. The KSZ8051 PHY has them while 758 * the switch does not. 759 */ 760 ret &= BMSR_ERCAP; 761 if (ksz_8051) 762 return ret; 763 else 764 return !ret; 765 } 766 767 static int ksz8051_match_phy_device(struct phy_device *phydev) 768 { 769 return ksz8051_ksz8795_match_phy_device(phydev, true); 770 } 771 772 static int ksz8081_config_init(struct phy_device *phydev) 773 { 774 /* KSZPHY_OMSO_FACTORY_TEST is set at de-assertion of the reset line 775 * based on the RXER (KSZ8081RNA/RND) or TXC (KSZ8081MNX/RNB) pin. If a 776 * pull-down is missing, the factory test mode should be cleared by 777 * manually writing a 0. 778 */ 779 phy_clear_bits(phydev, MII_KSZPHY_OMSO, KSZPHY_OMSO_FACTORY_TEST); 780 781 return kszphy_config_init(phydev); 782 } 783 784 static int ksz8081_config_mdix(struct phy_device *phydev, u8 ctrl) 785 { 786 u16 val; 787 788 switch (ctrl) { 789 case ETH_TP_MDI: 790 val = KSZ8081_CTRL2_DISABLE_AUTO_MDIX; 791 break; 792 case ETH_TP_MDI_X: 793 val = KSZ8081_CTRL2_DISABLE_AUTO_MDIX | 794 KSZ8081_CTRL2_MDI_MDI_X_SELECT; 795 break; 796 case ETH_TP_MDI_AUTO: 797 val = 0; 798 break; 799 default: 800 return 0; 801 } 802 803 return phy_modify(phydev, MII_KSZPHY_CTRL_2, 804 KSZ8081_CTRL2_HP_MDIX | 805 KSZ8081_CTRL2_MDI_MDI_X_SELECT | 806 KSZ8081_CTRL2_DISABLE_AUTO_MDIX, 807 KSZ8081_CTRL2_HP_MDIX | val); 808 } 809 810 static int ksz8081_config_aneg(struct phy_device *phydev) 811 { 812 int ret; 813 814 ret = genphy_config_aneg(phydev); 815 if (ret) 816 return ret; 817 818 /* The MDI-X configuration is automatically changed by the PHY after 819 * switching from autoneg off to on. So, take MDI-X configuration under 820 * own control and set it after autoneg configuration was done. 821 */ 822 return ksz8081_config_mdix(phydev, phydev->mdix_ctrl); 823 } 824 825 static int ksz8081_mdix_update(struct phy_device *phydev) 826 { 827 int ret; 828 829 ret = phy_read(phydev, MII_KSZPHY_CTRL_2); 830 if (ret < 0) 831 return ret; 832 833 if (ret & KSZ8081_CTRL2_DISABLE_AUTO_MDIX) { 834 if (ret & KSZ8081_CTRL2_MDI_MDI_X_SELECT) 835 phydev->mdix_ctrl = ETH_TP_MDI_X; 836 else 837 phydev->mdix_ctrl = ETH_TP_MDI; 838 } else { 839 phydev->mdix_ctrl = ETH_TP_MDI_AUTO; 840 } 841 842 ret = phy_read(phydev, MII_KSZPHY_CTRL_1); 843 if (ret < 0) 844 return ret; 845 846 if (ret & KSZ8081_CTRL1_MDIX_STAT) 847 phydev->mdix = ETH_TP_MDI; 848 else 849 phydev->mdix = ETH_TP_MDI_X; 850 851 return 0; 852 } 853 854 static int ksz8081_read_status(struct phy_device *phydev) 855 { 856 int ret; 857 858 ret = ksz8081_mdix_update(phydev); 859 if (ret < 0) 860 return ret; 861 862 return genphy_read_status(phydev); 863 } 864 865 static int ksz8061_config_init(struct phy_device *phydev) 866 { 867 int ret; 868 869 ret = phy_write_mmd(phydev, MDIO_MMD_PMAPMD, MDIO_DEVID1, 0xB61A); 870 if (ret) 871 return ret; 872 873 return kszphy_config_init(phydev); 874 } 875 876 static int ksz8795_match_phy_device(struct phy_device *phydev) 877 { 878 return ksz8051_ksz8795_match_phy_device(phydev, false); 879 } 880 881 static int ksz9021_load_values_from_of(struct phy_device *phydev, 882 const struct device_node *of_node, 883 u16 reg, 884 const char *field1, const char *field2, 885 const char *field3, const char *field4) 886 { 887 int val1 = -1; 888 int val2 = -2; 889 int val3 = -3; 890 int val4 = -4; 891 int newval; 892 int matches = 0; 893 894 if (!of_property_read_u32(of_node, field1, &val1)) 895 matches++; 896 897 if (!of_property_read_u32(of_node, field2, &val2)) 898 matches++; 899 900 if (!of_property_read_u32(of_node, field3, &val3)) 901 matches++; 902 903 if (!of_property_read_u32(of_node, field4, &val4)) 904 matches++; 905 906 if (!matches) 907 return 0; 908 909 if (matches < 4) 910 newval = kszphy_extended_read(phydev, reg); 911 else 912 newval = 0; 913 914 if (val1 != -1) 915 newval = ((newval & 0xfff0) | ((val1 / PS_TO_REG) & 0xf) << 0); 916 917 if (val2 != -2) 918 newval = ((newval & 0xff0f) | ((val2 / PS_TO_REG) & 0xf) << 4); 919 920 if (val3 != -3) 921 newval = ((newval & 0xf0ff) | ((val3 / PS_TO_REG) & 0xf) << 8); 922 923 if (val4 != -4) 924 newval = ((newval & 0x0fff) | ((val4 / PS_TO_REG) & 0xf) << 12); 925 926 return kszphy_extended_write(phydev, reg, newval); 927 } 928 929 static int ksz9021_config_init(struct phy_device *phydev) 930 { 931 const struct device_node *of_node; 932 const struct device *dev_walker; 933 934 /* The Micrel driver has a deprecated option to place phy OF 935 * properties in the MAC node. Walk up the tree of devices to 936 * find a device with an OF node. 937 */ 938 dev_walker = &phydev->mdio.dev; 939 do { 940 of_node = dev_walker->of_node; 941 dev_walker = dev_walker->parent; 942 943 } while (!of_node && dev_walker); 944 945 if (of_node) { 946 ksz9021_load_values_from_of(phydev, of_node, 947 MII_KSZPHY_CLK_CONTROL_PAD_SKEW, 948 "txen-skew-ps", "txc-skew-ps", 949 "rxdv-skew-ps", "rxc-skew-ps"); 950 ksz9021_load_values_from_of(phydev, of_node, 951 MII_KSZPHY_RX_DATA_PAD_SKEW, 952 "rxd0-skew-ps", "rxd1-skew-ps", 953 "rxd2-skew-ps", "rxd3-skew-ps"); 954 ksz9021_load_values_from_of(phydev, of_node, 955 MII_KSZPHY_TX_DATA_PAD_SKEW, 956 "txd0-skew-ps", "txd1-skew-ps", 957 "txd2-skew-ps", "txd3-skew-ps"); 958 } 959 return 0; 960 } 961 962 #define KSZ9031_PS_TO_REG 60 963 964 /* Extended registers */ 965 /* MMD Address 0x0 */ 966 #define MII_KSZ9031RN_FLP_BURST_TX_LO 3 967 #define MII_KSZ9031RN_FLP_BURST_TX_HI 4 968 969 /* MMD Address 0x2 */ 970 #define MII_KSZ9031RN_CONTROL_PAD_SKEW 4 971 #define MII_KSZ9031RN_RX_CTL_M GENMASK(7, 4) 972 #define MII_KSZ9031RN_TX_CTL_M GENMASK(3, 0) 973 974 #define MII_KSZ9031RN_RX_DATA_PAD_SKEW 5 975 #define MII_KSZ9031RN_RXD3 GENMASK(15, 12) 976 #define MII_KSZ9031RN_RXD2 GENMASK(11, 8) 977 #define MII_KSZ9031RN_RXD1 GENMASK(7, 4) 978 #define MII_KSZ9031RN_RXD0 GENMASK(3, 0) 979 980 #define MII_KSZ9031RN_TX_DATA_PAD_SKEW 6 981 #define MII_KSZ9031RN_TXD3 GENMASK(15, 12) 982 #define MII_KSZ9031RN_TXD2 GENMASK(11, 8) 983 #define MII_KSZ9031RN_TXD1 GENMASK(7, 4) 984 #define MII_KSZ9031RN_TXD0 GENMASK(3, 0) 985 986 #define MII_KSZ9031RN_CLK_PAD_SKEW 8 987 #define MII_KSZ9031RN_GTX_CLK GENMASK(9, 5) 988 #define MII_KSZ9031RN_RX_CLK GENMASK(4, 0) 989 990 /* KSZ9031 has internal RGMII_IDRX = 1.2ns and RGMII_IDTX = 0ns. To 991 * provide different RGMII options we need to configure delay offset 992 * for each pad relative to build in delay. 993 */ 994 /* keep rx as "No delay adjustment" and set rx_clk to +0.60ns to get delays of 995 * 1.80ns 996 */ 997 #define RX_ID 0x7 998 #define RX_CLK_ID 0x19 999 1000 /* set rx to +0.30ns and rx_clk to -0.90ns to compensate the 1001 * internal 1.2ns delay. 1002 */ 1003 #define RX_ND 0xc 1004 #define RX_CLK_ND 0x0 1005 1006 /* set tx to -0.42ns and tx_clk to +0.96ns to get 1.38ns delay */ 1007 #define TX_ID 0x0 1008 #define TX_CLK_ID 0x1f 1009 1010 /* set tx and tx_clk to "No delay adjustment" to keep 0ns 1011 * dealy 1012 */ 1013 #define TX_ND 0x7 1014 #define TX_CLK_ND 0xf 1015 1016 /* MMD Address 0x1C */ 1017 #define MII_KSZ9031RN_EDPD 0x23 1018 #define MII_KSZ9031RN_EDPD_ENABLE BIT(0) 1019 1020 static int ksz9031_of_load_skew_values(struct phy_device *phydev, 1021 const struct device_node *of_node, 1022 u16 reg, size_t field_sz, 1023 const char *field[], u8 numfields, 1024 bool *update) 1025 { 1026 int val[4] = {-1, -2, -3, -4}; 1027 int matches = 0; 1028 u16 mask; 1029 u16 maxval; 1030 u16 newval; 1031 int i; 1032 1033 for (i = 0; i < numfields; i++) 1034 if (!of_property_read_u32(of_node, field[i], val + i)) 1035 matches++; 1036 1037 if (!matches) 1038 return 0; 1039 1040 *update |= true; 1041 1042 if (matches < numfields) 1043 newval = phy_read_mmd(phydev, 2, reg); 1044 else 1045 newval = 0; 1046 1047 maxval = (field_sz == 4) ? 0xf : 0x1f; 1048 for (i = 0; i < numfields; i++) 1049 if (val[i] != -(i + 1)) { 1050 mask = 0xffff; 1051 mask ^= maxval << (field_sz * i); 1052 newval = (newval & mask) | 1053 (((val[i] / KSZ9031_PS_TO_REG) & maxval) 1054 << (field_sz * i)); 1055 } 1056 1057 return phy_write_mmd(phydev, 2, reg, newval); 1058 } 1059 1060 /* Center KSZ9031RNX FLP timing at 16ms. */ 1061 static int ksz9031_center_flp_timing(struct phy_device *phydev) 1062 { 1063 int result; 1064 1065 result = phy_write_mmd(phydev, 0, MII_KSZ9031RN_FLP_BURST_TX_HI, 1066 0x0006); 1067 if (result) 1068 return result; 1069 1070 result = phy_write_mmd(phydev, 0, MII_KSZ9031RN_FLP_BURST_TX_LO, 1071 0x1A80); 1072 if (result) 1073 return result; 1074 1075 return genphy_restart_aneg(phydev); 1076 } 1077 1078 /* Enable energy-detect power-down mode */ 1079 static int ksz9031_enable_edpd(struct phy_device *phydev) 1080 { 1081 int reg; 1082 1083 reg = phy_read_mmd(phydev, 0x1C, MII_KSZ9031RN_EDPD); 1084 if (reg < 0) 1085 return reg; 1086 return phy_write_mmd(phydev, 0x1C, MII_KSZ9031RN_EDPD, 1087 reg | MII_KSZ9031RN_EDPD_ENABLE); 1088 } 1089 1090 static int ksz9031_config_rgmii_delay(struct phy_device *phydev) 1091 { 1092 u16 rx, tx, rx_clk, tx_clk; 1093 int ret; 1094 1095 switch (phydev->interface) { 1096 case PHY_INTERFACE_MODE_RGMII: 1097 tx = TX_ND; 1098 tx_clk = TX_CLK_ND; 1099 rx = RX_ND; 1100 rx_clk = RX_CLK_ND; 1101 break; 1102 case PHY_INTERFACE_MODE_RGMII_ID: 1103 tx = TX_ID; 1104 tx_clk = TX_CLK_ID; 1105 rx = RX_ID; 1106 rx_clk = RX_CLK_ID; 1107 break; 1108 case PHY_INTERFACE_MODE_RGMII_RXID: 1109 tx = TX_ND; 1110 tx_clk = TX_CLK_ND; 1111 rx = RX_ID; 1112 rx_clk = RX_CLK_ID; 1113 break; 1114 case PHY_INTERFACE_MODE_RGMII_TXID: 1115 tx = TX_ID; 1116 tx_clk = TX_CLK_ID; 1117 rx = RX_ND; 1118 rx_clk = RX_CLK_ND; 1119 break; 1120 default: 1121 return 0; 1122 } 1123 1124 ret = phy_write_mmd(phydev, 2, MII_KSZ9031RN_CONTROL_PAD_SKEW, 1125 FIELD_PREP(MII_KSZ9031RN_RX_CTL_M, rx) | 1126 FIELD_PREP(MII_KSZ9031RN_TX_CTL_M, tx)); 1127 if (ret < 0) 1128 return ret; 1129 1130 ret = phy_write_mmd(phydev, 2, MII_KSZ9031RN_RX_DATA_PAD_SKEW, 1131 FIELD_PREP(MII_KSZ9031RN_RXD3, rx) | 1132 FIELD_PREP(MII_KSZ9031RN_RXD2, rx) | 1133 FIELD_PREP(MII_KSZ9031RN_RXD1, rx) | 1134 FIELD_PREP(MII_KSZ9031RN_RXD0, rx)); 1135 if (ret < 0) 1136 return ret; 1137 1138 ret = phy_write_mmd(phydev, 2, MII_KSZ9031RN_TX_DATA_PAD_SKEW, 1139 FIELD_PREP(MII_KSZ9031RN_TXD3, tx) | 1140 FIELD_PREP(MII_KSZ9031RN_TXD2, tx) | 1141 FIELD_PREP(MII_KSZ9031RN_TXD1, tx) | 1142 FIELD_PREP(MII_KSZ9031RN_TXD0, tx)); 1143 if (ret < 0) 1144 return ret; 1145 1146 return phy_write_mmd(phydev, 2, MII_KSZ9031RN_CLK_PAD_SKEW, 1147 FIELD_PREP(MII_KSZ9031RN_GTX_CLK, tx_clk) | 1148 FIELD_PREP(MII_KSZ9031RN_RX_CLK, rx_clk)); 1149 } 1150 1151 static int ksz9031_config_init(struct phy_device *phydev) 1152 { 1153 const struct device_node *of_node; 1154 static const char *clk_skews[2] = {"rxc-skew-ps", "txc-skew-ps"}; 1155 static const char *rx_data_skews[4] = { 1156 "rxd0-skew-ps", "rxd1-skew-ps", 1157 "rxd2-skew-ps", "rxd3-skew-ps" 1158 }; 1159 static const char *tx_data_skews[4] = { 1160 "txd0-skew-ps", "txd1-skew-ps", 1161 "txd2-skew-ps", "txd3-skew-ps" 1162 }; 1163 static const char *control_skews[2] = {"txen-skew-ps", "rxdv-skew-ps"}; 1164 const struct device *dev_walker; 1165 int result; 1166 1167 result = ksz9031_enable_edpd(phydev); 1168 if (result < 0) 1169 return result; 1170 1171 /* The Micrel driver has a deprecated option to place phy OF 1172 * properties in the MAC node. Walk up the tree of devices to 1173 * find a device with an OF node. 1174 */ 1175 dev_walker = &phydev->mdio.dev; 1176 do { 1177 of_node = dev_walker->of_node; 1178 dev_walker = dev_walker->parent; 1179 } while (!of_node && dev_walker); 1180 1181 if (of_node) { 1182 bool update = false; 1183 1184 if (phy_interface_is_rgmii(phydev)) { 1185 result = ksz9031_config_rgmii_delay(phydev); 1186 if (result < 0) 1187 return result; 1188 } 1189 1190 ksz9031_of_load_skew_values(phydev, of_node, 1191 MII_KSZ9031RN_CLK_PAD_SKEW, 5, 1192 clk_skews, 2, &update); 1193 1194 ksz9031_of_load_skew_values(phydev, of_node, 1195 MII_KSZ9031RN_CONTROL_PAD_SKEW, 4, 1196 control_skews, 2, &update); 1197 1198 ksz9031_of_load_skew_values(phydev, of_node, 1199 MII_KSZ9031RN_RX_DATA_PAD_SKEW, 4, 1200 rx_data_skews, 4, &update); 1201 1202 ksz9031_of_load_skew_values(phydev, of_node, 1203 MII_KSZ9031RN_TX_DATA_PAD_SKEW, 4, 1204 tx_data_skews, 4, &update); 1205 1206 if (update && !phy_interface_is_rgmii(phydev)) 1207 phydev_warn(phydev, 1208 "*-skew-ps values should be used only with RGMII PHY modes\n"); 1209 1210 /* Silicon Errata Sheet (DS80000691D or DS80000692D): 1211 * When the device links in the 1000BASE-T slave mode only, 1212 * the optional 125MHz reference output clock (CLK125_NDO) 1213 * has wide duty cycle variation. 1214 * 1215 * The optional CLK125_NDO clock does not meet the RGMII 1216 * 45/55 percent (min/max) duty cycle requirement and therefore 1217 * cannot be used directly by the MAC side for clocking 1218 * applications that have setup/hold time requirements on 1219 * rising and falling clock edges. 1220 * 1221 * Workaround: 1222 * Force the phy to be the master to receive a stable clock 1223 * which meets the duty cycle requirement. 1224 */ 1225 if (of_property_read_bool(of_node, "micrel,force-master")) { 1226 result = phy_read(phydev, MII_CTRL1000); 1227 if (result < 0) 1228 goto err_force_master; 1229 1230 /* enable master mode, config & prefer master */ 1231 result |= CTL1000_ENABLE_MASTER | CTL1000_AS_MASTER; 1232 result = phy_write(phydev, MII_CTRL1000, result); 1233 if (result < 0) 1234 goto err_force_master; 1235 } 1236 } 1237 1238 return ksz9031_center_flp_timing(phydev); 1239 1240 err_force_master: 1241 phydev_err(phydev, "failed to force the phy to master mode\n"); 1242 return result; 1243 } 1244 1245 #define KSZ9131_SKEW_5BIT_MAX 2400 1246 #define KSZ9131_SKEW_4BIT_MAX 800 1247 #define KSZ9131_OFFSET 700 1248 #define KSZ9131_STEP 100 1249 1250 static int ksz9131_of_load_skew_values(struct phy_device *phydev, 1251 struct device_node *of_node, 1252 u16 reg, size_t field_sz, 1253 char *field[], u8 numfields) 1254 { 1255 int val[4] = {-(1 + KSZ9131_OFFSET), -(2 + KSZ9131_OFFSET), 1256 -(3 + KSZ9131_OFFSET), -(4 + KSZ9131_OFFSET)}; 1257 int skewval, skewmax = 0; 1258 int matches = 0; 1259 u16 maxval; 1260 u16 newval; 1261 u16 mask; 1262 int i; 1263 1264 /* psec properties in dts should mean x pico seconds */ 1265 if (field_sz == 5) 1266 skewmax = KSZ9131_SKEW_5BIT_MAX; 1267 else 1268 skewmax = KSZ9131_SKEW_4BIT_MAX; 1269 1270 for (i = 0; i < numfields; i++) 1271 if (!of_property_read_s32(of_node, field[i], &skewval)) { 1272 if (skewval < -KSZ9131_OFFSET) 1273 skewval = -KSZ9131_OFFSET; 1274 else if (skewval > skewmax) 1275 skewval = skewmax; 1276 1277 val[i] = skewval + KSZ9131_OFFSET; 1278 matches++; 1279 } 1280 1281 if (!matches) 1282 return 0; 1283 1284 if (matches < numfields) 1285 newval = phy_read_mmd(phydev, 2, reg); 1286 else 1287 newval = 0; 1288 1289 maxval = (field_sz == 4) ? 0xf : 0x1f; 1290 for (i = 0; i < numfields; i++) 1291 if (val[i] != -(i + 1 + KSZ9131_OFFSET)) { 1292 mask = 0xffff; 1293 mask ^= maxval << (field_sz * i); 1294 newval = (newval & mask) | 1295 (((val[i] / KSZ9131_STEP) & maxval) 1296 << (field_sz * i)); 1297 } 1298 1299 return phy_write_mmd(phydev, 2, reg, newval); 1300 } 1301 1302 #define KSZ9131RN_MMD_COMMON_CTRL_REG 2 1303 #define KSZ9131RN_RXC_DLL_CTRL 76 1304 #define KSZ9131RN_TXC_DLL_CTRL 77 1305 #define KSZ9131RN_DLL_ENABLE_DELAY 0 1306 1307 static int ksz9131_config_rgmii_delay(struct phy_device *phydev) 1308 { 1309 const struct kszphy_type *type = phydev->drv->driver_data; 1310 u16 rxcdll_val, txcdll_val; 1311 int ret; 1312 1313 switch (phydev->interface) { 1314 case PHY_INTERFACE_MODE_RGMII: 1315 rxcdll_val = type->disable_dll_rx_bit; 1316 txcdll_val = type->disable_dll_tx_bit; 1317 break; 1318 case PHY_INTERFACE_MODE_RGMII_ID: 1319 rxcdll_val = KSZ9131RN_DLL_ENABLE_DELAY; 1320 txcdll_val = KSZ9131RN_DLL_ENABLE_DELAY; 1321 break; 1322 case PHY_INTERFACE_MODE_RGMII_RXID: 1323 rxcdll_val = KSZ9131RN_DLL_ENABLE_DELAY; 1324 txcdll_val = type->disable_dll_tx_bit; 1325 break; 1326 case PHY_INTERFACE_MODE_RGMII_TXID: 1327 rxcdll_val = type->disable_dll_rx_bit; 1328 txcdll_val = KSZ9131RN_DLL_ENABLE_DELAY; 1329 break; 1330 default: 1331 return 0; 1332 } 1333 1334 ret = phy_modify_mmd(phydev, KSZ9131RN_MMD_COMMON_CTRL_REG, 1335 KSZ9131RN_RXC_DLL_CTRL, type->disable_dll_mask, 1336 rxcdll_val); 1337 if (ret < 0) 1338 return ret; 1339 1340 return phy_modify_mmd(phydev, KSZ9131RN_MMD_COMMON_CTRL_REG, 1341 KSZ9131RN_TXC_DLL_CTRL, type->disable_dll_mask, 1342 txcdll_val); 1343 } 1344 1345 /* Silicon Errata DS80000693B 1346 * 1347 * When LEDs are configured in Individual Mode, LED1 is ON in a no-link 1348 * condition. Workaround is to set register 0x1e, bit 9, this way LED1 behaves 1349 * according to the datasheet (off if there is no link). 1350 */ 1351 static int ksz9131_led_errata(struct phy_device *phydev) 1352 { 1353 int reg; 1354 1355 reg = phy_read_mmd(phydev, 2, 0); 1356 if (reg < 0) 1357 return reg; 1358 1359 if (!(reg & BIT(4))) 1360 return 0; 1361 1362 return phy_set_bits(phydev, 0x1e, BIT(9)); 1363 } 1364 1365 static int ksz9131_config_init(struct phy_device *phydev) 1366 { 1367 struct device_node *of_node; 1368 char *clk_skews[2] = {"rxc-skew-psec", "txc-skew-psec"}; 1369 char *rx_data_skews[4] = { 1370 "rxd0-skew-psec", "rxd1-skew-psec", 1371 "rxd2-skew-psec", "rxd3-skew-psec" 1372 }; 1373 char *tx_data_skews[4] = { 1374 "txd0-skew-psec", "txd1-skew-psec", 1375 "txd2-skew-psec", "txd3-skew-psec" 1376 }; 1377 char *control_skews[2] = {"txen-skew-psec", "rxdv-skew-psec"}; 1378 const struct device *dev_walker; 1379 int ret; 1380 1381 dev_walker = &phydev->mdio.dev; 1382 do { 1383 of_node = dev_walker->of_node; 1384 dev_walker = dev_walker->parent; 1385 } while (!of_node && dev_walker); 1386 1387 if (!of_node) 1388 return 0; 1389 1390 if (phy_interface_is_rgmii(phydev)) { 1391 ret = ksz9131_config_rgmii_delay(phydev); 1392 if (ret < 0) 1393 return ret; 1394 } 1395 1396 ret = ksz9131_of_load_skew_values(phydev, of_node, 1397 MII_KSZ9031RN_CLK_PAD_SKEW, 5, 1398 clk_skews, 2); 1399 if (ret < 0) 1400 return ret; 1401 1402 ret = ksz9131_of_load_skew_values(phydev, of_node, 1403 MII_KSZ9031RN_CONTROL_PAD_SKEW, 4, 1404 control_skews, 2); 1405 if (ret < 0) 1406 return ret; 1407 1408 ret = ksz9131_of_load_skew_values(phydev, of_node, 1409 MII_KSZ9031RN_RX_DATA_PAD_SKEW, 4, 1410 rx_data_skews, 4); 1411 if (ret < 0) 1412 return ret; 1413 1414 ret = ksz9131_of_load_skew_values(phydev, of_node, 1415 MII_KSZ9031RN_TX_DATA_PAD_SKEW, 4, 1416 tx_data_skews, 4); 1417 if (ret < 0) 1418 return ret; 1419 1420 ret = ksz9131_led_errata(phydev); 1421 if (ret < 0) 1422 return ret; 1423 1424 return 0; 1425 } 1426 1427 #define MII_KSZ9131_AUTO_MDIX 0x1C 1428 #define MII_KSZ9131_AUTO_MDI_SET BIT(7) 1429 #define MII_KSZ9131_AUTO_MDIX_SWAP_OFF BIT(6) 1430 1431 static int ksz9131_mdix_update(struct phy_device *phydev) 1432 { 1433 int ret; 1434 1435 ret = phy_read(phydev, MII_KSZ9131_AUTO_MDIX); 1436 if (ret < 0) 1437 return ret; 1438 1439 if (ret & MII_KSZ9131_AUTO_MDIX_SWAP_OFF) { 1440 if (ret & MII_KSZ9131_AUTO_MDI_SET) 1441 phydev->mdix_ctrl = ETH_TP_MDI; 1442 else 1443 phydev->mdix_ctrl = ETH_TP_MDI_X; 1444 } else { 1445 phydev->mdix_ctrl = ETH_TP_MDI_AUTO; 1446 } 1447 1448 if (ret & MII_KSZ9131_AUTO_MDI_SET) 1449 phydev->mdix = ETH_TP_MDI; 1450 else 1451 phydev->mdix = ETH_TP_MDI_X; 1452 1453 return 0; 1454 } 1455 1456 static int ksz9131_config_mdix(struct phy_device *phydev, u8 ctrl) 1457 { 1458 u16 val; 1459 1460 switch (ctrl) { 1461 case ETH_TP_MDI: 1462 val = MII_KSZ9131_AUTO_MDIX_SWAP_OFF | 1463 MII_KSZ9131_AUTO_MDI_SET; 1464 break; 1465 case ETH_TP_MDI_X: 1466 val = MII_KSZ9131_AUTO_MDIX_SWAP_OFF; 1467 break; 1468 case ETH_TP_MDI_AUTO: 1469 val = 0; 1470 break; 1471 default: 1472 return 0; 1473 } 1474 1475 return phy_modify(phydev, MII_KSZ9131_AUTO_MDIX, 1476 MII_KSZ9131_AUTO_MDIX_SWAP_OFF | 1477 MII_KSZ9131_AUTO_MDI_SET, val); 1478 } 1479 1480 static int ksz9131_read_status(struct phy_device *phydev) 1481 { 1482 int ret; 1483 1484 ret = ksz9131_mdix_update(phydev); 1485 if (ret < 0) 1486 return ret; 1487 1488 return genphy_read_status(phydev); 1489 } 1490 1491 static int ksz9131_config_aneg(struct phy_device *phydev) 1492 { 1493 int ret; 1494 1495 ret = ksz9131_config_mdix(phydev, phydev->mdix_ctrl); 1496 if (ret) 1497 return ret; 1498 1499 return genphy_config_aneg(phydev); 1500 } 1501 1502 static int ksz9477_get_features(struct phy_device *phydev) 1503 { 1504 int ret; 1505 1506 ret = genphy_read_abilities(phydev); 1507 if (ret) 1508 return ret; 1509 1510 /* The "EEE control and capability 1" (Register 3.20) seems to be 1511 * influenced by the "EEE advertisement 1" (Register 7.60). Changes 1512 * on the 7.60 will affect 3.20. So, we need to construct our own list 1513 * of caps. 1514 * KSZ8563R should have 100BaseTX/Full only. 1515 */ 1516 linkmode_and(phydev->supported_eee, phydev->supported, 1517 PHY_EEE_CAP1_FEATURES); 1518 1519 return 0; 1520 } 1521 1522 #define KSZ8873MLL_GLOBAL_CONTROL_4 0x06 1523 #define KSZ8873MLL_GLOBAL_CONTROL_4_DUPLEX BIT(6) 1524 #define KSZ8873MLL_GLOBAL_CONTROL_4_SPEED BIT(4) 1525 static int ksz8873mll_read_status(struct phy_device *phydev) 1526 { 1527 int regval; 1528 1529 /* dummy read */ 1530 regval = phy_read(phydev, KSZ8873MLL_GLOBAL_CONTROL_4); 1531 1532 regval = phy_read(phydev, KSZ8873MLL_GLOBAL_CONTROL_4); 1533 1534 if (regval & KSZ8873MLL_GLOBAL_CONTROL_4_DUPLEX) 1535 phydev->duplex = DUPLEX_HALF; 1536 else 1537 phydev->duplex = DUPLEX_FULL; 1538 1539 if (regval & KSZ8873MLL_GLOBAL_CONTROL_4_SPEED) 1540 phydev->speed = SPEED_10; 1541 else 1542 phydev->speed = SPEED_100; 1543 1544 phydev->link = 1; 1545 phydev->pause = phydev->asym_pause = 0; 1546 1547 return 0; 1548 } 1549 1550 static int ksz9031_get_features(struct phy_device *phydev) 1551 { 1552 int ret; 1553 1554 ret = genphy_read_abilities(phydev); 1555 if (ret < 0) 1556 return ret; 1557 1558 /* Silicon Errata Sheet (DS80000691D or DS80000692D): 1559 * Whenever the device's Asymmetric Pause capability is set to 1, 1560 * link-up may fail after a link-up to link-down transition. 1561 * 1562 * The Errata Sheet is for ksz9031, but ksz9021 has the same issue 1563 * 1564 * Workaround: 1565 * Do not enable the Asymmetric Pause capability bit. 1566 */ 1567 linkmode_clear_bit(ETHTOOL_LINK_MODE_Asym_Pause_BIT, phydev->supported); 1568 1569 /* We force setting the Pause capability as the core will force the 1570 * Asymmetric Pause capability to 1 otherwise. 1571 */ 1572 linkmode_set_bit(ETHTOOL_LINK_MODE_Pause_BIT, phydev->supported); 1573 1574 return 0; 1575 } 1576 1577 static int ksz9031_read_status(struct phy_device *phydev) 1578 { 1579 int err; 1580 int regval; 1581 1582 err = genphy_read_status(phydev); 1583 if (err) 1584 return err; 1585 1586 /* Make sure the PHY is not broken. Read idle error count, 1587 * and reset the PHY if it is maxed out. 1588 */ 1589 regval = phy_read(phydev, MII_STAT1000); 1590 if ((regval & 0xFF) == 0xFF) { 1591 phy_init_hw(phydev); 1592 phydev->link = 0; 1593 if (phydev->drv->config_intr && phy_interrupt_is_valid(phydev)) 1594 phydev->drv->config_intr(phydev); 1595 return genphy_config_aneg(phydev); 1596 } 1597 1598 return 0; 1599 } 1600 1601 static int ksz9x31_cable_test_start(struct phy_device *phydev) 1602 { 1603 struct kszphy_priv *priv = phydev->priv; 1604 int ret; 1605 1606 /* KSZ9131RNX, DS00002841B-page 38, 4.14 LinkMD (R) Cable Diagnostic 1607 * Prior to running the cable diagnostics, Auto-negotiation should 1608 * be disabled, full duplex set and the link speed set to 1000Mbps 1609 * via the Basic Control Register. 1610 */ 1611 ret = phy_modify(phydev, MII_BMCR, 1612 BMCR_SPEED1000 | BMCR_FULLDPLX | 1613 BMCR_ANENABLE | BMCR_SPEED100, 1614 BMCR_SPEED1000 | BMCR_FULLDPLX); 1615 if (ret) 1616 return ret; 1617 1618 /* KSZ9131RNX, DS00002841B-page 38, 4.14 LinkMD (R) Cable Diagnostic 1619 * The Master-Slave configuration should be set to Slave by writing 1620 * a value of 0x1000 to the Auto-Negotiation Master Slave Control 1621 * Register. 1622 */ 1623 ret = phy_read(phydev, MII_CTRL1000); 1624 if (ret < 0) 1625 return ret; 1626 1627 /* Cache these bits, they need to be restored once LinkMD finishes. */ 1628 priv->vct_ctrl1000 = ret & (CTL1000_ENABLE_MASTER | CTL1000_AS_MASTER); 1629 ret &= ~(CTL1000_ENABLE_MASTER | CTL1000_AS_MASTER); 1630 ret |= CTL1000_ENABLE_MASTER; 1631 1632 return phy_write(phydev, MII_CTRL1000, ret); 1633 } 1634 1635 static int ksz9x31_cable_test_result_trans(u16 status) 1636 { 1637 switch (FIELD_GET(KSZ9x31_LMD_VCT_ST_MASK, status)) { 1638 case KSZ9x31_LMD_VCT_ST_NORMAL: 1639 return ETHTOOL_A_CABLE_RESULT_CODE_OK; 1640 case KSZ9x31_LMD_VCT_ST_OPEN: 1641 return ETHTOOL_A_CABLE_RESULT_CODE_OPEN; 1642 case KSZ9x31_LMD_VCT_ST_SHORT: 1643 return ETHTOOL_A_CABLE_RESULT_CODE_SAME_SHORT; 1644 case KSZ9x31_LMD_VCT_ST_FAIL: 1645 fallthrough; 1646 default: 1647 return ETHTOOL_A_CABLE_RESULT_CODE_UNSPEC; 1648 } 1649 } 1650 1651 static bool ksz9x31_cable_test_failed(u16 status) 1652 { 1653 int stat = FIELD_GET(KSZ9x31_LMD_VCT_ST_MASK, status); 1654 1655 return stat == KSZ9x31_LMD_VCT_ST_FAIL; 1656 } 1657 1658 static bool ksz9x31_cable_test_fault_length_valid(u16 status) 1659 { 1660 switch (FIELD_GET(KSZ9x31_LMD_VCT_ST_MASK, status)) { 1661 case KSZ9x31_LMD_VCT_ST_OPEN: 1662 fallthrough; 1663 case KSZ9x31_LMD_VCT_ST_SHORT: 1664 return true; 1665 } 1666 return false; 1667 } 1668 1669 static int ksz9x31_cable_test_fault_length(struct phy_device *phydev, u16 stat) 1670 { 1671 int dt = FIELD_GET(KSZ9x31_LMD_VCT_DATA_MASK, stat); 1672 1673 /* KSZ9131RNX, DS00002841B-page 38, 4.14 LinkMD (R) Cable Diagnostic 1674 * 1675 * distance to fault = (VCT_DATA - 22) * 4 / cable propagation velocity 1676 */ 1677 if (phydev_id_compare(phydev, PHY_ID_KSZ9131)) 1678 dt = clamp(dt - 22, 0, 255); 1679 1680 return (dt * 400) / 10; 1681 } 1682 1683 static int ksz9x31_cable_test_wait_for_completion(struct phy_device *phydev) 1684 { 1685 int val, ret; 1686 1687 ret = phy_read_poll_timeout(phydev, KSZ9x31_LMD, val, 1688 !(val & KSZ9x31_LMD_VCT_EN), 1689 30000, 100000, true); 1690 1691 return ret < 0 ? ret : 0; 1692 } 1693 1694 static int ksz9x31_cable_test_get_pair(int pair) 1695 { 1696 static const int ethtool_pair[] = { 1697 ETHTOOL_A_CABLE_PAIR_A, 1698 ETHTOOL_A_CABLE_PAIR_B, 1699 ETHTOOL_A_CABLE_PAIR_C, 1700 ETHTOOL_A_CABLE_PAIR_D, 1701 }; 1702 1703 return ethtool_pair[pair]; 1704 } 1705 1706 static int ksz9x31_cable_test_one_pair(struct phy_device *phydev, int pair) 1707 { 1708 int ret, val; 1709 1710 /* KSZ9131RNX, DS00002841B-page 38, 4.14 LinkMD (R) Cable Diagnostic 1711 * To test each individual cable pair, set the cable pair in the Cable 1712 * Diagnostics Test Pair (VCT_PAIR[1:0]) field of the LinkMD Cable 1713 * Diagnostic Register, along with setting the Cable Diagnostics Test 1714 * Enable (VCT_EN) bit. The Cable Diagnostics Test Enable (VCT_EN) bit 1715 * will self clear when the test is concluded. 1716 */ 1717 ret = phy_write(phydev, KSZ9x31_LMD, 1718 KSZ9x31_LMD_VCT_EN | KSZ9x31_LMD_VCT_PAIR(pair)); 1719 if (ret) 1720 return ret; 1721 1722 ret = ksz9x31_cable_test_wait_for_completion(phydev); 1723 if (ret) 1724 return ret; 1725 1726 val = phy_read(phydev, KSZ9x31_LMD); 1727 if (val < 0) 1728 return val; 1729 1730 if (ksz9x31_cable_test_failed(val)) 1731 return -EAGAIN; 1732 1733 ret = ethnl_cable_test_result(phydev, 1734 ksz9x31_cable_test_get_pair(pair), 1735 ksz9x31_cable_test_result_trans(val)); 1736 if (ret) 1737 return ret; 1738 1739 if (!ksz9x31_cable_test_fault_length_valid(val)) 1740 return 0; 1741 1742 return ethnl_cable_test_fault_length(phydev, 1743 ksz9x31_cable_test_get_pair(pair), 1744 ksz9x31_cable_test_fault_length(phydev, val)); 1745 } 1746 1747 static int ksz9x31_cable_test_get_status(struct phy_device *phydev, 1748 bool *finished) 1749 { 1750 struct kszphy_priv *priv = phydev->priv; 1751 unsigned long pair_mask = 0xf; 1752 int retries = 20; 1753 int pair, ret, rv; 1754 1755 *finished = false; 1756 1757 /* Try harder if link partner is active */ 1758 while (pair_mask && retries--) { 1759 for_each_set_bit(pair, &pair_mask, 4) { 1760 ret = ksz9x31_cable_test_one_pair(phydev, pair); 1761 if (ret == -EAGAIN) 1762 continue; 1763 if (ret < 0) 1764 return ret; 1765 clear_bit(pair, &pair_mask); 1766 } 1767 /* If link partner is in autonegotiation mode it will send 2ms 1768 * of FLPs with at least 6ms of silence. 1769 * Add 2ms sleep to have better chances to hit this silence. 1770 */ 1771 if (pair_mask) 1772 usleep_range(2000, 3000); 1773 } 1774 1775 /* Report remaining unfinished pair result as unknown. */ 1776 for_each_set_bit(pair, &pair_mask, 4) { 1777 ret = ethnl_cable_test_result(phydev, 1778 ksz9x31_cable_test_get_pair(pair), 1779 ETHTOOL_A_CABLE_RESULT_CODE_UNSPEC); 1780 } 1781 1782 *finished = true; 1783 1784 /* Restore cached bits from before LinkMD got started. */ 1785 rv = phy_modify(phydev, MII_CTRL1000, 1786 CTL1000_ENABLE_MASTER | CTL1000_AS_MASTER, 1787 priv->vct_ctrl1000); 1788 if (rv) 1789 return rv; 1790 1791 return ret; 1792 } 1793 1794 static int ksz8873mll_config_aneg(struct phy_device *phydev) 1795 { 1796 return 0; 1797 } 1798 1799 static int ksz886x_config_mdix(struct phy_device *phydev, u8 ctrl) 1800 { 1801 u16 val; 1802 1803 switch (ctrl) { 1804 case ETH_TP_MDI: 1805 val = KSZ886X_BMCR_DISABLE_AUTO_MDIX; 1806 break; 1807 case ETH_TP_MDI_X: 1808 /* Note: The naming of the bit KSZ886X_BMCR_FORCE_MDI is bit 1809 * counter intuitive, the "-X" in "1 = Force MDI" in the data 1810 * sheet seems to be missing: 1811 * 1 = Force MDI (sic!) (transmit on RX+/RX- pins) 1812 * 0 = Normal operation (transmit on TX+/TX- pins) 1813 */ 1814 val = KSZ886X_BMCR_DISABLE_AUTO_MDIX | KSZ886X_BMCR_FORCE_MDI; 1815 break; 1816 case ETH_TP_MDI_AUTO: 1817 val = 0; 1818 break; 1819 default: 1820 return 0; 1821 } 1822 1823 return phy_modify(phydev, MII_BMCR, 1824 KSZ886X_BMCR_HP_MDIX | KSZ886X_BMCR_FORCE_MDI | 1825 KSZ886X_BMCR_DISABLE_AUTO_MDIX, 1826 KSZ886X_BMCR_HP_MDIX | val); 1827 } 1828 1829 static int ksz886x_config_aneg(struct phy_device *phydev) 1830 { 1831 int ret; 1832 1833 ret = genphy_config_aneg(phydev); 1834 if (ret) 1835 return ret; 1836 1837 if (phydev->autoneg != AUTONEG_ENABLE) { 1838 /* When autonegotation is disabled, we need to manually force 1839 * the link state. If we don't do this, the PHY will keep 1840 * sending Fast Link Pulses (FLPs) which are part of the 1841 * autonegotiation process. This is not desired when 1842 * autonegotiation is off. 1843 */ 1844 ret = phy_set_bits(phydev, MII_KSZPHY_CTRL, 1845 KSZ886X_CTRL_FORCE_LINK); 1846 if (ret) 1847 return ret; 1848 } else { 1849 /* If we had previously forced the link state, we need to 1850 * clear KSZ886X_CTRL_FORCE_LINK bit now. Otherwise, the PHY 1851 * will not perform autonegotiation. 1852 */ 1853 ret = phy_clear_bits(phydev, MII_KSZPHY_CTRL, 1854 KSZ886X_CTRL_FORCE_LINK); 1855 if (ret) 1856 return ret; 1857 } 1858 1859 /* The MDI-X configuration is automatically changed by the PHY after 1860 * switching from autoneg off to on. So, take MDI-X configuration under 1861 * own control and set it after autoneg configuration was done. 1862 */ 1863 return ksz886x_config_mdix(phydev, phydev->mdix_ctrl); 1864 } 1865 1866 static int ksz886x_mdix_update(struct phy_device *phydev) 1867 { 1868 int ret; 1869 1870 ret = phy_read(phydev, MII_BMCR); 1871 if (ret < 0) 1872 return ret; 1873 1874 if (ret & KSZ886X_BMCR_DISABLE_AUTO_MDIX) { 1875 if (ret & KSZ886X_BMCR_FORCE_MDI) 1876 phydev->mdix_ctrl = ETH_TP_MDI_X; 1877 else 1878 phydev->mdix_ctrl = ETH_TP_MDI; 1879 } else { 1880 phydev->mdix_ctrl = ETH_TP_MDI_AUTO; 1881 } 1882 1883 ret = phy_read(phydev, MII_KSZPHY_CTRL); 1884 if (ret < 0) 1885 return ret; 1886 1887 /* Same reverse logic as KSZ886X_BMCR_FORCE_MDI */ 1888 if (ret & KSZ886X_CTRL_MDIX_STAT) 1889 phydev->mdix = ETH_TP_MDI_X; 1890 else 1891 phydev->mdix = ETH_TP_MDI; 1892 1893 return 0; 1894 } 1895 1896 static int ksz886x_read_status(struct phy_device *phydev) 1897 { 1898 int ret; 1899 1900 ret = ksz886x_mdix_update(phydev); 1901 if (ret < 0) 1902 return ret; 1903 1904 return genphy_read_status(phydev); 1905 } 1906 1907 struct ksz9477_errata_write { 1908 u8 dev_addr; 1909 u8 reg_addr; 1910 u16 val; 1911 }; 1912 1913 static const struct ksz9477_errata_write ksz9477_errata_writes[] = { 1914 /* Register settings are needed to improve PHY receive performance */ 1915 {0x01, 0x6f, 0xdd0b}, 1916 {0x01, 0x8f, 0x6032}, 1917 {0x01, 0x9d, 0x248c}, 1918 {0x01, 0x75, 0x0060}, 1919 {0x01, 0xd3, 0x7777}, 1920 {0x1c, 0x06, 0x3008}, 1921 {0x1c, 0x08, 0x2000}, 1922 1923 /* Transmit waveform amplitude can be improved (1000BASE-T, 100BASE-TX, 10BASE-Te) */ 1924 {0x1c, 0x04, 0x00d0}, 1925 1926 /* Register settings are required to meet data sheet supply current specifications */ 1927 {0x1c, 0x13, 0x6eff}, 1928 {0x1c, 0x14, 0xe6ff}, 1929 {0x1c, 0x15, 0x6eff}, 1930 {0x1c, 0x16, 0xe6ff}, 1931 {0x1c, 0x17, 0x00ff}, 1932 {0x1c, 0x18, 0x43ff}, 1933 {0x1c, 0x19, 0xc3ff}, 1934 {0x1c, 0x1a, 0x6fff}, 1935 {0x1c, 0x1b, 0x07ff}, 1936 {0x1c, 0x1c, 0x0fff}, 1937 {0x1c, 0x1d, 0xe7ff}, 1938 {0x1c, 0x1e, 0xefff}, 1939 {0x1c, 0x20, 0xeeee}, 1940 }; 1941 1942 static int ksz9477_phy_errata(struct phy_device *phydev) 1943 { 1944 int err; 1945 int i; 1946 1947 /* Apply PHY settings to address errata listed in 1948 * KSZ9477, KSZ9897, KSZ9896, KSZ9567, KSZ8565 1949 * Silicon Errata and Data Sheet Clarification documents. 1950 * 1951 * Document notes: Before configuring the PHY MMD registers, it is 1952 * necessary to set the PHY to 100 Mbps speed with auto-negotiation 1953 * disabled by writing to register 0xN100-0xN101. After writing the 1954 * MMD registers, and after all errata workarounds that involve PHY 1955 * register settings, write register 0xN100-0xN101 again to enable 1956 * and restart auto-negotiation. 1957 */ 1958 err = phy_write(phydev, MII_BMCR, BMCR_SPEED100 | BMCR_FULLDPLX); 1959 if (err) 1960 return err; 1961 1962 for (i = 0; i < ARRAY_SIZE(ksz9477_errata_writes); ++i) { 1963 const struct ksz9477_errata_write *errata = &ksz9477_errata_writes[i]; 1964 1965 err = phy_write_mmd(phydev, errata->dev_addr, errata->reg_addr, errata->val); 1966 if (err) 1967 return err; 1968 } 1969 1970 err = genphy_restart_aneg(phydev); 1971 if (err) 1972 return err; 1973 1974 return err; 1975 } 1976 1977 static int ksz9477_config_init(struct phy_device *phydev) 1978 { 1979 int err; 1980 1981 /* Only KSZ9897 family of switches needs this fix. */ 1982 if ((phydev->phy_id & 0xf) == 1) { 1983 err = ksz9477_phy_errata(phydev); 1984 if (err) 1985 return err; 1986 } 1987 1988 /* According to KSZ9477 Errata DS80000754C (Module 4) all EEE modes 1989 * in this switch shall be regarded as broken. 1990 */ 1991 if (phydev->dev_flags & MICREL_NO_EEE) 1992 phydev->eee_broken_modes = -1; 1993 1994 return kszphy_config_init(phydev); 1995 } 1996 1997 static int kszphy_get_sset_count(struct phy_device *phydev) 1998 { 1999 return ARRAY_SIZE(kszphy_hw_stats); 2000 } 2001 2002 static void kszphy_get_strings(struct phy_device *phydev, u8 *data) 2003 { 2004 int i; 2005 2006 for (i = 0; i < ARRAY_SIZE(kszphy_hw_stats); i++) { 2007 strscpy(data + i * ETH_GSTRING_LEN, 2008 kszphy_hw_stats[i].string, ETH_GSTRING_LEN); 2009 } 2010 } 2011 2012 static u64 kszphy_get_stat(struct phy_device *phydev, int i) 2013 { 2014 struct kszphy_hw_stat stat = kszphy_hw_stats[i]; 2015 struct kszphy_priv *priv = phydev->priv; 2016 int val; 2017 u64 ret; 2018 2019 val = phy_read(phydev, stat.reg); 2020 if (val < 0) { 2021 ret = U64_MAX; 2022 } else { 2023 val = val & ((1 << stat.bits) - 1); 2024 priv->stats[i] += val; 2025 ret = priv->stats[i]; 2026 } 2027 2028 return ret; 2029 } 2030 2031 static void kszphy_get_stats(struct phy_device *phydev, 2032 struct ethtool_stats *stats, u64 *data) 2033 { 2034 int i; 2035 2036 for (i = 0; i < ARRAY_SIZE(kszphy_hw_stats); i++) 2037 data[i] = kszphy_get_stat(phydev, i); 2038 } 2039 2040 static int kszphy_suspend(struct phy_device *phydev) 2041 { 2042 /* Disable PHY Interrupts */ 2043 if (phy_interrupt_is_valid(phydev)) { 2044 phydev->interrupts = PHY_INTERRUPT_DISABLED; 2045 if (phydev->drv->config_intr) 2046 phydev->drv->config_intr(phydev); 2047 } 2048 2049 return genphy_suspend(phydev); 2050 } 2051 2052 static void kszphy_parse_led_mode(struct phy_device *phydev) 2053 { 2054 const struct kszphy_type *type = phydev->drv->driver_data; 2055 const struct device_node *np = phydev->mdio.dev.of_node; 2056 struct kszphy_priv *priv = phydev->priv; 2057 int ret; 2058 2059 if (type && type->led_mode_reg) { 2060 ret = of_property_read_u32(np, "micrel,led-mode", 2061 &priv->led_mode); 2062 2063 if (ret) 2064 priv->led_mode = -1; 2065 2066 if (priv->led_mode > 3) { 2067 phydev_err(phydev, "invalid led mode: 0x%02x\n", 2068 priv->led_mode); 2069 priv->led_mode = -1; 2070 } 2071 } else { 2072 priv->led_mode = -1; 2073 } 2074 } 2075 2076 static int kszphy_resume(struct phy_device *phydev) 2077 { 2078 int ret; 2079 2080 genphy_resume(phydev); 2081 2082 /* After switching from power-down to normal mode, an internal global 2083 * reset is automatically generated. Wait a minimum of 1 ms before 2084 * read/write access to the PHY registers. 2085 */ 2086 usleep_range(1000, 2000); 2087 2088 ret = kszphy_config_reset(phydev); 2089 if (ret) 2090 return ret; 2091 2092 /* Enable PHY Interrupts */ 2093 if (phy_interrupt_is_valid(phydev)) { 2094 phydev->interrupts = PHY_INTERRUPT_ENABLED; 2095 if (phydev->drv->config_intr) 2096 phydev->drv->config_intr(phydev); 2097 } 2098 2099 return 0; 2100 } 2101 2102 static int ksz9477_resume(struct phy_device *phydev) 2103 { 2104 int ret; 2105 2106 /* No need to initialize registers if not powered down. */ 2107 ret = phy_read(phydev, MII_BMCR); 2108 if (ret < 0) 2109 return ret; 2110 if (!(ret & BMCR_PDOWN)) 2111 return 0; 2112 2113 genphy_resume(phydev); 2114 2115 /* After switching from power-down to normal mode, an internal global 2116 * reset is automatically generated. Wait a minimum of 1 ms before 2117 * read/write access to the PHY registers. 2118 */ 2119 usleep_range(1000, 2000); 2120 2121 /* Only KSZ9897 family of switches needs this fix. */ 2122 if ((phydev->phy_id & 0xf) == 1) { 2123 ret = ksz9477_phy_errata(phydev); 2124 if (ret) 2125 return ret; 2126 } 2127 2128 /* Enable PHY Interrupts */ 2129 if (phy_interrupt_is_valid(phydev)) { 2130 phydev->interrupts = PHY_INTERRUPT_ENABLED; 2131 if (phydev->drv->config_intr) 2132 phydev->drv->config_intr(phydev); 2133 } 2134 2135 return 0; 2136 } 2137 2138 static int kszphy_probe(struct phy_device *phydev) 2139 { 2140 const struct kszphy_type *type = phydev->drv->driver_data; 2141 const struct device_node *np = phydev->mdio.dev.of_node; 2142 struct kszphy_priv *priv; 2143 struct clk *clk; 2144 2145 priv = devm_kzalloc(&phydev->mdio.dev, sizeof(*priv), GFP_KERNEL); 2146 if (!priv) 2147 return -ENOMEM; 2148 2149 phydev->priv = priv; 2150 2151 priv->type = type; 2152 2153 kszphy_parse_led_mode(phydev); 2154 2155 clk = devm_clk_get_optional_enabled(&phydev->mdio.dev, "rmii-ref"); 2156 /* NOTE: clk may be NULL if building without CONFIG_HAVE_CLK */ 2157 if (!IS_ERR_OR_NULL(clk)) { 2158 unsigned long rate = clk_get_rate(clk); 2159 bool rmii_ref_clk_sel_25_mhz; 2160 2161 if (type) 2162 priv->rmii_ref_clk_sel = type->has_rmii_ref_clk_sel; 2163 rmii_ref_clk_sel_25_mhz = of_property_read_bool(np, 2164 "micrel,rmii-reference-clock-select-25-mhz"); 2165 2166 if (rate > 24500000 && rate < 25500000) { 2167 priv->rmii_ref_clk_sel_val = rmii_ref_clk_sel_25_mhz; 2168 } else if (rate > 49500000 && rate < 50500000) { 2169 priv->rmii_ref_clk_sel_val = !rmii_ref_clk_sel_25_mhz; 2170 } else { 2171 phydev_err(phydev, "Clock rate out of range: %ld\n", 2172 rate); 2173 return -EINVAL; 2174 } 2175 } else if (!clk) { 2176 /* unnamed clock from the generic ethernet-phy binding */ 2177 clk = devm_clk_get_optional_enabled(&phydev->mdio.dev, NULL); 2178 if (IS_ERR(clk)) 2179 return PTR_ERR(clk); 2180 } 2181 2182 if (ksz8041_fiber_mode(phydev)) 2183 phydev->port = PORT_FIBRE; 2184 2185 /* Support legacy board-file configuration */ 2186 if (phydev->dev_flags & MICREL_PHY_50MHZ_CLK) { 2187 priv->rmii_ref_clk_sel = true; 2188 priv->rmii_ref_clk_sel_val = true; 2189 } 2190 2191 return 0; 2192 } 2193 2194 static int lan8814_cable_test_start(struct phy_device *phydev) 2195 { 2196 /* If autoneg is enabled, we won't be able to test cross pair 2197 * short. In this case, the PHY will "detect" a link and 2198 * confuse the internal state machine - disable auto neg here. 2199 * Set the speed to 1000mbit and full duplex. 2200 */ 2201 return phy_modify(phydev, MII_BMCR, BMCR_ANENABLE | BMCR_SPEED100, 2202 BMCR_SPEED1000 | BMCR_FULLDPLX); 2203 } 2204 2205 static int ksz886x_cable_test_start(struct phy_device *phydev) 2206 { 2207 if (phydev->dev_flags & MICREL_KSZ8_P1_ERRATA) 2208 return -EOPNOTSUPP; 2209 2210 /* If autoneg is enabled, we won't be able to test cross pair 2211 * short. In this case, the PHY will "detect" a link and 2212 * confuse the internal state machine - disable auto neg here. 2213 * If autoneg is disabled, we should set the speed to 10mbit. 2214 */ 2215 return phy_clear_bits(phydev, MII_BMCR, BMCR_ANENABLE | BMCR_SPEED100); 2216 } 2217 2218 static __always_inline int ksz886x_cable_test_result_trans(u16 status, u16 mask) 2219 { 2220 switch (FIELD_GET(mask, status)) { 2221 case KSZ8081_LMD_STAT_NORMAL: 2222 return ETHTOOL_A_CABLE_RESULT_CODE_OK; 2223 case KSZ8081_LMD_STAT_SHORT: 2224 return ETHTOOL_A_CABLE_RESULT_CODE_SAME_SHORT; 2225 case KSZ8081_LMD_STAT_OPEN: 2226 return ETHTOOL_A_CABLE_RESULT_CODE_OPEN; 2227 case KSZ8081_LMD_STAT_FAIL: 2228 fallthrough; 2229 default: 2230 return ETHTOOL_A_CABLE_RESULT_CODE_UNSPEC; 2231 } 2232 } 2233 2234 static __always_inline bool ksz886x_cable_test_failed(u16 status, u16 mask) 2235 { 2236 return FIELD_GET(mask, status) == 2237 KSZ8081_LMD_STAT_FAIL; 2238 } 2239 2240 static __always_inline bool ksz886x_cable_test_fault_length_valid(u16 status, u16 mask) 2241 { 2242 switch (FIELD_GET(mask, status)) { 2243 case KSZ8081_LMD_STAT_OPEN: 2244 fallthrough; 2245 case KSZ8081_LMD_STAT_SHORT: 2246 return true; 2247 } 2248 return false; 2249 } 2250 2251 static __always_inline int ksz886x_cable_test_fault_length(struct phy_device *phydev, 2252 u16 status, u16 data_mask) 2253 { 2254 int dt; 2255 2256 /* According to the data sheet the distance to the fault is 2257 * DELTA_TIME * 0.4 meters for ksz phys. 2258 * (DELTA_TIME - 22) * 0.8 for lan8814 phy. 2259 */ 2260 dt = FIELD_GET(data_mask, status); 2261 2262 if (phydev_id_compare(phydev, PHY_ID_LAN8814)) 2263 return ((dt - 22) * 800) / 10; 2264 else 2265 return (dt * 400) / 10; 2266 } 2267 2268 static int ksz886x_cable_test_wait_for_completion(struct phy_device *phydev) 2269 { 2270 const struct kszphy_type *type = phydev->drv->driver_data; 2271 int val, ret; 2272 2273 ret = phy_read_poll_timeout(phydev, type->cable_diag_reg, val, 2274 !(val & KSZ8081_LMD_ENABLE_TEST), 2275 30000, 100000, true); 2276 2277 return ret < 0 ? ret : 0; 2278 } 2279 2280 static int lan8814_cable_test_one_pair(struct phy_device *phydev, int pair) 2281 { 2282 static const int ethtool_pair[] = { ETHTOOL_A_CABLE_PAIR_A, 2283 ETHTOOL_A_CABLE_PAIR_B, 2284 ETHTOOL_A_CABLE_PAIR_C, 2285 ETHTOOL_A_CABLE_PAIR_D, 2286 }; 2287 u32 fault_length; 2288 int ret; 2289 int val; 2290 2291 val = KSZ8081_LMD_ENABLE_TEST; 2292 val = val | (pair << LAN8814_PAIR_BIT_SHIFT); 2293 2294 ret = phy_write(phydev, LAN8814_CABLE_DIAG, val); 2295 if (ret < 0) 2296 return ret; 2297 2298 ret = ksz886x_cable_test_wait_for_completion(phydev); 2299 if (ret) 2300 return ret; 2301 2302 val = phy_read(phydev, LAN8814_CABLE_DIAG); 2303 if (val < 0) 2304 return val; 2305 2306 if (ksz886x_cable_test_failed(val, LAN8814_CABLE_DIAG_STAT_MASK)) 2307 return -EAGAIN; 2308 2309 ret = ethnl_cable_test_result(phydev, ethtool_pair[pair], 2310 ksz886x_cable_test_result_trans(val, 2311 LAN8814_CABLE_DIAG_STAT_MASK 2312 )); 2313 if (ret) 2314 return ret; 2315 2316 if (!ksz886x_cable_test_fault_length_valid(val, LAN8814_CABLE_DIAG_STAT_MASK)) 2317 return 0; 2318 2319 fault_length = ksz886x_cable_test_fault_length(phydev, val, 2320 LAN8814_CABLE_DIAG_VCT_DATA_MASK); 2321 2322 return ethnl_cable_test_fault_length(phydev, ethtool_pair[pair], fault_length); 2323 } 2324 2325 static int ksz886x_cable_test_one_pair(struct phy_device *phydev, int pair) 2326 { 2327 static const int ethtool_pair[] = { 2328 ETHTOOL_A_CABLE_PAIR_A, 2329 ETHTOOL_A_CABLE_PAIR_B, 2330 }; 2331 int ret, val, mdix; 2332 u32 fault_length; 2333 2334 /* There is no way to choice the pair, like we do one ksz9031. 2335 * We can workaround this limitation by using the MDI-X functionality. 2336 */ 2337 if (pair == 0) 2338 mdix = ETH_TP_MDI; 2339 else 2340 mdix = ETH_TP_MDI_X; 2341 2342 switch (phydev->phy_id & MICREL_PHY_ID_MASK) { 2343 case PHY_ID_KSZ8081: 2344 ret = ksz8081_config_mdix(phydev, mdix); 2345 break; 2346 case PHY_ID_KSZ886X: 2347 ret = ksz886x_config_mdix(phydev, mdix); 2348 break; 2349 default: 2350 ret = -ENODEV; 2351 } 2352 2353 if (ret) 2354 return ret; 2355 2356 /* Now we are ready to fire. This command will send a 100ns pulse 2357 * to the pair. 2358 */ 2359 ret = phy_write(phydev, KSZ8081_LMD, KSZ8081_LMD_ENABLE_TEST); 2360 if (ret) 2361 return ret; 2362 2363 ret = ksz886x_cable_test_wait_for_completion(phydev); 2364 if (ret) 2365 return ret; 2366 2367 val = phy_read(phydev, KSZ8081_LMD); 2368 if (val < 0) 2369 return val; 2370 2371 if (ksz886x_cable_test_failed(val, KSZ8081_LMD_STAT_MASK)) 2372 return -EAGAIN; 2373 2374 ret = ethnl_cable_test_result(phydev, ethtool_pair[pair], 2375 ksz886x_cable_test_result_trans(val, KSZ8081_LMD_STAT_MASK)); 2376 if (ret) 2377 return ret; 2378 2379 if (!ksz886x_cable_test_fault_length_valid(val, KSZ8081_LMD_STAT_MASK)) 2380 return 0; 2381 2382 fault_length = ksz886x_cable_test_fault_length(phydev, val, KSZ8081_LMD_DELTA_TIME_MASK); 2383 2384 return ethnl_cable_test_fault_length(phydev, ethtool_pair[pair], fault_length); 2385 } 2386 2387 static int ksz886x_cable_test_get_status(struct phy_device *phydev, 2388 bool *finished) 2389 { 2390 const struct kszphy_type *type = phydev->drv->driver_data; 2391 unsigned long pair_mask = type->pair_mask; 2392 int retries = 20; 2393 int ret = 0; 2394 int pair; 2395 2396 *finished = false; 2397 2398 /* Try harder if link partner is active */ 2399 while (pair_mask && retries--) { 2400 for_each_set_bit(pair, &pair_mask, 4) { 2401 if (type->cable_diag_reg == LAN8814_CABLE_DIAG) 2402 ret = lan8814_cable_test_one_pair(phydev, pair); 2403 else 2404 ret = ksz886x_cable_test_one_pair(phydev, pair); 2405 if (ret == -EAGAIN) 2406 continue; 2407 if (ret < 0) 2408 return ret; 2409 clear_bit(pair, &pair_mask); 2410 } 2411 /* If link partner is in autonegotiation mode it will send 2ms 2412 * of FLPs with at least 6ms of silence. 2413 * Add 2ms sleep to have better chances to hit this silence. 2414 */ 2415 if (pair_mask) 2416 msleep(2); 2417 } 2418 2419 *finished = true; 2420 2421 return ret; 2422 } 2423 2424 #define LAN_EXT_PAGE_ACCESS_CONTROL 0x16 2425 #define LAN_EXT_PAGE_ACCESS_ADDRESS_DATA 0x17 2426 #define LAN_EXT_PAGE_ACCESS_CTRL_EP_FUNC 0x4000 2427 2428 #define LAN8814_QSGMII_SOFT_RESET 0x43 2429 #define LAN8814_QSGMII_SOFT_RESET_BIT BIT(0) 2430 #define LAN8814_QSGMII_PCS1G_ANEG_CONFIG 0x13 2431 #define LAN8814_QSGMII_PCS1G_ANEG_CONFIG_ANEG_ENA BIT(3) 2432 #define LAN8814_ALIGN_SWAP 0x4a 2433 #define LAN8814_ALIGN_TX_A_B_SWAP 0x1 2434 #define LAN8814_ALIGN_TX_A_B_SWAP_MASK GENMASK(2, 0) 2435 2436 #define LAN8804_ALIGN_SWAP 0x4a 2437 #define LAN8804_ALIGN_TX_A_B_SWAP 0x1 2438 #define LAN8804_ALIGN_TX_A_B_SWAP_MASK GENMASK(2, 0) 2439 #define LAN8814_CLOCK_MANAGEMENT 0xd 2440 #define LAN8814_LINK_QUALITY 0x8e 2441 2442 static int lanphy_read_page_reg(struct phy_device *phydev, int page, u32 addr) 2443 { 2444 int data; 2445 2446 phy_lock_mdio_bus(phydev); 2447 __phy_write(phydev, LAN_EXT_PAGE_ACCESS_CONTROL, page); 2448 __phy_write(phydev, LAN_EXT_PAGE_ACCESS_ADDRESS_DATA, addr); 2449 __phy_write(phydev, LAN_EXT_PAGE_ACCESS_CONTROL, 2450 (page | LAN_EXT_PAGE_ACCESS_CTRL_EP_FUNC)); 2451 data = __phy_read(phydev, LAN_EXT_PAGE_ACCESS_ADDRESS_DATA); 2452 phy_unlock_mdio_bus(phydev); 2453 2454 return data; 2455 } 2456 2457 static int lanphy_write_page_reg(struct phy_device *phydev, int page, u16 addr, 2458 u16 val) 2459 { 2460 phy_lock_mdio_bus(phydev); 2461 __phy_write(phydev, LAN_EXT_PAGE_ACCESS_CONTROL, page); 2462 __phy_write(phydev, LAN_EXT_PAGE_ACCESS_ADDRESS_DATA, addr); 2463 __phy_write(phydev, LAN_EXT_PAGE_ACCESS_CONTROL, 2464 page | LAN_EXT_PAGE_ACCESS_CTRL_EP_FUNC); 2465 2466 val = __phy_write(phydev, LAN_EXT_PAGE_ACCESS_ADDRESS_DATA, val); 2467 if (val != 0) 2468 phydev_err(phydev, "Error: phy_write has returned error %d\n", 2469 val); 2470 phy_unlock_mdio_bus(phydev); 2471 return val; 2472 } 2473 2474 static int lan8814_config_ts_intr(struct phy_device *phydev, bool enable) 2475 { 2476 u16 val = 0; 2477 2478 if (enable) 2479 val = PTP_TSU_INT_EN_PTP_TX_TS_EN_ | 2480 PTP_TSU_INT_EN_PTP_TX_TS_OVRFL_EN_ | 2481 PTP_TSU_INT_EN_PTP_RX_TS_EN_ | 2482 PTP_TSU_INT_EN_PTP_RX_TS_OVRFL_EN_; 2483 2484 return lanphy_write_page_reg(phydev, 5, PTP_TSU_INT_EN, val); 2485 } 2486 2487 static void lan8814_ptp_rx_ts_get(struct phy_device *phydev, 2488 u32 *seconds, u32 *nano_seconds, u16 *seq_id) 2489 { 2490 *seconds = lanphy_read_page_reg(phydev, 5, PTP_RX_INGRESS_SEC_HI); 2491 *seconds = (*seconds << 16) | 2492 lanphy_read_page_reg(phydev, 5, PTP_RX_INGRESS_SEC_LO); 2493 2494 *nano_seconds = lanphy_read_page_reg(phydev, 5, PTP_RX_INGRESS_NS_HI); 2495 *nano_seconds = ((*nano_seconds & 0x3fff) << 16) | 2496 lanphy_read_page_reg(phydev, 5, PTP_RX_INGRESS_NS_LO); 2497 2498 *seq_id = lanphy_read_page_reg(phydev, 5, PTP_RX_MSG_HEADER2); 2499 } 2500 2501 static void lan8814_ptp_tx_ts_get(struct phy_device *phydev, 2502 u32 *seconds, u32 *nano_seconds, u16 *seq_id) 2503 { 2504 *seconds = lanphy_read_page_reg(phydev, 5, PTP_TX_EGRESS_SEC_HI); 2505 *seconds = *seconds << 16 | 2506 lanphy_read_page_reg(phydev, 5, PTP_TX_EGRESS_SEC_LO); 2507 2508 *nano_seconds = lanphy_read_page_reg(phydev, 5, PTP_TX_EGRESS_NS_HI); 2509 *nano_seconds = ((*nano_seconds & 0x3fff) << 16) | 2510 lanphy_read_page_reg(phydev, 5, PTP_TX_EGRESS_NS_LO); 2511 2512 *seq_id = lanphy_read_page_reg(phydev, 5, PTP_TX_MSG_HEADER2); 2513 } 2514 2515 static int lan8814_ts_info(struct mii_timestamper *mii_ts, struct ethtool_ts_info *info) 2516 { 2517 struct kszphy_ptp_priv *ptp_priv = container_of(mii_ts, struct kszphy_ptp_priv, mii_ts); 2518 struct phy_device *phydev = ptp_priv->phydev; 2519 struct lan8814_shared_priv *shared = phydev->shared->priv; 2520 2521 info->so_timestamping = SOF_TIMESTAMPING_TX_HARDWARE | 2522 SOF_TIMESTAMPING_RX_HARDWARE | 2523 SOF_TIMESTAMPING_RAW_HARDWARE; 2524 2525 info->phc_index = ptp_clock_index(shared->ptp_clock); 2526 2527 info->tx_types = 2528 (1 << HWTSTAMP_TX_OFF) | 2529 (1 << HWTSTAMP_TX_ON) | 2530 (1 << HWTSTAMP_TX_ONESTEP_SYNC); 2531 2532 info->rx_filters = 2533 (1 << HWTSTAMP_FILTER_NONE) | 2534 (1 << HWTSTAMP_FILTER_PTP_V1_L4_EVENT) | 2535 (1 << HWTSTAMP_FILTER_PTP_V2_L4_EVENT) | 2536 (1 << HWTSTAMP_FILTER_PTP_V2_L2_EVENT) | 2537 (1 << HWTSTAMP_FILTER_PTP_V2_EVENT); 2538 2539 return 0; 2540 } 2541 2542 static void lan8814_flush_fifo(struct phy_device *phydev, bool egress) 2543 { 2544 int i; 2545 2546 for (i = 0; i < FIFO_SIZE; ++i) 2547 lanphy_read_page_reg(phydev, 5, 2548 egress ? PTP_TX_MSG_HEADER2 : PTP_RX_MSG_HEADER2); 2549 2550 /* Read to clear overflow status bit */ 2551 lanphy_read_page_reg(phydev, 5, PTP_TSU_INT_STS); 2552 } 2553 2554 static int lan8814_hwtstamp(struct mii_timestamper *mii_ts, 2555 struct kernel_hwtstamp_config *config, 2556 struct netlink_ext_ack *extack) 2557 { 2558 struct kszphy_ptp_priv *ptp_priv = 2559 container_of(mii_ts, struct kszphy_ptp_priv, mii_ts); 2560 struct lan8814_ptp_rx_ts *rx_ts, *tmp; 2561 int txcfg = 0, rxcfg = 0; 2562 int pkt_ts_enable; 2563 int tx_mod; 2564 2565 ptp_priv->hwts_tx_type = config->tx_type; 2566 ptp_priv->rx_filter = config->rx_filter; 2567 2568 switch (config->rx_filter) { 2569 case HWTSTAMP_FILTER_NONE: 2570 ptp_priv->layer = 0; 2571 ptp_priv->version = 0; 2572 break; 2573 case HWTSTAMP_FILTER_PTP_V2_L4_EVENT: 2574 case HWTSTAMP_FILTER_PTP_V2_L4_SYNC: 2575 case HWTSTAMP_FILTER_PTP_V2_L4_DELAY_REQ: 2576 ptp_priv->layer = PTP_CLASS_L4; 2577 ptp_priv->version = PTP_CLASS_V2; 2578 break; 2579 case HWTSTAMP_FILTER_PTP_V2_L2_EVENT: 2580 case HWTSTAMP_FILTER_PTP_V2_L2_SYNC: 2581 case HWTSTAMP_FILTER_PTP_V2_L2_DELAY_REQ: 2582 ptp_priv->layer = PTP_CLASS_L2; 2583 ptp_priv->version = PTP_CLASS_V2; 2584 break; 2585 case HWTSTAMP_FILTER_PTP_V2_EVENT: 2586 case HWTSTAMP_FILTER_PTP_V2_SYNC: 2587 case HWTSTAMP_FILTER_PTP_V2_DELAY_REQ: 2588 ptp_priv->layer = PTP_CLASS_L4 | PTP_CLASS_L2; 2589 ptp_priv->version = PTP_CLASS_V2; 2590 break; 2591 default: 2592 return -ERANGE; 2593 } 2594 2595 if (ptp_priv->layer & PTP_CLASS_L2) { 2596 rxcfg = PTP_RX_PARSE_CONFIG_LAYER2_EN_; 2597 txcfg = PTP_TX_PARSE_CONFIG_LAYER2_EN_; 2598 } else if (ptp_priv->layer & PTP_CLASS_L4) { 2599 rxcfg |= PTP_RX_PARSE_CONFIG_IPV4_EN_ | PTP_RX_PARSE_CONFIG_IPV6_EN_; 2600 txcfg |= PTP_TX_PARSE_CONFIG_IPV4_EN_ | PTP_TX_PARSE_CONFIG_IPV6_EN_; 2601 } 2602 lanphy_write_page_reg(ptp_priv->phydev, 5, PTP_RX_PARSE_CONFIG, rxcfg); 2603 lanphy_write_page_reg(ptp_priv->phydev, 5, PTP_TX_PARSE_CONFIG, txcfg); 2604 2605 pkt_ts_enable = PTP_TIMESTAMP_EN_SYNC_ | PTP_TIMESTAMP_EN_DREQ_ | 2606 PTP_TIMESTAMP_EN_PDREQ_ | PTP_TIMESTAMP_EN_PDRES_; 2607 lanphy_write_page_reg(ptp_priv->phydev, 5, PTP_RX_TIMESTAMP_EN, pkt_ts_enable); 2608 lanphy_write_page_reg(ptp_priv->phydev, 5, PTP_TX_TIMESTAMP_EN, pkt_ts_enable); 2609 2610 tx_mod = lanphy_read_page_reg(ptp_priv->phydev, 5, PTP_TX_MOD); 2611 if (ptp_priv->hwts_tx_type == HWTSTAMP_TX_ONESTEP_SYNC) { 2612 lanphy_write_page_reg(ptp_priv->phydev, 5, PTP_TX_MOD, 2613 tx_mod | PTP_TX_MOD_TX_PTP_SYNC_TS_INSERT_); 2614 } else if (ptp_priv->hwts_tx_type == HWTSTAMP_TX_ON) { 2615 lanphy_write_page_reg(ptp_priv->phydev, 5, PTP_TX_MOD, 2616 tx_mod & ~PTP_TX_MOD_TX_PTP_SYNC_TS_INSERT_); 2617 } 2618 2619 if (config->rx_filter != HWTSTAMP_FILTER_NONE) 2620 lan8814_config_ts_intr(ptp_priv->phydev, true); 2621 else 2622 lan8814_config_ts_intr(ptp_priv->phydev, false); 2623 2624 /* In case of multiple starts and stops, these needs to be cleared */ 2625 list_for_each_entry_safe(rx_ts, tmp, &ptp_priv->rx_ts_list, list) { 2626 list_del(&rx_ts->list); 2627 kfree(rx_ts); 2628 } 2629 skb_queue_purge(&ptp_priv->rx_queue); 2630 skb_queue_purge(&ptp_priv->tx_queue); 2631 2632 lan8814_flush_fifo(ptp_priv->phydev, false); 2633 lan8814_flush_fifo(ptp_priv->phydev, true); 2634 2635 return 0; 2636 } 2637 2638 static void lan8814_txtstamp(struct mii_timestamper *mii_ts, 2639 struct sk_buff *skb, int type) 2640 { 2641 struct kszphy_ptp_priv *ptp_priv = container_of(mii_ts, struct kszphy_ptp_priv, mii_ts); 2642 2643 switch (ptp_priv->hwts_tx_type) { 2644 case HWTSTAMP_TX_ONESTEP_SYNC: 2645 if (ptp_msg_is_sync(skb, type)) { 2646 kfree_skb(skb); 2647 return; 2648 } 2649 fallthrough; 2650 case HWTSTAMP_TX_ON: 2651 skb_shinfo(skb)->tx_flags |= SKBTX_IN_PROGRESS; 2652 skb_queue_tail(&ptp_priv->tx_queue, skb); 2653 break; 2654 case HWTSTAMP_TX_OFF: 2655 default: 2656 kfree_skb(skb); 2657 break; 2658 } 2659 } 2660 2661 static bool lan8814_get_sig_rx(struct sk_buff *skb, u16 *sig) 2662 { 2663 struct ptp_header *ptp_header; 2664 u32 type; 2665 2666 skb_push(skb, ETH_HLEN); 2667 type = ptp_classify_raw(skb); 2668 ptp_header = ptp_parse_header(skb, type); 2669 skb_pull_inline(skb, ETH_HLEN); 2670 2671 if (!ptp_header) 2672 return false; 2673 2674 *sig = (__force u16)(ntohs(ptp_header->sequence_id)); 2675 return true; 2676 } 2677 2678 static bool lan8814_match_rx_skb(struct kszphy_ptp_priv *ptp_priv, 2679 struct sk_buff *skb) 2680 { 2681 struct skb_shared_hwtstamps *shhwtstamps; 2682 struct lan8814_ptp_rx_ts *rx_ts, *tmp; 2683 unsigned long flags; 2684 bool ret = false; 2685 u16 skb_sig; 2686 2687 if (!lan8814_get_sig_rx(skb, &skb_sig)) 2688 return ret; 2689 2690 /* Iterate over all RX timestamps and match it with the received skbs */ 2691 spin_lock_irqsave(&ptp_priv->rx_ts_lock, flags); 2692 list_for_each_entry_safe(rx_ts, tmp, &ptp_priv->rx_ts_list, list) { 2693 /* Check if we found the signature we were looking for. */ 2694 if (memcmp(&skb_sig, &rx_ts->seq_id, sizeof(rx_ts->seq_id))) 2695 continue; 2696 2697 shhwtstamps = skb_hwtstamps(skb); 2698 memset(shhwtstamps, 0, sizeof(*shhwtstamps)); 2699 shhwtstamps->hwtstamp = ktime_set(rx_ts->seconds, 2700 rx_ts->nsec); 2701 list_del(&rx_ts->list); 2702 kfree(rx_ts); 2703 2704 ret = true; 2705 break; 2706 } 2707 spin_unlock_irqrestore(&ptp_priv->rx_ts_lock, flags); 2708 2709 if (ret) 2710 netif_rx(skb); 2711 return ret; 2712 } 2713 2714 static bool lan8814_rxtstamp(struct mii_timestamper *mii_ts, struct sk_buff *skb, int type) 2715 { 2716 struct kszphy_ptp_priv *ptp_priv = 2717 container_of(mii_ts, struct kszphy_ptp_priv, mii_ts); 2718 2719 if (ptp_priv->rx_filter == HWTSTAMP_FILTER_NONE || 2720 type == PTP_CLASS_NONE) 2721 return false; 2722 2723 if ((type & ptp_priv->version) == 0 || (type & ptp_priv->layer) == 0) 2724 return false; 2725 2726 /* If we failed to match then add it to the queue for when the timestamp 2727 * will come 2728 */ 2729 if (!lan8814_match_rx_skb(ptp_priv, skb)) 2730 skb_queue_tail(&ptp_priv->rx_queue, skb); 2731 2732 return true; 2733 } 2734 2735 static void lan8814_ptp_clock_set(struct phy_device *phydev, 2736 time64_t sec, u32 nsec) 2737 { 2738 lanphy_write_page_reg(phydev, 4, PTP_CLOCK_SET_SEC_LO, lower_16_bits(sec)); 2739 lanphy_write_page_reg(phydev, 4, PTP_CLOCK_SET_SEC_MID, upper_16_bits(sec)); 2740 lanphy_write_page_reg(phydev, 4, PTP_CLOCK_SET_SEC_HI, upper_32_bits(sec)); 2741 lanphy_write_page_reg(phydev, 4, PTP_CLOCK_SET_NS_LO, lower_16_bits(nsec)); 2742 lanphy_write_page_reg(phydev, 4, PTP_CLOCK_SET_NS_HI, upper_16_bits(nsec)); 2743 2744 lanphy_write_page_reg(phydev, 4, PTP_CMD_CTL, PTP_CMD_CTL_PTP_CLOCK_LOAD_); 2745 } 2746 2747 static void lan8814_ptp_clock_get(struct phy_device *phydev, 2748 time64_t *sec, u32 *nsec) 2749 { 2750 lanphy_write_page_reg(phydev, 4, PTP_CMD_CTL, PTP_CMD_CTL_PTP_CLOCK_READ_); 2751 2752 *sec = lanphy_read_page_reg(phydev, 4, PTP_CLOCK_READ_SEC_HI); 2753 *sec <<= 16; 2754 *sec |= lanphy_read_page_reg(phydev, 4, PTP_CLOCK_READ_SEC_MID); 2755 *sec <<= 16; 2756 *sec |= lanphy_read_page_reg(phydev, 4, PTP_CLOCK_READ_SEC_LO); 2757 2758 *nsec = lanphy_read_page_reg(phydev, 4, PTP_CLOCK_READ_NS_HI); 2759 *nsec <<= 16; 2760 *nsec |= lanphy_read_page_reg(phydev, 4, PTP_CLOCK_READ_NS_LO); 2761 } 2762 2763 static int lan8814_ptpci_gettime64(struct ptp_clock_info *ptpci, 2764 struct timespec64 *ts) 2765 { 2766 struct lan8814_shared_priv *shared = container_of(ptpci, struct lan8814_shared_priv, 2767 ptp_clock_info); 2768 struct phy_device *phydev = shared->phydev; 2769 u32 nano_seconds; 2770 time64_t seconds; 2771 2772 mutex_lock(&shared->shared_lock); 2773 lan8814_ptp_clock_get(phydev, &seconds, &nano_seconds); 2774 mutex_unlock(&shared->shared_lock); 2775 ts->tv_sec = seconds; 2776 ts->tv_nsec = nano_seconds; 2777 2778 return 0; 2779 } 2780 2781 static int lan8814_ptpci_settime64(struct ptp_clock_info *ptpci, 2782 const struct timespec64 *ts) 2783 { 2784 struct lan8814_shared_priv *shared = container_of(ptpci, struct lan8814_shared_priv, 2785 ptp_clock_info); 2786 struct phy_device *phydev = shared->phydev; 2787 2788 mutex_lock(&shared->shared_lock); 2789 lan8814_ptp_clock_set(phydev, ts->tv_sec, ts->tv_nsec); 2790 mutex_unlock(&shared->shared_lock); 2791 2792 return 0; 2793 } 2794 2795 static void lan8814_ptp_set_target(struct phy_device *phydev, int event, 2796 s64 start_sec, u32 start_nsec) 2797 { 2798 /* Set the start time */ 2799 lanphy_write_page_reg(phydev, 4, LAN8814_PTP_CLOCK_TARGET_SEC_LO(event), 2800 lower_16_bits(start_sec)); 2801 lanphy_write_page_reg(phydev, 4, LAN8814_PTP_CLOCK_TARGET_SEC_HI(event), 2802 upper_16_bits(start_sec)); 2803 2804 lanphy_write_page_reg(phydev, 4, LAN8814_PTP_CLOCK_TARGET_NS_LO(event), 2805 lower_16_bits(start_nsec)); 2806 lanphy_write_page_reg(phydev, 4, LAN8814_PTP_CLOCK_TARGET_NS_HI(event), 2807 upper_16_bits(start_nsec) & 0x3fff); 2808 } 2809 2810 static void lan8814_ptp_update_target(struct phy_device *phydev, time64_t sec) 2811 { 2812 lan8814_ptp_set_target(phydev, LAN8814_EVENT_A, 2813 sec + LAN8814_BUFFER_TIME, 0); 2814 lan8814_ptp_set_target(phydev, LAN8814_EVENT_B, 2815 sec + LAN8814_BUFFER_TIME, 0); 2816 } 2817 2818 static void lan8814_ptp_clock_step(struct phy_device *phydev, 2819 s64 time_step_ns) 2820 { 2821 u32 nano_seconds_step; 2822 u64 abs_time_step_ns; 2823 time64_t set_seconds; 2824 u32 nano_seconds; 2825 u32 remainder; 2826 s32 seconds; 2827 2828 if (time_step_ns > 15000000000LL) { 2829 /* convert to clock set */ 2830 lan8814_ptp_clock_get(phydev, &set_seconds, &nano_seconds); 2831 set_seconds += div_u64_rem(time_step_ns, 1000000000LL, 2832 &remainder); 2833 nano_seconds += remainder; 2834 if (nano_seconds >= 1000000000) { 2835 set_seconds++; 2836 nano_seconds -= 1000000000; 2837 } 2838 lan8814_ptp_clock_set(phydev, set_seconds, nano_seconds); 2839 lan8814_ptp_update_target(phydev, set_seconds); 2840 return; 2841 } else if (time_step_ns < -15000000000LL) { 2842 /* convert to clock set */ 2843 time_step_ns = -time_step_ns; 2844 2845 lan8814_ptp_clock_get(phydev, &set_seconds, &nano_seconds); 2846 set_seconds -= div_u64_rem(time_step_ns, 1000000000LL, 2847 &remainder); 2848 nano_seconds_step = remainder; 2849 if (nano_seconds < nano_seconds_step) { 2850 set_seconds--; 2851 nano_seconds += 1000000000; 2852 } 2853 nano_seconds -= nano_seconds_step; 2854 lan8814_ptp_clock_set(phydev, set_seconds, nano_seconds); 2855 lan8814_ptp_update_target(phydev, set_seconds); 2856 return; 2857 } 2858 2859 /* do clock step */ 2860 if (time_step_ns >= 0) { 2861 abs_time_step_ns = (u64)time_step_ns; 2862 seconds = (s32)div_u64_rem(abs_time_step_ns, 1000000000, 2863 &remainder); 2864 nano_seconds = remainder; 2865 } else { 2866 abs_time_step_ns = (u64)(-time_step_ns); 2867 seconds = -((s32)div_u64_rem(abs_time_step_ns, 1000000000, 2868 &remainder)); 2869 nano_seconds = remainder; 2870 if (nano_seconds > 0) { 2871 /* subtracting nano seconds is not allowed 2872 * convert to subtracting from seconds, 2873 * and adding to nanoseconds 2874 */ 2875 seconds--; 2876 nano_seconds = (1000000000 - nano_seconds); 2877 } 2878 } 2879 2880 if (nano_seconds > 0) { 2881 /* add 8 ns to cover the likely normal increment */ 2882 nano_seconds += 8; 2883 } 2884 2885 if (nano_seconds >= 1000000000) { 2886 /* carry into seconds */ 2887 seconds++; 2888 nano_seconds -= 1000000000; 2889 } 2890 2891 while (seconds) { 2892 u32 nsec; 2893 2894 if (seconds > 0) { 2895 u32 adjustment_value = (u32)seconds; 2896 u16 adjustment_value_lo, adjustment_value_hi; 2897 2898 if (adjustment_value > 0xF) 2899 adjustment_value = 0xF; 2900 2901 adjustment_value_lo = adjustment_value & 0xffff; 2902 adjustment_value_hi = (adjustment_value >> 16) & 0x3fff; 2903 2904 lanphy_write_page_reg(phydev, 4, PTP_LTC_STEP_ADJ_LO, 2905 adjustment_value_lo); 2906 lanphy_write_page_reg(phydev, 4, PTP_LTC_STEP_ADJ_HI, 2907 PTP_LTC_STEP_ADJ_DIR_ | 2908 adjustment_value_hi); 2909 seconds -= ((s32)adjustment_value); 2910 2911 lan8814_ptp_clock_get(phydev, &set_seconds, &nsec); 2912 set_seconds -= adjustment_value; 2913 lan8814_ptp_update_target(phydev, set_seconds); 2914 } else { 2915 u32 adjustment_value = (u32)(-seconds); 2916 u16 adjustment_value_lo, adjustment_value_hi; 2917 2918 if (adjustment_value > 0xF) 2919 adjustment_value = 0xF; 2920 2921 adjustment_value_lo = adjustment_value & 0xffff; 2922 adjustment_value_hi = (adjustment_value >> 16) & 0x3fff; 2923 2924 lanphy_write_page_reg(phydev, 4, PTP_LTC_STEP_ADJ_LO, 2925 adjustment_value_lo); 2926 lanphy_write_page_reg(phydev, 4, PTP_LTC_STEP_ADJ_HI, 2927 adjustment_value_hi); 2928 seconds += ((s32)adjustment_value); 2929 2930 lan8814_ptp_clock_get(phydev, &set_seconds, &nsec); 2931 set_seconds += adjustment_value; 2932 lan8814_ptp_update_target(phydev, set_seconds); 2933 } 2934 lanphy_write_page_reg(phydev, 4, PTP_CMD_CTL, 2935 PTP_CMD_CTL_PTP_LTC_STEP_SEC_); 2936 } 2937 if (nano_seconds) { 2938 u16 nano_seconds_lo; 2939 u16 nano_seconds_hi; 2940 2941 nano_seconds_lo = nano_seconds & 0xffff; 2942 nano_seconds_hi = (nano_seconds >> 16) & 0x3fff; 2943 2944 lanphy_write_page_reg(phydev, 4, PTP_LTC_STEP_ADJ_LO, 2945 nano_seconds_lo); 2946 lanphy_write_page_reg(phydev, 4, PTP_LTC_STEP_ADJ_HI, 2947 PTP_LTC_STEP_ADJ_DIR_ | 2948 nano_seconds_hi); 2949 lanphy_write_page_reg(phydev, 4, PTP_CMD_CTL, 2950 PTP_CMD_CTL_PTP_LTC_STEP_NSEC_); 2951 } 2952 } 2953 2954 static int lan8814_ptpci_adjtime(struct ptp_clock_info *ptpci, s64 delta) 2955 { 2956 struct lan8814_shared_priv *shared = container_of(ptpci, struct lan8814_shared_priv, 2957 ptp_clock_info); 2958 struct phy_device *phydev = shared->phydev; 2959 2960 mutex_lock(&shared->shared_lock); 2961 lan8814_ptp_clock_step(phydev, delta); 2962 mutex_unlock(&shared->shared_lock); 2963 2964 return 0; 2965 } 2966 2967 static int lan8814_ptpci_adjfine(struct ptp_clock_info *ptpci, long scaled_ppm) 2968 { 2969 struct lan8814_shared_priv *shared = container_of(ptpci, struct lan8814_shared_priv, 2970 ptp_clock_info); 2971 struct phy_device *phydev = shared->phydev; 2972 u16 kszphy_rate_adj_lo, kszphy_rate_adj_hi; 2973 bool positive = true; 2974 u32 kszphy_rate_adj; 2975 2976 if (scaled_ppm < 0) { 2977 scaled_ppm = -scaled_ppm; 2978 positive = false; 2979 } 2980 2981 kszphy_rate_adj = LAN8814_1PPM_FORMAT * (scaled_ppm >> 16); 2982 kszphy_rate_adj += (LAN8814_1PPM_FORMAT * (0xffff & scaled_ppm)) >> 16; 2983 2984 kszphy_rate_adj_lo = kszphy_rate_adj & 0xffff; 2985 kszphy_rate_adj_hi = (kszphy_rate_adj >> 16) & 0x3fff; 2986 2987 if (positive) 2988 kszphy_rate_adj_hi |= PTP_CLOCK_RATE_ADJ_DIR_; 2989 2990 mutex_lock(&shared->shared_lock); 2991 lanphy_write_page_reg(phydev, 4, PTP_CLOCK_RATE_ADJ_HI, kszphy_rate_adj_hi); 2992 lanphy_write_page_reg(phydev, 4, PTP_CLOCK_RATE_ADJ_LO, kszphy_rate_adj_lo); 2993 mutex_unlock(&shared->shared_lock); 2994 2995 return 0; 2996 } 2997 2998 static void lan8814_ptp_set_reload(struct phy_device *phydev, int event, 2999 s64 period_sec, u32 period_nsec) 3000 { 3001 lanphy_write_page_reg(phydev, 4, 3002 LAN8814_PTP_CLOCK_TARGET_RELOAD_SEC_LO(event), 3003 lower_16_bits(period_sec)); 3004 lanphy_write_page_reg(phydev, 4, 3005 LAN8814_PTP_CLOCK_TARGET_RELOAD_SEC_HI(event), 3006 upper_16_bits(period_sec)); 3007 3008 lanphy_write_page_reg(phydev, 4, 3009 LAN8814_PTP_CLOCK_TARGET_RELOAD_NS_LO(event), 3010 lower_16_bits(period_nsec)); 3011 lanphy_write_page_reg(phydev, 4, 3012 LAN8814_PTP_CLOCK_TARGET_RELOAD_NS_HI(event), 3013 upper_16_bits(period_nsec) & 0x3fff); 3014 } 3015 3016 static void lan8814_ptp_enable_event(struct phy_device *phydev, int event, 3017 int pulse_width) 3018 { 3019 u16 val; 3020 3021 val = lanphy_read_page_reg(phydev, 4, LAN8814_PTP_GENERAL_CONFIG); 3022 /* Set the pulse width of the event */ 3023 val &= ~(LAN8814_PTP_GENERAL_CONFIG_LTC_EVENT_MASK(event)); 3024 /* Make sure that the target clock will be incremented each time when 3025 * local time reaches or pass it 3026 */ 3027 val |= LAN8814_PTP_GENERAL_CONFIG_LTC_EVENT_SET(event, pulse_width); 3028 val &= ~(LAN8814_PTP_GENERAL_CONFIG_RELOAD_ADD_X(event)); 3029 /* Set the polarity high */ 3030 val |= LAN8814_PTP_GENERAL_CONFIG_POLARITY_X(event); 3031 lanphy_write_page_reg(phydev, 4, LAN8814_PTP_GENERAL_CONFIG, val); 3032 } 3033 3034 static void lan8814_ptp_disable_event(struct phy_device *phydev, int event) 3035 { 3036 u16 val; 3037 3038 /* Set target to too far in the future, effectively disabling it */ 3039 lan8814_ptp_set_target(phydev, event, 0xFFFFFFFF, 0); 3040 3041 /* And then reload once it recheas the target */ 3042 val = lanphy_read_page_reg(phydev, 4, LAN8814_PTP_GENERAL_CONFIG); 3043 val |= LAN8814_PTP_GENERAL_CONFIG_RELOAD_ADD_X(event); 3044 lanphy_write_page_reg(phydev, 4, LAN8814_PTP_GENERAL_CONFIG, val); 3045 } 3046 3047 static void lan8814_ptp_perout_off(struct phy_device *phydev, int pin) 3048 { 3049 u16 val; 3050 3051 /* Disable gpio alternate function, 3052 * 1: select as gpio, 3053 * 0: select alt func 3054 */ 3055 val = lanphy_read_page_reg(phydev, 4, LAN8814_GPIO_EN_ADDR(pin)); 3056 val |= LAN8814_GPIO_EN_BIT(pin); 3057 lanphy_write_page_reg(phydev, 4, LAN8814_GPIO_EN_ADDR(pin), val); 3058 3059 val = lanphy_read_page_reg(phydev, 4, LAN8814_GPIO_DIR_ADDR(pin)); 3060 val &= ~LAN8814_GPIO_DIR_BIT(pin); 3061 lanphy_write_page_reg(phydev, 4, LAN8814_GPIO_DIR_ADDR(pin), val); 3062 3063 val = lanphy_read_page_reg(phydev, 4, LAN8814_GPIO_BUF_ADDR(pin)); 3064 val &= ~LAN8814_GPIO_BUF_BIT(pin); 3065 lanphy_write_page_reg(phydev, 4, LAN8814_GPIO_BUF_ADDR(pin), val); 3066 } 3067 3068 static void lan8814_ptp_perout_on(struct phy_device *phydev, int pin) 3069 { 3070 int val; 3071 3072 /* Set as gpio output */ 3073 val = lanphy_read_page_reg(phydev, 4, LAN8814_GPIO_DIR_ADDR(pin)); 3074 val |= LAN8814_GPIO_DIR_BIT(pin); 3075 lanphy_write_page_reg(phydev, 4, LAN8814_GPIO_DIR_ADDR(pin), val); 3076 3077 /* Enable gpio 0:for alternate function, 1:gpio */ 3078 val = lanphy_read_page_reg(phydev, 4, LAN8814_GPIO_EN_ADDR(pin)); 3079 val &= ~LAN8814_GPIO_EN_BIT(pin); 3080 lanphy_write_page_reg(phydev, 4, LAN8814_GPIO_EN_ADDR(pin), val); 3081 3082 /* Set buffer type to push pull */ 3083 val = lanphy_read_page_reg(phydev, 4, LAN8814_GPIO_BUF_ADDR(pin)); 3084 val |= LAN8814_GPIO_BUF_BIT(pin); 3085 lanphy_write_page_reg(phydev, 4, LAN8814_GPIO_BUF_ADDR(pin), val); 3086 } 3087 3088 static int lan8814_ptp_perout(struct ptp_clock_info *ptpci, 3089 struct ptp_clock_request *rq, int on) 3090 { 3091 struct lan8814_shared_priv *shared = container_of(ptpci, struct lan8814_shared_priv, 3092 ptp_clock_info); 3093 struct phy_device *phydev = shared->phydev; 3094 struct timespec64 ts_on, ts_period; 3095 s64 on_nsec, period_nsec; 3096 int pulse_width; 3097 int pin, event; 3098 3099 /* Reject requests with unsupported flags */ 3100 if (rq->perout.flags & ~PTP_PEROUT_DUTY_CYCLE) 3101 return -EOPNOTSUPP; 3102 3103 mutex_lock(&shared->shared_lock); 3104 event = rq->perout.index; 3105 pin = ptp_find_pin(shared->ptp_clock, PTP_PF_PEROUT, event); 3106 if (pin < 0 || pin >= LAN8814_PTP_PEROUT_NUM) { 3107 mutex_unlock(&shared->shared_lock); 3108 return -EBUSY; 3109 } 3110 3111 if (!on) { 3112 lan8814_ptp_perout_off(phydev, pin); 3113 lan8814_ptp_disable_event(phydev, event); 3114 mutex_unlock(&shared->shared_lock); 3115 return 0; 3116 } 3117 3118 ts_on.tv_sec = rq->perout.on.sec; 3119 ts_on.tv_nsec = rq->perout.on.nsec; 3120 on_nsec = timespec64_to_ns(&ts_on); 3121 3122 ts_period.tv_sec = rq->perout.period.sec; 3123 ts_period.tv_nsec = rq->perout.period.nsec; 3124 period_nsec = timespec64_to_ns(&ts_period); 3125 3126 if (period_nsec < 200) { 3127 pr_warn_ratelimited("%s: perout period too small, minimum is 200 nsec\n", 3128 phydev_name(phydev)); 3129 mutex_unlock(&shared->shared_lock); 3130 return -EOPNOTSUPP; 3131 } 3132 3133 if (on_nsec >= period_nsec) { 3134 pr_warn_ratelimited("%s: pulse width must be smaller than period\n", 3135 phydev_name(phydev)); 3136 mutex_unlock(&shared->shared_lock); 3137 return -EINVAL; 3138 } 3139 3140 switch (on_nsec) { 3141 case 200000000: 3142 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_200MS; 3143 break; 3144 case 100000000: 3145 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_100MS; 3146 break; 3147 case 50000000: 3148 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_50MS; 3149 break; 3150 case 10000000: 3151 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_10MS; 3152 break; 3153 case 5000000: 3154 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_5MS; 3155 break; 3156 case 1000000: 3157 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_1MS; 3158 break; 3159 case 500000: 3160 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_500US; 3161 break; 3162 case 100000: 3163 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_100US; 3164 break; 3165 case 50000: 3166 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_50US; 3167 break; 3168 case 10000: 3169 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_10US; 3170 break; 3171 case 5000: 3172 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_5US; 3173 break; 3174 case 1000: 3175 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_1US; 3176 break; 3177 case 500: 3178 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_500NS; 3179 break; 3180 case 100: 3181 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_100NS; 3182 break; 3183 default: 3184 pr_warn_ratelimited("%s: Use default duty cycle of 100ns\n", 3185 phydev_name(phydev)); 3186 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_100NS; 3187 break; 3188 } 3189 3190 /* Configure to pulse every period */ 3191 lan8814_ptp_enable_event(phydev, event, pulse_width); 3192 lan8814_ptp_set_target(phydev, event, rq->perout.start.sec, 3193 rq->perout.start.nsec); 3194 lan8814_ptp_set_reload(phydev, event, rq->perout.period.sec, 3195 rq->perout.period.nsec); 3196 lan8814_ptp_perout_on(phydev, pin); 3197 mutex_unlock(&shared->shared_lock); 3198 3199 return 0; 3200 } 3201 3202 static void lan8814_ptp_extts_on(struct phy_device *phydev, int pin, u32 flags) 3203 { 3204 u16 tmp; 3205 3206 /* Set as gpio input */ 3207 tmp = lanphy_read_page_reg(phydev, 4, LAN8814_GPIO_DIR_ADDR(pin)); 3208 tmp &= ~LAN8814_GPIO_DIR_BIT(pin); 3209 lanphy_write_page_reg(phydev, 4, LAN8814_GPIO_DIR_ADDR(pin), tmp); 3210 3211 /* Map the pin to ltc pin 0 of the capture map registers */ 3212 tmp = lanphy_read_page_reg(phydev, 4, PTP_GPIO_CAP_MAP_LO); 3213 tmp |= pin; 3214 lanphy_write_page_reg(phydev, 4, PTP_GPIO_CAP_MAP_LO, tmp); 3215 3216 /* Enable capture on the edges of the ltc pin */ 3217 tmp = lanphy_read_page_reg(phydev, 4, PTP_GPIO_CAP_EN); 3218 if (flags & PTP_RISING_EDGE) 3219 tmp |= PTP_GPIO_CAP_EN_GPIO_RE_CAPTURE_ENABLE(0); 3220 if (flags & PTP_FALLING_EDGE) 3221 tmp |= PTP_GPIO_CAP_EN_GPIO_FE_CAPTURE_ENABLE(0); 3222 lanphy_write_page_reg(phydev, 4, PTP_GPIO_CAP_EN, tmp); 3223 3224 /* Enable interrupt top interrupt */ 3225 tmp = lanphy_read_page_reg(phydev, 4, PTP_COMMON_INT_ENA); 3226 tmp |= PTP_COMMON_INT_ENA_GPIO_CAP_EN; 3227 lanphy_write_page_reg(phydev, 4, PTP_COMMON_INT_ENA, tmp); 3228 } 3229 3230 static void lan8814_ptp_extts_off(struct phy_device *phydev, int pin) 3231 { 3232 u16 tmp; 3233 3234 /* Set as gpio out */ 3235 tmp = lanphy_read_page_reg(phydev, 4, LAN8814_GPIO_DIR_ADDR(pin)); 3236 tmp |= LAN8814_GPIO_DIR_BIT(pin); 3237 lanphy_write_page_reg(phydev, 4, LAN8814_GPIO_DIR_ADDR(pin), tmp); 3238 3239 /* Enable alternate, 0:for alternate function, 1:gpio */ 3240 tmp = lanphy_read_page_reg(phydev, 4, LAN8814_GPIO_EN_ADDR(pin)); 3241 tmp &= ~LAN8814_GPIO_EN_BIT(pin); 3242 lanphy_write_page_reg(phydev, 4, LAN8814_GPIO_EN_ADDR(pin), tmp); 3243 3244 /* Clear the mapping of pin to registers 0 of the capture registers */ 3245 tmp = lanphy_read_page_reg(phydev, 4, PTP_GPIO_CAP_MAP_LO); 3246 tmp &= ~GENMASK(3, 0); 3247 lanphy_write_page_reg(phydev, 4, PTP_GPIO_CAP_MAP_LO, tmp); 3248 3249 /* Disable capture on both of the edges */ 3250 tmp = lanphy_read_page_reg(phydev, 4, PTP_GPIO_CAP_EN); 3251 tmp &= ~PTP_GPIO_CAP_EN_GPIO_RE_CAPTURE_ENABLE(pin); 3252 tmp &= ~PTP_GPIO_CAP_EN_GPIO_FE_CAPTURE_ENABLE(pin); 3253 lanphy_write_page_reg(phydev, 4, PTP_GPIO_CAP_EN, tmp); 3254 3255 /* Disable interrupt top interrupt */ 3256 tmp = lanphy_read_page_reg(phydev, 4, PTP_COMMON_INT_ENA); 3257 tmp &= ~PTP_COMMON_INT_ENA_GPIO_CAP_EN; 3258 lanphy_write_page_reg(phydev, 4, PTP_COMMON_INT_ENA, tmp); 3259 } 3260 3261 static int lan8814_ptp_extts(struct ptp_clock_info *ptpci, 3262 struct ptp_clock_request *rq, int on) 3263 { 3264 struct lan8814_shared_priv *shared = container_of(ptpci, struct lan8814_shared_priv, 3265 ptp_clock_info); 3266 struct phy_device *phydev = shared->phydev; 3267 int pin; 3268 3269 if (rq->extts.flags & ~(PTP_ENABLE_FEATURE | 3270 PTP_EXTTS_EDGES | 3271 PTP_STRICT_FLAGS)) 3272 return -EOPNOTSUPP; 3273 3274 pin = ptp_find_pin(shared->ptp_clock, PTP_PF_EXTTS, 3275 rq->extts.index); 3276 if (pin == -1 || pin != LAN8814_PTP_EXTTS_NUM) 3277 return -EINVAL; 3278 3279 mutex_lock(&shared->shared_lock); 3280 if (on) 3281 lan8814_ptp_extts_on(phydev, pin, rq->extts.flags); 3282 else 3283 lan8814_ptp_extts_off(phydev, pin); 3284 3285 mutex_unlock(&shared->shared_lock); 3286 3287 return 0; 3288 } 3289 3290 static int lan8814_ptpci_enable(struct ptp_clock_info *ptpci, 3291 struct ptp_clock_request *rq, int on) 3292 { 3293 switch (rq->type) { 3294 case PTP_CLK_REQ_PEROUT: 3295 return lan8814_ptp_perout(ptpci, rq, on); 3296 case PTP_CLK_REQ_EXTTS: 3297 return lan8814_ptp_extts(ptpci, rq, on); 3298 default: 3299 return -EINVAL; 3300 } 3301 } 3302 3303 static int lan8814_ptpci_verify(struct ptp_clock_info *ptp, unsigned int pin, 3304 enum ptp_pin_function func, unsigned int chan) 3305 { 3306 switch (func) { 3307 case PTP_PF_NONE: 3308 case PTP_PF_PEROUT: 3309 /* Only pins 0 and 1 can generate perout signals. And for pin 0 3310 * there is only chan 0 (event A) and for pin 1 there is only 3311 * chan 1 (event B) 3312 */ 3313 if (pin >= LAN8814_PTP_PEROUT_NUM || pin != chan) 3314 return -1; 3315 break; 3316 case PTP_PF_EXTTS: 3317 if (pin != LAN8814_PTP_EXTTS_NUM) 3318 return -1; 3319 break; 3320 default: 3321 return -1; 3322 } 3323 3324 return 0; 3325 } 3326 3327 static bool lan8814_get_sig_tx(struct sk_buff *skb, u16 *sig) 3328 { 3329 struct ptp_header *ptp_header; 3330 u32 type; 3331 3332 type = ptp_classify_raw(skb); 3333 ptp_header = ptp_parse_header(skb, type); 3334 3335 if (!ptp_header) 3336 return false; 3337 3338 *sig = (__force u16)(ntohs(ptp_header->sequence_id)); 3339 return true; 3340 } 3341 3342 static void lan8814_match_tx_skb(struct kszphy_ptp_priv *ptp_priv, 3343 u32 seconds, u32 nsec, u16 seq_id) 3344 { 3345 struct skb_shared_hwtstamps shhwtstamps; 3346 struct sk_buff *skb, *skb_tmp; 3347 unsigned long flags; 3348 bool ret = false; 3349 u16 skb_sig; 3350 3351 spin_lock_irqsave(&ptp_priv->tx_queue.lock, flags); 3352 skb_queue_walk_safe(&ptp_priv->tx_queue, skb, skb_tmp) { 3353 if (!lan8814_get_sig_tx(skb, &skb_sig)) 3354 continue; 3355 3356 if (memcmp(&skb_sig, &seq_id, sizeof(seq_id))) 3357 continue; 3358 3359 __skb_unlink(skb, &ptp_priv->tx_queue); 3360 ret = true; 3361 break; 3362 } 3363 spin_unlock_irqrestore(&ptp_priv->tx_queue.lock, flags); 3364 3365 if (ret) { 3366 memset(&shhwtstamps, 0, sizeof(shhwtstamps)); 3367 shhwtstamps.hwtstamp = ktime_set(seconds, nsec); 3368 skb_complete_tx_timestamp(skb, &shhwtstamps); 3369 } 3370 } 3371 3372 static void lan8814_dequeue_tx_skb(struct kszphy_ptp_priv *ptp_priv) 3373 { 3374 struct phy_device *phydev = ptp_priv->phydev; 3375 u32 seconds, nsec; 3376 u16 seq_id; 3377 3378 lan8814_ptp_tx_ts_get(phydev, &seconds, &nsec, &seq_id); 3379 lan8814_match_tx_skb(ptp_priv, seconds, nsec, seq_id); 3380 } 3381 3382 static void lan8814_get_tx_ts(struct kszphy_ptp_priv *ptp_priv) 3383 { 3384 struct phy_device *phydev = ptp_priv->phydev; 3385 u32 reg; 3386 3387 do { 3388 lan8814_dequeue_tx_skb(ptp_priv); 3389 3390 /* If other timestamps are available in the FIFO, 3391 * process them. 3392 */ 3393 reg = lanphy_read_page_reg(phydev, 5, PTP_CAP_INFO); 3394 } while (PTP_CAP_INFO_TX_TS_CNT_GET_(reg) > 0); 3395 } 3396 3397 static bool lan8814_match_skb(struct kszphy_ptp_priv *ptp_priv, 3398 struct lan8814_ptp_rx_ts *rx_ts) 3399 { 3400 struct skb_shared_hwtstamps *shhwtstamps; 3401 struct sk_buff *skb, *skb_tmp; 3402 unsigned long flags; 3403 bool ret = false; 3404 u16 skb_sig; 3405 3406 spin_lock_irqsave(&ptp_priv->rx_queue.lock, flags); 3407 skb_queue_walk_safe(&ptp_priv->rx_queue, skb, skb_tmp) { 3408 if (!lan8814_get_sig_rx(skb, &skb_sig)) 3409 continue; 3410 3411 if (memcmp(&skb_sig, &rx_ts->seq_id, sizeof(rx_ts->seq_id))) 3412 continue; 3413 3414 __skb_unlink(skb, &ptp_priv->rx_queue); 3415 3416 ret = true; 3417 break; 3418 } 3419 spin_unlock_irqrestore(&ptp_priv->rx_queue.lock, flags); 3420 3421 if (ret) { 3422 shhwtstamps = skb_hwtstamps(skb); 3423 memset(shhwtstamps, 0, sizeof(*shhwtstamps)); 3424 shhwtstamps->hwtstamp = ktime_set(rx_ts->seconds, rx_ts->nsec); 3425 netif_rx(skb); 3426 } 3427 3428 return ret; 3429 } 3430 3431 static void lan8814_match_rx_ts(struct kszphy_ptp_priv *ptp_priv, 3432 struct lan8814_ptp_rx_ts *rx_ts) 3433 { 3434 unsigned long flags; 3435 3436 /* If we failed to match the skb add it to the queue for when 3437 * the frame will come 3438 */ 3439 if (!lan8814_match_skb(ptp_priv, rx_ts)) { 3440 spin_lock_irqsave(&ptp_priv->rx_ts_lock, flags); 3441 list_add(&rx_ts->list, &ptp_priv->rx_ts_list); 3442 spin_unlock_irqrestore(&ptp_priv->rx_ts_lock, flags); 3443 } else { 3444 kfree(rx_ts); 3445 } 3446 } 3447 3448 static void lan8814_get_rx_ts(struct kszphy_ptp_priv *ptp_priv) 3449 { 3450 struct phy_device *phydev = ptp_priv->phydev; 3451 struct lan8814_ptp_rx_ts *rx_ts; 3452 u32 reg; 3453 3454 do { 3455 rx_ts = kzalloc(sizeof(*rx_ts), GFP_KERNEL); 3456 if (!rx_ts) 3457 return; 3458 3459 lan8814_ptp_rx_ts_get(phydev, &rx_ts->seconds, &rx_ts->nsec, 3460 &rx_ts->seq_id); 3461 lan8814_match_rx_ts(ptp_priv, rx_ts); 3462 3463 /* If other timestamps are available in the FIFO, 3464 * process them. 3465 */ 3466 reg = lanphy_read_page_reg(phydev, 5, PTP_CAP_INFO); 3467 } while (PTP_CAP_INFO_RX_TS_CNT_GET_(reg) > 0); 3468 } 3469 3470 static void lan8814_handle_ptp_interrupt(struct phy_device *phydev, u16 status) 3471 { 3472 struct kszphy_priv *priv = phydev->priv; 3473 struct kszphy_ptp_priv *ptp_priv = &priv->ptp_priv; 3474 3475 if (status & PTP_TSU_INT_STS_PTP_TX_TS_EN_) 3476 lan8814_get_tx_ts(ptp_priv); 3477 3478 if (status & PTP_TSU_INT_STS_PTP_RX_TS_EN_) 3479 lan8814_get_rx_ts(ptp_priv); 3480 3481 if (status & PTP_TSU_INT_STS_PTP_TX_TS_OVRFL_INT_) { 3482 lan8814_flush_fifo(phydev, true); 3483 skb_queue_purge(&ptp_priv->tx_queue); 3484 } 3485 3486 if (status & PTP_TSU_INT_STS_PTP_RX_TS_OVRFL_INT_) { 3487 lan8814_flush_fifo(phydev, false); 3488 skb_queue_purge(&ptp_priv->rx_queue); 3489 } 3490 } 3491 3492 static int lan8814_gpio_process_cap(struct lan8814_shared_priv *shared) 3493 { 3494 struct phy_device *phydev = shared->phydev; 3495 struct ptp_clock_event ptp_event = {0}; 3496 unsigned long nsec; 3497 s64 sec; 3498 u16 tmp; 3499 3500 /* This is 0 because whatever was the input pin it was mapped it to 3501 * ltc gpio pin 0 3502 */ 3503 tmp = lanphy_read_page_reg(phydev, 4, PTP_GPIO_SEL); 3504 tmp |= PTP_GPIO_SEL_GPIO_SEL(0); 3505 lanphy_write_page_reg(phydev, 4, PTP_GPIO_SEL, tmp); 3506 3507 tmp = lanphy_read_page_reg(phydev, 4, PTP_GPIO_CAP_STS); 3508 if (!(tmp & PTP_GPIO_CAP_STS_PTP_GPIO_RE_STS(0)) && 3509 !(tmp & PTP_GPIO_CAP_STS_PTP_GPIO_FE_STS(0))) 3510 return -1; 3511 3512 if (tmp & BIT(0)) { 3513 sec = lanphy_read_page_reg(phydev, 4, PTP_GPIO_RE_LTC_SEC_HI_CAP); 3514 sec <<= 16; 3515 sec |= lanphy_read_page_reg(phydev, 4, PTP_GPIO_RE_LTC_SEC_LO_CAP); 3516 3517 nsec = lanphy_read_page_reg(phydev, 4, PTP_GPIO_RE_LTC_NS_HI_CAP) & 0x3fff; 3518 nsec <<= 16; 3519 nsec |= lanphy_read_page_reg(phydev, 4, PTP_GPIO_RE_LTC_NS_LO_CAP); 3520 } else { 3521 sec = lanphy_read_page_reg(phydev, 4, PTP_GPIO_FE_LTC_SEC_HI_CAP); 3522 sec <<= 16; 3523 sec |= lanphy_read_page_reg(phydev, 4, PTP_GPIO_FE_LTC_SEC_LO_CAP); 3524 3525 nsec = lanphy_read_page_reg(phydev, 4, PTP_GPIO_FE_LTC_NS_HI_CAP) & 0x3fff; 3526 nsec <<= 16; 3527 nsec |= lanphy_read_page_reg(phydev, 4, PTP_GPIO_RE_LTC_NS_LO_CAP); 3528 } 3529 3530 ptp_event.index = 0; 3531 ptp_event.timestamp = ktime_set(sec, nsec); 3532 ptp_event.type = PTP_CLOCK_EXTTS; 3533 ptp_clock_event(shared->ptp_clock, &ptp_event); 3534 3535 return 0; 3536 } 3537 3538 static int lan8814_handle_gpio_interrupt(struct phy_device *phydev, u16 status) 3539 { 3540 struct lan8814_shared_priv *shared = phydev->shared->priv; 3541 int ret; 3542 3543 mutex_lock(&shared->shared_lock); 3544 ret = lan8814_gpio_process_cap(shared); 3545 mutex_unlock(&shared->shared_lock); 3546 3547 return ret; 3548 } 3549 3550 static int lan8804_config_init(struct phy_device *phydev) 3551 { 3552 int val; 3553 3554 /* MDI-X setting for swap A,B transmit */ 3555 val = lanphy_read_page_reg(phydev, 2, LAN8804_ALIGN_SWAP); 3556 val &= ~LAN8804_ALIGN_TX_A_B_SWAP_MASK; 3557 val |= LAN8804_ALIGN_TX_A_B_SWAP; 3558 lanphy_write_page_reg(phydev, 2, LAN8804_ALIGN_SWAP, val); 3559 3560 /* Make sure that the PHY will not stop generating the clock when the 3561 * link partner goes down 3562 */ 3563 lanphy_write_page_reg(phydev, 31, LAN8814_CLOCK_MANAGEMENT, 0x27e); 3564 lanphy_read_page_reg(phydev, 1, LAN8814_LINK_QUALITY); 3565 3566 return 0; 3567 } 3568 3569 static irqreturn_t lan8804_handle_interrupt(struct phy_device *phydev) 3570 { 3571 int status; 3572 3573 status = phy_read(phydev, LAN8814_INTS); 3574 if (status < 0) { 3575 phy_error(phydev); 3576 return IRQ_NONE; 3577 } 3578 3579 if (status > 0) 3580 phy_trigger_machine(phydev); 3581 3582 return IRQ_HANDLED; 3583 } 3584 3585 #define LAN8804_OUTPUT_CONTROL 25 3586 #define LAN8804_OUTPUT_CONTROL_INTR_BUFFER BIT(14) 3587 #define LAN8804_CONTROL 31 3588 #define LAN8804_CONTROL_INTR_POLARITY BIT(14) 3589 3590 static int lan8804_config_intr(struct phy_device *phydev) 3591 { 3592 int err; 3593 3594 /* This is an internal PHY of lan966x and is not possible to change the 3595 * polarity on the GIC found in lan966x, therefore change the polarity 3596 * of the interrupt in the PHY from being active low instead of active 3597 * high. 3598 */ 3599 phy_write(phydev, LAN8804_CONTROL, LAN8804_CONTROL_INTR_POLARITY); 3600 3601 /* By default interrupt buffer is open-drain in which case the interrupt 3602 * can be active only low. Therefore change the interrupt buffer to be 3603 * push-pull to be able to change interrupt polarity 3604 */ 3605 phy_write(phydev, LAN8804_OUTPUT_CONTROL, 3606 LAN8804_OUTPUT_CONTROL_INTR_BUFFER); 3607 3608 if (phydev->interrupts == PHY_INTERRUPT_ENABLED) { 3609 err = phy_read(phydev, LAN8814_INTS); 3610 if (err < 0) 3611 return err; 3612 3613 err = phy_write(phydev, LAN8814_INTC, LAN8814_INT_LINK); 3614 if (err) 3615 return err; 3616 } else { 3617 err = phy_write(phydev, LAN8814_INTC, 0); 3618 if (err) 3619 return err; 3620 3621 err = phy_read(phydev, LAN8814_INTS); 3622 if (err < 0) 3623 return err; 3624 } 3625 3626 return 0; 3627 } 3628 3629 static irqreturn_t lan8814_handle_interrupt(struct phy_device *phydev) 3630 { 3631 int ret = IRQ_NONE; 3632 int irq_status; 3633 3634 irq_status = phy_read(phydev, LAN8814_INTS); 3635 if (irq_status < 0) { 3636 phy_error(phydev); 3637 return IRQ_NONE; 3638 } 3639 3640 if (irq_status & LAN8814_INT_LINK) { 3641 phy_trigger_machine(phydev); 3642 ret = IRQ_HANDLED; 3643 } 3644 3645 while (true) { 3646 irq_status = lanphy_read_page_reg(phydev, 5, PTP_TSU_INT_STS); 3647 if (!irq_status) 3648 break; 3649 3650 lan8814_handle_ptp_interrupt(phydev, irq_status); 3651 ret = IRQ_HANDLED; 3652 } 3653 3654 if (!lan8814_handle_gpio_interrupt(phydev, irq_status)) 3655 ret = IRQ_HANDLED; 3656 3657 return ret; 3658 } 3659 3660 static int lan8814_ack_interrupt(struct phy_device *phydev) 3661 { 3662 /* bit[12..0] int status, which is a read and clear register. */ 3663 int rc; 3664 3665 rc = phy_read(phydev, LAN8814_INTS); 3666 3667 return (rc < 0) ? rc : 0; 3668 } 3669 3670 static int lan8814_config_intr(struct phy_device *phydev) 3671 { 3672 int err; 3673 3674 lanphy_write_page_reg(phydev, 4, LAN8814_INTR_CTRL_REG, 3675 LAN8814_INTR_CTRL_REG_POLARITY | 3676 LAN8814_INTR_CTRL_REG_INTR_ENABLE); 3677 3678 /* enable / disable interrupts */ 3679 if (phydev->interrupts == PHY_INTERRUPT_ENABLED) { 3680 err = lan8814_ack_interrupt(phydev); 3681 if (err) 3682 return err; 3683 3684 err = phy_write(phydev, LAN8814_INTC, LAN8814_INT_LINK); 3685 } else { 3686 err = phy_write(phydev, LAN8814_INTC, 0); 3687 if (err) 3688 return err; 3689 3690 err = lan8814_ack_interrupt(phydev); 3691 } 3692 3693 return err; 3694 } 3695 3696 static void lan8814_ptp_init(struct phy_device *phydev) 3697 { 3698 struct kszphy_priv *priv = phydev->priv; 3699 struct kszphy_ptp_priv *ptp_priv = &priv->ptp_priv; 3700 u32 temp; 3701 3702 if (!IS_ENABLED(CONFIG_PTP_1588_CLOCK) || 3703 !IS_ENABLED(CONFIG_NETWORK_PHY_TIMESTAMPING)) 3704 return; 3705 3706 lanphy_write_page_reg(phydev, 5, TSU_HARD_RESET, TSU_HARD_RESET_); 3707 3708 temp = lanphy_read_page_reg(phydev, 5, PTP_TX_MOD); 3709 temp |= PTP_TX_MOD_BAD_UDPV4_CHKSUM_FORCE_FCS_DIS_; 3710 lanphy_write_page_reg(phydev, 5, PTP_TX_MOD, temp); 3711 3712 temp = lanphy_read_page_reg(phydev, 5, PTP_RX_MOD); 3713 temp |= PTP_RX_MOD_BAD_UDPV4_CHKSUM_FORCE_FCS_DIS_; 3714 lanphy_write_page_reg(phydev, 5, PTP_RX_MOD, temp); 3715 3716 lanphy_write_page_reg(phydev, 5, PTP_RX_PARSE_CONFIG, 0); 3717 lanphy_write_page_reg(phydev, 5, PTP_TX_PARSE_CONFIG, 0); 3718 3719 /* Removing default registers configs related to L2 and IP */ 3720 lanphy_write_page_reg(phydev, 5, PTP_TX_PARSE_L2_ADDR_EN, 0); 3721 lanphy_write_page_reg(phydev, 5, PTP_RX_PARSE_L2_ADDR_EN, 0); 3722 lanphy_write_page_reg(phydev, 5, PTP_TX_PARSE_IP_ADDR_EN, 0); 3723 lanphy_write_page_reg(phydev, 5, PTP_RX_PARSE_IP_ADDR_EN, 0); 3724 3725 /* Disable checking for minorVersionPTP field */ 3726 lanphy_write_page_reg(phydev, 5, PTP_RX_VERSION, 3727 PTP_MAX_VERSION(0xff) | PTP_MIN_VERSION(0x0)); 3728 lanphy_write_page_reg(phydev, 5, PTP_TX_VERSION, 3729 PTP_MAX_VERSION(0xff) | PTP_MIN_VERSION(0x0)); 3730 3731 skb_queue_head_init(&ptp_priv->tx_queue); 3732 skb_queue_head_init(&ptp_priv->rx_queue); 3733 INIT_LIST_HEAD(&ptp_priv->rx_ts_list); 3734 spin_lock_init(&ptp_priv->rx_ts_lock); 3735 3736 ptp_priv->phydev = phydev; 3737 3738 ptp_priv->mii_ts.rxtstamp = lan8814_rxtstamp; 3739 ptp_priv->mii_ts.txtstamp = lan8814_txtstamp; 3740 ptp_priv->mii_ts.hwtstamp = lan8814_hwtstamp; 3741 ptp_priv->mii_ts.ts_info = lan8814_ts_info; 3742 3743 phydev->mii_ts = &ptp_priv->mii_ts; 3744 } 3745 3746 static int lan8814_ptp_probe_once(struct phy_device *phydev) 3747 { 3748 struct lan8814_shared_priv *shared = phydev->shared->priv; 3749 3750 /* Initialise shared lock for clock*/ 3751 mutex_init(&shared->shared_lock); 3752 3753 shared->pin_config = devm_kmalloc_array(&phydev->mdio.dev, 3754 LAN8814_PTP_GPIO_NUM, 3755 sizeof(*shared->pin_config), 3756 GFP_KERNEL); 3757 if (!shared->pin_config) 3758 return -ENOMEM; 3759 3760 for (int i = 0; i < LAN8814_PTP_GPIO_NUM; i++) { 3761 struct ptp_pin_desc *ptp_pin = &shared->pin_config[i]; 3762 3763 memset(ptp_pin, 0, sizeof(*ptp_pin)); 3764 snprintf(ptp_pin->name, 3765 sizeof(ptp_pin->name), "lan8814_ptp_pin_%02d", i); 3766 ptp_pin->index = i; 3767 ptp_pin->func = PTP_PF_NONE; 3768 } 3769 3770 shared->ptp_clock_info.owner = THIS_MODULE; 3771 snprintf(shared->ptp_clock_info.name, 30, "%s", phydev->drv->name); 3772 shared->ptp_clock_info.max_adj = 31249999; 3773 shared->ptp_clock_info.n_alarm = 0; 3774 shared->ptp_clock_info.n_ext_ts = LAN8814_PTP_EXTTS_NUM; 3775 shared->ptp_clock_info.n_pins = LAN8814_PTP_GPIO_NUM; 3776 shared->ptp_clock_info.pps = 0; 3777 shared->ptp_clock_info.pin_config = shared->pin_config; 3778 shared->ptp_clock_info.n_per_out = LAN8814_PTP_PEROUT_NUM; 3779 shared->ptp_clock_info.adjfine = lan8814_ptpci_adjfine; 3780 shared->ptp_clock_info.adjtime = lan8814_ptpci_adjtime; 3781 shared->ptp_clock_info.gettime64 = lan8814_ptpci_gettime64; 3782 shared->ptp_clock_info.settime64 = lan8814_ptpci_settime64; 3783 shared->ptp_clock_info.getcrosststamp = NULL; 3784 shared->ptp_clock_info.enable = lan8814_ptpci_enable; 3785 shared->ptp_clock_info.verify = lan8814_ptpci_verify; 3786 3787 shared->ptp_clock = ptp_clock_register(&shared->ptp_clock_info, 3788 &phydev->mdio.dev); 3789 if (IS_ERR(shared->ptp_clock)) { 3790 phydev_err(phydev, "ptp_clock_register failed %lu\n", 3791 PTR_ERR(shared->ptp_clock)); 3792 return -EINVAL; 3793 } 3794 3795 /* Check if PHC support is missing at the configuration level */ 3796 if (!shared->ptp_clock) 3797 return 0; 3798 3799 phydev_dbg(phydev, "successfully registered ptp clock\n"); 3800 3801 shared->phydev = phydev; 3802 3803 /* The EP.4 is shared between all the PHYs in the package and also it 3804 * can be accessed by any of the PHYs 3805 */ 3806 lanphy_write_page_reg(phydev, 4, LTC_HARD_RESET, LTC_HARD_RESET_); 3807 lanphy_write_page_reg(phydev, 4, PTP_OPERATING_MODE, 3808 PTP_OPERATING_MODE_STANDALONE_); 3809 3810 /* Enable ptp to run LTC clock for ptp and gpio 1PPS operation */ 3811 lanphy_write_page_reg(phydev, 4, PTP_CMD_CTL, PTP_CMD_CTL_PTP_ENABLE_); 3812 3813 return 0; 3814 } 3815 3816 static void lan8814_setup_led(struct phy_device *phydev, int val) 3817 { 3818 int temp; 3819 3820 temp = lanphy_read_page_reg(phydev, 5, LAN8814_LED_CTRL_1); 3821 3822 if (val) 3823 temp |= LAN8814_LED_CTRL_1_KSZ9031_LED_MODE_; 3824 else 3825 temp &= ~LAN8814_LED_CTRL_1_KSZ9031_LED_MODE_; 3826 3827 lanphy_write_page_reg(phydev, 5, LAN8814_LED_CTRL_1, temp); 3828 } 3829 3830 static int lan8814_config_init(struct phy_device *phydev) 3831 { 3832 struct kszphy_priv *lan8814 = phydev->priv; 3833 int val; 3834 3835 /* Reset the PHY */ 3836 val = lanphy_read_page_reg(phydev, 4, LAN8814_QSGMII_SOFT_RESET); 3837 val |= LAN8814_QSGMII_SOFT_RESET_BIT; 3838 lanphy_write_page_reg(phydev, 4, LAN8814_QSGMII_SOFT_RESET, val); 3839 3840 /* Disable ANEG with QSGMII PCS Host side */ 3841 val = lanphy_read_page_reg(phydev, 5, LAN8814_QSGMII_PCS1G_ANEG_CONFIG); 3842 val &= ~LAN8814_QSGMII_PCS1G_ANEG_CONFIG_ANEG_ENA; 3843 lanphy_write_page_reg(phydev, 5, LAN8814_QSGMII_PCS1G_ANEG_CONFIG, val); 3844 3845 /* MDI-X setting for swap A,B transmit */ 3846 val = lanphy_read_page_reg(phydev, 2, LAN8814_ALIGN_SWAP); 3847 val &= ~LAN8814_ALIGN_TX_A_B_SWAP_MASK; 3848 val |= LAN8814_ALIGN_TX_A_B_SWAP; 3849 lanphy_write_page_reg(phydev, 2, LAN8814_ALIGN_SWAP, val); 3850 3851 if (lan8814->led_mode >= 0) 3852 lan8814_setup_led(phydev, lan8814->led_mode); 3853 3854 return 0; 3855 } 3856 3857 /* It is expected that there will not be any 'lan8814_take_coma_mode' 3858 * function called in suspend. Because the GPIO line can be shared, so if one of 3859 * the phys goes back in coma mode, then all the other PHYs will go, which is 3860 * wrong. 3861 */ 3862 static int lan8814_release_coma_mode(struct phy_device *phydev) 3863 { 3864 struct gpio_desc *gpiod; 3865 3866 gpiod = devm_gpiod_get_optional(&phydev->mdio.dev, "coma-mode", 3867 GPIOD_OUT_HIGH_OPEN_DRAIN | 3868 GPIOD_FLAGS_BIT_NONEXCLUSIVE); 3869 if (IS_ERR(gpiod)) 3870 return PTR_ERR(gpiod); 3871 3872 gpiod_set_consumer_name(gpiod, "LAN8814 coma mode"); 3873 gpiod_set_value_cansleep(gpiod, 0); 3874 3875 return 0; 3876 } 3877 3878 static void lan8814_clear_2psp_bit(struct phy_device *phydev) 3879 { 3880 u16 val; 3881 3882 /* It was noticed that when traffic is passing through the PHY and the 3883 * cable is removed then the LED was still one even though there is no 3884 * link 3885 */ 3886 val = lanphy_read_page_reg(phydev, 2, LAN8814_EEE_STATE); 3887 val &= ~LAN8814_EEE_STATE_MASK2P5P; 3888 lanphy_write_page_reg(phydev, 2, LAN8814_EEE_STATE, val); 3889 } 3890 3891 static void lan8814_update_meas_time(struct phy_device *phydev) 3892 { 3893 u16 val; 3894 3895 /* By setting the measure time to a value of 0xb this will allow cables 3896 * longer than 100m to be used. This configuration can be used 3897 * regardless of the mode of operation of the PHY 3898 */ 3899 val = lanphy_read_page_reg(phydev, 1, LAN8814_PD_CONTROLS); 3900 val &= ~LAN8814_PD_CONTROLS_PD_MEAS_TIME_MASK; 3901 val |= LAN8814_PD_CONTROLS_PD_MEAS_TIME_VAL; 3902 lanphy_write_page_reg(phydev, 1, LAN8814_PD_CONTROLS, val); 3903 } 3904 3905 static int lan8814_probe(struct phy_device *phydev) 3906 { 3907 const struct kszphy_type *type = phydev->drv->driver_data; 3908 struct kszphy_priv *priv; 3909 u16 addr; 3910 int err; 3911 3912 priv = devm_kzalloc(&phydev->mdio.dev, sizeof(*priv), GFP_KERNEL); 3913 if (!priv) 3914 return -ENOMEM; 3915 3916 phydev->priv = priv; 3917 3918 priv->type = type; 3919 3920 kszphy_parse_led_mode(phydev); 3921 3922 /* Strap-in value for PHY address, below register read gives starting 3923 * phy address value 3924 */ 3925 addr = lanphy_read_page_reg(phydev, 4, 0) & 0x1F; 3926 devm_phy_package_join(&phydev->mdio.dev, phydev, 3927 addr, sizeof(struct lan8814_shared_priv)); 3928 3929 if (phy_package_init_once(phydev)) { 3930 err = lan8814_release_coma_mode(phydev); 3931 if (err) 3932 return err; 3933 3934 err = lan8814_ptp_probe_once(phydev); 3935 if (err) 3936 return err; 3937 } 3938 3939 lan8814_ptp_init(phydev); 3940 3941 /* Errata workarounds */ 3942 lan8814_clear_2psp_bit(phydev); 3943 lan8814_update_meas_time(phydev); 3944 3945 return 0; 3946 } 3947 3948 #define LAN8841_MMD_TIMER_REG 0 3949 #define LAN8841_MMD0_REGISTER_17 17 3950 #define LAN8841_MMD0_REGISTER_17_DROP_OPT(x) ((x) & 0x3) 3951 #define LAN8841_MMD0_REGISTER_17_XMIT_TOG_TX_DIS BIT(3) 3952 #define LAN8841_OPERATION_MODE_STRAP_OVERRIDE_LOW_REG 2 3953 #define LAN8841_OPERATION_MODE_STRAP_OVERRIDE_LOW_REG_MAGJACK BIT(14) 3954 #define LAN8841_MMD_ANALOG_REG 28 3955 #define LAN8841_ANALOG_CONTROL_1 1 3956 #define LAN8841_ANALOG_CONTROL_1_PLL_TRIM(x) (((x) & 0x3) << 5) 3957 #define LAN8841_ANALOG_CONTROL_10 13 3958 #define LAN8841_ANALOG_CONTROL_10_PLL_DIV(x) ((x) & 0x3) 3959 #define LAN8841_ANALOG_CONTROL_11 14 3960 #define LAN8841_ANALOG_CONTROL_11_LDO_REF(x) (((x) & 0x7) << 12) 3961 #define LAN8841_TX_LOW_I_CH_C_D_POWER_MANAGMENT 69 3962 #define LAN8841_TX_LOW_I_CH_C_D_POWER_MANAGMENT_VAL 0xbffc 3963 #define LAN8841_BTRX_POWER_DOWN 70 3964 #define LAN8841_BTRX_POWER_DOWN_QBIAS_CH_A BIT(0) 3965 #define LAN8841_BTRX_POWER_DOWN_BTRX_CH_A BIT(1) 3966 #define LAN8841_BTRX_POWER_DOWN_QBIAS_CH_B BIT(2) 3967 #define LAN8841_BTRX_POWER_DOWN_BTRX_CH_B BIT(3) 3968 #define LAN8841_BTRX_POWER_DOWN_BTRX_CH_C BIT(5) 3969 #define LAN8841_BTRX_POWER_DOWN_BTRX_CH_D BIT(7) 3970 #define LAN8841_ADC_CHANNEL_MASK 198 3971 #define LAN8841_PTP_RX_PARSE_L2_ADDR_EN 370 3972 #define LAN8841_PTP_RX_PARSE_IP_ADDR_EN 371 3973 #define LAN8841_PTP_RX_VERSION 374 3974 #define LAN8841_PTP_TX_PARSE_L2_ADDR_EN 434 3975 #define LAN8841_PTP_TX_PARSE_IP_ADDR_EN 435 3976 #define LAN8841_PTP_TX_VERSION 438 3977 #define LAN8841_PTP_CMD_CTL 256 3978 #define LAN8841_PTP_CMD_CTL_PTP_ENABLE BIT(2) 3979 #define LAN8841_PTP_CMD_CTL_PTP_DISABLE BIT(1) 3980 #define LAN8841_PTP_CMD_CTL_PTP_RESET BIT(0) 3981 #define LAN8841_PTP_RX_PARSE_CONFIG 368 3982 #define LAN8841_PTP_TX_PARSE_CONFIG 432 3983 #define LAN8841_PTP_RX_MODE 381 3984 #define LAN8841_PTP_INSERT_TS_EN BIT(0) 3985 #define LAN8841_PTP_INSERT_TS_32BIT BIT(1) 3986 3987 static int lan8841_config_init(struct phy_device *phydev) 3988 { 3989 int ret; 3990 3991 ret = ksz9131_config_init(phydev); 3992 if (ret) 3993 return ret; 3994 3995 /* Initialize the HW by resetting everything */ 3996 phy_modify_mmd(phydev, KSZ9131RN_MMD_COMMON_CTRL_REG, 3997 LAN8841_PTP_CMD_CTL, 3998 LAN8841_PTP_CMD_CTL_PTP_RESET, 3999 LAN8841_PTP_CMD_CTL_PTP_RESET); 4000 4001 phy_modify_mmd(phydev, KSZ9131RN_MMD_COMMON_CTRL_REG, 4002 LAN8841_PTP_CMD_CTL, 4003 LAN8841_PTP_CMD_CTL_PTP_ENABLE, 4004 LAN8841_PTP_CMD_CTL_PTP_ENABLE); 4005 4006 /* Don't process any frames */ 4007 phy_write_mmd(phydev, KSZ9131RN_MMD_COMMON_CTRL_REG, 4008 LAN8841_PTP_RX_PARSE_CONFIG, 0); 4009 phy_write_mmd(phydev, KSZ9131RN_MMD_COMMON_CTRL_REG, 4010 LAN8841_PTP_TX_PARSE_CONFIG, 0); 4011 phy_write_mmd(phydev, KSZ9131RN_MMD_COMMON_CTRL_REG, 4012 LAN8841_PTP_TX_PARSE_L2_ADDR_EN, 0); 4013 phy_write_mmd(phydev, KSZ9131RN_MMD_COMMON_CTRL_REG, 4014 LAN8841_PTP_RX_PARSE_L2_ADDR_EN, 0); 4015 phy_write_mmd(phydev, KSZ9131RN_MMD_COMMON_CTRL_REG, 4016 LAN8841_PTP_TX_PARSE_IP_ADDR_EN, 0); 4017 phy_write_mmd(phydev, KSZ9131RN_MMD_COMMON_CTRL_REG, 4018 LAN8841_PTP_RX_PARSE_IP_ADDR_EN, 0); 4019 4020 /* Disable checking for minorVersionPTP field */ 4021 phy_write_mmd(phydev, KSZ9131RN_MMD_COMMON_CTRL_REG, 4022 LAN8841_PTP_RX_VERSION, 0xff00); 4023 phy_write_mmd(phydev, KSZ9131RN_MMD_COMMON_CTRL_REG, 4024 LAN8841_PTP_TX_VERSION, 0xff00); 4025 4026 /* 100BT Clause 40 improvenent errata */ 4027 phy_write_mmd(phydev, LAN8841_MMD_ANALOG_REG, 4028 LAN8841_ANALOG_CONTROL_1, 4029 LAN8841_ANALOG_CONTROL_1_PLL_TRIM(0x2)); 4030 phy_write_mmd(phydev, LAN8841_MMD_ANALOG_REG, 4031 LAN8841_ANALOG_CONTROL_10, 4032 LAN8841_ANALOG_CONTROL_10_PLL_DIV(0x1)); 4033 4034 /* 10M/100M Ethernet Signal Tuning Errata for Shorted-Center Tap 4035 * Magnetics 4036 */ 4037 ret = phy_read_mmd(phydev, KSZ9131RN_MMD_COMMON_CTRL_REG, 4038 LAN8841_OPERATION_MODE_STRAP_OVERRIDE_LOW_REG); 4039 if (ret & LAN8841_OPERATION_MODE_STRAP_OVERRIDE_LOW_REG_MAGJACK) { 4040 phy_write_mmd(phydev, LAN8841_MMD_ANALOG_REG, 4041 LAN8841_TX_LOW_I_CH_C_D_POWER_MANAGMENT, 4042 LAN8841_TX_LOW_I_CH_C_D_POWER_MANAGMENT_VAL); 4043 phy_write_mmd(phydev, LAN8841_MMD_ANALOG_REG, 4044 LAN8841_BTRX_POWER_DOWN, 4045 LAN8841_BTRX_POWER_DOWN_QBIAS_CH_A | 4046 LAN8841_BTRX_POWER_DOWN_BTRX_CH_A | 4047 LAN8841_BTRX_POWER_DOWN_QBIAS_CH_B | 4048 LAN8841_BTRX_POWER_DOWN_BTRX_CH_B | 4049 LAN8841_BTRX_POWER_DOWN_BTRX_CH_C | 4050 LAN8841_BTRX_POWER_DOWN_BTRX_CH_D); 4051 } 4052 4053 /* LDO Adjustment errata */ 4054 phy_write_mmd(phydev, LAN8841_MMD_ANALOG_REG, 4055 LAN8841_ANALOG_CONTROL_11, 4056 LAN8841_ANALOG_CONTROL_11_LDO_REF(1)); 4057 4058 /* 100BT RGMII latency tuning errata */ 4059 phy_write_mmd(phydev, MDIO_MMD_PMAPMD, 4060 LAN8841_ADC_CHANNEL_MASK, 0x0); 4061 phy_write_mmd(phydev, LAN8841_MMD_TIMER_REG, 4062 LAN8841_MMD0_REGISTER_17, 4063 LAN8841_MMD0_REGISTER_17_DROP_OPT(2) | 4064 LAN8841_MMD0_REGISTER_17_XMIT_TOG_TX_DIS); 4065 4066 return 0; 4067 } 4068 4069 #define LAN8841_OUTPUT_CTRL 25 4070 #define LAN8841_OUTPUT_CTRL_INT_BUFFER BIT(14) 4071 #define LAN8841_INT_PTP BIT(9) 4072 4073 static int lan8841_config_intr(struct phy_device *phydev) 4074 { 4075 int err; 4076 4077 phy_modify(phydev, LAN8841_OUTPUT_CTRL, 4078 LAN8841_OUTPUT_CTRL_INT_BUFFER, 0); 4079 4080 if (phydev->interrupts == PHY_INTERRUPT_ENABLED) { 4081 err = phy_read(phydev, LAN8814_INTS); 4082 if (err < 0) 4083 return err; 4084 4085 /* Enable / disable interrupts. It is OK to enable PTP interrupt 4086 * even if it PTP is not enabled. Because the underneath blocks 4087 * will not enable the PTP so we will never get the PTP 4088 * interrupt. 4089 */ 4090 err = phy_write(phydev, LAN8814_INTC, 4091 LAN8814_INT_LINK | LAN8841_INT_PTP); 4092 } else { 4093 err = phy_write(phydev, LAN8814_INTC, 0); 4094 if (err) 4095 return err; 4096 4097 err = phy_read(phydev, LAN8814_INTS); 4098 if (err < 0) 4099 return err; 4100 4101 /* Getting a positive value doesn't mean that is an error, it 4102 * just indicates what was the status. Therefore make sure to 4103 * clear the value and say that there is no error. 4104 */ 4105 err = 0; 4106 } 4107 4108 return err; 4109 } 4110 4111 #define LAN8841_PTP_TX_EGRESS_SEC_LO 453 4112 #define LAN8841_PTP_TX_EGRESS_SEC_HI 452 4113 #define LAN8841_PTP_TX_EGRESS_NS_LO 451 4114 #define LAN8841_PTP_TX_EGRESS_NS_HI 450 4115 #define LAN8841_PTP_TX_EGRESS_NSEC_HI_VALID BIT(15) 4116 #define LAN8841_PTP_TX_MSG_HEADER2 455 4117 4118 static bool lan8841_ptp_get_tx_ts(struct kszphy_ptp_priv *ptp_priv, 4119 u32 *sec, u32 *nsec, u16 *seq) 4120 { 4121 struct phy_device *phydev = ptp_priv->phydev; 4122 4123 *nsec = phy_read_mmd(phydev, 2, LAN8841_PTP_TX_EGRESS_NS_HI); 4124 if (!(*nsec & LAN8841_PTP_TX_EGRESS_NSEC_HI_VALID)) 4125 return false; 4126 4127 *nsec = ((*nsec & 0x3fff) << 16); 4128 *nsec = *nsec | phy_read_mmd(phydev, 2, LAN8841_PTP_TX_EGRESS_NS_LO); 4129 4130 *sec = phy_read_mmd(phydev, 2, LAN8841_PTP_TX_EGRESS_SEC_HI); 4131 *sec = *sec << 16; 4132 *sec = *sec | phy_read_mmd(phydev, 2, LAN8841_PTP_TX_EGRESS_SEC_LO); 4133 4134 *seq = phy_read_mmd(phydev, 2, LAN8841_PTP_TX_MSG_HEADER2); 4135 4136 return true; 4137 } 4138 4139 static void lan8841_ptp_process_tx_ts(struct kszphy_ptp_priv *ptp_priv) 4140 { 4141 u32 sec, nsec; 4142 u16 seq; 4143 4144 while (lan8841_ptp_get_tx_ts(ptp_priv, &sec, &nsec, &seq)) 4145 lan8814_match_tx_skb(ptp_priv, sec, nsec, seq); 4146 } 4147 4148 #define LAN8841_PTP_INT_STS 259 4149 #define LAN8841_PTP_INT_STS_PTP_TX_TS_OVRFL_INT BIT(13) 4150 #define LAN8841_PTP_INT_STS_PTP_TX_TS_INT BIT(12) 4151 #define LAN8841_PTP_INT_STS_PTP_GPIO_CAP_INT BIT(2) 4152 4153 static void lan8841_ptp_flush_fifo(struct kszphy_ptp_priv *ptp_priv) 4154 { 4155 struct phy_device *phydev = ptp_priv->phydev; 4156 int i; 4157 4158 for (i = 0; i < FIFO_SIZE; ++i) 4159 phy_read_mmd(phydev, 2, LAN8841_PTP_TX_MSG_HEADER2); 4160 4161 phy_read_mmd(phydev, 2, LAN8841_PTP_INT_STS); 4162 } 4163 4164 #define LAN8841_PTP_GPIO_CAP_STS 506 4165 #define LAN8841_PTP_GPIO_SEL 327 4166 #define LAN8841_PTP_GPIO_SEL_GPIO_SEL(gpio) ((gpio) << 8) 4167 #define LAN8841_PTP_GPIO_RE_LTC_SEC_HI_CAP 498 4168 #define LAN8841_PTP_GPIO_RE_LTC_SEC_LO_CAP 499 4169 #define LAN8841_PTP_GPIO_RE_LTC_NS_HI_CAP 500 4170 #define LAN8841_PTP_GPIO_RE_LTC_NS_LO_CAP 501 4171 #define LAN8841_PTP_GPIO_FE_LTC_SEC_HI_CAP 502 4172 #define LAN8841_PTP_GPIO_FE_LTC_SEC_LO_CAP 503 4173 #define LAN8841_PTP_GPIO_FE_LTC_NS_HI_CAP 504 4174 #define LAN8841_PTP_GPIO_FE_LTC_NS_LO_CAP 505 4175 4176 static void lan8841_gpio_process_cap(struct kszphy_ptp_priv *ptp_priv) 4177 { 4178 struct phy_device *phydev = ptp_priv->phydev; 4179 struct ptp_clock_event ptp_event = {0}; 4180 int pin, ret, tmp; 4181 s32 sec, nsec; 4182 4183 pin = ptp_find_pin_unlocked(ptp_priv->ptp_clock, PTP_PF_EXTTS, 0); 4184 if (pin == -1) 4185 return; 4186 4187 tmp = phy_read_mmd(phydev, 2, LAN8841_PTP_GPIO_CAP_STS); 4188 if (tmp < 0) 4189 return; 4190 4191 ret = phy_write_mmd(phydev, 2, LAN8841_PTP_GPIO_SEL, 4192 LAN8841_PTP_GPIO_SEL_GPIO_SEL(pin)); 4193 if (ret) 4194 return; 4195 4196 mutex_lock(&ptp_priv->ptp_lock); 4197 if (tmp & BIT(pin)) { 4198 sec = phy_read_mmd(phydev, 2, LAN8841_PTP_GPIO_RE_LTC_SEC_HI_CAP); 4199 sec <<= 16; 4200 sec |= phy_read_mmd(phydev, 2, LAN8841_PTP_GPIO_RE_LTC_SEC_LO_CAP); 4201 4202 nsec = phy_read_mmd(phydev, 2, LAN8841_PTP_GPIO_RE_LTC_NS_HI_CAP) & 0x3fff; 4203 nsec <<= 16; 4204 nsec |= phy_read_mmd(phydev, 2, LAN8841_PTP_GPIO_RE_LTC_NS_LO_CAP); 4205 } else { 4206 sec = phy_read_mmd(phydev, 2, LAN8841_PTP_GPIO_FE_LTC_SEC_HI_CAP); 4207 sec <<= 16; 4208 sec |= phy_read_mmd(phydev, 2, LAN8841_PTP_GPIO_FE_LTC_SEC_LO_CAP); 4209 4210 nsec = phy_read_mmd(phydev, 2, LAN8841_PTP_GPIO_FE_LTC_NS_HI_CAP) & 0x3fff; 4211 nsec <<= 16; 4212 nsec |= phy_read_mmd(phydev, 2, LAN8841_PTP_GPIO_FE_LTC_NS_LO_CAP); 4213 } 4214 mutex_unlock(&ptp_priv->ptp_lock); 4215 ret = phy_write_mmd(phydev, 2, LAN8841_PTP_GPIO_SEL, 0); 4216 if (ret) 4217 return; 4218 4219 ptp_event.index = 0; 4220 ptp_event.timestamp = ktime_set(sec, nsec); 4221 ptp_event.type = PTP_CLOCK_EXTTS; 4222 ptp_clock_event(ptp_priv->ptp_clock, &ptp_event); 4223 } 4224 4225 static void lan8841_handle_ptp_interrupt(struct phy_device *phydev) 4226 { 4227 struct kszphy_priv *priv = phydev->priv; 4228 struct kszphy_ptp_priv *ptp_priv = &priv->ptp_priv; 4229 u16 status; 4230 4231 do { 4232 status = phy_read_mmd(phydev, 2, LAN8841_PTP_INT_STS); 4233 4234 if (status & LAN8841_PTP_INT_STS_PTP_TX_TS_INT) 4235 lan8841_ptp_process_tx_ts(ptp_priv); 4236 4237 if (status & LAN8841_PTP_INT_STS_PTP_GPIO_CAP_INT) 4238 lan8841_gpio_process_cap(ptp_priv); 4239 4240 if (status & LAN8841_PTP_INT_STS_PTP_TX_TS_OVRFL_INT) { 4241 lan8841_ptp_flush_fifo(ptp_priv); 4242 skb_queue_purge(&ptp_priv->tx_queue); 4243 } 4244 4245 } while (status & (LAN8841_PTP_INT_STS_PTP_TX_TS_INT | 4246 LAN8841_PTP_INT_STS_PTP_GPIO_CAP_INT | 4247 LAN8841_PTP_INT_STS_PTP_TX_TS_OVRFL_INT)); 4248 } 4249 4250 #define LAN8841_INTS_PTP BIT(9) 4251 4252 static irqreturn_t lan8841_handle_interrupt(struct phy_device *phydev) 4253 { 4254 irqreturn_t ret = IRQ_NONE; 4255 int irq_status; 4256 4257 irq_status = phy_read(phydev, LAN8814_INTS); 4258 if (irq_status < 0) { 4259 phy_error(phydev); 4260 return IRQ_NONE; 4261 } 4262 4263 if (irq_status & LAN8814_INT_LINK) { 4264 phy_trigger_machine(phydev); 4265 ret = IRQ_HANDLED; 4266 } 4267 4268 if (irq_status & LAN8841_INTS_PTP) { 4269 lan8841_handle_ptp_interrupt(phydev); 4270 ret = IRQ_HANDLED; 4271 } 4272 4273 return ret; 4274 } 4275 4276 static int lan8841_ts_info(struct mii_timestamper *mii_ts, 4277 struct ethtool_ts_info *info) 4278 { 4279 struct kszphy_ptp_priv *ptp_priv; 4280 4281 ptp_priv = container_of(mii_ts, struct kszphy_ptp_priv, mii_ts); 4282 4283 info->phc_index = ptp_priv->ptp_clock ? 4284 ptp_clock_index(ptp_priv->ptp_clock) : -1; 4285 if (info->phc_index == -1) 4286 return 0; 4287 4288 info->so_timestamping = SOF_TIMESTAMPING_TX_HARDWARE | 4289 SOF_TIMESTAMPING_RX_HARDWARE | 4290 SOF_TIMESTAMPING_RAW_HARDWARE; 4291 4292 info->tx_types = (1 << HWTSTAMP_TX_OFF) | 4293 (1 << HWTSTAMP_TX_ON) | 4294 (1 << HWTSTAMP_TX_ONESTEP_SYNC); 4295 4296 info->rx_filters = (1 << HWTSTAMP_FILTER_NONE) | 4297 (1 << HWTSTAMP_FILTER_PTP_V2_L4_EVENT) | 4298 (1 << HWTSTAMP_FILTER_PTP_V2_L2_EVENT) | 4299 (1 << HWTSTAMP_FILTER_PTP_V2_EVENT); 4300 4301 return 0; 4302 } 4303 4304 #define LAN8841_PTP_INT_EN 260 4305 #define LAN8841_PTP_INT_EN_PTP_TX_TS_OVRFL_EN BIT(13) 4306 #define LAN8841_PTP_INT_EN_PTP_TX_TS_EN BIT(12) 4307 4308 static void lan8841_ptp_enable_processing(struct kszphy_ptp_priv *ptp_priv, 4309 bool enable) 4310 { 4311 struct phy_device *phydev = ptp_priv->phydev; 4312 4313 if (enable) { 4314 /* Enable interrupts on the TX side */ 4315 phy_modify_mmd(phydev, 2, LAN8841_PTP_INT_EN, 4316 LAN8841_PTP_INT_EN_PTP_TX_TS_OVRFL_EN | 4317 LAN8841_PTP_INT_EN_PTP_TX_TS_EN, 4318 LAN8841_PTP_INT_EN_PTP_TX_TS_OVRFL_EN | 4319 LAN8841_PTP_INT_EN_PTP_TX_TS_EN); 4320 4321 /* Enable the modification of the frame on RX side, 4322 * this will add the ns and 2 bits of sec in the reserved field 4323 * of the PTP header 4324 */ 4325 phy_modify_mmd(phydev, KSZ9131RN_MMD_COMMON_CTRL_REG, 4326 LAN8841_PTP_RX_MODE, 4327 LAN8841_PTP_INSERT_TS_EN | 4328 LAN8841_PTP_INSERT_TS_32BIT, 4329 LAN8841_PTP_INSERT_TS_EN | 4330 LAN8841_PTP_INSERT_TS_32BIT); 4331 4332 ptp_schedule_worker(ptp_priv->ptp_clock, 0); 4333 } else { 4334 /* Disable interrupts on the TX side */ 4335 phy_modify_mmd(phydev, 2, LAN8841_PTP_INT_EN, 4336 LAN8841_PTP_INT_EN_PTP_TX_TS_OVRFL_EN | 4337 LAN8841_PTP_INT_EN_PTP_TX_TS_EN, 0); 4338 4339 /* Disable modification of the RX frames */ 4340 phy_modify_mmd(phydev, KSZ9131RN_MMD_COMMON_CTRL_REG, 4341 LAN8841_PTP_RX_MODE, 4342 LAN8841_PTP_INSERT_TS_EN | 4343 LAN8841_PTP_INSERT_TS_32BIT, 0); 4344 4345 ptp_cancel_worker_sync(ptp_priv->ptp_clock); 4346 } 4347 } 4348 4349 #define LAN8841_PTP_RX_TIMESTAMP_EN 379 4350 #define LAN8841_PTP_TX_TIMESTAMP_EN 443 4351 #define LAN8841_PTP_TX_MOD 445 4352 4353 static int lan8841_hwtstamp(struct mii_timestamper *mii_ts, 4354 struct kernel_hwtstamp_config *config, 4355 struct netlink_ext_ack *extack) 4356 { 4357 struct kszphy_ptp_priv *ptp_priv = container_of(mii_ts, struct kszphy_ptp_priv, mii_ts); 4358 struct phy_device *phydev = ptp_priv->phydev; 4359 int txcfg = 0, rxcfg = 0; 4360 int pkt_ts_enable; 4361 4362 ptp_priv->hwts_tx_type = config->tx_type; 4363 ptp_priv->rx_filter = config->rx_filter; 4364 4365 switch (config->rx_filter) { 4366 case HWTSTAMP_FILTER_NONE: 4367 ptp_priv->layer = 0; 4368 ptp_priv->version = 0; 4369 break; 4370 case HWTSTAMP_FILTER_PTP_V2_L4_EVENT: 4371 case HWTSTAMP_FILTER_PTP_V2_L4_SYNC: 4372 case HWTSTAMP_FILTER_PTP_V2_L4_DELAY_REQ: 4373 ptp_priv->layer = PTP_CLASS_L4; 4374 ptp_priv->version = PTP_CLASS_V2; 4375 break; 4376 case HWTSTAMP_FILTER_PTP_V2_L2_EVENT: 4377 case HWTSTAMP_FILTER_PTP_V2_L2_SYNC: 4378 case HWTSTAMP_FILTER_PTP_V2_L2_DELAY_REQ: 4379 ptp_priv->layer = PTP_CLASS_L2; 4380 ptp_priv->version = PTP_CLASS_V2; 4381 break; 4382 case HWTSTAMP_FILTER_PTP_V2_EVENT: 4383 case HWTSTAMP_FILTER_PTP_V2_SYNC: 4384 case HWTSTAMP_FILTER_PTP_V2_DELAY_REQ: 4385 ptp_priv->layer = PTP_CLASS_L4 | PTP_CLASS_L2; 4386 ptp_priv->version = PTP_CLASS_V2; 4387 break; 4388 default: 4389 return -ERANGE; 4390 } 4391 4392 /* Setup parsing of the frames and enable the timestamping for ptp 4393 * frames 4394 */ 4395 if (ptp_priv->layer & PTP_CLASS_L2) { 4396 rxcfg |= PTP_RX_PARSE_CONFIG_LAYER2_EN_; 4397 txcfg |= PTP_TX_PARSE_CONFIG_LAYER2_EN_; 4398 } else if (ptp_priv->layer & PTP_CLASS_L4) { 4399 rxcfg |= PTP_RX_PARSE_CONFIG_IPV4_EN_ | PTP_RX_PARSE_CONFIG_IPV6_EN_; 4400 txcfg |= PTP_TX_PARSE_CONFIG_IPV4_EN_ | PTP_TX_PARSE_CONFIG_IPV6_EN_; 4401 } 4402 4403 phy_write_mmd(phydev, 2, LAN8841_PTP_RX_PARSE_CONFIG, rxcfg); 4404 phy_write_mmd(phydev, 2, LAN8841_PTP_TX_PARSE_CONFIG, txcfg); 4405 4406 pkt_ts_enable = PTP_TIMESTAMP_EN_SYNC_ | PTP_TIMESTAMP_EN_DREQ_ | 4407 PTP_TIMESTAMP_EN_PDREQ_ | PTP_TIMESTAMP_EN_PDRES_; 4408 phy_write_mmd(phydev, 2, LAN8841_PTP_RX_TIMESTAMP_EN, pkt_ts_enable); 4409 phy_write_mmd(phydev, 2, LAN8841_PTP_TX_TIMESTAMP_EN, pkt_ts_enable); 4410 4411 /* Enable / disable of the TX timestamp in the SYNC frames */ 4412 phy_modify_mmd(phydev, 2, LAN8841_PTP_TX_MOD, 4413 PTP_TX_MOD_TX_PTP_SYNC_TS_INSERT_, 4414 ptp_priv->hwts_tx_type == HWTSTAMP_TX_ONESTEP_SYNC ? 4415 PTP_TX_MOD_TX_PTP_SYNC_TS_INSERT_ : 0); 4416 4417 /* Now enable/disable the timestamping */ 4418 lan8841_ptp_enable_processing(ptp_priv, 4419 config->rx_filter != HWTSTAMP_FILTER_NONE); 4420 4421 skb_queue_purge(&ptp_priv->tx_queue); 4422 4423 lan8841_ptp_flush_fifo(ptp_priv); 4424 4425 return 0; 4426 } 4427 4428 static bool lan8841_rxtstamp(struct mii_timestamper *mii_ts, 4429 struct sk_buff *skb, int type) 4430 { 4431 struct kszphy_ptp_priv *ptp_priv = 4432 container_of(mii_ts, struct kszphy_ptp_priv, mii_ts); 4433 struct ptp_header *header = ptp_parse_header(skb, type); 4434 struct skb_shared_hwtstamps *shhwtstamps; 4435 struct timespec64 ts; 4436 unsigned long flags; 4437 u32 ts_header; 4438 4439 if (!header) 4440 return false; 4441 4442 if (ptp_priv->rx_filter == HWTSTAMP_FILTER_NONE || 4443 type == PTP_CLASS_NONE) 4444 return false; 4445 4446 if ((type & ptp_priv->version) == 0 || (type & ptp_priv->layer) == 0) 4447 return false; 4448 4449 spin_lock_irqsave(&ptp_priv->seconds_lock, flags); 4450 ts.tv_sec = ptp_priv->seconds; 4451 spin_unlock_irqrestore(&ptp_priv->seconds_lock, flags); 4452 ts_header = __be32_to_cpu(header->reserved2); 4453 4454 shhwtstamps = skb_hwtstamps(skb); 4455 memset(shhwtstamps, 0, sizeof(*shhwtstamps)); 4456 4457 /* Check for any wrap arounds for the second part */ 4458 if ((ts.tv_sec & GENMASK(1, 0)) == 0 && (ts_header >> 30) == 3) 4459 ts.tv_sec -= GENMASK(1, 0) + 1; 4460 else if ((ts.tv_sec & GENMASK(1, 0)) == 3 && (ts_header >> 30) == 0) 4461 ts.tv_sec += 1; 4462 4463 shhwtstamps->hwtstamp = 4464 ktime_set((ts.tv_sec & ~(GENMASK(1, 0))) | ts_header >> 30, 4465 ts_header & GENMASK(29, 0)); 4466 header->reserved2 = 0; 4467 4468 netif_rx(skb); 4469 4470 return true; 4471 } 4472 4473 #define LAN8841_EVENT_A 0 4474 #define LAN8841_EVENT_B 1 4475 #define LAN8841_PTP_LTC_TARGET_SEC_HI(event) ((event) == LAN8841_EVENT_A ? 278 : 288) 4476 #define LAN8841_PTP_LTC_TARGET_SEC_LO(event) ((event) == LAN8841_EVENT_A ? 279 : 289) 4477 #define LAN8841_PTP_LTC_TARGET_NS_HI(event) ((event) == LAN8841_EVENT_A ? 280 : 290) 4478 #define LAN8841_PTP_LTC_TARGET_NS_LO(event) ((event) == LAN8841_EVENT_A ? 281 : 291) 4479 4480 static int lan8841_ptp_set_target(struct kszphy_ptp_priv *ptp_priv, u8 event, 4481 s64 sec, u32 nsec) 4482 { 4483 struct phy_device *phydev = ptp_priv->phydev; 4484 int ret; 4485 4486 ret = phy_write_mmd(phydev, 2, LAN8841_PTP_LTC_TARGET_SEC_HI(event), 4487 upper_16_bits(sec)); 4488 if (ret) 4489 return ret; 4490 4491 ret = phy_write_mmd(phydev, 2, LAN8841_PTP_LTC_TARGET_SEC_LO(event), 4492 lower_16_bits(sec)); 4493 if (ret) 4494 return ret; 4495 4496 ret = phy_write_mmd(phydev, 2, LAN8841_PTP_LTC_TARGET_NS_HI(event) & 0x3fff, 4497 upper_16_bits(nsec)); 4498 if (ret) 4499 return ret; 4500 4501 return phy_write_mmd(phydev, 2, LAN8841_PTP_LTC_TARGET_NS_LO(event), 4502 lower_16_bits(nsec)); 4503 } 4504 4505 #define LAN8841_BUFFER_TIME 2 4506 4507 static int lan8841_ptp_update_target(struct kszphy_ptp_priv *ptp_priv, 4508 const struct timespec64 *ts) 4509 { 4510 return lan8841_ptp_set_target(ptp_priv, LAN8841_EVENT_A, 4511 ts->tv_sec + LAN8841_BUFFER_TIME, 0); 4512 } 4513 4514 #define LAN8841_PTP_LTC_TARGET_RELOAD_SEC_HI(event) ((event) == LAN8841_EVENT_A ? 282 : 292) 4515 #define LAN8841_PTP_LTC_TARGET_RELOAD_SEC_LO(event) ((event) == LAN8841_EVENT_A ? 283 : 293) 4516 #define LAN8841_PTP_LTC_TARGET_RELOAD_NS_HI(event) ((event) == LAN8841_EVENT_A ? 284 : 294) 4517 #define LAN8841_PTP_LTC_TARGET_RELOAD_NS_LO(event) ((event) == LAN8841_EVENT_A ? 285 : 295) 4518 4519 static int lan8841_ptp_set_reload(struct kszphy_ptp_priv *ptp_priv, u8 event, 4520 s64 sec, u32 nsec) 4521 { 4522 struct phy_device *phydev = ptp_priv->phydev; 4523 int ret; 4524 4525 ret = phy_write_mmd(phydev, 2, LAN8841_PTP_LTC_TARGET_RELOAD_SEC_HI(event), 4526 upper_16_bits(sec)); 4527 if (ret) 4528 return ret; 4529 4530 ret = phy_write_mmd(phydev, 2, LAN8841_PTP_LTC_TARGET_RELOAD_SEC_LO(event), 4531 lower_16_bits(sec)); 4532 if (ret) 4533 return ret; 4534 4535 ret = phy_write_mmd(phydev, 2, LAN8841_PTP_LTC_TARGET_RELOAD_NS_HI(event) & 0x3fff, 4536 upper_16_bits(nsec)); 4537 if (ret) 4538 return ret; 4539 4540 return phy_write_mmd(phydev, 2, LAN8841_PTP_LTC_TARGET_RELOAD_NS_LO(event), 4541 lower_16_bits(nsec)); 4542 } 4543 4544 #define LAN8841_PTP_LTC_SET_SEC_HI 262 4545 #define LAN8841_PTP_LTC_SET_SEC_MID 263 4546 #define LAN8841_PTP_LTC_SET_SEC_LO 264 4547 #define LAN8841_PTP_LTC_SET_NS_HI 265 4548 #define LAN8841_PTP_LTC_SET_NS_LO 266 4549 #define LAN8841_PTP_CMD_CTL_PTP_LTC_LOAD BIT(4) 4550 4551 static int lan8841_ptp_settime64(struct ptp_clock_info *ptp, 4552 const struct timespec64 *ts) 4553 { 4554 struct kszphy_ptp_priv *ptp_priv = container_of(ptp, struct kszphy_ptp_priv, 4555 ptp_clock_info); 4556 struct phy_device *phydev = ptp_priv->phydev; 4557 unsigned long flags; 4558 int ret; 4559 4560 /* Set the value to be stored */ 4561 mutex_lock(&ptp_priv->ptp_lock); 4562 phy_write_mmd(phydev, 2, LAN8841_PTP_LTC_SET_SEC_LO, lower_16_bits(ts->tv_sec)); 4563 phy_write_mmd(phydev, 2, LAN8841_PTP_LTC_SET_SEC_MID, upper_16_bits(ts->tv_sec)); 4564 phy_write_mmd(phydev, 2, LAN8841_PTP_LTC_SET_SEC_HI, upper_32_bits(ts->tv_sec) & 0xffff); 4565 phy_write_mmd(phydev, 2, LAN8841_PTP_LTC_SET_NS_LO, lower_16_bits(ts->tv_nsec)); 4566 phy_write_mmd(phydev, 2, LAN8841_PTP_LTC_SET_NS_HI, upper_16_bits(ts->tv_nsec) & 0x3fff); 4567 4568 /* Set the command to load the LTC */ 4569 phy_write_mmd(phydev, 2, LAN8841_PTP_CMD_CTL, 4570 LAN8841_PTP_CMD_CTL_PTP_LTC_LOAD); 4571 ret = lan8841_ptp_update_target(ptp_priv, ts); 4572 mutex_unlock(&ptp_priv->ptp_lock); 4573 4574 spin_lock_irqsave(&ptp_priv->seconds_lock, flags); 4575 ptp_priv->seconds = ts->tv_sec; 4576 spin_unlock_irqrestore(&ptp_priv->seconds_lock, flags); 4577 4578 return ret; 4579 } 4580 4581 #define LAN8841_PTP_LTC_RD_SEC_HI 358 4582 #define LAN8841_PTP_LTC_RD_SEC_MID 359 4583 #define LAN8841_PTP_LTC_RD_SEC_LO 360 4584 #define LAN8841_PTP_LTC_RD_NS_HI 361 4585 #define LAN8841_PTP_LTC_RD_NS_LO 362 4586 #define LAN8841_PTP_CMD_CTL_PTP_LTC_READ BIT(3) 4587 4588 static int lan8841_ptp_gettime64(struct ptp_clock_info *ptp, 4589 struct timespec64 *ts) 4590 { 4591 struct kszphy_ptp_priv *ptp_priv = container_of(ptp, struct kszphy_ptp_priv, 4592 ptp_clock_info); 4593 struct phy_device *phydev = ptp_priv->phydev; 4594 time64_t s; 4595 s64 ns; 4596 4597 mutex_lock(&ptp_priv->ptp_lock); 4598 /* Issue the command to read the LTC */ 4599 phy_write_mmd(phydev, 2, LAN8841_PTP_CMD_CTL, 4600 LAN8841_PTP_CMD_CTL_PTP_LTC_READ); 4601 4602 /* Read the LTC */ 4603 s = phy_read_mmd(phydev, 2, LAN8841_PTP_LTC_RD_SEC_HI); 4604 s <<= 16; 4605 s |= phy_read_mmd(phydev, 2, LAN8841_PTP_LTC_RD_SEC_MID); 4606 s <<= 16; 4607 s |= phy_read_mmd(phydev, 2, LAN8841_PTP_LTC_RD_SEC_LO); 4608 4609 ns = phy_read_mmd(phydev, 2, LAN8841_PTP_LTC_RD_NS_HI) & 0x3fff; 4610 ns <<= 16; 4611 ns |= phy_read_mmd(phydev, 2, LAN8841_PTP_LTC_RD_NS_LO); 4612 mutex_unlock(&ptp_priv->ptp_lock); 4613 4614 set_normalized_timespec64(ts, s, ns); 4615 return 0; 4616 } 4617 4618 static void lan8841_ptp_getseconds(struct ptp_clock_info *ptp, 4619 struct timespec64 *ts) 4620 { 4621 struct kszphy_ptp_priv *ptp_priv = container_of(ptp, struct kszphy_ptp_priv, 4622 ptp_clock_info); 4623 struct phy_device *phydev = ptp_priv->phydev; 4624 time64_t s; 4625 4626 mutex_lock(&ptp_priv->ptp_lock); 4627 /* Issue the command to read the LTC */ 4628 phy_write_mmd(phydev, 2, LAN8841_PTP_CMD_CTL, 4629 LAN8841_PTP_CMD_CTL_PTP_LTC_READ); 4630 4631 /* Read the LTC */ 4632 s = phy_read_mmd(phydev, 2, LAN8841_PTP_LTC_RD_SEC_HI); 4633 s <<= 16; 4634 s |= phy_read_mmd(phydev, 2, LAN8841_PTP_LTC_RD_SEC_MID); 4635 s <<= 16; 4636 s |= phy_read_mmd(phydev, 2, LAN8841_PTP_LTC_RD_SEC_LO); 4637 mutex_unlock(&ptp_priv->ptp_lock); 4638 4639 set_normalized_timespec64(ts, s, 0); 4640 } 4641 4642 #define LAN8841_PTP_LTC_STEP_ADJ_LO 276 4643 #define LAN8841_PTP_LTC_STEP_ADJ_HI 275 4644 #define LAN8841_PTP_LTC_STEP_ADJ_DIR BIT(15) 4645 #define LAN8841_PTP_CMD_CTL_PTP_LTC_STEP_SECONDS BIT(5) 4646 #define LAN8841_PTP_CMD_CTL_PTP_LTC_STEP_NANOSECONDS BIT(6) 4647 4648 static int lan8841_ptp_adjtime(struct ptp_clock_info *ptp, s64 delta) 4649 { 4650 struct kszphy_ptp_priv *ptp_priv = container_of(ptp, struct kszphy_ptp_priv, 4651 ptp_clock_info); 4652 struct phy_device *phydev = ptp_priv->phydev; 4653 struct timespec64 ts; 4654 bool add = true; 4655 u32 nsec; 4656 s32 sec; 4657 int ret; 4658 4659 /* The HW allows up to 15 sec to adjust the time, but here we limit to 4660 * 10 sec the adjustment. The reason is, in case the adjustment is 14 4661 * sec and 999999999 nsec, then we add 8ns to compansate the actual 4662 * increment so the value can be bigger than 15 sec. Therefore limit the 4663 * possible adjustments so we will not have these corner cases 4664 */ 4665 if (delta > 10000000000LL || delta < -10000000000LL) { 4666 /* The timeadjustment is too big, so fall back using set time */ 4667 u64 now; 4668 4669 ptp->gettime64(ptp, &ts); 4670 4671 now = ktime_to_ns(timespec64_to_ktime(ts)); 4672 ts = ns_to_timespec64(now + delta); 4673 4674 ptp->settime64(ptp, &ts); 4675 return 0; 4676 } 4677 4678 sec = div_u64_rem(delta < 0 ? -delta : delta, NSEC_PER_SEC, &nsec); 4679 if (delta < 0 && nsec != 0) { 4680 /* It is not allowed to adjust low the nsec part, therefore 4681 * subtract more from second part and add to nanosecond such 4682 * that would roll over, so the second part will increase 4683 */ 4684 sec--; 4685 nsec = NSEC_PER_SEC - nsec; 4686 } 4687 4688 /* Calculate the adjustments and the direction */ 4689 if (delta < 0) 4690 add = false; 4691 4692 if (nsec > 0) 4693 /* add 8 ns to cover the likely normal increment */ 4694 nsec += 8; 4695 4696 if (nsec >= NSEC_PER_SEC) { 4697 /* carry into seconds */ 4698 sec++; 4699 nsec -= NSEC_PER_SEC; 4700 } 4701 4702 mutex_lock(&ptp_priv->ptp_lock); 4703 if (sec) { 4704 phy_write_mmd(phydev, 2, LAN8841_PTP_LTC_STEP_ADJ_LO, sec); 4705 phy_write_mmd(phydev, 2, LAN8841_PTP_LTC_STEP_ADJ_HI, 4706 add ? LAN8841_PTP_LTC_STEP_ADJ_DIR : 0); 4707 phy_write_mmd(phydev, 2, LAN8841_PTP_CMD_CTL, 4708 LAN8841_PTP_CMD_CTL_PTP_LTC_STEP_SECONDS); 4709 } 4710 4711 if (nsec) { 4712 phy_write_mmd(phydev, 2, LAN8841_PTP_LTC_STEP_ADJ_LO, 4713 nsec & 0xffff); 4714 phy_write_mmd(phydev, 2, LAN8841_PTP_LTC_STEP_ADJ_HI, 4715 (nsec >> 16) & 0x3fff); 4716 phy_write_mmd(phydev, 2, LAN8841_PTP_CMD_CTL, 4717 LAN8841_PTP_CMD_CTL_PTP_LTC_STEP_NANOSECONDS); 4718 } 4719 mutex_unlock(&ptp_priv->ptp_lock); 4720 4721 /* Update the target clock */ 4722 ptp->gettime64(ptp, &ts); 4723 mutex_lock(&ptp_priv->ptp_lock); 4724 ret = lan8841_ptp_update_target(ptp_priv, &ts); 4725 mutex_unlock(&ptp_priv->ptp_lock); 4726 4727 return ret; 4728 } 4729 4730 #define LAN8841_PTP_LTC_RATE_ADJ_HI 269 4731 #define LAN8841_PTP_LTC_RATE_ADJ_HI_DIR BIT(15) 4732 #define LAN8841_PTP_LTC_RATE_ADJ_LO 270 4733 4734 static int lan8841_ptp_adjfine(struct ptp_clock_info *ptp, long scaled_ppm) 4735 { 4736 struct kszphy_ptp_priv *ptp_priv = container_of(ptp, struct kszphy_ptp_priv, 4737 ptp_clock_info); 4738 struct phy_device *phydev = ptp_priv->phydev; 4739 bool faster = true; 4740 u32 rate; 4741 4742 if (!scaled_ppm) 4743 return 0; 4744 4745 if (scaled_ppm < 0) { 4746 scaled_ppm = -scaled_ppm; 4747 faster = false; 4748 } 4749 4750 rate = LAN8841_1PPM_FORMAT * (upper_16_bits(scaled_ppm)); 4751 rate += (LAN8841_1PPM_FORMAT * (lower_16_bits(scaled_ppm))) >> 16; 4752 4753 mutex_lock(&ptp_priv->ptp_lock); 4754 phy_write_mmd(phydev, 2, LAN8841_PTP_LTC_RATE_ADJ_HI, 4755 faster ? LAN8841_PTP_LTC_RATE_ADJ_HI_DIR | (upper_16_bits(rate) & 0x3fff) 4756 : upper_16_bits(rate) & 0x3fff); 4757 phy_write_mmd(phydev, 2, LAN8841_PTP_LTC_RATE_ADJ_LO, lower_16_bits(rate)); 4758 mutex_unlock(&ptp_priv->ptp_lock); 4759 4760 return 0; 4761 } 4762 4763 static int lan8841_ptp_verify(struct ptp_clock_info *ptp, unsigned int pin, 4764 enum ptp_pin_function func, unsigned int chan) 4765 { 4766 switch (func) { 4767 case PTP_PF_NONE: 4768 case PTP_PF_PEROUT: 4769 case PTP_PF_EXTTS: 4770 break; 4771 default: 4772 return -1; 4773 } 4774 4775 return 0; 4776 } 4777 4778 #define LAN8841_PTP_GPIO_NUM 10 4779 #define LAN8841_GPIO_EN 128 4780 #define LAN8841_GPIO_DIR 129 4781 #define LAN8841_GPIO_BUF 130 4782 4783 static int lan8841_ptp_perout_off(struct kszphy_ptp_priv *ptp_priv, int pin) 4784 { 4785 struct phy_device *phydev = ptp_priv->phydev; 4786 int ret; 4787 4788 ret = phy_clear_bits_mmd(phydev, 2, LAN8841_GPIO_EN, BIT(pin)); 4789 if (ret) 4790 return ret; 4791 4792 ret = phy_clear_bits_mmd(phydev, 2, LAN8841_GPIO_DIR, BIT(pin)); 4793 if (ret) 4794 return ret; 4795 4796 return phy_clear_bits_mmd(phydev, 2, LAN8841_GPIO_BUF, BIT(pin)); 4797 } 4798 4799 static int lan8841_ptp_perout_on(struct kszphy_ptp_priv *ptp_priv, int pin) 4800 { 4801 struct phy_device *phydev = ptp_priv->phydev; 4802 int ret; 4803 4804 ret = phy_set_bits_mmd(phydev, 2, LAN8841_GPIO_EN, BIT(pin)); 4805 if (ret) 4806 return ret; 4807 4808 ret = phy_set_bits_mmd(phydev, 2, LAN8841_GPIO_DIR, BIT(pin)); 4809 if (ret) 4810 return ret; 4811 4812 return phy_set_bits_mmd(phydev, 2, LAN8841_GPIO_BUF, BIT(pin)); 4813 } 4814 4815 #define LAN8841_GPIO_DATA_SEL1 131 4816 #define LAN8841_GPIO_DATA_SEL2 132 4817 #define LAN8841_GPIO_DATA_SEL_GPIO_DATA_SEL_EVENT_MASK GENMASK(2, 0) 4818 #define LAN8841_GPIO_DATA_SEL_GPIO_DATA_SEL_EVENT_A 1 4819 #define LAN8841_GPIO_DATA_SEL_GPIO_DATA_SEL_EVENT_B 2 4820 #define LAN8841_PTP_GENERAL_CONFIG 257 4821 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_POL_A BIT(1) 4822 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_POL_B BIT(3) 4823 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_A_MASK GENMASK(7, 4) 4824 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_B_MASK GENMASK(11, 8) 4825 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_A 4 4826 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_B 7 4827 4828 static int lan8841_ptp_remove_event(struct kszphy_ptp_priv *ptp_priv, int pin, 4829 u8 event) 4830 { 4831 struct phy_device *phydev = ptp_priv->phydev; 4832 u16 tmp; 4833 int ret; 4834 4835 /* Now remove pin from the event. GPIO_DATA_SEL1 contains the GPIO 4836 * pins 0-4 while GPIO_DATA_SEL2 contains GPIO pins 5-9, therefore 4837 * depending on the pin, it requires to read a different register 4838 */ 4839 if (pin < 5) { 4840 tmp = LAN8841_GPIO_DATA_SEL_GPIO_DATA_SEL_EVENT_MASK << (3 * pin); 4841 ret = phy_clear_bits_mmd(phydev, 2, LAN8841_GPIO_DATA_SEL1, tmp); 4842 } else { 4843 tmp = LAN8841_GPIO_DATA_SEL_GPIO_DATA_SEL_EVENT_MASK << (3 * (pin - 5)); 4844 ret = phy_clear_bits_mmd(phydev, 2, LAN8841_GPIO_DATA_SEL2, tmp); 4845 } 4846 if (ret) 4847 return ret; 4848 4849 /* Disable the event */ 4850 if (event == LAN8841_EVENT_A) 4851 tmp = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_POL_A | 4852 LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_A_MASK; 4853 else 4854 tmp = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_POL_B | 4855 LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_B_MASK; 4856 return phy_clear_bits_mmd(phydev, 2, LAN8841_GPIO_EN, tmp); 4857 } 4858 4859 static int lan8841_ptp_enable_event(struct kszphy_ptp_priv *ptp_priv, int pin, 4860 u8 event, int pulse_width) 4861 { 4862 struct phy_device *phydev = ptp_priv->phydev; 4863 u16 tmp; 4864 int ret; 4865 4866 /* Enable the event */ 4867 if (event == LAN8841_EVENT_A) 4868 ret = phy_modify_mmd(phydev, 2, LAN8841_PTP_GENERAL_CONFIG, 4869 LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_POL_A | 4870 LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_A_MASK, 4871 LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_POL_A | 4872 pulse_width << LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_A); 4873 else 4874 ret = phy_modify_mmd(phydev, 2, LAN8841_PTP_GENERAL_CONFIG, 4875 LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_POL_B | 4876 LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_B_MASK, 4877 LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_POL_B | 4878 pulse_width << LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_B); 4879 if (ret) 4880 return ret; 4881 4882 /* Now connect the pin to the event. GPIO_DATA_SEL1 contains the GPIO 4883 * pins 0-4 while GPIO_DATA_SEL2 contains GPIO pins 5-9, therefore 4884 * depending on the pin, it requires to read a different register 4885 */ 4886 if (event == LAN8841_EVENT_A) 4887 tmp = LAN8841_GPIO_DATA_SEL_GPIO_DATA_SEL_EVENT_A; 4888 else 4889 tmp = LAN8841_GPIO_DATA_SEL_GPIO_DATA_SEL_EVENT_B; 4890 4891 if (pin < 5) 4892 ret = phy_set_bits_mmd(phydev, 2, LAN8841_GPIO_DATA_SEL1, 4893 tmp << (3 * pin)); 4894 else 4895 ret = phy_set_bits_mmd(phydev, 2, LAN8841_GPIO_DATA_SEL2, 4896 tmp << (3 * (pin - 5))); 4897 4898 return ret; 4899 } 4900 4901 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_200MS 13 4902 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_100MS 12 4903 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_50MS 11 4904 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_10MS 10 4905 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_5MS 9 4906 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_1MS 8 4907 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_500US 7 4908 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_100US 6 4909 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_50US 5 4910 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_10US 4 4911 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_5US 3 4912 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_1US 2 4913 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_500NS 1 4914 #define LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_100NS 0 4915 4916 static int lan8841_ptp_perout(struct ptp_clock_info *ptp, 4917 struct ptp_clock_request *rq, int on) 4918 { 4919 struct kszphy_ptp_priv *ptp_priv = container_of(ptp, struct kszphy_ptp_priv, 4920 ptp_clock_info); 4921 struct phy_device *phydev = ptp_priv->phydev; 4922 struct timespec64 ts_on, ts_period; 4923 s64 on_nsec, period_nsec; 4924 int pulse_width; 4925 int pin; 4926 int ret; 4927 4928 if (rq->perout.flags & ~PTP_PEROUT_DUTY_CYCLE) 4929 return -EOPNOTSUPP; 4930 4931 pin = ptp_find_pin(ptp_priv->ptp_clock, PTP_PF_PEROUT, rq->perout.index); 4932 if (pin == -1 || pin >= LAN8841_PTP_GPIO_NUM) 4933 return -EINVAL; 4934 4935 if (!on) { 4936 ret = lan8841_ptp_perout_off(ptp_priv, pin); 4937 if (ret) 4938 return ret; 4939 4940 return lan8841_ptp_remove_event(ptp_priv, LAN8841_EVENT_A, pin); 4941 } 4942 4943 ts_on.tv_sec = rq->perout.on.sec; 4944 ts_on.tv_nsec = rq->perout.on.nsec; 4945 on_nsec = timespec64_to_ns(&ts_on); 4946 4947 ts_period.tv_sec = rq->perout.period.sec; 4948 ts_period.tv_nsec = rq->perout.period.nsec; 4949 period_nsec = timespec64_to_ns(&ts_period); 4950 4951 if (period_nsec < 200) { 4952 pr_warn_ratelimited("%s: perout period too small, minimum is 200 nsec\n", 4953 phydev_name(phydev)); 4954 return -EOPNOTSUPP; 4955 } 4956 4957 if (on_nsec >= period_nsec) { 4958 pr_warn_ratelimited("%s: pulse width must be smaller than period\n", 4959 phydev_name(phydev)); 4960 return -EINVAL; 4961 } 4962 4963 switch (on_nsec) { 4964 case 200000000: 4965 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_200MS; 4966 break; 4967 case 100000000: 4968 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_100MS; 4969 break; 4970 case 50000000: 4971 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_50MS; 4972 break; 4973 case 10000000: 4974 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_10MS; 4975 break; 4976 case 5000000: 4977 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_5MS; 4978 break; 4979 case 1000000: 4980 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_1MS; 4981 break; 4982 case 500000: 4983 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_500US; 4984 break; 4985 case 100000: 4986 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_100US; 4987 break; 4988 case 50000: 4989 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_50US; 4990 break; 4991 case 10000: 4992 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_10US; 4993 break; 4994 case 5000: 4995 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_5US; 4996 break; 4997 case 1000: 4998 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_1US; 4999 break; 5000 case 500: 5001 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_500NS; 5002 break; 5003 case 100: 5004 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_100NS; 5005 break; 5006 default: 5007 pr_warn_ratelimited("%s: Use default duty cycle of 100ns\n", 5008 phydev_name(phydev)); 5009 pulse_width = LAN8841_PTP_GENERAL_CONFIG_LTC_EVENT_100NS; 5010 break; 5011 } 5012 5013 mutex_lock(&ptp_priv->ptp_lock); 5014 ret = lan8841_ptp_set_target(ptp_priv, LAN8841_EVENT_A, rq->perout.start.sec, 5015 rq->perout.start.nsec); 5016 mutex_unlock(&ptp_priv->ptp_lock); 5017 if (ret) 5018 return ret; 5019 5020 ret = lan8841_ptp_set_reload(ptp_priv, LAN8841_EVENT_A, rq->perout.period.sec, 5021 rq->perout.period.nsec); 5022 if (ret) 5023 return ret; 5024 5025 ret = lan8841_ptp_enable_event(ptp_priv, pin, LAN8841_EVENT_A, 5026 pulse_width); 5027 if (ret) 5028 return ret; 5029 5030 ret = lan8841_ptp_perout_on(ptp_priv, pin); 5031 if (ret) 5032 lan8841_ptp_remove_event(ptp_priv, pin, LAN8841_EVENT_A); 5033 5034 return ret; 5035 } 5036 5037 #define LAN8841_PTP_GPIO_CAP_EN 496 5038 #define LAN8841_PTP_GPIO_CAP_EN_GPIO_RE_CAPTURE_ENABLE(gpio) (BIT(gpio)) 5039 #define LAN8841_PTP_GPIO_CAP_EN_GPIO_FE_CAPTURE_ENABLE(gpio) (BIT(gpio) << 8) 5040 #define LAN8841_PTP_INT_EN_PTP_GPIO_CAP_EN BIT(2) 5041 5042 static int lan8841_ptp_extts_on(struct kszphy_ptp_priv *ptp_priv, int pin, 5043 u32 flags) 5044 { 5045 struct phy_device *phydev = ptp_priv->phydev; 5046 u16 tmp = 0; 5047 int ret; 5048 5049 /* Set GPIO to be intput */ 5050 ret = phy_set_bits_mmd(phydev, 2, LAN8841_GPIO_EN, BIT(pin)); 5051 if (ret) 5052 return ret; 5053 5054 ret = phy_clear_bits_mmd(phydev, 2, LAN8841_GPIO_BUF, BIT(pin)); 5055 if (ret) 5056 return ret; 5057 5058 /* Enable capture on the edges of the pin */ 5059 if (flags & PTP_RISING_EDGE) 5060 tmp |= LAN8841_PTP_GPIO_CAP_EN_GPIO_RE_CAPTURE_ENABLE(pin); 5061 if (flags & PTP_FALLING_EDGE) 5062 tmp |= LAN8841_PTP_GPIO_CAP_EN_GPIO_FE_CAPTURE_ENABLE(pin); 5063 ret = phy_write_mmd(phydev, 2, LAN8841_PTP_GPIO_CAP_EN, tmp); 5064 if (ret) 5065 return ret; 5066 5067 /* Enable interrupt */ 5068 return phy_modify_mmd(phydev, 2, LAN8841_PTP_INT_EN, 5069 LAN8841_PTP_INT_EN_PTP_GPIO_CAP_EN, 5070 LAN8841_PTP_INT_EN_PTP_GPIO_CAP_EN); 5071 } 5072 5073 static int lan8841_ptp_extts_off(struct kszphy_ptp_priv *ptp_priv, int pin) 5074 { 5075 struct phy_device *phydev = ptp_priv->phydev; 5076 int ret; 5077 5078 /* Set GPIO to be output */ 5079 ret = phy_clear_bits_mmd(phydev, 2, LAN8841_GPIO_EN, BIT(pin)); 5080 if (ret) 5081 return ret; 5082 5083 ret = phy_clear_bits_mmd(phydev, 2, LAN8841_GPIO_BUF, BIT(pin)); 5084 if (ret) 5085 return ret; 5086 5087 /* Disable capture on both of the edges */ 5088 ret = phy_modify_mmd(phydev, 2, LAN8841_PTP_GPIO_CAP_EN, 5089 LAN8841_PTP_GPIO_CAP_EN_GPIO_RE_CAPTURE_ENABLE(pin) | 5090 LAN8841_PTP_GPIO_CAP_EN_GPIO_FE_CAPTURE_ENABLE(pin), 5091 0); 5092 if (ret) 5093 return ret; 5094 5095 /* Disable interrupt */ 5096 return phy_modify_mmd(phydev, 2, LAN8841_PTP_INT_EN, 5097 LAN8841_PTP_INT_EN_PTP_GPIO_CAP_EN, 5098 0); 5099 } 5100 5101 static int lan8841_ptp_extts(struct ptp_clock_info *ptp, 5102 struct ptp_clock_request *rq, int on) 5103 { 5104 struct kszphy_ptp_priv *ptp_priv = container_of(ptp, struct kszphy_ptp_priv, 5105 ptp_clock_info); 5106 int pin; 5107 int ret; 5108 5109 /* Reject requests with unsupported flags */ 5110 if (rq->extts.flags & ~(PTP_ENABLE_FEATURE | 5111 PTP_EXTTS_EDGES | 5112 PTP_STRICT_FLAGS)) 5113 return -EOPNOTSUPP; 5114 5115 pin = ptp_find_pin(ptp_priv->ptp_clock, PTP_PF_EXTTS, rq->extts.index); 5116 if (pin == -1 || pin >= LAN8841_PTP_GPIO_NUM) 5117 return -EINVAL; 5118 5119 mutex_lock(&ptp_priv->ptp_lock); 5120 if (on) 5121 ret = lan8841_ptp_extts_on(ptp_priv, pin, rq->extts.flags); 5122 else 5123 ret = lan8841_ptp_extts_off(ptp_priv, pin); 5124 mutex_unlock(&ptp_priv->ptp_lock); 5125 5126 return ret; 5127 } 5128 5129 static int lan8841_ptp_enable(struct ptp_clock_info *ptp, 5130 struct ptp_clock_request *rq, int on) 5131 { 5132 switch (rq->type) { 5133 case PTP_CLK_REQ_EXTTS: 5134 return lan8841_ptp_extts(ptp, rq, on); 5135 case PTP_CLK_REQ_PEROUT: 5136 return lan8841_ptp_perout(ptp, rq, on); 5137 default: 5138 return -EOPNOTSUPP; 5139 } 5140 5141 return 0; 5142 } 5143 5144 static long lan8841_ptp_do_aux_work(struct ptp_clock_info *ptp) 5145 { 5146 struct kszphy_ptp_priv *ptp_priv = container_of(ptp, struct kszphy_ptp_priv, 5147 ptp_clock_info); 5148 struct timespec64 ts; 5149 unsigned long flags; 5150 5151 lan8841_ptp_getseconds(&ptp_priv->ptp_clock_info, &ts); 5152 5153 spin_lock_irqsave(&ptp_priv->seconds_lock, flags); 5154 ptp_priv->seconds = ts.tv_sec; 5155 spin_unlock_irqrestore(&ptp_priv->seconds_lock, flags); 5156 5157 return nsecs_to_jiffies(LAN8841_GET_SEC_LTC_DELAY); 5158 } 5159 5160 static struct ptp_clock_info lan8841_ptp_clock_info = { 5161 .owner = THIS_MODULE, 5162 .name = "lan8841 ptp", 5163 .max_adj = 31249999, 5164 .gettime64 = lan8841_ptp_gettime64, 5165 .settime64 = lan8841_ptp_settime64, 5166 .adjtime = lan8841_ptp_adjtime, 5167 .adjfine = lan8841_ptp_adjfine, 5168 .verify = lan8841_ptp_verify, 5169 .enable = lan8841_ptp_enable, 5170 .do_aux_work = lan8841_ptp_do_aux_work, 5171 .n_per_out = LAN8841_PTP_GPIO_NUM, 5172 .n_ext_ts = LAN8841_PTP_GPIO_NUM, 5173 .n_pins = LAN8841_PTP_GPIO_NUM, 5174 }; 5175 5176 #define LAN8841_OPERATION_MODE_STRAP_LOW_REGISTER 3 5177 #define LAN8841_OPERATION_MODE_STRAP_LOW_REGISTER_STRAP_RGMII_EN BIT(0) 5178 5179 static int lan8841_probe(struct phy_device *phydev) 5180 { 5181 struct kszphy_ptp_priv *ptp_priv; 5182 struct kszphy_priv *priv; 5183 int err; 5184 5185 err = kszphy_probe(phydev); 5186 if (err) 5187 return err; 5188 5189 if (phy_read_mmd(phydev, KSZ9131RN_MMD_COMMON_CTRL_REG, 5190 LAN8841_OPERATION_MODE_STRAP_LOW_REGISTER) & 5191 LAN8841_OPERATION_MODE_STRAP_LOW_REGISTER_STRAP_RGMII_EN) 5192 phydev->interface = PHY_INTERFACE_MODE_RGMII_RXID; 5193 5194 /* Register the clock */ 5195 if (!IS_ENABLED(CONFIG_NETWORK_PHY_TIMESTAMPING)) 5196 return 0; 5197 5198 priv = phydev->priv; 5199 ptp_priv = &priv->ptp_priv; 5200 5201 ptp_priv->pin_config = devm_kcalloc(&phydev->mdio.dev, 5202 LAN8841_PTP_GPIO_NUM, 5203 sizeof(*ptp_priv->pin_config), 5204 GFP_KERNEL); 5205 if (!ptp_priv->pin_config) 5206 return -ENOMEM; 5207 5208 for (int i = 0; i < LAN8841_PTP_GPIO_NUM; ++i) { 5209 struct ptp_pin_desc *p = &ptp_priv->pin_config[i]; 5210 5211 snprintf(p->name, sizeof(p->name), "pin%d", i); 5212 p->index = i; 5213 p->func = PTP_PF_NONE; 5214 } 5215 5216 ptp_priv->ptp_clock_info = lan8841_ptp_clock_info; 5217 ptp_priv->ptp_clock_info.pin_config = ptp_priv->pin_config; 5218 ptp_priv->ptp_clock = ptp_clock_register(&ptp_priv->ptp_clock_info, 5219 &phydev->mdio.dev); 5220 if (IS_ERR(ptp_priv->ptp_clock)) { 5221 phydev_err(phydev, "ptp_clock_register failed: %lu\n", 5222 PTR_ERR(ptp_priv->ptp_clock)); 5223 return -EINVAL; 5224 } 5225 5226 if (!ptp_priv->ptp_clock) 5227 return 0; 5228 5229 /* Initialize the SW */ 5230 skb_queue_head_init(&ptp_priv->tx_queue); 5231 ptp_priv->phydev = phydev; 5232 mutex_init(&ptp_priv->ptp_lock); 5233 spin_lock_init(&ptp_priv->seconds_lock); 5234 5235 ptp_priv->mii_ts.rxtstamp = lan8841_rxtstamp; 5236 ptp_priv->mii_ts.txtstamp = lan8814_txtstamp; 5237 ptp_priv->mii_ts.hwtstamp = lan8841_hwtstamp; 5238 ptp_priv->mii_ts.ts_info = lan8841_ts_info; 5239 5240 phydev->mii_ts = &ptp_priv->mii_ts; 5241 5242 return 0; 5243 } 5244 5245 static int lan8841_suspend(struct phy_device *phydev) 5246 { 5247 struct kszphy_priv *priv = phydev->priv; 5248 struct kszphy_ptp_priv *ptp_priv = &priv->ptp_priv; 5249 5250 if (ptp_priv->ptp_clock) 5251 ptp_cancel_worker_sync(ptp_priv->ptp_clock); 5252 5253 return genphy_suspend(phydev); 5254 } 5255 5256 static struct phy_driver ksphy_driver[] = { 5257 { 5258 .phy_id = PHY_ID_KS8737, 5259 .phy_id_mask = MICREL_PHY_ID_MASK, 5260 .name = "Micrel KS8737", 5261 /* PHY_BASIC_FEATURES */ 5262 .driver_data = &ks8737_type, 5263 .probe = kszphy_probe, 5264 .config_init = kszphy_config_init, 5265 .config_intr = kszphy_config_intr, 5266 .handle_interrupt = kszphy_handle_interrupt, 5267 .suspend = kszphy_suspend, 5268 .resume = kszphy_resume, 5269 }, { 5270 .phy_id = PHY_ID_KSZ8021, 5271 .phy_id_mask = 0x00ffffff, 5272 .name = "Micrel KSZ8021 or KSZ8031", 5273 /* PHY_BASIC_FEATURES */ 5274 .driver_data = &ksz8021_type, 5275 .probe = kszphy_probe, 5276 .config_init = kszphy_config_init, 5277 .config_intr = kszphy_config_intr, 5278 .handle_interrupt = kszphy_handle_interrupt, 5279 .get_sset_count = kszphy_get_sset_count, 5280 .get_strings = kszphy_get_strings, 5281 .get_stats = kszphy_get_stats, 5282 .suspend = kszphy_suspend, 5283 .resume = kszphy_resume, 5284 }, { 5285 .phy_id = PHY_ID_KSZ8031, 5286 .phy_id_mask = 0x00ffffff, 5287 .name = "Micrel KSZ8031", 5288 /* PHY_BASIC_FEATURES */ 5289 .driver_data = &ksz8021_type, 5290 .probe = kszphy_probe, 5291 .config_init = kszphy_config_init, 5292 .config_intr = kszphy_config_intr, 5293 .handle_interrupt = kszphy_handle_interrupt, 5294 .get_sset_count = kszphy_get_sset_count, 5295 .get_strings = kszphy_get_strings, 5296 .get_stats = kszphy_get_stats, 5297 .suspend = kszphy_suspend, 5298 .resume = kszphy_resume, 5299 }, { 5300 .phy_id = PHY_ID_KSZ8041, 5301 .phy_id_mask = MICREL_PHY_ID_MASK, 5302 .name = "Micrel KSZ8041", 5303 /* PHY_BASIC_FEATURES */ 5304 .driver_data = &ksz8041_type, 5305 .probe = kszphy_probe, 5306 .config_init = ksz8041_config_init, 5307 .config_aneg = ksz8041_config_aneg, 5308 .config_intr = kszphy_config_intr, 5309 .handle_interrupt = kszphy_handle_interrupt, 5310 .get_sset_count = kszphy_get_sset_count, 5311 .get_strings = kszphy_get_strings, 5312 .get_stats = kszphy_get_stats, 5313 /* No suspend/resume callbacks because of errata DS80000700A, 5314 * receiver error following software power down. 5315 */ 5316 }, { 5317 .phy_id = PHY_ID_KSZ8041RNLI, 5318 .phy_id_mask = MICREL_PHY_ID_MASK, 5319 .name = "Micrel KSZ8041RNLI", 5320 /* PHY_BASIC_FEATURES */ 5321 .driver_data = &ksz8041_type, 5322 .probe = kszphy_probe, 5323 .config_init = kszphy_config_init, 5324 .config_intr = kszphy_config_intr, 5325 .handle_interrupt = kszphy_handle_interrupt, 5326 .get_sset_count = kszphy_get_sset_count, 5327 .get_strings = kszphy_get_strings, 5328 .get_stats = kszphy_get_stats, 5329 .suspend = kszphy_suspend, 5330 .resume = kszphy_resume, 5331 }, { 5332 .name = "Micrel KSZ8051", 5333 /* PHY_BASIC_FEATURES */ 5334 .driver_data = &ksz8051_type, 5335 .probe = kszphy_probe, 5336 .config_init = kszphy_config_init, 5337 .config_intr = kszphy_config_intr, 5338 .handle_interrupt = kszphy_handle_interrupt, 5339 .get_sset_count = kszphy_get_sset_count, 5340 .get_strings = kszphy_get_strings, 5341 .get_stats = kszphy_get_stats, 5342 .match_phy_device = ksz8051_match_phy_device, 5343 .suspend = kszphy_suspend, 5344 .resume = kszphy_resume, 5345 }, { 5346 .phy_id = PHY_ID_KSZ8001, 5347 .name = "Micrel KSZ8001 or KS8721", 5348 .phy_id_mask = 0x00fffffc, 5349 /* PHY_BASIC_FEATURES */ 5350 .driver_data = &ksz8041_type, 5351 .probe = kszphy_probe, 5352 .config_init = kszphy_config_init, 5353 .config_intr = kszphy_config_intr, 5354 .handle_interrupt = kszphy_handle_interrupt, 5355 .get_sset_count = kszphy_get_sset_count, 5356 .get_strings = kszphy_get_strings, 5357 .get_stats = kszphy_get_stats, 5358 .suspend = kszphy_suspend, 5359 .resume = kszphy_resume, 5360 }, { 5361 .phy_id = PHY_ID_KSZ8081, 5362 .name = "Micrel KSZ8081 or KSZ8091", 5363 .phy_id_mask = MICREL_PHY_ID_MASK, 5364 .flags = PHY_POLL_CABLE_TEST, 5365 /* PHY_BASIC_FEATURES */ 5366 .driver_data = &ksz8081_type, 5367 .probe = kszphy_probe, 5368 .config_init = ksz8081_config_init, 5369 .soft_reset = genphy_soft_reset, 5370 .config_aneg = ksz8081_config_aneg, 5371 .read_status = ksz8081_read_status, 5372 .config_intr = kszphy_config_intr, 5373 .handle_interrupt = kszphy_handle_interrupt, 5374 .get_sset_count = kszphy_get_sset_count, 5375 .get_strings = kszphy_get_strings, 5376 .get_stats = kszphy_get_stats, 5377 .suspend = kszphy_suspend, 5378 .resume = kszphy_resume, 5379 .cable_test_start = ksz886x_cable_test_start, 5380 .cable_test_get_status = ksz886x_cable_test_get_status, 5381 }, { 5382 .phy_id = PHY_ID_KSZ8061, 5383 .name = "Micrel KSZ8061", 5384 .phy_id_mask = MICREL_PHY_ID_MASK, 5385 /* PHY_BASIC_FEATURES */ 5386 .probe = kszphy_probe, 5387 .config_init = ksz8061_config_init, 5388 .soft_reset = genphy_soft_reset, 5389 .config_intr = kszphy_config_intr, 5390 .handle_interrupt = kszphy_handle_interrupt, 5391 .suspend = kszphy_suspend, 5392 .resume = kszphy_resume, 5393 }, { 5394 .phy_id = PHY_ID_KSZ9021, 5395 .phy_id_mask = 0x000ffffe, 5396 .name = "Micrel KSZ9021 Gigabit PHY", 5397 /* PHY_GBIT_FEATURES */ 5398 .driver_data = &ksz9021_type, 5399 .probe = kszphy_probe, 5400 .get_features = ksz9031_get_features, 5401 .config_init = ksz9021_config_init, 5402 .config_intr = kszphy_config_intr, 5403 .handle_interrupt = kszphy_handle_interrupt, 5404 .get_sset_count = kszphy_get_sset_count, 5405 .get_strings = kszphy_get_strings, 5406 .get_stats = kszphy_get_stats, 5407 .suspend = kszphy_suspend, 5408 .resume = kszphy_resume, 5409 .read_mmd = genphy_read_mmd_unsupported, 5410 .write_mmd = genphy_write_mmd_unsupported, 5411 }, { 5412 .phy_id = PHY_ID_KSZ9031, 5413 .phy_id_mask = MICREL_PHY_ID_MASK, 5414 .name = "Micrel KSZ9031 Gigabit PHY", 5415 .flags = PHY_POLL_CABLE_TEST, 5416 .driver_data = &ksz9021_type, 5417 .probe = kszphy_probe, 5418 .get_features = ksz9031_get_features, 5419 .config_init = ksz9031_config_init, 5420 .soft_reset = genphy_soft_reset, 5421 .read_status = ksz9031_read_status, 5422 .config_intr = kszphy_config_intr, 5423 .handle_interrupt = kszphy_handle_interrupt, 5424 .get_sset_count = kszphy_get_sset_count, 5425 .get_strings = kszphy_get_strings, 5426 .get_stats = kszphy_get_stats, 5427 .suspend = kszphy_suspend, 5428 .resume = kszphy_resume, 5429 .cable_test_start = ksz9x31_cable_test_start, 5430 .cable_test_get_status = ksz9x31_cable_test_get_status, 5431 }, { 5432 .phy_id = PHY_ID_LAN8814, 5433 .phy_id_mask = MICREL_PHY_ID_MASK, 5434 .name = "Microchip INDY Gigabit Quad PHY", 5435 .flags = PHY_POLL_CABLE_TEST, 5436 .config_init = lan8814_config_init, 5437 .driver_data = &lan8814_type, 5438 .probe = lan8814_probe, 5439 .soft_reset = genphy_soft_reset, 5440 .read_status = ksz9031_read_status, 5441 .get_sset_count = kszphy_get_sset_count, 5442 .get_strings = kszphy_get_strings, 5443 .get_stats = kszphy_get_stats, 5444 .suspend = genphy_suspend, 5445 .resume = kszphy_resume, 5446 .config_intr = lan8814_config_intr, 5447 .handle_interrupt = lan8814_handle_interrupt, 5448 .cable_test_start = lan8814_cable_test_start, 5449 .cable_test_get_status = ksz886x_cable_test_get_status, 5450 }, { 5451 .phy_id = PHY_ID_LAN8804, 5452 .phy_id_mask = MICREL_PHY_ID_MASK, 5453 .name = "Microchip LAN966X Gigabit PHY", 5454 .config_init = lan8804_config_init, 5455 .driver_data = &ksz9021_type, 5456 .probe = kszphy_probe, 5457 .soft_reset = genphy_soft_reset, 5458 .read_status = ksz9031_read_status, 5459 .get_sset_count = kszphy_get_sset_count, 5460 .get_strings = kszphy_get_strings, 5461 .get_stats = kszphy_get_stats, 5462 .suspend = genphy_suspend, 5463 .resume = kszphy_resume, 5464 .config_intr = lan8804_config_intr, 5465 .handle_interrupt = lan8804_handle_interrupt, 5466 }, { 5467 .phy_id = PHY_ID_LAN8841, 5468 .phy_id_mask = MICREL_PHY_ID_MASK, 5469 .name = "Microchip LAN8841 Gigabit PHY", 5470 .flags = PHY_POLL_CABLE_TEST, 5471 .driver_data = &lan8841_type, 5472 .config_init = lan8841_config_init, 5473 .probe = lan8841_probe, 5474 .soft_reset = genphy_soft_reset, 5475 .config_intr = lan8841_config_intr, 5476 .handle_interrupt = lan8841_handle_interrupt, 5477 .get_sset_count = kszphy_get_sset_count, 5478 .get_strings = kszphy_get_strings, 5479 .get_stats = kszphy_get_stats, 5480 .suspend = lan8841_suspend, 5481 .resume = genphy_resume, 5482 .cable_test_start = lan8814_cable_test_start, 5483 .cable_test_get_status = ksz886x_cable_test_get_status, 5484 }, { 5485 .phy_id = PHY_ID_KSZ9131, 5486 .phy_id_mask = MICREL_PHY_ID_MASK, 5487 .name = "Microchip KSZ9131 Gigabit PHY", 5488 /* PHY_GBIT_FEATURES */ 5489 .flags = PHY_POLL_CABLE_TEST, 5490 .driver_data = &ksz9131_type, 5491 .probe = kszphy_probe, 5492 .soft_reset = genphy_soft_reset, 5493 .config_init = ksz9131_config_init, 5494 .config_intr = kszphy_config_intr, 5495 .config_aneg = ksz9131_config_aneg, 5496 .read_status = ksz9131_read_status, 5497 .handle_interrupt = kszphy_handle_interrupt, 5498 .get_sset_count = kszphy_get_sset_count, 5499 .get_strings = kszphy_get_strings, 5500 .get_stats = kszphy_get_stats, 5501 .suspend = kszphy_suspend, 5502 .resume = kszphy_resume, 5503 .cable_test_start = ksz9x31_cable_test_start, 5504 .cable_test_get_status = ksz9x31_cable_test_get_status, 5505 .get_features = ksz9477_get_features, 5506 }, { 5507 .phy_id = PHY_ID_KSZ8873MLL, 5508 .phy_id_mask = MICREL_PHY_ID_MASK, 5509 .name = "Micrel KSZ8873MLL Switch", 5510 /* PHY_BASIC_FEATURES */ 5511 .config_init = kszphy_config_init, 5512 .config_aneg = ksz8873mll_config_aneg, 5513 .read_status = ksz8873mll_read_status, 5514 .suspend = genphy_suspend, 5515 .resume = genphy_resume, 5516 }, { 5517 .phy_id = PHY_ID_KSZ886X, 5518 .phy_id_mask = MICREL_PHY_ID_MASK, 5519 .name = "Micrel KSZ8851 Ethernet MAC or KSZ886X Switch", 5520 .driver_data = &ksz886x_type, 5521 /* PHY_BASIC_FEATURES */ 5522 .flags = PHY_POLL_CABLE_TEST, 5523 .config_init = kszphy_config_init, 5524 .config_aneg = ksz886x_config_aneg, 5525 .read_status = ksz886x_read_status, 5526 .suspend = genphy_suspend, 5527 .resume = genphy_resume, 5528 .cable_test_start = ksz886x_cable_test_start, 5529 .cable_test_get_status = ksz886x_cable_test_get_status, 5530 }, { 5531 .name = "Micrel KSZ87XX Switch", 5532 /* PHY_BASIC_FEATURES */ 5533 .config_init = kszphy_config_init, 5534 .match_phy_device = ksz8795_match_phy_device, 5535 .suspend = genphy_suspend, 5536 .resume = genphy_resume, 5537 }, { 5538 .phy_id = PHY_ID_KSZ9477, 5539 .phy_id_mask = MICREL_PHY_ID_MASK, 5540 .name = "Microchip KSZ9477", 5541 /* PHY_GBIT_FEATURES */ 5542 .config_init = ksz9477_config_init, 5543 .config_intr = kszphy_config_intr, 5544 .handle_interrupt = kszphy_handle_interrupt, 5545 .suspend = genphy_suspend, 5546 .resume = ksz9477_resume, 5547 .get_features = ksz9477_get_features, 5548 } }; 5549 5550 module_phy_driver(ksphy_driver); 5551 5552 MODULE_DESCRIPTION("Micrel PHY driver"); 5553 MODULE_AUTHOR("David J. Choi"); 5554 MODULE_LICENSE("GPL"); 5555 5556 static struct mdio_device_id __maybe_unused micrel_tbl[] = { 5557 { PHY_ID_KSZ9021, 0x000ffffe }, 5558 { PHY_ID_KSZ9031, MICREL_PHY_ID_MASK }, 5559 { PHY_ID_KSZ9131, MICREL_PHY_ID_MASK }, 5560 { PHY_ID_KSZ8001, 0x00fffffc }, 5561 { PHY_ID_KS8737, MICREL_PHY_ID_MASK }, 5562 { PHY_ID_KSZ8021, 0x00ffffff }, 5563 { PHY_ID_KSZ8031, 0x00ffffff }, 5564 { PHY_ID_KSZ8041, MICREL_PHY_ID_MASK }, 5565 { PHY_ID_KSZ8051, MICREL_PHY_ID_MASK }, 5566 { PHY_ID_KSZ8061, MICREL_PHY_ID_MASK }, 5567 { PHY_ID_KSZ8081, MICREL_PHY_ID_MASK }, 5568 { PHY_ID_KSZ8873MLL, MICREL_PHY_ID_MASK }, 5569 { PHY_ID_KSZ886X, MICREL_PHY_ID_MASK }, 5570 { PHY_ID_LAN8814, MICREL_PHY_ID_MASK }, 5571 { PHY_ID_LAN8804, MICREL_PHY_ID_MASK }, 5572 { PHY_ID_LAN8841, MICREL_PHY_ID_MASK }, 5573 { } 5574 }; 5575 5576 MODULE_DEVICE_TABLE(mdio, micrel_tbl); 5577