2 * linux/drivers/message/fusion/mptsas.c
3 * For use with LSI PCI chip/adapter(s)
4 * running LSI Fusion MPT (Message Passing Technology) firmware.
6 * Copyright (c) 1999-2008 LSI Corporation
7 * (mailto:DL-MPTFusionLinux@lsi.com)
9 /*=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=*/
11 This program is free software; you can redistribute it and/or modify
12 it under the terms of the GNU General Public License as published by
13 the Free Software Foundation; version 2 of the License.
15 This program is distributed in the hope that it will be useful,
16 but WITHOUT ANY WARRANTY; without even the implied warranty of
17 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 GNU General Public License for more details.
21 THE PROGRAM IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OR
22 CONDITIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED INCLUDING, WITHOUT
23 LIMITATION, ANY WARRANTIES OR CONDITIONS OF TITLE, NON-INFRINGEMENT,
24 MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Each Recipient is
25 solely responsible for determining the appropriateness of using and
26 distributing the Program and assumes all risks associated with its
27 exercise of rights under this Agreement, including but not limited to
28 the risks and costs of program errors, damage to or loss of data,
29 programs or equipment, and unavailability or interruption of operations.
31 DISCLAIMER OF LIABILITY
32 NEITHER RECIPIENT NOR ANY CONTRIBUTORS SHALL HAVE ANY LIABILITY FOR ANY
33 DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
34 DAMAGES (INCLUDING WITHOUT LIMITATION LOST PROFITS), HOWEVER CAUSED AND
35 ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
36 TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
37 USE OR DISTRIBUTION OF THE PROGRAM OR THE EXERCISE OF ANY RIGHTS GRANTED
38 HEREUNDER, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGES
40 You should have received a copy of the GNU General Public License
41 along with this program; if not, write to the Free Software
42 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
44 /*=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=*/
46 #include <linux/module.h>
47 #include <linux/kernel.h>
48 #include <linux/slab.h>
49 #include <linux/init.h>
50 #include <linux/errno.h>
51 #include <linux/jiffies.h>
52 #include <linux/workqueue.h>
53 #include <linux/delay.h> /* for mdelay */
55 #include <scsi/scsi.h>
56 #include <scsi/scsi_cmnd.h>
57 #include <scsi/scsi_device.h>
58 #include <scsi/scsi_host.h>
59 #include <scsi/scsi_transport_sas.h>
60 #include <scsi/scsi_transport.h>
61 #include <scsi/scsi_dbg.h>
68 #define my_NAME "Fusion MPT SAS Host driver"
69 #define my_VERSION MPT_LINUX_VERSION_COMMON
70 #define MYNAM "mptsas"
73 * Reserved channel for integrated raid
75 #define MPTSAS_RAID_CHANNEL 1
77 #define SAS_CONFIG_PAGE_TIMEOUT 30
78 MODULE_AUTHOR(MODULEAUTHOR
);
79 MODULE_DESCRIPTION(my_NAME
);
80 MODULE_LICENSE("GPL");
81 MODULE_VERSION(my_VERSION
);
83 static int mpt_pt_clear
;
84 module_param(mpt_pt_clear
, int, 0);
85 MODULE_PARM_DESC(mpt_pt_clear
,
86 " Clear persistency table: enable=1 "
87 "(default=MPTSCSIH_PT_CLEAR=0)");
89 /* scsi-mid layer global parmeter is max_report_luns, which is 511 */
90 #define MPTSAS_MAX_LUN (16895)
91 static int max_lun
= MPTSAS_MAX_LUN
;
92 module_param(max_lun
, int, 0);
93 MODULE_PARM_DESC(max_lun
, " max lun, default=16895 ");
95 static int mpt_loadtime_max_sectors
= 8192;
96 module_param(mpt_loadtime_max_sectors
, int, 0);
97 MODULE_PARM_DESC(mpt_loadtime_max_sectors
,
98 " Maximum sector define for Host Bus Adaptor.Range 64 to 8192 default=8192");
100 static u8 mptsasDoneCtx
= MPT_MAX_PROTOCOL_DRIVERS
;
101 static u8 mptsasTaskCtx
= MPT_MAX_PROTOCOL_DRIVERS
;
102 static u8 mptsasInternalCtx
= MPT_MAX_PROTOCOL_DRIVERS
; /* Used only for internal commands */
103 static u8 mptsasMgmtCtx
= MPT_MAX_PROTOCOL_DRIVERS
;
104 static u8 mptsasDeviceResetCtx
= MPT_MAX_PROTOCOL_DRIVERS
;
106 static void mptsas_firmware_event_work(struct work_struct
*work
);
107 static void mptsas_send_sas_event(struct fw_event_work
*fw_event
);
108 static void mptsas_send_raid_event(struct fw_event_work
*fw_event
);
109 static void mptsas_send_ir2_event(struct fw_event_work
*fw_event
);
110 static void mptsas_parse_device_info(struct sas_identify
*identify
,
111 struct mptsas_devinfo
*device_info
);
112 static inline void mptsas_set_rphy(MPT_ADAPTER
*ioc
,
113 struct mptsas_phyinfo
*phy_info
, struct sas_rphy
*rphy
);
114 static struct mptsas_phyinfo
*mptsas_find_phyinfo_by_sas_address
115 (MPT_ADAPTER
*ioc
, u64 sas_address
);
116 static int mptsas_sas_device_pg0(MPT_ADAPTER
*ioc
,
117 struct mptsas_devinfo
*device_info
, u32 form
, u32 form_specific
);
118 static int mptsas_sas_enclosure_pg0(MPT_ADAPTER
*ioc
,
119 struct mptsas_enclosure
*enclosure
, u32 form
, u32 form_specific
);
120 static int mptsas_add_end_device(MPT_ADAPTER
*ioc
,
121 struct mptsas_phyinfo
*phy_info
);
122 static void mptsas_del_end_device(MPT_ADAPTER
*ioc
,
123 struct mptsas_phyinfo
*phy_info
);
124 static void mptsas_send_link_status_event(struct fw_event_work
*fw_event
);
125 static struct mptsas_portinfo
*mptsas_find_portinfo_by_sas_address
126 (MPT_ADAPTER
*ioc
, u64 sas_address
);
127 static void mptsas_expander_delete(MPT_ADAPTER
*ioc
,
128 struct mptsas_portinfo
*port_info
, u8 force
);
129 static void mptsas_send_expander_event(struct fw_event_work
*fw_event
);
130 static void mptsas_not_responding_devices(MPT_ADAPTER
*ioc
);
131 static void mptsas_scan_sas_topology(MPT_ADAPTER
*ioc
);
132 static void mptsas_broadcast_primative_work(struct fw_event_work
*fw_event
);
133 static void mptsas_handle_queue_full_event(struct fw_event_work
*fw_event
);
134 static void mptsas_volume_delete(MPT_ADAPTER
*ioc
, u8 id
);
135 void mptsas_schedule_target_reset(void *ioc
);
137 static void mptsas_print_phy_data(MPT_ADAPTER
*ioc
,
138 MPI_SAS_IO_UNIT0_PHY_DATA
*phy_data
)
140 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
141 "---- IO UNIT PAGE 0 ------------\n", ioc
->name
));
142 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"Handle=0x%X\n",
143 ioc
->name
, le16_to_cpu(phy_data
->AttachedDeviceHandle
)));
144 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"Controller Handle=0x%X\n",
145 ioc
->name
, le16_to_cpu(phy_data
->ControllerDevHandle
)));
146 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"Port=0x%X\n",
147 ioc
->name
, phy_data
->Port
));
148 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"Port Flags=0x%X\n",
149 ioc
->name
, phy_data
->PortFlags
));
150 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"PHY Flags=0x%X\n",
151 ioc
->name
, phy_data
->PhyFlags
));
152 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"Negotiated Link Rate=0x%X\n",
153 ioc
->name
, phy_data
->NegotiatedLinkRate
));
154 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
155 "Controller PHY Device Info=0x%X\n", ioc
->name
,
156 le32_to_cpu(phy_data
->ControllerPhyDeviceInfo
)));
157 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"DiscoveryStatus=0x%X\n\n",
158 ioc
->name
, le32_to_cpu(phy_data
->DiscoveryStatus
)));
161 static void mptsas_print_phy_pg0(MPT_ADAPTER
*ioc
, SasPhyPage0_t
*pg0
)
165 memcpy(&sas_address
, &pg0
->SASAddress
, sizeof(__le64
));
167 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
168 "---- SAS PHY PAGE 0 ------------\n", ioc
->name
));
169 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
170 "Attached Device Handle=0x%X\n", ioc
->name
,
171 le16_to_cpu(pg0
->AttachedDevHandle
)));
172 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"SAS Address=0x%llX\n",
173 ioc
->name
, (unsigned long long)le64_to_cpu(sas_address
)));
174 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
175 "Attached PHY Identifier=0x%X\n", ioc
->name
,
176 pg0
->AttachedPhyIdentifier
));
177 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"Attached Device Info=0x%X\n",
178 ioc
->name
, le32_to_cpu(pg0
->AttachedDeviceInfo
)));
179 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"Programmed Link Rate=0x%X\n",
180 ioc
->name
, pg0
->ProgrammedLinkRate
));
181 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"Change Count=0x%X\n",
182 ioc
->name
, pg0
->ChangeCount
));
183 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"PHY Info=0x%X\n\n",
184 ioc
->name
, le32_to_cpu(pg0
->PhyInfo
)));
187 static void mptsas_print_phy_pg1(MPT_ADAPTER
*ioc
, SasPhyPage1_t
*pg1
)
189 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
190 "---- SAS PHY PAGE 1 ------------\n", ioc
->name
));
191 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"Invalid Dword Count=0x%x\n",
192 ioc
->name
, pg1
->InvalidDwordCount
));
193 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
194 "Running Disparity Error Count=0x%x\n", ioc
->name
,
195 pg1
->RunningDisparityErrorCount
));
196 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
197 "Loss Dword Synch Count=0x%x\n", ioc
->name
,
198 pg1
->LossDwordSynchCount
));
199 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
200 "PHY Reset Problem Count=0x%x\n\n", ioc
->name
,
201 pg1
->PhyResetProblemCount
));
204 static void mptsas_print_device_pg0(MPT_ADAPTER
*ioc
, SasDevicePage0_t
*pg0
)
208 memcpy(&sas_address
, &pg0
->SASAddress
, sizeof(__le64
));
210 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
211 "---- SAS DEVICE PAGE 0 ---------\n", ioc
->name
));
212 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"Handle=0x%X\n",
213 ioc
->name
, le16_to_cpu(pg0
->DevHandle
)));
214 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"Parent Handle=0x%X\n",
215 ioc
->name
, le16_to_cpu(pg0
->ParentDevHandle
)));
216 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"Enclosure Handle=0x%X\n",
217 ioc
->name
, le16_to_cpu(pg0
->EnclosureHandle
)));
218 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"Slot=0x%X\n",
219 ioc
->name
, le16_to_cpu(pg0
->Slot
)));
220 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"SAS Address=0x%llX\n",
221 ioc
->name
, (unsigned long long)le64_to_cpu(sas_address
)));
222 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"Target ID=0x%X\n",
223 ioc
->name
, pg0
->TargetID
));
224 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"Bus=0x%X\n",
225 ioc
->name
, pg0
->Bus
));
226 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"Parent Phy Num=0x%X\n",
227 ioc
->name
, pg0
->PhyNum
));
228 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"Access Status=0x%X\n",
229 ioc
->name
, le16_to_cpu(pg0
->AccessStatus
)));
230 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"Device Info=0x%X\n",
231 ioc
->name
, le32_to_cpu(pg0
->DeviceInfo
)));
232 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"Flags=0x%X\n",
233 ioc
->name
, le16_to_cpu(pg0
->Flags
)));
234 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"Physical Port=0x%X\n\n",
235 ioc
->name
, pg0
->PhysicalPort
));
238 static void mptsas_print_expander_pg1(MPT_ADAPTER
*ioc
, SasExpanderPage1_t
*pg1
)
240 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
241 "---- SAS EXPANDER PAGE 1 ------------\n", ioc
->name
));
242 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"Physical Port=0x%X\n",
243 ioc
->name
, pg1
->PhysicalPort
));
244 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"PHY Identifier=0x%X\n",
245 ioc
->name
, pg1
->PhyIdentifier
));
246 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"Negotiated Link Rate=0x%X\n",
247 ioc
->name
, pg1
->NegotiatedLinkRate
));
248 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"Programmed Link Rate=0x%X\n",
249 ioc
->name
, pg1
->ProgrammedLinkRate
));
250 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"Hardware Link Rate=0x%X\n",
251 ioc
->name
, pg1
->HwLinkRate
));
252 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"Owner Device Handle=0x%X\n",
253 ioc
->name
, le16_to_cpu(pg1
->OwnerDevHandle
)));
254 dsasprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
255 "Attached Device Handle=0x%X\n\n", ioc
->name
,
256 le16_to_cpu(pg1
->AttachedDevHandle
)));
259 /* inhibit sas firmware event handling */
261 mptsas_fw_event_off(MPT_ADAPTER
*ioc
)
265 spin_lock_irqsave(&ioc
->fw_event_lock
, flags
);
266 ioc
->fw_events_off
= 1;
267 ioc
->sas_discovery_quiesce_io
= 0;
268 spin_unlock_irqrestore(&ioc
->fw_event_lock
, flags
);
272 /* enable sas firmware event handling */
274 mptsas_fw_event_on(MPT_ADAPTER
*ioc
)
278 spin_lock_irqsave(&ioc
->fw_event_lock
, flags
);
279 ioc
->fw_events_off
= 0;
280 spin_unlock_irqrestore(&ioc
->fw_event_lock
, flags
);
283 /* queue a sas firmware event */
285 mptsas_add_fw_event(MPT_ADAPTER
*ioc
, struct fw_event_work
*fw_event
,
290 spin_lock_irqsave(&ioc
->fw_event_lock
, flags
);
291 list_add_tail(&fw_event
->list
, &ioc
->fw_event_list
);
292 INIT_DELAYED_WORK(&fw_event
->work
, mptsas_firmware_event_work
);
293 devtprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"%s: add (fw_event=0x%p)"
294 "on cpuid %d\n", ioc
->name
, __func__
,
295 fw_event
, smp_processor_id()));
296 queue_delayed_work_on(smp_processor_id(), ioc
->fw_event_q
,
297 &fw_event
->work
, delay
);
298 spin_unlock_irqrestore(&ioc
->fw_event_lock
, flags
);
301 /* requeue a sas firmware event */
303 mptsas_requeue_fw_event(MPT_ADAPTER
*ioc
, struct fw_event_work
*fw_event
,
307 spin_lock_irqsave(&ioc
->fw_event_lock
, flags
);
308 devtprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"%s: reschedule task "
309 "(fw_event=0x%p)on cpuid %d\n", ioc
->name
, __func__
,
310 fw_event
, smp_processor_id()));
312 queue_delayed_work_on(smp_processor_id(), ioc
->fw_event_q
,
313 &fw_event
->work
, msecs_to_jiffies(delay
));
314 spin_unlock_irqrestore(&ioc
->fw_event_lock
, flags
);
317 /* free memory associated to a sas firmware event */
319 mptsas_free_fw_event(MPT_ADAPTER
*ioc
, struct fw_event_work
*fw_event
)
323 spin_lock_irqsave(&ioc
->fw_event_lock
, flags
);
324 devtprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"%s: kfree (fw_event=0x%p)\n",
325 ioc
->name
, __func__
, fw_event
));
326 list_del(&fw_event
->list
);
328 spin_unlock_irqrestore(&ioc
->fw_event_lock
, flags
);
331 /* walk the firmware event queue, and either stop or wait for
332 * outstanding events to complete */
334 mptsas_cleanup_fw_event_q(MPT_ADAPTER
*ioc
)
336 struct fw_event_work
*fw_event
, *next
;
337 struct mptsas_target_reset_event
*target_reset_list
, *n
;
338 MPT_SCSI_HOST
*hd
= shost_priv(ioc
->sh
);
340 /* flush the target_reset_list */
341 if (!list_empty(&hd
->target_reset_list
)) {
342 list_for_each_entry_safe(target_reset_list
, n
,
343 &hd
->target_reset_list
, list
) {
344 dtmprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
345 "%s: removing target reset for id=%d\n",
347 target_reset_list
->sas_event_data
.TargetID
));
348 list_del(&target_reset_list
->list
);
349 kfree(target_reset_list
);
353 if (list_empty(&ioc
->fw_event_list
) ||
354 !ioc
->fw_event_q
|| in_interrupt())
357 list_for_each_entry_safe(fw_event
, next
, &ioc
->fw_event_list
, list
) {
358 if (cancel_delayed_work(&fw_event
->work
))
359 mptsas_free_fw_event(ioc
, fw_event
);
364 static inline MPT_ADAPTER
*phy_to_ioc(struct sas_phy
*phy
)
366 struct Scsi_Host
*shost
= dev_to_shost(phy
->dev
.parent
);
367 return ((MPT_SCSI_HOST
*)shost
->hostdata
)->ioc
;
370 static inline MPT_ADAPTER
*rphy_to_ioc(struct sas_rphy
*rphy
)
372 struct Scsi_Host
*shost
= dev_to_shost(rphy
->dev
.parent
->parent
);
373 return ((MPT_SCSI_HOST
*)shost
->hostdata
)->ioc
;
377 * mptsas_find_portinfo_by_handle
379 * This function should be called with the sas_topology_mutex already held
381 static struct mptsas_portinfo
*
382 mptsas_find_portinfo_by_handle(MPT_ADAPTER
*ioc
, u16 handle
)
384 struct mptsas_portinfo
*port_info
, *rc
=NULL
;
387 list_for_each_entry(port_info
, &ioc
->sas_topology
, list
)
388 for (i
= 0; i
< port_info
->num_phys
; i
++)
389 if (port_info
->phy_info
[i
].identify
.handle
== handle
) {
398 * mptsas_find_portinfo_by_sas_address -
399 * @ioc: Pointer to MPT_ADAPTER structure
402 * This function should be called with the sas_topology_mutex already held
405 static struct mptsas_portinfo
*
406 mptsas_find_portinfo_by_sas_address(MPT_ADAPTER
*ioc
, u64 sas_address
)
408 struct mptsas_portinfo
*port_info
, *rc
= NULL
;
411 if (sas_address
>= ioc
->hba_port_sas_addr
&&
412 sas_address
< (ioc
->hba_port_sas_addr
+
413 ioc
->hba_port_num_phy
))
414 return ioc
->hba_port_info
;
416 mutex_lock(&ioc
->sas_topology_mutex
);
417 list_for_each_entry(port_info
, &ioc
->sas_topology
, list
)
418 for (i
= 0; i
< port_info
->num_phys
; i
++)
419 if (port_info
->phy_info
[i
].identify
.sas_address
==
425 mutex_unlock(&ioc
->sas_topology_mutex
);
430 * Returns true if there is a scsi end device
433 mptsas_is_end_device(struct mptsas_devinfo
* attached
)
435 if ((attached
->sas_address
) &&
436 (attached
->device_info
&
437 MPI_SAS_DEVICE_INFO_END_DEVICE
) &&
438 ((attached
->device_info
&
439 MPI_SAS_DEVICE_INFO_SSP_TARGET
) |
440 (attached
->device_info
&
441 MPI_SAS_DEVICE_INFO_STP_TARGET
) |
442 (attached
->device_info
&
443 MPI_SAS_DEVICE_INFO_SATA_DEVICE
)))
451 mptsas_port_delete(MPT_ADAPTER
*ioc
, struct mptsas_portinfo_details
* port_details
)
453 struct mptsas_portinfo
*port_info
;
454 struct mptsas_phyinfo
*phy_info
;
460 port_info
= port_details
->port_info
;
461 phy_info
= port_info
->phy_info
;
463 dsaswideprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"%s: [%p]: num_phys=%02d "
464 "bitmask=0x%016llX\n", ioc
->name
, __func__
, port_details
,
465 port_details
->num_phys
, (unsigned long long)
466 port_details
->phy_bitmask
));
468 for (i
= 0; i
< port_info
->num_phys
; i
++, phy_info
++) {
469 if(phy_info
->port_details
!= port_details
)
471 memset(&phy_info
->attached
, 0, sizeof(struct mptsas_devinfo
));
472 mptsas_set_rphy(ioc
, phy_info
, NULL
);
473 phy_info
->port_details
= NULL
;
478 static inline struct sas_rphy
*
479 mptsas_get_rphy(struct mptsas_phyinfo
*phy_info
)
481 if (phy_info
->port_details
)
482 return phy_info
->port_details
->rphy
;
488 mptsas_set_rphy(MPT_ADAPTER
*ioc
, struct mptsas_phyinfo
*phy_info
, struct sas_rphy
*rphy
)
490 if (phy_info
->port_details
) {
491 phy_info
->port_details
->rphy
= rphy
;
492 dsaswideprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"sas_rphy_add: rphy=%p\n",
497 dsaswideprintk(ioc
, dev_printk(KERN_DEBUG
,
498 &rphy
->dev
, MYIOC_s_FMT
"add:", ioc
->name
));
499 dsaswideprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"rphy=%p release=%p\n",
500 ioc
->name
, rphy
, rphy
->dev
.release
));
504 static inline struct sas_port
*
505 mptsas_get_port(struct mptsas_phyinfo
*phy_info
)
507 if (phy_info
->port_details
)
508 return phy_info
->port_details
->port
;
514 mptsas_set_port(MPT_ADAPTER
*ioc
, struct mptsas_phyinfo
*phy_info
, struct sas_port
*port
)
516 if (phy_info
->port_details
)
517 phy_info
->port_details
->port
= port
;
520 dsaswideprintk(ioc
, dev_printk(KERN_DEBUG
,
521 &port
->dev
, MYIOC_s_FMT
"add:", ioc
->name
));
522 dsaswideprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"port=%p release=%p\n",
523 ioc
->name
, port
, port
->dev
.release
));
527 static inline struct scsi_target
*
528 mptsas_get_starget(struct mptsas_phyinfo
*phy_info
)
530 if (phy_info
->port_details
)
531 return phy_info
->port_details
->starget
;
537 mptsas_set_starget(struct mptsas_phyinfo
*phy_info
, struct scsi_target
*
540 if (phy_info
->port_details
)
541 phy_info
->port_details
->starget
= starget
;
545 * mptsas_add_device_component -
546 * @ioc: Pointer to MPT_ADAPTER structure
547 * @channel: fw mapped id's
554 mptsas_add_device_component(MPT_ADAPTER
*ioc
, u8 channel
, u8 id
,
555 u64 sas_address
, u32 device_info
, u16 slot
, u64 enclosure_logical_id
)
557 struct mptsas_device_info
*sas_info
, *next
;
558 struct scsi_device
*sdev
;
559 struct scsi_target
*starget
;
560 struct sas_rphy
*rphy
;
563 * Delete all matching devices out of the list
565 mutex_lock(&ioc
->sas_device_info_mutex
);
566 list_for_each_entry_safe(sas_info
, next
, &ioc
->sas_device_info_list
,
568 if (!sas_info
->is_logical_volume
&&
569 (sas_info
->sas_address
== sas_address
||
570 (sas_info
->fw
.channel
== channel
&&
571 sas_info
->fw
.id
== id
))) {
572 list_del(&sas_info
->list
);
577 sas_info
= kzalloc(sizeof(struct mptsas_device_info
), GFP_KERNEL
);
582 * Set Firmware mapping
584 sas_info
->fw
.id
= id
;
585 sas_info
->fw
.channel
= channel
;
587 sas_info
->sas_address
= sas_address
;
588 sas_info
->device_info
= device_info
;
589 sas_info
->slot
= slot
;
590 sas_info
->enclosure_logical_id
= enclosure_logical_id
;
591 INIT_LIST_HEAD(&sas_info
->list
);
592 list_add_tail(&sas_info
->list
, &ioc
->sas_device_info_list
);
597 shost_for_each_device(sdev
, ioc
->sh
) {
598 starget
= scsi_target(sdev
);
599 rphy
= dev_to_rphy(starget
->dev
.parent
);
600 if (rphy
->identify
.sas_address
== sas_address
) {
601 sas_info
->os
.id
= starget
->id
;
602 sas_info
->os
.channel
= starget
->channel
;
607 mutex_unlock(&ioc
->sas_device_info_mutex
);
612 * mptsas_add_device_component_by_fw -
613 * @ioc: Pointer to MPT_ADAPTER structure
614 * @channel: fw mapped id's
619 mptsas_add_device_component_by_fw(MPT_ADAPTER
*ioc
, u8 channel
, u8 id
)
621 struct mptsas_devinfo sas_device
;
622 struct mptsas_enclosure enclosure_info
;
625 rc
= mptsas_sas_device_pg0(ioc
, &sas_device
,
626 (MPI_SAS_DEVICE_PGAD_FORM_BUS_TARGET_ID
<<
627 MPI_SAS_DEVICE_PGAD_FORM_SHIFT
),
628 (channel
<< 8) + id
);
632 memset(&enclosure_info
, 0, sizeof(struct mptsas_enclosure
));
633 mptsas_sas_enclosure_pg0(ioc
, &enclosure_info
,
634 (MPI_SAS_ENCLOS_PGAD_FORM_HANDLE
<<
635 MPI_SAS_ENCLOS_PGAD_FORM_SHIFT
),
636 sas_device
.handle_enclosure
);
638 mptsas_add_device_component(ioc
, sas_device
.channel
,
639 sas_device
.id
, sas_device
.sas_address
, sas_device
.device_info
,
640 sas_device
.slot
, enclosure_info
.enclosure_logical_id
);
644 * mptsas_add_device_component_starget_ir - Handle Integrated RAID, adding each individual device to list
645 * @ioc: Pointer to MPT_ADAPTER structure
646 * @channel: fw mapped id's
651 mptsas_add_device_component_starget_ir(MPT_ADAPTER
*ioc
,
652 struct scsi_target
*starget
)
655 ConfigPageHeader_t hdr
;
656 dma_addr_t dma_handle
;
657 pRaidVolumePage0_t buffer
= NULL
;
659 RaidPhysDiskPage0_t phys_disk
;
660 struct mptsas_device_info
*sas_info
, *next
;
662 memset(&cfg
, 0 , sizeof(CONFIGPARMS
));
663 memset(&hdr
, 0 , sizeof(ConfigPageHeader_t
));
664 hdr
.PageType
= MPI_CONFIG_PAGETYPE_RAID_VOLUME
;
665 /* assumption that all volumes on channel = 0 */
666 cfg
.pageAddr
= starget
->id
;
667 cfg
.cfghdr
.hdr
= &hdr
;
668 cfg
.action
= MPI_CONFIG_ACTION_PAGE_HEADER
;
669 cfg
.timeout
= SAS_CONFIG_PAGE_TIMEOUT
;
671 if (mpt_config(ioc
, &cfg
) != 0)
677 buffer
= pci_alloc_consistent(ioc
->pcidev
, hdr
.PageLength
* 4,
683 cfg
.physAddr
= dma_handle
;
684 cfg
.action
= MPI_CONFIG_ACTION_PAGE_READ_CURRENT
;
686 if (mpt_config(ioc
, &cfg
) != 0)
689 if (!buffer
->NumPhysDisks
)
693 * Adding entry for hidden components
695 for (i
= 0; i
< buffer
->NumPhysDisks
; i
++) {
697 if (mpt_raid_phys_disk_pg0(ioc
,
698 buffer
->PhysDisk
[i
].PhysDiskNum
, &phys_disk
) != 0)
701 mptsas_add_device_component_by_fw(ioc
, phys_disk
.PhysDiskBus
,
702 phys_disk
.PhysDiskID
);
704 mutex_lock(&ioc
->sas_device_info_mutex
);
705 list_for_each_entry(sas_info
, &ioc
->sas_device_info_list
,
707 if (!sas_info
->is_logical_volume
&&
708 (sas_info
->fw
.channel
== phys_disk
.PhysDiskBus
&&
709 sas_info
->fw
.id
== phys_disk
.PhysDiskID
)) {
710 sas_info
->is_hidden_raid_component
= 1;
711 sas_info
->volume_id
= starget
->id
;
714 mutex_unlock(&ioc
->sas_device_info_mutex
);
719 * Delete all matching devices out of the list
721 mutex_lock(&ioc
->sas_device_info_mutex
);
722 list_for_each_entry_safe(sas_info
, next
, &ioc
->sas_device_info_list
,
724 if (sas_info
->is_logical_volume
&& sas_info
->fw
.id
==
726 list_del(&sas_info
->list
);
731 sas_info
= kzalloc(sizeof(struct mptsas_device_info
), GFP_KERNEL
);
733 sas_info
->fw
.id
= starget
->id
;
734 sas_info
->os
.id
= starget
->id
;
735 sas_info
->os
.channel
= starget
->channel
;
736 sas_info
->is_logical_volume
= 1;
737 INIT_LIST_HEAD(&sas_info
->list
);
738 list_add_tail(&sas_info
->list
, &ioc
->sas_device_info_list
);
740 mutex_unlock(&ioc
->sas_device_info_mutex
);
744 pci_free_consistent(ioc
->pcidev
, hdr
.PageLength
* 4, buffer
,
749 * mptsas_add_device_component_starget -
750 * @ioc: Pointer to MPT_ADAPTER structure
755 mptsas_add_device_component_starget(MPT_ADAPTER
*ioc
,
756 struct scsi_target
*starget
)
759 struct sas_rphy
*rphy
;
760 struct mptsas_phyinfo
*phy_info
= NULL
;
761 struct mptsas_enclosure enclosure_info
;
763 rphy
= dev_to_rphy(starget
->dev
.parent
);
764 vtarget
= starget
->hostdata
;
765 phy_info
= mptsas_find_phyinfo_by_sas_address(ioc
,
766 rphy
->identify
.sas_address
);
770 memset(&enclosure_info
, 0, sizeof(struct mptsas_enclosure
));
771 mptsas_sas_enclosure_pg0(ioc
, &enclosure_info
,
772 (MPI_SAS_ENCLOS_PGAD_FORM_HANDLE
<<
773 MPI_SAS_ENCLOS_PGAD_FORM_SHIFT
),
774 phy_info
->attached
.handle_enclosure
);
776 mptsas_add_device_component(ioc
, phy_info
->attached
.channel
,
777 phy_info
->attached
.id
, phy_info
->attached
.sas_address
,
778 phy_info
->attached
.device_info
,
779 phy_info
->attached
.slot
, enclosure_info
.enclosure_logical_id
);
783 * mptsas_del_device_component_by_os - Once a device has been removed, we mark the entry in the list as being cached
784 * @ioc: Pointer to MPT_ADAPTER structure
785 * @channel: os mapped id's
790 mptsas_del_device_component_by_os(MPT_ADAPTER
*ioc
, u8 channel
, u8 id
)
792 struct mptsas_device_info
*sas_info
, *next
;
797 list_for_each_entry_safe(sas_info
, next
, &ioc
->sas_device_info_list
,
799 if (sas_info
->os
.channel
== channel
&& sas_info
->os
.id
== id
)
800 sas_info
->is_cached
= 1;
805 * mptsas_del_device_components - Cleaning the list
806 * @ioc: Pointer to MPT_ADAPTER structure
810 mptsas_del_device_components(MPT_ADAPTER
*ioc
)
812 struct mptsas_device_info
*sas_info
, *next
;
814 mutex_lock(&ioc
->sas_device_info_mutex
);
815 list_for_each_entry_safe(sas_info
, next
, &ioc
->sas_device_info_list
,
817 list_del(&sas_info
->list
);
820 mutex_unlock(&ioc
->sas_device_info_mutex
);
825 * mptsas_setup_wide_ports
827 * Updates for new and existing narrow/wide port configuration
828 * in the sas_topology
831 mptsas_setup_wide_ports(MPT_ADAPTER
*ioc
, struct mptsas_portinfo
*port_info
)
833 struct mptsas_portinfo_details
* port_details
;
834 struct mptsas_phyinfo
*phy_info
, *phy_info_cmp
;
838 mutex_lock(&ioc
->sas_topology_mutex
);
840 phy_info
= port_info
->phy_info
;
841 for (i
= 0 ; i
< port_info
->num_phys
; i
++, phy_info
++) {
842 if (phy_info
->attached
.handle
)
844 port_details
= phy_info
->port_details
;
847 if (port_details
->num_phys
< 2)
850 * Removing a phy from a port, letting the last
851 * phy be removed by firmware events.
853 dsaswideprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
854 "%s: [%p]: deleting phy = %d\n",
855 ioc
->name
, __func__
, port_details
, i
));
856 port_details
->num_phys
--;
857 port_details
->phy_bitmask
&= ~ (1 << phy_info
->phy_id
);
858 memset(&phy_info
->attached
, 0, sizeof(struct mptsas_devinfo
));
860 devtprintk(ioc
, dev_printk(KERN_DEBUG
,
861 &phy_info
->phy
->dev
, MYIOC_s_FMT
862 "delete phy %d, phy-obj (0x%p)\n", ioc
->name
,
863 phy_info
->phy_id
, phy_info
->phy
));
864 sas_port_delete_phy(port_details
->port
, phy_info
->phy
);
866 phy_info
->port_details
= NULL
;
870 * Populate and refresh the tree
872 phy_info
= port_info
->phy_info
;
873 for (i
= 0 ; i
< port_info
->num_phys
; i
++, phy_info
++) {
874 sas_address
= phy_info
->attached
.sas_address
;
875 dsaswideprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"phy_id=%d sas_address=0x%018llX\n",
876 ioc
->name
, i
, (unsigned long long)sas_address
));
879 port_details
= phy_info
->port_details
;
884 port_details
= kzalloc(sizeof(struct
885 mptsas_portinfo_details
), GFP_KERNEL
);
888 port_details
->num_phys
= 1;
889 port_details
->port_info
= port_info
;
890 if (phy_info
->phy_id
< 64 )
891 port_details
->phy_bitmask
|=
892 (1 << phy_info
->phy_id
);
893 phy_info
->sas_port_add_phy
=1;
894 dsaswideprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"\t\tForming port\n\t\t"
895 "phy_id=%d sas_address=0x%018llX\n",
896 ioc
->name
, i
, (unsigned long long)sas_address
));
897 phy_info
->port_details
= port_details
;
900 if (i
== port_info
->num_phys
- 1)
902 phy_info_cmp
= &port_info
->phy_info
[i
+ 1];
903 for (j
= i
+ 1 ; j
< port_info
->num_phys
; j
++,
905 if (!phy_info_cmp
->attached
.sas_address
)
907 if (sas_address
!= phy_info_cmp
->attached
.sas_address
)
909 if (phy_info_cmp
->port_details
== port_details
)
911 dsaswideprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
912 "\t\tphy_id=%d sas_address=0x%018llX\n",
913 ioc
->name
, j
, (unsigned long long)
914 phy_info_cmp
->attached
.sas_address
));
915 if (phy_info_cmp
->port_details
) {
917 mptsas_get_rphy(phy_info_cmp
);
919 mptsas_get_port(phy_info_cmp
);
920 port_details
->starget
=
921 mptsas_get_starget(phy_info_cmp
);
922 port_details
->num_phys
=
923 phy_info_cmp
->port_details
->num_phys
;
924 if (!phy_info_cmp
->port_details
->num_phys
)
925 kfree(phy_info_cmp
->port_details
);
927 phy_info_cmp
->sas_port_add_phy
=1;
929 * Adding a phy to a port
931 phy_info_cmp
->port_details
= port_details
;
932 if (phy_info_cmp
->phy_id
< 64 )
933 port_details
->phy_bitmask
|=
934 (1 << phy_info_cmp
->phy_id
);
935 port_details
->num_phys
++;
941 for (i
= 0; i
< port_info
->num_phys
; i
++) {
942 port_details
= port_info
->phy_info
[i
].port_details
;
945 dsaswideprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
946 "%s: [%p]: phy_id=%02d num_phys=%02d "
947 "bitmask=0x%016llX\n", ioc
->name
, __func__
,
948 port_details
, i
, port_details
->num_phys
,
949 (unsigned long long)port_details
->phy_bitmask
));
950 dsaswideprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"\t\tport = %p rphy=%p\n",
951 ioc
->name
, port_details
->port
, port_details
->rphy
));
953 dsaswideprintk(ioc
, printk("\n"));
954 mutex_unlock(&ioc
->sas_topology_mutex
);
958 * csmisas_find_vtarget
966 mptsas_find_vtarget(MPT_ADAPTER
*ioc
, u8 channel
, u8 id
)
968 struct scsi_device
*sdev
;
970 VirtTarget
*vtarget
= NULL
;
972 shost_for_each_device(sdev
, ioc
->sh
) {
973 vdevice
= sdev
->hostdata
;
974 if ((vdevice
== NULL
) ||
975 (vdevice
->vtarget
== NULL
))
977 if ((vdevice
->vtarget
->tflags
&
978 MPT_TARGET_FLAGS_RAID_COMPONENT
||
979 vdevice
->vtarget
->raidVolume
))
981 if (vdevice
->vtarget
->id
== id
&&
982 vdevice
->vtarget
->channel
== channel
)
983 vtarget
= vdevice
->vtarget
;
989 mptsas_queue_device_delete(MPT_ADAPTER
*ioc
,
990 MpiEventDataSasDeviceStatusChange_t
*sas_event_data
)
992 struct fw_event_work
*fw_event
;
994 fw_event
= kzalloc(sizeof(*fw_event
) +
995 sizeof(MpiEventDataSasDeviceStatusChange_t
),
998 printk(MYIOC_s_WARN_FMT
"%s: failed at (line=%d)\n",
999 ioc
->name
, __func__
, __LINE__
);
1002 memcpy(fw_event
->event_data
, sas_event_data
,
1003 sizeof(MpiEventDataSasDeviceStatusChange_t
));
1004 fw_event
->event
= MPI_EVENT_SAS_DEVICE_STATUS_CHANGE
;
1005 fw_event
->ioc
= ioc
;
1006 mptsas_add_fw_event(ioc
, fw_event
, msecs_to_jiffies(1));
1010 mptsas_queue_rescan(MPT_ADAPTER
*ioc
)
1012 struct fw_event_work
*fw_event
;
1014 fw_event
= kzalloc(sizeof(*fw_event
), GFP_ATOMIC
);
1016 printk(MYIOC_s_WARN_FMT
"%s: failed at (line=%d)\n",
1017 ioc
->name
, __func__
, __LINE__
);
1020 fw_event
->event
= -1;
1021 fw_event
->ioc
= ioc
;
1022 mptsas_add_fw_event(ioc
, fw_event
, msecs_to_jiffies(1));
1027 * mptsas_target_reset
1029 * Issues TARGET_RESET to end device using handshaking method
1035 * Returns (1) success
1040 mptsas_target_reset(MPT_ADAPTER
*ioc
, u8 channel
, u8 id
)
1043 SCSITaskMgmt_t
*pScsiTm
;
1044 if (mpt_set_taskmgmt_in_progress_flag(ioc
) != 0)
1048 mf
= mpt_get_msg_frame(mptsasDeviceResetCtx
, ioc
);
1050 dfailprintk(ioc
, printk(MYIOC_s_WARN_FMT
1051 "%s, no msg frames @%d!!\n", ioc
->name
,
1052 __func__
, __LINE__
));
1056 dtmprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"TaskMgmt request (mf=%p)\n",
1059 /* Format the Request
1061 pScsiTm
= (SCSITaskMgmt_t
*) mf
;
1062 memset (pScsiTm
, 0, sizeof(SCSITaskMgmt_t
));
1063 pScsiTm
->TargetID
= id
;
1064 pScsiTm
->Bus
= channel
;
1065 pScsiTm
->Function
= MPI_FUNCTION_SCSI_TASK_MGMT
;
1066 pScsiTm
->TaskType
= MPI_SCSITASKMGMT_TASKTYPE_TARGET_RESET
;
1067 pScsiTm
->MsgFlags
= MPI_SCSITASKMGMT_MSGFLAGS_LIPRESET_RESET_OPTION
;
1069 DBG_DUMP_TM_REQUEST_FRAME(ioc
, (u32
*)mf
);
1071 dtmprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
1072 "TaskMgmt type=%d (sas device delete) fw_channel = %d fw_id = %d)\n",
1073 ioc
->name
, MPI_SCSITASKMGMT_TASKTYPE_TARGET_RESET
, channel
, id
));
1075 mpt_put_msg_frame_hi_pri(mptsasDeviceResetCtx
, ioc
, mf
);
1081 mpt_clear_taskmgmt_in_progress_flag(ioc
);
1086 mptsas_block_io_sdev(struct scsi_device
*sdev
, void *data
)
1088 scsi_device_set_state(sdev
, SDEV_BLOCK
);
1092 mptsas_block_io_starget(struct scsi_target
*starget
)
1095 starget_for_each_device(starget
, NULL
, mptsas_block_io_sdev
);
1099 * mptsas_target_reset_queue
1101 * Receive request for TARGET_RESET after receiving an firmware
1102 * event NOT_RESPONDING_EVENT, then put command in link list
1103 * and queue if task_queue already in use.
1110 mptsas_target_reset_queue(MPT_ADAPTER
*ioc
,
1111 EVENT_DATA_SAS_DEVICE_STATUS_CHANGE
*sas_event_data
)
1113 MPT_SCSI_HOST
*hd
= shost_priv(ioc
->sh
);
1114 VirtTarget
*vtarget
= NULL
;
1115 struct mptsas_target_reset_event
*target_reset_list
;
1118 id
= sas_event_data
->TargetID
;
1119 channel
= sas_event_data
->Bus
;
1121 vtarget
= mptsas_find_vtarget(ioc
, channel
, id
);
1123 mptsas_block_io_starget(vtarget
->starget
);
1124 vtarget
->deleted
= 1; /* block IO */
1127 target_reset_list
= kzalloc(sizeof(struct mptsas_target_reset_event
),
1129 if (!target_reset_list
) {
1130 dfailprintk(ioc
, printk(MYIOC_s_WARN_FMT
1131 "%s, failed to allocate mem @%d..!!\n",
1132 ioc
->name
, __func__
, __LINE__
));
1136 memcpy(&target_reset_list
->sas_event_data
, sas_event_data
,
1137 sizeof(*sas_event_data
));
1138 list_add_tail(&target_reset_list
->list
, &hd
->target_reset_list
);
1140 target_reset_list
->time_count
= jiffies
;
1142 if (mptsas_target_reset(ioc
, channel
, id
)) {
1143 target_reset_list
->target_reset_issued
= 1;
1148 * mptsas_schedule_target_reset- send pending target reset
1149 * @iocp: per adapter object
1151 * This function will delete scheduled target reset from the list and
1152 * try to send next target reset. This will be called from completion
1153 * context of any Task management command.
1157 mptsas_schedule_target_reset(void *iocp
)
1159 MPT_ADAPTER
*ioc
= (MPT_ADAPTER
*)(iocp
);
1160 MPT_SCSI_HOST
*hd
= shost_priv(ioc
->sh
);
1161 struct list_head
*head
= &hd
->target_reset_list
;
1162 struct mptsas_target_reset_event
*target_reset_list
;
1165 * issue target reset to next device in the queue
1168 head
= &hd
->target_reset_list
;
1169 if (list_empty(head
))
1172 target_reset_list
= list_entry(head
->next
,
1173 struct mptsas_target_reset_event
, list
);
1175 id
= target_reset_list
->sas_event_data
.TargetID
;
1176 channel
= target_reset_list
->sas_event_data
.Bus
;
1177 target_reset_list
->time_count
= jiffies
;
1179 if (mptsas_target_reset(ioc
, channel
, id
))
1180 target_reset_list
->target_reset_issued
= 1;
1186 * mptsas_taskmgmt_complete - complete SAS task management function
1187 * @ioc: Pointer to MPT_ADAPTER structure
1189 * Completion for TARGET_RESET after NOT_RESPONDING_EVENT, enable work
1190 * queue to finish off removing device from upper layers. then send next
1191 * TARGET_RESET in the queue.
1194 mptsas_taskmgmt_complete(MPT_ADAPTER
*ioc
, MPT_FRAME_HDR
*mf
, MPT_FRAME_HDR
*mr
)
1196 MPT_SCSI_HOST
*hd
= shost_priv(ioc
->sh
);
1197 struct list_head
*head
= &hd
->target_reset_list
;
1199 struct mptsas_target_reset_event
*target_reset_list
;
1200 SCSITaskMgmtReply_t
*pScsiTmReply
;
1202 dtmprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"TaskMgmt completed: "
1203 "(mf = %p, mr = %p)\n", ioc
->name
, mf
, mr
));
1205 pScsiTmReply
= (SCSITaskMgmtReply_t
*)mr
;
1209 dtmprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
1210 "\tTaskMgmt completed: fw_channel = %d, fw_id = %d,\n"
1211 "\ttask_type = 0x%02X, iocstatus = 0x%04X "
1212 "loginfo = 0x%08X,\n\tresponse_code = 0x%02X, "
1213 "term_cmnds = %d\n", ioc
->name
,
1214 pScsiTmReply
->Bus
, pScsiTmReply
->TargetID
,
1215 pScsiTmReply
->TaskType
,
1216 le16_to_cpu(pScsiTmReply
->IOCStatus
),
1217 le32_to_cpu(pScsiTmReply
->IOCLogInfo
),
1218 pScsiTmReply
->ResponseCode
,
1219 le32_to_cpu(pScsiTmReply
->TerminationCount
)));
1221 if (pScsiTmReply
->ResponseCode
)
1222 mptscsih_taskmgmt_response_code(ioc
,
1223 pScsiTmReply
->ResponseCode
);
1225 if (pScsiTmReply
->TaskType
==
1226 MPI_SCSITASKMGMT_TASKTYPE_QUERY_TASK
|| pScsiTmReply
->TaskType
==
1227 MPI_SCSITASKMGMT_TASKTYPE_ABRT_TASK_SET
) {
1228 ioc
->taskmgmt_cmds
.status
|= MPT_MGMT_STATUS_COMMAND_GOOD
;
1229 ioc
->taskmgmt_cmds
.status
|= MPT_MGMT_STATUS_RF_VALID
;
1230 memcpy(ioc
->taskmgmt_cmds
.reply
, mr
,
1231 min(MPT_DEFAULT_FRAME_SIZE
, 4 * mr
->u
.reply
.MsgLength
));
1232 if (ioc
->taskmgmt_cmds
.status
& MPT_MGMT_STATUS_PENDING
) {
1233 ioc
->taskmgmt_cmds
.status
&= ~MPT_MGMT_STATUS_PENDING
;
1234 complete(&ioc
->taskmgmt_cmds
.done
);
1240 mpt_clear_taskmgmt_in_progress_flag(ioc
);
1242 if (list_empty(head
))
1245 target_reset_list
= list_entry(head
->next
,
1246 struct mptsas_target_reset_event
, list
);
1248 dtmprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
1249 "TaskMgmt: completed (%d seconds)\n",
1250 ioc
->name
, jiffies_to_msecs(jiffies
-
1251 target_reset_list
->time_count
)/1000));
1253 id
= pScsiTmReply
->TargetID
;
1254 channel
= pScsiTmReply
->Bus
;
1255 target_reset_list
->time_count
= jiffies
;
1258 * retry target reset
1260 if (!target_reset_list
->target_reset_issued
) {
1261 if (mptsas_target_reset(ioc
, channel
, id
))
1262 target_reset_list
->target_reset_issued
= 1;
1267 * enable work queue to remove device from upper layers
1269 list_del(&target_reset_list
->list
);
1270 if (!ioc
->fw_events_off
)
1271 mptsas_queue_device_delete(ioc
,
1272 &target_reset_list
->sas_event_data
);
1275 ioc
->schedule_target_reset(ioc
);
1281 * mptscsih_ioc_reset
1288 mptsas_ioc_reset(MPT_ADAPTER
*ioc
, int reset_phase
)
1293 rc
= mptscsih_ioc_reset(ioc
, reset_phase
);
1294 if ((ioc
->bus_type
!= SAS
) || (!rc
))
1297 hd
= shost_priv(ioc
->sh
);
1301 switch (reset_phase
) {
1302 case MPT_IOC_SETUP_RESET
:
1303 dtmprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
1304 "%s: MPT_IOC_SETUP_RESET\n", ioc
->name
, __func__
));
1305 mptsas_fw_event_off(ioc
);
1307 case MPT_IOC_PRE_RESET
:
1308 dtmprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
1309 "%s: MPT_IOC_PRE_RESET\n", ioc
->name
, __func__
));
1311 case MPT_IOC_POST_RESET
:
1312 dtmprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
1313 "%s: MPT_IOC_POST_RESET\n", ioc
->name
, __func__
));
1314 if (ioc
->sas_mgmt
.status
& MPT_MGMT_STATUS_PENDING
) {
1315 ioc
->sas_mgmt
.status
|= MPT_MGMT_STATUS_DID_IOCRESET
;
1316 complete(&ioc
->sas_mgmt
.done
);
1318 mptsas_cleanup_fw_event_q(ioc
);
1319 mptsas_queue_rescan(ioc
);
1331 * enum device_state -
1332 * @DEVICE_RETRY: need to retry the TUR
1333 * @DEVICE_ERROR: TUR return error, don't add device
1334 * @DEVICE_READY: device can be added
1344 mptsas_sas_enclosure_pg0(MPT_ADAPTER
*ioc
, struct mptsas_enclosure
*enclosure
,
1345 u32 form
, u32 form_specific
)
1347 ConfigExtendedPageHeader_t hdr
;
1349 SasEnclosurePage0_t
*buffer
;
1350 dma_addr_t dma_handle
;
1352 __le64 le_identifier
;
1354 memset(&hdr
, 0, sizeof(hdr
));
1355 hdr
.PageVersion
= MPI_SASENCLOSURE0_PAGEVERSION
;
1357 hdr
.PageType
= MPI_CONFIG_PAGETYPE_EXTENDED
;
1358 hdr
.ExtPageType
= MPI_CONFIG_EXTPAGETYPE_ENCLOSURE
;
1360 cfg
.cfghdr
.ehdr
= &hdr
;
1362 cfg
.pageAddr
= form
+ form_specific
;
1363 cfg
.action
= MPI_CONFIG_ACTION_PAGE_HEADER
;
1364 cfg
.dir
= 0; /* read */
1365 cfg
.timeout
= SAS_CONFIG_PAGE_TIMEOUT
;
1367 error
= mpt_config(ioc
, &cfg
);
1370 if (!hdr
.ExtPageLength
) {
1375 buffer
= pci_alloc_consistent(ioc
->pcidev
, hdr
.ExtPageLength
* 4,
1382 cfg
.physAddr
= dma_handle
;
1383 cfg
.action
= MPI_CONFIG_ACTION_PAGE_READ_CURRENT
;
1385 error
= mpt_config(ioc
, &cfg
);
1387 goto out_free_consistent
;
1389 /* save config data */
1390 memcpy(&le_identifier
, &buffer
->EnclosureLogicalID
, sizeof(__le64
));
1391 enclosure
->enclosure_logical_id
= le64_to_cpu(le_identifier
);
1392 enclosure
->enclosure_handle
= le16_to_cpu(buffer
->EnclosureHandle
);
1393 enclosure
->flags
= le16_to_cpu(buffer
->Flags
);
1394 enclosure
->num_slot
= le16_to_cpu(buffer
->NumSlots
);
1395 enclosure
->start_slot
= le16_to_cpu(buffer
->StartSlot
);
1396 enclosure
->start_id
= buffer
->StartTargetID
;
1397 enclosure
->start_channel
= buffer
->StartBus
;
1398 enclosure
->sep_id
= buffer
->SEPTargetID
;
1399 enclosure
->sep_channel
= buffer
->SEPBus
;
1401 out_free_consistent
:
1402 pci_free_consistent(ioc
->pcidev
, hdr
.ExtPageLength
* 4,
1403 buffer
, dma_handle
);
1409 * mptsas_add_end_device - report a new end device to sas transport layer
1410 * @ioc: Pointer to MPT_ADAPTER structure
1411 * @phy_info: describes attached device
1413 * return (0) success (1) failure
1417 mptsas_add_end_device(MPT_ADAPTER
*ioc
, struct mptsas_phyinfo
*phy_info
)
1419 struct sas_rphy
*rphy
;
1420 struct sas_port
*port
;
1421 struct sas_identify identify
;
1426 dfailprintk(ioc
, printk(MYIOC_s_ERR_FMT
1427 "%s: exit at line=%d\n", ioc
->name
,
1428 __func__
, __LINE__
));
1432 fw_id
= phy_info
->attached
.id
;
1434 if (mptsas_get_rphy(phy_info
)) {
1435 dfailprintk(ioc
, printk(MYIOC_s_ERR_FMT
1436 "%s: fw_id=%d exit at line=%d\n", ioc
->name
,
1437 __func__
, fw_id
, __LINE__
));
1441 port
= mptsas_get_port(phy_info
);
1443 dfailprintk(ioc
, printk(MYIOC_s_ERR_FMT
1444 "%s: fw_id=%d exit at line=%d\n", ioc
->name
,
1445 __func__
, fw_id
, __LINE__
));
1449 if (phy_info
->attached
.device_info
&
1450 MPI_SAS_DEVICE_INFO_SSP_TARGET
)
1452 if (phy_info
->attached
.device_info
&
1453 MPI_SAS_DEVICE_INFO_STP_TARGET
)
1455 if (phy_info
->attached
.device_info
&
1456 MPI_SAS_DEVICE_INFO_SATA_DEVICE
)
1459 printk(MYIOC_s_INFO_FMT
"attaching %s device: fw_channel %d, fw_id %d,"
1460 " phy %d, sas_addr 0x%llx\n", ioc
->name
, ds
,
1461 phy_info
->attached
.channel
, phy_info
->attached
.id
,
1462 phy_info
->attached
.phy_id
, (unsigned long long)
1463 phy_info
->attached
.sas_address
);
1465 mptsas_parse_device_info(&identify
, &phy_info
->attached
);
1466 rphy
= sas_end_device_alloc(port
);
1468 dfailprintk(ioc
, printk(MYIOC_s_ERR_FMT
1469 "%s: fw_id=%d exit at line=%d\n", ioc
->name
,
1470 __func__
, fw_id
, __LINE__
));
1471 return 5; /* non-fatal: an rphy can be added later */
1474 rphy
->identify
= identify
;
1475 if (sas_rphy_add(rphy
)) {
1476 dfailprintk(ioc
, printk(MYIOC_s_ERR_FMT
1477 "%s: fw_id=%d exit at line=%d\n", ioc
->name
,
1478 __func__
, fw_id
, __LINE__
));
1479 sas_rphy_free(rphy
);
1482 mptsas_set_rphy(ioc
, phy_info
, rphy
);
1487 * mptsas_del_end_device - report a deleted end device to sas transport layer
1488 * @ioc: Pointer to MPT_ADAPTER structure
1489 * @phy_info: describes attached device
1493 mptsas_del_end_device(MPT_ADAPTER
*ioc
, struct mptsas_phyinfo
*phy_info
)
1495 struct sas_rphy
*rphy
;
1496 struct sas_port
*port
;
1497 struct mptsas_portinfo
*port_info
;
1498 struct mptsas_phyinfo
*phy_info_parent
;
1507 fw_id
= phy_info
->attached
.id
;
1508 sas_address
= phy_info
->attached
.sas_address
;
1510 if (!phy_info
->port_details
) {
1511 dfailprintk(ioc
, printk(MYIOC_s_ERR_FMT
1512 "%s: fw_id=%d exit at line=%d\n", ioc
->name
,
1513 __func__
, fw_id
, __LINE__
));
1516 rphy
= mptsas_get_rphy(phy_info
);
1518 dfailprintk(ioc
, printk(MYIOC_s_ERR_FMT
1519 "%s: fw_id=%d exit at line=%d\n", ioc
->name
,
1520 __func__
, fw_id
, __LINE__
));
1524 if (phy_info
->attached
.device_info
& MPI_SAS_DEVICE_INFO_SSP_INITIATOR
1525 || phy_info
->attached
.device_info
1526 & MPI_SAS_DEVICE_INFO_SMP_INITIATOR
1527 || phy_info
->attached
.device_info
1528 & MPI_SAS_DEVICE_INFO_STP_INITIATOR
)
1530 if (phy_info
->attached
.device_info
&
1531 MPI_SAS_DEVICE_INFO_SSP_TARGET
)
1533 if (phy_info
->attached
.device_info
&
1534 MPI_SAS_DEVICE_INFO_STP_TARGET
)
1536 if (phy_info
->attached
.device_info
&
1537 MPI_SAS_DEVICE_INFO_SATA_DEVICE
)
1540 dev_printk(KERN_DEBUG
, &rphy
->dev
, MYIOC_s_FMT
1541 "removing %s device: fw_channel %d, fw_id %d, phy %d,"
1542 "sas_addr 0x%llx\n", ioc
->name
, ds
, phy_info
->attached
.channel
,
1543 phy_info
->attached
.id
, phy_info
->attached
.phy_id
,
1544 (unsigned long long) sas_address
);
1546 port
= mptsas_get_port(phy_info
);
1548 dfailprintk(ioc
, printk(MYIOC_s_ERR_FMT
1549 "%s: fw_id=%d exit at line=%d\n", ioc
->name
,
1550 __func__
, fw_id
, __LINE__
));
1553 port_info
= phy_info
->portinfo
;
1554 phy_info_parent
= port_info
->phy_info
;
1555 for (i
= 0; i
< port_info
->num_phys
; i
++, phy_info_parent
++) {
1556 if (!phy_info_parent
->phy
)
1558 if (phy_info_parent
->attached
.sas_address
!=
1561 dev_printk(KERN_DEBUG
, &phy_info_parent
->phy
->dev
,
1562 MYIOC_s_FMT
"delete phy %d, phy-obj (0x%p)\n",
1563 ioc
->name
, phy_info_parent
->phy_id
,
1564 phy_info_parent
->phy
);
1565 sas_port_delete_phy(port
, phy_info_parent
->phy
);
1568 dev_printk(KERN_DEBUG
, &port
->dev
, MYIOC_s_FMT
1569 "delete port %d, sas_addr (0x%llx)\n", ioc
->name
,
1570 port
->port_identifier
, (unsigned long long)sas_address
);
1571 sas_port_delete(port
);
1572 mptsas_set_port(ioc
, phy_info
, NULL
);
1573 mptsas_port_delete(ioc
, phy_info
->port_details
);
1576 static struct mptsas_phyinfo
*
1577 mptsas_refreshing_device_handles(MPT_ADAPTER
*ioc
,
1578 struct mptsas_devinfo
*sas_device
)
1580 struct mptsas_phyinfo
*phy_info
;
1581 struct mptsas_portinfo
*port_info
;
1584 phy_info
= mptsas_find_phyinfo_by_sas_address(ioc
,
1585 sas_device
->sas_address
);
1588 port_info
= phy_info
->portinfo
;
1591 mutex_lock(&ioc
->sas_topology_mutex
);
1592 for (i
= 0; i
< port_info
->num_phys
; i
++) {
1593 if (port_info
->phy_info
[i
].attached
.sas_address
!=
1594 sas_device
->sas_address
)
1596 port_info
->phy_info
[i
].attached
.channel
= sas_device
->channel
;
1597 port_info
->phy_info
[i
].attached
.id
= sas_device
->id
;
1598 port_info
->phy_info
[i
].attached
.sas_address
=
1599 sas_device
->sas_address
;
1600 port_info
->phy_info
[i
].attached
.handle
= sas_device
->handle
;
1601 port_info
->phy_info
[i
].attached
.handle_parent
=
1602 sas_device
->handle_parent
;
1603 port_info
->phy_info
[i
].attached
.handle_enclosure
=
1604 sas_device
->handle_enclosure
;
1606 mutex_unlock(&ioc
->sas_topology_mutex
);
1612 * mptsas_firmware_event_work - work thread for processing fw events
1613 * @work: work queue payload containing info describing the event
1618 mptsas_firmware_event_work(struct work_struct
*work
)
1620 struct fw_event_work
*fw_event
=
1621 container_of(work
, struct fw_event_work
, work
.work
);
1622 MPT_ADAPTER
*ioc
= fw_event
->ioc
;
1624 /* special rescan topology handling */
1625 if (fw_event
->event
== -1) {
1626 if (ioc
->in_rescan
) {
1627 devtprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
1628 "%s: rescan ignored as it is in progress\n",
1629 ioc
->name
, __func__
));
1632 devtprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"%s: rescan after "
1633 "reset\n", ioc
->name
, __func__
));
1635 mptsas_not_responding_devices(ioc
);
1636 mptsas_scan_sas_topology(ioc
);
1638 mptsas_free_fw_event(ioc
, fw_event
);
1639 mptsas_fw_event_on(ioc
);
1643 /* events handling turned off during host reset */
1644 if (ioc
->fw_events_off
) {
1645 mptsas_free_fw_event(ioc
, fw_event
);
1649 devtprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"%s: fw_event=(0x%p), "
1650 "event = (0x%02x)\n", ioc
->name
, __func__
, fw_event
,
1651 (fw_event
->event
& 0xFF)));
1653 switch (fw_event
->event
) {
1654 case MPI_EVENT_SAS_DEVICE_STATUS_CHANGE
:
1655 mptsas_send_sas_event(fw_event
);
1657 case MPI_EVENT_INTEGRATED_RAID
:
1658 mptsas_send_raid_event(fw_event
);
1661 mptsas_send_ir2_event(fw_event
);
1663 case MPI_EVENT_PERSISTENT_TABLE_FULL
:
1664 mptbase_sas_persist_operation(ioc
,
1665 MPI_SAS_OP_CLEAR_NOT_PRESENT
);
1666 mptsas_free_fw_event(ioc
, fw_event
);
1668 case MPI_EVENT_SAS_BROADCAST_PRIMITIVE
:
1669 mptsas_broadcast_primative_work(fw_event
);
1671 case MPI_EVENT_SAS_EXPANDER_STATUS_CHANGE
:
1672 mptsas_send_expander_event(fw_event
);
1674 case MPI_EVENT_SAS_PHY_LINK_STATUS
:
1675 mptsas_send_link_status_event(fw_event
);
1677 case MPI_EVENT_QUEUE_FULL
:
1678 mptsas_handle_queue_full_event(fw_event
);
1686 mptsas_slave_configure(struct scsi_device
*sdev
)
1688 struct Scsi_Host
*host
= sdev
->host
;
1689 MPT_SCSI_HOST
*hd
= shost_priv(host
);
1690 MPT_ADAPTER
*ioc
= hd
->ioc
;
1691 VirtDevice
*vdevice
= sdev
->hostdata
;
1693 if (vdevice
->vtarget
->deleted
) {
1694 sdev_printk(KERN_INFO
, sdev
, "clearing deleted flag\n");
1695 vdevice
->vtarget
->deleted
= 0;
1699 * RAID volumes placed beyond the last expected port.
1700 * Ignore sending sas mode pages in that case..
1702 if (sdev
->channel
== MPTSAS_RAID_CHANNEL
) {
1703 mptsas_add_device_component_starget_ir(ioc
, scsi_target(sdev
));
1707 sas_read_port_mode_page(sdev
);
1709 mptsas_add_device_component_starget(ioc
, scsi_target(sdev
));
1712 return mptscsih_slave_configure(sdev
);
1716 mptsas_target_alloc(struct scsi_target
*starget
)
1718 struct Scsi_Host
*host
= dev_to_shost(&starget
->dev
);
1719 MPT_SCSI_HOST
*hd
= shost_priv(host
);
1720 VirtTarget
*vtarget
;
1722 struct sas_rphy
*rphy
;
1723 struct mptsas_portinfo
*p
;
1725 MPT_ADAPTER
*ioc
= hd
->ioc
;
1727 vtarget
= kzalloc(sizeof(VirtTarget
), GFP_KERNEL
);
1731 vtarget
->starget
= starget
;
1732 vtarget
->ioc_id
= ioc
->id
;
1733 vtarget
->tflags
= MPT_TARGET_FLAGS_Q_YES
;
1738 * RAID volumes placed beyond the last expected port.
1740 if (starget
->channel
== MPTSAS_RAID_CHANNEL
) {
1741 if (!ioc
->raid_data
.pIocPg2
) {
1745 for (i
= 0; i
< ioc
->raid_data
.pIocPg2
->NumActiveVolumes
; i
++) {
1746 if (id
== ioc
->raid_data
.pIocPg2
->
1747 RaidVolume
[i
].VolumeID
) {
1748 channel
= ioc
->raid_data
.pIocPg2
->
1749 RaidVolume
[i
].VolumeBus
;
1752 vtarget
->raidVolume
= 1;
1756 rphy
= dev_to_rphy(starget
->dev
.parent
);
1757 mutex_lock(&ioc
->sas_topology_mutex
);
1758 list_for_each_entry(p
, &ioc
->sas_topology
, list
) {
1759 for (i
= 0; i
< p
->num_phys
; i
++) {
1760 if (p
->phy_info
[i
].attached
.sas_address
!=
1761 rphy
->identify
.sas_address
)
1763 id
= p
->phy_info
[i
].attached
.id
;
1764 channel
= p
->phy_info
[i
].attached
.channel
;
1765 mptsas_set_starget(&p
->phy_info
[i
], starget
);
1768 * Exposing hidden raid components
1770 if (mptscsih_is_phys_disk(ioc
, channel
, id
)) {
1771 id
= mptscsih_raid_id_to_num(ioc
,
1774 MPT_TARGET_FLAGS_RAID_COMPONENT
;
1775 p
->phy_info
[i
].attached
.phys_disk_num
= id
;
1777 mutex_unlock(&ioc
->sas_topology_mutex
);
1781 mutex_unlock(&ioc
->sas_topology_mutex
);
1788 vtarget
->channel
= channel
;
1789 starget
->hostdata
= vtarget
;
1794 mptsas_target_destroy(struct scsi_target
*starget
)
1796 struct Scsi_Host
*host
= dev_to_shost(&starget
->dev
);
1797 MPT_SCSI_HOST
*hd
= shost_priv(host
);
1798 struct sas_rphy
*rphy
;
1799 struct mptsas_portinfo
*p
;
1801 MPT_ADAPTER
*ioc
= hd
->ioc
;
1802 VirtTarget
*vtarget
;
1804 if (!starget
->hostdata
)
1807 vtarget
= starget
->hostdata
;
1809 mptsas_del_device_component_by_os(ioc
, starget
->channel
,
1813 if (starget
->channel
== MPTSAS_RAID_CHANNEL
)
1816 rphy
= dev_to_rphy(starget
->dev
.parent
);
1817 list_for_each_entry(p
, &ioc
->sas_topology
, list
) {
1818 for (i
= 0; i
< p
->num_phys
; i
++) {
1819 if (p
->phy_info
[i
].attached
.sas_address
!=
1820 rphy
->identify
.sas_address
)
1823 starget_printk(KERN_INFO
, starget
, MYIOC_s_FMT
1824 "delete device: fw_channel %d, fw_id %d, phy %d, "
1825 "sas_addr 0x%llx\n", ioc
->name
,
1826 p
->phy_info
[i
].attached
.channel
,
1827 p
->phy_info
[i
].attached
.id
,
1828 p
->phy_info
[i
].attached
.phy_id
, (unsigned long long)
1829 p
->phy_info
[i
].attached
.sas_address
);
1831 mptsas_set_starget(&p
->phy_info
[i
], NULL
);
1836 vtarget
->starget
= NULL
;
1837 kfree(starget
->hostdata
);
1838 starget
->hostdata
= NULL
;
1843 mptsas_slave_alloc(struct scsi_device
*sdev
)
1845 struct Scsi_Host
*host
= sdev
->host
;
1846 MPT_SCSI_HOST
*hd
= shost_priv(host
);
1847 struct sas_rphy
*rphy
;
1848 struct mptsas_portinfo
*p
;
1849 VirtDevice
*vdevice
;
1850 struct scsi_target
*starget
;
1852 MPT_ADAPTER
*ioc
= hd
->ioc
;
1854 vdevice
= kzalloc(sizeof(VirtDevice
), GFP_KERNEL
);
1856 printk(MYIOC_s_ERR_FMT
"slave_alloc kzalloc(%zd) FAILED!\n",
1857 ioc
->name
, sizeof(VirtDevice
));
1860 starget
= scsi_target(sdev
);
1861 vdevice
->vtarget
= starget
->hostdata
;
1863 if (sdev
->channel
== MPTSAS_RAID_CHANNEL
)
1866 rphy
= dev_to_rphy(sdev
->sdev_target
->dev
.parent
);
1867 mutex_lock(&ioc
->sas_topology_mutex
);
1868 list_for_each_entry(p
, &ioc
->sas_topology
, list
) {
1869 for (i
= 0; i
< p
->num_phys
; i
++) {
1870 if (p
->phy_info
[i
].attached
.sas_address
!=
1871 rphy
->identify
.sas_address
)
1873 vdevice
->lun
= sdev
->lun
;
1875 * Exposing hidden raid components
1877 if (mptscsih_is_phys_disk(ioc
,
1878 p
->phy_info
[i
].attached
.channel
,
1879 p
->phy_info
[i
].attached
.id
))
1880 sdev
->no_uld_attach
= 1;
1881 mutex_unlock(&ioc
->sas_topology_mutex
);
1885 mutex_unlock(&ioc
->sas_topology_mutex
);
1891 vdevice
->vtarget
->num_luns
++;
1892 sdev
->hostdata
= vdevice
;
1897 mptsas_qcmd(struct Scsi_Host
*shost
, struct scsi_cmnd
*SCpnt
)
1901 VirtDevice
*vdevice
= SCpnt
->device
->hostdata
;
1903 if (!vdevice
|| !vdevice
->vtarget
|| vdevice
->vtarget
->deleted
) {
1904 SCpnt
->result
= DID_NO_CONNECT
<< 16;
1905 SCpnt
->scsi_done(SCpnt
);
1909 hd
= shost_priv(shost
);
1912 if (ioc
->sas_discovery_quiesce_io
)
1913 return SCSI_MLQUEUE_HOST_BUSY
;
1915 if (ioc
->debug_level
& MPT_DEBUG_SCSI
)
1916 scsi_print_command(SCpnt
);
1918 return mptscsih_qcmd(SCpnt
);
1922 * mptsas_mptsas_eh_timed_out - resets the scsi_cmnd timeout
1923 * if the device under question is currently in the
1924 * device removal delay.
1925 * @sc: scsi command that the midlayer is about to time out
1928 static enum blk_eh_timer_return
mptsas_eh_timed_out(struct scsi_cmnd
*sc
)
1932 VirtDevice
*vdevice
;
1933 enum blk_eh_timer_return rc
= BLK_EH_NOT_HANDLED
;
1935 hd
= shost_priv(sc
->device
->host
);
1937 printk(KERN_ERR MYNAM
": %s: Can't locate host! (sc=%p)\n",
1943 if (ioc
->bus_type
!= SAS
) {
1944 printk(KERN_ERR MYNAM
": %s: Wrong bus type (sc=%p)\n",
1949 /* In case if IOC is in reset from internal context.
1950 * Do not execute EEH for the same IOC. SML should to reset timer.
1952 if (ioc
->ioc_reset_in_progress
) {
1953 dtmprintk(ioc
, printk(MYIOC_s_WARN_FMT
": %s: ioc is in reset,"
1954 "SML need to reset the timer (sc=%p)\n",
1955 ioc
->name
, __func__
, sc
));
1956 rc
= BLK_EH_RESET_TIMER
;
1958 vdevice
= sc
->device
->hostdata
;
1959 if (vdevice
&& vdevice
->vtarget
&& (vdevice
->vtarget
->inDMD
1960 || vdevice
->vtarget
->deleted
)) {
1961 dtmprintk(ioc
, printk(MYIOC_s_WARN_FMT
": %s: target removed "
1962 "or in device removal delay (sc=%p)\n",
1963 ioc
->name
, __func__
, sc
));
1964 rc
= BLK_EH_RESET_TIMER
;
1973 static struct scsi_host_template mptsas_driver_template
= {
1974 .module
= THIS_MODULE
,
1975 .proc_name
= "mptsas",
1976 .show_info
= mptscsih_show_info
,
1977 .name
= "MPT SAS Host",
1978 .info
= mptscsih_info
,
1979 .queuecommand
= mptsas_qcmd
,
1980 .target_alloc
= mptsas_target_alloc
,
1981 .slave_alloc
= mptsas_slave_alloc
,
1982 .slave_configure
= mptsas_slave_configure
,
1983 .target_destroy
= mptsas_target_destroy
,
1984 .slave_destroy
= mptscsih_slave_destroy
,
1985 .change_queue_depth
= mptscsih_change_queue_depth
,
1986 .eh_abort_handler
= mptscsih_abort
,
1987 .eh_device_reset_handler
= mptscsih_dev_reset
,
1988 .eh_host_reset_handler
= mptscsih_host_reset
,
1989 .bios_param
= mptscsih_bios_param
,
1990 .can_queue
= MPT_SAS_CAN_QUEUE
,
1992 .sg_tablesize
= MPT_SCSI_SG_DEPTH
,
1993 .max_sectors
= 8192,
1995 .use_clustering
= ENABLE_CLUSTERING
,
1996 .shost_attrs
= mptscsih_host_attrs
,
2000 static int mptsas_get_linkerrors(struct sas_phy
*phy
)
2002 MPT_ADAPTER
*ioc
= phy_to_ioc(phy
);
2003 ConfigExtendedPageHeader_t hdr
;
2005 SasPhyPage1_t
*buffer
;
2006 dma_addr_t dma_handle
;
2009 /* FIXME: only have link errors on local phys */
2010 if (!scsi_is_sas_phy_local(phy
))
2013 hdr
.PageVersion
= MPI_SASPHY1_PAGEVERSION
;
2014 hdr
.ExtPageLength
= 0;
2015 hdr
.PageNumber
= 1 /* page number 1*/;
2018 hdr
.PageType
= MPI_CONFIG_PAGETYPE_EXTENDED
;
2019 hdr
.ExtPageType
= MPI_CONFIG_EXTPAGETYPE_SAS_PHY
;
2021 cfg
.cfghdr
.ehdr
= &hdr
;
2023 cfg
.pageAddr
= phy
->identify
.phy_identifier
;
2024 cfg
.action
= MPI_CONFIG_ACTION_PAGE_HEADER
;
2025 cfg
.dir
= 0; /* read */
2026 cfg
.timeout
= SAS_CONFIG_PAGE_TIMEOUT
;
2028 error
= mpt_config(ioc
, &cfg
);
2031 if (!hdr
.ExtPageLength
)
2034 buffer
= pci_alloc_consistent(ioc
->pcidev
, hdr
.ExtPageLength
* 4,
2039 cfg
.physAddr
= dma_handle
;
2040 cfg
.action
= MPI_CONFIG_ACTION_PAGE_READ_CURRENT
;
2042 error
= mpt_config(ioc
, &cfg
);
2044 goto out_free_consistent
;
2046 mptsas_print_phy_pg1(ioc
, buffer
);
2048 phy
->invalid_dword_count
= le32_to_cpu(buffer
->InvalidDwordCount
);
2049 phy
->running_disparity_error_count
=
2050 le32_to_cpu(buffer
->RunningDisparityErrorCount
);
2051 phy
->loss_of_dword_sync_count
=
2052 le32_to_cpu(buffer
->LossDwordSynchCount
);
2053 phy
->phy_reset_problem_count
=
2054 le32_to_cpu(buffer
->PhyResetProblemCount
);
2056 out_free_consistent
:
2057 pci_free_consistent(ioc
->pcidev
, hdr
.ExtPageLength
* 4,
2058 buffer
, dma_handle
);
2062 static int mptsas_mgmt_done(MPT_ADAPTER
*ioc
, MPT_FRAME_HDR
*req
,
2063 MPT_FRAME_HDR
*reply
)
2065 ioc
->sas_mgmt
.status
|= MPT_MGMT_STATUS_COMMAND_GOOD
;
2066 if (reply
!= NULL
) {
2067 ioc
->sas_mgmt
.status
|= MPT_MGMT_STATUS_RF_VALID
;
2068 memcpy(ioc
->sas_mgmt
.reply
, reply
,
2069 min(ioc
->reply_sz
, 4 * reply
->u
.reply
.MsgLength
));
2072 if (ioc
->sas_mgmt
.status
& MPT_MGMT_STATUS_PENDING
) {
2073 ioc
->sas_mgmt
.status
&= ~MPT_MGMT_STATUS_PENDING
;
2074 complete(&ioc
->sas_mgmt
.done
);
2080 static int mptsas_phy_reset(struct sas_phy
*phy
, int hard_reset
)
2082 MPT_ADAPTER
*ioc
= phy_to_ioc(phy
);
2083 SasIoUnitControlRequest_t
*req
;
2084 SasIoUnitControlReply_t
*reply
;
2087 unsigned long timeleft
;
2088 int error
= -ERESTARTSYS
;
2090 /* FIXME: fusion doesn't allow non-local phy reset */
2091 if (!scsi_is_sas_phy_local(phy
))
2094 /* not implemented for expanders */
2095 if (phy
->identify
.target_port_protocols
& SAS_PROTOCOL_SMP
)
2098 if (mutex_lock_interruptible(&ioc
->sas_mgmt
.mutex
))
2101 mf
= mpt_get_msg_frame(mptsasMgmtCtx
, ioc
);
2107 hdr
= (MPIHeader_t
*) mf
;
2108 req
= (SasIoUnitControlRequest_t
*)mf
;
2109 memset(req
, 0, sizeof(SasIoUnitControlRequest_t
));
2110 req
->Function
= MPI_FUNCTION_SAS_IO_UNIT_CONTROL
;
2111 req
->MsgContext
= hdr
->MsgContext
;
2112 req
->Operation
= hard_reset
?
2113 MPI_SAS_OP_PHY_HARD_RESET
: MPI_SAS_OP_PHY_LINK_RESET
;
2114 req
->PhyNum
= phy
->identify
.phy_identifier
;
2116 INITIALIZE_MGMT_STATUS(ioc
->sas_mgmt
.status
)
2117 mpt_put_msg_frame(mptsasMgmtCtx
, ioc
, mf
);
2119 timeleft
= wait_for_completion_timeout(&ioc
->sas_mgmt
.done
,
2121 if (!(ioc
->sas_mgmt
.status
& MPT_MGMT_STATUS_COMMAND_GOOD
)) {
2123 mpt_free_msg_frame(ioc
, mf
);
2124 if (ioc
->sas_mgmt
.status
& MPT_MGMT_STATUS_DID_IOCRESET
)
2127 mpt_Soft_Hard_ResetHandler(ioc
, CAN_SLEEP
);
2131 /* a reply frame is expected */
2132 if ((ioc
->sas_mgmt
.status
&
2133 MPT_MGMT_STATUS_RF_VALID
) == 0) {
2138 /* process the completed Reply Message Frame */
2139 reply
= (SasIoUnitControlReply_t
*)ioc
->sas_mgmt
.reply
;
2140 if (reply
->IOCStatus
!= MPI_IOCSTATUS_SUCCESS
) {
2141 printk(MYIOC_s_INFO_FMT
"%s: IOCStatus=0x%X IOCLogInfo=0x%X\n",
2142 ioc
->name
, __func__
, reply
->IOCStatus
, reply
->IOCLogInfo
);
2150 CLEAR_MGMT_STATUS(ioc
->sas_mgmt
.status
)
2151 mutex_unlock(&ioc
->sas_mgmt
.mutex
);
2157 mptsas_get_enclosure_identifier(struct sas_rphy
*rphy
, u64
*identifier
)
2159 MPT_ADAPTER
*ioc
= rphy_to_ioc(rphy
);
2161 struct mptsas_portinfo
*p
;
2162 struct mptsas_enclosure enclosure_info
;
2163 u64 enclosure_handle
;
2165 mutex_lock(&ioc
->sas_topology_mutex
);
2166 list_for_each_entry(p
, &ioc
->sas_topology
, list
) {
2167 for (i
= 0; i
< p
->num_phys
; i
++) {
2168 if (p
->phy_info
[i
].attached
.sas_address
==
2169 rphy
->identify
.sas_address
) {
2170 enclosure_handle
= p
->phy_info
[i
].
2171 attached
.handle_enclosure
;
2176 mutex_unlock(&ioc
->sas_topology_mutex
);
2180 mutex_unlock(&ioc
->sas_topology_mutex
);
2181 memset(&enclosure_info
, 0, sizeof(struct mptsas_enclosure
));
2182 error
= mptsas_sas_enclosure_pg0(ioc
, &enclosure_info
,
2183 (MPI_SAS_ENCLOS_PGAD_FORM_HANDLE
<<
2184 MPI_SAS_ENCLOS_PGAD_FORM_SHIFT
), enclosure_handle
);
2186 *identifier
= enclosure_info
.enclosure_logical_id
;
2191 mptsas_get_bay_identifier(struct sas_rphy
*rphy
)
2193 MPT_ADAPTER
*ioc
= rphy_to_ioc(rphy
);
2194 struct mptsas_portinfo
*p
;
2197 mutex_lock(&ioc
->sas_topology_mutex
);
2198 list_for_each_entry(p
, &ioc
->sas_topology
, list
) {
2199 for (i
= 0; i
< p
->num_phys
; i
++) {
2200 if (p
->phy_info
[i
].attached
.sas_address
==
2201 rphy
->identify
.sas_address
) {
2202 rc
= p
->phy_info
[i
].attached
.slot
;
2209 mutex_unlock(&ioc
->sas_topology_mutex
);
2213 static int mptsas_smp_handler(struct Scsi_Host
*shost
, struct sas_rphy
*rphy
,
2214 struct request
*req
)
2216 MPT_ADAPTER
*ioc
= ((MPT_SCSI_HOST
*) shost
->hostdata
)->ioc
;
2218 SmpPassthroughRequest_t
*smpreq
;
2219 struct request
*rsp
= req
->next_rq
;
2222 unsigned long timeleft
;
2224 dma_addr_t dma_addr_in
= 0;
2225 dma_addr_t dma_addr_out
= 0;
2226 u64 sas_address
= 0;
2229 printk(MYIOC_s_ERR_FMT
"%s: the smp response space is missing\n",
2230 ioc
->name
, __func__
);
2234 /* do we need to support multiple segments? */
2235 if (bio_multiple_segments(req
->bio
) ||
2236 bio_multiple_segments(rsp
->bio
)) {
2237 printk(MYIOC_s_ERR_FMT
"%s: multiple segments req %u, rsp %u\n",
2238 ioc
->name
, __func__
, blk_rq_bytes(req
), blk_rq_bytes(rsp
));
2242 ret
= mutex_lock_interruptible(&ioc
->sas_mgmt
.mutex
);
2246 mf
= mpt_get_msg_frame(mptsasMgmtCtx
, ioc
);
2252 smpreq
= (SmpPassthroughRequest_t
*)mf
;
2253 memset(smpreq
, 0, sizeof(*smpreq
));
2255 smpreq
->RequestDataLength
= cpu_to_le16(blk_rq_bytes(req
) - 4);
2256 smpreq
->Function
= MPI_FUNCTION_SMP_PASSTHROUGH
;
2259 sas_address
= rphy
->identify
.sas_address
;
2261 struct mptsas_portinfo
*port_info
;
2263 mutex_lock(&ioc
->sas_topology_mutex
);
2264 port_info
= ioc
->hba_port_info
;
2265 if (port_info
&& port_info
->phy_info
)
2267 port_info
->phy_info
[0].phy
->identify
.sas_address
;
2268 mutex_unlock(&ioc
->sas_topology_mutex
);
2271 *((u64
*)&smpreq
->SASAddress
) = cpu_to_le64(sas_address
);
2274 (((int *) mf
) + (offsetof(SmpPassthroughRequest_t
, SGL
) / 4));
2277 flagsLength
= (MPI_SGE_FLAGS_SIMPLE_ELEMENT
|
2278 MPI_SGE_FLAGS_END_OF_BUFFER
|
2279 MPI_SGE_FLAGS_DIRECTION
)
2280 << MPI_SGE_FLAGS_SHIFT
;
2281 flagsLength
|= (blk_rq_bytes(req
) - 4);
2283 dma_addr_out
= pci_map_single(ioc
->pcidev
, bio_data(req
->bio
),
2284 blk_rq_bytes(req
), PCI_DMA_BIDIRECTIONAL
);
2287 ioc
->add_sge(psge
, flagsLength
, dma_addr_out
);
2288 psge
+= ioc
->SGE_size
;
2291 flagsLength
= MPI_SGE_FLAGS_SIMPLE_ELEMENT
|
2292 MPI_SGE_FLAGS_SYSTEM_ADDRESS
|
2293 MPI_SGE_FLAGS_IOC_TO_HOST
|
2294 MPI_SGE_FLAGS_END_OF_BUFFER
;
2296 flagsLength
= flagsLength
<< MPI_SGE_FLAGS_SHIFT
;
2297 flagsLength
|= blk_rq_bytes(rsp
) + 4;
2298 dma_addr_in
= pci_map_single(ioc
->pcidev
, bio_data(rsp
->bio
),
2299 blk_rq_bytes(rsp
), PCI_DMA_BIDIRECTIONAL
);
2302 ioc
->add_sge(psge
, flagsLength
, dma_addr_in
);
2304 INITIALIZE_MGMT_STATUS(ioc
->sas_mgmt
.status
)
2305 mpt_put_msg_frame(mptsasMgmtCtx
, ioc
, mf
);
2307 timeleft
= wait_for_completion_timeout(&ioc
->sas_mgmt
.done
, 10 * HZ
);
2308 if (!(ioc
->sas_mgmt
.status
& MPT_MGMT_STATUS_COMMAND_GOOD
)) {
2310 mpt_free_msg_frame(ioc
, mf
);
2312 if (ioc
->sas_mgmt
.status
& MPT_MGMT_STATUS_DID_IOCRESET
)
2315 mpt_Soft_Hard_ResetHandler(ioc
, CAN_SLEEP
);
2320 if (ioc
->sas_mgmt
.status
& MPT_MGMT_STATUS_RF_VALID
) {
2321 SmpPassthroughReply_t
*smprep
;
2323 smprep
= (SmpPassthroughReply_t
*)ioc
->sas_mgmt
.reply
;
2324 memcpy(req
->sense
, smprep
, sizeof(*smprep
));
2325 req
->sense_len
= sizeof(*smprep
);
2327 rsp
->resid_len
-= smprep
->ResponseDataLength
;
2329 printk(MYIOC_s_ERR_FMT
2330 "%s: smp passthru reply failed to be returned\n",
2331 ioc
->name
, __func__
);
2336 pci_unmap_single(ioc
->pcidev
, dma_addr_out
, blk_rq_bytes(req
),
2337 PCI_DMA_BIDIRECTIONAL
);
2339 pci_unmap_single(ioc
->pcidev
, dma_addr_in
, blk_rq_bytes(rsp
),
2340 PCI_DMA_BIDIRECTIONAL
);
2343 mpt_free_msg_frame(ioc
, mf
);
2345 CLEAR_MGMT_STATUS(ioc
->sas_mgmt
.status
)
2346 mutex_unlock(&ioc
->sas_mgmt
.mutex
);
2351 static struct sas_function_template mptsas_transport_functions
= {
2352 .get_linkerrors
= mptsas_get_linkerrors
,
2353 .get_enclosure_identifier
= mptsas_get_enclosure_identifier
,
2354 .get_bay_identifier
= mptsas_get_bay_identifier
,
2355 .phy_reset
= mptsas_phy_reset
,
2356 .smp_handler
= mptsas_smp_handler
,
2359 static struct scsi_transport_template
*mptsas_transport_template
;
2362 mptsas_sas_io_unit_pg0(MPT_ADAPTER
*ioc
, struct mptsas_portinfo
*port_info
)
2364 ConfigExtendedPageHeader_t hdr
;
2366 SasIOUnitPage0_t
*buffer
;
2367 dma_addr_t dma_handle
;
2370 hdr
.PageVersion
= MPI_SASIOUNITPAGE0_PAGEVERSION
;
2371 hdr
.ExtPageLength
= 0;
2375 hdr
.PageType
= MPI_CONFIG_PAGETYPE_EXTENDED
;
2376 hdr
.ExtPageType
= MPI_CONFIG_EXTPAGETYPE_SAS_IO_UNIT
;
2378 cfg
.cfghdr
.ehdr
= &hdr
;
2381 cfg
.action
= MPI_CONFIG_ACTION_PAGE_HEADER
;
2382 cfg
.dir
= 0; /* read */
2383 cfg
.timeout
= SAS_CONFIG_PAGE_TIMEOUT
;
2385 error
= mpt_config(ioc
, &cfg
);
2388 if (!hdr
.ExtPageLength
) {
2393 buffer
= pci_alloc_consistent(ioc
->pcidev
, hdr
.ExtPageLength
* 4,
2400 cfg
.physAddr
= dma_handle
;
2401 cfg
.action
= MPI_CONFIG_ACTION_PAGE_READ_CURRENT
;
2403 error
= mpt_config(ioc
, &cfg
);
2405 goto out_free_consistent
;
2407 port_info
->num_phys
= buffer
->NumPhys
;
2408 port_info
->phy_info
= kcalloc(port_info
->num_phys
,
2409 sizeof(struct mptsas_phyinfo
), GFP_KERNEL
);
2410 if (!port_info
->phy_info
) {
2412 goto out_free_consistent
;
2415 ioc
->nvdata_version_persistent
=
2416 le16_to_cpu(buffer
->NvdataVersionPersistent
);
2417 ioc
->nvdata_version_default
=
2418 le16_to_cpu(buffer
->NvdataVersionDefault
);
2420 for (i
= 0; i
< port_info
->num_phys
; i
++) {
2421 mptsas_print_phy_data(ioc
, &buffer
->PhyData
[i
]);
2422 port_info
->phy_info
[i
].phy_id
= i
;
2423 port_info
->phy_info
[i
].port_id
=
2424 buffer
->PhyData
[i
].Port
;
2425 port_info
->phy_info
[i
].negotiated_link_rate
=
2426 buffer
->PhyData
[i
].NegotiatedLinkRate
;
2427 port_info
->phy_info
[i
].portinfo
= port_info
;
2428 port_info
->phy_info
[i
].handle
=
2429 le16_to_cpu(buffer
->PhyData
[i
].ControllerDevHandle
);
2432 out_free_consistent
:
2433 pci_free_consistent(ioc
->pcidev
, hdr
.ExtPageLength
* 4,
2434 buffer
, dma_handle
);
2440 mptsas_sas_io_unit_pg1(MPT_ADAPTER
*ioc
)
2442 ConfigExtendedPageHeader_t hdr
;
2444 SasIOUnitPage1_t
*buffer
;
2445 dma_addr_t dma_handle
;
2447 u8 device_missing_delay
;
2449 memset(&hdr
, 0, sizeof(ConfigExtendedPageHeader_t
));
2450 memset(&cfg
, 0, sizeof(CONFIGPARMS
));
2452 cfg
.cfghdr
.ehdr
= &hdr
;
2453 cfg
.action
= MPI_CONFIG_ACTION_PAGE_HEADER
;
2454 cfg
.timeout
= SAS_CONFIG_PAGE_TIMEOUT
;
2455 cfg
.cfghdr
.ehdr
->PageType
= MPI_CONFIG_PAGETYPE_EXTENDED
;
2456 cfg
.cfghdr
.ehdr
->ExtPageType
= MPI_CONFIG_EXTPAGETYPE_SAS_IO_UNIT
;
2457 cfg
.cfghdr
.ehdr
->PageVersion
= MPI_SASIOUNITPAGE1_PAGEVERSION
;
2458 cfg
.cfghdr
.ehdr
->PageNumber
= 1;
2460 error
= mpt_config(ioc
, &cfg
);
2463 if (!hdr
.ExtPageLength
) {
2468 buffer
= pci_alloc_consistent(ioc
->pcidev
, hdr
.ExtPageLength
* 4,
2475 cfg
.physAddr
= dma_handle
;
2476 cfg
.action
= MPI_CONFIG_ACTION_PAGE_READ_CURRENT
;
2478 error
= mpt_config(ioc
, &cfg
);
2480 goto out_free_consistent
;
2482 ioc
->io_missing_delay
=
2483 le16_to_cpu(buffer
->IODeviceMissingDelay
);
2484 device_missing_delay
= buffer
->ReportDeviceMissingDelay
;
2485 ioc
->device_missing_delay
= (device_missing_delay
& MPI_SAS_IOUNIT1_REPORT_MISSING_UNIT_16
) ?
2486 (device_missing_delay
& MPI_SAS_IOUNIT1_REPORT_MISSING_TIMEOUT_MASK
) * 16 :
2487 device_missing_delay
& MPI_SAS_IOUNIT1_REPORT_MISSING_TIMEOUT_MASK
;
2489 out_free_consistent
:
2490 pci_free_consistent(ioc
->pcidev
, hdr
.ExtPageLength
* 4,
2491 buffer
, dma_handle
);
2497 mptsas_sas_phy_pg0(MPT_ADAPTER
*ioc
, struct mptsas_phyinfo
*phy_info
,
2498 u32 form
, u32 form_specific
)
2500 ConfigExtendedPageHeader_t hdr
;
2502 SasPhyPage0_t
*buffer
;
2503 dma_addr_t dma_handle
;
2506 hdr
.PageVersion
= MPI_SASPHY0_PAGEVERSION
;
2507 hdr
.ExtPageLength
= 0;
2511 hdr
.PageType
= MPI_CONFIG_PAGETYPE_EXTENDED
;
2512 hdr
.ExtPageType
= MPI_CONFIG_EXTPAGETYPE_SAS_PHY
;
2514 cfg
.cfghdr
.ehdr
= &hdr
;
2515 cfg
.dir
= 0; /* read */
2516 cfg
.timeout
= SAS_CONFIG_PAGE_TIMEOUT
;
2518 /* Get Phy Pg 0 for each Phy. */
2520 cfg
.pageAddr
= form
+ form_specific
;
2521 cfg
.action
= MPI_CONFIG_ACTION_PAGE_HEADER
;
2523 error
= mpt_config(ioc
, &cfg
);
2527 if (!hdr
.ExtPageLength
) {
2532 buffer
= pci_alloc_consistent(ioc
->pcidev
, hdr
.ExtPageLength
* 4,
2539 cfg
.physAddr
= dma_handle
;
2540 cfg
.action
= MPI_CONFIG_ACTION_PAGE_READ_CURRENT
;
2542 error
= mpt_config(ioc
, &cfg
);
2544 goto out_free_consistent
;
2546 mptsas_print_phy_pg0(ioc
, buffer
);
2548 phy_info
->hw_link_rate
= buffer
->HwLinkRate
;
2549 phy_info
->programmed_link_rate
= buffer
->ProgrammedLinkRate
;
2550 phy_info
->identify
.handle
= le16_to_cpu(buffer
->OwnerDevHandle
);
2551 phy_info
->attached
.handle
= le16_to_cpu(buffer
->AttachedDevHandle
);
2553 out_free_consistent
:
2554 pci_free_consistent(ioc
->pcidev
, hdr
.ExtPageLength
* 4,
2555 buffer
, dma_handle
);
2561 mptsas_sas_device_pg0(MPT_ADAPTER
*ioc
, struct mptsas_devinfo
*device_info
,
2562 u32 form
, u32 form_specific
)
2564 ConfigExtendedPageHeader_t hdr
;
2566 SasDevicePage0_t
*buffer
;
2567 dma_addr_t dma_handle
;
2571 hdr
.PageVersion
= MPI_SASDEVICE0_PAGEVERSION
;
2572 hdr
.ExtPageLength
= 0;
2576 hdr
.PageType
= MPI_CONFIG_PAGETYPE_EXTENDED
;
2577 hdr
.ExtPageType
= MPI_CONFIG_EXTPAGETYPE_SAS_DEVICE
;
2579 cfg
.cfghdr
.ehdr
= &hdr
;
2580 cfg
.pageAddr
= form
+ form_specific
;
2582 cfg
.action
= MPI_CONFIG_ACTION_PAGE_HEADER
;
2583 cfg
.dir
= 0; /* read */
2584 cfg
.timeout
= SAS_CONFIG_PAGE_TIMEOUT
;
2586 memset(device_info
, 0, sizeof(struct mptsas_devinfo
));
2587 error
= mpt_config(ioc
, &cfg
);
2590 if (!hdr
.ExtPageLength
) {
2595 buffer
= pci_alloc_consistent(ioc
->pcidev
, hdr
.ExtPageLength
* 4,
2602 cfg
.physAddr
= dma_handle
;
2603 cfg
.action
= MPI_CONFIG_ACTION_PAGE_READ_CURRENT
;
2605 error
= mpt_config(ioc
, &cfg
);
2607 if (error
== MPI_IOCSTATUS_CONFIG_INVALID_PAGE
) {
2609 goto out_free_consistent
;
2613 goto out_free_consistent
;
2615 mptsas_print_device_pg0(ioc
, buffer
);
2617 memset(device_info
, 0, sizeof(struct mptsas_devinfo
));
2618 device_info
->handle
= le16_to_cpu(buffer
->DevHandle
);
2619 device_info
->handle_parent
= le16_to_cpu(buffer
->ParentDevHandle
);
2620 device_info
->handle_enclosure
=
2621 le16_to_cpu(buffer
->EnclosureHandle
);
2622 device_info
->slot
= le16_to_cpu(buffer
->Slot
);
2623 device_info
->phy_id
= buffer
->PhyNum
;
2624 device_info
->port_id
= buffer
->PhysicalPort
;
2625 device_info
->id
= buffer
->TargetID
;
2626 device_info
->phys_disk_num
= ~0;
2627 device_info
->channel
= buffer
->Bus
;
2628 memcpy(&sas_address
, &buffer
->SASAddress
, sizeof(__le64
));
2629 device_info
->sas_address
= le64_to_cpu(sas_address
);
2630 device_info
->device_info
=
2631 le32_to_cpu(buffer
->DeviceInfo
);
2632 device_info
->flags
= le16_to_cpu(buffer
->Flags
);
2634 out_free_consistent
:
2635 pci_free_consistent(ioc
->pcidev
, hdr
.ExtPageLength
* 4,
2636 buffer
, dma_handle
);
2642 mptsas_sas_expander_pg0(MPT_ADAPTER
*ioc
, struct mptsas_portinfo
*port_info
,
2643 u32 form
, u32 form_specific
)
2645 ConfigExtendedPageHeader_t hdr
;
2647 SasExpanderPage0_t
*buffer
;
2648 dma_addr_t dma_handle
;
2652 memset(port_info
, 0, sizeof(struct mptsas_portinfo
));
2653 hdr
.PageVersion
= MPI_SASEXPANDER0_PAGEVERSION
;
2654 hdr
.ExtPageLength
= 0;
2658 hdr
.PageType
= MPI_CONFIG_PAGETYPE_EXTENDED
;
2659 hdr
.ExtPageType
= MPI_CONFIG_EXTPAGETYPE_SAS_EXPANDER
;
2661 cfg
.cfghdr
.ehdr
= &hdr
;
2663 cfg
.pageAddr
= form
+ form_specific
;
2664 cfg
.action
= MPI_CONFIG_ACTION_PAGE_HEADER
;
2665 cfg
.dir
= 0; /* read */
2666 cfg
.timeout
= SAS_CONFIG_PAGE_TIMEOUT
;
2668 memset(port_info
, 0, sizeof(struct mptsas_portinfo
));
2669 error
= mpt_config(ioc
, &cfg
);
2673 if (!hdr
.ExtPageLength
) {
2678 buffer
= pci_alloc_consistent(ioc
->pcidev
, hdr
.ExtPageLength
* 4,
2685 cfg
.physAddr
= dma_handle
;
2686 cfg
.action
= MPI_CONFIG_ACTION_PAGE_READ_CURRENT
;
2688 error
= mpt_config(ioc
, &cfg
);
2689 if (error
== MPI_IOCSTATUS_CONFIG_INVALID_PAGE
) {
2691 goto out_free_consistent
;
2695 goto out_free_consistent
;
2697 /* save config data */
2698 port_info
->num_phys
= (buffer
->NumPhys
) ? buffer
->NumPhys
: 1;
2699 port_info
->phy_info
= kcalloc(port_info
->num_phys
,
2700 sizeof(struct mptsas_phyinfo
), GFP_KERNEL
);
2701 if (!port_info
->phy_info
) {
2703 goto out_free_consistent
;
2706 memcpy(&sas_address
, &buffer
->SASAddress
, sizeof(__le64
));
2707 for (i
= 0; i
< port_info
->num_phys
; i
++) {
2708 port_info
->phy_info
[i
].portinfo
= port_info
;
2709 port_info
->phy_info
[i
].handle
=
2710 le16_to_cpu(buffer
->DevHandle
);
2711 port_info
->phy_info
[i
].identify
.sas_address
=
2712 le64_to_cpu(sas_address
);
2713 port_info
->phy_info
[i
].identify
.handle_parent
=
2714 le16_to_cpu(buffer
->ParentDevHandle
);
2717 out_free_consistent
:
2718 pci_free_consistent(ioc
->pcidev
, hdr
.ExtPageLength
* 4,
2719 buffer
, dma_handle
);
2725 mptsas_sas_expander_pg1(MPT_ADAPTER
*ioc
, struct mptsas_phyinfo
*phy_info
,
2726 u32 form
, u32 form_specific
)
2728 ConfigExtendedPageHeader_t hdr
;
2730 SasExpanderPage1_t
*buffer
;
2731 dma_addr_t dma_handle
;
2734 hdr
.PageVersion
= MPI_SASEXPANDER1_PAGEVERSION
;
2735 hdr
.ExtPageLength
= 0;
2739 hdr
.PageType
= MPI_CONFIG_PAGETYPE_EXTENDED
;
2740 hdr
.ExtPageType
= MPI_CONFIG_EXTPAGETYPE_SAS_EXPANDER
;
2742 cfg
.cfghdr
.ehdr
= &hdr
;
2744 cfg
.pageAddr
= form
+ form_specific
;
2745 cfg
.action
= MPI_CONFIG_ACTION_PAGE_HEADER
;
2746 cfg
.dir
= 0; /* read */
2747 cfg
.timeout
= SAS_CONFIG_PAGE_TIMEOUT
;
2749 error
= mpt_config(ioc
, &cfg
);
2753 if (!hdr
.ExtPageLength
) {
2758 buffer
= pci_alloc_consistent(ioc
->pcidev
, hdr
.ExtPageLength
* 4,
2765 cfg
.physAddr
= dma_handle
;
2766 cfg
.action
= MPI_CONFIG_ACTION_PAGE_READ_CURRENT
;
2768 error
= mpt_config(ioc
, &cfg
);
2770 if (error
== MPI_IOCSTATUS_CONFIG_INVALID_PAGE
) {
2772 goto out_free_consistent
;
2776 goto out_free_consistent
;
2779 mptsas_print_expander_pg1(ioc
, buffer
);
2781 /* save config data */
2782 phy_info
->phy_id
= buffer
->PhyIdentifier
;
2783 phy_info
->port_id
= buffer
->PhysicalPort
;
2784 phy_info
->negotiated_link_rate
= buffer
->NegotiatedLinkRate
;
2785 phy_info
->programmed_link_rate
= buffer
->ProgrammedLinkRate
;
2786 phy_info
->hw_link_rate
= buffer
->HwLinkRate
;
2787 phy_info
->identify
.handle
= le16_to_cpu(buffer
->OwnerDevHandle
);
2788 phy_info
->attached
.handle
= le16_to_cpu(buffer
->AttachedDevHandle
);
2790 out_free_consistent
:
2791 pci_free_consistent(ioc
->pcidev
, hdr
.ExtPageLength
* 4,
2792 buffer
, dma_handle
);
2797 struct rep_manu_request
{
2804 struct rep_manu_reply
{
2805 u8 smp_frame_type
; /* 0x41 */
2806 u8 function
; /* 0x01 */
2809 u16 expander_change_count
;
2814 u8 vendor_id
[SAS_EXPANDER_VENDOR_ID_LEN
];
2815 u8 product_id
[SAS_EXPANDER_PRODUCT_ID_LEN
];
2816 u8 product_rev
[SAS_EXPANDER_PRODUCT_REV_LEN
];
2817 u8 component_vendor_id
[SAS_EXPANDER_COMPONENT_VENDOR_ID_LEN
];
2819 u8 component_revision_id
;
2821 u8 vendor_specific
[8];
2825 * mptsas_exp_repmanufacture_info -
2826 * @ioc: per adapter object
2827 * @sas_address: expander sas address
2828 * @edev: the sas_expander_device object
2830 * Fills in the sas_expander_device object when SMP port is created.
2832 * Returns 0 for success, non-zero for failure.
2835 mptsas_exp_repmanufacture_info(MPT_ADAPTER
*ioc
,
2836 u64 sas_address
, struct sas_expander_device
*edev
)
2839 SmpPassthroughRequest_t
*smpreq
;
2840 SmpPassthroughReply_t
*smprep
;
2841 struct rep_manu_reply
*manufacture_reply
;
2842 struct rep_manu_request
*manufacture_request
;
2845 unsigned long timeleft
;
2847 unsigned long flags
;
2848 void *data_out
= NULL
;
2849 dma_addr_t data_out_dma
= 0;
2852 spin_lock_irqsave(&ioc
->taskmgmt_lock
, flags
);
2853 if (ioc
->ioc_reset_in_progress
) {
2854 spin_unlock_irqrestore(&ioc
->taskmgmt_lock
, flags
);
2855 printk(MYIOC_s_INFO_FMT
"%s: host reset in progress!\n",
2856 __func__
, ioc
->name
);
2859 spin_unlock_irqrestore(&ioc
->taskmgmt_lock
, flags
);
2861 ret
= mutex_lock_interruptible(&ioc
->sas_mgmt
.mutex
);
2865 mf
= mpt_get_msg_frame(mptsasMgmtCtx
, ioc
);
2871 smpreq
= (SmpPassthroughRequest_t
*)mf
;
2872 memset(smpreq
, 0, sizeof(*smpreq
));
2874 sz
= sizeof(struct rep_manu_request
) + sizeof(struct rep_manu_reply
);
2876 data_out
= pci_alloc_consistent(ioc
->pcidev
, sz
, &data_out_dma
);
2878 printk(KERN_ERR
"Memory allocation failure at %s:%d/%s()!\n",
2879 __FILE__
, __LINE__
, __func__
);
2884 manufacture_request
= data_out
;
2885 manufacture_request
->smp_frame_type
= 0x40;
2886 manufacture_request
->function
= 1;
2887 manufacture_request
->reserved
= 0;
2888 manufacture_request
->request_length
= 0;
2890 smpreq
->Function
= MPI_FUNCTION_SMP_PASSTHROUGH
;
2891 smpreq
->PhysicalPort
= 0xFF;
2892 *((u64
*)&smpreq
->SASAddress
) = cpu_to_le64(sas_address
);
2893 smpreq
->RequestDataLength
= sizeof(struct rep_manu_request
);
2896 (((int *) mf
) + (offsetof(SmpPassthroughRequest_t
, SGL
) / 4));
2898 flagsLength
= MPI_SGE_FLAGS_SIMPLE_ELEMENT
|
2899 MPI_SGE_FLAGS_SYSTEM_ADDRESS
|
2900 MPI_SGE_FLAGS_HOST_TO_IOC
|
2901 MPI_SGE_FLAGS_END_OF_BUFFER
;
2902 flagsLength
= flagsLength
<< MPI_SGE_FLAGS_SHIFT
;
2903 flagsLength
|= sizeof(struct rep_manu_request
);
2905 ioc
->add_sge(psge
, flagsLength
, data_out_dma
);
2906 psge
+= ioc
->SGE_size
;
2908 flagsLength
= MPI_SGE_FLAGS_SIMPLE_ELEMENT
|
2909 MPI_SGE_FLAGS_SYSTEM_ADDRESS
|
2910 MPI_SGE_FLAGS_IOC_TO_HOST
|
2911 MPI_SGE_FLAGS_END_OF_BUFFER
;
2912 flagsLength
= flagsLength
<< MPI_SGE_FLAGS_SHIFT
;
2913 flagsLength
|= sizeof(struct rep_manu_reply
);
2914 ioc
->add_sge(psge
, flagsLength
, data_out_dma
+
2915 sizeof(struct rep_manu_request
));
2917 INITIALIZE_MGMT_STATUS(ioc
->sas_mgmt
.status
)
2918 mpt_put_msg_frame(mptsasMgmtCtx
, ioc
, mf
);
2920 timeleft
= wait_for_completion_timeout(&ioc
->sas_mgmt
.done
, 10 * HZ
);
2921 if (!(ioc
->sas_mgmt
.status
& MPT_MGMT_STATUS_COMMAND_GOOD
)) {
2923 mpt_free_msg_frame(ioc
, mf
);
2925 if (ioc
->sas_mgmt
.status
& MPT_MGMT_STATUS_DID_IOCRESET
)
2928 mpt_Soft_Hard_ResetHandler(ioc
, CAN_SLEEP
);
2934 if (ioc
->sas_mgmt
.status
& MPT_MGMT_STATUS_RF_VALID
) {
2937 smprep
= (SmpPassthroughReply_t
*)ioc
->sas_mgmt
.reply
;
2938 if (le16_to_cpu(smprep
->ResponseDataLength
) !=
2939 sizeof(struct rep_manu_reply
))
2942 manufacture_reply
= data_out
+ sizeof(struct rep_manu_request
);
2943 strncpy(edev
->vendor_id
, manufacture_reply
->vendor_id
,
2944 SAS_EXPANDER_VENDOR_ID_LEN
);
2945 strncpy(edev
->product_id
, manufacture_reply
->product_id
,
2946 SAS_EXPANDER_PRODUCT_ID_LEN
);
2947 strncpy(edev
->product_rev
, manufacture_reply
->product_rev
,
2948 SAS_EXPANDER_PRODUCT_REV_LEN
);
2949 edev
->level
= manufacture_reply
->sas_format
;
2950 if (manufacture_reply
->sas_format
) {
2951 strncpy(edev
->component_vendor_id
,
2952 manufacture_reply
->component_vendor_id
,
2953 SAS_EXPANDER_COMPONENT_VENDOR_ID_LEN
);
2954 tmp
= (u8
*)&manufacture_reply
->component_id
;
2955 edev
->component_id
= tmp
[0] << 8 | tmp
[1];
2956 edev
->component_revision_id
=
2957 manufacture_reply
->component_revision_id
;
2960 printk(MYIOC_s_ERR_FMT
2961 "%s: smp passthru reply failed to be returned\n",
2962 ioc
->name
, __func__
);
2967 pci_free_consistent(ioc
->pcidev
, sz
, data_out
, data_out_dma
);
2970 mpt_free_msg_frame(ioc
, mf
);
2972 CLEAR_MGMT_STATUS(ioc
->sas_mgmt
.status
)
2973 mutex_unlock(&ioc
->sas_mgmt
.mutex
);
2979 mptsas_parse_device_info(struct sas_identify
*identify
,
2980 struct mptsas_devinfo
*device_info
)
2984 identify
->sas_address
= device_info
->sas_address
;
2985 identify
->phy_identifier
= device_info
->phy_id
;
2988 * Fill in Phy Initiator Port Protocol.
2989 * Bits 6:3, more than one bit can be set, fall through cases.
2991 protocols
= device_info
->device_info
& 0x78;
2992 identify
->initiator_port_protocols
= 0;
2993 if (protocols
& MPI_SAS_DEVICE_INFO_SSP_INITIATOR
)
2994 identify
->initiator_port_protocols
|= SAS_PROTOCOL_SSP
;
2995 if (protocols
& MPI_SAS_DEVICE_INFO_STP_INITIATOR
)
2996 identify
->initiator_port_protocols
|= SAS_PROTOCOL_STP
;
2997 if (protocols
& MPI_SAS_DEVICE_INFO_SMP_INITIATOR
)
2998 identify
->initiator_port_protocols
|= SAS_PROTOCOL_SMP
;
2999 if (protocols
& MPI_SAS_DEVICE_INFO_SATA_HOST
)
3000 identify
->initiator_port_protocols
|= SAS_PROTOCOL_SATA
;
3003 * Fill in Phy Target Port Protocol.
3004 * Bits 10:7, more than one bit can be set, fall through cases.
3006 protocols
= device_info
->device_info
& 0x780;
3007 identify
->target_port_protocols
= 0;
3008 if (protocols
& MPI_SAS_DEVICE_INFO_SSP_TARGET
)
3009 identify
->target_port_protocols
|= SAS_PROTOCOL_SSP
;
3010 if (protocols
& MPI_SAS_DEVICE_INFO_STP_TARGET
)
3011 identify
->target_port_protocols
|= SAS_PROTOCOL_STP
;
3012 if (protocols
& MPI_SAS_DEVICE_INFO_SMP_TARGET
)
3013 identify
->target_port_protocols
|= SAS_PROTOCOL_SMP
;
3014 if (protocols
& MPI_SAS_DEVICE_INFO_SATA_DEVICE
)
3015 identify
->target_port_protocols
|= SAS_PROTOCOL_SATA
;
3018 * Fill in Attached device type.
3020 switch (device_info
->device_info
&
3021 MPI_SAS_DEVICE_INFO_MASK_DEVICE_TYPE
) {
3022 case MPI_SAS_DEVICE_INFO_NO_DEVICE
:
3023 identify
->device_type
= SAS_PHY_UNUSED
;
3025 case MPI_SAS_DEVICE_INFO_END_DEVICE
:
3026 identify
->device_type
= SAS_END_DEVICE
;
3028 case MPI_SAS_DEVICE_INFO_EDGE_EXPANDER
:
3029 identify
->device_type
= SAS_EDGE_EXPANDER_DEVICE
;
3031 case MPI_SAS_DEVICE_INFO_FANOUT_EXPANDER
:
3032 identify
->device_type
= SAS_FANOUT_EXPANDER_DEVICE
;
3037 static int mptsas_probe_one_phy(struct device
*dev
,
3038 struct mptsas_phyinfo
*phy_info
, int index
, int local
)
3041 struct sas_phy
*phy
;
3042 struct sas_port
*port
;
3044 VirtTarget
*vtarget
;
3051 if (!phy_info
->phy
) {
3052 phy
= sas_phy_alloc(dev
, index
);
3058 phy
= phy_info
->phy
;
3060 mptsas_parse_device_info(&phy
->identify
, &phy_info
->identify
);
3063 * Set Negotiated link rate.
3065 switch (phy_info
->negotiated_link_rate
) {
3066 case MPI_SAS_IOUNIT0_RATE_PHY_DISABLED
:
3067 phy
->negotiated_linkrate
= SAS_PHY_DISABLED
;
3069 case MPI_SAS_IOUNIT0_RATE_FAILED_SPEED_NEGOTIATION
:
3070 phy
->negotiated_linkrate
= SAS_LINK_RATE_FAILED
;
3072 case MPI_SAS_IOUNIT0_RATE_1_5
:
3073 phy
->negotiated_linkrate
= SAS_LINK_RATE_1_5_GBPS
;
3075 case MPI_SAS_IOUNIT0_RATE_3_0
:
3076 phy
->negotiated_linkrate
= SAS_LINK_RATE_3_0_GBPS
;
3078 case MPI_SAS_IOUNIT0_RATE_6_0
:
3079 phy
->negotiated_linkrate
= SAS_LINK_RATE_6_0_GBPS
;
3081 case MPI_SAS_IOUNIT0_RATE_SATA_OOB_COMPLETE
:
3082 case MPI_SAS_IOUNIT0_RATE_UNKNOWN
:
3084 phy
->negotiated_linkrate
= SAS_LINK_RATE_UNKNOWN
;
3089 * Set Max hardware link rate.
3091 switch (phy_info
->hw_link_rate
& MPI_SAS_PHY0_PRATE_MAX_RATE_MASK
) {
3092 case MPI_SAS_PHY0_HWRATE_MAX_RATE_1_5
:
3093 phy
->maximum_linkrate_hw
= SAS_LINK_RATE_1_5_GBPS
;
3095 case MPI_SAS_PHY0_PRATE_MAX_RATE_3_0
:
3096 phy
->maximum_linkrate_hw
= SAS_LINK_RATE_3_0_GBPS
;
3103 * Set Max programmed link rate.
3105 switch (phy_info
->programmed_link_rate
&
3106 MPI_SAS_PHY0_PRATE_MAX_RATE_MASK
) {
3107 case MPI_SAS_PHY0_PRATE_MAX_RATE_1_5
:
3108 phy
->maximum_linkrate
= SAS_LINK_RATE_1_5_GBPS
;
3110 case MPI_SAS_PHY0_PRATE_MAX_RATE_3_0
:
3111 phy
->maximum_linkrate
= SAS_LINK_RATE_3_0_GBPS
;
3118 * Set Min hardware link rate.
3120 switch (phy_info
->hw_link_rate
& MPI_SAS_PHY0_HWRATE_MIN_RATE_MASK
) {
3121 case MPI_SAS_PHY0_HWRATE_MIN_RATE_1_5
:
3122 phy
->minimum_linkrate_hw
= SAS_LINK_RATE_1_5_GBPS
;
3124 case MPI_SAS_PHY0_PRATE_MIN_RATE_3_0
:
3125 phy
->minimum_linkrate_hw
= SAS_LINK_RATE_3_0_GBPS
;
3132 * Set Min programmed link rate.
3134 switch (phy_info
->programmed_link_rate
&
3135 MPI_SAS_PHY0_PRATE_MIN_RATE_MASK
) {
3136 case MPI_SAS_PHY0_PRATE_MIN_RATE_1_5
:
3137 phy
->minimum_linkrate
= SAS_LINK_RATE_1_5_GBPS
;
3139 case MPI_SAS_PHY0_PRATE_MIN_RATE_3_0
:
3140 phy
->minimum_linkrate
= SAS_LINK_RATE_3_0_GBPS
;
3146 if (!phy_info
->phy
) {
3148 error
= sas_phy_add(phy
);
3153 phy_info
->phy
= phy
;
3156 if (!phy_info
->attached
.handle
||
3157 !phy_info
->port_details
)
3160 port
= mptsas_get_port(phy_info
);
3161 ioc
= phy_to_ioc(phy_info
->phy
);
3163 if (phy_info
->sas_port_add_phy
) {
3166 port
= sas_port_alloc_num(dev
);
3171 error
= sas_port_add(port
);
3173 dfailprintk(ioc
, printk(MYIOC_s_ERR_FMT
3174 "%s: exit at line=%d\n", ioc
->name
,
3175 __func__
, __LINE__
));
3178 mptsas_set_port(ioc
, phy_info
, port
);
3179 devtprintk(ioc
, dev_printk(KERN_DEBUG
, &port
->dev
,
3180 MYIOC_s_FMT
"add port %d, sas_addr (0x%llx)\n",
3181 ioc
->name
, port
->port_identifier
,
3182 (unsigned long long)phy_info
->
3183 attached
.sas_address
));
3185 dsaswideprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
3186 "sas_port_add_phy: phy_id=%d\n",
3187 ioc
->name
, phy_info
->phy_id
));
3188 sas_port_add_phy(port
, phy_info
->phy
);
3189 phy_info
->sas_port_add_phy
= 0;
3190 devtprintk(ioc
, dev_printk(KERN_DEBUG
, &phy_info
->phy
->dev
,
3191 MYIOC_s_FMT
"add phy %d, phy-obj (0x%p)\n", ioc
->name
,
3192 phy_info
->phy_id
, phy_info
->phy
));
3194 if (!mptsas_get_rphy(phy_info
) && port
&& !port
->rphy
) {
3196 struct sas_rphy
*rphy
;
3197 struct device
*parent
;
3198 struct sas_identify identify
;
3200 parent
= dev
->parent
->parent
;
3202 * Let the hotplug_work thread handle processing
3203 * the adding/removing of devices that occur
3204 * after start of day.
3206 if (mptsas_is_end_device(&phy_info
->attached
) &&
3207 phy_info
->attached
.handle_parent
) {
3211 mptsas_parse_device_info(&identify
, &phy_info
->attached
);
3212 if (scsi_is_host_device(parent
)) {
3213 struct mptsas_portinfo
*port_info
;
3216 port_info
= ioc
->hba_port_info
;
3218 for (i
= 0; i
< port_info
->num_phys
; i
++)
3219 if (port_info
->phy_info
[i
].identify
.sas_address
==
3220 identify
.sas_address
) {
3221 sas_port_mark_backlink(port
);
3225 } else if (scsi_is_sas_rphy(parent
)) {
3226 struct sas_rphy
*parent_rphy
= dev_to_rphy(parent
);
3227 if (identify
.sas_address
==
3228 parent_rphy
->identify
.sas_address
) {
3229 sas_port_mark_backlink(port
);
3234 switch (identify
.device_type
) {
3235 case SAS_END_DEVICE
:
3236 rphy
= sas_end_device_alloc(port
);
3238 case SAS_EDGE_EXPANDER_DEVICE
:
3239 case SAS_FANOUT_EXPANDER_DEVICE
:
3240 rphy
= sas_expander_alloc(port
, identify
.device_type
);
3247 dfailprintk(ioc
, printk(MYIOC_s_ERR_FMT
3248 "%s: exit at line=%d\n", ioc
->name
,
3249 __func__
, __LINE__
));
3253 rphy
->identify
= identify
;
3254 error
= sas_rphy_add(rphy
);
3256 dfailprintk(ioc
, printk(MYIOC_s_ERR_FMT
3257 "%s: exit at line=%d\n", ioc
->name
,
3258 __func__
, __LINE__
));
3259 sas_rphy_free(rphy
);
3262 mptsas_set_rphy(ioc
, phy_info
, rphy
);
3263 if (identify
.device_type
== SAS_EDGE_EXPANDER_DEVICE
||
3264 identify
.device_type
== SAS_FANOUT_EXPANDER_DEVICE
)
3265 mptsas_exp_repmanufacture_info(ioc
,
3266 identify
.sas_address
,
3267 rphy_to_expander_device(rphy
));
3270 /* If the device exists,verify it wasn't previously flagged
3271 as a missing device. If so, clear it */
3272 vtarget
= mptsas_find_vtarget(ioc
,
3273 phy_info
->attached
.channel
,
3274 phy_info
->attached
.id
);
3275 if (vtarget
&& vtarget
->inDMD
) {
3276 printk(KERN_INFO
"Device returned, unsetting inDMD\n");
3285 mptsas_probe_hba_phys(MPT_ADAPTER
*ioc
)
3287 struct mptsas_portinfo
*port_info
, *hba
;
3288 int error
= -ENOMEM
, i
;
3290 hba
= kzalloc(sizeof(struct mptsas_portinfo
), GFP_KERNEL
);
3294 error
= mptsas_sas_io_unit_pg0(ioc
, hba
);
3296 goto out_free_port_info
;
3298 mptsas_sas_io_unit_pg1(ioc
);
3299 mutex_lock(&ioc
->sas_topology_mutex
);
3300 port_info
= ioc
->hba_port_info
;
3302 ioc
->hba_port_info
= port_info
= hba
;
3303 ioc
->hba_port_num_phy
= port_info
->num_phys
;
3304 list_add_tail(&port_info
->list
, &ioc
->sas_topology
);
3306 for (i
= 0; i
< hba
->num_phys
; i
++) {
3307 port_info
->phy_info
[i
].negotiated_link_rate
=
3308 hba
->phy_info
[i
].negotiated_link_rate
;
3309 port_info
->phy_info
[i
].handle
=
3310 hba
->phy_info
[i
].handle
;
3311 port_info
->phy_info
[i
].port_id
=
3312 hba
->phy_info
[i
].port_id
;
3314 kfree(hba
->phy_info
);
3318 mutex_unlock(&ioc
->sas_topology_mutex
);
3319 #if defined(CPQ_CIM)
3320 ioc
->num_ports
= port_info
->num_phys
;
3322 for (i
= 0; i
< port_info
->num_phys
; i
++) {
3323 mptsas_sas_phy_pg0(ioc
, &port_info
->phy_info
[i
],
3324 (MPI_SAS_PHY_PGAD_FORM_PHY_NUMBER
<<
3325 MPI_SAS_PHY_PGAD_FORM_SHIFT
), i
);
3326 port_info
->phy_info
[i
].identify
.handle
=
3327 port_info
->phy_info
[i
].handle
;
3328 mptsas_sas_device_pg0(ioc
, &port_info
->phy_info
[i
].identify
,
3329 (MPI_SAS_DEVICE_PGAD_FORM_HANDLE
<<
3330 MPI_SAS_DEVICE_PGAD_FORM_SHIFT
),
3331 port_info
->phy_info
[i
].identify
.handle
);
3332 if (!ioc
->hba_port_sas_addr
)
3333 ioc
->hba_port_sas_addr
=
3334 port_info
->phy_info
[i
].identify
.sas_address
;
3335 port_info
->phy_info
[i
].identify
.phy_id
=
3336 port_info
->phy_info
[i
].phy_id
= i
;
3337 if (port_info
->phy_info
[i
].attached
.handle
)
3338 mptsas_sas_device_pg0(ioc
,
3339 &port_info
->phy_info
[i
].attached
,
3340 (MPI_SAS_DEVICE_PGAD_FORM_HANDLE
<<
3341 MPI_SAS_DEVICE_PGAD_FORM_SHIFT
),
3342 port_info
->phy_info
[i
].attached
.handle
);
3345 mptsas_setup_wide_ports(ioc
, port_info
);
3347 for (i
= 0; i
< port_info
->num_phys
; i
++, ioc
->sas_index
++)
3348 mptsas_probe_one_phy(&ioc
->sh
->shost_gendev
,
3349 &port_info
->phy_info
[i
], ioc
->sas_index
, 1);
3360 mptsas_expander_refresh(MPT_ADAPTER
*ioc
, struct mptsas_portinfo
*port_info
)
3362 struct mptsas_portinfo
*parent
;
3363 struct device
*parent_dev
;
3364 struct sas_rphy
*rphy
;
3366 u64 sas_address
; /* expander sas address */
3369 handle
= port_info
->phy_info
[0].handle
;
3370 sas_address
= port_info
->phy_info
[0].identify
.sas_address
;
3371 for (i
= 0; i
< port_info
->num_phys
; i
++) {
3372 mptsas_sas_expander_pg1(ioc
, &port_info
->phy_info
[i
],
3373 (MPI_SAS_EXPAND_PGAD_FORM_HANDLE_PHY_NUM
<<
3374 MPI_SAS_EXPAND_PGAD_FORM_SHIFT
), (i
<< 16) + handle
);
3376 mptsas_sas_device_pg0(ioc
,
3377 &port_info
->phy_info
[i
].identify
,
3378 (MPI_SAS_DEVICE_PGAD_FORM_HANDLE
<<
3379 MPI_SAS_DEVICE_PGAD_FORM_SHIFT
),
3380 port_info
->phy_info
[i
].identify
.handle
);
3381 port_info
->phy_info
[i
].identify
.phy_id
=
3382 port_info
->phy_info
[i
].phy_id
;
3384 if (port_info
->phy_info
[i
].attached
.handle
) {
3385 mptsas_sas_device_pg0(ioc
,
3386 &port_info
->phy_info
[i
].attached
,
3387 (MPI_SAS_DEVICE_PGAD_FORM_HANDLE
<<
3388 MPI_SAS_DEVICE_PGAD_FORM_SHIFT
),
3389 port_info
->phy_info
[i
].attached
.handle
);
3390 port_info
->phy_info
[i
].attached
.phy_id
=
3391 port_info
->phy_info
[i
].phy_id
;
3395 mutex_lock(&ioc
->sas_topology_mutex
);
3396 parent
= mptsas_find_portinfo_by_handle(ioc
,
3397 port_info
->phy_info
[0].identify
.handle_parent
);
3399 mutex_unlock(&ioc
->sas_topology_mutex
);
3402 for (i
= 0, parent_dev
= NULL
; i
< parent
->num_phys
&& !parent_dev
;
3404 if (parent
->phy_info
[i
].attached
.sas_address
== sas_address
) {
3405 rphy
= mptsas_get_rphy(&parent
->phy_info
[i
]);
3406 parent_dev
= &rphy
->dev
;
3409 mutex_unlock(&ioc
->sas_topology_mutex
);
3411 mptsas_setup_wide_ports(ioc
, port_info
);
3412 for (i
= 0; i
< port_info
->num_phys
; i
++, ioc
->sas_index
++)
3413 mptsas_probe_one_phy(parent_dev
, &port_info
->phy_info
[i
],
3418 mptsas_expander_event_add(MPT_ADAPTER
*ioc
,
3419 MpiEventDataSasExpanderStatusChange_t
*expander_data
)
3421 struct mptsas_portinfo
*port_info
;
3425 port_info
= kzalloc(sizeof(struct mptsas_portinfo
), GFP_KERNEL
);
3428 port_info
->num_phys
= (expander_data
->NumPhys
) ?
3429 expander_data
->NumPhys
: 1;
3430 port_info
->phy_info
= kcalloc(port_info
->num_phys
,
3431 sizeof(struct mptsas_phyinfo
), GFP_KERNEL
);
3432 if (!port_info
->phy_info
)
3434 memcpy(&sas_address
, &expander_data
->SASAddress
, sizeof(__le64
));
3435 for (i
= 0; i
< port_info
->num_phys
; i
++) {
3436 port_info
->phy_info
[i
].portinfo
= port_info
;
3437 port_info
->phy_info
[i
].handle
=
3438 le16_to_cpu(expander_data
->DevHandle
);
3439 port_info
->phy_info
[i
].identify
.sas_address
=
3440 le64_to_cpu(sas_address
);
3441 port_info
->phy_info
[i
].identify
.handle_parent
=
3442 le16_to_cpu(expander_data
->ParentDevHandle
);
3445 mutex_lock(&ioc
->sas_topology_mutex
);
3446 list_add_tail(&port_info
->list
, &ioc
->sas_topology
);
3447 mutex_unlock(&ioc
->sas_topology_mutex
);
3449 printk(MYIOC_s_INFO_FMT
"add expander: num_phys %d, "
3450 "sas_addr (0x%llx)\n", ioc
->name
, port_info
->num_phys
,
3451 (unsigned long long)sas_address
);
3453 mptsas_expander_refresh(ioc
, port_info
);
3457 * mptsas_delete_expander_siblings - remove siblings attached to expander
3458 * @ioc: Pointer to MPT_ADAPTER structure
3459 * @parent: the parent port_info object
3460 * @expander: the expander port_info object
3463 mptsas_delete_expander_siblings(MPT_ADAPTER
*ioc
, struct mptsas_portinfo
3464 *parent
, struct mptsas_portinfo
*expander
)
3466 struct mptsas_phyinfo
*phy_info
;
3467 struct mptsas_portinfo
*port_info
;
3468 struct sas_rphy
*rphy
;
3471 phy_info
= expander
->phy_info
;
3472 for (i
= 0; i
< expander
->num_phys
; i
++, phy_info
++) {
3473 rphy
= mptsas_get_rphy(phy_info
);
3476 if (rphy
->identify
.device_type
== SAS_END_DEVICE
)
3477 mptsas_del_end_device(ioc
, phy_info
);
3480 phy_info
= expander
->phy_info
;
3481 for (i
= 0; i
< expander
->num_phys
; i
++, phy_info
++) {
3482 rphy
= mptsas_get_rphy(phy_info
);
3485 if (rphy
->identify
.device_type
==
3486 MPI_SAS_DEVICE_INFO_EDGE_EXPANDER
||
3487 rphy
->identify
.device_type
==
3488 MPI_SAS_DEVICE_INFO_FANOUT_EXPANDER
) {
3489 port_info
= mptsas_find_portinfo_by_sas_address(ioc
,
3490 rphy
->identify
.sas_address
);
3493 if (port_info
== parent
) /* backlink rphy */
3496 Delete this expander even if the expdevpage is exists
3497 because the parent expander is already deleted
3499 mptsas_expander_delete(ioc
, port_info
, 1);
3506 * mptsas_expander_delete - remove this expander
3507 * @ioc: Pointer to MPT_ADAPTER structure
3508 * @port_info: expander port_info struct
3509 * @force: Flag to forcefully delete the expander
3513 static void mptsas_expander_delete(MPT_ADAPTER
*ioc
,
3514 struct mptsas_portinfo
*port_info
, u8 force
)
3517 struct mptsas_portinfo
*parent
;
3519 u64 expander_sas_address
;
3520 struct mptsas_phyinfo
*phy_info
;
3521 struct mptsas_portinfo buffer
;
3522 struct mptsas_portinfo_details
*port_details
;
3523 struct sas_port
*port
;
3528 /* see if expander is still there before deleting */
3529 mptsas_sas_expander_pg0(ioc
, &buffer
,
3530 (MPI_SAS_EXPAND_PGAD_FORM_HANDLE
<<
3531 MPI_SAS_EXPAND_PGAD_FORM_SHIFT
),
3532 port_info
->phy_info
[0].identify
.handle
);
3534 if (buffer
.num_phys
) {
3535 kfree(buffer
.phy_info
);
3542 * Obtain the port_info instance to the parent port
3544 port_details
= NULL
;
3545 expander_sas_address
=
3546 port_info
->phy_info
[0].identify
.sas_address
;
3547 parent
= mptsas_find_portinfo_by_handle(ioc
,
3548 port_info
->phy_info
[0].identify
.handle_parent
);
3549 mptsas_delete_expander_siblings(ioc
, parent
, port_info
);
3554 * Delete rphys in the parent that point
3557 phy_info
= parent
->phy_info
;
3559 for (i
= 0; i
< parent
->num_phys
; i
++, phy_info
++) {
3562 if (phy_info
->attached
.sas_address
!=
3563 expander_sas_address
)
3566 port
= mptsas_get_port(phy_info
);
3567 port_details
= phy_info
->port_details
;
3569 dev_printk(KERN_DEBUG
, &phy_info
->phy
->dev
,
3570 MYIOC_s_FMT
"delete phy %d, phy-obj (0x%p)\n", ioc
->name
,
3571 phy_info
->phy_id
, phy_info
->phy
);
3572 sas_port_delete_phy(port
, phy_info
->phy
);
3575 dev_printk(KERN_DEBUG
, &port
->dev
,
3576 MYIOC_s_FMT
"delete port %d, sas_addr (0x%llx)\n",
3577 ioc
->name
, port
->port_identifier
,
3578 (unsigned long long)expander_sas_address
);
3579 sas_port_delete(port
);
3580 mptsas_port_delete(ioc
, port_details
);
3584 printk(MYIOC_s_INFO_FMT
"delete expander: num_phys %d, "
3585 "sas_addr (0x%llx)\n", ioc
->name
, port_info
->num_phys
,
3586 (unsigned long long)expander_sas_address
);
3591 list_del(&port_info
->list
);
3592 kfree(port_info
->phy_info
);
3598 * mptsas_send_expander_event - expanders events
3599 * @ioc: Pointer to MPT_ADAPTER structure
3600 * @expander_data: event data
3603 * This function handles adding, removing, and refreshing
3604 * device handles within the expander objects.
3607 mptsas_send_expander_event(struct fw_event_work
*fw_event
)
3610 MpiEventDataSasExpanderStatusChange_t
*expander_data
;
3611 struct mptsas_portinfo
*port_info
;
3615 ioc
= fw_event
->ioc
;
3616 expander_data
= (MpiEventDataSasExpanderStatusChange_t
*)
3617 fw_event
->event_data
;
3618 memcpy(&sas_address
, &expander_data
->SASAddress
, sizeof(__le64
));
3619 sas_address
= le64_to_cpu(sas_address
);
3620 port_info
= mptsas_find_portinfo_by_sas_address(ioc
, sas_address
);
3622 if (expander_data
->ReasonCode
== MPI_EVENT_SAS_EXP_RC_ADDED
) {
3624 for (i
= 0; i
< port_info
->num_phys
; i
++) {
3625 port_info
->phy_info
[i
].portinfo
= port_info
;
3626 port_info
->phy_info
[i
].handle
=
3627 le16_to_cpu(expander_data
->DevHandle
);
3628 port_info
->phy_info
[i
].identify
.sas_address
=
3629 le64_to_cpu(sas_address
);
3630 port_info
->phy_info
[i
].identify
.handle_parent
=
3631 le16_to_cpu(expander_data
->ParentDevHandle
);
3633 mptsas_expander_refresh(ioc
, port_info
);
3634 } else if (!port_info
&& expander_data
->NumPhys
)
3635 mptsas_expander_event_add(ioc
, expander_data
);
3636 } else if (expander_data
->ReasonCode
==
3637 MPI_EVENT_SAS_EXP_RC_NOT_RESPONDING
)
3638 mptsas_expander_delete(ioc
, port_info
, 0);
3640 mptsas_free_fw_event(ioc
, fw_event
);
3645 * mptsas_expander_add -
3646 * @ioc: Pointer to MPT_ADAPTER structure
3650 static struct mptsas_portinfo
*
3651 mptsas_expander_add(MPT_ADAPTER
*ioc
, u16 handle
)
3653 struct mptsas_portinfo buffer
, *port_info
;
3656 if ((mptsas_sas_expander_pg0(ioc
, &buffer
,
3657 (MPI_SAS_EXPAND_PGAD_FORM_HANDLE
<<
3658 MPI_SAS_EXPAND_PGAD_FORM_SHIFT
), handle
)))
3661 port_info
= kzalloc(sizeof(struct mptsas_portinfo
), GFP_ATOMIC
);
3663 dfailprintk(ioc
, printk(MYIOC_s_ERR_FMT
3664 "%s: exit at line=%d\n", ioc
->name
,
3665 __func__
, __LINE__
));
3668 port_info
->num_phys
= buffer
.num_phys
;
3669 port_info
->phy_info
= buffer
.phy_info
;
3670 for (i
= 0; i
< port_info
->num_phys
; i
++)
3671 port_info
->phy_info
[i
].portinfo
= port_info
;
3672 mutex_lock(&ioc
->sas_topology_mutex
);
3673 list_add_tail(&port_info
->list
, &ioc
->sas_topology
);
3674 mutex_unlock(&ioc
->sas_topology_mutex
);
3675 printk(MYIOC_s_INFO_FMT
"add expander: num_phys %d, "
3676 "sas_addr (0x%llx)\n", ioc
->name
, port_info
->num_phys
,
3677 (unsigned long long)buffer
.phy_info
[0].identify
.sas_address
);
3678 mptsas_expander_refresh(ioc
, port_info
);
3683 mptsas_send_link_status_event(struct fw_event_work
*fw_event
)
3686 MpiEventDataSasPhyLinkStatus_t
*link_data
;
3687 struct mptsas_portinfo
*port_info
;
3688 struct mptsas_phyinfo
*phy_info
= NULL
;
3693 ioc
= fw_event
->ioc
;
3694 link_data
= (MpiEventDataSasPhyLinkStatus_t
*)fw_event
->event_data
;
3696 memcpy(&sas_address
, &link_data
->SASAddress
, sizeof(__le64
));
3697 sas_address
= le64_to_cpu(sas_address
);
3698 link_rate
= link_data
->LinkRates
>> 4;
3699 phy_num
= link_data
->PhyNum
;
3701 port_info
= mptsas_find_portinfo_by_sas_address(ioc
, sas_address
);
3703 phy_info
= &port_info
->phy_info
[phy_num
];
3705 phy_info
->negotiated_link_rate
= link_rate
;
3708 if (link_rate
== MPI_SAS_IOUNIT0_RATE_1_5
||
3709 link_rate
== MPI_SAS_IOUNIT0_RATE_3_0
||
3710 link_rate
== MPI_SAS_IOUNIT0_RATE_6_0
) {
3713 if (ioc
->old_sas_discovery_protocal
) {
3714 port_info
= mptsas_expander_add(ioc
,
3715 le16_to_cpu(link_data
->DevHandle
));
3722 if (port_info
== ioc
->hba_port_info
)
3723 mptsas_probe_hba_phys(ioc
);
3725 mptsas_expander_refresh(ioc
, port_info
);
3726 } else if (phy_info
&& phy_info
->phy
) {
3727 if (link_rate
== MPI_SAS_IOUNIT0_RATE_PHY_DISABLED
)
3728 phy_info
->phy
->negotiated_linkrate
=
3730 else if (link_rate
==
3731 MPI_SAS_IOUNIT0_RATE_FAILED_SPEED_NEGOTIATION
)
3732 phy_info
->phy
->negotiated_linkrate
=
3733 SAS_LINK_RATE_FAILED
;
3735 phy_info
->phy
->negotiated_linkrate
=
3736 SAS_LINK_RATE_UNKNOWN
;
3737 if (ioc
->device_missing_delay
&&
3738 mptsas_is_end_device(&phy_info
->attached
)) {
3739 struct scsi_device
*sdev
;
3740 VirtDevice
*vdevice
;
3742 id
= phy_info
->attached
.id
;
3743 channel
= phy_info
->attached
.channel
;
3744 devtprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
3745 "Link down for fw_id %d:fw_channel %d\n",
3746 ioc
->name
, phy_info
->attached
.id
,
3747 phy_info
->attached
.channel
));
3749 shost_for_each_device(sdev
, ioc
->sh
) {
3750 vdevice
= sdev
->hostdata
;
3751 if ((vdevice
== NULL
) ||
3752 (vdevice
->vtarget
== NULL
))
3754 if ((vdevice
->vtarget
->tflags
&
3755 MPT_TARGET_FLAGS_RAID_COMPONENT
||
3756 vdevice
->vtarget
->raidVolume
))
3758 if (vdevice
->vtarget
->id
== id
&&
3759 vdevice
->vtarget
->channel
==
3762 printk(MYIOC_s_DEBUG_FMT
3763 "SDEV OUTSTANDING CMDS"
3765 atomic_read(&sdev
->device_busy
)));
3772 mptsas_free_fw_event(ioc
, fw_event
);
3776 mptsas_not_responding_devices(MPT_ADAPTER
*ioc
)
3778 struct mptsas_portinfo buffer
, *port_info
;
3779 struct mptsas_device_info
*sas_info
;
3780 struct mptsas_devinfo sas_device
;
3782 VirtTarget
*vtarget
= NULL
;
3783 struct mptsas_phyinfo
*phy_info
;
3785 int retval
, retry_count
;
3786 unsigned long flags
;
3788 mpt_findImVolumes(ioc
);
3790 spin_lock_irqsave(&ioc
->taskmgmt_lock
, flags
);
3791 if (ioc
->ioc_reset_in_progress
) {
3792 dfailprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
3793 "%s: exiting due to a parallel reset \n", ioc
->name
,
3795 spin_unlock_irqrestore(&ioc
->taskmgmt_lock
, flags
);
3798 spin_unlock_irqrestore(&ioc
->taskmgmt_lock
, flags
);
3800 /* devices, logical volumes */
3801 mutex_lock(&ioc
->sas_device_info_mutex
);
3803 list_for_each_entry(sas_info
, &ioc
->sas_device_info_list
, list
) {
3804 if (sas_info
->is_cached
)
3806 if (!sas_info
->is_logical_volume
) {
3807 sas_device
.handle
= 0;
3810 retval
= mptsas_sas_device_pg0(ioc
, &sas_device
,
3811 (MPI_SAS_DEVICE_PGAD_FORM_BUS_TARGET_ID
3812 << MPI_SAS_DEVICE_PGAD_FORM_SHIFT
),
3813 (sas_info
->fw
.channel
<< 8) +
3816 if (sas_device
.handle
)
3818 if (retval
== -EBUSY
) {
3819 spin_lock_irqsave(&ioc
->taskmgmt_lock
, flags
);
3820 if (ioc
->ioc_reset_in_progress
) {
3822 printk(MYIOC_s_DEBUG_FMT
3823 "%s: exiting due to reset\n",
3824 ioc
->name
, __func__
));
3825 spin_unlock_irqrestore
3826 (&ioc
->taskmgmt_lock
, flags
);
3828 sas_device_info_mutex
);
3831 spin_unlock_irqrestore(&ioc
->taskmgmt_lock
,
3835 if (retval
&& (retval
!= -ENODEV
)) {
3836 if (retry_count
< 10) {
3840 devtprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
3841 "%s: Config page retry exceeded retry "
3842 "count deleting device 0x%llx\n",
3843 ioc
->name
, __func__
,
3844 sas_info
->sas_address
));
3849 vtarget
= mptsas_find_vtarget(ioc
,
3850 sas_info
->fw
.channel
, sas_info
->fw
.id
);
3853 vtarget
->deleted
= 1;
3855 phy_info
= mptsas_find_phyinfo_by_sas_address(ioc
,
3856 sas_info
->sas_address
);
3858 mptsas_del_end_device(ioc
, phy_info
);
3859 goto redo_device_scan
;
3861 mptsas_volume_delete(ioc
, sas_info
->fw
.id
);
3863 mutex_unlock(&ioc
->sas_device_info_mutex
);
3866 mutex_lock(&ioc
->sas_topology_mutex
);
3868 list_for_each_entry(port_info
, &ioc
->sas_topology
, list
) {
3870 if (!(port_info
->phy_info
[0].identify
.device_info
&
3871 MPI_SAS_DEVICE_INFO_SMP_TARGET
))
3875 while (!mptsas_sas_expander_pg0(ioc
, &buffer
,
3876 (MPI_SAS_EXPAND_PGAD_FORM_GET_NEXT_HANDLE
<<
3877 MPI_SAS_EXPAND_PGAD_FORM_SHIFT
), handle
) &&
3880 handle
= buffer
.phy_info
[0].handle
;
3881 if (buffer
.phy_info
[0].identify
.sas_address
==
3882 port_info
->phy_info
[0].identify
.sas_address
) {
3885 kfree(buffer
.phy_info
);
3888 if (!found_expander
) {
3889 mptsas_expander_delete(ioc
, port_info
, 0);
3890 goto redo_expander_scan
;
3893 mutex_unlock(&ioc
->sas_topology_mutex
);
3897 * mptsas_probe_expanders - adding expanders
3898 * @ioc: Pointer to MPT_ADAPTER structure
3902 mptsas_probe_expanders(MPT_ADAPTER
*ioc
)
3904 struct mptsas_portinfo buffer
, *port_info
;
3909 while (!mptsas_sas_expander_pg0(ioc
, &buffer
,
3910 (MPI_SAS_EXPAND_PGAD_FORM_GET_NEXT_HANDLE
<<
3911 MPI_SAS_EXPAND_PGAD_FORM_SHIFT
), handle
)) {
3913 handle
= buffer
.phy_info
[0].handle
;
3914 port_info
= mptsas_find_portinfo_by_sas_address(ioc
,
3915 buffer
.phy_info
[0].identify
.sas_address
);
3918 /* refreshing handles */
3919 for (i
= 0; i
< buffer
.num_phys
; i
++) {
3920 port_info
->phy_info
[i
].handle
= handle
;
3921 port_info
->phy_info
[i
].identify
.handle_parent
=
3922 buffer
.phy_info
[0].identify
.handle_parent
;
3924 mptsas_expander_refresh(ioc
, port_info
);
3925 kfree(buffer
.phy_info
);
3929 port_info
= kzalloc(sizeof(struct mptsas_portinfo
), GFP_KERNEL
);
3931 dfailprintk(ioc
, printk(MYIOC_s_ERR_FMT
3932 "%s: exit at line=%d\n", ioc
->name
,
3933 __func__
, __LINE__
));
3936 port_info
->num_phys
= buffer
.num_phys
;
3937 port_info
->phy_info
= buffer
.phy_info
;
3938 for (i
= 0; i
< port_info
->num_phys
; i
++)
3939 port_info
->phy_info
[i
].portinfo
= port_info
;
3940 mutex_lock(&ioc
->sas_topology_mutex
);
3941 list_add_tail(&port_info
->list
, &ioc
->sas_topology
);
3942 mutex_unlock(&ioc
->sas_topology_mutex
);
3943 printk(MYIOC_s_INFO_FMT
"add expander: num_phys %d, "
3944 "sas_addr (0x%llx)\n", ioc
->name
, port_info
->num_phys
,
3945 (unsigned long long)buffer
.phy_info
[0].identify
.sas_address
);
3946 mptsas_expander_refresh(ioc
, port_info
);
3951 mptsas_probe_devices(MPT_ADAPTER
*ioc
)
3954 struct mptsas_devinfo sas_device
;
3955 struct mptsas_phyinfo
*phy_info
;
3958 while (!(mptsas_sas_device_pg0(ioc
, &sas_device
,
3959 MPI_SAS_DEVICE_PGAD_FORM_GET_NEXT_HANDLE
, handle
))) {
3961 handle
= sas_device
.handle
;
3963 if ((sas_device
.device_info
&
3964 (MPI_SAS_DEVICE_INFO_SSP_TARGET
|
3965 MPI_SAS_DEVICE_INFO_STP_TARGET
|
3966 MPI_SAS_DEVICE_INFO_SATA_DEVICE
)) == 0)
3969 /* If there is no FW B_T mapping for this device then continue
3971 if (!(sas_device
.flags
& MPI_SAS_DEVICE0_FLAGS_DEVICE_PRESENT
)
3972 || !(sas_device
.flags
&
3973 MPI_SAS_DEVICE0_FLAGS_DEVICE_MAPPED
))
3976 phy_info
= mptsas_refreshing_device_handles(ioc
, &sas_device
);
3980 if (mptsas_get_rphy(phy_info
))
3983 mptsas_add_end_device(ioc
, phy_info
);
3988 * mptsas_scan_sas_topology -
3989 * @ioc: Pointer to MPT_ADAPTER structure
3994 mptsas_scan_sas_topology(MPT_ADAPTER
*ioc
)
3996 struct scsi_device
*sdev
;
3999 mptsas_probe_hba_phys(ioc
);
4000 mptsas_probe_expanders(ioc
);
4001 mptsas_probe_devices(ioc
);
4004 Reporting RAID volumes.
4006 if (!ioc
->ir_firmware
|| !ioc
->raid_data
.pIocPg2
||
4007 !ioc
->raid_data
.pIocPg2
->NumActiveVolumes
)
4009 for (i
= 0; i
< ioc
->raid_data
.pIocPg2
->NumActiveVolumes
; i
++) {
4010 sdev
= scsi_device_lookup(ioc
->sh
, MPTSAS_RAID_CHANNEL
,
4011 ioc
->raid_data
.pIocPg2
->RaidVolume
[i
].VolumeID
, 0);
4013 scsi_device_put(sdev
);
4016 printk(MYIOC_s_INFO_FMT
"attaching raid volume, channel %d, "
4017 "id %d\n", ioc
->name
, MPTSAS_RAID_CHANNEL
,
4018 ioc
->raid_data
.pIocPg2
->RaidVolume
[i
].VolumeID
);
4019 scsi_add_device(ioc
->sh
, MPTSAS_RAID_CHANNEL
,
4020 ioc
->raid_data
.pIocPg2
->RaidVolume
[i
].VolumeID
, 0);
4026 mptsas_handle_queue_full_event(struct fw_event_work
*fw_event
)
4029 EventDataQueueFull_t
*qfull_data
;
4030 struct mptsas_device_info
*sas_info
;
4031 struct scsi_device
*sdev
;
4035 int fw_id
, fw_channel
;
4039 ioc
= fw_event
->ioc
;
4040 qfull_data
= (EventDataQueueFull_t
*)fw_event
->event_data
;
4041 fw_id
= qfull_data
->TargetID
;
4042 fw_channel
= qfull_data
->Bus
;
4043 current_depth
= le16_to_cpu(qfull_data
->CurrentDepth
);
4045 /* if hidden raid component, look for the volume id */
4046 mutex_lock(&ioc
->sas_device_info_mutex
);
4047 if (mptscsih_is_phys_disk(ioc
, fw_channel
, fw_id
)) {
4048 list_for_each_entry(sas_info
, &ioc
->sas_device_info_list
,
4050 if (sas_info
->is_cached
||
4051 sas_info
->is_logical_volume
)
4053 if (sas_info
->is_hidden_raid_component
&&
4054 (sas_info
->fw
.channel
== fw_channel
&&
4055 sas_info
->fw
.id
== fw_id
)) {
4056 id
= sas_info
->volume_id
;
4057 channel
= MPTSAS_RAID_CHANNEL
;
4062 list_for_each_entry(sas_info
, &ioc
->sas_device_info_list
,
4064 if (sas_info
->is_cached
||
4065 sas_info
->is_hidden_raid_component
||
4066 sas_info
->is_logical_volume
)
4068 if (sas_info
->fw
.channel
== fw_channel
&&
4069 sas_info
->fw
.id
== fw_id
) {
4070 id
= sas_info
->os
.id
;
4071 channel
= sas_info
->os
.channel
;
4079 mutex_unlock(&ioc
->sas_device_info_mutex
);
4082 shost_for_each_device(sdev
, ioc
->sh
) {
4083 if (sdev
->id
== id
&& sdev
->channel
== channel
) {
4084 if (current_depth
> sdev
->queue_depth
) {
4085 sdev_printk(KERN_INFO
, sdev
,
4086 "strange observation, the queue "
4087 "depth is (%d) meanwhile fw queue "
4088 "depth (%d)\n", sdev
->queue_depth
,
4092 depth
= scsi_track_queue_full(sdev
,
4095 sdev_printk(KERN_INFO
, sdev
,
4096 "Queue depth reduced to (%d)\n",
4099 sdev_printk(KERN_INFO
, sdev
,
4100 "Tagged Command Queueing is being "
4102 else if (depth
== 0)
4103 sdev_printk(KERN_INFO
, sdev
,
4104 "Queue depth not changed yet\n");
4109 mptsas_free_fw_event(ioc
, fw_event
);
4113 static struct mptsas_phyinfo
*
4114 mptsas_find_phyinfo_by_sas_address(MPT_ADAPTER
*ioc
, u64 sas_address
)
4116 struct mptsas_portinfo
*port_info
;
4117 struct mptsas_phyinfo
*phy_info
= NULL
;
4120 mutex_lock(&ioc
->sas_topology_mutex
);
4121 list_for_each_entry(port_info
, &ioc
->sas_topology
, list
) {
4122 for (i
= 0; i
< port_info
->num_phys
; i
++) {
4123 if (!mptsas_is_end_device(
4124 &port_info
->phy_info
[i
].attached
))
4126 if (port_info
->phy_info
[i
].attached
.sas_address
4129 phy_info
= &port_info
->phy_info
[i
];
4133 mutex_unlock(&ioc
->sas_topology_mutex
);
4138 * mptsas_find_phyinfo_by_phys_disk_num -
4139 * @ioc: Pointer to MPT_ADAPTER structure
4145 static struct mptsas_phyinfo
*
4146 mptsas_find_phyinfo_by_phys_disk_num(MPT_ADAPTER
*ioc
, u8 phys_disk_num
,
4149 struct mptsas_phyinfo
*phy_info
= NULL
;
4150 struct mptsas_portinfo
*port_info
;
4151 RaidPhysDiskPage1_t
*phys_disk
= NULL
;
4153 u64 sas_address
= 0;
4157 if (!ioc
->raid_data
.pIocPg3
)
4159 /* dual port support */
4160 num_paths
= mpt_raid_phys_disk_get_num_paths(ioc
, phys_disk_num
);
4163 phys_disk
= kzalloc(offsetof(RaidPhysDiskPage1_t
, Path
) +
4164 (num_paths
* sizeof(RAID_PHYS_DISK1_PATH
)), GFP_KERNEL
);
4167 mpt_raid_phys_disk_pg1(ioc
, phys_disk_num
, phys_disk
);
4168 for (i
= 0; i
< num_paths
; i
++) {
4169 if ((phys_disk
->Path
[i
].Flags
& 1) != 0)
4170 /* entry no longer valid */
4172 if ((id
== phys_disk
->Path
[i
].PhysDiskID
) &&
4173 (channel
== phys_disk
->Path
[i
].PhysDiskBus
)) {
4174 memcpy(&sas_address
, &phys_disk
->Path
[i
].WWID
,
4176 phy_info
= mptsas_find_phyinfo_by_sas_address(ioc
,
4188 * Extra code to handle RAID0 case, where the sas_address is not updated
4189 * in phys_disk_page_1 when hotswapped
4191 mutex_lock(&ioc
->sas_topology_mutex
);
4192 list_for_each_entry(port_info
, &ioc
->sas_topology
, list
) {
4193 for (i
= 0; i
< port_info
->num_phys
&& !phy_info
; i
++) {
4194 if (!mptsas_is_end_device(
4195 &port_info
->phy_info
[i
].attached
))
4197 if (port_info
->phy_info
[i
].attached
.phys_disk_num
== ~0)
4199 if ((port_info
->phy_info
[i
].attached
.phys_disk_num
==
4201 (port_info
->phy_info
[i
].attached
.id
== id
) &&
4202 (port_info
->phy_info
[i
].attached
.channel
==
4204 phy_info
= &port_info
->phy_info
[i
];
4207 mutex_unlock(&ioc
->sas_topology_mutex
);
4212 mptsas_reprobe_lun(struct scsi_device
*sdev
, void *data
)
4216 sdev
->no_uld_attach
= data
? 1 : 0;
4217 rc
= scsi_device_reprobe(sdev
);
4221 mptsas_reprobe_target(struct scsi_target
*starget
, int uld_attach
)
4223 starget_for_each_device(starget
, uld_attach
? (void *)1 : NULL
,
4224 mptsas_reprobe_lun
);
4228 mptsas_adding_inactive_raid_components(MPT_ADAPTER
*ioc
, u8 channel
, u8 id
)
4231 ConfigPageHeader_t hdr
;
4232 dma_addr_t dma_handle
;
4233 pRaidVolumePage0_t buffer
= NULL
;
4234 RaidPhysDiskPage0_t phys_disk
;
4236 struct mptsas_phyinfo
*phy_info
;
4237 struct mptsas_devinfo sas_device
;
4239 memset(&cfg
, 0 , sizeof(CONFIGPARMS
));
4240 memset(&hdr
, 0 , sizeof(ConfigPageHeader_t
));
4241 hdr
.PageType
= MPI_CONFIG_PAGETYPE_RAID_VOLUME
;
4242 cfg
.pageAddr
= (channel
<< 8) + id
;
4243 cfg
.cfghdr
.hdr
= &hdr
;
4244 cfg
.action
= MPI_CONFIG_ACTION_PAGE_HEADER
;
4245 cfg
.timeout
= SAS_CONFIG_PAGE_TIMEOUT
;
4247 if (mpt_config(ioc
, &cfg
) != 0)
4250 if (!hdr
.PageLength
)
4253 buffer
= pci_alloc_consistent(ioc
->pcidev
, hdr
.PageLength
* 4,
4259 cfg
.physAddr
= dma_handle
;
4260 cfg
.action
= MPI_CONFIG_ACTION_PAGE_READ_CURRENT
;
4262 if (mpt_config(ioc
, &cfg
) != 0)
4265 if (!(buffer
->VolumeStatus
.Flags
&
4266 MPI_RAIDVOL0_STATUS_FLAG_VOLUME_INACTIVE
))
4269 if (!buffer
->NumPhysDisks
)
4272 for (i
= 0; i
< buffer
->NumPhysDisks
; i
++) {
4274 if (mpt_raid_phys_disk_pg0(ioc
,
4275 buffer
->PhysDisk
[i
].PhysDiskNum
, &phys_disk
) != 0)
4278 if (mptsas_sas_device_pg0(ioc
, &sas_device
,
4279 (MPI_SAS_DEVICE_PGAD_FORM_BUS_TARGET_ID
<<
4280 MPI_SAS_DEVICE_PGAD_FORM_SHIFT
),
4281 (phys_disk
.PhysDiskBus
<< 8) +
4282 phys_disk
.PhysDiskID
))
4285 /* If there is no FW B_T mapping for this device then continue
4287 if (!(sas_device
.flags
& MPI_SAS_DEVICE0_FLAGS_DEVICE_PRESENT
)
4288 || !(sas_device
.flags
&
4289 MPI_SAS_DEVICE0_FLAGS_DEVICE_MAPPED
))
4293 phy_info
= mptsas_find_phyinfo_by_sas_address(ioc
,
4294 sas_device
.sas_address
);
4295 mptsas_add_end_device(ioc
, phy_info
);
4300 pci_free_consistent(ioc
->pcidev
, hdr
.PageLength
* 4, buffer
,
4304 * Work queue thread to handle SAS hotplug events
4307 mptsas_hotplug_work(MPT_ADAPTER
*ioc
, struct fw_event_work
*fw_event
,
4308 struct mptsas_hotplug_event
*hot_plug_info
)
4310 struct mptsas_phyinfo
*phy_info
;
4311 struct scsi_target
* starget
;
4312 struct mptsas_devinfo sas_device
;
4313 VirtTarget
*vtarget
;
4315 struct mptsas_portinfo
*port_info
;
4317 switch (hot_plug_info
->event_type
) {
4319 case MPTSAS_ADD_PHYSDISK
:
4321 if (!ioc
->raid_data
.pIocPg2
)
4324 for (i
= 0; i
< ioc
->raid_data
.pIocPg2
->NumActiveVolumes
; i
++) {
4325 if (ioc
->raid_data
.pIocPg2
->RaidVolume
[i
].VolumeID
==
4326 hot_plug_info
->id
) {
4327 printk(MYIOC_s_WARN_FMT
"firmware bug: unable "
4328 "to add hidden disk - target_id matchs "
4329 "volume_id\n", ioc
->name
);
4330 mptsas_free_fw_event(ioc
, fw_event
);
4334 mpt_findImVolumes(ioc
);
4336 case MPTSAS_ADD_DEVICE
:
4337 memset(&sas_device
, 0, sizeof(struct mptsas_devinfo
));
4338 mptsas_sas_device_pg0(ioc
, &sas_device
,
4339 (MPI_SAS_DEVICE_PGAD_FORM_BUS_TARGET_ID
<<
4340 MPI_SAS_DEVICE_PGAD_FORM_SHIFT
),
4341 (hot_plug_info
->channel
<< 8) +
4344 /* If there is no FW B_T mapping for this device then break
4346 if (!(sas_device
.flags
& MPI_SAS_DEVICE0_FLAGS_DEVICE_PRESENT
)
4347 || !(sas_device
.flags
&
4348 MPI_SAS_DEVICE0_FLAGS_DEVICE_MAPPED
))
4351 if (!sas_device
.handle
)
4354 phy_info
= mptsas_refreshing_device_handles(ioc
, &sas_device
);
4355 /* Only For SATA Device ADD */
4356 if (!phy_info
&& (sas_device
.device_info
&
4357 MPI_SAS_DEVICE_INFO_SATA_DEVICE
)) {
4358 devtprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
4359 "%s %d SATA HOT PLUG: "
4360 "parent handle of device %x\n", ioc
->name
,
4361 __func__
, __LINE__
, sas_device
.handle_parent
));
4362 port_info
= mptsas_find_portinfo_by_handle(ioc
,
4363 sas_device
.handle_parent
);
4365 if (port_info
== ioc
->hba_port_info
)
4366 mptsas_probe_hba_phys(ioc
);
4368 mptsas_expander_refresh(ioc
, port_info
);
4370 dfailprintk(ioc
, printk(MYIOC_s_ERR_FMT
4371 "%s %d port info is NULL\n",
4372 ioc
->name
, __func__
, __LINE__
));
4375 phy_info
= mptsas_refreshing_device_handles
4380 dfailprintk(ioc
, printk(MYIOC_s_ERR_FMT
4381 "%s %d phy info is NULL\n",
4382 ioc
->name
, __func__
, __LINE__
));
4386 if (mptsas_get_rphy(phy_info
))
4389 mptsas_add_end_device(ioc
, phy_info
);
4392 case MPTSAS_DEL_DEVICE
:
4393 phy_info
= mptsas_find_phyinfo_by_sas_address(ioc
,
4394 hot_plug_info
->sas_address
);
4395 mptsas_del_end_device(ioc
, phy_info
);
4398 case MPTSAS_DEL_PHYSDISK
:
4400 mpt_findImVolumes(ioc
);
4402 phy_info
= mptsas_find_phyinfo_by_phys_disk_num(
4403 ioc
, hot_plug_info
->phys_disk_num
,
4404 hot_plug_info
->channel
,
4406 mptsas_del_end_device(ioc
, phy_info
);
4409 case MPTSAS_ADD_PHYSDISK_REPROBE
:
4411 if (mptsas_sas_device_pg0(ioc
, &sas_device
,
4412 (MPI_SAS_DEVICE_PGAD_FORM_BUS_TARGET_ID
<<
4413 MPI_SAS_DEVICE_PGAD_FORM_SHIFT
),
4414 (hot_plug_info
->channel
<< 8) + hot_plug_info
->id
)) {
4415 dfailprintk(ioc
, printk(MYIOC_s_ERR_FMT
4416 "%s: fw_id=%d exit at line=%d\n", ioc
->name
,
4417 __func__
, hot_plug_info
->id
, __LINE__
));
4421 /* If there is no FW B_T mapping for this device then break
4423 if (!(sas_device
.flags
& MPI_SAS_DEVICE0_FLAGS_DEVICE_PRESENT
)
4424 || !(sas_device
.flags
&
4425 MPI_SAS_DEVICE0_FLAGS_DEVICE_MAPPED
))
4428 phy_info
= mptsas_find_phyinfo_by_sas_address(
4429 ioc
, sas_device
.sas_address
);
4432 dfailprintk(ioc
, printk(MYIOC_s_ERR_FMT
4433 "%s: fw_id=%d exit at line=%d\n", ioc
->name
,
4434 __func__
, hot_plug_info
->id
, __LINE__
));
4438 starget
= mptsas_get_starget(phy_info
);
4440 dfailprintk(ioc
, printk(MYIOC_s_ERR_FMT
4441 "%s: fw_id=%d exit at line=%d\n", ioc
->name
,
4442 __func__
, hot_plug_info
->id
, __LINE__
));
4446 vtarget
= starget
->hostdata
;
4448 dfailprintk(ioc
, printk(MYIOC_s_ERR_FMT
4449 "%s: fw_id=%d exit at line=%d\n", ioc
->name
,
4450 __func__
, hot_plug_info
->id
, __LINE__
));
4454 mpt_findImVolumes(ioc
);
4456 starget_printk(KERN_INFO
, starget
, MYIOC_s_FMT
"RAID Hidding: "
4457 "fw_channel=%d, fw_id=%d, physdsk %d, sas_addr 0x%llx\n",
4458 ioc
->name
, hot_plug_info
->channel
, hot_plug_info
->id
,
4459 hot_plug_info
->phys_disk_num
, (unsigned long long)
4460 sas_device
.sas_address
);
4462 vtarget
->id
= hot_plug_info
->phys_disk_num
;
4463 vtarget
->tflags
|= MPT_TARGET_FLAGS_RAID_COMPONENT
;
4464 phy_info
->attached
.phys_disk_num
= hot_plug_info
->phys_disk_num
;
4465 mptsas_reprobe_target(starget
, 1);
4468 case MPTSAS_DEL_PHYSDISK_REPROBE
:
4470 if (mptsas_sas_device_pg0(ioc
, &sas_device
,
4471 (MPI_SAS_DEVICE_PGAD_FORM_BUS_TARGET_ID
<<
4472 MPI_SAS_DEVICE_PGAD_FORM_SHIFT
),
4473 (hot_plug_info
->channel
<< 8) + hot_plug_info
->id
)) {
4474 dfailprintk(ioc
, printk(MYIOC_s_ERR_FMT
4475 "%s: fw_id=%d exit at line=%d\n",
4476 ioc
->name
, __func__
,
4477 hot_plug_info
->id
, __LINE__
));
4481 /* If there is no FW B_T mapping for this device then break
4483 if (!(sas_device
.flags
& MPI_SAS_DEVICE0_FLAGS_DEVICE_PRESENT
)
4484 || !(sas_device
.flags
&
4485 MPI_SAS_DEVICE0_FLAGS_DEVICE_MAPPED
))
4488 phy_info
= mptsas_find_phyinfo_by_sas_address(ioc
,
4489 sas_device
.sas_address
);
4491 dfailprintk(ioc
, printk(MYIOC_s_ERR_FMT
4492 "%s: fw_id=%d exit at line=%d\n", ioc
->name
,
4493 __func__
, hot_plug_info
->id
, __LINE__
));
4497 starget
= mptsas_get_starget(phy_info
);
4499 dfailprintk(ioc
, printk(MYIOC_s_ERR_FMT
4500 "%s: fw_id=%d exit at line=%d\n", ioc
->name
,
4501 __func__
, hot_plug_info
->id
, __LINE__
));
4505 vtarget
= starget
->hostdata
;
4507 dfailprintk(ioc
, printk(MYIOC_s_ERR_FMT
4508 "%s: fw_id=%d exit at line=%d\n", ioc
->name
,
4509 __func__
, hot_plug_info
->id
, __LINE__
));
4513 if (!(vtarget
->tflags
& MPT_TARGET_FLAGS_RAID_COMPONENT
)) {
4514 dfailprintk(ioc
, printk(MYIOC_s_ERR_FMT
4515 "%s: fw_id=%d exit at line=%d\n", ioc
->name
,
4516 __func__
, hot_plug_info
->id
, __LINE__
));
4520 mpt_findImVolumes(ioc
);
4522 starget_printk(KERN_INFO
, starget
, MYIOC_s_FMT
"RAID Exposing:"
4523 " fw_channel=%d, fw_id=%d, physdsk %d, sas_addr 0x%llx\n",
4524 ioc
->name
, hot_plug_info
->channel
, hot_plug_info
->id
,
4525 hot_plug_info
->phys_disk_num
, (unsigned long long)
4526 sas_device
.sas_address
);
4528 vtarget
->tflags
&= ~MPT_TARGET_FLAGS_RAID_COMPONENT
;
4529 vtarget
->id
= hot_plug_info
->id
;
4530 phy_info
->attached
.phys_disk_num
= ~0;
4531 mptsas_reprobe_target(starget
, 0);
4532 mptsas_add_device_component_by_fw(ioc
,
4533 hot_plug_info
->channel
, hot_plug_info
->id
);
4536 case MPTSAS_ADD_RAID
:
4538 mpt_findImVolumes(ioc
);
4539 printk(MYIOC_s_INFO_FMT
"attaching raid volume, channel %d, "
4540 "id %d\n", ioc
->name
, MPTSAS_RAID_CHANNEL
,
4542 scsi_add_device(ioc
->sh
, MPTSAS_RAID_CHANNEL
,
4543 hot_plug_info
->id
, 0);
4546 case MPTSAS_DEL_RAID
:
4548 mpt_findImVolumes(ioc
);
4549 printk(MYIOC_s_INFO_FMT
"removing raid volume, channel %d, "
4550 "id %d\n", ioc
->name
, MPTSAS_RAID_CHANNEL
,
4552 scsi_remove_device(hot_plug_info
->sdev
);
4553 scsi_device_put(hot_plug_info
->sdev
);
4556 case MPTSAS_ADD_INACTIVE_VOLUME
:
4558 mpt_findImVolumes(ioc
);
4559 mptsas_adding_inactive_raid_components(ioc
,
4560 hot_plug_info
->channel
, hot_plug_info
->id
);
4567 mptsas_free_fw_event(ioc
, fw_event
);
4571 mptsas_send_sas_event(struct fw_event_work
*fw_event
)
4574 struct mptsas_hotplug_event hot_plug_info
;
4575 EVENT_DATA_SAS_DEVICE_STATUS_CHANGE
*sas_event_data
;
4579 ioc
= fw_event
->ioc
;
4580 sas_event_data
= (EVENT_DATA_SAS_DEVICE_STATUS_CHANGE
*)
4581 fw_event
->event_data
;
4582 device_info
= le32_to_cpu(sas_event_data
->DeviceInfo
);
4585 (MPI_SAS_DEVICE_INFO_SSP_TARGET
|
4586 MPI_SAS_DEVICE_INFO_STP_TARGET
|
4587 MPI_SAS_DEVICE_INFO_SATA_DEVICE
)) == 0) {
4588 mptsas_free_fw_event(ioc
, fw_event
);
4592 if (sas_event_data
->ReasonCode
==
4593 MPI_EVENT_SAS_DEV_STAT_RC_NO_PERSIST_ADDED
) {
4594 mptbase_sas_persist_operation(ioc
,
4595 MPI_SAS_OP_CLEAR_NOT_PRESENT
);
4596 mptsas_free_fw_event(ioc
, fw_event
);
4600 switch (sas_event_data
->ReasonCode
) {
4601 case MPI_EVENT_SAS_DEV_STAT_RC_NOT_RESPONDING
:
4602 case MPI_EVENT_SAS_DEV_STAT_RC_ADDED
:
4603 memset(&hot_plug_info
, 0, sizeof(struct mptsas_hotplug_event
));
4604 hot_plug_info
.handle
= le16_to_cpu(sas_event_data
->DevHandle
);
4605 hot_plug_info
.channel
= sas_event_data
->Bus
;
4606 hot_plug_info
.id
= sas_event_data
->TargetID
;
4607 hot_plug_info
.phy_id
= sas_event_data
->PhyNum
;
4608 memcpy(&sas_address
, &sas_event_data
->SASAddress
,
4610 hot_plug_info
.sas_address
= le64_to_cpu(sas_address
);
4611 hot_plug_info
.device_info
= device_info
;
4612 if (sas_event_data
->ReasonCode
&
4613 MPI_EVENT_SAS_DEV_STAT_RC_ADDED
)
4614 hot_plug_info
.event_type
= MPTSAS_ADD_DEVICE
;
4616 hot_plug_info
.event_type
= MPTSAS_DEL_DEVICE
;
4617 mptsas_hotplug_work(ioc
, fw_event
, &hot_plug_info
);
4620 case MPI_EVENT_SAS_DEV_STAT_RC_NO_PERSIST_ADDED
:
4621 mptbase_sas_persist_operation(ioc
,
4622 MPI_SAS_OP_CLEAR_NOT_PRESENT
);
4623 mptsas_free_fw_event(ioc
, fw_event
);
4626 case MPI_EVENT_SAS_DEV_STAT_RC_SMART_DATA
:
4628 case MPI_EVENT_SAS_DEV_STAT_RC_INTERNAL_DEVICE_RESET
:
4631 mptsas_free_fw_event(ioc
, fw_event
);
4637 mptsas_send_raid_event(struct fw_event_work
*fw_event
)
4640 EVENT_DATA_RAID
*raid_event_data
;
4641 struct mptsas_hotplug_event hot_plug_info
;
4644 struct scsi_device
*sdev
= NULL
;
4645 VirtDevice
*vdevice
= NULL
;
4646 RaidPhysDiskPage0_t phys_disk
;
4648 ioc
= fw_event
->ioc
;
4649 raid_event_data
= (EVENT_DATA_RAID
*)fw_event
->event_data
;
4650 status
= le32_to_cpu(raid_event_data
->SettingsStatus
);
4651 state
= (status
>> 8) & 0xff;
4653 memset(&hot_plug_info
, 0, sizeof(struct mptsas_hotplug_event
));
4654 hot_plug_info
.id
= raid_event_data
->VolumeID
;
4655 hot_plug_info
.channel
= raid_event_data
->VolumeBus
;
4656 hot_plug_info
.phys_disk_num
= raid_event_data
->PhysDiskNum
;
4658 if (raid_event_data
->ReasonCode
== MPI_EVENT_RAID_RC_VOLUME_DELETED
||
4659 raid_event_data
->ReasonCode
== MPI_EVENT_RAID_RC_VOLUME_CREATED
||
4660 raid_event_data
->ReasonCode
==
4661 MPI_EVENT_RAID_RC_VOLUME_STATUS_CHANGED
) {
4662 sdev
= scsi_device_lookup(ioc
->sh
, MPTSAS_RAID_CHANNEL
,
4663 hot_plug_info
.id
, 0);
4664 hot_plug_info
.sdev
= sdev
;
4666 vdevice
= sdev
->hostdata
;
4669 devtprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"Entering %s: "
4670 "ReasonCode=%02x\n", ioc
->name
, __func__
,
4671 raid_event_data
->ReasonCode
));
4673 switch (raid_event_data
->ReasonCode
) {
4674 case MPI_EVENT_RAID_RC_PHYSDISK_DELETED
:
4675 hot_plug_info
.event_type
= MPTSAS_DEL_PHYSDISK_REPROBE
;
4677 case MPI_EVENT_RAID_RC_PHYSDISK_CREATED
:
4678 hot_plug_info
.event_type
= MPTSAS_ADD_PHYSDISK_REPROBE
;
4680 case MPI_EVENT_RAID_RC_PHYSDISK_STATUS_CHANGED
:
4682 case MPI_PD_STATE_ONLINE
:
4683 case MPI_PD_STATE_NOT_COMPATIBLE
:
4684 mpt_raid_phys_disk_pg0(ioc
,
4685 raid_event_data
->PhysDiskNum
, &phys_disk
);
4686 hot_plug_info
.id
= phys_disk
.PhysDiskID
;
4687 hot_plug_info
.channel
= phys_disk
.PhysDiskBus
;
4688 hot_plug_info
.event_type
= MPTSAS_ADD_PHYSDISK
;
4690 case MPI_PD_STATE_FAILED
:
4691 case MPI_PD_STATE_MISSING
:
4692 case MPI_PD_STATE_OFFLINE_AT_HOST_REQUEST
:
4693 case MPI_PD_STATE_FAILED_AT_HOST_REQUEST
:
4694 case MPI_PD_STATE_OFFLINE_FOR_ANOTHER_REASON
:
4695 hot_plug_info
.event_type
= MPTSAS_DEL_PHYSDISK
;
4701 case MPI_EVENT_RAID_RC_VOLUME_DELETED
:
4704 vdevice
->vtarget
->deleted
= 1; /* block IO */
4705 hot_plug_info
.event_type
= MPTSAS_DEL_RAID
;
4707 case MPI_EVENT_RAID_RC_VOLUME_CREATED
:
4709 scsi_device_put(sdev
);
4712 hot_plug_info
.event_type
= MPTSAS_ADD_RAID
;
4714 case MPI_EVENT_RAID_RC_VOLUME_STATUS_CHANGED
:
4715 if (!(status
& MPI_RAIDVOL0_STATUS_FLAG_ENABLED
)) {
4718 vdevice
->vtarget
->deleted
= 1; /* block IO */
4719 hot_plug_info
.event_type
= MPTSAS_DEL_RAID
;
4723 case MPI_RAIDVOL0_STATUS_STATE_FAILED
:
4724 case MPI_RAIDVOL0_STATUS_STATE_MISSING
:
4727 vdevice
->vtarget
->deleted
= 1; /* block IO */
4728 hot_plug_info
.event_type
= MPTSAS_DEL_RAID
;
4730 case MPI_RAIDVOL0_STATUS_STATE_OPTIMAL
:
4731 case MPI_RAIDVOL0_STATUS_STATE_DEGRADED
:
4733 scsi_device_put(sdev
);
4736 hot_plug_info
.event_type
= MPTSAS_ADD_RAID
;
4746 if (hot_plug_info
.event_type
!= MPTSAS_IGNORE_EVENT
)
4747 mptsas_hotplug_work(ioc
, fw_event
, &hot_plug_info
);
4749 mptsas_free_fw_event(ioc
, fw_event
);
4753 * mptsas_issue_tm - send mptsas internal tm request
4754 * @ioc: Pointer to MPT_ADAPTER structure
4755 * @type: Task Management type
4756 * @channel: channel number for task management
4757 * @id: Logical Target ID for reset (if appropriate)
4758 * @lun: Logical unit for reset (if appropriate)
4759 * @task_context: Context for the task to be aborted
4760 * @timeout: timeout for task management control
4762 * return 0 on success and -1 on failure:
4766 mptsas_issue_tm(MPT_ADAPTER
*ioc
, u8 type
, u8 channel
, u8 id
, u64 lun
,
4767 int task_context
, ulong timeout
, u8
*issue_reset
)
4770 SCSITaskMgmt_t
*pScsiTm
;
4772 unsigned long timeleft
;
4775 mf
= mpt_get_msg_frame(mptsasDeviceResetCtx
, ioc
);
4777 retval
= -1; /* return failure */
4778 dtmprintk(ioc
, printk(MYIOC_s_WARN_FMT
"TaskMgmt request: no "
4779 "msg frames!!\n", ioc
->name
));
4783 dtmprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"TaskMgmt request: mr = %p, "
4784 "task_type = 0x%02X,\n\t timeout = %ld, fw_channel = %d, "
4785 "fw_id = %d, lun = %lld,\n\t task_context = 0x%x\n", ioc
->name
, mf
,
4786 type
, timeout
, channel
, id
, (unsigned long long)lun
,
4789 pScsiTm
= (SCSITaskMgmt_t
*) mf
;
4790 memset(pScsiTm
, 0, sizeof(SCSITaskMgmt_t
));
4791 pScsiTm
->Function
= MPI_FUNCTION_SCSI_TASK_MGMT
;
4792 pScsiTm
->TaskType
= type
;
4793 pScsiTm
->MsgFlags
= 0;
4794 pScsiTm
->TargetID
= id
;
4795 pScsiTm
->Bus
= channel
;
4796 pScsiTm
->ChainOffset
= 0;
4797 pScsiTm
->Reserved
= 0;
4798 pScsiTm
->Reserved1
= 0;
4799 pScsiTm
->TaskMsgContext
= task_context
;
4800 int_to_scsilun(lun
, (struct scsi_lun
*)pScsiTm
->LUN
);
4802 INITIALIZE_MGMT_STATUS(ioc
->taskmgmt_cmds
.status
)
4803 CLEAR_MGMT_STATUS(ioc
->internal_cmds
.status
)
4805 mpt_put_msg_frame_hi_pri(mptsasDeviceResetCtx
, ioc
, mf
);
4807 /* Now wait for the command to complete */
4808 timeleft
= wait_for_completion_timeout(&ioc
->taskmgmt_cmds
.done
,
4810 if (!(ioc
->taskmgmt_cmds
.status
& MPT_MGMT_STATUS_COMMAND_GOOD
)) {
4811 retval
= -1; /* return failure */
4812 dtmprintk(ioc
, printk(MYIOC_s_ERR_FMT
4813 "TaskMgmt request: TIMED OUT!(mr=%p)\n", ioc
->name
, mf
));
4814 mpt_free_msg_frame(ioc
, mf
);
4815 if (ioc
->taskmgmt_cmds
.status
& MPT_MGMT_STATUS_DID_IOCRESET
)
4821 if (!(ioc
->taskmgmt_cmds
.status
& MPT_MGMT_STATUS_RF_VALID
)) {
4822 retval
= -1; /* return failure */
4823 dtmprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
4824 "TaskMgmt request: failed with no reply\n", ioc
->name
));
4829 CLEAR_MGMT_STATUS(ioc
->taskmgmt_cmds
.status
)
4834 * mptsas_broadcast_primative_work - Handle broadcast primitives
4835 * @work: work queue payload containing info describing the event
4837 * this will be handled in workqueue context.
4840 mptsas_broadcast_primative_work(struct fw_event_work
*fw_event
)
4842 MPT_ADAPTER
*ioc
= fw_event
->ioc
;
4844 VirtDevice
*vdevice
;
4846 struct scsi_cmnd
*sc
;
4847 SCSITaskMgmtReply_t
*pScsiTmReply
;
4852 u32 termination_count
;
4855 dtmprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
4856 "%s - enter\n", ioc
->name
, __func__
));
4858 mutex_lock(&ioc
->taskmgmt_cmds
.mutex
);
4859 if (mpt_set_taskmgmt_in_progress_flag(ioc
) != 0) {
4860 mutex_unlock(&ioc
->taskmgmt_cmds
.mutex
);
4861 mptsas_requeue_fw_event(ioc
, fw_event
, 1000);
4866 termination_count
= 0;
4868 mpt_findImVolumes(ioc
);
4869 pScsiTmReply
= (SCSITaskMgmtReply_t
*) ioc
->taskmgmt_cmds
.reply
;
4871 for (ii
= 0; ii
< ioc
->req_depth
; ii
++) {
4872 if (ioc
->fw_events_off
)
4874 sc
= mptscsih_get_scsi_lookup(ioc
, ii
);
4877 mf
= MPT_INDEX_2_MFPTR(ioc
, ii
);
4880 task_context
= mf
->u
.frame
.hwhdr
.msgctxu
.MsgContext
;
4881 vdevice
= sc
->device
->hostdata
;
4882 if (!vdevice
|| !vdevice
->vtarget
)
4884 if (vdevice
->vtarget
->tflags
& MPT_TARGET_FLAGS_RAID_COMPONENT
)
4885 continue; /* skip hidden raid components */
4886 if (vdevice
->vtarget
->raidVolume
)
4887 continue; /* skip hidden raid components */
4888 channel
= vdevice
->vtarget
->channel
;
4889 id
= vdevice
->vtarget
->id
;
4891 if (mptsas_issue_tm(ioc
, MPI_SCSITASKMGMT_TASKTYPE_QUERY_TASK
,
4892 channel
, id
, (u64
)lun
, task_context
, 30, &issue_reset
))
4895 termination_count
+=
4896 le32_to_cpu(pScsiTmReply
->TerminationCount
);
4897 if ((pScsiTmReply
->IOCStatus
== MPI_IOCSTATUS_SUCCESS
) &&
4898 (pScsiTmReply
->ResponseCode
==
4899 MPI_SCSITASKMGMT_RSP_TM_SUCCEEDED
||
4900 pScsiTmReply
->ResponseCode
==
4901 MPI_SCSITASKMGMT_RSP_IO_QUEUED_ON_IOC
))
4903 if (mptsas_issue_tm(ioc
,
4904 MPI_SCSITASKMGMT_TASKTYPE_ABRT_TASK_SET
,
4905 channel
, id
, (u64
)lun
, 0, 30, &issue_reset
))
4907 termination_count
+=
4908 le32_to_cpu(pScsiTmReply
->TerminationCount
);
4912 dtmprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
4913 "%s - exit, query_count = %d termination_count = %d\n",
4914 ioc
->name
, __func__
, query_count
, termination_count
));
4916 ioc
->broadcast_aen_busy
= 0;
4917 mpt_clear_taskmgmt_in_progress_flag(ioc
);
4918 mutex_unlock(&ioc
->taskmgmt_cmds
.mutex
);
4921 printk(MYIOC_s_WARN_FMT
4922 "Issuing Reset from %s!! doorbell=0x%08x\n",
4923 ioc
->name
, __func__
, mpt_GetIocState(ioc
, 0));
4924 mpt_Soft_Hard_ResetHandler(ioc
, CAN_SLEEP
);
4926 mptsas_free_fw_event(ioc
, fw_event
);
4930 * mptsas_send_ir2_event - handle exposing hidden disk when
4931 * an inactive raid volume is added
4933 * @ioc: Pointer to MPT_ADAPTER structure
4938 mptsas_send_ir2_event(struct fw_event_work
*fw_event
)
4941 struct mptsas_hotplug_event hot_plug_info
;
4942 MPI_EVENT_DATA_IR2
*ir2_data
;
4944 RaidPhysDiskPage0_t phys_disk
;
4946 ioc
= fw_event
->ioc
;
4947 ir2_data
= (MPI_EVENT_DATA_IR2
*)fw_event
->event_data
;
4948 reasonCode
= ir2_data
->ReasonCode
;
4950 devtprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"Entering %s: "
4951 "ReasonCode=%02x\n", ioc
->name
, __func__
, reasonCode
));
4953 memset(&hot_plug_info
, 0, sizeof(struct mptsas_hotplug_event
));
4954 hot_plug_info
.id
= ir2_data
->TargetID
;
4955 hot_plug_info
.channel
= ir2_data
->Bus
;
4956 switch (reasonCode
) {
4957 case MPI_EVENT_IR2_RC_FOREIGN_CFG_DETECTED
:
4958 hot_plug_info
.event_type
= MPTSAS_ADD_INACTIVE_VOLUME
;
4960 case MPI_EVENT_IR2_RC_DUAL_PORT_REMOVED
:
4961 hot_plug_info
.phys_disk_num
= ir2_data
->PhysDiskNum
;
4962 hot_plug_info
.event_type
= MPTSAS_DEL_PHYSDISK
;
4964 case MPI_EVENT_IR2_RC_DUAL_PORT_ADDED
:
4965 hot_plug_info
.phys_disk_num
= ir2_data
->PhysDiskNum
;
4966 mpt_raid_phys_disk_pg0(ioc
,
4967 ir2_data
->PhysDiskNum
, &phys_disk
);
4968 hot_plug_info
.id
= phys_disk
.PhysDiskID
;
4969 hot_plug_info
.event_type
= MPTSAS_ADD_PHYSDISK
;
4972 mptsas_free_fw_event(ioc
, fw_event
);
4975 mptsas_hotplug_work(ioc
, fw_event
, &hot_plug_info
);
4979 mptsas_event_process(MPT_ADAPTER
*ioc
, EventNotificationReply_t
*reply
)
4981 u32 event
= le32_to_cpu(reply
->Event
);
4983 struct fw_event_work
*fw_event
;
4984 unsigned long delay
;
4986 if (ioc
->bus_type
!= SAS
)
4989 /* events turned off due to host reset or driver unloading */
4990 if (ioc
->fw_events_off
)
4993 delay
= msecs_to_jiffies(1);
4995 case MPI_EVENT_SAS_BROADCAST_PRIMITIVE
:
4997 EVENT_DATA_SAS_BROADCAST_PRIMITIVE
*broadcast_event_data
=
4998 (EVENT_DATA_SAS_BROADCAST_PRIMITIVE
*)reply
->Data
;
4999 if (broadcast_event_data
->Primitive
!=
5000 MPI_EVENT_PRIMITIVE_ASYNCHRONOUS_EVENT
)
5002 if (ioc
->broadcast_aen_busy
)
5004 ioc
->broadcast_aen_busy
= 1;
5007 case MPI_EVENT_SAS_DEVICE_STATUS_CHANGE
:
5009 EVENT_DATA_SAS_DEVICE_STATUS_CHANGE
*sas_event_data
=
5010 (EVENT_DATA_SAS_DEVICE_STATUS_CHANGE
*)reply
->Data
;
5012 ioc_stat
= le16_to_cpu(reply
->IOCStatus
);
5014 if (sas_event_data
->ReasonCode
==
5015 MPI_EVENT_SAS_DEV_STAT_RC_NOT_RESPONDING
) {
5016 mptsas_target_reset_queue(ioc
, sas_event_data
);
5019 if (sas_event_data
->ReasonCode
==
5020 MPI_EVENT_SAS_DEV_STAT_RC_INTERNAL_DEVICE_RESET
&&
5021 ioc
->device_missing_delay
&&
5022 (ioc_stat
& MPI_IOCSTATUS_FLAG_LOG_INFO_AVAILABLE
)) {
5023 VirtTarget
*vtarget
= NULL
;
5026 id
= sas_event_data
->TargetID
;
5027 channel
= sas_event_data
->Bus
;
5029 vtarget
= mptsas_find_vtarget(ioc
, channel
, id
);
5031 devtprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
5032 "LogInfo (0x%x) available for "
5033 "INTERNAL_DEVICE_RESET"
5034 "fw_id %d fw_channel %d\n", ioc
->name
,
5035 le32_to_cpu(reply
->IOCLogInfo
),
5037 if (vtarget
->raidVolume
) {
5038 devtprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
5039 "Skipping Raid Volume for inDMD\n",
5042 devtprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
5043 "Setting device flag inDMD\n",
5054 case MPI_EVENT_SAS_EXPANDER_STATUS_CHANGE
:
5056 MpiEventDataSasExpanderStatusChange_t
*expander_data
=
5057 (MpiEventDataSasExpanderStatusChange_t
*)reply
->Data
;
5059 if (ioc
->old_sas_discovery_protocal
)
5062 if (expander_data
->ReasonCode
==
5063 MPI_EVENT_SAS_EXP_RC_NOT_RESPONDING
&&
5064 ioc
->device_missing_delay
)
5065 delay
= HZ
* ioc
->device_missing_delay
;
5068 case MPI_EVENT_SAS_DISCOVERY
:
5070 u32 discovery_status
;
5071 EventDataSasDiscovery_t
*discovery_data
=
5072 (EventDataSasDiscovery_t
*)reply
->Data
;
5074 discovery_status
= le32_to_cpu(discovery_data
->DiscoveryStatus
);
5075 ioc
->sas_discovery_quiesce_io
= discovery_status
? 1 : 0;
5076 if (ioc
->old_sas_discovery_protocal
&& !discovery_status
)
5077 mptsas_queue_rescan(ioc
);
5080 case MPI_EVENT_INTEGRATED_RAID
:
5081 case MPI_EVENT_PERSISTENT_TABLE_FULL
:
5083 case MPI_EVENT_SAS_PHY_LINK_STATUS
:
5084 case MPI_EVENT_QUEUE_FULL
:
5090 event_data_sz
= ((reply
->MsgLength
* 4) -
5091 offsetof(EventNotificationReply_t
, Data
));
5092 fw_event
= kzalloc(sizeof(*fw_event
) + event_data_sz
, GFP_ATOMIC
);
5094 printk(MYIOC_s_WARN_FMT
"%s: failed at (line=%d)\n", ioc
->name
,
5095 __func__
, __LINE__
);
5098 memcpy(fw_event
->event_data
, reply
->Data
, event_data_sz
);
5099 fw_event
->event
= event
;
5100 fw_event
->ioc
= ioc
;
5101 mptsas_add_fw_event(ioc
, fw_event
, delay
);
5105 /* Delete a volume when no longer listed in ioc pg2
5107 static void mptsas_volume_delete(MPT_ADAPTER
*ioc
, u8 id
)
5109 struct scsi_device
*sdev
;
5112 sdev
= scsi_device_lookup(ioc
->sh
, MPTSAS_RAID_CHANNEL
, id
, 0);
5115 if (!ioc
->raid_data
.pIocPg2
)
5117 if (!ioc
->raid_data
.pIocPg2
->NumActiveVolumes
)
5119 for (i
= 0; i
< ioc
->raid_data
.pIocPg2
->NumActiveVolumes
; i
++)
5120 if (ioc
->raid_data
.pIocPg2
->RaidVolume
[i
].VolumeID
== id
)
5123 printk(MYIOC_s_INFO_FMT
"removing raid volume, channel %d, "
5124 "id %d\n", ioc
->name
, MPTSAS_RAID_CHANNEL
, id
);
5125 scsi_remove_device(sdev
);
5127 scsi_device_put(sdev
);
5131 mptsas_probe(struct pci_dev
*pdev
, const struct pci_device_id
*id
)
5133 struct Scsi_Host
*sh
;
5136 unsigned long flags
;
5144 r
= mpt_attach(pdev
,id
);
5148 ioc
= pci_get_drvdata(pdev
);
5149 mptsas_fw_event_off(ioc
);
5150 ioc
->DoneCtx
= mptsasDoneCtx
;
5151 ioc
->TaskCtx
= mptsasTaskCtx
;
5152 ioc
->InternalCtx
= mptsasInternalCtx
;
5153 ioc
->schedule_target_reset
= &mptsas_schedule_target_reset
;
5154 ioc
->schedule_dead_ioc_flush_running_cmds
=
5155 &mptscsih_flush_running_cmds
;
5156 /* Added sanity check on readiness of the MPT adapter.
5158 if (ioc
->last_state
!= MPI_IOC_STATE_OPERATIONAL
) {
5159 printk(MYIOC_s_WARN_FMT
5160 "Skipping because it's not operational!\n",
5163 goto out_mptsas_probe
;
5167 printk(MYIOC_s_WARN_FMT
"Skipping because it's disabled!\n",
5170 goto out_mptsas_probe
;
5173 /* Sanity check - ensure at least 1 port is INITIATOR capable
5176 for (ii
= 0; ii
< ioc
->facts
.NumberOfPorts
; ii
++) {
5177 if (ioc
->pfacts
[ii
].ProtocolFlags
&
5178 MPI_PORTFACTS_PROTOCOL_INITIATOR
)
5183 printk(MYIOC_s_WARN_FMT
5184 "Skipping ioc=%p because SCSI Initiator mode "
5185 "is NOT enabled!\n", ioc
->name
, ioc
);
5189 sh
= scsi_host_alloc(&mptsas_driver_template
, sizeof(MPT_SCSI_HOST
));
5191 printk(MYIOC_s_WARN_FMT
5192 "Unable to register controller with SCSI subsystem\n",
5195 goto out_mptsas_probe
;
5198 spin_lock_irqsave(&ioc
->FreeQlock
, flags
);
5200 /* Attach the SCSI Host to the IOC structure
5208 /* set 16 byte cdb's */
5209 sh
->max_cmd_len
= 16;
5210 sh
->can_queue
= min_t(int, ioc
->req_depth
- 10, sh
->can_queue
);
5212 sh
->max_lun
= max_lun
;
5213 sh
->transportt
= mptsas_transport_template
;
5217 sh
->unique_id
= ioc
->id
;
5219 INIT_LIST_HEAD(&ioc
->sas_topology
);
5220 mutex_init(&ioc
->sas_topology_mutex
);
5221 mutex_init(&ioc
->sas_discovery_mutex
);
5222 mutex_init(&ioc
->sas_mgmt
.mutex
);
5223 init_completion(&ioc
->sas_mgmt
.done
);
5225 /* Verify that we won't exceed the maximum
5226 * number of chain buffers
5227 * We can optimize: ZZ = req_sz/sizeof(SGE)
5229 * numSGE = 1 + (ZZ-1)*(maxChain -1) + ZZ
5230 * + (req_sz - 64)/sizeof(SGE)
5231 * A slightly different algorithm is required for
5234 scale
= ioc
->req_sz
/ioc
->SGE_size
;
5235 if (ioc
->sg_addr_size
== sizeof(u64
)) {
5236 numSGE
= (scale
- 1) *
5237 (ioc
->facts
.MaxChainDepth
-1) + scale
+
5238 (ioc
->req_sz
- 60) / ioc
->SGE_size
;
5240 numSGE
= 1 + (scale
- 1) *
5241 (ioc
->facts
.MaxChainDepth
-1) + scale
+
5242 (ioc
->req_sz
- 64) / ioc
->SGE_size
;
5245 if (numSGE
< sh
->sg_tablesize
) {
5246 /* Reset this value */
5247 dprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
5248 "Resetting sg_tablesize to %d from %d\n",
5249 ioc
->name
, numSGE
, sh
->sg_tablesize
));
5250 sh
->sg_tablesize
= numSGE
;
5253 if (mpt_loadtime_max_sectors
) {
5254 if (mpt_loadtime_max_sectors
< 64 ||
5255 mpt_loadtime_max_sectors
> 8192) {
5256 printk(MYIOC_s_INFO_FMT
"Invalid value passed for"
5257 "mpt_loadtime_max_sectors %d."
5258 "Range from 64 to 8192\n", ioc
->name
,
5259 mpt_loadtime_max_sectors
);
5261 mpt_loadtime_max_sectors
&= 0xFFFFFFFE;
5262 dprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
5263 "Resetting max sector to %d from %d\n",
5264 ioc
->name
, mpt_loadtime_max_sectors
, sh
->max_sectors
));
5265 sh
->max_sectors
= mpt_loadtime_max_sectors
;
5268 hd
= shost_priv(sh
);
5271 /* SCSI needs scsi_cmnd lookup table!
5272 * (with size equal to req_depth*PtrSz!)
5274 ioc
->ScsiLookup
= kcalloc(ioc
->req_depth
, sizeof(void *), GFP_ATOMIC
);
5275 if (!ioc
->ScsiLookup
) {
5277 spin_unlock_irqrestore(&ioc
->FreeQlock
, flags
);
5278 goto out_mptsas_probe
;
5280 spin_lock_init(&ioc
->scsi_lookup_lock
);
5282 dprintk(ioc
, printk(MYIOC_s_DEBUG_FMT
"ScsiLookup @ %p\n",
5283 ioc
->name
, ioc
->ScsiLookup
));
5285 ioc
->sas_data
.ptClear
= mpt_pt_clear
;
5287 hd
->last_queue_full
= 0;
5288 INIT_LIST_HEAD(&hd
->target_reset_list
);
5289 INIT_LIST_HEAD(&ioc
->sas_device_info_list
);
5290 mutex_init(&ioc
->sas_device_info_mutex
);
5292 spin_unlock_irqrestore(&ioc
->FreeQlock
, flags
);
5294 if (ioc
->sas_data
.ptClear
==1) {
5295 mptbase_sas_persist_operation(
5296 ioc
, MPI_SAS_OP_CLEAR_ALL_PERSISTENT
);
5299 error
= scsi_add_host(sh
, &ioc
->pcidev
->dev
);
5301 dprintk(ioc
, printk(MYIOC_s_ERR_FMT
5302 "scsi_add_host failed\n", ioc
->name
));
5303 goto out_mptsas_probe
;
5306 /* older firmware doesn't support expander events */
5307 if ((ioc
->facts
.HeaderVersion
>> 8) < 0xE)
5308 ioc
->old_sas_discovery_protocal
= 1;
5309 mptsas_scan_sas_topology(ioc
);
5310 mptsas_fw_event_on(ioc
);
5315 mptscsih_remove(pdev
);
5320 mptsas_shutdown(struct pci_dev
*pdev
)
5322 MPT_ADAPTER
*ioc
= pci_get_drvdata(pdev
);
5324 mptsas_fw_event_off(ioc
);
5325 mptsas_cleanup_fw_event_q(ioc
);
5328 static void mptsas_remove(struct pci_dev
*pdev
)
5330 MPT_ADAPTER
*ioc
= pci_get_drvdata(pdev
);
5331 struct mptsas_portinfo
*p
, *n
;
5335 printk(MYIOC_s_INFO_FMT
"IOC is in Target mode\n", ioc
->name
);
5340 mptsas_shutdown(pdev
);
5342 mptsas_del_device_components(ioc
);
5344 ioc
->sas_discovery_ignore_events
= 1;
5345 sas_remove_host(ioc
->sh
);
5347 mutex_lock(&ioc
->sas_topology_mutex
);
5348 list_for_each_entry_safe(p
, n
, &ioc
->sas_topology
, list
) {
5350 for (i
= 0 ; i
< p
->num_phys
; i
++)
5351 mptsas_port_delete(ioc
, p
->phy_info
[i
].port_details
);
5356 mutex_unlock(&ioc
->sas_topology_mutex
);
5357 ioc
->hba_port_info
= NULL
;
5358 mptscsih_remove(pdev
);
5361 static struct pci_device_id mptsas_pci_table
[] = {
5362 { PCI_VENDOR_ID_LSI_LOGIC
, MPI_MANUFACTPAGE_DEVID_SAS1064
,
5363 PCI_ANY_ID
, PCI_ANY_ID
},
5364 { PCI_VENDOR_ID_LSI_LOGIC
, MPI_MANUFACTPAGE_DEVID_SAS1068
,
5365 PCI_ANY_ID
, PCI_ANY_ID
},
5366 { PCI_VENDOR_ID_LSI_LOGIC
, MPI_MANUFACTPAGE_DEVID_SAS1064E
,
5367 PCI_ANY_ID
, PCI_ANY_ID
},
5368 { PCI_VENDOR_ID_LSI_LOGIC
, MPI_MANUFACTPAGE_DEVID_SAS1068E
,
5369 PCI_ANY_ID
, PCI_ANY_ID
},
5370 { PCI_VENDOR_ID_LSI_LOGIC
, MPI_MANUFACTPAGE_DEVID_SAS1078
,
5371 PCI_ANY_ID
, PCI_ANY_ID
},
5372 { PCI_VENDOR_ID_LSI_LOGIC
, MPI_MANUFACTPAGE_DEVID_SAS1068_820XELP
,
5373 PCI_ANY_ID
, PCI_ANY_ID
},
5374 {0} /* Terminating entry */
5376 MODULE_DEVICE_TABLE(pci
, mptsas_pci_table
);
5379 static struct pci_driver mptsas_driver
= {
5381 .id_table
= mptsas_pci_table
,
5382 .probe
= mptsas_probe
,
5383 .remove
= mptsas_remove
,
5384 .shutdown
= mptsas_shutdown
,
5386 .suspend
= mptscsih_suspend
,
5387 .resume
= mptscsih_resume
,
5396 show_mptmod_ver(my_NAME
, my_VERSION
);
5398 mptsas_transport_template
=
5399 sas_attach_transport(&mptsas_transport_functions
);
5400 if (!mptsas_transport_template
)
5402 mptsas_transport_template
->eh_timed_out
= mptsas_eh_timed_out
;
5404 mptsasDoneCtx
= mpt_register(mptscsih_io_done
, MPTSAS_DRIVER
,
5405 "mptscsih_io_done");
5406 mptsasTaskCtx
= mpt_register(mptscsih_taskmgmt_complete
, MPTSAS_DRIVER
,
5407 "mptscsih_taskmgmt_complete");
5409 mpt_register(mptscsih_scandv_complete
, MPTSAS_DRIVER
,
5410 "mptscsih_scandv_complete");
5411 mptsasMgmtCtx
= mpt_register(mptsas_mgmt_done
, MPTSAS_DRIVER
,
5412 "mptsas_mgmt_done");
5413 mptsasDeviceResetCtx
=
5414 mpt_register(mptsas_taskmgmt_complete
, MPTSAS_DRIVER
,
5415 "mptsas_taskmgmt_complete");
5417 mpt_event_register(mptsasDoneCtx
, mptsas_event_process
);
5418 mpt_reset_register(mptsasDoneCtx
, mptsas_ioc_reset
);
5420 error
= pci_register_driver(&mptsas_driver
);
5422 sas_release_transport(mptsas_transport_template
);
5430 pci_unregister_driver(&mptsas_driver
);
5431 sas_release_transport(mptsas_transport_template
);
5433 mpt_reset_deregister(mptsasDoneCtx
);
5434 mpt_event_deregister(mptsasDoneCtx
);
5436 mpt_deregister(mptsasMgmtCtx
);
5437 mpt_deregister(mptsasInternalCtx
);
5438 mpt_deregister(mptsasTaskCtx
);
5439 mpt_deregister(mptsasDoneCtx
);
5440 mpt_deregister(mptsasDeviceResetCtx
);
5443 module_init(mptsas_init
);
5444 module_exit(mptsas_exit
);