aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJames Smart <james.smart@emulex.com>2010-09-29 11:19:14 -0400
committerJames Bottomley <James.Bottomley@suse.de>2010-10-07 18:30:36 -0400
commit3677a3a76e190f801af0778df3b8efa1fe161a6e (patch)
tree1a1ebb2267f27963a5699ff27f04b88bec2533c8
parenteee8877ee5e8a879f78034001b5e7c04db005ab2 (diff)
[SCSI] lpfc 8.3.17: Replace function reset methodology
Replace graceful teardown steps with the singular function reset command. Signed-off-by: Alex Iannicelli <alex.iannicelli@emulex.com> Signed-off-by: James Smart <james.smart@emulex.com> Signed-off-by: James Bottomley <James.Bottomley@suse.de>
-rw-r--r--drivers/scsi/lpfc/lpfc_init.c132
-rw-r--r--drivers/scsi/lpfc/lpfc_sli.c76
-rw-r--r--drivers/scsi/lpfc/lpfc_sli4.h2
3 files changed, 9 insertions, 201 deletions
diff --git a/drivers/scsi/lpfc/lpfc_init.c b/drivers/scsi/lpfc/lpfc_init.c
index 053eaef09005..295c7ddb36c1 100644
--- a/drivers/scsi/lpfc/lpfc_init.c
+++ b/drivers/scsi/lpfc/lpfc_init.c
@@ -2888,65 +2888,6 @@ lpfc_stop_port(struct lpfc_hba *phba)
2888} 2888}
2889 2889
2890/** 2890/**
2891 * lpfc_sli4_remove_dflt_fcf - Remove the driver default fcf record from the port.
2892 * @phba: pointer to lpfc hba data structure.
2893 *
2894 * This routine is invoked to remove the driver default fcf record from
2895 * the port. This routine currently acts on FCF Index 0.
2896 *
2897 **/
2898void
2899lpfc_sli_remove_dflt_fcf(struct lpfc_hba *phba)
2900{
2901 int rc = 0;
2902 LPFC_MBOXQ_t *mboxq;
2903 struct lpfc_mbx_del_fcf_tbl_entry *del_fcf_record;
2904 uint32_t mbox_tmo, req_len;
2905 uint32_t shdr_status, shdr_add_status;
2906
2907 mboxq = mempool_alloc(phba->mbox_mem_pool, GFP_KERNEL);
2908 if (!mboxq) {
2909 lpfc_printf_log(phba, KERN_ERR, LOG_INIT,
2910 "2020 Failed to allocate mbox for ADD_FCF cmd\n");
2911 return;
2912 }
2913
2914 req_len = sizeof(struct lpfc_mbx_del_fcf_tbl_entry) -
2915 sizeof(struct lpfc_sli4_cfg_mhdr);
2916 rc = lpfc_sli4_config(phba, mboxq, LPFC_MBOX_SUBSYSTEM_FCOE,
2917 LPFC_MBOX_OPCODE_FCOE_DELETE_FCF,
2918 req_len, LPFC_SLI4_MBX_EMBED);
2919 /*
2920 * In phase 1, there is a single FCF index, 0. In phase2, the driver
2921 * supports multiple FCF indices.
2922 */
2923 del_fcf_record = &mboxq->u.mqe.un.del_fcf_entry;
2924 bf_set(lpfc_mbx_del_fcf_tbl_count, del_fcf_record, 1);
2925 bf_set(lpfc_mbx_del_fcf_tbl_index, del_fcf_record,
2926 phba->fcf.current_rec.fcf_indx);
2927
2928 if (!phba->sli4_hba.intr_enable)
2929 rc = lpfc_sli_issue_mbox(phba, mboxq, MBX_POLL);
2930 else {
2931 mbox_tmo = lpfc_mbox_tmo_val(phba, MBX_SLI4_CONFIG);
2932 rc = lpfc_sli_issue_mbox_wait(phba, mboxq, mbox_tmo);
2933 }
2934 /* The IOCTL status is embedded in the mailbox subheader. */
2935 shdr_status = bf_get(lpfc_mbox_hdr_status,
2936 &del_fcf_record->header.cfg_shdr.response);
2937 shdr_add_status = bf_get(lpfc_mbox_hdr_add_status,
2938 &del_fcf_record->header.cfg_shdr.response);
2939 if (shdr_status || shdr_add_status || rc != MBX_SUCCESS) {
2940 lpfc_printf_log(phba, KERN_ERR, LOG_SLI,
2941 "2516 DEL FCF of default FCF Index failed "
2942 "mbx status x%x, status x%x add_status x%x\n",
2943 rc, shdr_status, shdr_add_status);
2944 }
2945 if (rc != MBX_TIMEOUT)
2946 mempool_free(mboxq, phba->mbox_mem_pool);
2947}
2948
2949/**
2950 * lpfc_fcf_redisc_wait_start_timer - Start fcf rediscover wait timer 2891 * lpfc_fcf_redisc_wait_start_timer - Start fcf rediscover wait timer
2951 * @phba: Pointer to hba for which this call is being executed. 2892 * @phba: Pointer to hba for which this call is being executed.
2952 * 2893 *
@@ -4288,12 +4229,6 @@ lpfc_sli4_driver_resource_unset(struct lpfc_hba *phba)
4288{ 4229{
4289 struct lpfc_fcf_conn_entry *conn_entry, *next_conn_entry; 4230 struct lpfc_fcf_conn_entry *conn_entry, *next_conn_entry;
4290 4231
4291 /* unregister default FCFI from the HBA */
4292 lpfc_sli4_fcfi_unreg(phba, phba->fcf.fcfi);
4293
4294 /* Free the default FCR table */
4295 lpfc_sli_remove_dflt_fcf(phba);
4296
4297 /* Free memory allocated for msi-x interrupt vector entries */ 4232 /* Free memory allocated for msi-x interrupt vector entries */
4298 kfree(phba->sli4_hba.msix_entries); 4233 kfree(phba->sli4_hba.msix_entries);
4299 4234
@@ -4321,9 +4256,6 @@ lpfc_sli4_driver_resource_unset(struct lpfc_hba *phba)
4321 lpfc_sli4_cq_event_release_all(phba); 4256 lpfc_sli4_cq_event_release_all(phba);
4322 lpfc_sli4_cq_event_pool_destroy(phba); 4257 lpfc_sli4_cq_event_pool_destroy(phba);
4323 4258
4324 /* Reset SLI4 HBA FCoE function */
4325 lpfc_pci_function_reset(phba);
4326
4327 /* Free the bsmbx region. */ 4259 /* Free the bsmbx region. */
4328 lpfc_destroy_bootstrap_mbox(phba); 4260 lpfc_destroy_bootstrap_mbox(phba);
4329 4261
@@ -4550,7 +4482,6 @@ lpfc_free_sgl_list(struct lpfc_hba *phba)
4550{ 4482{
4551 struct lpfc_sglq *sglq_entry = NULL, *sglq_next = NULL; 4483 struct lpfc_sglq *sglq_entry = NULL, *sglq_next = NULL;
4552 LIST_HEAD(sglq_list); 4484 LIST_HEAD(sglq_list);
4553 int rc = 0;
4554 4485
4555 spin_lock_irq(&phba->hbalock); 4486 spin_lock_irq(&phba->hbalock);
4556 list_splice_init(&phba->sli4_hba.lpfc_sgl_list, &sglq_list); 4487 list_splice_init(&phba->sli4_hba.lpfc_sgl_list, &sglq_list);
@@ -4563,11 +4494,6 @@ lpfc_free_sgl_list(struct lpfc_hba *phba)
4563 kfree(sglq_entry); 4494 kfree(sglq_entry);
4564 phba->sli4_hba.total_sglq_bufs--; 4495 phba->sli4_hba.total_sglq_bufs--;
4565 } 4496 }
4566 rc = lpfc_sli4_remove_all_sgl_pages(phba);
4567 if (rc) {
4568 lpfc_printf_log(phba, KERN_ERR, LOG_SLI,
4569 "2005 Unable to deregister pages from HBA: %x\n", rc);
4570 }
4571 kfree(phba->sli4_hba.lpfc_els_sgl_array); 4497 kfree(phba->sli4_hba.lpfc_els_sgl_array);
4572} 4498}
4573 4499
@@ -6597,50 +6523,6 @@ lpfc_sli4_send_nop_mbox_cmds(struct lpfc_hba *phba, uint32_t cnt)
6597} 6523}
6598 6524
6599/** 6525/**
6600 * lpfc_sli4_fcfi_unreg - Unregister fcfi to device
6601 * @phba: pointer to lpfc hba data structure.
6602 * @fcfi: fcf index.
6603 *
6604 * This routine is invoked to unregister a FCFI from device.
6605 **/
6606void
6607lpfc_sli4_fcfi_unreg(struct lpfc_hba *phba, uint16_t fcfi)
6608{
6609 LPFC_MBOXQ_t *mbox;
6610 uint32_t mbox_tmo;
6611 int rc;
6612 unsigned long flags;
6613
6614 mbox = mempool_alloc(phba->mbox_mem_pool, GFP_KERNEL);
6615
6616 if (!mbox)
6617 return;
6618
6619 lpfc_unreg_fcfi(mbox, fcfi);
6620
6621 if (!phba->sli4_hba.intr_enable)
6622 rc = lpfc_sli_issue_mbox(phba, mbox, MBX_POLL);
6623 else {
6624 mbox_tmo = lpfc_mbox_tmo_val(phba, MBX_SLI4_CONFIG);
6625 rc = lpfc_sli_issue_mbox_wait(phba, mbox, mbox_tmo);
6626 }
6627 if (rc != MBX_TIMEOUT)
6628 mempool_free(mbox, phba->mbox_mem_pool);
6629 if (rc != MBX_SUCCESS)
6630 lpfc_printf_log(phba, KERN_ERR, LOG_SLI,
6631 "2517 Unregister FCFI command failed "
6632 "status %d, mbxStatus x%x\n", rc,
6633 bf_get(lpfc_mqe_status, &mbox->u.mqe));
6634 else {
6635 spin_lock_irqsave(&phba->hbalock, flags);
6636 /* Mark the FCFI is no longer registered */
6637 phba->fcf.fcf_flag &=
6638 ~(FCF_AVAILABLE | FCF_REGISTERED | FCF_SCAN_DONE);
6639 spin_unlock_irqrestore(&phba->hbalock, flags);
6640 }
6641}
6642
6643/**
6644 * lpfc_sli4_pci_mem_setup - Setup SLI4 HBA PCI memory space. 6526 * lpfc_sli4_pci_mem_setup - Setup SLI4 HBA PCI memory space.
6645 * @phba: pointer to lpfc hba data structure. 6527 * @phba: pointer to lpfc hba data structure.
6646 * 6528 *
@@ -7377,10 +7259,14 @@ lpfc_sli4_unset_hba(struct lpfc_hba *phba)
7377 7259
7378 phba->pport->work_port_events = 0; 7260 phba->pport->work_port_events = 0;
7379 7261
7380 lpfc_sli4_hba_down(phba); 7262 /* Stop the SLI4 device port */
7263 lpfc_stop_port(phba);
7381 7264
7382 lpfc_sli4_disable_intr(phba); 7265 lpfc_sli4_disable_intr(phba);
7383 7266
7267 /* Reset SLI4 HBA FCoE function */
7268 lpfc_pci_function_reset(phba);
7269
7384 return; 7270 return;
7385} 7271}
7386 7272
@@ -7429,15 +7315,15 @@ lpfc_sli4_hba_unset(struct lpfc_hba *phba)
7429 spin_unlock_irq(&phba->hbalock); 7315 spin_unlock_irq(&phba->hbalock);
7430 } 7316 }
7431 7317
7432 /* Tear down the queues in the HBA */
7433 lpfc_sli4_queue_unset(phba);
7434
7435 /* Disable PCI subsystem interrupt */ 7318 /* Disable PCI subsystem interrupt */
7436 lpfc_sli4_disable_intr(phba); 7319 lpfc_sli4_disable_intr(phba);
7437 7320
7438 /* Stop kthread signal shall trigger work_done one more time */ 7321 /* Stop kthread signal shall trigger work_done one more time */
7439 kthread_stop(phba->worker_thread); 7322 kthread_stop(phba->worker_thread);
7440 7323
7324 /* Reset SLI4 HBA FCoE function */
7325 lpfc_pci_function_reset(phba);
7326
7441 /* Stop the SLI4 device port */ 7327 /* Stop the SLI4 device port */
7442 phba->pport->work_port_events = 0; 7328 phba->pport->work_port_events = 0;
7443} 7329}
@@ -8373,7 +8259,7 @@ lpfc_pci_remove_one_s4(struct pci_dev *pdev)
8373 list_del_init(&vport->listentry); 8259 list_del_init(&vport->listentry);
8374 spin_unlock_irq(&phba->hbalock); 8260 spin_unlock_irq(&phba->hbalock);
8375 8261
8376 /* Call scsi_free before lpfc_sli4_driver_resource_unset since scsi 8262 /* Perform scsi free before driver resource_unset since scsi
8377 * buffers are released to their corresponding pools here. 8263 * buffers are released to their corresponding pools here.
8378 */ 8264 */
8379 lpfc_scsi_free(phba); 8265 lpfc_scsi_free(phba);
diff --git a/drivers/scsi/lpfc/lpfc_sli.c b/drivers/scsi/lpfc/lpfc_sli.c
index 34dd87f542c2..0d1e187b005d 100644
--- a/drivers/scsi/lpfc/lpfc_sli.c
+++ b/drivers/scsi/lpfc/lpfc_sli.c
@@ -6930,37 +6930,6 @@ lpfc_sli_hba_down(struct lpfc_hba *phba)
6930} 6930}
6931 6931
6932/** 6932/**
6933 * lpfc_sli4_hba_down - PCI function resource cleanup for the SLI4 HBA
6934 * @phba: Pointer to HBA context object.
6935 *
6936 * This function cleans up all queues, iocb, buffers, mailbox commands while
6937 * shutting down the SLI4 HBA FCoE function. This function is called with no
6938 * lock held and always returns 1.
6939 *
6940 * This function does the following to cleanup driver FCoE function resources:
6941 * - Free discovery resources for each virtual port
6942 * - Cleanup any pending fabric iocbs
6943 * - Iterate through the iocb txq and free each entry in the list.
6944 * - Free up any buffer posted to the HBA.
6945 * - Clean up all the queue entries: WQ, RQ, MQ, EQ, CQ, etc.
6946 * - Free mailbox commands in the mailbox queue.
6947 **/
6948int
6949lpfc_sli4_hba_down(struct lpfc_hba *phba)
6950{
6951 /* Stop the SLI4 device port */
6952 lpfc_stop_port(phba);
6953
6954 /* Tear down the queues in the HBA */
6955 lpfc_sli4_queue_unset(phba);
6956
6957 /* unregister default FCFI from the HBA */
6958 lpfc_sli4_fcfi_unreg(phba, phba->fcf.fcfi);
6959
6960 return 1;
6961}
6962
6963/**
6964 * lpfc_sli_pcimem_bcopy - SLI memory copy function 6933 * lpfc_sli_pcimem_bcopy - SLI memory copy function
6965 * @srcp: Source memory pointer. 6934 * @srcp: Source memory pointer.
6966 * @destp: Destination memory pointer. 6935 * @destp: Destination memory pointer.
@@ -10788,51 +10757,6 @@ lpfc_sli4_post_sgl(struct lpfc_hba *phba,
10788 } 10757 }
10789 return 0; 10758 return 0;
10790} 10759}
10791/**
10792 * lpfc_sli4_remove_all_sgl_pages - Post scatter gather list for an XRI to HBA
10793 * @phba: The virtual port for which this call being executed.
10794 *
10795 * This routine will remove all of the sgl pages registered with the hba.
10796 *
10797 * Return codes:
10798 * 0 - Success
10799 * -ENXIO, -ENOMEM - Failure
10800 **/
10801int
10802lpfc_sli4_remove_all_sgl_pages(struct lpfc_hba *phba)
10803{
10804 LPFC_MBOXQ_t *mbox;
10805 int rc;
10806 uint32_t shdr_status, shdr_add_status;
10807 union lpfc_sli4_cfg_shdr *shdr;
10808
10809 mbox = mempool_alloc(phba->mbox_mem_pool, GFP_KERNEL);
10810 if (!mbox)
10811 return -ENOMEM;
10812
10813 lpfc_sli4_config(phba, mbox, LPFC_MBOX_SUBSYSTEM_FCOE,
10814 LPFC_MBOX_OPCODE_FCOE_REMOVE_SGL_PAGES, 0,
10815 LPFC_SLI4_MBX_EMBED);
10816 if (!phba->sli4_hba.intr_enable)
10817 rc = lpfc_sli_issue_mbox(phba, mbox, MBX_POLL);
10818 else
10819 rc = lpfc_sli_issue_mbox_wait(phba, mbox, LPFC_MBOX_TMO);
10820 /* The IOCTL status is embedded in the mailbox subheader. */
10821 shdr = (union lpfc_sli4_cfg_shdr *)
10822 &mbox->u.mqe.un.sli4_config.header.cfg_shdr;
10823 shdr_status = bf_get(lpfc_mbox_hdr_status, &shdr->response);
10824 shdr_add_status = bf_get(lpfc_mbox_hdr_add_status, &shdr->response);
10825 if (rc != MBX_TIMEOUT)
10826 mempool_free(mbox, phba->mbox_mem_pool);
10827 if (shdr_status || shdr_add_status || rc) {
10828 lpfc_printf_log(phba, KERN_ERR, LOG_INIT,
10829 "2512 REMOVE_ALL_SGL_PAGES mailbox failed with "
10830 "status x%x add_status x%x, mbx status x%x\n",
10831 shdr_status, shdr_add_status, rc);
10832 rc = -ENXIO;
10833 }
10834 return rc;
10835}
10836 10760
10837/** 10761/**
10838 * lpfc_sli4_next_xritag - Get an xritag for the io 10762 * lpfc_sli4_next_xritag - Get an xritag for the io
diff --git a/drivers/scsi/lpfc/lpfc_sli4.h b/drivers/scsi/lpfc/lpfc_sli4.h
index a3b24d99a2a7..a0ca572ec28b 100644
--- a/drivers/scsi/lpfc/lpfc_sli4.h
+++ b/drivers/scsi/lpfc/lpfc_sli4.h
@@ -481,7 +481,6 @@ struct lpfc_rpi_hdr {
481 */ 481 */
482int lpfc_pci_function_reset(struct lpfc_hba *); 482int lpfc_pci_function_reset(struct lpfc_hba *);
483int lpfc_sli4_hba_setup(struct lpfc_hba *); 483int lpfc_sli4_hba_setup(struct lpfc_hba *);
484int lpfc_sli4_hba_down(struct lpfc_hba *);
485int lpfc_sli4_config(struct lpfc_hba *, struct lpfcMboxq *, uint8_t, 484int lpfc_sli4_config(struct lpfc_hba *, struct lpfcMboxq *, uint8_t,
486 uint8_t, uint32_t, bool); 485 uint8_t, uint32_t, bool);
487void lpfc_sli4_mbox_cmd_free(struct lpfc_hba *, struct lpfcMboxq *); 486void lpfc_sli4_mbox_cmd_free(struct lpfc_hba *, struct lpfcMboxq *);
@@ -514,7 +513,6 @@ int lpfc_sli4_queue_setup(struct lpfc_hba *);
514void lpfc_sli4_queue_unset(struct lpfc_hba *); 513void lpfc_sli4_queue_unset(struct lpfc_hba *);
515int lpfc_sli4_post_sgl(struct lpfc_hba *, dma_addr_t, dma_addr_t, uint16_t); 514int lpfc_sli4_post_sgl(struct lpfc_hba *, dma_addr_t, dma_addr_t, uint16_t);
516int lpfc_sli4_repost_scsi_sgl_list(struct lpfc_hba *); 515int lpfc_sli4_repost_scsi_sgl_list(struct lpfc_hba *);
517int lpfc_sli4_remove_all_sgl_pages(struct lpfc_hba *);
518uint16_t lpfc_sli4_next_xritag(struct lpfc_hba *); 516uint16_t lpfc_sli4_next_xritag(struct lpfc_hba *);
519int lpfc_sli4_post_async_mbox(struct lpfc_hba *); 517int lpfc_sli4_post_async_mbox(struct lpfc_hba *);
520int lpfc_sli4_post_sgl_list(struct lpfc_hba *phba); 518int lpfc_sli4_post_sgl_list(struct lpfc_hba *phba);