Lines Matching refs:int_params

520 	if (cdev->int_params.out.int_mode == QED_INT_MODE_MSIX) {  in qed_disable_msix()
522 kfree(cdev->int_params.msix_table); in qed_disable_msix()
523 } else if (cdev->int_params.out.int_mode == QED_INT_MODE_MSI) { in qed_disable_msix()
527 memset(&cdev->int_params.out, 0, sizeof(struct qed_int_param)); in qed_disable_msix()
531 struct qed_int_params *int_params) in qed_enable_msix() argument
535 cnt = int_params->in.num_vectors; in qed_enable_msix()
538 int_params->msix_table[i].entry = i; in qed_enable_msix()
540 rc = pci_enable_msix_range(cdev->pdev, int_params->msix_table, in qed_enable_msix()
541 int_params->in.min_msix_cnt, cnt); in qed_enable_msix()
542 if (rc < cnt && rc >= int_params->in.min_msix_cnt && in qed_enable_msix()
553 cnt, int_params->in.num_vectors); in qed_enable_msix()
554 rc = pci_enable_msix_exact(cdev->pdev, int_params->msix_table, in qed_enable_msix()
562 int_params->out.int_mode = QED_INT_MODE_MSIX; in qed_enable_msix()
563 int_params->out.num_vectors = rc; in qed_enable_msix()
577 struct qed_int_params *int_params = &cdev->int_params; in qed_set_int_mode() local
581 switch (int_params->in.int_mode) { in qed_set_int_mode()
584 cnt = int_params->in.num_vectors; in qed_set_int_mode()
585 int_params->msix_table = kcalloc(cnt, sizeof(*tbl), GFP_KERNEL); in qed_set_int_mode()
586 if (!int_params->msix_table) { in qed_set_int_mode()
592 rc = qed_enable_msix(cdev, int_params); in qed_set_int_mode()
597 kfree(int_params->msix_table); in qed_set_int_mode()
606 int_params->out.int_mode = QED_INT_MODE_MSI; in qed_set_int_mode()
617 int_params->out.int_mode = QED_INT_MODE_INTA; in qed_set_int_mode()
622 int_params->in.int_mode); in qed_set_int_mode()
629 int_params->out.int_mode == QED_INT_MODE_INTA ? in qed_set_int_mode()
630 "INTa" : int_params->out.int_mode == QED_INT_MODE_MSI ? in qed_set_int_mode()
719 int_mode = cdev->int_params.out.int_mode; in qed_slowpath_irq_req()
725 rc = request_irq(cdev->int_params.msix_table[id].vector, in qed_slowpath_irq_req()
734 if (cdev->int_params.out.int_mode == QED_INT_MODE_INTA) in qed_slowpath_irq_req()
769 int_mode = cdev->int_params.out.int_mode; in qed_slowpath_irq_sync()
771 synchronize_irq(cdev->int_params.msix_table[id].vector); in qed_slowpath_irq_sync()
782 if (cdev->int_params.out.int_mode == QED_INT_MODE_MSIX) { in qed_slowpath_irq_free()
786 synchronize_irq(cdev->int_params.msix_table[i].vector); in qed_slowpath_irq_free()
787 free_irq(cdev->int_params.msix_table[i].vector, in qed_slowpath_irq_free()
849 cdev->int_params.fp_initialized = cnt ? true : false; in qed_set_int_fp()
851 if (cdev->int_params.out.int_mode != QED_INT_MODE_MSIX) in qed_set_int_fp()
853 else if (cdev->int_params.fp_msix_cnt) in qed_set_int_fp()
854 limit = cdev->int_params.fp_msix_cnt; in qed_set_int_fp()
866 if (!cdev->int_params.fp_initialized) { in qed_get_int_fp()
875 if (cdev->int_params.out.int_mode == QED_INT_MODE_MSIX) { in qed_get_int_fp()
876 int msix_base = cdev->int_params.fp_msix_base; in qed_get_int_fp()
878 info->msix_cnt = cdev->int_params.fp_msix_cnt; in qed_get_int_fp()
879 info->msix = &cdev->int_params.msix_table[msix_base]; in qed_get_int_fp()
898 memset(&cdev->int_params, 0, sizeof(struct qed_int_params)); in qed_slowpath_setup_int()
899 cdev->int_params.in.int_mode = int_mode; in qed_slowpath_setup_int()
903 cdev->int_params.in.num_vectors += sb_cnt_info.cnt; in qed_slowpath_setup_int()
904 cdev->int_params.in.num_vectors++; /* slowpath */ in qed_slowpath_setup_int()
908 cdev->int_params.in.min_msix_cnt = cdev->num_hwfns * 2; in qed_slowpath_setup_int()
913 cdev->int_params.in.min_msix_cnt); in qed_slowpath_setup_int()
914 cdev->int_params.in.num_vectors = in qed_slowpath_setup_int()
915 cdev->int_params.in.min_msix_cnt; in qed_slowpath_setup_int()
924 cdev->int_params.fp_msix_base = cdev->num_hwfns; in qed_slowpath_setup_int()
925 cdev->int_params.fp_msix_cnt = cdev->int_params.out.num_vectors - in qed_slowpath_setup_int()
937 cdev->int_params.fp_msix_cnt, num_l2_queues); in qed_slowpath_setup_int()
939 if (cdev->int_params.fp_msix_cnt > num_l2_queues) { in qed_slowpath_setup_int()
940 cdev->int_params.rdma_msix_cnt = in qed_slowpath_setup_int()
941 (cdev->int_params.fp_msix_cnt - num_l2_queues) in qed_slowpath_setup_int()
943 cdev->int_params.rdma_msix_base = in qed_slowpath_setup_int()
944 cdev->int_params.fp_msix_base + num_l2_queues; in qed_slowpath_setup_int()
945 cdev->int_params.fp_msix_cnt = num_l2_queues; in qed_slowpath_setup_int()
947 cdev->int_params.rdma_msix_cnt = 0; in qed_slowpath_setup_int()
951 cdev->int_params.rdma_msix_cnt, in qed_slowpath_setup_int()
952 cdev->int_params.rdma_msix_base); in qed_slowpath_setup_int()
961 memset(&cdev->int_params, 0, sizeof(struct qed_int_params)); in qed_slowpath_vf_setup_int()
962 cdev->int_params.in.int_mode = QED_INT_MODE_MSIX; in qed_slowpath_vf_setup_int()
965 &cdev->int_params.in.num_vectors); in qed_slowpath_vf_setup_int()
970 cdev->int_params.in.num_vectors += vectors; in qed_slowpath_vf_setup_int()
974 cdev->int_params.in.min_msix_cnt = cdev->num_hwfns; in qed_slowpath_vf_setup_int()
980 cdev->int_params.fp_msix_base = 0; in qed_slowpath_vf_setup_int()
981 cdev->int_params.fp_msix_cnt = cdev->int_params.out.num_vectors; in qed_slowpath_vf_setup_int()
1287 hw_init_params.int_mode = cdev->int_params.out.int_mode; in qed_slowpath_start()