diff options
author | James Smart <james.smart@emulex.com> | 2010-06-08 18:31:21 -0400 |
---|---|---|
committer | James Bottomley <James.Bottomley@suse.de> | 2010-07-27 13:01:35 -0400 |
commit | 75baf69657ea2107f2c202cd29dada206ae4b7c4 (patch) | |
tree | 76f48393730c19e0a0286ceaa5132d8e500f127f /drivers/scsi/lpfc/lpfc_attr.c | |
parent | c20c426732a5a5d21e99b36286f79c2024115341 (diff) |
[SCSI] lpfc 8.3.14: PCI fixes and enhancements
- Allow enabling MSI-X intterupts with fewer vectors than requested
by looking at the return value from pci_enable_msix.
- Implemented driver PCI AER error handling routines for supporting
AER error recovering on SLI4 devices.
- Remove redundant SLI_ACTIVE checks
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>
Diffstat (limited to 'drivers/scsi/lpfc/lpfc_attr.c')
-rw-r--r-- | drivers/scsi/lpfc/lpfc_attr.c | 22 |
1 files changed, 3 insertions, 19 deletions
diff --git a/drivers/scsi/lpfc/lpfc_attr.c b/drivers/scsi/lpfc/lpfc_attr.c index 39b0760c438d..a7c6b7390554 100644 --- a/drivers/scsi/lpfc/lpfc_attr.c +++ b/drivers/scsi/lpfc/lpfc_attr.c | |||
@@ -864,7 +864,6 @@ lpfc_get_hba_info(struct lpfc_hba *phba, | |||
864 | uint32_t *mrpi, uint32_t *arpi, | 864 | uint32_t *mrpi, uint32_t *arpi, |
865 | uint32_t *mvpi, uint32_t *avpi) | 865 | uint32_t *mvpi, uint32_t *avpi) |
866 | { | 866 | { |
867 | struct lpfc_sli *psli = &phba->sli; | ||
868 | struct lpfc_mbx_read_config *rd_config; | 867 | struct lpfc_mbx_read_config *rd_config; |
869 | LPFC_MBOXQ_t *pmboxq; | 868 | LPFC_MBOXQ_t *pmboxq; |
870 | MAILBOX_t *pmb; | 869 | MAILBOX_t *pmb; |
@@ -893,8 +892,7 @@ lpfc_get_hba_info(struct lpfc_hba *phba, | |||
893 | pmb->mbxOwner = OWN_HOST; | 892 | pmb->mbxOwner = OWN_HOST; |
894 | pmboxq->context1 = NULL; | 893 | pmboxq->context1 = NULL; |
895 | 894 | ||
896 | if ((phba->pport->fc_flag & FC_OFFLINE_MODE) || | 895 | if (phba->pport->fc_flag & FC_OFFLINE_MODE) |
897 | (!(psli->sli_flag & LPFC_SLI_ACTIVE))) | ||
898 | rc = MBX_NOT_FINISHED; | 896 | rc = MBX_NOT_FINISHED; |
899 | else | 897 | else |
900 | rc = lpfc_sli_issue_mbox_wait(phba, pmboxq, phba->fc_ratov * 2); | 898 | rc = lpfc_sli_issue_mbox_wait(phba, pmboxq, phba->fc_ratov * 2); |
@@ -2943,9 +2941,6 @@ lpfc_aer_support_store(struct device *dev, struct device_attribute *attr, | |||
2943 | struct lpfc_hba *phba = vport->phba; | 2941 | struct lpfc_hba *phba = vport->phba; |
2944 | int val = 0, rc = -EINVAL; | 2942 | int val = 0, rc = -EINVAL; |
2945 | 2943 | ||
2946 | /* AER not supported on OC devices yet */ | ||
2947 | if (phba->pci_dev_grp == LPFC_PCI_DEV_OC) | ||
2948 | return -EPERM; | ||
2949 | if (!isdigit(buf[0])) | 2944 | if (!isdigit(buf[0])) |
2950 | return -EINVAL; | 2945 | return -EINVAL; |
2951 | if (sscanf(buf, "%i", &val) != 1) | 2946 | if (sscanf(buf, "%i", &val) != 1) |
@@ -3018,12 +3013,6 @@ lpfc_param_show(aer_support) | |||
3018 | static int | 3013 | static int |
3019 | lpfc_aer_support_init(struct lpfc_hba *phba, int val) | 3014 | lpfc_aer_support_init(struct lpfc_hba *phba, int val) |
3020 | { | 3015 | { |
3021 | /* AER not supported on OC devices yet */ | ||
3022 | if (phba->pci_dev_grp == LPFC_PCI_DEV_OC) { | ||
3023 | phba->cfg_aer_support = 0; | ||
3024 | return -EPERM; | ||
3025 | } | ||
3026 | |||
3027 | if (val == 0 || val == 1) { | 3016 | if (val == 0 || val == 1) { |
3028 | phba->cfg_aer_support = val; | 3017 | phba->cfg_aer_support = val; |
3029 | return 0; | 3018 | return 0; |
@@ -3068,9 +3057,6 @@ lpfc_aer_cleanup_state(struct device *dev, struct device_attribute *attr, | |||
3068 | struct lpfc_hba *phba = vport->phba; | 3057 | struct lpfc_hba *phba = vport->phba; |
3069 | int val, rc = -1; | 3058 | int val, rc = -1; |
3070 | 3059 | ||
3071 | /* AER not supported on OC devices yet */ | ||
3072 | if (phba->pci_dev_grp == LPFC_PCI_DEV_OC) | ||
3073 | return -EPERM; | ||
3074 | if (!isdigit(buf[0])) | 3060 | if (!isdigit(buf[0])) |
3075 | return -EINVAL; | 3061 | return -EINVAL; |
3076 | if (sscanf(buf, "%i", &val) != 1) | 3062 | if (sscanf(buf, "%i", &val) != 1) |
@@ -4099,8 +4085,7 @@ lpfc_get_stats(struct Scsi_Host *shost) | |||
4099 | pmboxq->context1 = NULL; | 4085 | pmboxq->context1 = NULL; |
4100 | pmboxq->vport = vport; | 4086 | pmboxq->vport = vport; |
4101 | 4087 | ||
4102 | if ((vport->fc_flag & FC_OFFLINE_MODE) || | 4088 | if (vport->fc_flag & FC_OFFLINE_MODE) |
4103 | (!(psli->sli_flag & LPFC_SLI_ACTIVE))) | ||
4104 | rc = lpfc_sli_issue_mbox(phba, pmboxq, MBX_POLL); | 4089 | rc = lpfc_sli_issue_mbox(phba, pmboxq, MBX_POLL); |
4105 | else | 4090 | else |
4106 | rc = lpfc_sli_issue_mbox_wait(phba, pmboxq, phba->fc_ratov * 2); | 4091 | rc = lpfc_sli_issue_mbox_wait(phba, pmboxq, phba->fc_ratov * 2); |
@@ -4124,8 +4109,7 @@ lpfc_get_stats(struct Scsi_Host *shost) | |||
4124 | pmboxq->context1 = NULL; | 4109 | pmboxq->context1 = NULL; |
4125 | pmboxq->vport = vport; | 4110 | pmboxq->vport = vport; |
4126 | 4111 | ||
4127 | if ((vport->fc_flag & FC_OFFLINE_MODE) || | 4112 | if (vport->fc_flag & FC_OFFLINE_MODE) |
4128 | (!(psli->sli_flag & LPFC_SLI_ACTIVE))) | ||
4129 | rc = lpfc_sli_issue_mbox(phba, pmboxq, MBX_POLL); | 4113 | rc = lpfc_sli_issue_mbox(phba, pmboxq, MBX_POLL); |
4130 | else | 4114 | else |
4131 | rc = lpfc_sli_issue_mbox_wait(phba, pmboxq, phba->fc_ratov * 2); | 4115 | rc = lpfc_sli_issue_mbox_wait(phba, pmboxq, phba->fc_ratov * 2); |