Lines Matching refs:int_params

402 	if (cdev->int_params.out.int_mode == QED_INT_MODE_MSIX) {  in qed_disable_msix()
404 kfree(cdev->int_params.msix_table); in qed_disable_msix()
405 } else if (cdev->int_params.out.int_mode == QED_INT_MODE_MSI) { in qed_disable_msix()
409 memset(&cdev->int_params.out, 0, sizeof(struct qed_int_param)); in qed_disable_msix()
413 struct qed_int_params *int_params) in qed_enable_msix() argument
417 cnt = int_params->in.num_vectors; in qed_enable_msix()
420 int_params->msix_table[i].entry = i; in qed_enable_msix()
422 rc = pci_enable_msix_range(cdev->pdev, int_params->msix_table, in qed_enable_msix()
423 int_params->in.min_msix_cnt, cnt); in qed_enable_msix()
424 if (rc < cnt && rc >= int_params->in.min_msix_cnt && in qed_enable_msix()
435 cnt, int_params->in.num_vectors); in qed_enable_msix()
436 rc = pci_enable_msix_exact(cdev->pdev, int_params->msix_table, in qed_enable_msix()
444 int_params->out.int_mode = QED_INT_MODE_MSIX; in qed_enable_msix()
445 int_params->out.num_vectors = rc; in qed_enable_msix()
459 struct qed_int_params *int_params = &cdev->int_params; in qed_set_int_mode() local
463 switch (int_params->in.int_mode) { in qed_set_int_mode()
466 cnt = int_params->in.num_vectors; in qed_set_int_mode()
467 int_params->msix_table = kcalloc(cnt, sizeof(*tbl), GFP_KERNEL); in qed_set_int_mode()
468 if (!int_params->msix_table) { in qed_set_int_mode()
474 rc = qed_enable_msix(cdev, int_params); in qed_set_int_mode()
479 kfree(int_params->msix_table); in qed_set_int_mode()
488 int_params->out.int_mode = QED_INT_MODE_MSI; in qed_set_int_mode()
499 int_params->out.int_mode = QED_INT_MODE_INTA; in qed_set_int_mode()
504 int_params->in.int_mode); in qed_set_int_mode()
511 int_params->out.int_mode == QED_INT_MODE_INTA ? in qed_set_int_mode()
512 "INTa" : int_params->out.int_mode == QED_INT_MODE_MSI ? in qed_set_int_mode()
601 int_mode = cdev->int_params.out.int_mode; in qed_slowpath_irq_req()
607 rc = request_irq(cdev->int_params.msix_table[id].vector, in qed_slowpath_irq_req()
616 if (cdev->int_params.out.int_mode == QED_INT_MODE_INTA) in qed_slowpath_irq_req()
651 int_mode = cdev->int_params.out.int_mode; in qed_slowpath_irq_sync()
653 synchronize_irq(cdev->int_params.msix_table[id].vector); in qed_slowpath_irq_sync()
664 if (cdev->int_params.out.int_mode == QED_INT_MODE_MSIX) { in qed_slowpath_irq_free()
668 synchronize_irq(cdev->int_params.msix_table[i].vector); in qed_slowpath_irq_free()
669 free_irq(cdev->int_params.msix_table[i].vector, in qed_slowpath_irq_free()
731 cdev->int_params.fp_initialized = cnt ? true : false; in qed_set_int_fp()
733 if (cdev->int_params.out.int_mode != QED_INT_MODE_MSIX) in qed_set_int_fp()
735 else if (cdev->int_params.fp_msix_cnt) in qed_set_int_fp()
736 limit = cdev->int_params.fp_msix_cnt; in qed_set_int_fp()
748 if (!cdev->int_params.fp_initialized) { in qed_get_int_fp()
757 if (cdev->int_params.out.int_mode == QED_INT_MODE_MSIX) { in qed_get_int_fp()
758 int msix_base = cdev->int_params.fp_msix_base; in qed_get_int_fp()
760 info->msix_cnt = cdev->int_params.fp_msix_cnt; in qed_get_int_fp()
761 info->msix = &cdev->int_params.msix_table[msix_base]; in qed_get_int_fp()
780 memset(&cdev->int_params, 0, sizeof(struct qed_int_params)); in qed_slowpath_setup_int()
781 cdev->int_params.in.int_mode = int_mode; in qed_slowpath_setup_int()
785 cdev->int_params.in.num_vectors += sb_cnt_info.cnt; in qed_slowpath_setup_int()
786 cdev->int_params.in.num_vectors++; /* slowpath */ in qed_slowpath_setup_int()
790 cdev->int_params.in.min_msix_cnt = cdev->num_hwfns * 2; in qed_slowpath_setup_int()
795 cdev->int_params.in.min_msix_cnt); in qed_slowpath_setup_int()
796 cdev->int_params.in.num_vectors = in qed_slowpath_setup_int()
797 cdev->int_params.in.min_msix_cnt; in qed_slowpath_setup_int()
806 cdev->int_params.fp_msix_base = cdev->num_hwfns; in qed_slowpath_setup_int()
807 cdev->int_params.fp_msix_cnt = cdev->int_params.out.num_vectors - in qed_slowpath_setup_int()
819 cdev->int_params.fp_msix_cnt, num_l2_queues); in qed_slowpath_setup_int()
821 if (cdev->int_params.fp_msix_cnt > num_l2_queues) { in qed_slowpath_setup_int()
822 cdev->int_params.rdma_msix_cnt = in qed_slowpath_setup_int()
823 (cdev->int_params.fp_msix_cnt - num_l2_queues) in qed_slowpath_setup_int()
825 cdev->int_params.rdma_msix_base = in qed_slowpath_setup_int()
826 cdev->int_params.fp_msix_base + num_l2_queues; in qed_slowpath_setup_int()
827 cdev->int_params.fp_msix_cnt = num_l2_queues; in qed_slowpath_setup_int()
829 cdev->int_params.rdma_msix_cnt = 0; in qed_slowpath_setup_int()
833 cdev->int_params.rdma_msix_cnt, in qed_slowpath_setup_int()
834 cdev->int_params.rdma_msix_base); in qed_slowpath_setup_int()
843 memset(&cdev->int_params, 0, sizeof(struct qed_int_params)); in qed_slowpath_vf_setup_int()
844 cdev->int_params.in.int_mode = QED_INT_MODE_MSIX; in qed_slowpath_vf_setup_int()
847 &cdev->int_params.in.num_vectors); in qed_slowpath_vf_setup_int()
852 cdev->int_params.in.num_vectors += vectors; in qed_slowpath_vf_setup_int()
856 cdev->int_params.in.min_msix_cnt = cdev->num_hwfns; in qed_slowpath_vf_setup_int()
862 cdev->int_params.fp_msix_base = 0; in qed_slowpath_vf_setup_int()
863 cdev->int_params.fp_msix_cnt = cdev->int_params.out.num_vectors; in qed_slowpath_vf_setup_int()
1109 hw_init_params.int_mode = cdev->int_params.out.int_mode; in qed_slowpath_start()