diff options
-rw-r--r-- | drivers/scsi/mpt2sas/mpt2sas_base.h | 2 | ||||
-rw-r--r-- | drivers/scsi/mpt2sas/mpt2sas_scsih.c | 44 | ||||
-rw-r--r-- | drivers/scsi/mpt2sas/mpt2sas_transport.c | 4 |
3 files changed, 17 insertions, 33 deletions
diff --git a/drivers/scsi/mpt2sas/mpt2sas_base.h b/drivers/scsi/mpt2sas/mpt2sas_base.h index 15827582a90e..39dc69627bc7 100644 --- a/drivers/scsi/mpt2sas/mpt2sas_base.h +++ b/drivers/scsi/mpt2sas/mpt2sas_base.h | |||
@@ -798,7 +798,7 @@ int mpt2sas_transport_add_host_phy(struct MPT2SAS_ADAPTER *ioc, struct _sas_phy | |||
798 | *mpt2sas_phy, Mpi2SasPhyPage0_t phy_pg0, struct device *parent_dev); | 798 | *mpt2sas_phy, Mpi2SasPhyPage0_t phy_pg0, struct device *parent_dev); |
799 | int mpt2sas_transport_add_expander_phy(struct MPT2SAS_ADAPTER *ioc, struct _sas_phy | 799 | int mpt2sas_transport_add_expander_phy(struct MPT2SAS_ADAPTER *ioc, struct _sas_phy |
800 | *mpt2sas_phy, Mpi2ExpanderPage1_t expander_pg1, struct device *parent_dev); | 800 | *mpt2sas_phy, Mpi2ExpanderPage1_t expander_pg1, struct device *parent_dev); |
801 | void mpt2sas_transport_update_phy_link_change(struct MPT2SAS_ADAPTER *ioc, u16 handle, | 801 | void mpt2sas_transport_update_links(struct MPT2SAS_ADAPTER *ioc, u16 handle, |
802 | u16 attached_handle, u8 phy_number, u8 link_rate); | 802 | u16 attached_handle, u8 phy_number, u8 link_rate); |
803 | extern struct sas_function_template mpt2sas_transport_functions; | 803 | extern struct sas_function_template mpt2sas_transport_functions; |
804 | extern struct scsi_transport_template *mpt2sas_transport_template; | 804 | extern struct scsi_transport_template *mpt2sas_transport_template; |
diff --git a/drivers/scsi/mpt2sas/mpt2sas_scsih.c b/drivers/scsi/mpt2sas/mpt2sas_scsih.c index 195f5e5aabf1..c0d5d5e1f9c8 100644 --- a/drivers/scsi/mpt2sas/mpt2sas_scsih.c +++ b/drivers/scsi/mpt2sas/mpt2sas_scsih.c | |||
@@ -3124,25 +3124,6 @@ _scsih_io_done(struct MPT2SAS_ADAPTER *ioc, u16 smid, u8 VF_ID, u32 reply) | |||
3124 | } | 3124 | } |
3125 | 3125 | ||
3126 | /** | 3126 | /** |
3127 | * _scsih_link_change - process phy link changes | ||
3128 | * @ioc: per adapter object | ||
3129 | * @handle: phy handle | ||
3130 | * @attached_handle: valid for devices attached to link | ||
3131 | * @phy_number: phy number | ||
3132 | * @link_rate: new link rate | ||
3133 | * Context: user. | ||
3134 | * | ||
3135 | * Return nothing. | ||
3136 | */ | ||
3137 | static void | ||
3138 | _scsih_link_change(struct MPT2SAS_ADAPTER *ioc, u16 handle, u16 attached_handle, | ||
3139 | u8 phy_number, u8 link_rate) | ||
3140 | { | ||
3141 | mpt2sas_transport_update_phy_link_change(ioc, handle, attached_handle, | ||
3142 | phy_number, link_rate); | ||
3143 | } | ||
3144 | |||
3145 | /** | ||
3146 | * _scsih_sas_host_refresh - refreshing sas host object contents | 3127 | * _scsih_sas_host_refresh - refreshing sas host object contents |
3147 | * @ioc: per adapter object | 3128 | * @ioc: per adapter object |
3148 | * @update: update link information | 3129 | * @update: update link information |
@@ -3186,7 +3167,8 @@ _scsih_sas_host_refresh(struct MPT2SAS_ADAPTER *ioc, u8 update) | |||
3186 | le16_to_cpu(sas_iounit_pg0->PhyData[i]. | 3167 | le16_to_cpu(sas_iounit_pg0->PhyData[i]. |
3187 | ControllerDevHandle); | 3168 | ControllerDevHandle); |
3188 | if (update) | 3169 | if (update) |
3189 | _scsih_link_change(ioc, | 3170 | mpt2sas_transport_update_links( |
3171 | ioc, | ||
3190 | ioc->sas_hba.phy[i].handle, | 3172 | ioc->sas_hba.phy[i].handle, |
3191 | le16_to_cpu(sas_iounit_pg0->PhyData[i]. | 3173 | le16_to_cpu(sas_iounit_pg0->PhyData[i]. |
3192 | AttachedDevHandle), i, | 3174 | AttachedDevHandle), i, |
@@ -3868,9 +3850,10 @@ _scsih_sas_topology_change_event(struct MPT2SAS_ADAPTER *ioc, u8 VF_ID, | |||
3868 | case MPI2_EVENT_SAS_TOPO_RC_TARG_ADDED: | 3850 | case MPI2_EVENT_SAS_TOPO_RC_TARG_ADDED: |
3869 | if (!parent_handle) { | 3851 | if (!parent_handle) { |
3870 | if (phy_number < ioc->sas_hba.num_phys) | 3852 | if (phy_number < ioc->sas_hba.num_phys) |
3871 | _scsih_link_change(ioc, | 3853 | mpt2sas_transport_update_links( |
3872 | ioc->sas_hba.phy[phy_number].handle, | 3854 | ioc, |
3873 | handle, phy_number, link_rate_); | 3855 | ioc->sas_hba.phy[phy_number].handle, |
3856 | handle, phy_number, link_rate_); | ||
3874 | } else { | 3857 | } else { |
3875 | spin_lock_irqsave(&ioc->sas_node_lock, flags); | 3858 | spin_lock_irqsave(&ioc->sas_node_lock, flags); |
3876 | sas_expander = | 3859 | sas_expander = |
@@ -3880,11 +3863,12 @@ _scsih_sas_topology_change_event(struct MPT2SAS_ADAPTER *ioc, u8 VF_ID, | |||
3880 | flags); | 3863 | flags); |
3881 | if (sas_expander) { | 3864 | if (sas_expander) { |
3882 | if (phy_number < sas_expander->num_phys) | 3865 | if (phy_number < sas_expander->num_phys) |
3883 | _scsih_link_change(ioc, | 3866 | mpt2sas_transport_update_links( |
3884 | sas_expander-> | 3867 | ioc, |
3885 | phy[phy_number].handle, | 3868 | sas_expander-> |
3886 | handle, phy_number, | 3869 | phy[phy_number].handle, |
3887 | link_rate_); | 3870 | handle, phy_number, |
3871 | link_rate_); | ||
3888 | } | 3872 | } |
3889 | } | 3873 | } |
3890 | if (reason_code == MPI2_EVENT_SAS_TOPO_RC_PHY_CHANGED) { | 3874 | if (reason_code == MPI2_EVENT_SAS_TOPO_RC_PHY_CHANGED) { |
@@ -4400,7 +4384,7 @@ _scsih_sas_pd_add(struct MPT2SAS_ADAPTER *ioc, | |||
4400 | return; | 4384 | return; |
4401 | } | 4385 | } |
4402 | 4386 | ||
4403 | _scsih_link_change(ioc, | 4387 | mpt2sas_transport_update_links(ioc, |
4404 | le16_to_cpu(sas_device_pg0.ParentDevHandle), | 4388 | le16_to_cpu(sas_device_pg0.ParentDevHandle), |
4405 | handle, sas_device_pg0.PhyNum, MPI2_SAS_NEG_LINK_RATE_1_5); | 4389 | handle, sas_device_pg0.PhyNum, MPI2_SAS_NEG_LINK_RATE_1_5); |
4406 | 4390 | ||
@@ -4689,7 +4673,7 @@ _scsih_sas_ir_physical_disk_event(struct MPT2SAS_ADAPTER *ioc, u8 VF_ID, | |||
4689 | return; | 4673 | return; |
4690 | } | 4674 | } |
4691 | 4675 | ||
4692 | _scsih_link_change(ioc, | 4676 | mpt2sas_transport_update_links(ioc, |
4693 | le16_to_cpu(sas_device_pg0.ParentDevHandle), | 4677 | le16_to_cpu(sas_device_pg0.ParentDevHandle), |
4694 | handle, sas_device_pg0.PhyNum, MPI2_SAS_NEG_LINK_RATE_1_5); | 4678 | handle, sas_device_pg0.PhyNum, MPI2_SAS_NEG_LINK_RATE_1_5); |
4695 | 4679 | ||
diff --git a/drivers/scsi/mpt2sas/mpt2sas_transport.c b/drivers/scsi/mpt2sas/mpt2sas_transport.c index a53086d0381a..742324a0a11e 100644 --- a/drivers/scsi/mpt2sas/mpt2sas_transport.c +++ b/drivers/scsi/mpt2sas/mpt2sas_transport.c | |||
@@ -792,7 +792,7 @@ mpt2sas_transport_add_expander_phy(struct MPT2SAS_ADAPTER *ioc, struct _sas_phy | |||
792 | } | 792 | } |
793 | 793 | ||
794 | /** | 794 | /** |
795 | * mpt2sas_transport_update_phy_link_change - refreshing phy link changes and attached devices | 795 | * mpt2sas_transport_update_links - refreshing phy link changes |
796 | * @ioc: per adapter object | 796 | * @ioc: per adapter object |
797 | * @handle: handle to sas_host or expander | 797 | * @handle: handle to sas_host or expander |
798 | * @attached_handle: attached device handle | 798 | * @attached_handle: attached device handle |
@@ -802,7 +802,7 @@ mpt2sas_transport_add_expander_phy(struct MPT2SAS_ADAPTER *ioc, struct _sas_phy | |||
802 | * Returns nothing. | 802 | * Returns nothing. |
803 | */ | 803 | */ |
804 | void | 804 | void |
805 | mpt2sas_transport_update_phy_link_change(struct MPT2SAS_ADAPTER *ioc, | 805 | mpt2sas_transport_update_links(struct MPT2SAS_ADAPTER *ioc, |
806 | u16 handle, u16 attached_handle, u8 phy_number, u8 link_rate) | 806 | u16 handle, u16 attached_handle, u8 phy_number, u8 link_rate) |
807 | { | 807 | { |
808 | unsigned long flags; | 808 | unsigned long flags; |