aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorJames Smart <james.smart@emulex.com>2011-12-13 13:21:35 -0500
committerJames Bottomley <JBottomley@Parallels.com>2011-12-15 01:57:44 -0500
commitff78d8f97c85a568c0799b06137a4171db45b923 (patch)
treef5bb5d1875075175075c0beb09d770073dd82612 /drivers
parent026abb87a5586c838a47aca7198d78e356b6351e (diff)
[SCSI] lpfc 8.3.28: SLI fixes and added SLI4 support
Adapter (SLI) interface fixes: - Modify WQ handling to use entry_repost (CR 123981) - Fix for ABTS. Do not free original IOCB whenever ABTS fails. (CR 115829) - Check board for FCoE before reading FCoE paramaters (CR124731) - Add support for SLI4 FC Loop mode (CR 124721) - Add support for resource count changes during fw reset. (CR 125888, 125675) - Increase CQE count from 256 to 1024. (CR 126149) Signed-off-by: Alex Iannicelli <alex.iannicelli@emulex.com> Signed-off-by: James Smart <james.smart@emulex.com> Signed-off-by: James Bottomley <JBottomley@Parallels.com>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/scsi/lpfc/lpfc_attr.c23
-rw-r--r--drivers/scsi/lpfc/lpfc_crtn.h2
-rw-r--r--drivers/scsi/lpfc/lpfc_els.c18
-rw-r--r--drivers/scsi/lpfc/lpfc_hbadisc.c1
-rw-r--r--drivers/scsi/lpfc/lpfc_init.c52
-rw-r--r--drivers/scsi/lpfc/lpfc_sli.c184
-rw-r--r--drivers/scsi/lpfc/lpfc_sli4.h2
7 files changed, 156 insertions, 126 deletions
diff --git a/drivers/scsi/lpfc/lpfc_attr.c b/drivers/scsi/lpfc/lpfc_attr.c
index 7bf492e156d..f6697cb0e21 100644
--- a/drivers/scsi/lpfc/lpfc_attr.c
+++ b/drivers/scsi/lpfc/lpfc_attr.c
@@ -2777,6 +2777,14 @@ lpfc_topology_store(struct device *dev, struct device_attribute *attr,
2777 if (val >= 0 && val <= 6) { 2777 if (val >= 0 && val <= 6) {
2778 prev_val = phba->cfg_topology; 2778 prev_val = phba->cfg_topology;
2779 phba->cfg_topology = val; 2779 phba->cfg_topology = val;
2780 if (phba->cfg_link_speed == LPFC_USER_LINK_SPEED_16G &&
2781 val == 4) {
2782 lpfc_printf_vlog(vport, KERN_ERR, LOG_INIT,
2783 "3113 Loop mode not supported at speed %d\n",
2784 phba->cfg_link_speed);
2785 phba->cfg_topology = prev_val;
2786 return -EINVAL;
2787 }
2780 if (nolip) 2788 if (nolip)
2781 return strlen(buf); 2789 return strlen(buf);
2782 2790
@@ -3222,6 +3230,14 @@ lpfc_link_speed_store(struct device *dev, struct device_attribute *attr,
3222 val); 3230 val);
3223 return -EINVAL; 3231 return -EINVAL;
3224 } 3232 }
3233 if (val == LPFC_USER_LINK_SPEED_16G &&
3234 phba->fc_topology == LPFC_TOPOLOGY_LOOP) {
3235 lpfc_printf_log(phba, KERN_ERR, LOG_INIT,
3236 "3112 lpfc_link_speed attribute cannot be set "
3237 "to %d. Speed is not supported in loop mode.\n",
3238 val);
3239 return -EINVAL;
3240 }
3225 if ((val >= 0) && (val <= LPFC_USER_LINK_SPEED_MAX) && 3241 if ((val >= 0) && (val <= LPFC_USER_LINK_SPEED_MAX) &&
3226 (LPFC_USER_LINK_SPEED_BITMAP & (1 << val))) { 3242 (LPFC_USER_LINK_SPEED_BITMAP & (1 << val))) {
3227 prev_val = phba->cfg_link_speed; 3243 prev_val = phba->cfg_link_speed;
@@ -3266,6 +3282,13 @@ lpfc_param_show(link_speed)
3266static int 3282static int
3267lpfc_link_speed_init(struct lpfc_hba *phba, int val) 3283lpfc_link_speed_init(struct lpfc_hba *phba, int val)
3268{ 3284{
3285 if (val == LPFC_USER_LINK_SPEED_16G && phba->cfg_topology == 4) {
3286 lpfc_printf_log(phba, KERN_ERR, LOG_INIT,
3287 "3111 lpfc_link_speed of %d cannot "
3288 "support loop mode, setting topology to default.\n",
3289 val);
3290 phba->cfg_topology = 0;
3291 }
3269 if ((val >= 0) && (val <= LPFC_USER_LINK_SPEED_MAX) && 3292 if ((val >= 0) && (val <= LPFC_USER_LINK_SPEED_MAX) &&
3270 (LPFC_USER_LINK_SPEED_BITMAP & (1 << val))) { 3293 (LPFC_USER_LINK_SPEED_BITMAP & (1 << val))) {
3271 phba->cfg_link_speed = val; 3294 phba->cfg_link_speed = val;
diff --git a/drivers/scsi/lpfc/lpfc_crtn.h b/drivers/scsi/lpfc/lpfc_crtn.h
index f74afa23e0d..9237ff15423 100644
--- a/drivers/scsi/lpfc/lpfc_crtn.h
+++ b/drivers/scsi/lpfc/lpfc_crtn.h
@@ -453,3 +453,5 @@ int lpfc_sli_probe_sriov_nr_virtfn(struct lpfc_hba *, int);
453uint16_t lpfc_sli_sriov_nr_virtfn_get(struct lpfc_hba *); 453uint16_t lpfc_sli_sriov_nr_virtfn_get(struct lpfc_hba *);
454int lpfc_sli4_queue_create(struct lpfc_hba *); 454int lpfc_sli4_queue_create(struct lpfc_hba *);
455void lpfc_sli4_queue_destroy(struct lpfc_hba *); 455void lpfc_sli4_queue_destroy(struct lpfc_hba *);
456int lpfc_sli4_read_config(struct lpfc_hba *phba);
457int lpfc_scsi_buf_update(struct lpfc_hba *phba);
diff --git a/drivers/scsi/lpfc/lpfc_els.c b/drivers/scsi/lpfc/lpfc_els.c
index 445826a4c98..846ebfd37b5 100644
--- a/drivers/scsi/lpfc/lpfc_els.c
+++ b/drivers/scsi/lpfc/lpfc_els.c
@@ -909,15 +909,15 @@ lpfc_cmpl_els_flogi(struct lpfc_hba *phba, struct lpfc_iocbq *cmdiocb,
909 */ 909 */
910 if (phba->alpa_map[0] == 0) { 910 if (phba->alpa_map[0] == 0) {
911 vport->cfg_discovery_threads = LPFC_MAX_DISC_THREADS; 911 vport->cfg_discovery_threads = LPFC_MAX_DISC_THREADS;
912 if ((phba->sli_rev == LPFC_SLI_REV4) && 912 }
913 (!(vport->fc_flag & FC_VFI_REGISTERED) || 913 if ((phba->sli_rev == LPFC_SLI_REV4) &&
914 (vport->fc_prevDID != vport->fc_myDID))) { 914 (!(vport->fc_flag & FC_VFI_REGISTERED) ||
915 if (vport->fc_flag & FC_VFI_REGISTERED) 915 (vport->fc_prevDID != vport->fc_myDID))) {
916 lpfc_sli4_unreg_all_rpis(vport); 916 if (vport->fc_flag & FC_VFI_REGISTERED)
917 lpfc_issue_reg_vfi(vport); 917 lpfc_sli4_unreg_all_rpis(vport);
918 lpfc_nlp_put(ndlp); 918 lpfc_issue_reg_vfi(vport);
919 goto out; 919 lpfc_nlp_put(ndlp);
920 } 920 goto out;
921 } 921 }
922 goto flogifail; 922 goto flogifail;
923 } 923 }
diff --git a/drivers/scsi/lpfc/lpfc_hbadisc.c b/drivers/scsi/lpfc/lpfc_hbadisc.c
index 091f68e5cb7..cf4408f9a2c 100644
--- a/drivers/scsi/lpfc/lpfc_hbadisc.c
+++ b/drivers/scsi/lpfc/lpfc_hbadisc.c
@@ -2858,7 +2858,6 @@ lpfc_mbx_cmpl_reg_vfi(struct lpfc_hba *phba, LPFC_MBOXQ_t *mboxq)
2858 if (vport->port_state == LPFC_FABRIC_CFG_LINK) { 2858 if (vport->port_state == LPFC_FABRIC_CFG_LINK) {
2859 /* For private loop just start discovery and we are done. */ 2859 /* For private loop just start discovery and we are done. */
2860 if ((phba->fc_topology == LPFC_TOPOLOGY_LOOP) && 2860 if ((phba->fc_topology == LPFC_TOPOLOGY_LOOP) &&
2861 (phba->alpa_map[0] == 0) &&
2862 !(vport->fc_flag & FC_PUBLIC_LOOP)) { 2861 !(vport->fc_flag & FC_PUBLIC_LOOP)) {
2863 /* Use loop map to make discovery list */ 2862 /* Use loop map to make discovery list */
2864 lpfc_disc_list_loopmap(vport); 2863 lpfc_disc_list_loopmap(vport);
diff --git a/drivers/scsi/lpfc/lpfc_init.c b/drivers/scsi/lpfc/lpfc_init.c
index d247eb01552..6096c9a091d 100644
--- a/drivers/scsi/lpfc/lpfc_init.c
+++ b/drivers/scsi/lpfc/lpfc_init.c
@@ -62,7 +62,6 @@ static int lpfc_post_rcv_buf(struct lpfc_hba *);
62static int lpfc_sli4_queue_verify(struct lpfc_hba *); 62static int lpfc_sli4_queue_verify(struct lpfc_hba *);
63static int lpfc_create_bootstrap_mbox(struct lpfc_hba *); 63static int lpfc_create_bootstrap_mbox(struct lpfc_hba *);
64static int lpfc_setup_endian_order(struct lpfc_hba *); 64static int lpfc_setup_endian_order(struct lpfc_hba *);
65static int lpfc_sli4_read_config(struct lpfc_hba *);
66static void lpfc_destroy_bootstrap_mbox(struct lpfc_hba *); 65static void lpfc_destroy_bootstrap_mbox(struct lpfc_hba *);
67static void lpfc_free_sgl_list(struct lpfc_hba *); 66static void lpfc_free_sgl_list(struct lpfc_hba *);
68static int lpfc_init_sgl_list(struct lpfc_hba *); 67static int lpfc_init_sgl_list(struct lpfc_hba *);
@@ -2655,6 +2654,32 @@ lpfc_offline(struct lpfc_hba *phba)
2655} 2654}
2656 2655
2657/** 2656/**
2657 * lpfc_scsi_buf_update - Update the scsi_buffers that are already allocated.
2658 * @phba: pointer to lpfc hba data structure.
2659 *
2660 * This routine goes through all the scsi buffers in the system and updates the
2661 * Physical XRIs assigned to the SCSI buffer because these may change after any
2662 * firmware reset
2663 *
2664 * Return codes
2665 * 0 - successful (for now, it always returns 0)
2666 **/
2667int
2668lpfc_scsi_buf_update(struct lpfc_hba *phba)
2669{
2670 struct lpfc_scsi_buf *sb, *sb_next;
2671
2672 spin_lock_irq(&phba->hbalock);
2673 spin_lock(&phba->scsi_buf_list_lock);
2674 list_for_each_entry_safe(sb, sb_next, &phba->lpfc_scsi_buf_list, list)
2675 sb->cur_iocbq.sli4_xritag =
2676 phba->sli4_hba.xri_ids[sb->cur_iocbq.sli4_lxritag];
2677 spin_unlock(&phba->scsi_buf_list_lock);
2678 spin_unlock_irq(&phba->hbalock);
2679 return 0;
2680}
2681
2682/**
2658 * lpfc_scsi_free - Free all the SCSI buffers and IOCBs from driver lists 2683 * lpfc_scsi_free - Free all the SCSI buffers and IOCBs from driver lists
2659 * @phba: pointer to lpfc hba data structure. 2684 * @phba: pointer to lpfc hba data structure.
2660 * 2685 *
@@ -5021,15 +5046,8 @@ lpfc_sli4_init_rpi_hdrs(struct lpfc_hba *phba)
5021 struct lpfc_rpi_hdr *rpi_hdr; 5046 struct lpfc_rpi_hdr *rpi_hdr;
5022 5047
5023 INIT_LIST_HEAD(&phba->sli4_hba.lpfc_rpi_hdr_list); 5048 INIT_LIST_HEAD(&phba->sli4_hba.lpfc_rpi_hdr_list);
5024 /* 5049 if (!phba->sli4_hba.rpi_hdrs_in_use)
5025 * If the SLI4 port supports extents, posting the rpi header isn't
5026 * required. Set the expected maximum count and let the actual value
5027 * get set when extents are fully allocated.
5028 */
5029 if (!phba->sli4_hba.rpi_hdrs_in_use) {
5030 phba->sli4_hba.next_rpi = phba->sli4_hba.max_cfg_param.max_rpi;
5031 return rc; 5050 return rc;
5032 }
5033 if (phba->sli4_hba.extents_in_use) 5051 if (phba->sli4_hba.extents_in_use)
5034 return -EIO; 5052 return -EIO;
5035 5053
@@ -5923,7 +5941,7 @@ lpfc_destroy_bootstrap_mbox(struct lpfc_hba *phba)
5923 * -ENOMEM - No available memory 5941 * -ENOMEM - No available memory
5924 * -EIO - The mailbox failed to complete successfully. 5942 * -EIO - The mailbox failed to complete successfully.
5925 **/ 5943 **/
5926static int 5944int
5927lpfc_sli4_read_config(struct lpfc_hba *phba) 5945lpfc_sli4_read_config(struct lpfc_hba *phba)
5928{ 5946{
5929 LPFC_MBOXQ_t *pmb; 5947 LPFC_MBOXQ_t *pmb;
@@ -5955,6 +5973,20 @@ lpfc_sli4_read_config(struct lpfc_hba *phba)
5955 rc = -EIO; 5973 rc = -EIO;
5956 } else { 5974 } else {
5957 rd_config = &pmb->u.mqe.un.rd_config; 5975 rd_config = &pmb->u.mqe.un.rd_config;
5976 if (bf_get(lpfc_mbx_rd_conf_lnk_ldv, rd_config)) {
5977 phba->sli4_hba.lnk_info.lnk_dv = LPFC_LNK_DAT_VAL;
5978 phba->sli4_hba.lnk_info.lnk_tp =
5979 bf_get(lpfc_mbx_rd_conf_lnk_type, rd_config);
5980 phba->sli4_hba.lnk_info.lnk_no =
5981 bf_get(lpfc_mbx_rd_conf_lnk_numb, rd_config);
5982 lpfc_printf_log(phba, KERN_INFO, LOG_SLI,
5983 "3081 lnk_type:%d, lnk_numb:%d\n",
5984 phba->sli4_hba.lnk_info.lnk_tp,
5985 phba->sli4_hba.lnk_info.lnk_no);
5986 } else
5987 lpfc_printf_log(phba, KERN_WARNING, LOG_SLI,
5988 "3082 Mailbox (x%x) returned ldv:x0\n",
5989 bf_get(lpfc_mqe_command, &pmb->u.mqe));
5958 phba->sli4_hba.extents_in_use = 5990 phba->sli4_hba.extents_in_use =
5959 bf_get(lpfc_mbx_rd_conf_extnts_inuse, rd_config); 5991 bf_get(lpfc_mbx_rd_conf_extnts_inuse, rd_config);
5960 phba->sli4_hba.max_cfg_param.max_xri = 5992 phba->sli4_hba.max_cfg_param.max_xri =
diff --git a/drivers/scsi/lpfc/lpfc_sli.c b/drivers/scsi/lpfc/lpfc_sli.c
index 1be13e757ed..4c4d77356bb 100644
--- a/drivers/scsi/lpfc/lpfc_sli.c
+++ b/drivers/scsi/lpfc/lpfc_sli.c
@@ -97,7 +97,7 @@ lpfc_sli4_wq_put(struct lpfc_queue *q, union lpfc_wqe *wqe)
97 if (((q->host_index + 1) % q->entry_count) == q->hba_index) 97 if (((q->host_index + 1) % q->entry_count) == q->hba_index)
98 return -ENOMEM; 98 return -ENOMEM;
99 /* set consumption flag every once in a while */ 99 /* set consumption flag every once in a while */
100 if (!((q->host_index + 1) % LPFC_RELEASE_NOTIFICATION_INTERVAL)) 100 if (!((q->host_index + 1) % q->entry_repost))
101 bf_set(wqe_wqec, &wqe->generic.wqe_com, 1); 101 bf_set(wqe_wqec, &wqe->generic.wqe_com, 1);
102 if (q->phba->sli3_options & LPFC_SLI4_PHWQ_ENABLED) 102 if (q->phba->sli3_options & LPFC_SLI4_PHWQ_ENABLED)
103 bf_set(wqe_wqid, &wqe->generic.wqe_com, q->queue_id); 103 bf_set(wqe_wqid, &wqe->generic.wqe_com, q->queue_id);
@@ -4551,9 +4551,9 @@ lpfc_sli_hba_setup_error:
4551 * data structure. 4551 * data structure.
4552 **/ 4552 **/
4553static int 4553static int
4554lpfc_sli4_read_fcoe_params(struct lpfc_hba *phba, 4554lpfc_sli4_read_fcoe_params(struct lpfc_hba *phba)
4555 LPFC_MBOXQ_t *mboxq)
4556{ 4555{
4556 LPFC_MBOXQ_t *mboxq;
4557 struct lpfc_dmabuf *mp; 4557 struct lpfc_dmabuf *mp;
4558 struct lpfc_mqe *mqe; 4558 struct lpfc_mqe *mqe;
4559 uint32_t data_length; 4559 uint32_t data_length;
@@ -4565,10 +4565,16 @@ lpfc_sli4_read_fcoe_params(struct lpfc_hba *phba,
4565 phba->fc_map[1] = LPFC_FCOE_FCF_MAP1; 4565 phba->fc_map[1] = LPFC_FCOE_FCF_MAP1;
4566 phba->fc_map[2] = LPFC_FCOE_FCF_MAP2; 4566 phba->fc_map[2] = LPFC_FCOE_FCF_MAP2;
4567 4567
4568 mqe = &mboxq->u.mqe; 4568 mboxq = (LPFC_MBOXQ_t *)mempool_alloc(phba->mbox_mem_pool, GFP_KERNEL);
4569 if (lpfc_sli4_dump_cfg_rg23(phba, mboxq)) 4569 if (!mboxq)
4570 return -ENOMEM; 4570 return -ENOMEM;
4571 4571
4572 mqe = &mboxq->u.mqe;
4573 if (lpfc_sli4_dump_cfg_rg23(phba, mboxq)) {
4574 rc = -ENOMEM;
4575 goto out_free_mboxq;
4576 }
4577
4572 mp = (struct lpfc_dmabuf *) mboxq->context1; 4578 mp = (struct lpfc_dmabuf *) mboxq->context1;
4573 rc = lpfc_sli_issue_mbox(phba, mboxq, MBX_POLL); 4579 rc = lpfc_sli_issue_mbox(phba, mboxq, MBX_POLL);
4574 4580
@@ -4596,19 +4602,25 @@ lpfc_sli4_read_fcoe_params(struct lpfc_hba *phba,
4596 if (rc) { 4602 if (rc) {
4597 lpfc_mbuf_free(phba, mp->virt, mp->phys); 4603 lpfc_mbuf_free(phba, mp->virt, mp->phys);
4598 kfree(mp); 4604 kfree(mp);
4599 return -EIO; 4605 rc = -EIO;
4606 goto out_free_mboxq;
4600 } 4607 }
4601 data_length = mqe->un.mb_words[5]; 4608 data_length = mqe->un.mb_words[5];
4602 if (data_length > DMP_RGN23_SIZE) { 4609 if (data_length > DMP_RGN23_SIZE) {
4603 lpfc_mbuf_free(phba, mp->virt, mp->phys); 4610 lpfc_mbuf_free(phba, mp->virt, mp->phys);
4604 kfree(mp); 4611 kfree(mp);
4605 return -EIO; 4612 rc = -EIO;
4613 goto out_free_mboxq;
4606 } 4614 }
4607 4615
4608 lpfc_parse_fcoe_conf(phba, mp->virt, data_length); 4616 lpfc_parse_fcoe_conf(phba, mp->virt, data_length);
4609 lpfc_mbuf_free(phba, mp->virt, mp->phys); 4617 lpfc_mbuf_free(phba, mp->virt, mp->phys);
4610 kfree(mp); 4618 kfree(mp);
4611 return 0; 4619 rc = 0;
4620
4621out_free_mboxq:
4622 mempool_free(mboxq, phba->mbox_mem_pool);
4623 return rc;
4612} 4624}
4613 4625
4614/** 4626/**
@@ -4706,7 +4718,6 @@ static int
4706lpfc_sli4_retrieve_pport_name(struct lpfc_hba *phba) 4718lpfc_sli4_retrieve_pport_name(struct lpfc_hba *phba)
4707{ 4719{
4708 LPFC_MBOXQ_t *mboxq; 4720 LPFC_MBOXQ_t *mboxq;
4709 struct lpfc_mbx_read_config *rd_config;
4710 struct lpfc_mbx_get_cntl_attributes *mbx_cntl_attr; 4721 struct lpfc_mbx_get_cntl_attributes *mbx_cntl_attr;
4711 struct lpfc_controller_attribute *cntl_attr; 4722 struct lpfc_controller_attribute *cntl_attr;
4712 struct lpfc_mbx_get_port_name *get_port_name; 4723 struct lpfc_mbx_get_port_name *get_port_name;
@@ -4724,33 +4735,11 @@ lpfc_sli4_retrieve_pport_name(struct lpfc_hba *phba)
4724 mboxq = (LPFC_MBOXQ_t *)mempool_alloc(phba->mbox_mem_pool, GFP_KERNEL); 4735 mboxq = (LPFC_MBOXQ_t *)mempool_alloc(phba->mbox_mem_pool, GFP_KERNEL);
4725 if (!mboxq) 4736 if (!mboxq)
4726 return -ENOMEM; 4737 return -ENOMEM;
4727
4728 /* obtain link type and link number via READ_CONFIG */ 4738 /* obtain link type and link number via READ_CONFIG */
4729 lpfc_read_config(phba, mboxq); 4739 phba->sli4_hba.lnk_info.lnk_dv = LPFC_LNK_DAT_INVAL;
4730 rc = lpfc_sli_issue_mbox(phba, mboxq, MBX_POLL); 4740 lpfc_sli4_read_config(phba);
4731 if (rc == MBX_SUCCESS) { 4741 if (phba->sli4_hba.lnk_info.lnk_dv == LPFC_LNK_DAT_VAL)
4732 rd_config = &mboxq->u.mqe.un.rd_config; 4742 goto retrieve_ppname;
4733 if (bf_get(lpfc_mbx_rd_conf_lnk_ldv, rd_config)) {
4734 phba->sli4_hba.lnk_info.lnk_dv = LPFC_LNK_DAT_VAL;
4735 phba->sli4_hba.lnk_info.lnk_tp =
4736 bf_get(lpfc_mbx_rd_conf_lnk_type, rd_config);
4737 phba->sli4_hba.lnk_info.lnk_no =
4738 bf_get(lpfc_mbx_rd_conf_lnk_numb, rd_config);
4739 lpfc_printf_log(phba, KERN_INFO, LOG_SLI,
4740 "3081 lnk_type:%d, lnk_numb:%d\n",
4741 phba->sli4_hba.lnk_info.lnk_tp,
4742 phba->sli4_hba.lnk_info.lnk_no);
4743 goto retrieve_ppname;
4744 } else
4745 lpfc_printf_log(phba, KERN_WARNING, LOG_SLI,
4746 "3082 Mailbox (x%x) returned ldv:x0\n",
4747 bf_get(lpfc_mqe_command,
4748 &mboxq->u.mqe));
4749 } else
4750 lpfc_printf_log(phba, KERN_WARNING, LOG_SLI,
4751 "3083 Mailbox (x%x) failed, status:x%x\n",
4752 bf_get(lpfc_mqe_command, &mboxq->u.mqe),
4753 bf_get(lpfc_mqe_status, &mboxq->u.mqe));
4754 4743
4755 /* obtain link type and link number via COMMON_GET_CNTL_ATTRIBUTES */ 4744 /* obtain link type and link number via COMMON_GET_CNTL_ATTRIBUTES */
4756 reqlen = sizeof(struct lpfc_mbx_get_cntl_attributes); 4745 reqlen = sizeof(struct lpfc_mbx_get_cntl_attributes);
@@ -5457,6 +5446,8 @@ lpfc_sli4_alloc_resource_identifiers(struct lpfc_hba *phba)
5457 uint16_t count, base; 5446 uint16_t count, base;
5458 unsigned long longs; 5447 unsigned long longs;
5459 5448
5449 if (!phba->sli4_hba.rpi_hdrs_in_use)
5450 phba->sli4_hba.next_rpi = phba->sli4_hba.max_cfg_param.max_rpi;
5460 if (phba->sli4_hba.extents_in_use) { 5451 if (phba->sli4_hba.extents_in_use) {
5461 /* 5452 /*
5462 * The port supports resource extents. The XRI, VPI, VFI, RPI 5453 * The port supports resource extents. The XRI, VPI, VFI, RPI
@@ -5538,9 +5529,10 @@ lpfc_sli4_alloc_resource_identifiers(struct lpfc_hba *phba)
5538 * need any action - just exit. 5529 * need any action - just exit.
5539 */ 5530 */
5540 if (bf_get(lpfc_idx_rsrc_rdy, &phba->sli4_hba.sli4_flags) == 5531 if (bf_get(lpfc_idx_rsrc_rdy, &phba->sli4_hba.sli4_flags) ==
5541 LPFC_IDX_RSRC_RDY) 5532 LPFC_IDX_RSRC_RDY) {
5542 return 0; 5533 lpfc_sli4_dealloc_resource_identifiers(phba);
5543 5534 lpfc_sli4_remove_rpis(phba);
5535 }
5544 /* RPIs. */ 5536 /* RPIs. */
5545 count = phba->sli4_hba.max_cfg_param.max_rpi; 5537 count = phba->sli4_hba.max_cfg_param.max_rpi;
5546 base = phba->sli4_hba.max_cfg_param.rpi_base; 5538 base = phba->sli4_hba.max_cfg_param.rpi_base;
@@ -5880,14 +5872,6 @@ lpfc_sli4_hba_setup(struct lpfc_hba *phba)
5880 if (!mboxq) 5872 if (!mboxq)
5881 return -ENOMEM; 5873 return -ENOMEM;
5882 5874
5883 /*
5884 * Continue initialization with default values even if driver failed
5885 * to read FCoE param config regions
5886 */
5887 if (lpfc_sli4_read_fcoe_params(phba, mboxq))
5888 lpfc_printf_log(phba, KERN_WARNING, LOG_MBOX | LOG_INIT,
5889 "2570 Failed to read FCoE parameters\n");
5890
5891 /* Issue READ_REV to collect vpd and FW information. */ 5875 /* Issue READ_REV to collect vpd and FW information. */
5892 vpd_size = SLI4_PAGE_SIZE; 5876 vpd_size = SLI4_PAGE_SIZE;
5893 vpd = kzalloc(vpd_size, GFP_KERNEL); 5877 vpd = kzalloc(vpd_size, GFP_KERNEL);
@@ -5925,6 +5909,16 @@ lpfc_sli4_hba_setup(struct lpfc_hba *phba)
5925 } 5909 }
5926 5910
5927 /* 5911 /*
5912 * Continue initialization with default values even if driver failed
5913 * to read FCoE param config regions, only read parameters if the
5914 * board is FCoE
5915 */
5916 if (phba->hba_flag & HBA_FCOE_MODE &&
5917 lpfc_sli4_read_fcoe_params(phba))
5918 lpfc_printf_log(phba, KERN_WARNING, LOG_MBOX | LOG_INIT,
5919 "2570 Failed to read FCoE parameters\n");
5920
5921 /*
5928 * Retrieve sli4 device physical port name, failure of doing it 5922 * Retrieve sli4 device physical port name, failure of doing it
5929 * is considered as non-fatal. 5923 * is considered as non-fatal.
5930 */ 5924 */
@@ -6044,6 +6038,8 @@ lpfc_sli4_hba_setup(struct lpfc_hba *phba)
6044 "rc = x%x\n", rc); 6038 "rc = x%x\n", rc);
6045 goto out_free_mbox; 6039 goto out_free_mbox;
6046 } 6040 }
6041 /* update physical xri mappings in the scsi buffers */
6042 lpfc_scsi_buf_update(phba);
6047 6043
6048 /* Read the port's service parameters. */ 6044 /* Read the port's service parameters. */
6049 rc = lpfc_read_sparam(phba, mboxq, vport->vpi); 6045 rc = lpfc_read_sparam(phba, mboxq, vport->vpi);
@@ -7632,6 +7628,7 @@ lpfc_sli4_iocb2wqe(struct lpfc_hba *phba, struct lpfc_iocbq *iocbq,
7632 int numBdes, i; 7628 int numBdes, i;
7633 struct ulp_bde64 bde; 7629 struct ulp_bde64 bde;
7634 struct lpfc_nodelist *ndlp; 7630 struct lpfc_nodelist *ndlp;
7631 uint32_t *pcmd;
7635 7632
7636 fip = phba->hba_flag & HBA_FIP_SUPPORT; 7633 fip = phba->hba_flag & HBA_FIP_SUPPORT;
7637 /* The fcp commands will set command type */ 7634 /* The fcp commands will set command type */
@@ -7685,6 +7682,7 @@ lpfc_sli4_iocb2wqe(struct lpfc_hba *phba, struct lpfc_iocbq *iocbq,
7685 iocbq->iocb.ulpCommand); 7682 iocbq->iocb.ulpCommand);
7686 return IOCB_ERROR; 7683 return IOCB_ERROR;
7687 } 7684 }
7685
7688 wqe->els_req.payload_len = xmit_len; 7686 wqe->els_req.payload_len = xmit_len;
7689 /* Els_reguest64 has a TMO */ 7687 /* Els_reguest64 has a TMO */
7690 bf_set(wqe_tmo, &wqe->els_req.wqe_com, 7688 bf_set(wqe_tmo, &wqe->els_req.wqe_com,
@@ -7699,9 +7697,25 @@ lpfc_sli4_iocb2wqe(struct lpfc_hba *phba, struct lpfc_iocbq *iocbq,
7699 bf_set(wqe_ct, &wqe->els_req.wqe_com, ct); 7697 bf_set(wqe_ct, &wqe->els_req.wqe_com, ct);
7700 bf_set(wqe_pu, &wqe->els_req.wqe_com, 0); 7698 bf_set(wqe_pu, &wqe->els_req.wqe_com, 0);
7701 /* CCP CCPE PV PRI in word10 were set in the memcpy */ 7699 /* CCP CCPE PV PRI in word10 were set in the memcpy */
7702 if (command_type == ELS_COMMAND_FIP) { 7700 if (command_type == ELS_COMMAND_FIP)
7703 els_id = ((iocbq->iocb_flag & LPFC_FIP_ELS_ID_MASK) 7701 els_id = ((iocbq->iocb_flag & LPFC_FIP_ELS_ID_MASK)
7704 >> LPFC_FIP_ELS_ID_SHIFT); 7702 >> LPFC_FIP_ELS_ID_SHIFT);
7703 pcmd = (uint32_t *) (((struct lpfc_dmabuf *)
7704 iocbq->context2)->virt);
7705 if (phba->fc_topology == LPFC_TOPOLOGY_LOOP) {
7706 if (pcmd && (*pcmd == ELS_CMD_FLOGI ||
7707 *pcmd == ELS_CMD_PLOGI)) {
7708 bf_set(els_req64_sp, &wqe->els_req, 1);
7709 bf_set(els_req64_sid, &wqe->els_req,
7710 iocbq->vport->fc_myDID);
7711 bf_set(wqe_ct, &wqe->els_req.wqe_com, 1);
7712 bf_set(wqe_ctxt_tag, &wqe->els_req.wqe_com,
7713 phba->vpi_ids[phba->pport->vpi]);
7714 } else if (iocbq->context1) {
7715 bf_set(wqe_ct, &wqe->els_req.wqe_com, 0);
7716 bf_set(wqe_ctxt_tag, &wqe->els_req.wqe_com,
7717 phba->sli4_hba.rpi_ids[ndlp->nlp_rpi]);
7718 }
7705 } 7719 }
7706 bf_set(wqe_temp_rpi, &wqe->els_req.wqe_com, 7720 bf_set(wqe_temp_rpi, &wqe->els_req.wqe_com,
7707 phba->sli4_hba.rpi_ids[ndlp->nlp_rpi]); 7721 phba->sli4_hba.rpi_ids[ndlp->nlp_rpi]);
@@ -7862,6 +7876,16 @@ lpfc_sli4_iocb2wqe(struct lpfc_hba *phba, struct lpfc_iocbq *iocbq,
7862 bf_set(wqe_ebde_cnt, &wqe->xmit_els_rsp.wqe_com, 0); 7876 bf_set(wqe_ebde_cnt, &wqe->xmit_els_rsp.wqe_com, 0);
7863 bf_set(wqe_rsp_temp_rpi, &wqe->xmit_els_rsp, 7877 bf_set(wqe_rsp_temp_rpi, &wqe->xmit_els_rsp,
7864 phba->sli4_hba.rpi_ids[ndlp->nlp_rpi]); 7878 phba->sli4_hba.rpi_ids[ndlp->nlp_rpi]);
7879 pcmd = (uint32_t *) (((struct lpfc_dmabuf *)
7880 iocbq->context2)->virt);
7881 if (phba->fc_topology == LPFC_TOPOLOGY_LOOP) {
7882 bf_set(els_req64_sp, &wqe->els_req, 1);
7883 bf_set(els_req64_sid, &wqe->els_req,
7884 iocbq->vport->fc_myDID);
7885 bf_set(wqe_ct, &wqe->els_req.wqe_com, 1);
7886 bf_set(wqe_ctxt_tag, &wqe->els_req.wqe_com,
7887 phba->vpi_ids[phba->pport->vpi]);
7888 }
7865 command_type = OTHER_COMMAND; 7889 command_type = OTHER_COMMAND;
7866 break; 7890 break;
7867 case CMD_CLOSE_XRI_CN: 7891 case CMD_CLOSE_XRI_CN:
@@ -8839,12 +8863,14 @@ lpfc_sli_abort_els_cmpl(struct lpfc_hba *phba, struct lpfc_iocbq *cmdiocb,
8839{ 8863{
8840 IOCB_t *irsp = &rspiocb->iocb; 8864 IOCB_t *irsp = &rspiocb->iocb;
8841 uint16_t abort_iotag, abort_context; 8865 uint16_t abort_iotag, abort_context;
8842 struct lpfc_iocbq *abort_iocb; 8866 struct lpfc_iocbq *abort_iocb = NULL;
8843 struct lpfc_sli_ring *pring = &phba->sli.ring[LPFC_ELS_RING];
8844
8845 abort_iocb = NULL;
8846 8867
8847 if (irsp->ulpStatus) { 8868 if (irsp->ulpStatus) {
8869
8870 /*
8871 * Assume that the port already completed and returned, or
8872 * will return the iocb. Just Log the message.
8873 */
8848 abort_context = cmdiocb->iocb.un.acxri.abortContextTag; 8874 abort_context = cmdiocb->iocb.un.acxri.abortContextTag;
8849 abort_iotag = cmdiocb->iocb.un.acxri.abortIoTag; 8875 abort_iotag = cmdiocb->iocb.un.acxri.abortIoTag;
8850 8876
@@ -8862,68 +8888,15 @@ lpfc_sli_abort_els_cmpl(struct lpfc_hba *phba, struct lpfc_iocbq *cmdiocb,
8862 */ 8888 */
8863 abort_iocb = phba->sli.iocbq_lookup[abort_context]; 8889 abort_iocb = phba->sli.iocbq_lookup[abort_context];
8864 8890
8865 /*
8866 * If the iocb is not found in Firmware queue the iocb
8867 * might have completed already. Do not free it again.
8868 */
8869 if (irsp->ulpStatus == IOSTAT_LOCAL_REJECT) {
8870 if (irsp->un.ulpWord[4] != IOERR_NO_XRI) {
8871 spin_unlock_irq(&phba->hbalock);
8872 lpfc_sli_release_iocbq(phba, cmdiocb);
8873 return;
8874 }
8875 /* For SLI4 the ulpContext field for abort IOCB
8876 * holds the iotag of the IOCB being aborted so
8877 * the local abort_context needs to be reset to
8878 * match the aborted IOCBs ulpContext.
8879 */
8880 if (abort_iocb && phba->sli_rev == LPFC_SLI_REV4)
8881 abort_context = abort_iocb->iocb.ulpContext;
8882 }
8883
8884 lpfc_printf_log(phba, KERN_WARNING, LOG_ELS | LOG_SLI, 8891 lpfc_printf_log(phba, KERN_WARNING, LOG_ELS | LOG_SLI,
8885 "0327 Cannot abort els iocb %p " 8892 "0327 Cannot abort els iocb %p "
8886 "with tag %x context %x, abort status %x, " 8893 "with tag %x context %x, abort status %x, "
8887 "abort code %x\n", 8894 "abort code %x\n",
8888 abort_iocb, abort_iotag, abort_context, 8895 abort_iocb, abort_iotag, abort_context,
8889 irsp->ulpStatus, irsp->un.ulpWord[4]); 8896 irsp->ulpStatus, irsp->un.ulpWord[4]);
8890 /*
8891 * make sure we have the right iocbq before taking it
8892 * off the txcmplq and try to call completion routine.
8893 */
8894 if (!abort_iocb ||
8895 abort_iocb->iocb.ulpContext != abort_context ||
8896 (abort_iocb->iocb_flag & LPFC_DRIVER_ABORTED) == 0)
8897 spin_unlock_irq(&phba->hbalock);
8898 else if (phba->sli_rev < LPFC_SLI_REV4) {
8899 /*
8900 * leave the SLI4 aborted command on the txcmplq
8901 * list and the command complete WCQE's XB bit
8902 * will tell whether the SGL (XRI) can be released
8903 * immediately or to the aborted SGL list for the
8904 * following abort XRI from the HBA.
8905 */
8906 list_del_init(&abort_iocb->list);
8907 if (abort_iocb->iocb_flag & LPFC_IO_ON_Q) {
8908 abort_iocb->iocb_flag &= ~LPFC_IO_ON_Q;
8909 pring->txcmplq_cnt--;
8910 }
8911
8912 /* Firmware could still be in progress of DMAing
8913 * payload, so don't free data buffer till after
8914 * a hbeat.
8915 */
8916 abort_iocb->iocb_flag |= LPFC_DELAY_MEM_FREE;
8917 abort_iocb->iocb_flag &= ~LPFC_DRIVER_ABORTED;
8918 spin_unlock_irq(&phba->hbalock);
8919 8897
8920 abort_iocb->iocb.ulpStatus = IOSTAT_LOCAL_REJECT; 8898 spin_unlock_irq(&phba->hbalock);
8921 abort_iocb->iocb.un.ulpWord[4] = IOERR_ABORT_REQUESTED;
8922 (abort_iocb->iocb_cmpl)(phba, abort_iocb, abort_iocb);
8923 } else
8924 spin_unlock_irq(&phba->hbalock);
8925 } 8899 }
8926
8927 lpfc_sli_release_iocbq(phba, cmdiocb); 8900 lpfc_sli_release_iocbq(phba, cmdiocb);
8928 return; 8901 return;
8929} 8902}
@@ -12167,6 +12140,7 @@ lpfc_wq_create(struct lpfc_hba *phba, struct lpfc_queue *wq,
12167 wq->subtype = subtype; 12140 wq->subtype = subtype;
12168 wq->host_index = 0; 12141 wq->host_index = 0;
12169 wq->hba_index = 0; 12142 wq->hba_index = 0;
12143 wq->entry_repost = LPFC_RELEASE_NOTIFICATION_INTERVAL;
12170 12144
12171 /* link the wq onto the parent cq child list */ 12145 /* link the wq onto the parent cq child list */
12172 list_add_tail(&wq->list, &cq->child_list); 12146 list_add_tail(&wq->list, &cq->child_list);
diff --git a/drivers/scsi/lpfc/lpfc_sli4.h b/drivers/scsi/lpfc/lpfc_sli4.h
index d5cffd8af34..7d444c444db 100644
--- a/drivers/scsi/lpfc/lpfc_sli4.h
+++ b/drivers/scsi/lpfc/lpfc_sli4.h
@@ -291,7 +291,7 @@ struct lpfc_bmbx {
291#define LPFC_RQE_SIZE 8 291#define LPFC_RQE_SIZE 8
292 292
293#define LPFC_EQE_DEF_COUNT 1024 293#define LPFC_EQE_DEF_COUNT 1024
294#define LPFC_CQE_DEF_COUNT 256 294#define LPFC_CQE_DEF_COUNT 1024
295#define LPFC_WQE_DEF_COUNT 256 295#define LPFC_WQE_DEF_COUNT 256
296#define LPFC_MQE_DEF_COUNT 16 296#define LPFC_MQE_DEF_COUNT 16
297#define LPFC_RQE_DEF_COUNT 512 297#define LPFC_RQE_DEF_COUNT 512