Linux kernel mirror (for testing)
git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel
os
linux
1// SPDX-License-Identifier: GPL-2.0+
2/*
3 * Motorcomm 8511/8521/8531/8531S PHY driver.
4 *
5 * Author: Peter Geis <pgwipeout@gmail.com>
6 * Author: Frank <Frank.Sae@motor-comm.com>
7 */
8
9#include <linux/etherdevice.h>
10#include <linux/kernel.h>
11#include <linux/module.h>
12#include <linux/phy.h>
13#include <linux/of.h>
14
15#define PHY_ID_YT8511 0x0000010a
16#define PHY_ID_YT8521 0x0000011a
17#define PHY_ID_YT8531 0x4f51e91b
18#define PHY_ID_YT8531S 0x4f51e91a
19
20/* YT8521/YT8531S Register Overview
21 * UTP Register space | FIBER Register space
22 * ------------------------------------------------------------
23 * | UTP MII | FIBER MII |
24 * | UTP MMD | |
25 * | UTP Extended | FIBER Extended |
26 * ------------------------------------------------------------
27 * | Common Extended |
28 * ------------------------------------------------------------
29 */
30
31/* 0x10 ~ 0x15 , 0x1E and 0x1F are common MII registers of yt phy */
32
33/* Specific Function Control Register */
34#define YTPHY_SPECIFIC_FUNCTION_CONTROL_REG 0x10
35
36/* 2b00 Manual MDI configuration
37 * 2b01 Manual MDIX configuration
38 * 2b10 Reserved
39 * 2b11 Enable automatic crossover for all modes *default*
40 */
41#define YTPHY_SFCR_MDI_CROSSOVER_MODE_MASK (BIT(6) | BIT(5))
42#define YTPHY_SFCR_CROSSOVER_EN BIT(3)
43#define YTPHY_SFCR_SQE_TEST_EN BIT(2)
44#define YTPHY_SFCR_POLARITY_REVERSAL_EN BIT(1)
45#define YTPHY_SFCR_JABBER_DIS BIT(0)
46
47/* Specific Status Register */
48#define YTPHY_SPECIFIC_STATUS_REG 0x11
49#define YTPHY_SSR_SPEED_MODE_OFFSET 14
50
51#define YTPHY_SSR_SPEED_MODE_MASK (BIT(15) | BIT(14))
52#define YTPHY_SSR_SPEED_10M 0x0
53#define YTPHY_SSR_SPEED_100M 0x1
54#define YTPHY_SSR_SPEED_1000M 0x2
55#define YTPHY_SSR_DUPLEX_OFFSET 13
56#define YTPHY_SSR_DUPLEX BIT(13)
57#define YTPHY_SSR_PAGE_RECEIVED BIT(12)
58#define YTPHY_SSR_SPEED_DUPLEX_RESOLVED BIT(11)
59#define YTPHY_SSR_LINK BIT(10)
60#define YTPHY_SSR_MDIX_CROSSOVER BIT(6)
61#define YTPHY_SSR_DOWNGRADE BIT(5)
62#define YTPHY_SSR_TRANSMIT_PAUSE BIT(3)
63#define YTPHY_SSR_RECEIVE_PAUSE BIT(2)
64#define YTPHY_SSR_POLARITY BIT(1)
65#define YTPHY_SSR_JABBER BIT(0)
66
67/* Interrupt enable Register */
68#define YTPHY_INTERRUPT_ENABLE_REG 0x12
69#define YTPHY_IER_WOL BIT(6)
70
71/* Interrupt Status Register */
72#define YTPHY_INTERRUPT_STATUS_REG 0x13
73#define YTPHY_ISR_AUTONEG_ERR BIT(15)
74#define YTPHY_ISR_SPEED_CHANGED BIT(14)
75#define YTPHY_ISR_DUPLEX_CHANGED BIT(13)
76#define YTPHY_ISR_PAGE_RECEIVED BIT(12)
77#define YTPHY_ISR_LINK_FAILED BIT(11)
78#define YTPHY_ISR_LINK_SUCCESSED BIT(10)
79#define YTPHY_ISR_WOL BIT(6)
80#define YTPHY_ISR_WIRESPEED_DOWNGRADE BIT(5)
81#define YTPHY_ISR_SERDES_LINK_FAILED BIT(3)
82#define YTPHY_ISR_SERDES_LINK_SUCCESSED BIT(2)
83#define YTPHY_ISR_POLARITY_CHANGED BIT(1)
84#define YTPHY_ISR_JABBER_HAPPENED BIT(0)
85
86/* Speed Auto Downgrade Control Register */
87#define YTPHY_SPEED_AUTO_DOWNGRADE_CONTROL_REG 0x14
88#define YTPHY_SADCR_SPEED_DOWNGRADE_EN BIT(5)
89
90/* If these bits are set to 3, the PHY attempts five times ( 3(set value) +
91 * additional 2) before downgrading, default 0x3
92 */
93#define YTPHY_SADCR_SPEED_RETRY_LIMIT (0x3 << 2)
94
95/* Rx Error Counter Register */
96#define YTPHY_RX_ERROR_COUNTER_REG 0x15
97
98/* Extended Register's Address Offset Register */
99#define YTPHY_PAGE_SELECT 0x1E
100
101/* Extended Register's Data Register */
102#define YTPHY_PAGE_DATA 0x1F
103
104/* FIBER Auto-Negotiation link partner ability */
105#define YTPHY_FLPA_PAUSE (0x3 << 7)
106#define YTPHY_FLPA_ASYM_PAUSE (0x2 << 7)
107
108#define YT8511_PAGE_SELECT 0x1e
109#define YT8511_PAGE 0x1f
110#define YT8511_EXT_CLK_GATE 0x0c
111#define YT8511_EXT_DELAY_DRIVE 0x0d
112#define YT8511_EXT_SLEEP_CTRL 0x27
113
114/* 2b00 25m from pll
115 * 2b01 25m from xtl *default*
116 * 2b10 62.m from pll
117 * 2b11 125m from pll
118 */
119#define YT8511_CLK_125M (BIT(2) | BIT(1))
120#define YT8511_PLLON_SLP BIT(14)
121
122/* RX Delay enabled = 1.8ns 1000T, 8ns 10/100T */
123#define YT8511_DELAY_RX BIT(0)
124
125/* TX Gig-E Delay is bits 7:4, default 0x5
126 * TX Fast-E Delay is bits 15:12, default 0xf
127 * Delay = 150ps * N - 250ps
128 * On = 2000ps, off = 50ps
129 */
130#define YT8511_DELAY_GE_TX_EN (0xf << 4)
131#define YT8511_DELAY_GE_TX_DIS (0x2 << 4)
132#define YT8511_DELAY_FE_TX_EN (0xf << 12)
133#define YT8511_DELAY_FE_TX_DIS (0x2 << 12)
134
135/* Extended register is different from MMD Register and MII Register.
136 * We can use ytphy_read_ext/ytphy_write_ext/ytphy_modify_ext function to
137 * operate extended register.
138 * Extended Register start
139 */
140
141/* Phy gmii clock gating Register */
142#define YT8521_CLOCK_GATING_REG 0xC
143#define YT8521_CGR_RX_CLK_EN BIT(12)
144
145#define YT8521_EXTREG_SLEEP_CONTROL1_REG 0x27
146#define YT8521_ESC1R_SLEEP_SW BIT(15)
147#define YT8521_ESC1R_PLLON_SLP BIT(14)
148
149/* Phy fiber Link timer cfg2 Register */
150#define YT8521_LINK_TIMER_CFG2_REG 0xA5
151#define YT8521_LTCR_EN_AUTOSEN BIT(15)
152
153/* 0xA000, 0xA001, 0xA003, 0xA006 ~ 0xA00A and 0xA012 are common ext registers
154 * of yt8521 phy. There is no need to switch reg space when operating these
155 * registers.
156 */
157
158#define YT8521_REG_SPACE_SELECT_REG 0xA000
159#define YT8521_RSSR_SPACE_MASK BIT(1)
160#define YT8521_RSSR_FIBER_SPACE (0x1 << 1)
161#define YT8521_RSSR_UTP_SPACE (0x0 << 1)
162#define YT8521_RSSR_TO_BE_ARBITRATED (0xFF)
163
164#define YT8521_CHIP_CONFIG_REG 0xA001
165#define YT8521_CCR_SW_RST BIT(15)
166/* 1b0 disable 1.9ns rxc clock delay *default*
167 * 1b1 enable 1.9ns rxc clock delay
168 */
169#define YT8521_CCR_RXC_DLY_EN BIT(8)
170#define YT8521_CCR_RXC_DLY_1_900_NS 1900
171
172#define YT8521_CCR_MODE_SEL_MASK (BIT(2) | BIT(1) | BIT(0))
173#define YT8521_CCR_MODE_UTP_TO_RGMII 0
174#define YT8521_CCR_MODE_FIBER_TO_RGMII 1
175#define YT8521_CCR_MODE_UTP_FIBER_TO_RGMII 2
176#define YT8521_CCR_MODE_UTP_TO_SGMII 3
177#define YT8521_CCR_MODE_SGPHY_TO_RGMAC 4
178#define YT8521_CCR_MODE_SGMAC_TO_RGPHY 5
179#define YT8521_CCR_MODE_UTP_TO_FIBER_AUTO 6
180#define YT8521_CCR_MODE_UTP_TO_FIBER_FORCE 7
181
182/* 3 phy polling modes,poll mode combines utp and fiber mode*/
183#define YT8521_MODE_FIBER 0x1
184#define YT8521_MODE_UTP 0x2
185#define YT8521_MODE_POLL 0x3
186
187#define YT8521_RGMII_CONFIG1_REG 0xA003
188/* 1b0 use original tx_clk_rgmii *default*
189 * 1b1 use inverted tx_clk_rgmii.
190 */
191#define YT8521_RC1R_TX_CLK_SEL_INVERTED BIT(14)
192#define YT8521_RC1R_RX_DELAY_MASK GENMASK(13, 10)
193#define YT8521_RC1R_FE_TX_DELAY_MASK GENMASK(7, 4)
194#define YT8521_RC1R_GE_TX_DELAY_MASK GENMASK(3, 0)
195#define YT8521_RC1R_RGMII_0_000_NS 0
196#define YT8521_RC1R_RGMII_0_150_NS 1
197#define YT8521_RC1R_RGMII_0_300_NS 2
198#define YT8521_RC1R_RGMII_0_450_NS 3
199#define YT8521_RC1R_RGMII_0_600_NS 4
200#define YT8521_RC1R_RGMII_0_750_NS 5
201#define YT8521_RC1R_RGMII_0_900_NS 6
202#define YT8521_RC1R_RGMII_1_050_NS 7
203#define YT8521_RC1R_RGMII_1_200_NS 8
204#define YT8521_RC1R_RGMII_1_350_NS 9
205#define YT8521_RC1R_RGMII_1_500_NS 10
206#define YT8521_RC1R_RGMII_1_650_NS 11
207#define YT8521_RC1R_RGMII_1_800_NS 12
208#define YT8521_RC1R_RGMII_1_950_NS 13
209#define YT8521_RC1R_RGMII_2_100_NS 14
210#define YT8521_RC1R_RGMII_2_250_NS 15
211
212#define YTPHY_MISC_CONFIG_REG 0xA006
213#define YTPHY_MCR_FIBER_SPEED_MASK BIT(0)
214#define YTPHY_MCR_FIBER_1000BX (0x1 << 0)
215#define YTPHY_MCR_FIBER_100FX (0x0 << 0)
216
217/* WOL MAC ADDR: MACADDR2(highest), MACADDR1(middle), MACADDR0(lowest) */
218#define YTPHY_WOL_MACADDR2_REG 0xA007
219#define YTPHY_WOL_MACADDR1_REG 0xA008
220#define YTPHY_WOL_MACADDR0_REG 0xA009
221
222#define YTPHY_WOL_CONFIG_REG 0xA00A
223#define YTPHY_WCR_INTR_SEL BIT(6)
224#define YTPHY_WCR_ENABLE BIT(3)
225
226/* 2b00 84ms
227 * 2b01 168ms *default*
228 * 2b10 336ms
229 * 2b11 672ms
230 */
231#define YTPHY_WCR_PULSE_WIDTH_MASK (BIT(2) | BIT(1))
232#define YTPHY_WCR_PULSE_WIDTH_672MS (BIT(2) | BIT(1))
233
234/* 1b0 Interrupt and WOL events is level triggered and active LOW *default*
235 * 1b1 Interrupt and WOL events is pulse triggered and active LOW
236 */
237#define YTPHY_WCR_TYPE_PULSE BIT(0)
238
239#define YTPHY_SYNCE_CFG_REG 0xA012
240#define YT8521_SCR_SYNCE_ENABLE BIT(5)
241/* 1b0 output 25m clock
242 * 1b1 output 125m clock *default*
243 */
244#define YT8521_SCR_CLK_FRE_SEL_125M BIT(3)
245#define YT8521_SCR_CLK_SRC_MASK GENMASK(2, 1)
246#define YT8521_SCR_CLK_SRC_PLL_125M 0
247#define YT8521_SCR_CLK_SRC_UTP_RX 1
248#define YT8521_SCR_CLK_SRC_SDS_RX 2
249#define YT8521_SCR_CLK_SRC_REF_25M 3
250#define YT8531_SCR_SYNCE_ENABLE BIT(6)
251/* 1b0 output 25m clock *default*
252 * 1b1 output 125m clock
253 */
254#define YT8531_SCR_CLK_FRE_SEL_125M BIT(4)
255#define YT8531_SCR_CLK_SRC_MASK GENMASK(3, 1)
256#define YT8531_SCR_CLK_SRC_PLL_125M 0
257#define YT8531_SCR_CLK_SRC_UTP_RX 1
258#define YT8531_SCR_CLK_SRC_SDS_RX 2
259#define YT8531_SCR_CLK_SRC_CLOCK_FROM_DIGITAL 3
260#define YT8531_SCR_CLK_SRC_REF_25M 4
261#define YT8531_SCR_CLK_SRC_SSC_25M 5
262
263/* Extended Register end */
264
265#define YTPHY_DTS_OUTPUT_CLK_DIS 0
266#define YTPHY_DTS_OUTPUT_CLK_25M 25000000
267#define YTPHY_DTS_OUTPUT_CLK_125M 125000000
268
269struct yt8521_priv {
270 /* combo_advertising is used for case of YT8521 in combo mode,
271 * this means that yt8521 may work in utp or fiber mode which depends
272 * on which media is connected (YT8521_RSSR_TO_BE_ARBITRATED).
273 */
274 __ETHTOOL_DECLARE_LINK_MODE_MASK(combo_advertising);
275
276 /* YT8521_MODE_FIBER / YT8521_MODE_UTP / YT8521_MODE_POLL*/
277 u8 polling_mode;
278 u8 strap_mode; /* 8 working modes */
279 /* current reg page of yt8521 phy:
280 * YT8521_RSSR_UTP_SPACE
281 * YT8521_RSSR_FIBER_SPACE
282 * YT8521_RSSR_TO_BE_ARBITRATED
283 */
284 u8 reg_page;
285};
286
287/**
288 * ytphy_read_ext() - read a PHY's extended register
289 * @phydev: a pointer to a &struct phy_device
290 * @regnum: register number to read
291 *
292 * NOTE:The caller must have taken the MDIO bus lock.
293 *
294 * returns the value of regnum reg or negative error code
295 */
296static int ytphy_read_ext(struct phy_device *phydev, u16 regnum)
297{
298 int ret;
299
300 ret = __phy_write(phydev, YTPHY_PAGE_SELECT, regnum);
301 if (ret < 0)
302 return ret;
303
304 return __phy_read(phydev, YTPHY_PAGE_DATA);
305}
306
307/**
308 * ytphy_read_ext_with_lock() - read a PHY's extended register
309 * @phydev: a pointer to a &struct phy_device
310 * @regnum: register number to read
311 *
312 * returns the value of regnum reg or negative error code
313 */
314static int ytphy_read_ext_with_lock(struct phy_device *phydev, u16 regnum)
315{
316 int ret;
317
318 phy_lock_mdio_bus(phydev);
319 ret = ytphy_read_ext(phydev, regnum);
320 phy_unlock_mdio_bus(phydev);
321
322 return ret;
323}
324
325/**
326 * ytphy_write_ext() - write a PHY's extended register
327 * @phydev: a pointer to a &struct phy_device
328 * @regnum: register number to write
329 * @val: value to write to @regnum
330 *
331 * NOTE:The caller must have taken the MDIO bus lock.
332 *
333 * returns 0 or negative error code
334 */
335static int ytphy_write_ext(struct phy_device *phydev, u16 regnum, u16 val)
336{
337 int ret;
338
339 ret = __phy_write(phydev, YTPHY_PAGE_SELECT, regnum);
340 if (ret < 0)
341 return ret;
342
343 return __phy_write(phydev, YTPHY_PAGE_DATA, val);
344}
345
346/**
347 * ytphy_write_ext_with_lock() - write a PHY's extended register
348 * @phydev: a pointer to a &struct phy_device
349 * @regnum: register number to write
350 * @val: value to write to @regnum
351 *
352 * returns 0 or negative error code
353 */
354static int ytphy_write_ext_with_lock(struct phy_device *phydev, u16 regnum,
355 u16 val)
356{
357 int ret;
358
359 phy_lock_mdio_bus(phydev);
360 ret = ytphy_write_ext(phydev, regnum, val);
361 phy_unlock_mdio_bus(phydev);
362
363 return ret;
364}
365
366/**
367 * ytphy_modify_ext() - bits modify a PHY's extended register
368 * @phydev: a pointer to a &struct phy_device
369 * @regnum: register number to write
370 * @mask: bit mask of bits to clear
371 * @set: bit mask of bits to set
372 *
373 * NOTE: Convenience function which allows a PHY's extended register to be
374 * modified as new register value = (old register value & ~mask) | set.
375 * The caller must have taken the MDIO bus lock.
376 *
377 * returns 0 or negative error code
378 */
379static int ytphy_modify_ext(struct phy_device *phydev, u16 regnum, u16 mask,
380 u16 set)
381{
382 int ret;
383
384 ret = __phy_write(phydev, YTPHY_PAGE_SELECT, regnum);
385 if (ret < 0)
386 return ret;
387
388 return __phy_modify(phydev, YTPHY_PAGE_DATA, mask, set);
389}
390
391/**
392 * ytphy_modify_ext_with_lock() - bits modify a PHY's extended register
393 * @phydev: a pointer to a &struct phy_device
394 * @regnum: register number to write
395 * @mask: bit mask of bits to clear
396 * @set: bit mask of bits to set
397 *
398 * NOTE: Convenience function which allows a PHY's extended register to be
399 * modified as new register value = (old register value & ~mask) | set.
400 *
401 * returns 0 or negative error code
402 */
403static int ytphy_modify_ext_with_lock(struct phy_device *phydev, u16 regnum,
404 u16 mask, u16 set)
405{
406 int ret;
407
408 phy_lock_mdio_bus(phydev);
409 ret = ytphy_modify_ext(phydev, regnum, mask, set);
410 phy_unlock_mdio_bus(phydev);
411
412 return ret;
413}
414
415/**
416 * ytphy_get_wol() - report whether wake-on-lan is enabled
417 * @phydev: a pointer to a &struct phy_device
418 * @wol: a pointer to a &struct ethtool_wolinfo
419 *
420 * NOTE: YTPHY_WOL_CONFIG_REG is common ext reg.
421 */
422static void ytphy_get_wol(struct phy_device *phydev,
423 struct ethtool_wolinfo *wol)
424{
425 int wol_config;
426
427 wol->supported = WAKE_MAGIC;
428 wol->wolopts = 0;
429
430 wol_config = ytphy_read_ext_with_lock(phydev, YTPHY_WOL_CONFIG_REG);
431 if (wol_config < 0)
432 return;
433
434 if (wol_config & YTPHY_WCR_ENABLE)
435 wol->wolopts |= WAKE_MAGIC;
436}
437
438/**
439 * ytphy_set_wol() - turn wake-on-lan on or off
440 * @phydev: a pointer to a &struct phy_device
441 * @wol: a pointer to a &struct ethtool_wolinfo
442 *
443 * NOTE: YTPHY_WOL_CONFIG_REG, YTPHY_WOL_MACADDR2_REG, YTPHY_WOL_MACADDR1_REG
444 * and YTPHY_WOL_MACADDR0_REG are common ext reg. The
445 * YTPHY_INTERRUPT_ENABLE_REG of UTP is special, fiber also use this register.
446 *
447 * returns 0 or negative errno code
448 */
449static int ytphy_set_wol(struct phy_device *phydev, struct ethtool_wolinfo *wol)
450{
451 struct net_device *p_attached_dev;
452 const u16 mac_addr_reg[] = {
453 YTPHY_WOL_MACADDR2_REG,
454 YTPHY_WOL_MACADDR1_REG,
455 YTPHY_WOL_MACADDR0_REG,
456 };
457 const u8 *mac_addr;
458 int old_page;
459 int ret = 0;
460 u16 mask;
461 u16 val;
462 u8 i;
463
464 if (wol->wolopts & WAKE_MAGIC) {
465 p_attached_dev = phydev->attached_dev;
466 if (!p_attached_dev)
467 return -ENODEV;
468
469 mac_addr = (const u8 *)p_attached_dev->dev_addr;
470 if (!is_valid_ether_addr(mac_addr))
471 return -EINVAL;
472
473 /* lock mdio bus then switch to utp reg space */
474 old_page = phy_select_page(phydev, YT8521_RSSR_UTP_SPACE);
475 if (old_page < 0)
476 goto err_restore_page;
477
478 /* Store the device address for the magic packet */
479 for (i = 0; i < 3; i++) {
480 ret = ytphy_write_ext(phydev, mac_addr_reg[i],
481 ((mac_addr[i * 2] << 8)) |
482 (mac_addr[i * 2 + 1]));
483 if (ret < 0)
484 goto err_restore_page;
485 }
486
487 /* Enable WOL feature */
488 mask = YTPHY_WCR_PULSE_WIDTH_MASK | YTPHY_WCR_INTR_SEL;
489 val = YTPHY_WCR_ENABLE | YTPHY_WCR_INTR_SEL;
490 val |= YTPHY_WCR_TYPE_PULSE | YTPHY_WCR_PULSE_WIDTH_672MS;
491 ret = ytphy_modify_ext(phydev, YTPHY_WOL_CONFIG_REG, mask, val);
492 if (ret < 0)
493 goto err_restore_page;
494
495 /* Enable WOL interrupt */
496 ret = __phy_modify(phydev, YTPHY_INTERRUPT_ENABLE_REG, 0,
497 YTPHY_IER_WOL);
498 if (ret < 0)
499 goto err_restore_page;
500
501 } else {
502 old_page = phy_select_page(phydev, YT8521_RSSR_UTP_SPACE);
503 if (old_page < 0)
504 goto err_restore_page;
505
506 /* Disable WOL feature */
507 mask = YTPHY_WCR_ENABLE | YTPHY_WCR_INTR_SEL;
508 ret = ytphy_modify_ext(phydev, YTPHY_WOL_CONFIG_REG, mask, 0);
509
510 /* Disable WOL interrupt */
511 ret = __phy_modify(phydev, YTPHY_INTERRUPT_ENABLE_REG,
512 YTPHY_IER_WOL, 0);
513 if (ret < 0)
514 goto err_restore_page;
515 }
516
517err_restore_page:
518 return phy_restore_page(phydev, old_page, ret);
519}
520
521static int yt8531_set_wol(struct phy_device *phydev,
522 struct ethtool_wolinfo *wol)
523{
524 const u16 mac_addr_reg[] = {
525 YTPHY_WOL_MACADDR2_REG,
526 YTPHY_WOL_MACADDR1_REG,
527 YTPHY_WOL_MACADDR0_REG,
528 };
529 const u8 *mac_addr;
530 u16 mask, val;
531 int ret;
532 u8 i;
533
534 if (wol->wolopts & WAKE_MAGIC) {
535 mac_addr = phydev->attached_dev->dev_addr;
536
537 /* Store the device address for the magic packet */
538 for (i = 0; i < 3; i++) {
539 ret = ytphy_write_ext_with_lock(phydev, mac_addr_reg[i],
540 ((mac_addr[i * 2] << 8)) |
541 (mac_addr[i * 2 + 1]));
542 if (ret < 0)
543 return ret;
544 }
545
546 /* Enable WOL feature */
547 mask = YTPHY_WCR_PULSE_WIDTH_MASK | YTPHY_WCR_INTR_SEL;
548 val = YTPHY_WCR_ENABLE | YTPHY_WCR_INTR_SEL;
549 val |= YTPHY_WCR_TYPE_PULSE | YTPHY_WCR_PULSE_WIDTH_672MS;
550 ret = ytphy_modify_ext_with_lock(phydev, YTPHY_WOL_CONFIG_REG,
551 mask, val);
552 if (ret < 0)
553 return ret;
554
555 /* Enable WOL interrupt */
556 ret = phy_modify(phydev, YTPHY_INTERRUPT_ENABLE_REG, 0,
557 YTPHY_IER_WOL);
558 if (ret < 0)
559 return ret;
560 } else {
561 /* Disable WOL feature */
562 mask = YTPHY_WCR_ENABLE | YTPHY_WCR_INTR_SEL;
563 ret = ytphy_modify_ext_with_lock(phydev, YTPHY_WOL_CONFIG_REG,
564 mask, 0);
565
566 /* Disable WOL interrupt */
567 ret = phy_modify(phydev, YTPHY_INTERRUPT_ENABLE_REG,
568 YTPHY_IER_WOL, 0);
569 if (ret < 0)
570 return ret;
571 }
572
573 return 0;
574}
575
576static int yt8511_read_page(struct phy_device *phydev)
577{
578 return __phy_read(phydev, YT8511_PAGE_SELECT);
579};
580
581static int yt8511_write_page(struct phy_device *phydev, int page)
582{
583 return __phy_write(phydev, YT8511_PAGE_SELECT, page);
584};
585
586static int yt8511_config_init(struct phy_device *phydev)
587{
588 int oldpage, ret = 0;
589 unsigned int ge, fe;
590
591 oldpage = phy_select_page(phydev, YT8511_EXT_CLK_GATE);
592 if (oldpage < 0)
593 goto err_restore_page;
594
595 /* set rgmii delay mode */
596 switch (phydev->interface) {
597 case PHY_INTERFACE_MODE_RGMII:
598 ge = YT8511_DELAY_GE_TX_DIS;
599 fe = YT8511_DELAY_FE_TX_DIS;
600 break;
601 case PHY_INTERFACE_MODE_RGMII_RXID:
602 ge = YT8511_DELAY_RX | YT8511_DELAY_GE_TX_DIS;
603 fe = YT8511_DELAY_FE_TX_DIS;
604 break;
605 case PHY_INTERFACE_MODE_RGMII_TXID:
606 ge = YT8511_DELAY_GE_TX_EN;
607 fe = YT8511_DELAY_FE_TX_EN;
608 break;
609 case PHY_INTERFACE_MODE_RGMII_ID:
610 ge = YT8511_DELAY_RX | YT8511_DELAY_GE_TX_EN;
611 fe = YT8511_DELAY_FE_TX_EN;
612 break;
613 default: /* do not support other modes */
614 ret = -EOPNOTSUPP;
615 goto err_restore_page;
616 }
617
618 ret = __phy_modify(phydev, YT8511_PAGE, (YT8511_DELAY_RX | YT8511_DELAY_GE_TX_EN), ge);
619 if (ret < 0)
620 goto err_restore_page;
621
622 /* set clock mode to 125mhz */
623 ret = __phy_modify(phydev, YT8511_PAGE, 0, YT8511_CLK_125M);
624 if (ret < 0)
625 goto err_restore_page;
626
627 /* fast ethernet delay is in a separate page */
628 ret = __phy_write(phydev, YT8511_PAGE_SELECT, YT8511_EXT_DELAY_DRIVE);
629 if (ret < 0)
630 goto err_restore_page;
631
632 ret = __phy_modify(phydev, YT8511_PAGE, YT8511_DELAY_FE_TX_EN, fe);
633 if (ret < 0)
634 goto err_restore_page;
635
636 /* leave pll enabled in sleep */
637 ret = __phy_write(phydev, YT8511_PAGE_SELECT, YT8511_EXT_SLEEP_CTRL);
638 if (ret < 0)
639 goto err_restore_page;
640
641 ret = __phy_modify(phydev, YT8511_PAGE, 0, YT8511_PLLON_SLP);
642 if (ret < 0)
643 goto err_restore_page;
644
645err_restore_page:
646 return phy_restore_page(phydev, oldpage, ret);
647}
648
649/**
650 * yt8521_read_page() - read reg page
651 * @phydev: a pointer to a &struct phy_device
652 *
653 * returns current reg space of yt8521 (YT8521_RSSR_FIBER_SPACE/
654 * YT8521_RSSR_UTP_SPACE) or negative errno code
655 */
656static int yt8521_read_page(struct phy_device *phydev)
657{
658 int old_page;
659
660 old_page = ytphy_read_ext(phydev, YT8521_REG_SPACE_SELECT_REG);
661 if (old_page < 0)
662 return old_page;
663
664 if ((old_page & YT8521_RSSR_SPACE_MASK) == YT8521_RSSR_FIBER_SPACE)
665 return YT8521_RSSR_FIBER_SPACE;
666
667 return YT8521_RSSR_UTP_SPACE;
668};
669
670/**
671 * yt8521_write_page() - write reg page
672 * @phydev: a pointer to a &struct phy_device
673 * @page: The reg page(YT8521_RSSR_FIBER_SPACE/YT8521_RSSR_UTP_SPACE) to write.
674 *
675 * returns 0 or negative errno code
676 */
677static int yt8521_write_page(struct phy_device *phydev, int page)
678{
679 int mask = YT8521_RSSR_SPACE_MASK;
680 int set;
681
682 if ((page & YT8521_RSSR_SPACE_MASK) == YT8521_RSSR_FIBER_SPACE)
683 set = YT8521_RSSR_FIBER_SPACE;
684 else
685 set = YT8521_RSSR_UTP_SPACE;
686
687 return ytphy_modify_ext(phydev, YT8521_REG_SPACE_SELECT_REG, mask, set);
688};
689
690/**
691 * struct ytphy_cfg_reg_map - map a config value to a register value
692 * @cfg: value in device configuration
693 * @reg: value in the register
694 */
695struct ytphy_cfg_reg_map {
696 u32 cfg;
697 u32 reg;
698};
699
700static const struct ytphy_cfg_reg_map ytphy_rgmii_delays[] = {
701 /* for tx delay / rx delay with YT8521_CCR_RXC_DLY_EN is not set. */
702 { 0, YT8521_RC1R_RGMII_0_000_NS },
703 { 150, YT8521_RC1R_RGMII_0_150_NS },
704 { 300, YT8521_RC1R_RGMII_0_300_NS },
705 { 450, YT8521_RC1R_RGMII_0_450_NS },
706 { 600, YT8521_RC1R_RGMII_0_600_NS },
707 { 750, YT8521_RC1R_RGMII_0_750_NS },
708 { 900, YT8521_RC1R_RGMII_0_900_NS },
709 { 1050, YT8521_RC1R_RGMII_1_050_NS },
710 { 1200, YT8521_RC1R_RGMII_1_200_NS },
711 { 1350, YT8521_RC1R_RGMII_1_350_NS },
712 { 1500, YT8521_RC1R_RGMII_1_500_NS },
713 { 1650, YT8521_RC1R_RGMII_1_650_NS },
714 { 1800, YT8521_RC1R_RGMII_1_800_NS },
715 { 1950, YT8521_RC1R_RGMII_1_950_NS }, /* default tx/rx delay */
716 { 2100, YT8521_RC1R_RGMII_2_100_NS },
717 { 2250, YT8521_RC1R_RGMII_2_250_NS },
718
719 /* only for rx delay with YT8521_CCR_RXC_DLY_EN is set. */
720 { 0 + YT8521_CCR_RXC_DLY_1_900_NS, YT8521_RC1R_RGMII_0_000_NS },
721 { 150 + YT8521_CCR_RXC_DLY_1_900_NS, YT8521_RC1R_RGMII_0_150_NS },
722 { 300 + YT8521_CCR_RXC_DLY_1_900_NS, YT8521_RC1R_RGMII_0_300_NS },
723 { 450 + YT8521_CCR_RXC_DLY_1_900_NS, YT8521_RC1R_RGMII_0_450_NS },
724 { 600 + YT8521_CCR_RXC_DLY_1_900_NS, YT8521_RC1R_RGMII_0_600_NS },
725 { 750 + YT8521_CCR_RXC_DLY_1_900_NS, YT8521_RC1R_RGMII_0_750_NS },
726 { 900 + YT8521_CCR_RXC_DLY_1_900_NS, YT8521_RC1R_RGMII_0_900_NS },
727 { 1050 + YT8521_CCR_RXC_DLY_1_900_NS, YT8521_RC1R_RGMII_1_050_NS },
728 { 1200 + YT8521_CCR_RXC_DLY_1_900_NS, YT8521_RC1R_RGMII_1_200_NS },
729 { 1350 + YT8521_CCR_RXC_DLY_1_900_NS, YT8521_RC1R_RGMII_1_350_NS },
730 { 1500 + YT8521_CCR_RXC_DLY_1_900_NS, YT8521_RC1R_RGMII_1_500_NS },
731 { 1650 + YT8521_CCR_RXC_DLY_1_900_NS, YT8521_RC1R_RGMII_1_650_NS },
732 { 1800 + YT8521_CCR_RXC_DLY_1_900_NS, YT8521_RC1R_RGMII_1_800_NS },
733 { 1950 + YT8521_CCR_RXC_DLY_1_900_NS, YT8521_RC1R_RGMII_1_950_NS },
734 { 2100 + YT8521_CCR_RXC_DLY_1_900_NS, YT8521_RC1R_RGMII_2_100_NS },
735 { 2250 + YT8521_CCR_RXC_DLY_1_900_NS, YT8521_RC1R_RGMII_2_250_NS }
736};
737
738static u32 ytphy_get_delay_reg_value(struct phy_device *phydev,
739 const char *prop_name,
740 const struct ytphy_cfg_reg_map *tbl,
741 int tb_size,
742 u16 *rxc_dly_en,
743 u32 dflt)
744{
745 struct device_node *node = phydev->mdio.dev.of_node;
746 int tb_size_half = tb_size / 2;
747 u32 val;
748 int i;
749
750 if (of_property_read_u32(node, prop_name, &val))
751 goto err_dts_val;
752
753 /* when rxc_dly_en is NULL, it is get the delay for tx, only half of
754 * tb_size is valid.
755 */
756 if (!rxc_dly_en)
757 tb_size = tb_size_half;
758
759 for (i = 0; i < tb_size; i++) {
760 if (tbl[i].cfg == val) {
761 if (rxc_dly_en && i < tb_size_half)
762 *rxc_dly_en = 0;
763 return tbl[i].reg;
764 }
765 }
766
767 phydev_warn(phydev, "Unsupported value %d for %s using default (%u)\n",
768 val, prop_name, dflt);
769
770err_dts_val:
771 /* when rxc_dly_en is not NULL, it is get the delay for rx.
772 * The rx default in dts and ytphy_rgmii_clk_delay_config is 1950 ps,
773 * so YT8521_CCR_RXC_DLY_EN should not be set.
774 */
775 if (rxc_dly_en)
776 *rxc_dly_en = 0;
777
778 return dflt;
779}
780
781static int ytphy_rgmii_clk_delay_config(struct phy_device *phydev)
782{
783 int tb_size = ARRAY_SIZE(ytphy_rgmii_delays);
784 u16 rxc_dly_en = YT8521_CCR_RXC_DLY_EN;
785 u32 rx_reg, tx_reg;
786 u16 mask, val = 0;
787 int ret;
788
789 rx_reg = ytphy_get_delay_reg_value(phydev, "rx-internal-delay-ps",
790 ytphy_rgmii_delays, tb_size,
791 &rxc_dly_en,
792 YT8521_RC1R_RGMII_1_950_NS);
793 tx_reg = ytphy_get_delay_reg_value(phydev, "tx-internal-delay-ps",
794 ytphy_rgmii_delays, tb_size, NULL,
795 YT8521_RC1R_RGMII_1_950_NS);
796
797 switch (phydev->interface) {
798 case PHY_INTERFACE_MODE_RGMII:
799 rxc_dly_en = 0;
800 break;
801 case PHY_INTERFACE_MODE_RGMII_RXID:
802 val |= FIELD_PREP(YT8521_RC1R_RX_DELAY_MASK, rx_reg);
803 break;
804 case PHY_INTERFACE_MODE_RGMII_TXID:
805 rxc_dly_en = 0;
806 val |= FIELD_PREP(YT8521_RC1R_GE_TX_DELAY_MASK, tx_reg);
807 break;
808 case PHY_INTERFACE_MODE_RGMII_ID:
809 val |= FIELD_PREP(YT8521_RC1R_RX_DELAY_MASK, rx_reg) |
810 FIELD_PREP(YT8521_RC1R_GE_TX_DELAY_MASK, tx_reg);
811 break;
812 default: /* do not support other modes */
813 return -EOPNOTSUPP;
814 }
815
816 ret = ytphy_modify_ext(phydev, YT8521_CHIP_CONFIG_REG,
817 YT8521_CCR_RXC_DLY_EN, rxc_dly_en);
818 if (ret < 0)
819 return ret;
820
821 /* Generally, it is not necessary to adjust YT8521_RC1R_FE_TX_DELAY */
822 mask = YT8521_RC1R_RX_DELAY_MASK | YT8521_RC1R_GE_TX_DELAY_MASK;
823 return ytphy_modify_ext(phydev, YT8521_RGMII_CONFIG1_REG, mask, val);
824}
825
826static int ytphy_rgmii_clk_delay_config_with_lock(struct phy_device *phydev)
827{
828 int ret;
829
830 phy_lock_mdio_bus(phydev);
831 ret = ytphy_rgmii_clk_delay_config(phydev);
832 phy_unlock_mdio_bus(phydev);
833
834 return ret;
835}
836
837/**
838 * yt8521_probe() - read chip config then set suitable polling_mode
839 * @phydev: a pointer to a &struct phy_device
840 *
841 * returns 0 or negative errno code
842 */
843static int yt8521_probe(struct phy_device *phydev)
844{
845 struct device_node *node = phydev->mdio.dev.of_node;
846 struct device *dev = &phydev->mdio.dev;
847 struct yt8521_priv *priv;
848 int chip_config;
849 u16 mask, val;
850 u32 freq;
851 int ret;
852
853 priv = devm_kzalloc(dev, sizeof(*priv), GFP_KERNEL);
854 if (!priv)
855 return -ENOMEM;
856
857 phydev->priv = priv;
858
859 chip_config = ytphy_read_ext_with_lock(phydev, YT8521_CHIP_CONFIG_REG);
860 if (chip_config < 0)
861 return chip_config;
862
863 priv->strap_mode = chip_config & YT8521_CCR_MODE_SEL_MASK;
864 switch (priv->strap_mode) {
865 case YT8521_CCR_MODE_FIBER_TO_RGMII:
866 case YT8521_CCR_MODE_SGPHY_TO_RGMAC:
867 case YT8521_CCR_MODE_SGMAC_TO_RGPHY:
868 priv->polling_mode = YT8521_MODE_FIBER;
869 priv->reg_page = YT8521_RSSR_FIBER_SPACE;
870 phydev->port = PORT_FIBRE;
871 break;
872 case YT8521_CCR_MODE_UTP_FIBER_TO_RGMII:
873 case YT8521_CCR_MODE_UTP_TO_FIBER_AUTO:
874 case YT8521_CCR_MODE_UTP_TO_FIBER_FORCE:
875 priv->polling_mode = YT8521_MODE_POLL;
876 priv->reg_page = YT8521_RSSR_TO_BE_ARBITRATED;
877 phydev->port = PORT_NONE;
878 break;
879 case YT8521_CCR_MODE_UTP_TO_SGMII:
880 case YT8521_CCR_MODE_UTP_TO_RGMII:
881 priv->polling_mode = YT8521_MODE_UTP;
882 priv->reg_page = YT8521_RSSR_UTP_SPACE;
883 phydev->port = PORT_TP;
884 break;
885 }
886 /* set default reg space */
887 if (priv->reg_page != YT8521_RSSR_TO_BE_ARBITRATED) {
888 ret = ytphy_write_ext_with_lock(phydev,
889 YT8521_REG_SPACE_SELECT_REG,
890 priv->reg_page);
891 if (ret < 0)
892 return ret;
893 }
894
895 if (of_property_read_u32(node, "motorcomm,clk-out-frequency-hz", &freq))
896 freq = YTPHY_DTS_OUTPUT_CLK_DIS;
897
898 if (phydev->drv->phy_id == PHY_ID_YT8521) {
899 switch (freq) {
900 case YTPHY_DTS_OUTPUT_CLK_DIS:
901 mask = YT8521_SCR_SYNCE_ENABLE;
902 val = 0;
903 break;
904 case YTPHY_DTS_OUTPUT_CLK_25M:
905 mask = YT8521_SCR_SYNCE_ENABLE |
906 YT8521_SCR_CLK_SRC_MASK |
907 YT8521_SCR_CLK_FRE_SEL_125M;
908 val = YT8521_SCR_SYNCE_ENABLE |
909 FIELD_PREP(YT8521_SCR_CLK_SRC_MASK,
910 YT8521_SCR_CLK_SRC_REF_25M);
911 break;
912 case YTPHY_DTS_OUTPUT_CLK_125M:
913 mask = YT8521_SCR_SYNCE_ENABLE |
914 YT8521_SCR_CLK_SRC_MASK |
915 YT8521_SCR_CLK_FRE_SEL_125M;
916 val = YT8521_SCR_SYNCE_ENABLE |
917 YT8521_SCR_CLK_FRE_SEL_125M |
918 FIELD_PREP(YT8521_SCR_CLK_SRC_MASK,
919 YT8521_SCR_CLK_SRC_PLL_125M);
920 break;
921 default:
922 phydev_warn(phydev, "Freq err:%u\n", freq);
923 return -EINVAL;
924 }
925 } else if (phydev->drv->phy_id == PHY_ID_YT8531S) {
926 switch (freq) {
927 case YTPHY_DTS_OUTPUT_CLK_DIS:
928 mask = YT8531_SCR_SYNCE_ENABLE;
929 val = 0;
930 break;
931 case YTPHY_DTS_OUTPUT_CLK_25M:
932 mask = YT8531_SCR_SYNCE_ENABLE |
933 YT8531_SCR_CLK_SRC_MASK |
934 YT8531_SCR_CLK_FRE_SEL_125M;
935 val = YT8531_SCR_SYNCE_ENABLE |
936 FIELD_PREP(YT8531_SCR_CLK_SRC_MASK,
937 YT8531_SCR_CLK_SRC_REF_25M);
938 break;
939 case YTPHY_DTS_OUTPUT_CLK_125M:
940 mask = YT8531_SCR_SYNCE_ENABLE |
941 YT8531_SCR_CLK_SRC_MASK |
942 YT8531_SCR_CLK_FRE_SEL_125M;
943 val = YT8531_SCR_SYNCE_ENABLE |
944 YT8531_SCR_CLK_FRE_SEL_125M |
945 FIELD_PREP(YT8531_SCR_CLK_SRC_MASK,
946 YT8531_SCR_CLK_SRC_PLL_125M);
947 break;
948 default:
949 phydev_warn(phydev, "Freq err:%u\n", freq);
950 return -EINVAL;
951 }
952 } else {
953 phydev_warn(phydev, "PHY id err\n");
954 return -EINVAL;
955 }
956
957 return ytphy_modify_ext_with_lock(phydev, YTPHY_SYNCE_CFG_REG, mask,
958 val);
959}
960
961static int yt8531_probe(struct phy_device *phydev)
962{
963 struct device_node *node = phydev->mdio.dev.of_node;
964 u16 mask, val;
965 u32 freq;
966
967 if (of_property_read_u32(node, "motorcomm,clk-out-frequency-hz", &freq))
968 freq = YTPHY_DTS_OUTPUT_CLK_DIS;
969
970 switch (freq) {
971 case YTPHY_DTS_OUTPUT_CLK_DIS:
972 mask = YT8531_SCR_SYNCE_ENABLE;
973 val = 0;
974 break;
975 case YTPHY_DTS_OUTPUT_CLK_25M:
976 mask = YT8531_SCR_SYNCE_ENABLE | YT8531_SCR_CLK_SRC_MASK |
977 YT8531_SCR_CLK_FRE_SEL_125M;
978 val = YT8531_SCR_SYNCE_ENABLE |
979 FIELD_PREP(YT8531_SCR_CLK_SRC_MASK,
980 YT8531_SCR_CLK_SRC_REF_25M);
981 break;
982 case YTPHY_DTS_OUTPUT_CLK_125M:
983 mask = YT8531_SCR_SYNCE_ENABLE | YT8531_SCR_CLK_SRC_MASK |
984 YT8531_SCR_CLK_FRE_SEL_125M;
985 val = YT8531_SCR_SYNCE_ENABLE | YT8531_SCR_CLK_FRE_SEL_125M |
986 FIELD_PREP(YT8531_SCR_CLK_SRC_MASK,
987 YT8531_SCR_CLK_SRC_PLL_125M);
988 break;
989 default:
990 phydev_warn(phydev, "Freq err:%u\n", freq);
991 return -EINVAL;
992 }
993
994 return ytphy_modify_ext_with_lock(phydev, YTPHY_SYNCE_CFG_REG, mask,
995 val);
996}
997
998/**
999 * ytphy_utp_read_lpa() - read LPA then setup lp_advertising for utp
1000 * @phydev: a pointer to a &struct phy_device
1001 *
1002 * NOTE:The caller must have taken the MDIO bus lock.
1003 *
1004 * returns 0 or negative errno code
1005 */
1006static int ytphy_utp_read_lpa(struct phy_device *phydev)
1007{
1008 int lpa, lpagb;
1009
1010 if (phydev->autoneg == AUTONEG_ENABLE) {
1011 if (!phydev->autoneg_complete) {
1012 mii_stat1000_mod_linkmode_lpa_t(phydev->lp_advertising,
1013 0);
1014 mii_lpa_mod_linkmode_lpa_t(phydev->lp_advertising, 0);
1015 return 0;
1016 }
1017
1018 if (phydev->is_gigabit_capable) {
1019 lpagb = __phy_read(phydev, MII_STAT1000);
1020 if (lpagb < 0)
1021 return lpagb;
1022
1023 if (lpagb & LPA_1000MSFAIL) {
1024 int adv = __phy_read(phydev, MII_CTRL1000);
1025
1026 if (adv < 0)
1027 return adv;
1028
1029 if (adv & CTL1000_ENABLE_MASTER)
1030 phydev_err(phydev, "Master/Slave resolution failed, maybe conflicting manual settings?\n");
1031 else
1032 phydev_err(phydev, "Master/Slave resolution failed\n");
1033 return -ENOLINK;
1034 }
1035
1036 mii_stat1000_mod_linkmode_lpa_t(phydev->lp_advertising,
1037 lpagb);
1038 }
1039
1040 lpa = __phy_read(phydev, MII_LPA);
1041 if (lpa < 0)
1042 return lpa;
1043
1044 mii_lpa_mod_linkmode_lpa_t(phydev->lp_advertising, lpa);
1045 } else {
1046 linkmode_zero(phydev->lp_advertising);
1047 }
1048
1049 return 0;
1050}
1051
1052/**
1053 * yt8521_adjust_status() - update speed and duplex to phydev. when in fiber
1054 * mode, adjust speed and duplex.
1055 * @phydev: a pointer to a &struct phy_device
1056 * @status: yt8521 status read from YTPHY_SPECIFIC_STATUS_REG
1057 * @is_utp: false(yt8521 work in fiber mode) or true(yt8521 work in utp mode)
1058 *
1059 * NOTE:The caller must have taken the MDIO bus lock.
1060 *
1061 * returns 0
1062 */
1063static int yt8521_adjust_status(struct phy_device *phydev, int status,
1064 bool is_utp)
1065{
1066 int speed_mode, duplex;
1067 int speed;
1068 int err;
1069 int lpa;
1070
1071 if (is_utp)
1072 duplex = (status & YTPHY_SSR_DUPLEX) >> YTPHY_SSR_DUPLEX_OFFSET;
1073 else
1074 duplex = DUPLEX_FULL; /* for fiber, it always DUPLEX_FULL */
1075
1076 speed_mode = (status & YTPHY_SSR_SPEED_MODE_MASK) >>
1077 YTPHY_SSR_SPEED_MODE_OFFSET;
1078
1079 switch (speed_mode) {
1080 case YTPHY_SSR_SPEED_10M:
1081 if (is_utp)
1082 speed = SPEED_10;
1083 else
1084 /* for fiber, it will never run here, default to
1085 * SPEED_UNKNOWN
1086 */
1087 speed = SPEED_UNKNOWN;
1088 break;
1089 case YTPHY_SSR_SPEED_100M:
1090 speed = SPEED_100;
1091 break;
1092 case YTPHY_SSR_SPEED_1000M:
1093 speed = SPEED_1000;
1094 break;
1095 default:
1096 speed = SPEED_UNKNOWN;
1097 break;
1098 }
1099
1100 phydev->speed = speed;
1101 phydev->duplex = duplex;
1102
1103 if (is_utp) {
1104 err = ytphy_utp_read_lpa(phydev);
1105 if (err < 0)
1106 return err;
1107
1108 phy_resolve_aneg_pause(phydev);
1109 } else {
1110 lpa = __phy_read(phydev, MII_LPA);
1111 if (lpa < 0)
1112 return lpa;
1113
1114 /* only support 1000baseX Full */
1115 linkmode_mod_bit(ETHTOOL_LINK_MODE_1000baseX_Full_BIT,
1116 phydev->lp_advertising, lpa & LPA_1000XFULL);
1117
1118 if (!(lpa & YTPHY_FLPA_PAUSE)) {
1119 phydev->pause = 0;
1120 phydev->asym_pause = 0;
1121 } else if ((lpa & YTPHY_FLPA_ASYM_PAUSE)) {
1122 phydev->pause = 1;
1123 phydev->asym_pause = 1;
1124 } else {
1125 phydev->pause = 1;
1126 phydev->asym_pause = 0;
1127 }
1128 }
1129
1130 return 0;
1131}
1132
1133/**
1134 * yt8521_read_status_paged() - determines the speed and duplex of one page
1135 * @phydev: a pointer to a &struct phy_device
1136 * @page: The reg page(YT8521_RSSR_FIBER_SPACE/YT8521_RSSR_UTP_SPACE) to
1137 * operate.
1138 *
1139 * returns 1 (utp or fiber link),0 (no link) or negative errno code
1140 */
1141static int yt8521_read_status_paged(struct phy_device *phydev, int page)
1142{
1143 int fiber_latch_val;
1144 int fiber_curr_val;
1145 int old_page;
1146 int ret = 0;
1147 int status;
1148 int link;
1149
1150 linkmode_zero(phydev->lp_advertising);
1151 phydev->duplex = DUPLEX_UNKNOWN;
1152 phydev->speed = SPEED_UNKNOWN;
1153 phydev->asym_pause = 0;
1154 phydev->pause = 0;
1155
1156 /* YT8521 has two reg space (utp/fiber) for linkup with utp/fiber
1157 * respectively. but for utp/fiber combo mode, reg space should be
1158 * arbitrated based on media priority. by default, utp takes
1159 * priority. reg space should be properly set before read
1160 * YTPHY_SPECIFIC_STATUS_REG.
1161 */
1162
1163 page &= YT8521_RSSR_SPACE_MASK;
1164 old_page = phy_select_page(phydev, page);
1165 if (old_page < 0)
1166 goto err_restore_page;
1167
1168 /* Read YTPHY_SPECIFIC_STATUS_REG, which indicates the speed and duplex
1169 * of the PHY is actually using.
1170 */
1171 ret = __phy_read(phydev, YTPHY_SPECIFIC_STATUS_REG);
1172 if (ret < 0)
1173 goto err_restore_page;
1174
1175 status = ret;
1176 link = !!(status & YTPHY_SSR_LINK);
1177
1178 /* When PHY is in fiber mode, speed transferred from 1000Mbps to
1179 * 100Mbps,there is not link down from YTPHY_SPECIFIC_STATUS_REG, so
1180 * we need check MII_BMSR to identify such case.
1181 */
1182 if (page == YT8521_RSSR_FIBER_SPACE) {
1183 ret = __phy_read(phydev, MII_BMSR);
1184 if (ret < 0)
1185 goto err_restore_page;
1186
1187 fiber_latch_val = ret;
1188 ret = __phy_read(phydev, MII_BMSR);
1189 if (ret < 0)
1190 goto err_restore_page;
1191
1192 fiber_curr_val = ret;
1193 if (link && fiber_latch_val != fiber_curr_val) {
1194 link = 0;
1195 phydev_info(phydev,
1196 "%s, fiber link down detect, latch = %04x, curr = %04x\n",
1197 __func__, fiber_latch_val, fiber_curr_val);
1198 }
1199 } else {
1200 /* Read autonegotiation status */
1201 ret = __phy_read(phydev, MII_BMSR);
1202 if (ret < 0)
1203 goto err_restore_page;
1204
1205 phydev->autoneg_complete = ret & BMSR_ANEGCOMPLETE ? 1 : 0;
1206 }
1207
1208 if (link) {
1209 if (page == YT8521_RSSR_UTP_SPACE)
1210 yt8521_adjust_status(phydev, status, true);
1211 else
1212 yt8521_adjust_status(phydev, status, false);
1213 }
1214 return phy_restore_page(phydev, old_page, link);
1215
1216err_restore_page:
1217 return phy_restore_page(phydev, old_page, ret);
1218}
1219
1220/**
1221 * yt8521_read_status() - determines the negotiated speed and duplex
1222 * @phydev: a pointer to a &struct phy_device
1223 *
1224 * returns 0 or negative errno code
1225 */
1226static int yt8521_read_status(struct phy_device *phydev)
1227{
1228 struct yt8521_priv *priv = phydev->priv;
1229 int link_fiber = 0;
1230 int link_utp;
1231 int link;
1232 int ret;
1233
1234 if (priv->reg_page != YT8521_RSSR_TO_BE_ARBITRATED) {
1235 link = yt8521_read_status_paged(phydev, priv->reg_page);
1236 if (link < 0)
1237 return link;
1238 } else {
1239 /* when page is YT8521_RSSR_TO_BE_ARBITRATED, arbitration is
1240 * needed. by default, utp is higher priority.
1241 */
1242
1243 link_utp = yt8521_read_status_paged(phydev,
1244 YT8521_RSSR_UTP_SPACE);
1245 if (link_utp < 0)
1246 return link_utp;
1247
1248 if (!link_utp) {
1249 link_fiber = yt8521_read_status_paged(phydev,
1250 YT8521_RSSR_FIBER_SPACE);
1251 if (link_fiber < 0)
1252 return link_fiber;
1253 }
1254
1255 link = link_utp || link_fiber;
1256 }
1257
1258 if (link) {
1259 if (phydev->link == 0) {
1260 /* arbitrate reg space based on linkup media type. */
1261 if (priv->polling_mode == YT8521_MODE_POLL &&
1262 priv->reg_page == YT8521_RSSR_TO_BE_ARBITRATED) {
1263 if (link_fiber)
1264 priv->reg_page =
1265 YT8521_RSSR_FIBER_SPACE;
1266 else
1267 priv->reg_page = YT8521_RSSR_UTP_SPACE;
1268
1269 ret = ytphy_write_ext_with_lock(phydev,
1270 YT8521_REG_SPACE_SELECT_REG,
1271 priv->reg_page);
1272 if (ret < 0)
1273 return ret;
1274
1275 phydev->port = link_fiber ? PORT_FIBRE : PORT_TP;
1276
1277 phydev_info(phydev, "%s, link up, media: %s\n",
1278 __func__,
1279 (phydev->port == PORT_TP) ?
1280 "UTP" : "Fiber");
1281 }
1282 }
1283 phydev->link = 1;
1284 } else {
1285 if (phydev->link == 1) {
1286 phydev_info(phydev, "%s, link down, media: %s\n",
1287 __func__, (phydev->port == PORT_TP) ?
1288 "UTP" : "Fiber");
1289
1290 /* When in YT8521_MODE_POLL mode, need prepare for next
1291 * arbitration.
1292 */
1293 if (priv->polling_mode == YT8521_MODE_POLL) {
1294 priv->reg_page = YT8521_RSSR_TO_BE_ARBITRATED;
1295 phydev->port = PORT_NONE;
1296 }
1297 }
1298
1299 phydev->link = 0;
1300 }
1301
1302 return 0;
1303}
1304
1305/**
1306 * yt8521_modify_bmcr_paged - bits modify a PHY's BMCR register of one page
1307 * @phydev: the phy_device struct
1308 * @page: The reg page(YT8521_RSSR_FIBER_SPACE/YT8521_RSSR_UTP_SPACE) to operate
1309 * @mask: bit mask of bits to clear
1310 * @set: bit mask of bits to set
1311 *
1312 * NOTE: Convenience function which allows a PHY's BMCR register to be
1313 * modified as new register value = (old register value & ~mask) | set.
1314 * YT8521 has two space (utp/fiber) and three mode (utp/fiber/poll), each space
1315 * has MII_BMCR. poll mode combines utp and faber,so need do both.
1316 * If it is reset, it will wait for completion.
1317 *
1318 * returns 0 or negative errno code
1319 */
1320static int yt8521_modify_bmcr_paged(struct phy_device *phydev, int page,
1321 u16 mask, u16 set)
1322{
1323 int max_cnt = 500; /* the max wait time of reset ~ 500 ms */
1324 int old_page;
1325 int ret = 0;
1326
1327 old_page = phy_select_page(phydev, page & YT8521_RSSR_SPACE_MASK);
1328 if (old_page < 0)
1329 goto err_restore_page;
1330
1331 ret = __phy_modify(phydev, MII_BMCR, mask, set);
1332 if (ret < 0)
1333 goto err_restore_page;
1334
1335 /* If it is reset, need to wait for the reset to complete */
1336 if (set == BMCR_RESET) {
1337 while (max_cnt--) {
1338 usleep_range(1000, 1100);
1339 ret = __phy_read(phydev, MII_BMCR);
1340 if (ret < 0)
1341 goto err_restore_page;
1342
1343 if (!(ret & BMCR_RESET))
1344 return phy_restore_page(phydev, old_page, 0);
1345 }
1346 }
1347
1348err_restore_page:
1349 return phy_restore_page(phydev, old_page, ret);
1350}
1351
1352/**
1353 * yt8521_modify_utp_fiber_bmcr - bits modify a PHY's BMCR register
1354 * @phydev: the phy_device struct
1355 * @mask: bit mask of bits to clear
1356 * @set: bit mask of bits to set
1357 *
1358 * NOTE: Convenience function which allows a PHY's BMCR register to be
1359 * modified as new register value = (old register value & ~mask) | set.
1360 * YT8521 has two space (utp/fiber) and three mode (utp/fiber/poll), each space
1361 * has MII_BMCR. poll mode combines utp and faber,so need do both.
1362 *
1363 * returns 0 or negative errno code
1364 */
1365static int yt8521_modify_utp_fiber_bmcr(struct phy_device *phydev, u16 mask,
1366 u16 set)
1367{
1368 struct yt8521_priv *priv = phydev->priv;
1369 int ret;
1370
1371 if (priv->reg_page != YT8521_RSSR_TO_BE_ARBITRATED) {
1372 ret = yt8521_modify_bmcr_paged(phydev, priv->reg_page, mask,
1373 set);
1374 if (ret < 0)
1375 return ret;
1376 } else {
1377 ret = yt8521_modify_bmcr_paged(phydev, YT8521_RSSR_UTP_SPACE,
1378 mask, set);
1379 if (ret < 0)
1380 return ret;
1381
1382 ret = yt8521_modify_bmcr_paged(phydev, YT8521_RSSR_FIBER_SPACE,
1383 mask, set);
1384 if (ret < 0)
1385 return ret;
1386 }
1387 return 0;
1388}
1389
1390/**
1391 * yt8521_soft_reset() - called to issue a PHY software reset
1392 * @phydev: a pointer to a &struct phy_device
1393 *
1394 * returns 0 or negative errno code
1395 */
1396static int yt8521_soft_reset(struct phy_device *phydev)
1397{
1398 return yt8521_modify_utp_fiber_bmcr(phydev, 0, BMCR_RESET);
1399}
1400
1401/**
1402 * yt8521_suspend() - suspend the hardware
1403 * @phydev: a pointer to a &struct phy_device
1404 *
1405 * returns 0 or negative errno code
1406 */
1407static int yt8521_suspend(struct phy_device *phydev)
1408{
1409 int wol_config;
1410
1411 /* YTPHY_WOL_CONFIG_REG is common ext reg */
1412 wol_config = ytphy_read_ext_with_lock(phydev, YTPHY_WOL_CONFIG_REG);
1413 if (wol_config < 0)
1414 return wol_config;
1415
1416 /* if wol enable, do nothing */
1417 if (wol_config & YTPHY_WCR_ENABLE)
1418 return 0;
1419
1420 return yt8521_modify_utp_fiber_bmcr(phydev, 0, BMCR_PDOWN);
1421}
1422
1423/**
1424 * yt8521_resume() - resume the hardware
1425 * @phydev: a pointer to a &struct phy_device
1426 *
1427 * returns 0 or negative errno code
1428 */
1429static int yt8521_resume(struct phy_device *phydev)
1430{
1431 int ret;
1432 int wol_config;
1433
1434 /* disable auto sleep */
1435 ret = ytphy_modify_ext_with_lock(phydev,
1436 YT8521_EXTREG_SLEEP_CONTROL1_REG,
1437 YT8521_ESC1R_SLEEP_SW, 0);
1438 if (ret < 0)
1439 return ret;
1440
1441 wol_config = ytphy_read_ext_with_lock(phydev, YTPHY_WOL_CONFIG_REG);
1442 if (wol_config < 0)
1443 return wol_config;
1444
1445 /* if wol enable, do nothing */
1446 if (wol_config & YTPHY_WCR_ENABLE)
1447 return 0;
1448
1449 return yt8521_modify_utp_fiber_bmcr(phydev, BMCR_PDOWN, 0);
1450}
1451
1452/**
1453 * yt8521_config_init() - called to initialize the PHY
1454 * @phydev: a pointer to a &struct phy_device
1455 *
1456 * returns 0 or negative errno code
1457 */
1458static int yt8521_config_init(struct phy_device *phydev)
1459{
1460 struct device_node *node = phydev->mdio.dev.of_node;
1461 int old_page;
1462 int ret = 0;
1463
1464 old_page = phy_select_page(phydev, YT8521_RSSR_UTP_SPACE);
1465 if (old_page < 0)
1466 goto err_restore_page;
1467
1468 /* set rgmii delay mode */
1469 if (phydev->interface != PHY_INTERFACE_MODE_SGMII) {
1470 ret = ytphy_rgmii_clk_delay_config(phydev);
1471 if (ret < 0)
1472 goto err_restore_page;
1473 }
1474
1475 if (of_property_read_bool(node, "motorcomm,auto-sleep-disabled")) {
1476 /* disable auto sleep */
1477 ret = ytphy_modify_ext(phydev, YT8521_EXTREG_SLEEP_CONTROL1_REG,
1478 YT8521_ESC1R_SLEEP_SW, 0);
1479 if (ret < 0)
1480 goto err_restore_page;
1481 }
1482
1483 if (of_property_read_bool(node, "motorcomm,keep-pll-enabled")) {
1484 /* enable RXC clock when no wire plug */
1485 ret = ytphy_modify_ext(phydev, YT8521_CLOCK_GATING_REG,
1486 YT8521_CGR_RX_CLK_EN, 0);
1487 if (ret < 0)
1488 goto err_restore_page;
1489 }
1490err_restore_page:
1491 return phy_restore_page(phydev, old_page, ret);
1492}
1493
1494static int yt8531_config_init(struct phy_device *phydev)
1495{
1496 struct device_node *node = phydev->mdio.dev.of_node;
1497 int ret;
1498
1499 ret = ytphy_rgmii_clk_delay_config_with_lock(phydev);
1500 if (ret < 0)
1501 return ret;
1502
1503 if (of_property_read_bool(node, "motorcomm,auto-sleep-disabled")) {
1504 /* disable auto sleep */
1505 ret = ytphy_modify_ext_with_lock(phydev,
1506 YT8521_EXTREG_SLEEP_CONTROL1_REG,
1507 YT8521_ESC1R_SLEEP_SW, 0);
1508 if (ret < 0)
1509 return ret;
1510 }
1511
1512 if (of_property_read_bool(node, "motorcomm,keep-pll-enabled")) {
1513 /* enable RXC clock when no wire plug */
1514 ret = ytphy_modify_ext_with_lock(phydev,
1515 YT8521_CLOCK_GATING_REG,
1516 YT8521_CGR_RX_CLK_EN, 0);
1517 if (ret < 0)
1518 return ret;
1519 }
1520
1521 return 0;
1522}
1523
1524/**
1525 * yt8531_link_change_notify() - Adjust the tx clock direction according to
1526 * the current speed and dts config.
1527 * @phydev: a pointer to a &struct phy_device
1528 *
1529 * NOTE: This function is only used to adapt to VF2 with JH7110 SoC. Please
1530 * keep "motorcomm,tx-clk-adj-enabled" not exist in dts when the soc is not
1531 * JH7110.
1532 */
1533static void yt8531_link_change_notify(struct phy_device *phydev)
1534{
1535 struct device_node *node = phydev->mdio.dev.of_node;
1536 bool tx_clk_1000_inverted = false;
1537 bool tx_clk_100_inverted = false;
1538 bool tx_clk_10_inverted = false;
1539 bool tx_clk_adj_enabled = false;
1540 u16 val = 0;
1541 int ret;
1542
1543 if (of_property_read_bool(node, "motorcomm,tx-clk-adj-enabled"))
1544 tx_clk_adj_enabled = true;
1545
1546 if (!tx_clk_adj_enabled)
1547 return;
1548
1549 if (of_property_read_bool(node, "motorcomm,tx-clk-10-inverted"))
1550 tx_clk_10_inverted = true;
1551 if (of_property_read_bool(node, "motorcomm,tx-clk-100-inverted"))
1552 tx_clk_100_inverted = true;
1553 if (of_property_read_bool(node, "motorcomm,tx-clk-1000-inverted"))
1554 tx_clk_1000_inverted = true;
1555
1556 if (phydev->speed < 0)
1557 return;
1558
1559 switch (phydev->speed) {
1560 case SPEED_1000:
1561 if (tx_clk_1000_inverted)
1562 val = YT8521_RC1R_TX_CLK_SEL_INVERTED;
1563 break;
1564 case SPEED_100:
1565 if (tx_clk_100_inverted)
1566 val = YT8521_RC1R_TX_CLK_SEL_INVERTED;
1567 break;
1568 case SPEED_10:
1569 if (tx_clk_10_inverted)
1570 val = YT8521_RC1R_TX_CLK_SEL_INVERTED;
1571 break;
1572 default:
1573 return;
1574 }
1575
1576 ret = ytphy_modify_ext_with_lock(phydev, YT8521_RGMII_CONFIG1_REG,
1577 YT8521_RC1R_TX_CLK_SEL_INVERTED, val);
1578 if (ret < 0)
1579 phydev_warn(phydev, "Modify TX_CLK_SEL err:%d\n", ret);
1580}
1581
1582/**
1583 * yt8521_prepare_fiber_features() - A small helper function that setup
1584 * fiber's features.
1585 * @phydev: a pointer to a &struct phy_device
1586 * @dst: a pointer to store fiber's features
1587 */
1588static void yt8521_prepare_fiber_features(struct phy_device *phydev,
1589 unsigned long *dst)
1590{
1591 linkmode_set_bit(ETHTOOL_LINK_MODE_100baseFX_Full_BIT, dst);
1592 linkmode_set_bit(ETHTOOL_LINK_MODE_1000baseX_Full_BIT, dst);
1593 linkmode_set_bit(ETHTOOL_LINK_MODE_Autoneg_BIT, dst);
1594 linkmode_set_bit(ETHTOOL_LINK_MODE_FIBRE_BIT, dst);
1595}
1596
1597/**
1598 * yt8521_fiber_setup_forced - configures/forces speed from @phydev
1599 * @phydev: target phy_device struct
1600 *
1601 * NOTE:The caller must have taken the MDIO bus lock.
1602 *
1603 * returns 0 or negative errno code
1604 */
1605static int yt8521_fiber_setup_forced(struct phy_device *phydev)
1606{
1607 u16 val;
1608 int ret;
1609
1610 if (phydev->speed == SPEED_1000)
1611 val = YTPHY_MCR_FIBER_1000BX;
1612 else if (phydev->speed == SPEED_100)
1613 val = YTPHY_MCR_FIBER_100FX;
1614 else
1615 return -EINVAL;
1616
1617 ret = __phy_modify(phydev, MII_BMCR, BMCR_ANENABLE, 0);
1618 if (ret < 0)
1619 return ret;
1620
1621 /* disable Fiber auto sensing */
1622 ret = ytphy_modify_ext(phydev, YT8521_LINK_TIMER_CFG2_REG,
1623 YT8521_LTCR_EN_AUTOSEN, 0);
1624 if (ret < 0)
1625 return ret;
1626
1627 ret = ytphy_modify_ext(phydev, YTPHY_MISC_CONFIG_REG,
1628 YTPHY_MCR_FIBER_SPEED_MASK, val);
1629 if (ret < 0)
1630 return ret;
1631
1632 return ytphy_modify_ext(phydev, YT8521_CHIP_CONFIG_REG,
1633 YT8521_CCR_SW_RST, 0);
1634}
1635
1636/**
1637 * ytphy_check_and_restart_aneg - Enable and restart auto-negotiation
1638 * @phydev: target phy_device struct
1639 * @restart: whether aneg restart is requested
1640 *
1641 * NOTE:The caller must have taken the MDIO bus lock.
1642 *
1643 * returns 0 or negative errno code
1644 */
1645static int ytphy_check_and_restart_aneg(struct phy_device *phydev, bool restart)
1646{
1647 int ret;
1648
1649 if (!restart) {
1650 /* Advertisement hasn't changed, but maybe aneg was never on to
1651 * begin with? Or maybe phy was isolated?
1652 */
1653 ret = __phy_read(phydev, MII_BMCR);
1654 if (ret < 0)
1655 return ret;
1656
1657 if (!(ret & BMCR_ANENABLE) || (ret & BMCR_ISOLATE))
1658 restart = true;
1659 }
1660 /* Enable and Restart Autonegotiation
1661 * Don't isolate the PHY if we're negotiating
1662 */
1663 if (restart)
1664 return __phy_modify(phydev, MII_BMCR, BMCR_ISOLATE,
1665 BMCR_ANENABLE | BMCR_ANRESTART);
1666
1667 return 0;
1668}
1669
1670/**
1671 * yt8521_fiber_config_aneg - restart auto-negotiation or write
1672 * YTPHY_MISC_CONFIG_REG.
1673 * @phydev: target phy_device struct
1674 *
1675 * NOTE:The caller must have taken the MDIO bus lock.
1676 *
1677 * returns 0 or negative errno code
1678 */
1679static int yt8521_fiber_config_aneg(struct phy_device *phydev)
1680{
1681 int err, changed = 0;
1682 int bmcr;
1683 u16 adv;
1684
1685 if (phydev->autoneg != AUTONEG_ENABLE)
1686 return yt8521_fiber_setup_forced(phydev);
1687
1688 /* enable Fiber auto sensing */
1689 err = ytphy_modify_ext(phydev, YT8521_LINK_TIMER_CFG2_REG,
1690 0, YT8521_LTCR_EN_AUTOSEN);
1691 if (err < 0)
1692 return err;
1693
1694 err = ytphy_modify_ext(phydev, YT8521_CHIP_CONFIG_REG,
1695 YT8521_CCR_SW_RST, 0);
1696 if (err < 0)
1697 return err;
1698
1699 bmcr = __phy_read(phydev, MII_BMCR);
1700 if (bmcr < 0)
1701 return bmcr;
1702
1703 /* When it is coming from fiber forced mode, add bmcr power down
1704 * and power up to let aneg work fine.
1705 */
1706 if (!(bmcr & BMCR_ANENABLE)) {
1707 __phy_modify(phydev, MII_BMCR, 0, BMCR_PDOWN);
1708 usleep_range(1000, 1100);
1709 __phy_modify(phydev, MII_BMCR, BMCR_PDOWN, 0);
1710 }
1711
1712 adv = linkmode_adv_to_mii_adv_x(phydev->advertising,
1713 ETHTOOL_LINK_MODE_1000baseX_Full_BIT);
1714
1715 /* Setup fiber advertisement */
1716 err = __phy_modify_changed(phydev, MII_ADVERTISE,
1717 ADVERTISE_1000XHALF | ADVERTISE_1000XFULL |
1718 ADVERTISE_1000XPAUSE |
1719 ADVERTISE_1000XPSE_ASYM,
1720 adv);
1721 if (err < 0)
1722 return err;
1723
1724 if (err > 0)
1725 changed = 1;
1726
1727 return ytphy_check_and_restart_aneg(phydev, changed);
1728}
1729
1730/**
1731 * ytphy_setup_master_slave
1732 * @phydev: target phy_device struct
1733 *
1734 * NOTE: The caller must have taken the MDIO bus lock.
1735 *
1736 * returns 0 or negative errno code
1737 */
1738static int ytphy_setup_master_slave(struct phy_device *phydev)
1739{
1740 u16 ctl = 0;
1741
1742 if (!phydev->is_gigabit_capable)
1743 return 0;
1744
1745 switch (phydev->master_slave_set) {
1746 case MASTER_SLAVE_CFG_MASTER_PREFERRED:
1747 ctl |= CTL1000_PREFER_MASTER;
1748 break;
1749 case MASTER_SLAVE_CFG_SLAVE_PREFERRED:
1750 break;
1751 case MASTER_SLAVE_CFG_MASTER_FORCE:
1752 ctl |= CTL1000_AS_MASTER;
1753 fallthrough;
1754 case MASTER_SLAVE_CFG_SLAVE_FORCE:
1755 ctl |= CTL1000_ENABLE_MASTER;
1756 break;
1757 case MASTER_SLAVE_CFG_UNKNOWN:
1758 case MASTER_SLAVE_CFG_UNSUPPORTED:
1759 return 0;
1760 default:
1761 phydev_warn(phydev, "Unsupported Master/Slave mode\n");
1762 return -EOPNOTSUPP;
1763 }
1764
1765 return __phy_modify_changed(phydev, MII_CTRL1000,
1766 (CTL1000_ENABLE_MASTER | CTL1000_AS_MASTER |
1767 CTL1000_PREFER_MASTER), ctl);
1768}
1769
1770/**
1771 * ytphy_utp_config_advert - sanitize and advertise auto-negotiation parameters
1772 * @phydev: target phy_device struct
1773 *
1774 * NOTE: Writes MII_ADVERTISE with the appropriate values,
1775 * after sanitizing the values to make sure we only advertise
1776 * what is supported. Returns < 0 on error, 0 if the PHY's advertisement
1777 * hasn't changed, and > 0 if it has changed.
1778 * The caller must have taken the MDIO bus lock.
1779 *
1780 * returns 0 or negative errno code
1781 */
1782static int ytphy_utp_config_advert(struct phy_device *phydev)
1783{
1784 int err, bmsr, changed = 0;
1785 u32 adv;
1786
1787 /* Only allow advertising what this PHY supports */
1788 linkmode_and(phydev->advertising, phydev->advertising,
1789 phydev->supported);
1790
1791 adv = linkmode_adv_to_mii_adv_t(phydev->advertising);
1792
1793 /* Setup standard advertisement */
1794 err = __phy_modify_changed(phydev, MII_ADVERTISE,
1795 ADVERTISE_ALL | ADVERTISE_100BASE4 |
1796 ADVERTISE_PAUSE_CAP | ADVERTISE_PAUSE_ASYM,
1797 adv);
1798 if (err < 0)
1799 return err;
1800 if (err > 0)
1801 changed = 1;
1802
1803 bmsr = __phy_read(phydev, MII_BMSR);
1804 if (bmsr < 0)
1805 return bmsr;
1806
1807 /* Per 802.3-2008, Section 22.2.4.2.16 Extended status all
1808 * 1000Mbits/sec capable PHYs shall have the BMSR_ESTATEN bit set to a
1809 * logical 1.
1810 */
1811 if (!(bmsr & BMSR_ESTATEN))
1812 return changed;
1813
1814 adv = linkmode_adv_to_mii_ctrl1000_t(phydev->advertising);
1815
1816 err = __phy_modify_changed(phydev, MII_CTRL1000,
1817 ADVERTISE_1000FULL | ADVERTISE_1000HALF,
1818 adv);
1819 if (err < 0)
1820 return err;
1821 if (err > 0)
1822 changed = 1;
1823
1824 return changed;
1825}
1826
1827/**
1828 * ytphy_utp_config_aneg - restart auto-negotiation or write BMCR
1829 * @phydev: target phy_device struct
1830 * @changed: whether autoneg is requested
1831 *
1832 * NOTE: If auto-negotiation is enabled, we configure the
1833 * advertising, and then restart auto-negotiation. If it is not
1834 * enabled, then we write the BMCR.
1835 * The caller must have taken the MDIO bus lock.
1836 *
1837 * returns 0 or negative errno code
1838 */
1839static int ytphy_utp_config_aneg(struct phy_device *phydev, bool changed)
1840{
1841 int err;
1842 u16 ctl;
1843
1844 err = ytphy_setup_master_slave(phydev);
1845 if (err < 0)
1846 return err;
1847 else if (err)
1848 changed = true;
1849
1850 if (phydev->autoneg != AUTONEG_ENABLE) {
1851 /* configures/forces speed/duplex from @phydev */
1852
1853 ctl = mii_bmcr_encode_fixed(phydev->speed, phydev->duplex);
1854
1855 return __phy_modify(phydev, MII_BMCR, ~(BMCR_LOOPBACK |
1856 BMCR_ISOLATE | BMCR_PDOWN), ctl);
1857 }
1858
1859 err = ytphy_utp_config_advert(phydev);
1860 if (err < 0) /* error */
1861 return err;
1862 else if (err)
1863 changed = true;
1864
1865 return ytphy_check_and_restart_aneg(phydev, changed);
1866}
1867
1868/**
1869 * yt8521_config_aneg_paged() - switch reg space then call genphy_config_aneg
1870 * of one page
1871 * @phydev: a pointer to a &struct phy_device
1872 * @page: The reg page(YT8521_RSSR_FIBER_SPACE/YT8521_RSSR_UTP_SPACE) to
1873 * operate.
1874 *
1875 * returns 0 or negative errno code
1876 */
1877static int yt8521_config_aneg_paged(struct phy_device *phydev, int page)
1878{
1879 __ETHTOOL_DECLARE_LINK_MODE_MASK(fiber_supported);
1880 struct yt8521_priv *priv = phydev->priv;
1881 int old_page;
1882 int ret = 0;
1883
1884 page &= YT8521_RSSR_SPACE_MASK;
1885
1886 old_page = phy_select_page(phydev, page);
1887 if (old_page < 0)
1888 goto err_restore_page;
1889
1890 /* If reg_page is YT8521_RSSR_TO_BE_ARBITRATED,
1891 * phydev->advertising should be updated.
1892 */
1893 if (priv->reg_page == YT8521_RSSR_TO_BE_ARBITRATED) {
1894 linkmode_zero(fiber_supported);
1895 yt8521_prepare_fiber_features(phydev, fiber_supported);
1896
1897 /* prepare fiber_supported, then setup advertising. */
1898 if (page == YT8521_RSSR_FIBER_SPACE) {
1899 linkmode_set_bit(ETHTOOL_LINK_MODE_Pause_BIT,
1900 fiber_supported);
1901 linkmode_set_bit(ETHTOOL_LINK_MODE_Asym_Pause_BIT,
1902 fiber_supported);
1903 linkmode_and(phydev->advertising,
1904 priv->combo_advertising, fiber_supported);
1905 } else {
1906 /* ETHTOOL_LINK_MODE_Autoneg_BIT is also used in utp */
1907 linkmode_clear_bit(ETHTOOL_LINK_MODE_Autoneg_BIT,
1908 fiber_supported);
1909 linkmode_andnot(phydev->advertising,
1910 priv->combo_advertising,
1911 fiber_supported);
1912 }
1913 }
1914
1915 if (page == YT8521_RSSR_FIBER_SPACE)
1916 ret = yt8521_fiber_config_aneg(phydev);
1917 else
1918 ret = ytphy_utp_config_aneg(phydev, false);
1919
1920err_restore_page:
1921 return phy_restore_page(phydev, old_page, ret);
1922}
1923
1924/**
1925 * yt8521_config_aneg() - change reg space then call yt8521_config_aneg_paged
1926 * @phydev: a pointer to a &struct phy_device
1927 *
1928 * returns 0 or negative errno code
1929 */
1930static int yt8521_config_aneg(struct phy_device *phydev)
1931{
1932 struct yt8521_priv *priv = phydev->priv;
1933 int ret;
1934
1935 if (priv->reg_page != YT8521_RSSR_TO_BE_ARBITRATED) {
1936 ret = yt8521_config_aneg_paged(phydev, priv->reg_page);
1937 if (ret < 0)
1938 return ret;
1939 } else {
1940 /* If reg_page is YT8521_RSSR_TO_BE_ARBITRATED,
1941 * phydev->advertising need to be saved at first run.
1942 * Because it contains the advertising which supported by both
1943 * mac and yt8521(utp and fiber).
1944 */
1945 if (linkmode_empty(priv->combo_advertising)) {
1946 linkmode_copy(priv->combo_advertising,
1947 phydev->advertising);
1948 }
1949
1950 ret = yt8521_config_aneg_paged(phydev, YT8521_RSSR_UTP_SPACE);
1951 if (ret < 0)
1952 return ret;
1953
1954 ret = yt8521_config_aneg_paged(phydev, YT8521_RSSR_FIBER_SPACE);
1955 if (ret < 0)
1956 return ret;
1957
1958 /* we don't known which will be link, so restore
1959 * phydev->advertising as default value.
1960 */
1961 linkmode_copy(phydev->advertising, priv->combo_advertising);
1962 }
1963 return 0;
1964}
1965
1966/**
1967 * yt8521_aneg_done_paged() - determines the auto negotiation result of one
1968 * page.
1969 * @phydev: a pointer to a &struct phy_device
1970 * @page: The reg page(YT8521_RSSR_FIBER_SPACE/YT8521_RSSR_UTP_SPACE) to
1971 * operate.
1972 *
1973 * returns 0(no link)or 1(fiber or utp link) or negative errno code
1974 */
1975static int yt8521_aneg_done_paged(struct phy_device *phydev, int page)
1976{
1977 int old_page;
1978 int ret = 0;
1979 int link;
1980
1981 old_page = phy_select_page(phydev, page & YT8521_RSSR_SPACE_MASK);
1982 if (old_page < 0)
1983 goto err_restore_page;
1984
1985 ret = __phy_read(phydev, YTPHY_SPECIFIC_STATUS_REG);
1986 if (ret < 0)
1987 goto err_restore_page;
1988
1989 link = !!(ret & YTPHY_SSR_LINK);
1990 ret = link;
1991
1992err_restore_page:
1993 return phy_restore_page(phydev, old_page, ret);
1994}
1995
1996/**
1997 * yt8521_aneg_done() - determines the auto negotiation result
1998 * @phydev: a pointer to a &struct phy_device
1999 *
2000 * returns 0(no link)or 1(fiber or utp link) or negative errno code
2001 */
2002static int yt8521_aneg_done(struct phy_device *phydev)
2003{
2004 struct yt8521_priv *priv = phydev->priv;
2005 int link_fiber = 0;
2006 int link_utp;
2007 int link;
2008
2009 if (priv->reg_page != YT8521_RSSR_TO_BE_ARBITRATED) {
2010 link = yt8521_aneg_done_paged(phydev, priv->reg_page);
2011 } else {
2012 link_utp = yt8521_aneg_done_paged(phydev,
2013 YT8521_RSSR_UTP_SPACE);
2014 if (link_utp < 0)
2015 return link_utp;
2016
2017 if (!link_utp) {
2018 link_fiber = yt8521_aneg_done_paged(phydev,
2019 YT8521_RSSR_FIBER_SPACE);
2020 if (link_fiber < 0)
2021 return link_fiber;
2022 }
2023 link = link_fiber || link_utp;
2024 phydev_info(phydev, "%s, link_fiber: %d, link_utp: %d\n",
2025 __func__, link_fiber, link_utp);
2026 }
2027
2028 return link;
2029}
2030
2031/**
2032 * ytphy_utp_read_abilities - read PHY abilities from Clause 22 registers
2033 * @phydev: target phy_device struct
2034 *
2035 * NOTE: Reads the PHY's abilities and populates
2036 * phydev->supported accordingly.
2037 * The caller must have taken the MDIO bus lock.
2038 *
2039 * returns 0 or negative errno code
2040 */
2041static int ytphy_utp_read_abilities(struct phy_device *phydev)
2042{
2043 int val;
2044
2045 linkmode_set_bit_array(phy_basic_ports_array,
2046 ARRAY_SIZE(phy_basic_ports_array),
2047 phydev->supported);
2048
2049 val = __phy_read(phydev, MII_BMSR);
2050 if (val < 0)
2051 return val;
2052
2053 linkmode_mod_bit(ETHTOOL_LINK_MODE_Autoneg_BIT, phydev->supported,
2054 val & BMSR_ANEGCAPABLE);
2055
2056 linkmode_mod_bit(ETHTOOL_LINK_MODE_100baseT_Full_BIT, phydev->supported,
2057 val & BMSR_100FULL);
2058 linkmode_mod_bit(ETHTOOL_LINK_MODE_100baseT_Half_BIT, phydev->supported,
2059 val & BMSR_100HALF);
2060 linkmode_mod_bit(ETHTOOL_LINK_MODE_10baseT_Full_BIT, phydev->supported,
2061 val & BMSR_10FULL);
2062 linkmode_mod_bit(ETHTOOL_LINK_MODE_10baseT_Half_BIT, phydev->supported,
2063 val & BMSR_10HALF);
2064
2065 if (val & BMSR_ESTATEN) {
2066 val = __phy_read(phydev, MII_ESTATUS);
2067 if (val < 0)
2068 return val;
2069
2070 linkmode_mod_bit(ETHTOOL_LINK_MODE_1000baseT_Full_BIT,
2071 phydev->supported, val & ESTATUS_1000_TFULL);
2072 linkmode_mod_bit(ETHTOOL_LINK_MODE_1000baseT_Half_BIT,
2073 phydev->supported, val & ESTATUS_1000_THALF);
2074 linkmode_mod_bit(ETHTOOL_LINK_MODE_1000baseX_Full_BIT,
2075 phydev->supported, val & ESTATUS_1000_XFULL);
2076 }
2077
2078 return 0;
2079}
2080
2081/**
2082 * yt8521_get_features_paged() - read supported link modes for one page
2083 * @phydev: a pointer to a &struct phy_device
2084 * @page: The reg page(YT8521_RSSR_FIBER_SPACE/YT8521_RSSR_UTP_SPACE) to
2085 * operate.
2086 *
2087 * returns 0 or negative errno code
2088 */
2089static int yt8521_get_features_paged(struct phy_device *phydev, int page)
2090{
2091 int old_page;
2092 int ret = 0;
2093
2094 page &= YT8521_RSSR_SPACE_MASK;
2095 old_page = phy_select_page(phydev, page);
2096 if (old_page < 0)
2097 goto err_restore_page;
2098
2099 if (page == YT8521_RSSR_FIBER_SPACE) {
2100 linkmode_zero(phydev->supported);
2101 yt8521_prepare_fiber_features(phydev, phydev->supported);
2102 } else {
2103 ret = ytphy_utp_read_abilities(phydev);
2104 if (ret < 0)
2105 goto err_restore_page;
2106 }
2107
2108err_restore_page:
2109 return phy_restore_page(phydev, old_page, ret);
2110}
2111
2112/**
2113 * yt8521_get_features - switch reg space then call yt8521_get_features_paged
2114 * @phydev: target phy_device struct
2115 *
2116 * returns 0 or negative errno code
2117 */
2118static int yt8521_get_features(struct phy_device *phydev)
2119{
2120 struct yt8521_priv *priv = phydev->priv;
2121 int ret;
2122
2123 if (priv->reg_page != YT8521_RSSR_TO_BE_ARBITRATED) {
2124 ret = yt8521_get_features_paged(phydev, priv->reg_page);
2125 } else {
2126 ret = yt8521_get_features_paged(phydev,
2127 YT8521_RSSR_UTP_SPACE);
2128 if (ret < 0)
2129 return ret;
2130
2131 /* add fiber's features to phydev->supported */
2132 yt8521_prepare_fiber_features(phydev, phydev->supported);
2133 }
2134 return ret;
2135}
2136
2137static struct phy_driver motorcomm_phy_drvs[] = {
2138 {
2139 PHY_ID_MATCH_EXACT(PHY_ID_YT8511),
2140 .name = "YT8511 Gigabit Ethernet",
2141 .config_init = yt8511_config_init,
2142 .suspend = genphy_suspend,
2143 .resume = genphy_resume,
2144 .read_page = yt8511_read_page,
2145 .write_page = yt8511_write_page,
2146 },
2147 {
2148 PHY_ID_MATCH_EXACT(PHY_ID_YT8521),
2149 .name = "YT8521 Gigabit Ethernet",
2150 .get_features = yt8521_get_features,
2151 .probe = yt8521_probe,
2152 .read_page = yt8521_read_page,
2153 .write_page = yt8521_write_page,
2154 .get_wol = ytphy_get_wol,
2155 .set_wol = ytphy_set_wol,
2156 .config_aneg = yt8521_config_aneg,
2157 .aneg_done = yt8521_aneg_done,
2158 .config_init = yt8521_config_init,
2159 .read_status = yt8521_read_status,
2160 .soft_reset = yt8521_soft_reset,
2161 .suspend = yt8521_suspend,
2162 .resume = yt8521_resume,
2163 },
2164 {
2165 PHY_ID_MATCH_EXACT(PHY_ID_YT8531),
2166 .name = "YT8531 Gigabit Ethernet",
2167 .probe = yt8531_probe,
2168 .config_init = yt8531_config_init,
2169 .suspend = genphy_suspend,
2170 .resume = genphy_resume,
2171 .get_wol = ytphy_get_wol,
2172 .set_wol = yt8531_set_wol,
2173 .link_change_notify = yt8531_link_change_notify,
2174 },
2175 {
2176 PHY_ID_MATCH_EXACT(PHY_ID_YT8531S),
2177 .name = "YT8531S Gigabit Ethernet",
2178 .get_features = yt8521_get_features,
2179 .probe = yt8521_probe,
2180 .read_page = yt8521_read_page,
2181 .write_page = yt8521_write_page,
2182 .get_wol = ytphy_get_wol,
2183 .set_wol = ytphy_set_wol,
2184 .config_aneg = yt8521_config_aneg,
2185 .aneg_done = yt8521_aneg_done,
2186 .config_init = yt8521_config_init,
2187 .read_status = yt8521_read_status,
2188 .soft_reset = yt8521_soft_reset,
2189 .suspend = yt8521_suspend,
2190 .resume = yt8521_resume,
2191 },
2192};
2193
2194module_phy_driver(motorcomm_phy_drvs);
2195
2196MODULE_DESCRIPTION("Motorcomm 8511/8521/8531/8531S PHY driver");
2197MODULE_AUTHOR("Peter Geis");
2198MODULE_AUTHOR("Frank");
2199MODULE_LICENSE("GPL");
2200
2201static const struct mdio_device_id __maybe_unused motorcomm_tbl[] = {
2202 { PHY_ID_MATCH_EXACT(PHY_ID_YT8511) },
2203 { PHY_ID_MATCH_EXACT(PHY_ID_YT8521) },
2204 { PHY_ID_MATCH_EXACT(PHY_ID_YT8531) },
2205 { PHY_ID_MATCH_EXACT(PHY_ID_YT8531S) },
2206 { /* sentinel */ }
2207};
2208
2209MODULE_DEVICE_TABLE(mdio, motorcomm_tbl);