Lines Matching +full:port +full:-

1 // SPDX-License-Identifier: GPL-2.0-only
3 * Copyright (c) 2005-2014 Brocade Communications Systems, Inc.
4 * Copyright (c) 2014- QLogic Corporation.
8 * Linux driver for QLogic BR-series Fibre Channel Host Bus Adapter.
18 BFA_TRC_FILE(CNA, PORT);
21 bfa_port_stats_swap(struct bfa_port_s *port, union bfa_port_stats_u *stats) in bfa_port_stats_swap() argument
45 * @param[in] port - Pointer to the port module
46 * status - Return status from the f/w
51 bfa_port_enable_isr(struct bfa_port_s *port, bfa_status_t status) in bfa_port_enable_isr() argument
53 bfa_trc(port, status); in bfa_port_enable_isr()
54 port->endis_pending = BFA_FALSE; in bfa_port_enable_isr()
55 port->endis_cbfn(port->endis_cbarg, status); in bfa_port_enable_isr()
62 * @param[in] port - Pointer to the port module
63 * status - Return status from the f/w
68 bfa_port_disable_isr(struct bfa_port_s *port, bfa_status_t status) in bfa_port_disable_isr() argument
70 bfa_trc(port, status); in bfa_port_disable_isr()
71 port->endis_pending = BFA_FALSE; in bfa_port_disable_isr()
72 port->endis_cbfn(port->endis_cbarg, status); in bfa_port_disable_isr()
79 * @param[in] port - Pointer to the Port module
80 * status - Return status from the f/w
85 bfa_port_get_stats_isr(struct bfa_port_s *port, bfa_status_t status) in bfa_port_get_stats_isr() argument
87 port->stats_status = status; in bfa_port_get_stats_isr()
88 port->stats_busy = BFA_FALSE; in bfa_port_get_stats_isr()
91 memcpy(port->stats, port->stats_dma.kva, in bfa_port_get_stats_isr()
93 bfa_port_stats_swap(port, port->stats); in bfa_port_get_stats_isr()
95 port->stats->fc.secs_reset = ktime_get_seconds() - port->stats_reset_time; in bfa_port_get_stats_isr()
98 if (port->stats_cbfn) { in bfa_port_get_stats_isr()
99 port->stats_cbfn(port->stats_cbarg, status); in bfa_port_get_stats_isr()
100 port->stats_cbfn = NULL; in bfa_port_get_stats_isr()
108 * @param[in] port - Pointer to the Port module
109 * status - Return status from the f/w
114 bfa_port_clear_stats_isr(struct bfa_port_s *port, bfa_status_t status) in bfa_port_clear_stats_isr() argument
116 port->stats_status = status; in bfa_port_clear_stats_isr()
117 port->stats_busy = BFA_FALSE; in bfa_port_clear_stats_isr()
120 * re-initialize time stamp for stats reset in bfa_port_clear_stats_isr()
122 port->stats_reset_time = ktime_get_seconds(); in bfa_port_clear_stats_isr()
124 if (port->stats_cbfn) { in bfa_port_clear_stats_isr()
125 port->stats_cbfn(port->stats_cbarg, status); in bfa_port_clear_stats_isr()
126 port->stats_cbfn = NULL; in bfa_port_clear_stats_isr()
134 * @param[in] Pointer to the Port module data structure.
141 struct bfa_port_s *port = (struct bfa_port_s *) cbarg; in bfa_port_isr() local
145 bfa_trc(port, m->mh.msg_id); in bfa_port_isr()
147 switch (m->mh.msg_id) { in bfa_port_isr()
149 if (port->endis_pending == BFA_FALSE) in bfa_port_isr()
151 bfa_port_enable_isr(port, i2hmsg->enable_rsp.status); in bfa_port_isr()
155 if (port->endis_pending == BFA_FALSE) in bfa_port_isr()
157 bfa_port_disable_isr(port, i2hmsg->disable_rsp.status); in bfa_port_isr()
162 if (port->stats_busy == BFA_FALSE) in bfa_port_isr()
164 bfa_port_get_stats_isr(port, i2hmsg->getstats_rsp.status); in bfa_port_isr()
168 if (port->stats_busy == BFA_FALSE) in bfa_port_isr()
170 bfa_port_clear_stats_isr(port, i2hmsg->clearstats_rsp.status); in bfa_port_isr()
196 * @param[in] port Port module pointer
197 * dma_kva Kernel Virtual Address of Port DMA Memory
198 * dma_pa Physical Address of Port DMA Memory
203 bfa_port_mem_claim(struct bfa_port_s *port, u8 *dma_kva, u64 dma_pa) in bfa_port_mem_claim() argument
205 port->stats_dma.kva = dma_kva; in bfa_port_mem_claim()
206 port->stats_dma.pa = dma_pa; in bfa_port_mem_claim()
212 * Send the Port enable request to the f/w
214 * @param[in] Pointer to the Port module data structure.
219 bfa_port_enable(struct bfa_port_s *port, bfa_port_endis_cbfn_t cbfn, in bfa_port_enable() argument
224 /* If port is PBC disabled, return error */ in bfa_port_enable()
225 if (port->pbc_disabled) { in bfa_port_enable()
226 bfa_trc(port, BFA_STATUS_PBC); in bfa_port_enable()
230 if (bfa_ioc_is_disabled(port->ioc)) { in bfa_port_enable()
231 bfa_trc(port, BFA_STATUS_IOC_DISABLED); in bfa_port_enable()
235 if (!bfa_ioc_is_operational(port->ioc)) { in bfa_port_enable()
236 bfa_trc(port, BFA_STATUS_IOC_FAILURE); in bfa_port_enable()
240 /* if port is d-port enabled, return error */ in bfa_port_enable()
241 if (port->dport_enabled) { in bfa_port_enable()
242 bfa_trc(port, BFA_STATUS_DPORT_ERR); in bfa_port_enable()
246 if (port->endis_pending) { in bfa_port_enable()
247 bfa_trc(port, BFA_STATUS_DEVBUSY); in bfa_port_enable()
251 m = (struct bfi_port_generic_req_s *) port->endis_mb.msg; in bfa_port_enable()
253 port->msgtag++; in bfa_port_enable()
254 port->endis_cbfn = cbfn; in bfa_port_enable()
255 port->endis_cbarg = cbarg; in bfa_port_enable()
256 port->endis_pending = BFA_TRUE; in bfa_port_enable()
258 bfi_h2i_set(m->mh, BFI_MC_PORT, BFI_PORT_H2I_ENABLE_REQ, in bfa_port_enable()
259 bfa_ioc_portid(port->ioc)); in bfa_port_enable()
260 bfa_ioc_mbox_queue(port->ioc, &port->endis_mb); in bfa_port_enable()
268 * Send the Port disable request to the f/w
270 * @param[in] Pointer to the Port module data structure.
275 bfa_port_disable(struct bfa_port_s *port, bfa_port_endis_cbfn_t cbfn, in bfa_port_disable() argument
280 /* If port is PBC disabled, return error */ in bfa_port_disable()
281 if (port->pbc_disabled) { in bfa_port_disable()
282 bfa_trc(port, BFA_STATUS_PBC); in bfa_port_disable()
286 if (bfa_ioc_is_disabled(port->ioc)) { in bfa_port_disable()
287 bfa_trc(port, BFA_STATUS_IOC_DISABLED); in bfa_port_disable()
291 if (!bfa_ioc_is_operational(port->ioc)) { in bfa_port_disable()
292 bfa_trc(port, BFA_STATUS_IOC_FAILURE); in bfa_port_disable()
296 /* if port is d-port enabled, return error */ in bfa_port_disable()
297 if (port->dport_enabled) { in bfa_port_disable()
298 bfa_trc(port, BFA_STATUS_DPORT_ERR); in bfa_port_disable()
302 if (port->endis_pending) { in bfa_port_disable()
303 bfa_trc(port, BFA_STATUS_DEVBUSY); in bfa_port_disable()
307 m = (struct bfi_port_generic_req_s *) port->endis_mb.msg; in bfa_port_disable()
309 port->msgtag++; in bfa_port_disable()
310 port->endis_cbfn = cbfn; in bfa_port_disable()
311 port->endis_cbarg = cbarg; in bfa_port_disable()
312 port->endis_pending = BFA_TRUE; in bfa_port_disable()
314 bfi_h2i_set(m->mh, BFI_MC_PORT, BFI_PORT_H2I_DISABLE_REQ, in bfa_port_disable()
315 bfa_ioc_portid(port->ioc)); in bfa_port_disable()
316 bfa_ioc_mbox_queue(port->ioc, &port->endis_mb); in bfa_port_disable()
324 * Send the request to the f/w to fetch Port statistics.
326 * @param[in] Pointer to the Port module data structure.
331 bfa_port_get_stats(struct bfa_port_s *port, union bfa_port_stats_u *stats, in bfa_port_get_stats() argument
336 if (!bfa_ioc_is_operational(port->ioc)) { in bfa_port_get_stats()
337 bfa_trc(port, BFA_STATUS_IOC_FAILURE); in bfa_port_get_stats()
341 if (port->stats_busy) { in bfa_port_get_stats()
342 bfa_trc(port, BFA_STATUS_DEVBUSY); in bfa_port_get_stats()
346 m = (struct bfi_port_get_stats_req_s *) port->stats_mb.msg; in bfa_port_get_stats()
348 port->stats = stats; in bfa_port_get_stats()
349 port->stats_cbfn = cbfn; in bfa_port_get_stats()
350 port->stats_cbarg = cbarg; in bfa_port_get_stats()
351 port->stats_busy = BFA_TRUE; in bfa_port_get_stats()
352 bfa_dma_be_addr_set(m->dma_addr, port->stats_dma.pa); in bfa_port_get_stats()
354 bfi_h2i_set(m->mh, BFI_MC_PORT, BFI_PORT_H2I_GET_STATS_REQ, in bfa_port_get_stats()
355 bfa_ioc_portid(port->ioc)); in bfa_port_get_stats()
356 bfa_ioc_mbox_queue(port->ioc, &port->stats_mb); in bfa_port_get_stats()
365 * @param[in] Pointer to the Port module data structure.
370 bfa_port_clear_stats(struct bfa_port_s *port, bfa_port_stats_cbfn_t cbfn, in bfa_port_clear_stats() argument
375 if (!bfa_ioc_is_operational(port->ioc)) { in bfa_port_clear_stats()
376 bfa_trc(port, BFA_STATUS_IOC_FAILURE); in bfa_port_clear_stats()
380 if (port->stats_busy) { in bfa_port_clear_stats()
381 bfa_trc(port, BFA_STATUS_DEVBUSY); in bfa_port_clear_stats()
385 m = (struct bfi_port_generic_req_s *) port->stats_mb.msg; in bfa_port_clear_stats()
387 port->stats_cbfn = cbfn; in bfa_port_clear_stats()
388 port->stats_cbarg = cbarg; in bfa_port_clear_stats()
389 port->stats_busy = BFA_TRUE; in bfa_port_clear_stats()
391 bfi_h2i_set(m->mh, BFI_MC_PORT, BFI_PORT_H2I_CLEAR_STATS_REQ, in bfa_port_clear_stats()
392 bfa_ioc_portid(port->ioc)); in bfa_port_clear_stats()
393 bfa_ioc_mbox_queue(port->ioc, &port->stats_mb); in bfa_port_clear_stats()
401 * Port module IOC event handler
403 * @param[in] Pointer to the Port module data structure.
411 struct bfa_port_s *port = (struct bfa_port_s *) arg; in bfa_port_notify() local
417 if (port->stats_busy) { in bfa_port_notify()
418 if (port->stats_cbfn) in bfa_port_notify()
419 port->stats_cbfn(port->stats_cbarg, in bfa_port_notify()
421 port->stats_cbfn = NULL; in bfa_port_notify()
422 port->stats_busy = BFA_FALSE; in bfa_port_notify()
426 if (port->endis_pending) { in bfa_port_notify()
427 if (port->endis_cbfn) in bfa_port_notify()
428 port->endis_cbfn(port->endis_cbarg, in bfa_port_notify()
430 port->endis_cbfn = NULL; in bfa_port_notify()
431 port->endis_pending = BFA_FALSE; in bfa_port_notify()
434 /* clear D-port mode */ in bfa_port_notify()
435 if (port->dport_enabled) in bfa_port_notify()
436 bfa_port_set_dportenabled(port, BFA_FALSE); in bfa_port_notify()
447 * @param[in] port - Pointer to the Port module data structure
448 * ioc - Pointer to the ioc module data structure
449 * dev - Pointer to the device driver module data structure
452 * trcmod -
457 bfa_port_attach(struct bfa_port_s *port, struct bfa_ioc_s *ioc, in bfa_port_attach() argument
460 WARN_ON(!port); in bfa_port_attach()
462 port->dev = dev; in bfa_port_attach()
463 port->ioc = ioc; in bfa_port_attach()
464 port->trcmod = trcmod; in bfa_port_attach()
466 port->stats_busy = BFA_FALSE; in bfa_port_attach()
467 port->endis_pending = BFA_FALSE; in bfa_port_attach()
468 port->stats_cbfn = NULL; in bfa_port_attach()
469 port->endis_cbfn = NULL; in bfa_port_attach()
470 port->pbc_disabled = BFA_FALSE; in bfa_port_attach()
471 port->dport_enabled = BFA_FALSE; in bfa_port_attach()
473 bfa_ioc_mbox_regisr(port->ioc, BFI_MC_PORT, bfa_port_isr, port); in bfa_port_attach()
474 bfa_q_qe_init(&port->ioc_notify); in bfa_port_attach()
475 bfa_ioc_notify_init(&port->ioc_notify, bfa_port_notify, port); in bfa_port_attach()
476 list_add_tail(&port->ioc_notify.qe, &port->ioc->notify_q); in bfa_port_attach()
481 port->stats_reset_time = ktime_get_seconds(); in bfa_port_attach()
483 bfa_trc(port, 0); in bfa_port_attach()
489 * Port module- set pbc disabled flag
491 * @param[in] port - Pointer to the Port module data structure
496 bfa_port_set_dportenabled(struct bfa_port_s *port, bfa_boolean_t enabled) in bfa_port_set_dportenabled() argument
498 port->dport_enabled = enabled; in bfa_port_set_dportenabled()
508 * @brief CEE ISR for get-attributes responses from f/w
510 * @param[in] cee - Pointer to the CEE module
511 * status - Return status from the f/w
518 struct bfa_cee_lldp_cfg_s *lldp_cfg = &cee->attr->lldp_remote; in bfa_cee_get_attr_isr()
520 cee->get_attr_status = status; in bfa_cee_get_attr_isr()
524 memcpy(cee->attr, cee->attr_dma.kva, in bfa_cee_get_attr_isr()
526 lldp_cfg->time_to_live = be16_to_cpu(lldp_cfg->time_to_live); in bfa_cee_get_attr_isr()
527 lldp_cfg->enabled_system_cap = in bfa_cee_get_attr_isr()
528 be16_to_cpu(lldp_cfg->enabled_system_cap); in bfa_cee_get_attr_isr()
530 cee->get_attr_pending = BFA_FALSE; in bfa_cee_get_attr_isr()
531 if (cee->cbfn.get_attr_cbfn) { in bfa_cee_get_attr_isr()
533 cee->cbfn.get_attr_cbfn(cee->cbfn.get_attr_cbarg, status); in bfa_cee_get_attr_isr()
540 * @brief CEE ISR for get-stats responses from f/w
542 * @param[in] cee - Pointer to the CEE module
543 * status - Return status from the f/w
553 cee->get_stats_status = status; in bfa_cee_get_stats_isr()
557 memcpy(cee->stats, cee->stats_dma.kva, in bfa_cee_get_stats_isr()
560 buffer = (u32 *)cee->stats; in bfa_cee_get_stats_isr()
565 cee->get_stats_pending = BFA_FALSE; in bfa_cee_get_stats_isr()
567 if (cee->cbfn.get_stats_cbfn) { in bfa_cee_get_stats_isr()
569 cee->cbfn.get_stats_cbfn(cee->cbfn.get_stats_cbarg, status); in bfa_cee_get_stats_isr()
576 * @brief CEE ISR for reset-stats responses from f/w
578 * @param[in] cee - Pointer to the CEE module
579 * status - Return status from the f/w
586 cee->reset_stats_status = status; in bfa_cee_reset_stats_isr()
587 cee->reset_stats_pending = BFA_FALSE; in bfa_cee_reset_stats_isr()
588 if (cee->cbfn.reset_stats_cbfn) in bfa_cee_reset_stats_isr()
589 cee->cbfn.reset_stats_cbfn(cee->cbfn.reset_stats_cbarg, status); in bfa_cee_reset_stats_isr()
622 cee->attr_dma.kva = dma_kva; in bfa_cee_mem_claim()
623 cee->attr_dma.pa = dma_pa; in bfa_cee_mem_claim()
624 cee->stats_dma.kva = dma_kva + BFA_ROUNDUP( in bfa_cee_mem_claim()
626 cee->stats_dma.pa = dma_pa + BFA_ROUNDUP( in bfa_cee_mem_claim()
628 cee->attr = (struct bfa_cee_attr_s *) dma_kva; in bfa_cee_mem_claim()
629 cee->stats = (struct bfa_cee_stats_s *) (dma_kva + BFA_ROUNDUP( in bfa_cee_mem_claim()
650 WARN_ON((cee == NULL) || (cee->ioc == NULL)); in bfa_cee_get_attr()
652 if (!bfa_ioc_is_operational(cee->ioc)) { in bfa_cee_get_attr()
656 if (cee->get_attr_pending == BFA_TRUE) { in bfa_cee_get_attr()
660 cee->get_attr_pending = BFA_TRUE; in bfa_cee_get_attr()
661 cmd = (struct bfi_cee_get_req_s *) cee->get_cfg_mb.msg; in bfa_cee_get_attr()
662 cee->attr = attr; in bfa_cee_get_attr()
663 cee->cbfn.get_attr_cbfn = cbfn; in bfa_cee_get_attr()
664 cee->cbfn.get_attr_cbarg = cbarg; in bfa_cee_get_attr()
665 bfi_h2i_set(cmd->mh, BFI_MC_CEE, BFI_CEE_H2I_GET_CFG_REQ, in bfa_cee_get_attr()
666 bfa_ioc_portid(cee->ioc)); in bfa_cee_get_attr()
667 bfa_dma_be_addr_set(cmd->dma_addr, cee->attr_dma.pa); in bfa_cee_get_attr()
668 bfa_ioc_mbox_queue(cee->ioc, &cee->get_cfg_mb); in bfa_cee_get_attr()
690 WARN_ON((cee == NULL) || (cee->ioc == NULL)); in bfa_cee_get_stats()
692 if (!bfa_ioc_is_operational(cee->ioc)) { in bfa_cee_get_stats()
696 if (cee->get_stats_pending == BFA_TRUE) { in bfa_cee_get_stats()
700 cee->get_stats_pending = BFA_TRUE; in bfa_cee_get_stats()
701 cmd = (struct bfi_cee_get_req_s *) cee->get_stats_mb.msg; in bfa_cee_get_stats()
702 cee->stats = stats; in bfa_cee_get_stats()
703 cee->cbfn.get_stats_cbfn = cbfn; in bfa_cee_get_stats()
704 cee->cbfn.get_stats_cbarg = cbarg; in bfa_cee_get_stats()
705 bfi_h2i_set(cmd->mh, BFI_MC_CEE, BFI_CEE_H2I_GET_STATS_REQ, in bfa_cee_get_stats()
706 bfa_ioc_portid(cee->ioc)); in bfa_cee_get_stats()
707 bfa_dma_be_addr_set(cmd->dma_addr, cee->stats_dma.pa); in bfa_cee_get_stats()
708 bfa_ioc_mbox_queue(cee->ioc, &cee->get_stats_mb); in bfa_cee_get_stats()
729 WARN_ON((cee == NULL) || (cee->ioc == NULL)); in bfa_cee_reset_stats()
730 if (!bfa_ioc_is_operational(cee->ioc)) { in bfa_cee_reset_stats()
734 if (cee->reset_stats_pending == BFA_TRUE) { in bfa_cee_reset_stats()
738 cee->reset_stats_pending = BFA_TRUE; in bfa_cee_reset_stats()
739 cmd = (struct bfi_cee_reset_stats_s *) cee->reset_stats_mb.msg; in bfa_cee_reset_stats()
740 cee->cbfn.reset_stats_cbfn = cbfn; in bfa_cee_reset_stats()
741 cee->cbfn.reset_stats_cbarg = cbarg; in bfa_cee_reset_stats()
742 bfi_h2i_set(cmd->mh, BFI_MC_CEE, BFI_CEE_H2I_RESET_STATS, in bfa_cee_reset_stats()
743 bfa_ioc_portid(cee->ioc)); in bfa_cee_reset_stats()
744 bfa_ioc_mbox_queue(cee->ioc, &cee->reset_stats_mb); in bfa_cee_reset_stats()
752 * @brief Handles Mail-box interrupts for CEE module.
767 bfa_trc(cee, msg->mh.msg_id); in bfa_cee_isr()
768 switch (msg->mh.msg_id) { in bfa_cee_isr()
770 bfa_trc(cee, get_rsp->cmd_status); in bfa_cee_isr()
771 bfa_cee_get_attr_isr(cee, get_rsp->cmd_status); in bfa_cee_isr()
774 bfa_cee_get_stats_isr(cee, get_rsp->cmd_status); in bfa_cee_isr()
777 bfa_cee_reset_stats_isr(cee, get_rsp->cmd_status); in bfa_cee_isr()
805 if (cee->get_attr_pending == BFA_TRUE) { in bfa_cee_notify()
806 cee->get_attr_status = BFA_STATUS_FAILED; in bfa_cee_notify()
807 cee->get_attr_pending = BFA_FALSE; in bfa_cee_notify()
808 if (cee->cbfn.get_attr_cbfn) { in bfa_cee_notify()
809 cee->cbfn.get_attr_cbfn( in bfa_cee_notify()
810 cee->cbfn.get_attr_cbarg, in bfa_cee_notify()
814 if (cee->get_stats_pending == BFA_TRUE) { in bfa_cee_notify()
815 cee->get_stats_status = BFA_STATUS_FAILED; in bfa_cee_notify()
816 cee->get_stats_pending = BFA_FALSE; in bfa_cee_notify()
817 if (cee->cbfn.get_stats_cbfn) { in bfa_cee_notify()
818 cee->cbfn.get_stats_cbfn( in bfa_cee_notify()
819 cee->cbfn.get_stats_cbarg, in bfa_cee_notify()
823 if (cee->reset_stats_pending == BFA_TRUE) { in bfa_cee_notify()
824 cee->reset_stats_status = BFA_STATUS_FAILED; in bfa_cee_notify()
825 cee->reset_stats_pending = BFA_FALSE; in bfa_cee_notify()
826 if (cee->cbfn.reset_stats_cbfn) { in bfa_cee_notify()
827 cee->cbfn.reset_stats_cbfn( in bfa_cee_notify()
828 cee->cbfn.reset_stats_cbarg, in bfa_cee_notify()
842 * @brief CEE module-attach API
844 * @param[in] cee - Pointer to the CEE module data structure
845 * ioc - Pointer to the ioc module data structure
846 * dev - Pointer to the device driver module data structure
857 cee->dev = dev; in bfa_cee_attach()
858 cee->ioc = ioc; in bfa_cee_attach()
860 bfa_ioc_mbox_regisr(cee->ioc, BFI_MC_CEE, bfa_cee_isr, cee); in bfa_cee_attach()
861 bfa_q_qe_init(&cee->ioc_notify); in bfa_cee_attach()
862 bfa_ioc_notify_init(&cee->ioc_notify, bfa_cee_notify, cee); in bfa_cee_attach()
863 list_add_tail(&cee->ioc_notify.qe, &cee->ioc->notify_q); in bfa_cee_attach()