diff options
Diffstat (limited to 'drivers/scsi/lpfc/lpfc_sli.c')
-rw-r--r-- | drivers/scsi/lpfc/lpfc_sli.c | 69 |
1 files changed, 3 insertions, 66 deletions
diff --git a/drivers/scsi/lpfc/lpfc_sli.c b/drivers/scsi/lpfc/lpfc_sli.c index 41f13a300ba5..744bad627596 100644 --- a/drivers/scsi/lpfc/lpfc_sli.c +++ b/drivers/scsi/lpfc/lpfc_sli.c | |||
@@ -474,8 +474,7 @@ lpfc_sli_resume_iocb(struct lpfc_hba *phba, struct lpfc_sli_ring *pring) | |||
474 | if (pring->txq_cnt && | 474 | if (pring->txq_cnt && |
475 | lpfc_is_link_up(phba) && | 475 | lpfc_is_link_up(phba) && |
476 | (pring->ringno != phba->sli.fcp_ring || | 476 | (pring->ringno != phba->sli.fcp_ring || |
477 | phba->sli.sli_flag & LPFC_PROCESS_LA) && | 477 | phba->sli.sli_flag & LPFC_PROCESS_LA)) { |
478 | !(pring->flag & LPFC_STOP_IOCB_MBX)) { | ||
479 | 478 | ||
480 | while ((iocb = lpfc_sli_next_iocb_slot(phba, pring)) && | 479 | while ((iocb = lpfc_sli_next_iocb_slot(phba, pring)) && |
481 | (nextiocb = lpfc_sli_ringtx_get(phba, pring))) | 480 | (nextiocb = lpfc_sli_ringtx_get(phba, pring))) |
@@ -490,31 +489,6 @@ lpfc_sli_resume_iocb(struct lpfc_hba *phba, struct lpfc_sli_ring *pring) | |||
490 | return; | 489 | return; |
491 | } | 490 | } |
492 | 491 | ||
493 | /* lpfc_sli_turn_on_ring is only called by lpfc_sli_handle_mb_event below */ | ||
494 | static void | ||
495 | lpfc_sli_turn_on_ring(struct lpfc_hba *phba, int ringno) | ||
496 | { | ||
497 | struct lpfc_pgp *pgp = (phba->sli_rev == 3) ? | ||
498 | &phba->slim2p->mbx.us.s3_pgp.port[ringno] : | ||
499 | &phba->slim2p->mbx.us.s2.port[ringno]; | ||
500 | unsigned long iflags; | ||
501 | |||
502 | /* If the ring is active, flag it */ | ||
503 | spin_lock_irqsave(&phba->hbalock, iflags); | ||
504 | if (phba->sli.ring[ringno].cmdringaddr) { | ||
505 | if (phba->sli.ring[ringno].flag & LPFC_STOP_IOCB_MBX) { | ||
506 | phba->sli.ring[ringno].flag &= ~LPFC_STOP_IOCB_MBX; | ||
507 | /* | ||
508 | * Force update of the local copy of cmdGetInx | ||
509 | */ | ||
510 | phba->sli.ring[ringno].local_getidx | ||
511 | = le32_to_cpu(pgp->cmdGetInx); | ||
512 | lpfc_sli_resume_iocb(phba, &phba->sli.ring[ringno]); | ||
513 | } | ||
514 | } | ||
515 | spin_unlock_irqrestore(&phba->hbalock, iflags); | ||
516 | } | ||
517 | |||
518 | struct lpfc_hbq_entry * | 492 | struct lpfc_hbq_entry * |
519 | lpfc_sli_next_hbq_slot(struct lpfc_hba *phba, uint32_t hbqno) | 493 | lpfc_sli_next_hbq_slot(struct lpfc_hba *phba, uint32_t hbqno) |
520 | { | 494 | { |
@@ -2590,21 +2564,6 @@ lpfc_sli_issue_mbox(struct lpfc_hba *phba, LPFC_MBOXQ_t *pmbox, uint32_t flag) | |||
2590 | return MBX_NOT_FINISHED; | 2564 | return MBX_NOT_FINISHED; |
2591 | } | 2565 | } |
2592 | 2566 | ||
2593 | /* Handle STOP IOCB processing flag. This is only meaningful | ||
2594 | * if we are not polling for mbox completion. | ||
2595 | */ | ||
2596 | if (flag & MBX_STOP_IOCB) { | ||
2597 | flag &= ~MBX_STOP_IOCB; | ||
2598 | /* Now flag each ring */ | ||
2599 | for (i = 0; i < psli->num_rings; i++) { | ||
2600 | /* If the ring is active, flag it */ | ||
2601 | if (psli->ring[i].cmdringaddr) { | ||
2602 | psli->ring[i].flag |= | ||
2603 | LPFC_STOP_IOCB_MBX; | ||
2604 | } | ||
2605 | } | ||
2606 | } | ||
2607 | |||
2608 | /* Another mailbox command is still being processed, queue this | 2567 | /* Another mailbox command is still being processed, queue this |
2609 | * command to be processed later. | 2568 | * command to be processed later. |
2610 | */ | 2569 | */ |
@@ -2639,23 +2598,6 @@ lpfc_sli_issue_mbox(struct lpfc_hba *phba, LPFC_MBOXQ_t *pmbox, uint32_t flag) | |||
2639 | return MBX_BUSY; | 2598 | return MBX_BUSY; |
2640 | } | 2599 | } |
2641 | 2600 | ||
2642 | /* Handle STOP IOCB processing flag. This is only meaningful | ||
2643 | * if we are not polling for mbox completion. | ||
2644 | */ | ||
2645 | if (flag & MBX_STOP_IOCB) { | ||
2646 | flag &= ~MBX_STOP_IOCB; | ||
2647 | if (flag == MBX_NOWAIT) { | ||
2648 | /* Now flag each ring */ | ||
2649 | for (i = 0; i < psli->num_rings; i++) { | ||
2650 | /* If the ring is active, flag it */ | ||
2651 | if (psli->ring[i].cmdringaddr) { | ||
2652 | psli->ring[i].flag |= | ||
2653 | LPFC_STOP_IOCB_MBX; | ||
2654 | } | ||
2655 | } | ||
2656 | } | ||
2657 | } | ||
2658 | |||
2659 | psli->sli_flag |= LPFC_SLI_MBOX_ACTIVE; | 2601 | psli->sli_flag |= LPFC_SLI_MBOX_ACTIVE; |
2660 | 2602 | ||
2661 | /* If we are not polling, we MUST be in SLI2 mode */ | 2603 | /* If we are not polling, we MUST be in SLI2 mode */ |
@@ -2898,9 +2840,9 @@ __lpfc_sli_issue_iocb(struct lpfc_hba *phba, struct lpfc_sli_ring *pring, | |||
2898 | 2840 | ||
2899 | /* | 2841 | /* |
2900 | * Check to see if we are blocking IOCB processing because of a | 2842 | * Check to see if we are blocking IOCB processing because of a |
2901 | * outstanding mbox command. | 2843 | * outstanding event. |
2902 | */ | 2844 | */ |
2903 | if (unlikely(pring->flag & LPFC_STOP_IOCB_MBX)) | 2845 | if (unlikely(pring->flag & LPFC_STOP_IOCB_EVENT)) |
2904 | goto iocb_busy; | 2846 | goto iocb_busy; |
2905 | 2847 | ||
2906 | if (unlikely(phba->link_state == LPFC_LINK_DOWN)) { | 2848 | if (unlikely(phba->link_state == LPFC_LINK_DOWN)) { |
@@ -3847,7 +3789,6 @@ lpfc_intr_handler(int irq, void *dev_id) | |||
3847 | uint32_t ha_copy; | 3789 | uint32_t ha_copy; |
3848 | uint32_t work_ha_copy; | 3790 | uint32_t work_ha_copy; |
3849 | unsigned long status; | 3791 | unsigned long status; |
3850 | int i; | ||
3851 | uint32_t control; | 3792 | uint32_t control; |
3852 | 3793 | ||
3853 | MAILBOX_t *mbox, *pmbox; | 3794 | MAILBOX_t *mbox, *pmbox; |
@@ -4066,10 +4007,6 @@ send_current_mbox: | |||
4066 | lpfc_mbox_cmpl_put(phba, pmb); | 4007 | lpfc_mbox_cmpl_put(phba, pmb); |
4067 | goto send_next_mbox; | 4008 | goto send_next_mbox; |
4068 | } | 4009 | } |
4069 | } else { | ||
4070 | /* Turn on IOCB processing */ | ||
4071 | for (i = 0; i < phba->sli.num_rings; i++) | ||
4072 | lpfc_sli_turn_on_ring(phba, i); | ||
4073 | } | 4010 | } |
4074 | 4011 | ||
4075 | } | 4012 | } |