xref: /openbmc/linux/drivers/net/ethernet/aquantia/atlantic/aq_ptp.c (revision 2b1b1267080fe822789d0845a58ebb452724736b)
1 // SPDX-License-Identifier: GPL-2.0-only
2 /* Aquantia Corporation Network Driver
3  * Copyright (C) 2014-2019 Aquantia Corporation. All rights reserved
4  */
5 
6 /* File aq_ptp.c:
7  * Definition of functions for Linux PTP support.
8  */
9 
10 #include <linux/ptp_clock_kernel.h>
11 #include <linux/ptp_classify.h>
12 #include <linux/interrupt.h>
13 #include <linux/clocksource.h>
14 
15 #include "aq_nic.h"
16 #include "aq_ptp.h"
17 #include "aq_ring.h"
18 #include "aq_phy.h"
19 #include "aq_filters.h"
20 
21 #define AQ_PTP_TX_TIMEOUT        (HZ *  10)
22 
23 #define POLL_SYNC_TIMER_MS 15
24 
25 enum ptp_speed_offsets {
26 	ptp_offset_idx_10 = 0,
27 	ptp_offset_idx_100,
28 	ptp_offset_idx_1000,
29 	ptp_offset_idx_2500,
30 	ptp_offset_idx_5000,
31 	ptp_offset_idx_10000,
32 };
33 
34 struct ptp_skb_ring {
35 	struct sk_buff **buff;
36 	spinlock_t lock;
37 	unsigned int size;
38 	unsigned int head;
39 	unsigned int tail;
40 };
41 
42 struct ptp_tx_timeout {
43 	spinlock_t lock;
44 	bool active;
45 	unsigned long tx_start;
46 };
47 
48 struct aq_ptp_s {
49 	struct aq_nic_s *aq_nic;
50 	struct hwtstamp_config hwtstamp_config;
51 	spinlock_t ptp_lock;
52 	spinlock_t ptp_ring_lock;
53 	struct ptp_clock *ptp_clock;
54 	struct ptp_clock_info ptp_info;
55 
56 	atomic_t offset_egress;
57 	atomic_t offset_ingress;
58 
59 	struct aq_ring_param_s ptp_ring_param;
60 
61 	struct ptp_tx_timeout ptp_tx_timeout;
62 
63 	unsigned int idx_vector;
64 	struct napi_struct napi;
65 
66 	struct aq_ring_s ptp_tx;
67 	struct aq_ring_s ptp_rx;
68 	struct aq_ring_s hwts_rx;
69 
70 	struct ptp_skb_ring skb_ring;
71 
72 	struct aq_rx_filter_l3l4 udp_filter;
73 	struct aq_rx_filter_l2 eth_type_filter;
74 
75 	struct delayed_work poll_sync;
76 	u32 poll_timeout_ms;
77 
78 	bool extts_pin_enabled;
79 	u64 last_sync1588_ts;
80 };
81 
82 struct ptp_tm_offset {
83 	unsigned int mbps;
84 	int egress;
85 	int ingress;
86 };
87 
88 static struct ptp_tm_offset ptp_offset[6];
89 
90 void aq_ptp_tm_offset_set(struct aq_nic_s *aq_nic, unsigned int mbps)
91 {
92 	struct aq_ptp_s *aq_ptp = aq_nic->aq_ptp;
93 	int i, egress, ingress;
94 
95 	if (!aq_ptp)
96 		return;
97 
98 	egress = 0;
99 	ingress = 0;
100 
101 	for (i = 0; i < ARRAY_SIZE(ptp_offset); i++) {
102 		if (mbps == ptp_offset[i].mbps) {
103 			egress = ptp_offset[i].egress;
104 			ingress = ptp_offset[i].ingress;
105 			break;
106 		}
107 	}
108 
109 	atomic_set(&aq_ptp->offset_egress, egress);
110 	atomic_set(&aq_ptp->offset_ingress, ingress);
111 }
112 
113 static int __aq_ptp_skb_put(struct ptp_skb_ring *ring, struct sk_buff *skb)
114 {
115 	unsigned int next_head = (ring->head + 1) % ring->size;
116 
117 	if (next_head == ring->tail)
118 		return -ENOMEM;
119 
120 	ring->buff[ring->head] = skb_get(skb);
121 	ring->head = next_head;
122 
123 	return 0;
124 }
125 
126 static int aq_ptp_skb_put(struct ptp_skb_ring *ring, struct sk_buff *skb)
127 {
128 	unsigned long flags;
129 	int ret;
130 
131 	spin_lock_irqsave(&ring->lock, flags);
132 	ret = __aq_ptp_skb_put(ring, skb);
133 	spin_unlock_irqrestore(&ring->lock, flags);
134 
135 	return ret;
136 }
137 
138 static struct sk_buff *__aq_ptp_skb_get(struct ptp_skb_ring *ring)
139 {
140 	struct sk_buff *skb;
141 
142 	if (ring->tail == ring->head)
143 		return NULL;
144 
145 	skb = ring->buff[ring->tail];
146 	ring->tail = (ring->tail + 1) % ring->size;
147 
148 	return skb;
149 }
150 
151 static struct sk_buff *aq_ptp_skb_get(struct ptp_skb_ring *ring)
152 {
153 	unsigned long flags;
154 	struct sk_buff *skb;
155 
156 	spin_lock_irqsave(&ring->lock, flags);
157 	skb = __aq_ptp_skb_get(ring);
158 	spin_unlock_irqrestore(&ring->lock, flags);
159 
160 	return skb;
161 }
162 
163 static unsigned int aq_ptp_skb_buf_len(struct ptp_skb_ring *ring)
164 {
165 	unsigned long flags;
166 	unsigned int len;
167 
168 	spin_lock_irqsave(&ring->lock, flags);
169 	len = (ring->head >= ring->tail) ?
170 	ring->head - ring->tail :
171 	ring->size - ring->tail + ring->head;
172 	spin_unlock_irqrestore(&ring->lock, flags);
173 
174 	return len;
175 }
176 
177 static int aq_ptp_skb_ring_init(struct ptp_skb_ring *ring, unsigned int size)
178 {
179 	struct sk_buff **buff = kmalloc(sizeof(*buff) * size, GFP_KERNEL);
180 
181 	if (!buff)
182 		return -ENOMEM;
183 
184 	spin_lock_init(&ring->lock);
185 
186 	ring->buff = buff;
187 	ring->size = size;
188 	ring->head = 0;
189 	ring->tail = 0;
190 
191 	return 0;
192 }
193 
194 static void aq_ptp_skb_ring_clean(struct ptp_skb_ring *ring)
195 {
196 	struct sk_buff *skb;
197 
198 	while ((skb = aq_ptp_skb_get(ring)) != NULL)
199 		dev_kfree_skb_any(skb);
200 }
201 
202 static void aq_ptp_skb_ring_release(struct ptp_skb_ring *ring)
203 {
204 	if (ring->buff) {
205 		aq_ptp_skb_ring_clean(ring);
206 		kfree(ring->buff);
207 		ring->buff = NULL;
208 	}
209 }
210 
211 static void aq_ptp_tx_timeout_init(struct ptp_tx_timeout *timeout)
212 {
213 	spin_lock_init(&timeout->lock);
214 	timeout->active = false;
215 }
216 
217 static void aq_ptp_tx_timeout_start(struct aq_ptp_s *aq_ptp)
218 {
219 	struct ptp_tx_timeout *timeout = &aq_ptp->ptp_tx_timeout;
220 	unsigned long flags;
221 
222 	spin_lock_irqsave(&timeout->lock, flags);
223 	timeout->active = true;
224 	timeout->tx_start = jiffies;
225 	spin_unlock_irqrestore(&timeout->lock, flags);
226 }
227 
228 static void aq_ptp_tx_timeout_update(struct aq_ptp_s *aq_ptp)
229 {
230 	if (!aq_ptp_skb_buf_len(&aq_ptp->skb_ring)) {
231 		struct ptp_tx_timeout *timeout = &aq_ptp->ptp_tx_timeout;
232 		unsigned long flags;
233 
234 		spin_lock_irqsave(&timeout->lock, flags);
235 		timeout->active = false;
236 		spin_unlock_irqrestore(&timeout->lock, flags);
237 	}
238 }
239 
240 static void aq_ptp_tx_timeout_check(struct aq_ptp_s *aq_ptp)
241 {
242 	struct ptp_tx_timeout *timeout = &aq_ptp->ptp_tx_timeout;
243 	unsigned long flags;
244 	bool timeout_flag;
245 
246 	timeout_flag = false;
247 
248 	spin_lock_irqsave(&timeout->lock, flags);
249 	if (timeout->active) {
250 		timeout_flag = time_is_before_jiffies(timeout->tx_start +
251 						      AQ_PTP_TX_TIMEOUT);
252 		/* reset active flag if timeout detected */
253 		if (timeout_flag)
254 			timeout->active = false;
255 	}
256 	spin_unlock_irqrestore(&timeout->lock, flags);
257 
258 	if (timeout_flag) {
259 		aq_ptp_skb_ring_clean(&aq_ptp->skb_ring);
260 		netdev_err(aq_ptp->aq_nic->ndev,
261 			   "PTP Timeout. Clearing Tx Timestamp SKBs\n");
262 	}
263 }
264 
265 /* aq_ptp_adjfine
266  * @ptp: the ptp clock structure
267  * @ppb: parts per billion adjustment from base
268  *
269  * adjust the frequency of the ptp cycle counter by the
270  * indicated ppb from the base frequency.
271  */
272 static int aq_ptp_adjfine(struct ptp_clock_info *ptp, long scaled_ppm)
273 {
274 	struct aq_ptp_s *aq_ptp = container_of(ptp, struct aq_ptp_s, ptp_info);
275 	struct aq_nic_s *aq_nic = aq_ptp->aq_nic;
276 
277 	mutex_lock(&aq_nic->fwreq_mutex);
278 	aq_nic->aq_hw_ops->hw_adj_clock_freq(aq_nic->aq_hw,
279 					     scaled_ppm_to_ppb(scaled_ppm));
280 	mutex_unlock(&aq_nic->fwreq_mutex);
281 
282 	return 0;
283 }
284 
285 /* aq_ptp_adjtime
286  * @ptp: the ptp clock structure
287  * @delta: offset to adjust the cycle counter by
288  *
289  * adjust the timer by resetting the timecounter structure.
290  */
291 static int aq_ptp_adjtime(struct ptp_clock_info *ptp, s64 delta)
292 {
293 	struct aq_ptp_s *aq_ptp = container_of(ptp, struct aq_ptp_s, ptp_info);
294 	struct aq_nic_s *aq_nic = aq_ptp->aq_nic;
295 	unsigned long flags;
296 
297 	spin_lock_irqsave(&aq_ptp->ptp_lock, flags);
298 	aq_nic->aq_hw_ops->hw_adj_sys_clock(aq_nic->aq_hw, delta);
299 	spin_unlock_irqrestore(&aq_ptp->ptp_lock, flags);
300 
301 	return 0;
302 }
303 
304 /* aq_ptp_gettime
305  * @ptp: the ptp clock structure
306  * @ts: timespec structure to hold the current time value
307  *
308  * read the timecounter and return the correct value on ns,
309  * after converting it into a struct timespec.
310  */
311 static int aq_ptp_gettime(struct ptp_clock_info *ptp, struct timespec64 *ts)
312 {
313 	struct aq_ptp_s *aq_ptp = container_of(ptp, struct aq_ptp_s, ptp_info);
314 	struct aq_nic_s *aq_nic = aq_ptp->aq_nic;
315 	unsigned long flags;
316 	u64 ns;
317 
318 	spin_lock_irqsave(&aq_ptp->ptp_lock, flags);
319 	aq_nic->aq_hw_ops->hw_get_ptp_ts(aq_nic->aq_hw, &ns);
320 	spin_unlock_irqrestore(&aq_ptp->ptp_lock, flags);
321 
322 	*ts = ns_to_timespec64(ns);
323 
324 	return 0;
325 }
326 
327 /* aq_ptp_settime
328  * @ptp: the ptp clock structure
329  * @ts: the timespec containing the new time for the cycle counter
330  *
331  * reset the timecounter to use a new base value instead of the kernel
332  * wall timer value.
333  */
334 static int aq_ptp_settime(struct ptp_clock_info *ptp,
335 			  const struct timespec64 *ts)
336 {
337 	struct aq_ptp_s *aq_ptp = container_of(ptp, struct aq_ptp_s, ptp_info);
338 	struct aq_nic_s *aq_nic = aq_ptp->aq_nic;
339 	unsigned long flags;
340 	u64 ns = timespec64_to_ns(ts);
341 	u64 now;
342 
343 	spin_lock_irqsave(&aq_ptp->ptp_lock, flags);
344 	aq_nic->aq_hw_ops->hw_get_ptp_ts(aq_nic->aq_hw, &now);
345 	aq_nic->aq_hw_ops->hw_adj_sys_clock(aq_nic->aq_hw, (s64)ns - (s64)now);
346 
347 	spin_unlock_irqrestore(&aq_ptp->ptp_lock, flags);
348 
349 	return 0;
350 }
351 
352 static void aq_ptp_convert_to_hwtstamp(struct aq_ptp_s *aq_ptp,
353 				       struct skb_shared_hwtstamps *hwtstamp,
354 				       u64 timestamp)
355 {
356 	memset(hwtstamp, 0, sizeof(*hwtstamp));
357 	hwtstamp->hwtstamp = ns_to_ktime(timestamp);
358 }
359 
360 static int aq_ptp_hw_pin_conf(struct aq_nic_s *aq_nic, u32 pin_index, u64 start,
361 			      u64 period)
362 {
363 	if (period)
364 		netdev_dbg(aq_nic->ndev,
365 			   "Enable GPIO %d pulsing, start time %llu, period %u\n",
366 			   pin_index, start, (u32)period);
367 	else
368 		netdev_dbg(aq_nic->ndev,
369 			   "Disable GPIO %d pulsing, start time %llu, period %u\n",
370 			   pin_index, start, (u32)period);
371 
372 	/* Notify hardware of request to being sending pulses.
373 	 * If period is ZERO then pulsen is disabled.
374 	 */
375 	mutex_lock(&aq_nic->fwreq_mutex);
376 	aq_nic->aq_hw_ops->hw_gpio_pulse(aq_nic->aq_hw, pin_index,
377 					 start, (u32)period);
378 	mutex_unlock(&aq_nic->fwreq_mutex);
379 
380 	return 0;
381 }
382 
383 static int aq_ptp_perout_pin_configure(struct ptp_clock_info *ptp,
384 				       struct ptp_clock_request *rq, int on)
385 {
386 	struct aq_ptp_s *aq_ptp = container_of(ptp, struct aq_ptp_s, ptp_info);
387 	struct ptp_clock_time *t = &rq->perout.period;
388 	struct ptp_clock_time *s = &rq->perout.start;
389 	struct aq_nic_s *aq_nic = aq_ptp->aq_nic;
390 	u64 start, period;
391 	u32 pin_index = rq->perout.index;
392 
393 	/* verify the request channel is there */
394 	if (pin_index >= ptp->n_per_out)
395 		return -EINVAL;
396 
397 	/* we cannot support periods greater
398 	 * than 4 seconds due to reg limit
399 	 */
400 	if (t->sec > 4 || t->sec < 0)
401 		return -ERANGE;
402 
403 	/* convert to unsigned 64b ns,
404 	 * verify we can put it in a 32b register
405 	 */
406 	period = on ? t->sec * NSEC_PER_SEC + t->nsec : 0;
407 
408 	/* verify the value is in range supported by hardware */
409 	if (period > U32_MAX)
410 		return -ERANGE;
411 	/* convert to unsigned 64b ns */
412 	/* TODO convert to AQ time */
413 	start = on ? s->sec * NSEC_PER_SEC + s->nsec : 0;
414 
415 	aq_ptp_hw_pin_conf(aq_nic, pin_index, start, period);
416 
417 	return 0;
418 }
419 
420 static int aq_ptp_pps_pin_configure(struct ptp_clock_info *ptp,
421 				    struct ptp_clock_request *rq, int on)
422 {
423 	struct aq_ptp_s *aq_ptp = container_of(ptp, struct aq_ptp_s, ptp_info);
424 	struct aq_nic_s *aq_nic = aq_ptp->aq_nic;
425 	u64 start, period;
426 	u32 pin_index = 0;
427 	u32 rest = 0;
428 
429 	/* verify the request channel is there */
430 	if (pin_index >= ptp->n_per_out)
431 		return -EINVAL;
432 
433 	aq_nic->aq_hw_ops->hw_get_ptp_ts(aq_nic->aq_hw, &start);
434 	div_u64_rem(start, NSEC_PER_SEC, &rest);
435 	period = on ? NSEC_PER_SEC : 0; /* PPS - pulse per second */
436 	start = on ? start - rest + NSEC_PER_SEC *
437 		(rest > 990000000LL ? 2 : 1) : 0;
438 
439 	aq_ptp_hw_pin_conf(aq_nic, pin_index, start, period);
440 
441 	return 0;
442 }
443 
444 static void aq_ptp_extts_pin_ctrl(struct aq_ptp_s *aq_ptp)
445 {
446 	struct aq_nic_s *aq_nic = aq_ptp->aq_nic;
447 	u32 enable = aq_ptp->extts_pin_enabled;
448 
449 	if (aq_nic->aq_hw_ops->hw_extts_gpio_enable)
450 		aq_nic->aq_hw_ops->hw_extts_gpio_enable(aq_nic->aq_hw, 0,
451 							enable);
452 }
453 
454 static int aq_ptp_extts_pin_configure(struct ptp_clock_info *ptp,
455 				      struct ptp_clock_request *rq, int on)
456 {
457 	struct aq_ptp_s *aq_ptp = container_of(ptp, struct aq_ptp_s, ptp_info);
458 
459 	u32 pin_index = rq->extts.index;
460 
461 	if (pin_index >= ptp->n_ext_ts)
462 		return -EINVAL;
463 
464 	aq_ptp->extts_pin_enabled = !!on;
465 	if (on) {
466 		aq_ptp->poll_timeout_ms = POLL_SYNC_TIMER_MS;
467 		cancel_delayed_work_sync(&aq_ptp->poll_sync);
468 		schedule_delayed_work(&aq_ptp->poll_sync,
469 				      msecs_to_jiffies(aq_ptp->poll_timeout_ms));
470 	}
471 
472 	aq_ptp_extts_pin_ctrl(aq_ptp);
473 	return 0;
474 }
475 
476 /* aq_ptp_gpio_feature_enable
477  * @ptp: the ptp clock structure
478  * @rq: the requested feature to change
479  * @on: whether to enable or disable the feature
480  */
481 static int aq_ptp_gpio_feature_enable(struct ptp_clock_info *ptp,
482 				      struct ptp_clock_request *rq, int on)
483 {
484 	switch (rq->type) {
485 	case PTP_CLK_REQ_EXTTS:
486 		return aq_ptp_extts_pin_configure(ptp, rq, on);
487 	case PTP_CLK_REQ_PEROUT:
488 		return aq_ptp_perout_pin_configure(ptp, rq, on);
489 	case PTP_CLK_REQ_PPS:
490 		return aq_ptp_pps_pin_configure(ptp, rq, on);
491 	default:
492 		return -EOPNOTSUPP;
493 	}
494 
495 	return 0;
496 }
497 
498 /* aq_ptp_verify
499  * @ptp: the ptp clock structure
500  * @pin: index of the pin in question
501  * @func: the desired function to use
502  * @chan: the function channel index to use
503  */
504 static int aq_ptp_verify(struct ptp_clock_info *ptp, unsigned int pin,
505 			 enum ptp_pin_function func, unsigned int chan)
506 {
507 	/* verify the requested pin is there */
508 	if (!ptp->pin_config || pin >= ptp->n_pins)
509 		return -EINVAL;
510 
511 	/* enforce locked channels, no changing them */
512 	if (chan != ptp->pin_config[pin].chan)
513 		return -EINVAL;
514 
515 	/* we want to keep the functions locked as well */
516 	if (func != ptp->pin_config[pin].func)
517 		return -EINVAL;
518 
519 	return 0;
520 }
521 
522 /* aq_ptp_tx_hwtstamp - utility function which checks for TX time stamp
523  * @adapter: the private adapter struct
524  *
525  * if the timestamp is valid, we convert it into the timecounter ns
526  * value, then store that result into the hwtstamps structure which
527  * is passed up the network stack
528  */
529 void aq_ptp_tx_hwtstamp(struct aq_nic_s *aq_nic, u64 timestamp)
530 {
531 	struct aq_ptp_s *aq_ptp = aq_nic->aq_ptp;
532 	struct sk_buff *skb = aq_ptp_skb_get(&aq_ptp->skb_ring);
533 	struct skb_shared_hwtstamps hwtstamp;
534 
535 	if (!skb) {
536 		netdev_err(aq_nic->ndev, "have timestamp but tx_queues empty\n");
537 		return;
538 	}
539 
540 	timestamp += atomic_read(&aq_ptp->offset_egress);
541 	aq_ptp_convert_to_hwtstamp(aq_ptp, &hwtstamp, timestamp);
542 	skb_tstamp_tx(skb, &hwtstamp);
543 	dev_kfree_skb_any(skb);
544 
545 	aq_ptp_tx_timeout_update(aq_ptp);
546 }
547 
548 /* aq_ptp_rx_hwtstamp - utility function which checks for RX time stamp
549  * @adapter: pointer to adapter struct
550  * @skb: particular skb to send timestamp with
551  *
552  * if the timestamp is valid, we convert it into the timecounter ns
553  * value, then store that result into the hwtstamps structure which
554  * is passed up the network stack
555  */
556 static void aq_ptp_rx_hwtstamp(struct aq_ptp_s *aq_ptp, struct sk_buff *skb,
557 			       u64 timestamp)
558 {
559 	timestamp -= atomic_read(&aq_ptp->offset_ingress);
560 	aq_ptp_convert_to_hwtstamp(aq_ptp, skb_hwtstamps(skb), timestamp);
561 }
562 
563 void aq_ptp_hwtstamp_config_get(struct aq_ptp_s *aq_ptp,
564 				struct hwtstamp_config *config)
565 {
566 	*config = aq_ptp->hwtstamp_config;
567 }
568 
569 static void aq_ptp_prepare_filters(struct aq_ptp_s *aq_ptp)
570 {
571 	aq_ptp->udp_filter.cmd = HW_ATL_RX_ENABLE_FLTR_L3L4 |
572 			       HW_ATL_RX_ENABLE_CMP_PROT_L4 |
573 			       HW_ATL_RX_UDP |
574 			       HW_ATL_RX_ENABLE_CMP_DEST_PORT_L4 |
575 			       HW_ATL_RX_HOST << HW_ATL_RX_ACTION_FL3F4_SHIFT |
576 			       HW_ATL_RX_ENABLE_QUEUE_L3L4 |
577 			       aq_ptp->ptp_rx.idx << HW_ATL_RX_QUEUE_FL3L4_SHIFT;
578 	aq_ptp->udp_filter.p_dst = PTP_EV_PORT;
579 
580 	aq_ptp->eth_type_filter.ethertype = ETH_P_1588;
581 	aq_ptp->eth_type_filter.queue = aq_ptp->ptp_rx.idx;
582 }
583 
584 int aq_ptp_hwtstamp_config_set(struct aq_ptp_s *aq_ptp,
585 			       struct hwtstamp_config *config)
586 {
587 	struct aq_nic_s *aq_nic = aq_ptp->aq_nic;
588 	const struct aq_hw_ops *hw_ops;
589 	int err = 0;
590 
591 	hw_ops = aq_nic->aq_hw_ops;
592 	if (config->tx_type == HWTSTAMP_TX_ON ||
593 	    config->rx_filter == HWTSTAMP_FILTER_PTP_V2_EVENT) {
594 		aq_ptp_prepare_filters(aq_ptp);
595 		if (hw_ops->hw_filter_l3l4_set) {
596 			err = hw_ops->hw_filter_l3l4_set(aq_nic->aq_hw,
597 							 &aq_ptp->udp_filter);
598 		}
599 		if (!err && hw_ops->hw_filter_l2_set) {
600 			err = hw_ops->hw_filter_l2_set(aq_nic->aq_hw,
601 						       &aq_ptp->eth_type_filter);
602 		}
603 		aq_utils_obj_set(&aq_nic->flags, AQ_NIC_PTP_DPATH_UP);
604 	} else {
605 		aq_ptp->udp_filter.cmd &= ~HW_ATL_RX_ENABLE_FLTR_L3L4;
606 		if (hw_ops->hw_filter_l3l4_set) {
607 			err = hw_ops->hw_filter_l3l4_set(aq_nic->aq_hw,
608 							 &aq_ptp->udp_filter);
609 		}
610 		if (!err && hw_ops->hw_filter_l2_clear) {
611 			err = hw_ops->hw_filter_l2_clear(aq_nic->aq_hw,
612 							&aq_ptp->eth_type_filter);
613 		}
614 		aq_utils_obj_clear(&aq_nic->flags, AQ_NIC_PTP_DPATH_UP);
615 	}
616 
617 	if (err)
618 		return -EREMOTEIO;
619 
620 	aq_ptp->hwtstamp_config = *config;
621 
622 	return 0;
623 }
624 
625 bool aq_ptp_ring(struct aq_nic_s *aq_nic, struct aq_ring_s *ring)
626 {
627 	struct aq_ptp_s *aq_ptp = aq_nic->aq_ptp;
628 
629 	if (!aq_ptp)
630 		return false;
631 
632 	return &aq_ptp->ptp_tx == ring ||
633 	       &aq_ptp->ptp_rx == ring || &aq_ptp->hwts_rx == ring;
634 }
635 
636 u16 aq_ptp_extract_ts(struct aq_nic_s *aq_nic, struct sk_buff *skb, u8 *p,
637 		      unsigned int len)
638 {
639 	struct aq_ptp_s *aq_ptp = aq_nic->aq_ptp;
640 	u64 timestamp = 0;
641 	u16 ret = aq_nic->aq_hw_ops->rx_extract_ts(aq_nic->aq_hw,
642 						   p, len, &timestamp);
643 
644 	if (ret > 0)
645 		aq_ptp_rx_hwtstamp(aq_ptp, skb, timestamp);
646 
647 	return ret;
648 }
649 
650 static int aq_ptp_poll(struct napi_struct *napi, int budget)
651 {
652 	struct aq_ptp_s *aq_ptp = container_of(napi, struct aq_ptp_s, napi);
653 	struct aq_nic_s *aq_nic = aq_ptp->aq_nic;
654 	bool was_cleaned = false;
655 	int work_done = 0;
656 	int err;
657 
658 	/* Processing PTP TX traffic */
659 	err = aq_nic->aq_hw_ops->hw_ring_tx_head_update(aq_nic->aq_hw,
660 							&aq_ptp->ptp_tx);
661 	if (err < 0)
662 		goto err_exit;
663 
664 	if (aq_ptp->ptp_tx.sw_head != aq_ptp->ptp_tx.hw_head) {
665 		aq_ring_tx_clean(&aq_ptp->ptp_tx);
666 
667 		was_cleaned = true;
668 	}
669 
670 	/* Processing HW_TIMESTAMP RX traffic */
671 	err = aq_nic->aq_hw_ops->hw_ring_hwts_rx_receive(aq_nic->aq_hw,
672 							 &aq_ptp->hwts_rx);
673 	if (err < 0)
674 		goto err_exit;
675 
676 	if (aq_ptp->hwts_rx.sw_head != aq_ptp->hwts_rx.hw_head) {
677 		aq_ring_hwts_rx_clean(&aq_ptp->hwts_rx, aq_nic);
678 
679 		err = aq_nic->aq_hw_ops->hw_ring_hwts_rx_fill(aq_nic->aq_hw,
680 							      &aq_ptp->hwts_rx);
681 		if (err < 0)
682 			goto err_exit;
683 
684 		was_cleaned = true;
685 	}
686 
687 	/* Processing PTP RX traffic */
688 	err = aq_nic->aq_hw_ops->hw_ring_rx_receive(aq_nic->aq_hw,
689 						    &aq_ptp->ptp_rx);
690 	if (err < 0)
691 		goto err_exit;
692 
693 	if (aq_ptp->ptp_rx.sw_head != aq_ptp->ptp_rx.hw_head) {
694 		unsigned int sw_tail_old;
695 
696 		err = aq_ring_rx_clean(&aq_ptp->ptp_rx, napi, &work_done, budget);
697 		if (err < 0)
698 			goto err_exit;
699 
700 		sw_tail_old = aq_ptp->ptp_rx.sw_tail;
701 		err = aq_ring_rx_fill(&aq_ptp->ptp_rx);
702 		if (err < 0)
703 			goto err_exit;
704 
705 		err = aq_nic->aq_hw_ops->hw_ring_rx_fill(aq_nic->aq_hw,
706 							 &aq_ptp->ptp_rx,
707 							 sw_tail_old);
708 		if (err < 0)
709 			goto err_exit;
710 	}
711 
712 	if (was_cleaned)
713 		work_done = budget;
714 
715 	if (work_done < budget) {
716 		napi_complete_done(napi, work_done);
717 		aq_nic->aq_hw_ops->hw_irq_enable(aq_nic->aq_hw,
718 					BIT_ULL(aq_ptp->ptp_ring_param.vec_idx));
719 	}
720 
721 err_exit:
722 	return work_done;
723 }
724 
725 static irqreturn_t aq_ptp_isr(int irq, void *private)
726 {
727 	struct aq_ptp_s *aq_ptp = private;
728 	int err = 0;
729 
730 	if (!aq_ptp) {
731 		err = -EINVAL;
732 		goto err_exit;
733 	}
734 	napi_schedule(&aq_ptp->napi);
735 
736 err_exit:
737 	return err >= 0 ? IRQ_HANDLED : IRQ_NONE;
738 }
739 
740 int aq_ptp_xmit(struct aq_nic_s *aq_nic, struct sk_buff *skb)
741 {
742 	struct aq_ptp_s *aq_ptp = aq_nic->aq_ptp;
743 	struct aq_ring_s *ring = &aq_ptp->ptp_tx;
744 	unsigned long irq_flags;
745 	int err = NETDEV_TX_OK;
746 	unsigned int frags;
747 
748 	if (skb->len <= 0) {
749 		dev_kfree_skb_any(skb);
750 		goto err_exit;
751 	}
752 
753 	frags = skb_shinfo(skb)->nr_frags + 1;
754 	/* Frags cannot be bigger 16KB
755 	 * because PTP usually works
756 	 * without Jumbo even in a background
757 	 */
758 	if (frags > AQ_CFG_SKB_FRAGS_MAX || frags > aq_ring_avail_dx(ring)) {
759 		/* Drop packet because it doesn't make sence to delay it */
760 		dev_kfree_skb_any(skb);
761 		goto err_exit;
762 	}
763 
764 	err = aq_ptp_skb_put(&aq_ptp->skb_ring, skb);
765 	if (err) {
766 		netdev_err(aq_nic->ndev, "SKB Ring is overflow (%u)!\n",
767 			   ring->size);
768 		return NETDEV_TX_BUSY;
769 	}
770 	skb_shinfo(skb)->tx_flags |= SKBTX_IN_PROGRESS;
771 	aq_ptp_tx_timeout_start(aq_ptp);
772 	skb_tx_timestamp(skb);
773 
774 	spin_lock_irqsave(&aq_nic->aq_ptp->ptp_ring_lock, irq_flags);
775 	frags = aq_nic_map_skb(aq_nic, skb, ring);
776 
777 	if (likely(frags)) {
778 		err = aq_nic->aq_hw_ops->hw_ring_tx_xmit(aq_nic->aq_hw,
779 						       ring, frags);
780 		if (err >= 0) {
781 			++ring->stats.tx.packets;
782 			ring->stats.tx.bytes += skb->len;
783 		}
784 	} else {
785 		err = NETDEV_TX_BUSY;
786 	}
787 	spin_unlock_irqrestore(&aq_nic->aq_ptp->ptp_ring_lock, irq_flags);
788 
789 err_exit:
790 	return err;
791 }
792 
793 void aq_ptp_service_task(struct aq_nic_s *aq_nic)
794 {
795 	struct aq_ptp_s *aq_ptp = aq_nic->aq_ptp;
796 
797 	if (!aq_ptp)
798 		return;
799 
800 	aq_ptp_tx_timeout_check(aq_ptp);
801 }
802 
803 int aq_ptp_irq_alloc(struct aq_nic_s *aq_nic)
804 {
805 	struct pci_dev *pdev = aq_nic->pdev;
806 	struct aq_ptp_s *aq_ptp = aq_nic->aq_ptp;
807 	int err = 0;
808 
809 	if (!aq_ptp)
810 		return 0;
811 
812 	if (pdev->msix_enabled || pdev->msi_enabled) {
813 		err = request_irq(pci_irq_vector(pdev, aq_ptp->idx_vector),
814 				  aq_ptp_isr, 0, aq_nic->ndev->name, aq_ptp);
815 	} else {
816 		err = -EINVAL;
817 		goto err_exit;
818 	}
819 
820 err_exit:
821 	return err;
822 }
823 
824 void aq_ptp_irq_free(struct aq_nic_s *aq_nic)
825 {
826 	struct aq_ptp_s *aq_ptp = aq_nic->aq_ptp;
827 	struct pci_dev *pdev = aq_nic->pdev;
828 
829 	if (!aq_ptp)
830 		return;
831 
832 	free_irq(pci_irq_vector(pdev, aq_ptp->idx_vector), aq_ptp);
833 }
834 
835 int aq_ptp_ring_init(struct aq_nic_s *aq_nic)
836 {
837 	struct aq_ptp_s *aq_ptp = aq_nic->aq_ptp;
838 	int err = 0;
839 
840 	if (!aq_ptp)
841 		return 0;
842 
843 	err = aq_ring_init(&aq_ptp->ptp_tx);
844 	if (err < 0)
845 		goto err_exit;
846 	err = aq_nic->aq_hw_ops->hw_ring_tx_init(aq_nic->aq_hw,
847 						 &aq_ptp->ptp_tx,
848 						 &aq_ptp->ptp_ring_param);
849 	if (err < 0)
850 		goto err_exit;
851 
852 	err = aq_ring_init(&aq_ptp->ptp_rx);
853 	if (err < 0)
854 		goto err_exit;
855 	err = aq_nic->aq_hw_ops->hw_ring_rx_init(aq_nic->aq_hw,
856 						 &aq_ptp->ptp_rx,
857 						 &aq_ptp->ptp_ring_param);
858 	if (err < 0)
859 		goto err_exit;
860 
861 	err = aq_ring_rx_fill(&aq_ptp->ptp_rx);
862 	if (err < 0)
863 		goto err_rx_free;
864 	err = aq_nic->aq_hw_ops->hw_ring_rx_fill(aq_nic->aq_hw,
865 						 &aq_ptp->ptp_rx,
866 						 0U);
867 	if (err < 0)
868 		goto err_rx_free;
869 
870 	err = aq_ring_init(&aq_ptp->hwts_rx);
871 	if (err < 0)
872 		goto err_rx_free;
873 	err = aq_nic->aq_hw_ops->hw_ring_rx_init(aq_nic->aq_hw,
874 						 &aq_ptp->hwts_rx,
875 						 &aq_ptp->ptp_ring_param);
876 	if (err < 0)
877 		goto err_exit;
878 	err = aq_nic->aq_hw_ops->hw_ring_hwts_rx_fill(aq_nic->aq_hw,
879 						      &aq_ptp->hwts_rx);
880 	if (err < 0)
881 		goto err_exit;
882 
883 	return err;
884 
885 err_rx_free:
886 	aq_ring_rx_deinit(&aq_ptp->ptp_rx);
887 err_exit:
888 	return err;
889 }
890 
891 int aq_ptp_ring_start(struct aq_nic_s *aq_nic)
892 {
893 	struct aq_ptp_s *aq_ptp = aq_nic->aq_ptp;
894 	int err = 0;
895 
896 	if (!aq_ptp)
897 		return 0;
898 
899 	err = aq_nic->aq_hw_ops->hw_ring_tx_start(aq_nic->aq_hw, &aq_ptp->ptp_tx);
900 	if (err < 0)
901 		goto err_exit;
902 
903 	err = aq_nic->aq_hw_ops->hw_ring_rx_start(aq_nic->aq_hw, &aq_ptp->ptp_rx);
904 	if (err < 0)
905 		goto err_exit;
906 
907 	err = aq_nic->aq_hw_ops->hw_ring_rx_start(aq_nic->aq_hw,
908 						  &aq_ptp->hwts_rx);
909 	if (err < 0)
910 		goto err_exit;
911 
912 	napi_enable(&aq_ptp->napi);
913 
914 err_exit:
915 	return err;
916 }
917 
918 void aq_ptp_ring_stop(struct aq_nic_s *aq_nic)
919 {
920 	struct aq_ptp_s *aq_ptp = aq_nic->aq_ptp;
921 
922 	if (!aq_ptp)
923 		return;
924 
925 	aq_nic->aq_hw_ops->hw_ring_tx_stop(aq_nic->aq_hw, &aq_ptp->ptp_tx);
926 	aq_nic->aq_hw_ops->hw_ring_rx_stop(aq_nic->aq_hw, &aq_ptp->ptp_rx);
927 
928 	aq_nic->aq_hw_ops->hw_ring_rx_stop(aq_nic->aq_hw, &aq_ptp->hwts_rx);
929 
930 	napi_disable(&aq_ptp->napi);
931 }
932 
933 void aq_ptp_ring_deinit(struct aq_nic_s *aq_nic)
934 {
935 	struct aq_ptp_s *aq_ptp = aq_nic->aq_ptp;
936 
937 	if (!aq_ptp || !aq_ptp->ptp_tx.aq_nic || !aq_ptp->ptp_rx.aq_nic)
938 		return;
939 
940 	aq_ring_tx_clean(&aq_ptp->ptp_tx);
941 	aq_ring_rx_deinit(&aq_ptp->ptp_rx);
942 }
943 
944 #define PTP_8TC_RING_IDX             8
945 #define PTP_4TC_RING_IDX            16
946 #define PTP_HWST_RING_IDX           31
947 
948 /* Index must be 8 (8 TCs) or 16 (4 TCs).
949  * It depends on Traffic Class mode.
950  */
951 static unsigned int ptp_ring_idx(const enum aq_tc_mode tc_mode)
952 {
953 	if (tc_mode == AQ_TC_MODE_8TCS)
954 		return PTP_8TC_RING_IDX;
955 
956 	return PTP_4TC_RING_IDX;
957 }
958 
959 int aq_ptp_ring_alloc(struct aq_nic_s *aq_nic)
960 {
961 	struct aq_ptp_s *aq_ptp = aq_nic->aq_ptp;
962 	unsigned int tx_ring_idx, rx_ring_idx;
963 	struct aq_ring_s *hwts;
964 	struct aq_ring_s *ring;
965 	int err;
966 
967 	if (!aq_ptp)
968 		return 0;
969 
970 	tx_ring_idx = ptp_ring_idx(aq_nic->aq_nic_cfg.tc_mode);
971 
972 	ring = aq_ring_tx_alloc(&aq_ptp->ptp_tx, aq_nic,
973 				tx_ring_idx, &aq_nic->aq_nic_cfg);
974 	if (!ring) {
975 		err = -ENOMEM;
976 		goto err_exit;
977 	}
978 
979 	rx_ring_idx = ptp_ring_idx(aq_nic->aq_nic_cfg.tc_mode);
980 
981 	ring = aq_ring_rx_alloc(&aq_ptp->ptp_rx, aq_nic,
982 				rx_ring_idx, &aq_nic->aq_nic_cfg);
983 	if (!ring) {
984 		err = -ENOMEM;
985 		goto err_exit_ptp_tx;
986 	}
987 
988 	hwts = aq_ring_hwts_rx_alloc(&aq_ptp->hwts_rx, aq_nic, PTP_HWST_RING_IDX,
989 				     aq_nic->aq_nic_cfg.rxds,
990 				     aq_nic->aq_nic_cfg.aq_hw_caps->rxd_size);
991 	if (!hwts) {
992 		err = -ENOMEM;
993 		goto err_exit_ptp_rx;
994 	}
995 
996 	err = aq_ptp_skb_ring_init(&aq_ptp->skb_ring, aq_nic->aq_nic_cfg.rxds);
997 	if (err != 0) {
998 		err = -ENOMEM;
999 		goto err_exit_hwts_rx;
1000 	}
1001 
1002 	aq_ptp->ptp_ring_param.vec_idx = aq_ptp->idx_vector;
1003 	aq_ptp->ptp_ring_param.cpu = aq_ptp->ptp_ring_param.vec_idx +
1004 			aq_nic_get_cfg(aq_nic)->aq_rss.base_cpu_number;
1005 	cpumask_set_cpu(aq_ptp->ptp_ring_param.cpu,
1006 			&aq_ptp->ptp_ring_param.affinity_mask);
1007 
1008 	return 0;
1009 
1010 err_exit_hwts_rx:
1011 	aq_ring_free(&aq_ptp->hwts_rx);
1012 err_exit_ptp_rx:
1013 	aq_ring_free(&aq_ptp->ptp_rx);
1014 err_exit_ptp_tx:
1015 	aq_ring_free(&aq_ptp->ptp_tx);
1016 err_exit:
1017 	return err;
1018 }
1019 
1020 void aq_ptp_ring_free(struct aq_nic_s *aq_nic)
1021 {
1022 	struct aq_ptp_s *aq_ptp = aq_nic->aq_ptp;
1023 
1024 	if (!aq_ptp)
1025 		return;
1026 
1027 	aq_ring_free(&aq_ptp->ptp_tx);
1028 	aq_ring_free(&aq_ptp->ptp_rx);
1029 	aq_ring_free(&aq_ptp->hwts_rx);
1030 
1031 	aq_ptp_skb_ring_release(&aq_ptp->skb_ring);
1032 }
1033 
1034 #define MAX_PTP_GPIO_COUNT 4
1035 
1036 static struct ptp_clock_info aq_ptp_clock = {
1037 	.owner		= THIS_MODULE,
1038 	.name		= "atlantic ptp",
1039 	.max_adj	= 999999999,
1040 	.n_ext_ts	= 0,
1041 	.pps		= 0,
1042 	.adjfine	= aq_ptp_adjfine,
1043 	.adjtime	= aq_ptp_adjtime,
1044 	.gettime64	= aq_ptp_gettime,
1045 	.settime64	= aq_ptp_settime,
1046 	.n_per_out	= 0,
1047 	.enable		= aq_ptp_gpio_feature_enable,
1048 	.n_pins		= 0,
1049 	.verify		= aq_ptp_verify,
1050 	.pin_config	= NULL,
1051 };
1052 
1053 #define ptp_offset_init(__idx, __mbps, __egress, __ingress)   do { \
1054 		ptp_offset[__idx].mbps = (__mbps); \
1055 		ptp_offset[__idx].egress = (__egress); \
1056 		ptp_offset[__idx].ingress = (__ingress); } \
1057 		while (0)
1058 
1059 static void aq_ptp_offset_init_from_fw(const struct hw_atl_ptp_offset *offsets)
1060 {
1061 	int i;
1062 
1063 	/* Load offsets for PTP */
1064 	for (i = 0; i < ARRAY_SIZE(ptp_offset); i++) {
1065 		switch (i) {
1066 		/* 100M */
1067 		case ptp_offset_idx_100:
1068 			ptp_offset_init(i, 100,
1069 					offsets->egress_100,
1070 					offsets->ingress_100);
1071 			break;
1072 		/* 1G */
1073 		case ptp_offset_idx_1000:
1074 			ptp_offset_init(i, 1000,
1075 					offsets->egress_1000,
1076 					offsets->ingress_1000);
1077 			break;
1078 		/* 2.5G */
1079 		case ptp_offset_idx_2500:
1080 			ptp_offset_init(i, 2500,
1081 					offsets->egress_2500,
1082 					offsets->ingress_2500);
1083 			break;
1084 		/* 5G */
1085 		case ptp_offset_idx_5000:
1086 			ptp_offset_init(i, 5000,
1087 					offsets->egress_5000,
1088 					offsets->ingress_5000);
1089 			break;
1090 		/* 10G */
1091 		case ptp_offset_idx_10000:
1092 			ptp_offset_init(i, 10000,
1093 					offsets->egress_10000,
1094 					offsets->ingress_10000);
1095 			break;
1096 		}
1097 	}
1098 }
1099 
1100 static void aq_ptp_offset_init(const struct hw_atl_ptp_offset *offsets)
1101 {
1102 	memset(ptp_offset, 0, sizeof(ptp_offset));
1103 
1104 	aq_ptp_offset_init_from_fw(offsets);
1105 }
1106 
1107 static void aq_ptp_gpio_init(struct ptp_clock_info *info,
1108 			     struct hw_atl_info *hw_info)
1109 {
1110 	struct ptp_pin_desc pin_desc[MAX_PTP_GPIO_COUNT];
1111 	u32 extts_pin_cnt = 0;
1112 	u32 out_pin_cnt = 0;
1113 	u32 i;
1114 
1115 	memset(pin_desc, 0, sizeof(pin_desc));
1116 
1117 	for (i = 0; i < MAX_PTP_GPIO_COUNT - 1; i++) {
1118 		if (hw_info->gpio_pin[i] ==
1119 		    (GPIO_PIN_FUNCTION_PTP0 + out_pin_cnt)) {
1120 			snprintf(pin_desc[out_pin_cnt].name,
1121 				 sizeof(pin_desc[out_pin_cnt].name),
1122 				 "AQ_GPIO%d", i);
1123 			pin_desc[out_pin_cnt].index = out_pin_cnt;
1124 			pin_desc[out_pin_cnt].chan = out_pin_cnt;
1125 			pin_desc[out_pin_cnt++].func = PTP_PF_PEROUT;
1126 		}
1127 	}
1128 
1129 	info->n_per_out = out_pin_cnt;
1130 
1131 	if (hw_info->caps_ex & BIT(CAPS_EX_PHY_CTRL_TS_PIN)) {
1132 		extts_pin_cnt += 1;
1133 
1134 		snprintf(pin_desc[out_pin_cnt].name,
1135 			 sizeof(pin_desc[out_pin_cnt].name),
1136 			  "AQ_GPIO%d", out_pin_cnt);
1137 		pin_desc[out_pin_cnt].index = out_pin_cnt;
1138 		pin_desc[out_pin_cnt].chan = 0;
1139 		pin_desc[out_pin_cnt].func = PTP_PF_EXTTS;
1140 	}
1141 
1142 	info->n_pins = out_pin_cnt + extts_pin_cnt;
1143 	info->n_ext_ts = extts_pin_cnt;
1144 
1145 	if (!info->n_pins)
1146 		return;
1147 
1148 	info->pin_config = kcalloc(info->n_pins, sizeof(struct ptp_pin_desc),
1149 				   GFP_KERNEL);
1150 
1151 	if (!info->pin_config)
1152 		return;
1153 
1154 	memcpy(info->pin_config, &pin_desc,
1155 	       sizeof(struct ptp_pin_desc) * info->n_pins);
1156 }
1157 
1158 void aq_ptp_clock_init(struct aq_nic_s *aq_nic)
1159 {
1160 	struct aq_ptp_s *aq_ptp = aq_nic->aq_ptp;
1161 	struct timespec64 ts;
1162 
1163 	ktime_get_real_ts64(&ts);
1164 	aq_ptp_settime(&aq_ptp->ptp_info, &ts);
1165 }
1166 
1167 static void aq_ptp_poll_sync_work_cb(struct work_struct *w);
1168 
1169 int aq_ptp_init(struct aq_nic_s *aq_nic, unsigned int idx_vec)
1170 {
1171 	struct hw_atl_utils_mbox mbox;
1172 	struct ptp_clock *clock;
1173 	struct aq_ptp_s *aq_ptp;
1174 	int err = 0;
1175 
1176 	if (!aq_nic->aq_hw_ops->hw_get_ptp_ts) {
1177 		aq_nic->aq_ptp = NULL;
1178 		return 0;
1179 	}
1180 
1181 	if (!aq_nic->aq_fw_ops->enable_ptp) {
1182 		aq_nic->aq_ptp = NULL;
1183 		return 0;
1184 	}
1185 
1186 	hw_atl_utils_mpi_read_stats(aq_nic->aq_hw, &mbox);
1187 
1188 	if (!(mbox.info.caps_ex & BIT(CAPS_EX_PHY_PTP_EN))) {
1189 		aq_nic->aq_ptp = NULL;
1190 		return 0;
1191 	}
1192 
1193 	aq_ptp_offset_init(&mbox.info.ptp_offset);
1194 
1195 	aq_ptp = kzalloc(sizeof(*aq_ptp), GFP_KERNEL);
1196 	if (!aq_ptp) {
1197 		err = -ENOMEM;
1198 		goto err_exit;
1199 	}
1200 
1201 	aq_ptp->aq_nic = aq_nic;
1202 
1203 	spin_lock_init(&aq_ptp->ptp_lock);
1204 	spin_lock_init(&aq_ptp->ptp_ring_lock);
1205 
1206 	aq_ptp->ptp_info = aq_ptp_clock;
1207 	aq_ptp_gpio_init(&aq_ptp->ptp_info, &mbox.info);
1208 	clock = ptp_clock_register(&aq_ptp->ptp_info, &aq_nic->ndev->dev);
1209 	if (IS_ERR(clock)) {
1210 		netdev_err(aq_nic->ndev, "ptp_clock_register failed\n");
1211 		err = PTR_ERR(clock);
1212 		goto err_exit;
1213 	}
1214 	aq_ptp->ptp_clock = clock;
1215 	aq_ptp_tx_timeout_init(&aq_ptp->ptp_tx_timeout);
1216 
1217 	atomic_set(&aq_ptp->offset_egress, 0);
1218 	atomic_set(&aq_ptp->offset_ingress, 0);
1219 
1220 	netif_napi_add(aq_nic_get_ndev(aq_nic), &aq_ptp->napi,
1221 		       aq_ptp_poll, AQ_CFG_NAPI_WEIGHT);
1222 
1223 	aq_ptp->idx_vector = idx_vec;
1224 
1225 	aq_nic->aq_ptp = aq_ptp;
1226 
1227 	/* enable ptp counter */
1228 	aq_utils_obj_set(&aq_nic->aq_hw->flags, AQ_HW_PTP_AVAILABLE);
1229 	mutex_lock(&aq_nic->fwreq_mutex);
1230 	aq_nic->aq_fw_ops->enable_ptp(aq_nic->aq_hw, 1);
1231 	aq_ptp_clock_init(aq_nic);
1232 	mutex_unlock(&aq_nic->fwreq_mutex);
1233 
1234 	INIT_DELAYED_WORK(&aq_ptp->poll_sync, &aq_ptp_poll_sync_work_cb);
1235 	aq_ptp->eth_type_filter.location =
1236 			aq_nic_reserve_filter(aq_nic, aq_rx_filter_ethertype);
1237 	aq_ptp->udp_filter.location =
1238 			aq_nic_reserve_filter(aq_nic, aq_rx_filter_l3l4);
1239 
1240 	return 0;
1241 
1242 err_exit:
1243 	if (aq_ptp)
1244 		kfree(aq_ptp->ptp_info.pin_config);
1245 	kfree(aq_ptp);
1246 	aq_nic->aq_ptp = NULL;
1247 	return err;
1248 }
1249 
1250 void aq_ptp_unregister(struct aq_nic_s *aq_nic)
1251 {
1252 	struct aq_ptp_s *aq_ptp = aq_nic->aq_ptp;
1253 
1254 	if (!aq_ptp)
1255 		return;
1256 
1257 	ptp_clock_unregister(aq_ptp->ptp_clock);
1258 }
1259 
1260 void aq_ptp_free(struct aq_nic_s *aq_nic)
1261 {
1262 	struct aq_ptp_s *aq_ptp = aq_nic->aq_ptp;
1263 
1264 	if (!aq_ptp)
1265 		return;
1266 
1267 	aq_nic_release_filter(aq_nic, aq_rx_filter_ethertype,
1268 			      aq_ptp->eth_type_filter.location);
1269 	aq_nic_release_filter(aq_nic, aq_rx_filter_l3l4,
1270 			      aq_ptp->udp_filter.location);
1271 	cancel_delayed_work_sync(&aq_ptp->poll_sync);
1272 	/* disable ptp */
1273 	mutex_lock(&aq_nic->fwreq_mutex);
1274 	aq_nic->aq_fw_ops->enable_ptp(aq_nic->aq_hw, 0);
1275 	mutex_unlock(&aq_nic->fwreq_mutex);
1276 
1277 	kfree(aq_ptp->ptp_info.pin_config);
1278 
1279 	netif_napi_del(&aq_ptp->napi);
1280 	kfree(aq_ptp);
1281 	aq_nic->aq_ptp = NULL;
1282 }
1283 
1284 struct ptp_clock *aq_ptp_get_ptp_clock(struct aq_ptp_s *aq_ptp)
1285 {
1286 	return aq_ptp->ptp_clock;
1287 }
1288 
1289 /* PTP external GPIO nanoseconds count */
1290 static uint64_t aq_ptp_get_sync1588_ts(struct aq_nic_s *aq_nic)
1291 {
1292 	u64 ts = 0;
1293 
1294 	if (aq_nic->aq_hw_ops->hw_get_sync_ts)
1295 		aq_nic->aq_hw_ops->hw_get_sync_ts(aq_nic->aq_hw, &ts);
1296 
1297 	return ts;
1298 }
1299 
1300 static void aq_ptp_start_work(struct aq_ptp_s *aq_ptp)
1301 {
1302 	if (aq_ptp->extts_pin_enabled) {
1303 		aq_ptp->poll_timeout_ms = POLL_SYNC_TIMER_MS;
1304 		aq_ptp->last_sync1588_ts =
1305 				aq_ptp_get_sync1588_ts(aq_ptp->aq_nic);
1306 		schedule_delayed_work(&aq_ptp->poll_sync,
1307 				      msecs_to_jiffies(aq_ptp->poll_timeout_ms));
1308 	}
1309 }
1310 
1311 int aq_ptp_link_change(struct aq_nic_s *aq_nic)
1312 {
1313 	struct aq_ptp_s *aq_ptp = aq_nic->aq_ptp;
1314 
1315 	if (!aq_ptp)
1316 		return 0;
1317 
1318 	if (aq_nic->aq_hw->aq_link_status.mbps)
1319 		aq_ptp_start_work(aq_ptp);
1320 	else
1321 		cancel_delayed_work_sync(&aq_ptp->poll_sync);
1322 
1323 	return 0;
1324 }
1325 
1326 static bool aq_ptp_sync_ts_updated(struct aq_ptp_s *aq_ptp, u64 *new_ts)
1327 {
1328 	struct aq_nic_s *aq_nic = aq_ptp->aq_nic;
1329 	u64 sync_ts2;
1330 	u64 sync_ts;
1331 
1332 	sync_ts = aq_ptp_get_sync1588_ts(aq_nic);
1333 
1334 	if (sync_ts != aq_ptp->last_sync1588_ts) {
1335 		sync_ts2 = aq_ptp_get_sync1588_ts(aq_nic);
1336 		if (sync_ts != sync_ts2) {
1337 			sync_ts = sync_ts2;
1338 			sync_ts2 = aq_ptp_get_sync1588_ts(aq_nic);
1339 			if (sync_ts != sync_ts2) {
1340 				netdev_err(aq_nic->ndev,
1341 					   "%s: Unable to get correct GPIO TS",
1342 					   __func__);
1343 				sync_ts = 0;
1344 			}
1345 		}
1346 
1347 		*new_ts = sync_ts;
1348 		return true;
1349 	}
1350 	return false;
1351 }
1352 
1353 static int aq_ptp_check_sync1588(struct aq_ptp_s *aq_ptp)
1354 {
1355 	struct aq_nic_s *aq_nic = aq_ptp->aq_nic;
1356 	u64 sync_ts;
1357 
1358 	 /* Sync1588 pin was triggered */
1359 	if (aq_ptp_sync_ts_updated(aq_ptp, &sync_ts)) {
1360 		if (aq_ptp->extts_pin_enabled) {
1361 			struct ptp_clock_event ptp_event;
1362 			u64 time = 0;
1363 
1364 			aq_nic->aq_hw_ops->hw_ts_to_sys_clock(aq_nic->aq_hw,
1365 							      sync_ts, &time);
1366 			ptp_event.index = aq_ptp->ptp_info.n_pins - 1;
1367 			ptp_event.timestamp = time;
1368 
1369 			ptp_event.type = PTP_CLOCK_EXTTS;
1370 			ptp_clock_event(aq_ptp->ptp_clock, &ptp_event);
1371 		}
1372 
1373 		aq_ptp->last_sync1588_ts = sync_ts;
1374 	}
1375 
1376 	return 0;
1377 }
1378 
1379 static void aq_ptp_poll_sync_work_cb(struct work_struct *w)
1380 {
1381 	struct delayed_work *dw = to_delayed_work(w);
1382 	struct aq_ptp_s *aq_ptp = container_of(dw, struct aq_ptp_s, poll_sync);
1383 
1384 	aq_ptp_check_sync1588(aq_ptp);
1385 
1386 	if (aq_ptp->extts_pin_enabled) {
1387 		unsigned long timeout = msecs_to_jiffies(aq_ptp->poll_timeout_ms);
1388 
1389 		schedule_delayed_work(&aq_ptp->poll_sync, timeout);
1390 	}
1391 }
1392