• Home
  • Raw
  • Download

Lines Matching refs:ppd

96 	struct qib_pportdata *ppd;  in qib_count_active_units()  local
105 ppd = dd->pport + pidx; in qib_count_active_units()
106 if (ppd->lid && (ppd->lflags & (QIBL_LINKINIT | in qib_count_active_units()
128 struct qib_pportdata *ppd; in qib_count_units() local
136 ppd = dd->pport + pidx; in qib_count_units()
137 if (ppd->lid && (ppd->lflags & (QIBL_LINKINIT | in qib_count_units()
164 int qib_wait_linkstate(struct qib_pportdata *ppd, u32 state, int msecs) in qib_wait_linkstate() argument
169 spin_lock_irqsave(&ppd->lflags_lock, flags); in qib_wait_linkstate()
170 if (ppd->state_wanted) { in qib_wait_linkstate()
171 spin_unlock_irqrestore(&ppd->lflags_lock, flags); in qib_wait_linkstate()
175 ppd->state_wanted = state; in qib_wait_linkstate()
176 spin_unlock_irqrestore(&ppd->lflags_lock, flags); in qib_wait_linkstate()
177 wait_event_interruptible_timeout(ppd->state_wait, in qib_wait_linkstate()
178 (ppd->lflags & state), in qib_wait_linkstate()
180 spin_lock_irqsave(&ppd->lflags_lock, flags); in qib_wait_linkstate()
181 ppd->state_wanted = 0; in qib_wait_linkstate()
182 spin_unlock_irqrestore(&ppd->lflags_lock, flags); in qib_wait_linkstate()
184 if (!(ppd->lflags & state)) in qib_wait_linkstate()
192 int qib_set_linkstate(struct qib_pportdata *ppd, u8 newstate) in qib_set_linkstate() argument
196 struct qib_devdata *dd = ppd->dd; in qib_set_linkstate()
201 dd->f_set_ib_cfg(ppd, QIB_IB_CFG_LSTATE, in qib_set_linkstate()
208 dd->f_set_ib_cfg(ppd, QIB_IB_CFG_LSTATE, in qib_set_linkstate()
215 dd->f_set_ib_cfg(ppd, QIB_IB_CFG_LSTATE, in qib_set_linkstate()
222 dd->f_set_ib_cfg(ppd, QIB_IB_CFG_LSTATE, in qib_set_linkstate()
229 if (ppd->lflags & QIBL_LINKARMED) { in qib_set_linkstate()
233 if (!(ppd->lflags & (QIBL_LINKINIT | QIBL_LINKACTIVE))) { in qib_set_linkstate()
243 spin_lock_irqsave(&ppd->lflags_lock, flags); in qib_set_linkstate()
244 ppd->lflags &= ~QIBL_LINKV; in qib_set_linkstate()
245 spin_unlock_irqrestore(&ppd->lflags_lock, flags); in qib_set_linkstate()
246 dd->f_set_ib_cfg(ppd, QIB_IB_CFG_LSTATE, in qib_set_linkstate()
252 if (ppd->lflags & QIBL_LINKACTIVE) { in qib_set_linkstate()
256 if (!(ppd->lflags & QIBL_LINKARMED)) { in qib_set_linkstate()
260 dd->f_set_ib_cfg(ppd, QIB_IB_CFG_LSTATE, in qib_set_linkstate()
269 ret = qib_wait_linkstate(ppd, lstate, 10); in qib_set_linkstate()
291 static u32 qib_rcv_hdrerr(struct qib_ctxtdata *rcd, struct qib_pportdata *ppd, in qib_rcv_hdrerr() argument
303 struct qib_ibport *ibp = &ppd->ibport_data; in qib_rcv_hdrerr()
304 struct qib_devdata *dd = ppd->dd; in qib_rcv_hdrerr()
320 lid &= ~((1 << ppd->lmc) - 1); in qib_rcv_hdrerr()
321 if (unlikely(lid != ppd->lid)) in qib_rcv_hdrerr()
443 struct qib_pportdata *ppd = rcd->ppd; in qib_kreceive() local
508 crcs += qib_rcv_hdrerr(rcd, ppd, rcd->ctxt, eflags, l, in qib_kreceive()
598 int qib_set_mtu(struct qib_pportdata *ppd, u16 arg) in qib_set_mtu() argument
614 piosize = ppd->ibmaxlen; in qib_set_mtu()
615 ppd->ibmtu = arg; in qib_set_mtu()
619 if (piosize != ppd->init_ibmaxlen) { in qib_set_mtu()
620 if (arg > piosize && arg <= ppd->init_ibmaxlen) in qib_set_mtu()
621 piosize = ppd->init_ibmaxlen - 2 * sizeof(u32); in qib_set_mtu()
622 ppd->ibmaxlen = piosize; in qib_set_mtu()
624 } else if ((arg + QIB_PIO_MAXIBHDR) != ppd->ibmaxlen) { in qib_set_mtu()
626 ppd->ibmaxlen = piosize; in qib_set_mtu()
629 ppd->dd->f_set_ib_cfg(ppd, QIB_IB_CFG_MTU, 0); in qib_set_mtu()
637 int qib_set_lid(struct qib_pportdata *ppd, u32 lid, u8 lmc) in qib_set_lid() argument
639 struct qib_devdata *dd = ppd->dd; in qib_set_lid()
641 ppd->lid = lid; in qib_set_lid()
642 ppd->lmc = lmc; in qib_set_lid()
644 dd->f_set_ib_cfg(ppd, QIB_IB_CFG_LIDLMC, in qib_set_lid()
648 dd->unit, ppd->port, lid); in qib_set_lid()
667 struct qib_pportdata *ppd = from_timer(ppd, t, in qib_run_led_override() local
669 struct qib_devdata *dd = ppd->dd; in qib_run_led_override()
676 ph_idx = ppd->led_override_phase++ & 1; in qib_run_led_override()
677 ppd->led_override = ppd->led_override_vals[ph_idx]; in qib_run_led_override()
678 timeoff = ppd->led_override_timeoff; in qib_run_led_override()
680 dd->f_setextled(ppd, 1); in qib_run_led_override()
685 if (ppd->led_override_vals[0] || ppd->led_override_vals[1]) in qib_run_led_override()
686 mod_timer(&ppd->led_override_timer, jiffies + timeoff); in qib_run_led_override()
689 void qib_set_led_override(struct qib_pportdata *ppd, unsigned int val) in qib_set_led_override() argument
691 struct qib_devdata *dd = ppd->dd; in qib_set_led_override()
703 ppd->led_override_vals[0] = val & 0xF; in qib_set_led_override()
704 ppd->led_override_vals[1] = (val >> 4) & 0xF; in qib_set_led_override()
708 ppd->led_override_vals[0] = val & 0xF; in qib_set_led_override()
709 ppd->led_override_vals[1] = val & 0xF; in qib_set_led_override()
711 ppd->led_override_timeoff = timeoff; in qib_set_led_override()
717 if (atomic_inc_return(&ppd->led_override_timer_active) == 1) { in qib_set_led_override()
719 timer_setup(&ppd->led_override_timer, qib_run_led_override, 0); in qib_set_led_override()
720 ppd->led_override_timer.expires = jiffies + 1; in qib_set_led_override()
721 add_timer(&ppd->led_override_timer); in qib_set_led_override()
723 if (ppd->led_override_vals[0] || ppd->led_override_vals[1]) in qib_set_led_override()
724 mod_timer(&ppd->led_override_timer, jiffies + 1); in qib_set_led_override()
725 atomic_dec(&ppd->led_override_timer_active); in qib_set_led_override()
742 struct qib_pportdata *ppd; in qib_reset_device() local
773 ppd = dd->pport + pidx; in qib_reset_device()
774 if (atomic_read(&ppd->led_override_timer_active)) { in qib_reset_device()
776 del_timer_sync(&ppd->led_override_timer); in qib_reset_device()
777 atomic_set(&ppd->led_override_timer_active, 0); in qib_reset_device()
781 ppd->led_override = LED_OVER_BOTH_OFF; in qib_reset_device()
782 dd->f_setextled(ppd, 0); in qib_reset_device()
784 qib_teardown_sdma(ppd); in qib_reset_device()