/linux/drivers/ptp/ |
H A D | ptp_chardev.c | 38 rq.perout.index = chan; in ptp_disable_pinfunc() 251 if (copy_from_user(&req.perout, (void __user *)arg, in ptp_ioctl() 252 sizeof(req.perout))) { in ptp_ioctl() 257 struct ptp_perout_request *perout = &req.perout; in ptp_ioctl() local 259 if (perout->flags & ~PTP_PEROUT_VALID_FLAGS) { in ptp_ioctl() 268 if (!(perout->flags & PTP_PEROUT_DUTY_CYCLE) && in ptp_ioctl() 269 (perout->rsv[0] || perout->rsv[1] || in ptp_ioctl() 270 perout->rsv[2] || perout->rsv[3])) { in ptp_ioctl() 274 if (perout->flags & PTP_PEROUT_DUTY_CYCLE) { in ptp_ioctl() 276 if (perout->on.sec > perout->period.sec || in ptp_ioctl() [all …]
|
H A D | ptp_sysfs.c | 120 cnt = sscanf(buf, "%u %lld %u %lld %u", &req.perout.index, in period_store() 121 &req.perout.start.sec, &req.perout.start.nsec, in period_store() 122 &req.perout.period.sec, &req.perout.period.nsec); in period_store() 125 if (req.perout.index >= ops->n_per_out) in period_store() 128 enable = req.perout.period.sec || req.perout.period.nsec; in period_store()
|
H A D | ptp_idt82p33.c | 900 struct ptp_perout_request *perout) in idt82p33_perout_enable() argument 903 return idt82p33_output_enable(channel, enable, perout->index); in idt82p33_perout_enable() 957 &rq->perout); in idt82p33_enable() 959 else if (rq->perout.start.nsec || rq->perout.period.sec != 1 || in idt82p33_enable() 960 rq->perout.period.nsec) in idt82p33_enable() 964 &rq->perout); in idt82p33_enable()
|
H A D | ptp_clockmatrix.c | 1356 struct ptp_perout_request *perout, in idtcm_perout_enable() argument 1363 err = idtcm_output_enable(channel, enable, perout->index); in idtcm_perout_enable() 1943 err = idtcm_perout_enable(channel, &rq->perout, false); in idtcm_enable() 1945 else if (rq->perout.start.nsec || rq->perout.period.sec != 1 || in idtcm_enable() 1946 rq->perout.period.nsec) in idtcm_enable() 1949 err = idtcm_perout_enable(channel, &rq->perout, true); in idtcm_enable()
|
H A D | ptp_fc3.c | 546 else if (rq->perout.start.nsec || rq->perout.period.sec != 1 || in idtfc3_enable() 547 rq->perout.period.nsec) in idtfc3_enable()
|
/linux/drivers/net/ethernet/renesas/ |
H A D | ravb_ptp.c | 212 struct ravb_ptp_perout *perout; in ravb_ptp_perout() local 244 perout = &priv->ptp.perout[req->index]; in ravb_ptp_perout() 245 perout->target = (u32)start_ns; in ravb_ptp_perout() 246 perout->period = (u32)period_ns; in ravb_ptp_perout() 258 perout = &priv->ptp.perout[req->index]; in ravb_ptp_perout() 259 perout->period = 0; in ravb_ptp_perout() 279 return ravb_ptp_perout(ptp, &req->perout, on); in ravb_ptp_enable() 314 struct ravb_ptp_perout *perout = priv->ptp.perout; in ravb_ptp_interrupt() local 316 if (perout->period) { in ravb_ptp_interrupt() 317 perout->target += perout->period; in ravb_ptp_interrupt() [all …]
|
H A D | ravb.h | 1045 struct ravb_ptp_perout perout[N_PER_OUT]; member
|
/linux/drivers/net/ethernet/microchip/ |
H A D | lan743x_ptp.c | 428 struct lan743x_ptp_perout *perout = &ptp->perout[index]; in lan743x_ptp_perout_off() local 430 if (perout->gpio_pin >= 0) { in lan743x_ptp_perout_off() 431 lan743x_gpio_release(adapter, perout->gpio_pin); in lan743x_ptp_perout_off() 432 perout->gpio_pin = -1; in lan743x_ptp_perout_off() 435 if (perout->event_ch >= 0) { in lan743x_ptp_perout_off() 438 PTP_CLOCK_TARGET_SEC_X(perout->event_ch), in lan743x_ptp_perout_off() 441 PTP_CLOCK_TARGET_NS_X(perout->event_ch), in lan743x_ptp_perout_off() 446 (perout->event_ch); in lan743x_ptp_perout_off() 448 lan743x_ptp_release_event_ch(adapter, perout->event_ch); in lan743x_ptp_perout_off() 449 perout->event_ch = -1; in lan743x_ptp_perout_off() [all …]
|
H A D | lan743x_ptp.h | 83 struct lan743x_ptp_perout perout[LAN743X_PTP_N_PEROUT]; member
|
/linux/drivers/net/ethernet/intel/igb/ |
H A D | igb_ptp.c | 543 if (rq->perout.flags) in igb_ptp_feature_enable_82580() 548 rq->perout.index); in igb_ptp_feature_enable_82580() 552 ts.tv_sec = rq->perout.period.sec; in igb_ptp_feature_enable_82580() 553 ts.tv_nsec = rq->perout.period.nsec; in igb_ptp_feature_enable_82580() 559 if (rq->perout.index == 1) { in igb_ptp_feature_enable_82580() 573 if (rq->perout.index == 1) { in igb_ptp_feature_enable_82580() 581 int i = rq->perout.index; in igb_ptp_feature_enable_82580() 619 igb->perout[i].start.tv_sec = start.tv_sec; in igb_ptp_feature_enable_82580() 620 igb->perout[i].start.tv_nsec = start.tv_nsec; in igb_ptp_feature_enable_82580() 621 igb->perout[i].period.tv_sec = ts.tv_sec; in igb_ptp_feature_enable_82580() [all …]
|
/linux/drivers/net/ethernet/intel/igc/ |
H A D | igc_ptp.c | 304 if (rq->perout.flags) in igc_ptp_feature_enable_i225() 309 rq->perout.index); in igc_ptp_feature_enable_i225() 313 ts.tv_sec = rq->perout.period.sec; in igc_ptp_feature_enable_i225() 314 ts.tv_nsec = rq->perout.period.nsec; in igc_ptp_feature_enable_i225() 324 if (rq->perout.index == 1) { in igc_ptp_feature_enable_i225() 350 if (rq->perout.index == 1) { in igc_ptp_feature_enable_i225() 361 int i = rq->perout.index; in igc_ptp_feature_enable_i225() 378 if (rq->perout.start.sec < safe_start.tv_sec) in igc_ptp_feature_enable_i225() 379 igc->perout[i].start.tv_sec = safe_start.tv_sec; in igc_ptp_feature_enable_i225() 381 igc->perout[i].start.tv_sec = rq->perout.start.sec; in igc_ptp_feature_enable_i225() [all …]
|
H A D | igc_main.c | 5444 ts = timespec64_add(adapter->perout[0].start, in igc_tsync_interrupt() 5445 adapter->perout[0].period); in igc_tsync_interrupt() 5451 adapter->perout[0].start = ts; in igc_tsync_interrupt() 5457 ts = timespec64_add(adapter->perout[1].start, in igc_tsync_interrupt() 5458 adapter->perout[1].period); in igc_tsync_interrupt() 5464 adapter->perout[1].start = ts; in igc_tsync_interrupt()
|
/linux/drivers/net/ethernet/microchip/lan966x/ |
H A D | lan966x_ptp.c | 818 if (rq->perout.flags & ~(PTP_PEROUT_DUTY_CYCLE | in lan966x_ptp_perout() 822 pin = ptp_find_pin(phc->clock, PTP_PF_PEROUT, rq->perout.index); in lan966x_ptp_perout() 839 if (rq->perout.period.sec == 1 && in lan966x_ptp_perout() 840 rq->perout.period.nsec == 0) in lan966x_ptp_perout() 843 if (rq->perout.flags & PTP_PEROUT_PHASE) { in lan966x_ptp_perout() 844 ts_phase.tv_sec = rq->perout.phase.sec; in lan966x_ptp_perout() 845 ts_phase.tv_nsec = rq->perout.phase.nsec; in lan966x_ptp_perout() 847 ts_phase.tv_sec = rq->perout.start.sec; in lan966x_ptp_perout() 848 ts_phase.tv_nsec = rq->perout.start.nsec; in lan966x_ptp_perout() 857 if (rq->perout.flags & PTP_PEROUT_DUTY_CYCLE) { in lan966x_ptp_perout() [all …]
|
/linux/drivers/net/ethernet/mscc/ |
H A D | ocelot_ptp.c | 215 if (rq->perout.flags & ~(PTP_PEROUT_DUTY_CYCLE | in ocelot_ptp_enable() 220 rq->perout.index); in ocelot_ptp_enable() 232 ts_period.tv_sec = rq->perout.period.sec; in ocelot_ptp_enable() 233 ts_period.tv_nsec = rq->perout.period.nsec; in ocelot_ptp_enable() 247 if (rq->perout.flags & PTP_PEROUT_PHASE) { in ocelot_ptp_enable() 248 ts_phase.tv_sec = rq->perout.phase.sec; in ocelot_ptp_enable() 249 ts_phase.tv_nsec = rq->perout.phase.nsec; in ocelot_ptp_enable() 252 ts_phase.tv_sec = rq->perout.start.sec; in ocelot_ptp_enable() 253 ts_phase.tv_nsec = rq->perout.start.nsec; in ocelot_ptp_enable() 264 if (rq->perout.flags & PTP_PEROUT_DUTY_CYCLE) { in ocelot_ptp_enable() [all …]
|
/linux/drivers/net/dsa/sja1105/ |
H A D | sja1105_ptp.c | 718 struct ptp_perout_request *perout, in sja1105_per_out_enable() argument 727 if (perout->index != 0) in sja1105_per_out_enable() 731 if (perout->flags) in sja1105_per_out_enable() 742 .tv_sec = perout->period.sec, in sja1105_per_out_enable() 743 .tv_nsec = perout->period.nsec, in sja1105_per_out_enable() 746 .tv_sec = perout->start.sec, in sja1105_per_out_enable() 747 .tv_nsec = perout->start.nsec, in sja1105_per_out_enable() 848 rc = sja1105_per_out_enable(priv, &req->perout, on); in sja1105_ptp_enable()
|
/linux/drivers/net/ethernet/ti/icssg/ |
H A D | icss_iep.c | 548 rq.perout.index = 0; in icss_iep_pps_enable() 552 rq.perout.period.sec = 1; in icss_iep_pps_enable() 553 rq.perout.period.nsec = 0; in icss_iep_pps_enable() 554 rq.perout.start.sec = ts.tv_sec + 2; in icss_iep_pps_enable() 555 rq.perout.start.nsec = 0; in icss_iep_pps_enable() 556 ret = icss_iep_perout_enable_hw(iep, &rq.perout, on); in icss_iep_pps_enable() 558 ret = icss_iep_perout_enable_hw(iep, &rq.perout, on); in icss_iep_pps_enable() 610 return icss_iep_perout_enable(iep, &rq->perout, on); in icss_iep_ptp_enable()
|
/linux/drivers/net/ethernet/freescale/ |
H A D | fec_ptp.c | 534 if (rq->perout.flags) in fec_ptp_enable() 537 if (rq->perout.index != fep->pps_channel) in fec_ptp_enable() 540 period.tv_sec = rq->perout.period.sec; in fec_ptp_enable() 541 period.tv_nsec = rq->perout.period.nsec; in fec_ptp_enable() 555 start_time.tv_sec = rq->perout.start.sec; in fec_ptp_enable() 556 start_time.tv_nsec = rq->perout.start.nsec; in fec_ptp_enable()
|
/linux/drivers/net/phy/ |
H A D | nxp-c45-tja11xx.c | 757 struct ptp_perout_request *perout, int on) in nxp_c45_perout_enable() argument 763 if (perout->flags & ~PTP_PEROUT_PHASE) in nxp_c45_perout_enable() 766 pin = ptp_find_pin(priv->ptp_clock, PTP_PF_PEROUT, perout->index); in nxp_c45_perout_enable() 785 if (perout->period.sec != 1 || perout->period.nsec != 0) { in nxp_c45_perout_enable() 790 if (!(perout->flags & PTP_PEROUT_PHASE)) { in nxp_c45_perout_enable() 791 if (perout->start.sec != 0 || perout->start.nsec != 0) { in nxp_c45_perout_enable() 796 if (perout->phase.nsec != 0 && in nxp_c45_perout_enable() 797 perout->phase.nsec != (NSEC_PER_SEC >> 1)) { in nxp_c45_perout_enable() 802 if (perout->phase.nsec == 0) in nxp_c45_perout_enable() 906 return nxp_c45_perout_enable(priv, &req->perout, on); in nxp_c45_ptp_enable()
|
H A D | micrel.c | 3216 if (rq->perout.flags & ~PTP_PEROUT_DUTY_CYCLE) in lan8814_ptp_perout() 3220 event = rq->perout.index; in lan8814_ptp_perout() 3234 ts_on.tv_sec = rq->perout.on.sec; in lan8814_ptp_perout() 3235 ts_on.tv_nsec = rq->perout.on.nsec; in lan8814_ptp_perout() 3238 ts_period.tv_sec = rq->perout.period.sec; in lan8814_ptp_perout() 3239 ts_period.tv_nsec = rq->perout.period.nsec; in lan8814_ptp_perout() 3308 lan8814_ptp_set_target(phydev, event, rq->perout.start.sec, in lan8814_ptp_perout() 3309 rq->perout.start.nsec); in lan8814_ptp_perout() 3310 lan8814_ptp_set_reload(phydev, event, rq->perout.period.sec, in lan8814_ptp_perout() 3311 rq->perout.period.nsec); in lan8814_ptp_perout() [all …]
|
H A D | bcm-phy-ptp.c | 699 err = bcm_ptp_perout_locked(priv, &rq->perout, on); in bcm_ptp_enable()
|
/linux/drivers/net/ethernet/marvell/octeontx2/nic/ |
H A D | otx2_ptp.c | 363 if (rq->perout.flags) in otx2_ptp_enable() 366 if (rq->perout.index >= ptp_info->n_pins) in otx2_ptp_enable() 369 period = rq->perout.period.sec * NSEC_PER_SEC + in otx2_ptp_enable() 370 rq->perout.period.nsec; in otx2_ptp_enable()
|
/linux/drivers/net/ethernet/ti/ |
H A D | am65-cpts.c | 714 rq.perout.period.sec = 1; in am65_cpts_pps_enable() 715 rq.perout.period.nsec = 0; in am65_cpts_pps_enable() 716 rq.perout.start.sec = ts.tv_sec + 2; in am65_cpts_pps_enable() 717 rq.perout.start.nsec = 0; in am65_cpts_pps_enable() 718 rq.perout.index = cpts->pps_genf_idx; in am65_cpts_pps_enable() 720 am65_cpts_perout_enable_hw(cpts, &rq.perout, on); in am65_cpts_pps_enable() 723 rq.perout.index = cpts->pps_genf_idx; in am65_cpts_pps_enable() 724 am65_cpts_perout_enable_hw(cpts, &rq.perout, on); in am65_cpts_pps_enable() 745 return am65_cpts_perout_enable(cpts, &rq->perout, on); in am65_cpts_ptp_enable()
|
/linux/drivers/net/ethernet/aquantia/atlantic/ |
H A D | aq_ptp.c | 393 struct ptp_clock_time *t = &rq->perout.period; in aq_ptp_perout_pin_configure() 394 struct ptp_clock_time *s = &rq->perout.start; in aq_ptp_perout_pin_configure() 397 u32 pin_index = rq->perout.index; in aq_ptp_perout_pin_configure()
|
/linux/drivers/net/ethernet/broadcom/bnxt/ |
H A D | bnxt_ptp.c | 450 ts.tv_sec = rq->perout.start.sec; in bnxt_ptp_perout_cfg() 451 ts.tv_nsec = rq->perout.start.nsec; in bnxt_ptp_perout_cfg() 504 rq->perout.index); in bnxt_ptp_enable()
|
/linux/drivers/net/ethernet/intel/ice/ |
H A D | ice_ptp.c | 2012 &pf->ptp.perout_rqs[rq->perout.index]; in ice_ptp_gpio_enable() 2014 err = ice_ptp_cfg_perout(pf, &rq->perout, on); in ice_ptp_gpio_enable() 2016 *cached = rq->perout; in ice_ptp_gpio_enable()
|