1 // SPDX-License-Identifier: GPL-2.0+
3 * Driver for the National Semiconductor DP83640 PHYTER
5 * Copyright (C) 2010 OMICRON electronics GmbH
8 #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
10 #include <linux/crc32.h>
11 #include <linux/ethtool.h>
12 #include <linux/kernel.h>
13 #include <linux/list.h>
14 #include <linux/mii.h>
15 #include <linux/module.h>
16 #include <linux/net_tstamp.h>
17 #include <linux/netdevice.h>
18 #include <linux/if_vlan.h>
19 #include <linux/phy.h>
20 #include <linux/ptp_classify.h>
21 #include <linux/ptp_clock_kernel.h>
23 #include "dp83640_reg.h"
25 #define DP83640_PHY_ID 0x20005ce1
31 #define PSF_EVNT 0x4000
37 #define DP83640_N_PINS 12
39 #define MII_DP83640_MICR 0x11
40 #define MII_DP83640_MISR 0x12
42 #define MII_DP83640_MICR_OE 0x1
43 #define MII_DP83640_MICR_IE 0x2
45 #define MII_DP83640_MISR_RHF_INT_EN 0x01
46 #define MII_DP83640_MISR_FHF_INT_EN 0x02
47 #define MII_DP83640_MISR_ANC_INT_EN 0x04
48 #define MII_DP83640_MISR_DUP_INT_EN 0x08
49 #define MII_DP83640_MISR_SPD_INT_EN 0x10
50 #define MII_DP83640_MISR_LINK_INT_EN 0x20
51 #define MII_DP83640_MISR_ED_INT_EN 0x40
52 #define MII_DP83640_MISR_LQ_INT_EN 0x80
54 /* phyter seems to miss the mark by 16 ns */
55 #define ADJTIME_FIX 16
57 #define SKB_TIMESTAMP_TIMEOUT 2 /* jiffies */
59 #if defined(__BIG_ENDIAN)
61 #elif defined(__LITTLE_ENDIAN)
62 #define ENDIAN_FLAG PSF_ENDIAN
65 struct dp83640_skb_info
{
71 u16 ns_lo
; /* ns[15:0] */
72 u16 ns_hi
; /* overflow[1:0], ns[29:16] */
73 u16 sec_lo
; /* sec[15:0] */
74 u16 sec_hi
; /* sec[31:16] */
75 u16 seqid
; /* sequenceId[15:0] */
76 u16 msgtype
; /* messageType[3:0], hash[11:0] */
80 u16 ns_lo
; /* ns[15:0] */
81 u16 ns_hi
; /* overflow[1:0], ns[29:16] */
82 u16 sec_lo
; /* sec[15:0] */
83 u16 sec_hi
; /* sec[31:16] */
87 struct list_head list
;
97 struct dp83640_private
{
98 struct list_head list
;
99 struct dp83640_clock
*clock
;
100 struct phy_device
*phydev
;
101 struct delayed_work ts_work
;
106 /* remember state of cfg0 during calibration */
108 /* remember the last event time stamp */
109 struct phy_txts edata
;
110 /* list of rx timestamps */
111 struct list_head rxts
;
112 struct list_head rxpool
;
113 struct rxts rx_pool_data
[MAX_RXTS
];
114 /* protects above three fields from concurrent access */
116 /* queues of incoming and outgoing packets */
117 struct sk_buff_head rx_queue
;
118 struct sk_buff_head tx_queue
;
121 struct dp83640_clock
{
122 /* keeps the instance in the 'phyter_clocks' list */
123 struct list_head list
;
124 /* we create one clock instance per MII bus */
126 /* protects extended registers from concurrent access */
127 struct mutex extreg_lock
;
128 /* remembers which page was last selected */
130 /* our advertised capabilities */
131 struct ptp_clock_info caps
;
132 /* protects the three fields below from concurrent access */
133 struct mutex clock_lock
;
134 /* the one phyter from which we shall read */
135 struct dp83640_private
*chosen
;
136 /* list of the other attached phyters, not chosen */
137 struct list_head phylist
;
138 /* reference to our PTP hardware clock */
139 struct ptp_clock
*ptp_clock
;
156 static int chosen_phy
= -1;
157 static ushort gpio_tab
[GPIO_TABLE_SIZE
] = {
158 1, 2, 3, 4, 8, 9, 10, 11
161 module_param(chosen_phy
, int, 0444);
162 module_param_array(gpio_tab
, ushort
, NULL
, 0444);
164 MODULE_PARM_DESC(chosen_phy
, \
165 "The address of the PHY to use for the ancillary clock features");
166 MODULE_PARM_DESC(gpio_tab
, \
167 "Which GPIO line to use for which purpose: cal,perout,extts1,...,extts6");
169 static void dp83640_gpio_defaults(struct ptp_pin_desc
*pd
)
173 for (i
= 0; i
< DP83640_N_PINS
; i
++) {
174 snprintf(pd
[i
].name
, sizeof(pd
[i
].name
), "GPIO%d", 1 + i
);
178 for (i
= 0; i
< GPIO_TABLE_SIZE
; i
++) {
179 if (gpio_tab
[i
] < 1 || gpio_tab
[i
] > DP83640_N_PINS
) {
180 pr_err("gpio_tab[%d]=%hu out of range", i
, gpio_tab
[i
]);
185 index
= gpio_tab
[CALIBRATE_GPIO
] - 1;
186 pd
[index
].func
= PTP_PF_PHYSYNC
;
189 index
= gpio_tab
[PEROUT_GPIO
] - 1;
190 pd
[index
].func
= PTP_PF_PEROUT
;
193 for (i
= EXTTS0_GPIO
; i
< GPIO_TABLE_SIZE
; i
++) {
194 index
= gpio_tab
[i
] - 1;
195 pd
[index
].func
= PTP_PF_EXTTS
;
196 pd
[index
].chan
= i
- EXTTS0_GPIO
;
200 /* a list of clocks and a mutex to protect it */
201 static LIST_HEAD(phyter_clocks
);
202 static DEFINE_MUTEX(phyter_clocks_lock
);
204 static void rx_timestamp_work(struct work_struct
*work
);
206 /* extended register access functions */
208 #define BROADCAST_ADDR 31
210 static inline int broadcast_write(struct phy_device
*phydev
, u32 regnum
,
213 return mdiobus_write(phydev
->mdio
.bus
, BROADCAST_ADDR
, regnum
, val
);
216 /* Caller must hold extreg_lock. */
217 static int ext_read(struct phy_device
*phydev
, int page
, u32 regnum
)
219 struct dp83640_private
*dp83640
= phydev
->priv
;
222 if (dp83640
->clock
->page
!= page
) {
223 broadcast_write(phydev
, PAGESEL
, page
);
224 dp83640
->clock
->page
= page
;
226 val
= phy_read(phydev
, regnum
);
231 /* Caller must hold extreg_lock. */
232 static void ext_write(int broadcast
, struct phy_device
*phydev
,
233 int page
, u32 regnum
, u16 val
)
235 struct dp83640_private
*dp83640
= phydev
->priv
;
237 if (dp83640
->clock
->page
!= page
) {
238 broadcast_write(phydev
, PAGESEL
, page
);
239 dp83640
->clock
->page
= page
;
242 broadcast_write(phydev
, regnum
, val
);
244 phy_write(phydev
, regnum
, val
);
247 /* Caller must hold extreg_lock. */
248 static int tdr_write(int bc
, struct phy_device
*dev
,
249 const struct timespec64
*ts
, u16 cmd
)
251 ext_write(bc
, dev
, PAGE4
, PTP_TDR
, ts
->tv_nsec
& 0xffff);/* ns[15:0] */
252 ext_write(bc
, dev
, PAGE4
, PTP_TDR
, ts
->tv_nsec
>> 16); /* ns[31:16] */
253 ext_write(bc
, dev
, PAGE4
, PTP_TDR
, ts
->tv_sec
& 0xffff); /* sec[15:0] */
254 ext_write(bc
, dev
, PAGE4
, PTP_TDR
, ts
->tv_sec
>> 16); /* sec[31:16]*/
256 ext_write(bc
, dev
, PAGE4
, PTP_CTL
, cmd
);
261 /* convert phy timestamps into driver timestamps */
263 static void phy2rxts(struct phy_rxts
*p
, struct rxts
*rxts
)
268 sec
|= p
->sec_hi
<< 16;
271 rxts
->ns
|= (p
->ns_hi
& 0x3fff) << 16;
272 rxts
->ns
+= ((u64
)sec
) * 1000000000ULL;
273 rxts
->seqid
= p
->seqid
;
274 rxts
->msgtype
= (p
->msgtype
>> 12) & 0xf;
275 rxts
->hash
= p
->msgtype
& 0x0fff;
276 rxts
->tmo
= jiffies
+ SKB_TIMESTAMP_TIMEOUT
;
279 static u64
phy2txts(struct phy_txts
*p
)
285 sec
|= p
->sec_hi
<< 16;
288 ns
|= (p
->ns_hi
& 0x3fff) << 16;
289 ns
+= ((u64
)sec
) * 1000000000ULL;
294 static int periodic_output(struct dp83640_clock
*clock
,
295 struct ptp_clock_request
*clkreq
, bool on
,
298 struct dp83640_private
*dp83640
= clock
->chosen
;
299 struct phy_device
*phydev
= dp83640
->phydev
;
300 u32 sec
, nsec
, pwidth
;
301 u16 gpio
, ptp_trig
, val
;
304 gpio
= 1 + ptp_find_pin(clock
->ptp_clock
, PTP_PF_PEROUT
,
313 (trigger
& TRIG_CSEL_MASK
) << TRIG_CSEL_SHIFT
|
314 (gpio
& TRIG_GPIO_MASK
) << TRIG_GPIO_SHIFT
|
318 val
= (trigger
& TRIG_SEL_MASK
) << TRIG_SEL_SHIFT
;
322 mutex_lock(&clock
->extreg_lock
);
323 ext_write(0, phydev
, PAGE5
, PTP_TRIG
, ptp_trig
);
324 ext_write(0, phydev
, PAGE4
, PTP_CTL
, val
);
325 mutex_unlock(&clock
->extreg_lock
);
329 sec
= clkreq
->perout
.start
.sec
;
330 nsec
= clkreq
->perout
.start
.nsec
;
331 pwidth
= clkreq
->perout
.period
.sec
* 1000000000UL;
332 pwidth
+= clkreq
->perout
.period
.nsec
;
335 mutex_lock(&clock
->extreg_lock
);
337 ext_write(0, phydev
, PAGE5
, PTP_TRIG
, ptp_trig
);
341 ext_write(0, phydev
, PAGE4
, PTP_CTL
, val
);
342 ext_write(0, phydev
, PAGE4
, PTP_TDR
, nsec
& 0xffff); /* ns[15:0] */
343 ext_write(0, phydev
, PAGE4
, PTP_TDR
, nsec
>> 16); /* ns[31:16] */
344 ext_write(0, phydev
, PAGE4
, PTP_TDR
, sec
& 0xffff); /* sec[15:0] */
345 ext_write(0, phydev
, PAGE4
, PTP_TDR
, sec
>> 16); /* sec[31:16] */
346 ext_write(0, phydev
, PAGE4
, PTP_TDR
, pwidth
& 0xffff); /* ns[15:0] */
347 ext_write(0, phydev
, PAGE4
, PTP_TDR
, pwidth
>> 16); /* ns[31:16] */
348 /* Triggers 0 and 1 has programmable pulsewidth2 */
350 ext_write(0, phydev
, PAGE4
, PTP_TDR
, pwidth
& 0xffff);
351 ext_write(0, phydev
, PAGE4
, PTP_TDR
, pwidth
>> 16);
357 ext_write(0, phydev
, PAGE4
, PTP_CTL
, val
);
359 mutex_unlock(&clock
->extreg_lock
);
363 /* ptp clock methods */
365 static int ptp_dp83640_adjfine(struct ptp_clock_info
*ptp
, long scaled_ppm
)
367 struct dp83640_clock
*clock
=
368 container_of(ptp
, struct dp83640_clock
, caps
);
369 struct phy_device
*phydev
= clock
->chosen
->phydev
;
374 if (scaled_ppm
< 0) {
376 scaled_ppm
= -scaled_ppm
;
380 rate
= div_u64(rate
, 15625);
382 hi
= (rate
>> 16) & PTP_RATE_HI_MASK
;
388 mutex_lock(&clock
->extreg_lock
);
390 ext_write(1, phydev
, PAGE4
, PTP_RATEH
, hi
);
391 ext_write(1, phydev
, PAGE4
, PTP_RATEL
, lo
);
393 mutex_unlock(&clock
->extreg_lock
);
398 static int ptp_dp83640_adjtime(struct ptp_clock_info
*ptp
, s64 delta
)
400 struct dp83640_clock
*clock
=
401 container_of(ptp
, struct dp83640_clock
, caps
);
402 struct phy_device
*phydev
= clock
->chosen
->phydev
;
403 struct timespec64 ts
;
406 delta
+= ADJTIME_FIX
;
408 ts
= ns_to_timespec64(delta
);
410 mutex_lock(&clock
->extreg_lock
);
412 err
= tdr_write(1, phydev
, &ts
, PTP_STEP_CLK
);
414 mutex_unlock(&clock
->extreg_lock
);
419 static int ptp_dp83640_gettime(struct ptp_clock_info
*ptp
,
420 struct timespec64
*ts
)
422 struct dp83640_clock
*clock
=
423 container_of(ptp
, struct dp83640_clock
, caps
);
424 struct phy_device
*phydev
= clock
->chosen
->phydev
;
427 mutex_lock(&clock
->extreg_lock
);
429 ext_write(0, phydev
, PAGE4
, PTP_CTL
, PTP_RD_CLK
);
431 val
[0] = ext_read(phydev
, PAGE4
, PTP_TDR
); /* ns[15:0] */
432 val
[1] = ext_read(phydev
, PAGE4
, PTP_TDR
); /* ns[31:16] */
433 val
[2] = ext_read(phydev
, PAGE4
, PTP_TDR
); /* sec[15:0] */
434 val
[3] = ext_read(phydev
, PAGE4
, PTP_TDR
); /* sec[31:16] */
436 mutex_unlock(&clock
->extreg_lock
);
438 ts
->tv_nsec
= val
[0] | (val
[1] << 16);
439 ts
->tv_sec
= val
[2] | (val
[3] << 16);
444 static int ptp_dp83640_settime(struct ptp_clock_info
*ptp
,
445 const struct timespec64
*ts
)
447 struct dp83640_clock
*clock
=
448 container_of(ptp
, struct dp83640_clock
, caps
);
449 struct phy_device
*phydev
= clock
->chosen
->phydev
;
452 mutex_lock(&clock
->extreg_lock
);
454 err
= tdr_write(1, phydev
, ts
, PTP_LOAD_CLK
);
456 mutex_unlock(&clock
->extreg_lock
);
461 static int ptp_dp83640_enable(struct ptp_clock_info
*ptp
,
462 struct ptp_clock_request
*rq
, int on
)
464 struct dp83640_clock
*clock
=
465 container_of(ptp
, struct dp83640_clock
, caps
);
466 struct phy_device
*phydev
= clock
->chosen
->phydev
;
468 u16 evnt
, event_num
, gpio_num
;
471 case PTP_CLK_REQ_EXTTS
:
472 index
= rq
->extts
.index
;
473 if (index
>= N_EXT_TS
)
475 event_num
= EXT_EVENT
+ index
;
476 evnt
= EVNT_WR
| (event_num
& EVNT_SEL_MASK
) << EVNT_SEL_SHIFT
;
478 gpio_num
= 1 + ptp_find_pin(clock
->ptp_clock
,
479 PTP_PF_EXTTS
, index
);
482 evnt
|= (gpio_num
& EVNT_GPIO_MASK
) << EVNT_GPIO_SHIFT
;
483 if (rq
->extts
.flags
& PTP_FALLING_EDGE
)
488 mutex_lock(&clock
->extreg_lock
);
489 ext_write(0, phydev
, PAGE5
, PTP_EVNT
, evnt
);
490 mutex_unlock(&clock
->extreg_lock
);
493 case PTP_CLK_REQ_PEROUT
:
494 if (rq
->perout
.index
>= N_PER_OUT
)
496 return periodic_output(clock
, rq
, on
, rq
->perout
.index
);
505 static int ptp_dp83640_verify(struct ptp_clock_info
*ptp
, unsigned int pin
,
506 enum ptp_pin_function func
, unsigned int chan
)
508 struct dp83640_clock
*clock
=
509 container_of(ptp
, struct dp83640_clock
, caps
);
511 if (clock
->caps
.pin_config
[pin
].func
== PTP_PF_PHYSYNC
&&
512 !list_empty(&clock
->phylist
))
515 if (func
== PTP_PF_PHYSYNC
)
521 static u8 status_frame_dst
[6] = { 0x01, 0x1B, 0x19, 0x00, 0x00, 0x00 };
522 static u8 status_frame_src
[6] = { 0x08, 0x00, 0x17, 0x0B, 0x6B, 0x0F };
524 static void enable_status_frames(struct phy_device
*phydev
, bool on
)
526 struct dp83640_private
*dp83640
= phydev
->priv
;
527 struct dp83640_clock
*clock
= dp83640
->clock
;
531 cfg0
= PSF_EVNT_EN
| PSF_RXTS_EN
| PSF_TXTS_EN
| ENDIAN_FLAG
;
533 ver
= (PSF_PTPVER
& VERSIONPTP_MASK
) << VERSIONPTP_SHIFT
;
535 mutex_lock(&clock
->extreg_lock
);
537 ext_write(0, phydev
, PAGE5
, PSF_CFG0
, cfg0
);
538 ext_write(0, phydev
, PAGE6
, PSF_CFG1
, ver
);
540 mutex_unlock(&clock
->extreg_lock
);
542 if (!phydev
->attached_dev
) {
544 "expected to find an attached netdevice\n");
549 if (dev_mc_add(phydev
->attached_dev
, status_frame_dst
))
550 phydev_warn(phydev
, "failed to add mc address\n");
552 if (dev_mc_del(phydev
->attached_dev
, status_frame_dst
))
553 phydev_warn(phydev
, "failed to delete mc address\n");
557 static bool is_status_frame(struct sk_buff
*skb
, int type
)
559 struct ethhdr
*h
= eth_hdr(skb
);
561 if (PTP_CLASS_V2_L2
== type
&&
562 !memcmp(h
->h_source
, status_frame_src
, sizeof(status_frame_src
)))
568 static int expired(struct rxts
*rxts
)
570 return time_after(jiffies
, rxts
->tmo
);
573 /* Caller must hold rx_lock. */
574 static void prune_rx_ts(struct dp83640_private
*dp83640
)
576 struct list_head
*this, *next
;
579 list_for_each_safe(this, next
, &dp83640
->rxts
) {
580 rxts
= list_entry(this, struct rxts
, list
);
582 list_del_init(&rxts
->list
);
583 list_add(&rxts
->list
, &dp83640
->rxpool
);
588 /* synchronize the phyters so they act as one clock */
590 static void enable_broadcast(struct phy_device
*phydev
, int init_page
, int on
)
593 phy_write(phydev
, PAGESEL
, 0);
594 val
= phy_read(phydev
, PHYCR2
);
599 phy_write(phydev
, PHYCR2
, val
);
600 phy_write(phydev
, PAGESEL
, init_page
);
603 static void recalibrate(struct dp83640_clock
*clock
)
606 struct phy_txts event_ts
;
607 struct timespec64 ts
;
608 struct list_head
*this;
609 struct dp83640_private
*tmp
;
610 struct phy_device
*master
= clock
->chosen
->phydev
;
611 u16 cal_gpio
, cfg0
, evnt
, ptp_trig
, trigger
, val
;
613 trigger
= CAL_TRIGGER
;
614 cal_gpio
= 1 + ptp_find_pin(clock
->ptp_clock
, PTP_PF_PHYSYNC
, 0);
616 pr_err("PHY calibration pin not available - PHY is not calibrated.");
620 mutex_lock(&clock
->extreg_lock
);
623 * enable broadcast, disable status frames, enable ptp clock
625 list_for_each(this, &clock
->phylist
) {
626 tmp
= list_entry(this, struct dp83640_private
, list
);
627 enable_broadcast(tmp
->phydev
, clock
->page
, 1);
628 tmp
->cfg0
= ext_read(tmp
->phydev
, PAGE5
, PSF_CFG0
);
629 ext_write(0, tmp
->phydev
, PAGE5
, PSF_CFG0
, 0);
630 ext_write(0, tmp
->phydev
, PAGE4
, PTP_CTL
, PTP_ENABLE
);
632 enable_broadcast(master
, clock
->page
, 1);
633 cfg0
= ext_read(master
, PAGE5
, PSF_CFG0
);
634 ext_write(0, master
, PAGE5
, PSF_CFG0
, 0);
635 ext_write(0, master
, PAGE4
, PTP_CTL
, PTP_ENABLE
);
638 * enable an event timestamp
640 evnt
= EVNT_WR
| EVNT_RISE
| EVNT_SINGLE
;
641 evnt
|= (CAL_EVENT
& EVNT_SEL_MASK
) << EVNT_SEL_SHIFT
;
642 evnt
|= (cal_gpio
& EVNT_GPIO_MASK
) << EVNT_GPIO_SHIFT
;
644 list_for_each(this, &clock
->phylist
) {
645 tmp
= list_entry(this, struct dp83640_private
, list
);
646 ext_write(0, tmp
->phydev
, PAGE5
, PTP_EVNT
, evnt
);
648 ext_write(0, master
, PAGE5
, PTP_EVNT
, evnt
);
651 * configure a trigger
653 ptp_trig
= TRIG_WR
| TRIG_IF_LATE
| TRIG_PULSE
;
654 ptp_trig
|= (trigger
& TRIG_CSEL_MASK
) << TRIG_CSEL_SHIFT
;
655 ptp_trig
|= (cal_gpio
& TRIG_GPIO_MASK
) << TRIG_GPIO_SHIFT
;
656 ext_write(0, master
, PAGE5
, PTP_TRIG
, ptp_trig
);
659 val
= (trigger
& TRIG_SEL_MASK
) << TRIG_SEL_SHIFT
;
661 ext_write(0, master
, PAGE4
, PTP_CTL
, val
);
666 ext_write(0, master
, PAGE4
, PTP_CTL
, val
);
668 /* disable trigger */
669 val
= (trigger
& TRIG_SEL_MASK
) << TRIG_SEL_SHIFT
;
671 ext_write(0, master
, PAGE4
, PTP_CTL
, val
);
674 * read out and correct offsets
676 val
= ext_read(master
, PAGE4
, PTP_STS
);
677 phydev_info(master
, "master PTP_STS 0x%04hx\n", val
);
678 val
= ext_read(master
, PAGE4
, PTP_ESTS
);
679 phydev_info(master
, "master PTP_ESTS 0x%04hx\n", val
);
680 event_ts
.ns_lo
= ext_read(master
, PAGE4
, PTP_EDATA
);
681 event_ts
.ns_hi
= ext_read(master
, PAGE4
, PTP_EDATA
);
682 event_ts
.sec_lo
= ext_read(master
, PAGE4
, PTP_EDATA
);
683 event_ts
.sec_hi
= ext_read(master
, PAGE4
, PTP_EDATA
);
684 now
= phy2txts(&event_ts
);
686 list_for_each(this, &clock
->phylist
) {
687 tmp
= list_entry(this, struct dp83640_private
, list
);
688 val
= ext_read(tmp
->phydev
, PAGE4
, PTP_STS
);
689 phydev_info(tmp
->phydev
, "slave PTP_STS 0x%04hx\n", val
);
690 val
= ext_read(tmp
->phydev
, PAGE4
, PTP_ESTS
);
691 phydev_info(tmp
->phydev
, "slave PTP_ESTS 0x%04hx\n", val
);
692 event_ts
.ns_lo
= ext_read(tmp
->phydev
, PAGE4
, PTP_EDATA
);
693 event_ts
.ns_hi
= ext_read(tmp
->phydev
, PAGE4
, PTP_EDATA
);
694 event_ts
.sec_lo
= ext_read(tmp
->phydev
, PAGE4
, PTP_EDATA
);
695 event_ts
.sec_hi
= ext_read(tmp
->phydev
, PAGE4
, PTP_EDATA
);
696 diff
= now
- (s64
) phy2txts(&event_ts
);
697 phydev_info(tmp
->phydev
, "slave offset %lld nanoseconds\n",
700 ts
= ns_to_timespec64(diff
);
701 tdr_write(0, tmp
->phydev
, &ts
, PTP_STEP_CLK
);
705 * restore status frames
707 list_for_each(this, &clock
->phylist
) {
708 tmp
= list_entry(this, struct dp83640_private
, list
);
709 ext_write(0, tmp
->phydev
, PAGE5
, PSF_CFG0
, tmp
->cfg0
);
711 ext_write(0, master
, PAGE5
, PSF_CFG0
, cfg0
);
713 mutex_unlock(&clock
->extreg_lock
);
716 /* time stamping methods */
718 static inline u16
exts_chan_to_edata(int ch
)
720 return 1 << ((ch
+ EXT_EVENT
) * 2);
723 static int decode_evnt(struct dp83640_private
*dp83640
,
724 void *data
, int len
, u16 ests
)
726 struct phy_txts
*phy_txts
;
727 struct ptp_clock_event event
;
729 int words
= (ests
>> EVNT_TS_LEN_SHIFT
) & EVNT_TS_LEN_MASK
;
732 /* calculate length of the event timestamp status message */
733 if (ests
& MULT_EVNT
)
734 parsed
= (words
+ 2) * sizeof(u16
);
736 parsed
= (words
+ 1) * sizeof(u16
);
738 /* check if enough data is available */
742 if (ests
& MULT_EVNT
) {
743 ext_status
= *(u16
*) data
;
744 data
+= sizeof(ext_status
);
751 dp83640
->edata
.sec_hi
= phy_txts
->sec_hi
;
754 dp83640
->edata
.sec_lo
= phy_txts
->sec_lo
;
757 dp83640
->edata
.ns_hi
= phy_txts
->ns_hi
;
760 dp83640
->edata
.ns_lo
= phy_txts
->ns_lo
;
764 i
= ((ests
>> EVNT_NUM_SHIFT
) & EVNT_NUM_MASK
) - EXT_EVENT
;
765 ext_status
= exts_chan_to_edata(i
);
768 event
.type
= PTP_CLOCK_EXTTS
;
769 event
.timestamp
= phy2txts(&dp83640
->edata
);
771 /* Compensate for input path and synchronization delays */
772 event
.timestamp
-= 35;
774 for (i
= 0; i
< N_EXT_TS
; i
++) {
775 if (ext_status
& exts_chan_to_edata(i
)) {
777 ptp_clock_event(dp83640
->clock
->ptp_clock
, &event
);
784 #define DP83640_PACKET_HASH_OFFSET 20
785 #define DP83640_PACKET_HASH_LEN 10
787 static int match(struct sk_buff
*skb
, unsigned int type
, struct rxts
*rxts
)
790 unsigned int offset
= 0;
791 u8
*msgtype
, *data
= skb_mac_header(skb
);
793 /* check sequenceID, messageType, 12 bit hash of offset 20-29 */
795 if (type
& PTP_CLASS_VLAN
)
798 switch (type
& PTP_CLASS_PMASK
) {
800 offset
+= ETH_HLEN
+ IPV4_HLEN(data
+ offset
) + UDP_HLEN
;
803 offset
+= ETH_HLEN
+ IP6_HLEN
+ UDP_HLEN
;
812 if (skb
->len
+ ETH_HLEN
< offset
+ OFF_PTP_SEQUENCE_ID
+ sizeof(*seqid
))
815 if (unlikely(type
& PTP_CLASS_V1
))
816 msgtype
= data
+ offset
+ OFF_PTP_CONTROL
;
818 msgtype
= data
+ offset
;
819 if (rxts
->msgtype
!= (*msgtype
& 0xf))
822 seqid
= (u16
*)(data
+ offset
+ OFF_PTP_SEQUENCE_ID
);
823 if (rxts
->seqid
!= ntohs(*seqid
))
826 hash
= ether_crc(DP83640_PACKET_HASH_LEN
,
827 data
+ offset
+ DP83640_PACKET_HASH_OFFSET
) >> 20;
828 if (rxts
->hash
!= hash
)
834 static void decode_rxts(struct dp83640_private
*dp83640
,
835 struct phy_rxts
*phy_rxts
)
838 struct skb_shared_hwtstamps
*shhwtstamps
= NULL
;
843 overflow
= (phy_rxts
->ns_hi
>> 14) & 0x3;
845 pr_debug("rx timestamp queue overflow, count %d\n", overflow
);
847 spin_lock_irqsave(&dp83640
->rx_lock
, flags
);
849 prune_rx_ts(dp83640
);
851 if (list_empty(&dp83640
->rxpool
)) {
852 pr_debug("rx timestamp pool is empty\n");
855 rxts
= list_first_entry(&dp83640
->rxpool
, struct rxts
, list
);
856 list_del_init(&rxts
->list
);
857 phy2rxts(phy_rxts
, rxts
);
859 spin_lock(&dp83640
->rx_queue
.lock
);
860 skb_queue_walk(&dp83640
->rx_queue
, skb
) {
861 struct dp83640_skb_info
*skb_info
;
863 skb_info
= (struct dp83640_skb_info
*)skb
->cb
;
864 if (match(skb
, skb_info
->ptp_type
, rxts
)) {
865 __skb_unlink(skb
, &dp83640
->rx_queue
);
866 shhwtstamps
= skb_hwtstamps(skb
);
867 memset(shhwtstamps
, 0, sizeof(*shhwtstamps
));
868 shhwtstamps
->hwtstamp
= ns_to_ktime(rxts
->ns
);
869 list_add(&rxts
->list
, &dp83640
->rxpool
);
873 spin_unlock(&dp83640
->rx_queue
.lock
);
876 list_add_tail(&rxts
->list
, &dp83640
->rxts
);
878 spin_unlock_irqrestore(&dp83640
->rx_lock
, flags
);
884 static void decode_txts(struct dp83640_private
*dp83640
,
885 struct phy_txts
*phy_txts
)
887 struct skb_shared_hwtstamps shhwtstamps
;
888 struct dp83640_skb_info
*skb_info
;
893 /* We must already have the skb that triggered this. */
895 skb
= skb_dequeue(&dp83640
->tx_queue
);
897 pr_debug("have timestamp but tx_queue empty\n");
901 overflow
= (phy_txts
->ns_hi
>> 14) & 0x3;
903 pr_debug("tx timestamp queue overflow, count %d\n", overflow
);
906 skb
= skb_dequeue(&dp83640
->tx_queue
);
910 skb_info
= (struct dp83640_skb_info
*)skb
->cb
;
911 if (time_after(jiffies
, skb_info
->tmo
)) {
916 ns
= phy2txts(phy_txts
);
917 memset(&shhwtstamps
, 0, sizeof(shhwtstamps
));
918 shhwtstamps
.hwtstamp
= ns_to_ktime(ns
);
919 skb_complete_tx_timestamp(skb
, &shhwtstamps
);
922 static void decode_status_frame(struct dp83640_private
*dp83640
,
925 struct phy_rxts
*phy_rxts
;
926 struct phy_txts
*phy_txts
;
933 for (len
= skb_headlen(skb
) - 2; len
> sizeof(type
); len
-= size
) {
936 ests
= type
& 0x0fff;
937 type
= type
& 0xf000;
941 if (PSF_RX
== type
&& len
>= sizeof(*phy_rxts
)) {
943 phy_rxts
= (struct phy_rxts
*) ptr
;
944 decode_rxts(dp83640
, phy_rxts
);
945 size
= sizeof(*phy_rxts
);
947 } else if (PSF_TX
== type
&& len
>= sizeof(*phy_txts
)) {
949 phy_txts
= (struct phy_txts
*) ptr
;
950 decode_txts(dp83640
, phy_txts
);
951 size
= sizeof(*phy_txts
);
953 } else if (PSF_EVNT
== type
) {
955 size
= decode_evnt(dp83640
, ptr
, len
, ests
);
965 static int is_sync(struct sk_buff
*skb
, int type
)
967 u8
*data
= skb
->data
, *msgtype
;
968 unsigned int offset
= 0;
970 if (type
& PTP_CLASS_VLAN
)
973 switch (type
& PTP_CLASS_PMASK
) {
975 offset
+= ETH_HLEN
+ IPV4_HLEN(data
+ offset
) + UDP_HLEN
;
978 offset
+= ETH_HLEN
+ IP6_HLEN
+ UDP_HLEN
;
987 if (type
& PTP_CLASS_V1
)
988 offset
+= OFF_PTP_CONTROL
;
990 if (skb
->len
< offset
+ 1)
993 msgtype
= data
+ offset
;
995 return (*msgtype
& 0xf) == 0;
998 static void dp83640_free_clocks(void)
1000 struct dp83640_clock
*clock
;
1001 struct list_head
*this, *next
;
1003 mutex_lock(&phyter_clocks_lock
);
1005 list_for_each_safe(this, next
, &phyter_clocks
) {
1006 clock
= list_entry(this, struct dp83640_clock
, list
);
1007 if (!list_empty(&clock
->phylist
)) {
1008 pr_warn("phy list non-empty while unloading\n");
1011 list_del(&clock
->list
);
1012 mutex_destroy(&clock
->extreg_lock
);
1013 mutex_destroy(&clock
->clock_lock
);
1014 put_device(&clock
->bus
->dev
);
1015 kfree(clock
->caps
.pin_config
);
1019 mutex_unlock(&phyter_clocks_lock
);
1022 static void dp83640_clock_init(struct dp83640_clock
*clock
, struct mii_bus
*bus
)
1024 INIT_LIST_HEAD(&clock
->list
);
1026 mutex_init(&clock
->extreg_lock
);
1027 mutex_init(&clock
->clock_lock
);
1028 INIT_LIST_HEAD(&clock
->phylist
);
1029 clock
->caps
.owner
= THIS_MODULE
;
1030 sprintf(clock
->caps
.name
, "dp83640 timer");
1031 clock
->caps
.max_adj
= 1953124;
1032 clock
->caps
.n_alarm
= 0;
1033 clock
->caps
.n_ext_ts
= N_EXT_TS
;
1034 clock
->caps
.n_per_out
= N_PER_OUT
;
1035 clock
->caps
.n_pins
= DP83640_N_PINS
;
1036 clock
->caps
.pps
= 0;
1037 clock
->caps
.adjfine
= ptp_dp83640_adjfine
;
1038 clock
->caps
.adjtime
= ptp_dp83640_adjtime
;
1039 clock
->caps
.gettime64
= ptp_dp83640_gettime
;
1040 clock
->caps
.settime64
= ptp_dp83640_settime
;
1041 clock
->caps
.enable
= ptp_dp83640_enable
;
1042 clock
->caps
.verify
= ptp_dp83640_verify
;
1044 * Convert the module param defaults into a dynamic pin configuration.
1046 dp83640_gpio_defaults(clock
->caps
.pin_config
);
1048 * Get a reference to this bus instance.
1050 get_device(&bus
->dev
);
1053 static int choose_this_phy(struct dp83640_clock
*clock
,
1054 struct phy_device
*phydev
)
1056 if (chosen_phy
== -1 && !clock
->chosen
)
1059 if (chosen_phy
== phydev
->mdio
.addr
)
1065 static struct dp83640_clock
*dp83640_clock_get(struct dp83640_clock
*clock
)
1068 mutex_lock(&clock
->clock_lock
);
1073 * Look up and lock a clock by bus instance.
1074 * If there is no clock for this bus, then create it first.
1076 static struct dp83640_clock
*dp83640_clock_get_bus(struct mii_bus
*bus
)
1078 struct dp83640_clock
*clock
= NULL
, *tmp
;
1079 struct list_head
*this;
1081 mutex_lock(&phyter_clocks_lock
);
1083 list_for_each(this, &phyter_clocks
) {
1084 tmp
= list_entry(this, struct dp83640_clock
, list
);
1085 if (tmp
->bus
== bus
) {
1093 clock
= kzalloc(sizeof(struct dp83640_clock
), GFP_KERNEL
);
1097 clock
->caps
.pin_config
= kcalloc(DP83640_N_PINS
,
1098 sizeof(struct ptp_pin_desc
),
1100 if (!clock
->caps
.pin_config
) {
1105 dp83640_clock_init(clock
, bus
);
1106 list_add_tail(&phyter_clocks
, &clock
->list
);
1108 mutex_unlock(&phyter_clocks_lock
);
1110 return dp83640_clock_get(clock
);
1113 static void dp83640_clock_put(struct dp83640_clock
*clock
)
1115 mutex_unlock(&clock
->clock_lock
);
1118 static int dp83640_probe(struct phy_device
*phydev
)
1120 struct dp83640_clock
*clock
;
1121 struct dp83640_private
*dp83640
;
1122 int err
= -ENOMEM
, i
;
1124 if (phydev
->mdio
.addr
== BROADCAST_ADDR
)
1127 clock
= dp83640_clock_get_bus(phydev
->mdio
.bus
);
1131 dp83640
= kzalloc(sizeof(struct dp83640_private
), GFP_KERNEL
);
1135 dp83640
->phydev
= phydev
;
1136 INIT_DELAYED_WORK(&dp83640
->ts_work
, rx_timestamp_work
);
1138 INIT_LIST_HEAD(&dp83640
->rxts
);
1139 INIT_LIST_HEAD(&dp83640
->rxpool
);
1140 for (i
= 0; i
< MAX_RXTS
; i
++)
1141 list_add(&dp83640
->rx_pool_data
[i
].list
, &dp83640
->rxpool
);
1143 phydev
->priv
= dp83640
;
1145 spin_lock_init(&dp83640
->rx_lock
);
1146 skb_queue_head_init(&dp83640
->rx_queue
);
1147 skb_queue_head_init(&dp83640
->tx_queue
);
1149 dp83640
->clock
= clock
;
1151 if (choose_this_phy(clock
, phydev
)) {
1152 clock
->chosen
= dp83640
;
1153 clock
->ptp_clock
= ptp_clock_register(&clock
->caps
,
1155 if (IS_ERR(clock
->ptp_clock
)) {
1156 err
= PTR_ERR(clock
->ptp_clock
);
1160 list_add_tail(&dp83640
->list
, &clock
->phylist
);
1162 dp83640_clock_put(clock
);
1166 clock
->chosen
= NULL
;
1169 dp83640_clock_put(clock
);
1174 static void dp83640_remove(struct phy_device
*phydev
)
1176 struct dp83640_clock
*clock
;
1177 struct list_head
*this, *next
;
1178 struct dp83640_private
*tmp
, *dp83640
= phydev
->priv
;
1180 if (phydev
->mdio
.addr
== BROADCAST_ADDR
)
1183 enable_status_frames(phydev
, false);
1184 cancel_delayed_work_sync(&dp83640
->ts_work
);
1186 skb_queue_purge(&dp83640
->rx_queue
);
1187 skb_queue_purge(&dp83640
->tx_queue
);
1189 clock
= dp83640_clock_get(dp83640
->clock
);
1191 if (dp83640
== clock
->chosen
) {
1192 ptp_clock_unregister(clock
->ptp_clock
);
1193 clock
->chosen
= NULL
;
1195 list_for_each_safe(this, next
, &clock
->phylist
) {
1196 tmp
= list_entry(this, struct dp83640_private
, list
);
1197 if (tmp
== dp83640
) {
1198 list_del_init(&tmp
->list
);
1204 dp83640_clock_put(clock
);
1208 static int dp83640_soft_reset(struct phy_device
*phydev
)
1212 ret
= genphy_soft_reset(phydev
);
1216 /* From DP83640 datasheet: "Software driver code must wait 3 us
1217 * following a software reset before allowing further serial MII
1218 * operations with the DP83640."
1220 udelay(10); /* Taking udelay inaccuracy into account */
1225 static int dp83640_config_init(struct phy_device
*phydev
)
1227 struct dp83640_private
*dp83640
= phydev
->priv
;
1228 struct dp83640_clock
*clock
= dp83640
->clock
;
1230 if (clock
->chosen
&& !list_empty(&clock
->phylist
))
1233 mutex_lock(&clock
->extreg_lock
);
1234 enable_broadcast(phydev
, clock
->page
, 1);
1235 mutex_unlock(&clock
->extreg_lock
);
1238 enable_status_frames(phydev
, true);
1240 mutex_lock(&clock
->extreg_lock
);
1241 ext_write(0, phydev
, PAGE4
, PTP_CTL
, PTP_ENABLE
);
1242 mutex_unlock(&clock
->extreg_lock
);
1247 static int dp83640_ack_interrupt(struct phy_device
*phydev
)
1249 int err
= phy_read(phydev
, MII_DP83640_MISR
);
1257 static int dp83640_config_intr(struct phy_device
*phydev
)
1263 if (phydev
->interrupts
== PHY_INTERRUPT_ENABLED
) {
1264 misr
= phy_read(phydev
, MII_DP83640_MISR
);
1268 (MII_DP83640_MISR_ANC_INT_EN
|
1269 MII_DP83640_MISR_DUP_INT_EN
|
1270 MII_DP83640_MISR_SPD_INT_EN
|
1271 MII_DP83640_MISR_LINK_INT_EN
);
1272 err
= phy_write(phydev
, MII_DP83640_MISR
, misr
);
1276 micr
= phy_read(phydev
, MII_DP83640_MICR
);
1280 (MII_DP83640_MICR_OE
|
1281 MII_DP83640_MICR_IE
);
1282 return phy_write(phydev
, MII_DP83640_MICR
, micr
);
1284 micr
= phy_read(phydev
, MII_DP83640_MICR
);
1288 ~(MII_DP83640_MICR_OE
|
1289 MII_DP83640_MICR_IE
);
1290 err
= phy_write(phydev
, MII_DP83640_MICR
, micr
);
1294 misr
= phy_read(phydev
, MII_DP83640_MISR
);
1298 ~(MII_DP83640_MISR_ANC_INT_EN
|
1299 MII_DP83640_MISR_DUP_INT_EN
|
1300 MII_DP83640_MISR_SPD_INT_EN
|
1301 MII_DP83640_MISR_LINK_INT_EN
);
1302 return phy_write(phydev
, MII_DP83640_MISR
, misr
);
1306 static int dp83640_hwtstamp(struct phy_device
*phydev
, struct ifreq
*ifr
)
1308 struct dp83640_private
*dp83640
= phydev
->priv
;
1309 struct hwtstamp_config cfg
;
1312 if (copy_from_user(&cfg
, ifr
->ifr_data
, sizeof(cfg
)))
1315 if (cfg
.flags
) /* reserved for future extensions */
1318 if (cfg
.tx_type
< 0 || cfg
.tx_type
> HWTSTAMP_TX_ONESTEP_SYNC
)
1321 dp83640
->hwts_tx_en
= cfg
.tx_type
;
1323 switch (cfg
.rx_filter
) {
1324 case HWTSTAMP_FILTER_NONE
:
1325 dp83640
->hwts_rx_en
= 0;
1327 dp83640
->version
= 0;
1329 case HWTSTAMP_FILTER_PTP_V1_L4_EVENT
:
1330 case HWTSTAMP_FILTER_PTP_V1_L4_SYNC
:
1331 case HWTSTAMP_FILTER_PTP_V1_L4_DELAY_REQ
:
1332 dp83640
->hwts_rx_en
= 1;
1333 dp83640
->layer
= PTP_CLASS_L4
;
1334 dp83640
->version
= PTP_CLASS_V1
;
1336 case HWTSTAMP_FILTER_PTP_V2_L4_EVENT
:
1337 case HWTSTAMP_FILTER_PTP_V2_L4_SYNC
:
1338 case HWTSTAMP_FILTER_PTP_V2_L4_DELAY_REQ
:
1339 dp83640
->hwts_rx_en
= 1;
1340 dp83640
->layer
= PTP_CLASS_L4
;
1341 dp83640
->version
= PTP_CLASS_V2
;
1343 case HWTSTAMP_FILTER_PTP_V2_L2_EVENT
:
1344 case HWTSTAMP_FILTER_PTP_V2_L2_SYNC
:
1345 case HWTSTAMP_FILTER_PTP_V2_L2_DELAY_REQ
:
1346 dp83640
->hwts_rx_en
= 1;
1347 dp83640
->layer
= PTP_CLASS_L2
;
1348 dp83640
->version
= PTP_CLASS_V2
;
1350 case HWTSTAMP_FILTER_PTP_V2_EVENT
:
1351 case HWTSTAMP_FILTER_PTP_V2_SYNC
:
1352 case HWTSTAMP_FILTER_PTP_V2_DELAY_REQ
:
1353 dp83640
->hwts_rx_en
= 1;
1354 dp83640
->layer
= PTP_CLASS_L4
| PTP_CLASS_L2
;
1355 dp83640
->version
= PTP_CLASS_V2
;
1361 txcfg0
= (dp83640
->version
& TX_PTP_VER_MASK
) << TX_PTP_VER_SHIFT
;
1362 rxcfg0
= (dp83640
->version
& TX_PTP_VER_MASK
) << TX_PTP_VER_SHIFT
;
1364 if (dp83640
->layer
& PTP_CLASS_L2
) {
1368 if (dp83640
->layer
& PTP_CLASS_L4
) {
1369 txcfg0
|= TX_IPV6_EN
| TX_IPV4_EN
;
1370 rxcfg0
|= RX_IPV6_EN
| RX_IPV4_EN
;
1373 if (dp83640
->hwts_tx_en
)
1376 if (dp83640
->hwts_tx_en
== HWTSTAMP_TX_ONESTEP_SYNC
)
1377 txcfg0
|= SYNC_1STEP
| CHK_1STEP
;
1379 if (dp83640
->hwts_rx_en
)
1382 mutex_lock(&dp83640
->clock
->extreg_lock
);
1384 ext_write(0, phydev
, PAGE5
, PTP_TXCFG0
, txcfg0
);
1385 ext_write(0, phydev
, PAGE5
, PTP_RXCFG0
, rxcfg0
);
1387 mutex_unlock(&dp83640
->clock
->extreg_lock
);
1389 return copy_to_user(ifr
->ifr_data
, &cfg
, sizeof(cfg
)) ? -EFAULT
: 0;
1392 static void rx_timestamp_work(struct work_struct
*work
)
1394 struct dp83640_private
*dp83640
=
1395 container_of(work
, struct dp83640_private
, ts_work
.work
);
1396 struct sk_buff
*skb
;
1398 /* Deliver expired packets. */
1399 while ((skb
= skb_dequeue(&dp83640
->rx_queue
))) {
1400 struct dp83640_skb_info
*skb_info
;
1402 skb_info
= (struct dp83640_skb_info
*)skb
->cb
;
1403 if (!time_after(jiffies
, skb_info
->tmo
)) {
1404 skb_queue_head(&dp83640
->rx_queue
, skb
);
1411 if (!skb_queue_empty(&dp83640
->rx_queue
))
1412 schedule_delayed_work(&dp83640
->ts_work
, SKB_TIMESTAMP_TIMEOUT
);
1415 static bool dp83640_rxtstamp(struct phy_device
*phydev
,
1416 struct sk_buff
*skb
, int type
)
1418 struct dp83640_private
*dp83640
= phydev
->priv
;
1419 struct dp83640_skb_info
*skb_info
= (struct dp83640_skb_info
*)skb
->cb
;
1420 struct list_head
*this, *next
;
1422 struct skb_shared_hwtstamps
*shhwtstamps
= NULL
;
1423 unsigned long flags
;
1425 if (is_status_frame(skb
, type
)) {
1426 decode_status_frame(dp83640
, skb
);
1431 if (!dp83640
->hwts_rx_en
)
1434 if ((type
& dp83640
->version
) == 0 || (type
& dp83640
->layer
) == 0)
1437 spin_lock_irqsave(&dp83640
->rx_lock
, flags
);
1438 prune_rx_ts(dp83640
);
1439 list_for_each_safe(this, next
, &dp83640
->rxts
) {
1440 rxts
= list_entry(this, struct rxts
, list
);
1441 if (match(skb
, type
, rxts
)) {
1442 shhwtstamps
= skb_hwtstamps(skb
);
1443 memset(shhwtstamps
, 0, sizeof(*shhwtstamps
));
1444 shhwtstamps
->hwtstamp
= ns_to_ktime(rxts
->ns
);
1445 list_del_init(&rxts
->list
);
1446 list_add(&rxts
->list
, &dp83640
->rxpool
);
1450 spin_unlock_irqrestore(&dp83640
->rx_lock
, flags
);
1453 skb_info
->ptp_type
= type
;
1454 skb_info
->tmo
= jiffies
+ SKB_TIMESTAMP_TIMEOUT
;
1455 skb_queue_tail(&dp83640
->rx_queue
, skb
);
1456 schedule_delayed_work(&dp83640
->ts_work
, SKB_TIMESTAMP_TIMEOUT
);
1464 static void dp83640_txtstamp(struct phy_device
*phydev
,
1465 struct sk_buff
*skb
, int type
)
1467 struct dp83640_skb_info
*skb_info
= (struct dp83640_skb_info
*)skb
->cb
;
1468 struct dp83640_private
*dp83640
= phydev
->priv
;
1470 switch (dp83640
->hwts_tx_en
) {
1472 case HWTSTAMP_TX_ONESTEP_SYNC
:
1473 if (is_sync(skb
, type
)) {
1478 case HWTSTAMP_TX_ON
:
1479 skb_shinfo(skb
)->tx_flags
|= SKBTX_IN_PROGRESS
;
1480 skb_info
->tmo
= jiffies
+ SKB_TIMESTAMP_TIMEOUT
;
1481 skb_queue_tail(&dp83640
->tx_queue
, skb
);
1484 case HWTSTAMP_TX_OFF
:
1491 static int dp83640_ts_info(struct phy_device
*dev
, struct ethtool_ts_info
*info
)
1493 struct dp83640_private
*dp83640
= dev
->priv
;
1495 info
->so_timestamping
=
1496 SOF_TIMESTAMPING_TX_HARDWARE
|
1497 SOF_TIMESTAMPING_RX_HARDWARE
|
1498 SOF_TIMESTAMPING_RAW_HARDWARE
;
1499 info
->phc_index
= ptp_clock_index(dp83640
->clock
->ptp_clock
);
1501 (1 << HWTSTAMP_TX_OFF
) |
1502 (1 << HWTSTAMP_TX_ON
) |
1503 (1 << HWTSTAMP_TX_ONESTEP_SYNC
);
1505 (1 << HWTSTAMP_FILTER_NONE
) |
1506 (1 << HWTSTAMP_FILTER_PTP_V1_L4_EVENT
) |
1507 (1 << HWTSTAMP_FILTER_PTP_V2_L4_EVENT
) |
1508 (1 << HWTSTAMP_FILTER_PTP_V2_L2_EVENT
) |
1509 (1 << HWTSTAMP_FILTER_PTP_V2_EVENT
);
1513 static struct phy_driver dp83640_driver
= {
1514 .phy_id
= DP83640_PHY_ID
,
1515 .phy_id_mask
= 0xfffffff0,
1516 .name
= "NatSemi DP83640",
1517 /* PHY_BASIC_FEATURES */
1518 .probe
= dp83640_probe
,
1519 .remove
= dp83640_remove
,
1520 .soft_reset
= dp83640_soft_reset
,
1521 .config_init
= dp83640_config_init
,
1522 .ack_interrupt
= dp83640_ack_interrupt
,
1523 .config_intr
= dp83640_config_intr
,
1524 .ts_info
= dp83640_ts_info
,
1525 .hwtstamp
= dp83640_hwtstamp
,
1526 .rxtstamp
= dp83640_rxtstamp
,
1527 .txtstamp
= dp83640_txtstamp
,
1530 static int __init
dp83640_init(void)
1532 return phy_driver_register(&dp83640_driver
, THIS_MODULE
);
1535 static void __exit
dp83640_exit(void)
1537 dp83640_free_clocks();
1538 phy_driver_unregister(&dp83640_driver
);
1541 MODULE_DESCRIPTION("National Semiconductor DP83640 PHY driver");
1542 MODULE_AUTHOR("Richard Cochran <richardcochran@gmail.com>");
1543 MODULE_LICENSE("GPL");
1545 module_init(dp83640_init
);
1546 module_exit(dp83640_exit
);
1548 static struct mdio_device_id __maybe_unused dp83640_tbl
[] = {
1549 { DP83640_PHY_ID
, 0xfffffff0 },
1553 MODULE_DEVICE_TABLE(mdio
, dp83640_tbl
);