2 * Scsi Host Layer for MPT (Message Passing Technology) based controllers
4 * This code is based on drivers/scsi/mpt3sas/mpt3sas_scsih.c
5 * Copyright (C) 2012-2014 LSI Corporation
6 * Copyright (C) 2013-2014 Avago Technologies
7 * (mailto: MPT-FusionLinux.pdl@avagotech.com)
9 * This program is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU General Public License
11 * as published by the Free Software Foundation; either version 2
12 * of the License, or (at your option) any later version.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
20 * THE PROGRAM IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OR
21 * CONDITIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED INCLUDING, WITHOUT
22 * LIMITATION, ANY WARRANTIES OR CONDITIONS OF TITLE, NON-INFRINGEMENT,
23 * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Each Recipient is
24 * solely responsible for determining the appropriateness of using and
25 * distributing the Program and assumes all risks associated with its
26 * exercise of rights under this Agreement, including but not limited to
27 * the risks and costs of program errors, damage to or loss of data,
28 * programs or equipment, and unavailability or interruption of operations.
30 * DISCLAIMER OF LIABILITY
31 * NEITHER RECIPIENT NOR ANY CONTRIBUTORS SHALL HAVE ANY LIABILITY FOR ANY
32 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
33 * DAMAGES (INCLUDING WITHOUT LIMITATION LOST PROFITS), HOWEVER CAUSED AND
34 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
35 * TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
36 * USE OR DISTRIBUTION OF THE PROGRAM OR THE EXERCISE OF ANY RIGHTS GRANTED
37 * HEREUNDER, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGES
39 * You should have received a copy of the GNU General Public License
40 * along with this program; if not, write to the Free Software
41 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
45 #include <linux/module.h>
46 #include <linux/kernel.h>
47 #include <linux/init.h>
48 #include <linux/errno.h>
49 #include <linux/blkdev.h>
50 #include <linux/sched.h>
51 #include <linux/workqueue.h>
52 #include <linux/delay.h>
53 #include <linux/pci.h>
54 #include <linux/interrupt.h>
55 #include <linux/aer.h>
56 #include <linux/raid_class.h>
58 #include "mpt3sas_base.h"
60 MODULE_AUTHOR(MPT3SAS_AUTHOR);
61 MODULE_DESCRIPTION(MPT3SAS_DESCRIPTION);
62 MODULE_LICENSE("GPL");
63 MODULE_VERSION(MPT3SAS_DRIVER_VERSION);
65 #define RAID_CHANNEL 1
67 static void _scsih_expander_node_remove(struct MPT3SAS_ADAPTER *ioc,
68 struct _sas_node *sas_expander);
69 static void _firmware_event_work(struct work_struct *work);
71 static void _scsih_remove_device(struct MPT3SAS_ADAPTER *ioc,
72 struct _sas_device *sas_device);
73 static int _scsih_add_device(struct MPT3SAS_ADAPTER *ioc, u16 handle,
74 u8 retry_count, u8 is_pd);
76 static u8 _scsih_check_for_pending_tm(struct MPT3SAS_ADAPTER *ioc, u16 smid);
78 static void _scsih_scan_start(struct Scsi_Host *shost);
79 static int _scsih_scan_finished(struct Scsi_Host *shost, unsigned long time);
81 /* global parameters */
82 LIST_HEAD(mpt3sas_ioc_list);
84 /* local parameters */
85 static u8 scsi_io_cb_idx = -1;
86 static u8 tm_cb_idx = -1;
87 static u8 ctl_cb_idx = -1;
88 static u8 base_cb_idx = -1;
89 static u8 port_enable_cb_idx = -1;
90 static u8 transport_cb_idx = -1;
91 static u8 scsih_cb_idx = -1;
92 static u8 config_cb_idx = -1;
95 static u8 tm_tr_cb_idx = -1 ;
96 static u8 tm_tr_volume_cb_idx = -1 ;
97 static u8 tm_sas_control_cb_idx = -1;
99 /* command line options */
100 static u32 logging_level;
101 MODULE_PARM_DESC(logging_level,
102 " bits for enabling additional logging info (default=0)");
105 static ushort max_sectors = 0xFFFF;
106 module_param(max_sectors, ushort, 0);
107 MODULE_PARM_DESC(max_sectors, "max sectors, range 64 to 32767 default=32767");
110 static int missing_delay[2] = {-1, -1};
111 module_param_array(missing_delay, int, NULL, 0);
112 MODULE_PARM_DESC(missing_delay, " device missing delay , io missing delay");
114 /* scsi-mid layer global parmeter is max_report_luns, which is 511 */
115 #define MPT3SAS_MAX_LUN (16895)
116 static u64 max_lun = MPT3SAS_MAX_LUN;
117 module_param(max_lun, ullong, 0);
118 MODULE_PARM_DESC(max_lun, " max lun, default=16895 ");
123 /* diag_buffer_enable is bitwise
125 * bit 1 set = SNAPSHOT
126 * bit 2 set = EXTENDED
128 * Either bit can be set, or both
130 static int diag_buffer_enable = -1;
131 module_param(diag_buffer_enable, int, 0);
132 MODULE_PARM_DESC(diag_buffer_enable,
133 " post diag buffers (TRACE=1/SNAPSHOT=2/EXTENDED=4/default=0)");
134 static int disable_discovery = -1;
135 module_param(disable_discovery, int, 0);
136 MODULE_PARM_DESC(disable_discovery, " disable discovery ");
139 /* permit overriding the host protection capabilities mask (EEDP/T10 PI) */
140 static int prot_mask = -1;
141 module_param(prot_mask, int, 0);
142 MODULE_PARM_DESC(prot_mask, " host protection capabilities mask, def=7 ");
145 /* raid transport support */
147 static struct raid_template *mpt3sas_raid_template;
151 * struct sense_info - common structure for obtaining sense keys
153 * @asc: additional sense code
154 * @ascq: additional sense code qualifier
162 #define MPT3SAS_PROCESS_TRIGGER_DIAG (0xFFFB)
163 #define MPT3SAS_TURN_ON_PFA_LED (0xFFFC)
164 #define MPT3SAS_PORT_ENABLE_COMPLETE (0xFFFD)
165 #define MPT3SAS_ABRT_TASK_SET (0xFFFE)
166 #define MPT3SAS_REMOVE_UNRESPONDING_DEVICES (0xFFFF)
168 * struct fw_event_work - firmware event struct
169 * @list: link list framework
170 * @work: work object (ioc->fault_reset_work_q)
171 * @cancel_pending_work: flag set during reset handling
172 * @ioc: per adapter object
173 * @device_handle: device handle
174 * @VF_ID: virtual function id
175 * @VP_ID: virtual port id
176 * @ignore: flag meaning this event has been marked to ignore
177 * @event: firmware event MPI2_EVENT_XXX defined in mpt2_ioc.h
178 * @refcount: reference count for fw_event_work
179 * @event_data: reply event data payload follows
181 * This object stored on ioc->fw_event_list.
183 struct fw_event_work {
184 struct list_head list;
185 struct work_struct work;
186 u8 cancel_pending_work;
187 struct delayed_work delayed_work;
189 struct MPT3SAS_ADAPTER *ioc;
195 struct kref refcount;
196 char event_data[0] __aligned(4);
199 static void fw_event_work_free(struct kref *r)
201 kfree(container_of(r, struct fw_event_work, refcount));
204 static void fw_event_work_get(struct fw_event_work *fw_work)
206 kref_get(&fw_work->refcount);
209 static void fw_event_work_put(struct fw_event_work *fw_work)
211 kref_put(&fw_work->refcount, fw_event_work_free);
214 static struct fw_event_work *alloc_fw_event_work(int len)
216 struct fw_event_work *fw_event;
218 fw_event = kzalloc(sizeof(*fw_event) + len, GFP_ATOMIC);
222 kref_init(&fw_event->refcount);
226 /* raid transport support */
227 static struct raid_template *mpt3sas_raid_template;
230 * struct _scsi_io_transfer - scsi io transfer
231 * @handle: sas device handle (assigned by firmware)
232 * @is_raid: flag set for hidden raid components
233 * @dir: DMA_TO_DEVICE, DMA_FROM_DEVICE,
234 * @data_length: data transfer length
235 * @data_dma: dma pointer to data
238 * @cdb_length: cdb length
240 * @timeout: timeout for this command
241 * @VF_ID: virtual function id
242 * @VP_ID: virtual port id
243 * @valid_reply: flag set for reply message
244 * @sense_length: sense length
245 * @ioc_status: ioc status
246 * @scsi_state: scsi state
247 * @scsi_status: scsi staus
248 * @log_info: log information
249 * @transfer_length: data length transfer when there is a reply message
251 * Used for sending internal scsi commands to devices within this module.
252 * Refer to _scsi_send_scsi_io().
254 struct _scsi_io_transfer {
257 enum dma_data_direction dir;
260 u8 sense[SCSI_SENSE_BUFFERSIZE];
268 /* the following bits are only valid when 'valid_reply = 1' */
278 * The pci device ids are defined in mpi/mpi2_cnfg.h.
280 static const struct pci_device_id scsih_pci_table[] = {
281 /* Fury ~ 3004 and 3008 */
282 { MPI2_MFGPAGE_VENDORID_LSI, MPI25_MFGPAGE_DEVID_SAS3004,
283 PCI_ANY_ID, PCI_ANY_ID },
284 { MPI2_MFGPAGE_VENDORID_LSI, MPI25_MFGPAGE_DEVID_SAS3008,
285 PCI_ANY_ID, PCI_ANY_ID },
287 { MPI2_MFGPAGE_VENDORID_LSI, MPI25_MFGPAGE_DEVID_SAS3108_1,
288 PCI_ANY_ID, PCI_ANY_ID },
289 { MPI2_MFGPAGE_VENDORID_LSI, MPI25_MFGPAGE_DEVID_SAS3108_2,
290 PCI_ANY_ID, PCI_ANY_ID },
291 { MPI2_MFGPAGE_VENDORID_LSI, MPI25_MFGPAGE_DEVID_SAS3108_5,
292 PCI_ANY_ID, PCI_ANY_ID },
293 { MPI2_MFGPAGE_VENDORID_LSI, MPI25_MFGPAGE_DEVID_SAS3108_6,
294 PCI_ANY_ID, PCI_ANY_ID },
295 {0} /* Terminating entry */
297 MODULE_DEVICE_TABLE(pci, scsih_pci_table);
300 * _scsih_set_debug_level - global setting of ioc->logging_level.
302 * Note: The logging levels are defined in mpt3sas_debug.h.
305 _scsih_set_debug_level(const char *val, struct kernel_param *kp)
307 int ret = param_set_int(val, kp);
308 struct MPT3SAS_ADAPTER *ioc;
313 pr_info("setting logging_level(0x%08x)\n", logging_level);
314 list_for_each_entry(ioc, &mpt3sas_ioc_list, list)
315 ioc->logging_level = logging_level;
318 module_param_call(logging_level, _scsih_set_debug_level, param_get_int,
319 &logging_level, 0644);
322 * _scsih_srch_boot_sas_address - search based on sas_address
323 * @sas_address: sas address
324 * @boot_device: boot device object from bios page 2
326 * Returns 1 when there's a match, 0 means no match.
329 _scsih_srch_boot_sas_address(u64 sas_address,
330 Mpi2BootDeviceSasWwid_t *boot_device)
332 return (sas_address == le64_to_cpu(boot_device->SASAddress)) ? 1 : 0;
336 * _scsih_srch_boot_device_name - search based on device name
337 * @device_name: device name specified in INDENTIFY fram
338 * @boot_device: boot device object from bios page 2
340 * Returns 1 when there's a match, 0 means no match.
343 _scsih_srch_boot_device_name(u64 device_name,
344 Mpi2BootDeviceDeviceName_t *boot_device)
346 return (device_name == le64_to_cpu(boot_device->DeviceName)) ? 1 : 0;
350 * _scsih_srch_boot_encl_slot - search based on enclosure_logical_id/slot
351 * @enclosure_logical_id: enclosure logical id
352 * @slot_number: slot number
353 * @boot_device: boot device object from bios page 2
355 * Returns 1 when there's a match, 0 means no match.
358 _scsih_srch_boot_encl_slot(u64 enclosure_logical_id, u16 slot_number,
359 Mpi2BootDeviceEnclosureSlot_t *boot_device)
361 return (enclosure_logical_id == le64_to_cpu(boot_device->
362 EnclosureLogicalID) && slot_number == le16_to_cpu(boot_device->
363 SlotNumber)) ? 1 : 0;
367 * _scsih_is_boot_device - search for matching boot device.
368 * @sas_address: sas address
369 * @device_name: device name specified in INDENTIFY fram
370 * @enclosure_logical_id: enclosure logical id
371 * @slot_number: slot number
372 * @form: specifies boot device form
373 * @boot_device: boot device object from bios page 2
375 * Returns 1 when there's a match, 0 means no match.
378 _scsih_is_boot_device(u64 sas_address, u64 device_name,
379 u64 enclosure_logical_id, u16 slot, u8 form,
380 Mpi2BiosPage2BootDevice_t *boot_device)
385 case MPI2_BIOSPAGE2_FORM_SAS_WWID:
388 rc = _scsih_srch_boot_sas_address(
389 sas_address, &boot_device->SasWwid);
391 case MPI2_BIOSPAGE2_FORM_ENCLOSURE_SLOT:
392 if (!enclosure_logical_id)
394 rc = _scsih_srch_boot_encl_slot(
395 enclosure_logical_id,
396 slot, &boot_device->EnclosureSlot);
398 case MPI2_BIOSPAGE2_FORM_DEVICE_NAME:
401 rc = _scsih_srch_boot_device_name(
402 device_name, &boot_device->DeviceName);
404 case MPI2_BIOSPAGE2_FORM_NO_DEVICE_SPECIFIED:
412 * _scsih_get_sas_address - set the sas_address for given device handle
413 * @handle: device handle
414 * @sas_address: sas address
416 * Returns 0 success, non-zero when failure
419 _scsih_get_sas_address(struct MPT3SAS_ADAPTER *ioc, u16 handle,
422 Mpi2SasDevicePage0_t sas_device_pg0;
423 Mpi2ConfigReply_t mpi_reply;
428 if (handle <= ioc->sas_hba.num_phys) {
429 *sas_address = ioc->sas_hba.sas_address;
433 if ((mpt3sas_config_get_sas_device_pg0(ioc, &mpi_reply, &sas_device_pg0,
434 MPI2_SAS_DEVICE_PGAD_FORM_HANDLE, handle))) {
435 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n", ioc->name,
436 __FILE__, __LINE__, __func__);
440 ioc_status = le16_to_cpu(mpi_reply.IOCStatus) & MPI2_IOCSTATUS_MASK;
441 if (ioc_status == MPI2_IOCSTATUS_SUCCESS) {
442 *sas_address = le64_to_cpu(sas_device_pg0.SASAddress);
446 /* we hit this becuase the given parent handle doesn't exist */
447 if (ioc_status == MPI2_IOCSTATUS_CONFIG_INVALID_PAGE)
450 /* else error case */
452 "handle(0x%04x), ioc_status(0x%04x), failure at %s:%d/%s()!\n",
453 ioc->name, handle, ioc_status,
454 __FILE__, __LINE__, __func__);
459 * _scsih_determine_boot_device - determine boot device.
460 * @ioc: per adapter object
461 * @device: either sas_device or raid_device object
462 * @is_raid: [flag] 1 = raid object, 0 = sas object
464 * Determines whether this device should be first reported device to
465 * to scsi-ml or sas transport, this purpose is for persistent boot device.
466 * There are primary, alternate, and current entries in bios page 2. The order
467 * priority is primary, alternate, then current. This routine saves
468 * the corresponding device object and is_raid flag in the ioc object.
469 * The saved data to be used later in _scsih_probe_boot_devices().
472 _scsih_determine_boot_device(struct MPT3SAS_ADAPTER *ioc,
473 void *device, u8 is_raid)
475 struct _sas_device *sas_device;
476 struct _raid_device *raid_device;
479 u64 enclosure_logical_id;
482 /* only process this function when driver loads */
483 if (!ioc->is_driver_loading)
486 /* no Bios, return immediately */
487 if (!ioc->bios_pg3.BiosVersion)
492 sas_address = sas_device->sas_address;
493 device_name = sas_device->device_name;
494 enclosure_logical_id = sas_device->enclosure_logical_id;
495 slot = sas_device->slot;
497 raid_device = device;
498 sas_address = raid_device->wwid;
500 enclosure_logical_id = 0;
504 if (!ioc->req_boot_device.device) {
505 if (_scsih_is_boot_device(sas_address, device_name,
506 enclosure_logical_id, slot,
507 (ioc->bios_pg2.ReqBootDeviceForm &
508 MPI2_BIOSPAGE2_FORM_MASK),
509 &ioc->bios_pg2.RequestedBootDevice)) {
510 dinitprintk(ioc, pr_info(MPT3SAS_FMT
511 "%s: req_boot_device(0x%016llx)\n",
513 (unsigned long long)sas_address));
514 ioc->req_boot_device.device = device;
515 ioc->req_boot_device.is_raid = is_raid;
519 if (!ioc->req_alt_boot_device.device) {
520 if (_scsih_is_boot_device(sas_address, device_name,
521 enclosure_logical_id, slot,
522 (ioc->bios_pg2.ReqAltBootDeviceForm &
523 MPI2_BIOSPAGE2_FORM_MASK),
524 &ioc->bios_pg2.RequestedAltBootDevice)) {
525 dinitprintk(ioc, pr_info(MPT3SAS_FMT
526 "%s: req_alt_boot_device(0x%016llx)\n",
528 (unsigned long long)sas_address));
529 ioc->req_alt_boot_device.device = device;
530 ioc->req_alt_boot_device.is_raid = is_raid;
534 if (!ioc->current_boot_device.device) {
535 if (_scsih_is_boot_device(sas_address, device_name,
536 enclosure_logical_id, slot,
537 (ioc->bios_pg2.CurrentBootDeviceForm &
538 MPI2_BIOSPAGE2_FORM_MASK),
539 &ioc->bios_pg2.CurrentBootDevice)) {
540 dinitprintk(ioc, pr_info(MPT3SAS_FMT
541 "%s: current_boot_device(0x%016llx)\n",
543 (unsigned long long)sas_address));
544 ioc->current_boot_device.device = device;
545 ioc->current_boot_device.is_raid = is_raid;
550 static struct _sas_device *
551 __mpt3sas_get_sdev_from_target(struct MPT3SAS_ADAPTER *ioc,
552 struct MPT3SAS_TARGET *tgt_priv)
554 struct _sas_device *ret;
556 assert_spin_locked(&ioc->sas_device_lock);
558 ret = tgt_priv->sdev;
565 static struct _sas_device *
566 mpt3sas_get_sdev_from_target(struct MPT3SAS_ADAPTER *ioc,
567 struct MPT3SAS_TARGET *tgt_priv)
569 struct _sas_device *ret;
572 spin_lock_irqsave(&ioc->sas_device_lock, flags);
573 ret = __mpt3sas_get_sdev_from_target(ioc, tgt_priv);
574 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
580 __mpt3sas_get_sdev_by_addr(struct MPT3SAS_ADAPTER *ioc,
583 struct _sas_device *sas_device;
585 assert_spin_locked(&ioc->sas_device_lock);
587 list_for_each_entry(sas_device, &ioc->sas_device_list, list)
588 if (sas_device->sas_address == sas_address)
591 list_for_each_entry(sas_device, &ioc->sas_device_init_list, list)
592 if (sas_device->sas_address == sas_address)
598 sas_device_get(sas_device);
604 * mpt3sas_get_sdev_by_addr - sas device search
605 * @ioc: per adapter object
606 * @sas_address: sas address
607 * Context: Calling function should acquire ioc->sas_device_lock
609 * This searches for sas_device based on sas_address, then return sas_device
613 mpt3sas_get_sdev_by_addr(struct MPT3SAS_ADAPTER *ioc,
616 struct _sas_device *sas_device;
619 spin_lock_irqsave(&ioc->sas_device_lock, flags);
620 sas_device = __mpt3sas_get_sdev_by_addr(ioc,
622 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
627 static struct _sas_device *
628 __mpt3sas_get_sdev_by_handle(struct MPT3SAS_ADAPTER *ioc, u16 handle)
630 struct _sas_device *sas_device;
632 assert_spin_locked(&ioc->sas_device_lock);
634 list_for_each_entry(sas_device, &ioc->sas_device_list, list)
635 if (sas_device->handle == handle)
638 list_for_each_entry(sas_device, &ioc->sas_device_init_list, list)
639 if (sas_device->handle == handle)
645 sas_device_get(sas_device);
650 * mpt3sas_get_sdev_by_handle - sas device search
651 * @ioc: per adapter object
652 * @handle: sas device handle (assigned by firmware)
653 * Context: Calling function should acquire ioc->sas_device_lock
655 * This searches for sas_device based on sas_address, then return sas_device
658 static struct _sas_device *
659 mpt3sas_get_sdev_by_handle(struct MPT3SAS_ADAPTER *ioc, u16 handle)
661 struct _sas_device *sas_device;
664 spin_lock_irqsave(&ioc->sas_device_lock, flags);
665 sas_device = __mpt3sas_get_sdev_by_handle(ioc, handle);
666 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
672 * _scsih_sas_device_remove - remove sas_device from list.
673 * @ioc: per adapter object
674 * @sas_device: the sas_device object
675 * Context: This function will acquire ioc->sas_device_lock.
677 * If sas_device is on the list, remove it and decrement its reference count.
680 _scsih_sas_device_remove(struct MPT3SAS_ADAPTER *ioc,
681 struct _sas_device *sas_device)
688 "removing handle(0x%04x), sas_addr(0x%016llx)\n",
689 ioc->name, sas_device->handle,
690 (unsigned long long) sas_device->sas_address);
692 if (sas_device->enclosure_handle != 0)
694 "removing enclosure logical id(0x%016llx), slot(%d)\n",
695 ioc->name, (unsigned long long)
696 sas_device->enclosure_logical_id, sas_device->slot);
698 if (sas_device->connector_name[0] != '\0')
700 "removing enclosure level(0x%04x), connector name( %s)\n",
701 ioc->name, sas_device->enclosure_level,
702 sas_device->connector_name);
704 * The lock serializes access to the list, but we still need to verify
705 * that nobody removed the entry while we were waiting on the lock.
707 spin_lock_irqsave(&ioc->sas_device_lock, flags);
708 if (!list_empty(&sas_device->list)) {
709 list_del_init(&sas_device->list);
710 sas_device_put(sas_device);
712 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
716 * _scsih_device_remove_by_handle - removing device object by handle
717 * @ioc: per adapter object
718 * @handle: device handle
723 _scsih_device_remove_by_handle(struct MPT3SAS_ADAPTER *ioc, u16 handle)
725 struct _sas_device *sas_device;
728 if (ioc->shost_recovery)
731 spin_lock_irqsave(&ioc->sas_device_lock, flags);
732 sas_device = __mpt3sas_get_sdev_by_handle(ioc, handle);
734 list_del_init(&sas_device->list);
735 sas_device_put(sas_device);
737 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
740 _scsih_remove_device(ioc, sas_device);
741 sas_device_put(sas_device);
746 * mpt3sas_device_remove_by_sas_address - removing device object by sas address
747 * @ioc: per adapter object
748 * @sas_address: device sas_address
753 mpt3sas_device_remove_by_sas_address(struct MPT3SAS_ADAPTER *ioc,
756 struct _sas_device *sas_device;
759 if (ioc->shost_recovery)
762 spin_lock_irqsave(&ioc->sas_device_lock, flags);
763 sas_device = __mpt3sas_get_sdev_by_addr(ioc, sas_address);
765 list_del_init(&sas_device->list);
766 sas_device_put(sas_device);
768 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
771 _scsih_remove_device(ioc, sas_device);
772 sas_device_put(sas_device);
777 * _scsih_sas_device_add - insert sas_device to the list.
778 * @ioc: per adapter object
779 * @sas_device: the sas_device object
780 * Context: This function will acquire ioc->sas_device_lock.
782 * Adding new object to the ioc->sas_device_list.
785 _scsih_sas_device_add(struct MPT3SAS_ADAPTER *ioc,
786 struct _sas_device *sas_device)
790 dewtprintk(ioc, pr_info(MPT3SAS_FMT
791 "%s: handle(0x%04x), sas_addr(0x%016llx)\n",
792 ioc->name, __func__, sas_device->handle,
793 (unsigned long long)sas_device->sas_address));
795 if (sas_device->enclosure_handle != 0)
796 dewtprintk(ioc, pr_info(MPT3SAS_FMT
797 "%s: enclosure logical id(0x%016llx), slot( %d)\n",
798 ioc->name, __func__, (unsigned long long)
799 sas_device->enclosure_logical_id, sas_device->slot));
801 if (sas_device->connector_name[0] != '\0')
802 dewtprintk(ioc, pr_info(MPT3SAS_FMT
803 "%s: enclosure level(0x%04x), connector name( %s)\n",
805 sas_device->enclosure_level, sas_device->connector_name));
807 spin_lock_irqsave(&ioc->sas_device_lock, flags);
808 sas_device_get(sas_device);
809 list_add_tail(&sas_device->list, &ioc->sas_device_list);
810 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
812 if (!mpt3sas_transport_port_add(ioc, sas_device->handle,
813 sas_device->sas_address_parent)) {
814 _scsih_sas_device_remove(ioc, sas_device);
815 } else if (!sas_device->starget) {
817 * When asyn scanning is enabled, its not possible to remove
818 * devices while scanning is turned on due to an oops in
819 * scsi_sysfs_add_sdev()->add_device()->sysfs_addrm_start()
821 if (!ioc->is_driver_loading) {
822 mpt3sas_transport_port_remove(ioc,
823 sas_device->sas_address,
824 sas_device->sas_address_parent);
825 _scsih_sas_device_remove(ioc, sas_device);
831 * _scsih_sas_device_init_add - insert sas_device to the list.
832 * @ioc: per adapter object
833 * @sas_device: the sas_device object
834 * Context: This function will acquire ioc->sas_device_lock.
836 * Adding new object at driver load time to the ioc->sas_device_init_list.
839 _scsih_sas_device_init_add(struct MPT3SAS_ADAPTER *ioc,
840 struct _sas_device *sas_device)
844 dewtprintk(ioc, pr_info(MPT3SAS_FMT
845 "%s: handle(0x%04x), sas_addr(0x%016llx)\n", ioc->name,
846 __func__, sas_device->handle,
847 (unsigned long long)sas_device->sas_address));
849 if (sas_device->enclosure_handle != 0)
850 dewtprintk(ioc, pr_info(MPT3SAS_FMT
851 "%s: enclosure logical id(0x%016llx), slot( %d)\n",
852 ioc->name, __func__, (unsigned long long)
853 sas_device->enclosure_logical_id, sas_device->slot));
855 if (sas_device->connector_name[0] != '\0')
856 dewtprintk(ioc, pr_info(MPT3SAS_FMT
857 "%s: enclosure level(0x%04x), connector name( %s)\n",
858 ioc->name, __func__, sas_device->enclosure_level,
859 sas_device->connector_name));
861 spin_lock_irqsave(&ioc->sas_device_lock, flags);
862 sas_device_get(sas_device);
863 list_add_tail(&sas_device->list, &ioc->sas_device_init_list);
864 _scsih_determine_boot_device(ioc, sas_device, 0);
865 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
869 * _scsih_raid_device_find_by_id - raid device search
870 * @ioc: per adapter object
871 * @id: sas device target id
872 * @channel: sas device channel
873 * Context: Calling function should acquire ioc->raid_device_lock
875 * This searches for raid_device based on target id, then return raid_device
878 static struct _raid_device *
879 _scsih_raid_device_find_by_id(struct MPT3SAS_ADAPTER *ioc, int id, int channel)
881 struct _raid_device *raid_device, *r;
884 list_for_each_entry(raid_device, &ioc->raid_device_list, list) {
885 if (raid_device->id == id && raid_device->channel == channel) {
896 * _scsih_raid_device_find_by_handle - raid device search
897 * @ioc: per adapter object
898 * @handle: sas device handle (assigned by firmware)
899 * Context: Calling function should acquire ioc->raid_device_lock
901 * This searches for raid_device based on handle, then return raid_device
904 static struct _raid_device *
905 _scsih_raid_device_find_by_handle(struct MPT3SAS_ADAPTER *ioc, u16 handle)
907 struct _raid_device *raid_device, *r;
910 list_for_each_entry(raid_device, &ioc->raid_device_list, list) {
911 if (raid_device->handle != handle)
922 * _scsih_raid_device_find_by_wwid - raid device search
923 * @ioc: per adapter object
924 * @handle: sas device handle (assigned by firmware)
925 * Context: Calling function should acquire ioc->raid_device_lock
927 * This searches for raid_device based on wwid, then return raid_device
930 static struct _raid_device *
931 _scsih_raid_device_find_by_wwid(struct MPT3SAS_ADAPTER *ioc, u64 wwid)
933 struct _raid_device *raid_device, *r;
936 list_for_each_entry(raid_device, &ioc->raid_device_list, list) {
937 if (raid_device->wwid != wwid)
948 * _scsih_raid_device_add - add raid_device object
949 * @ioc: per adapter object
950 * @raid_device: raid_device object
952 * This is added to the raid_device_list link list.
955 _scsih_raid_device_add(struct MPT3SAS_ADAPTER *ioc,
956 struct _raid_device *raid_device)
960 dewtprintk(ioc, pr_info(MPT3SAS_FMT
961 "%s: handle(0x%04x), wwid(0x%016llx)\n", ioc->name, __func__,
962 raid_device->handle, (unsigned long long)raid_device->wwid));
964 spin_lock_irqsave(&ioc->raid_device_lock, flags);
965 list_add_tail(&raid_device->list, &ioc->raid_device_list);
966 spin_unlock_irqrestore(&ioc->raid_device_lock, flags);
970 * _scsih_raid_device_remove - delete raid_device object
971 * @ioc: per adapter object
972 * @raid_device: raid_device object
976 _scsih_raid_device_remove(struct MPT3SAS_ADAPTER *ioc,
977 struct _raid_device *raid_device)
981 spin_lock_irqsave(&ioc->raid_device_lock, flags);
982 list_del(&raid_device->list);
984 spin_unlock_irqrestore(&ioc->raid_device_lock, flags);
988 * mpt3sas_scsih_expander_find_by_handle - expander device search
989 * @ioc: per adapter object
990 * @handle: expander handle (assigned by firmware)
991 * Context: Calling function should acquire ioc->sas_device_lock
993 * This searches for expander device based on handle, then returns the
997 mpt3sas_scsih_expander_find_by_handle(struct MPT3SAS_ADAPTER *ioc, u16 handle)
999 struct _sas_node *sas_expander, *r;
1002 list_for_each_entry(sas_expander, &ioc->sas_expander_list, list) {
1003 if (sas_expander->handle != handle)
1013 * mpt3sas_scsih_expander_find_by_sas_address - expander device search
1014 * @ioc: per adapter object
1015 * @sas_address: sas address
1016 * Context: Calling function should acquire ioc->sas_node_lock.
1018 * This searches for expander device based on sas_address, then returns the
1022 mpt3sas_scsih_expander_find_by_sas_address(struct MPT3SAS_ADAPTER *ioc,
1025 struct _sas_node *sas_expander, *r;
1028 list_for_each_entry(sas_expander, &ioc->sas_expander_list, list) {
1029 if (sas_expander->sas_address != sas_address)
1039 * _scsih_expander_node_add - insert expander device to the list.
1040 * @ioc: per adapter object
1041 * @sas_expander: the sas_device object
1042 * Context: This function will acquire ioc->sas_node_lock.
1044 * Adding new object to the ioc->sas_expander_list.
1049 _scsih_expander_node_add(struct MPT3SAS_ADAPTER *ioc,
1050 struct _sas_node *sas_expander)
1052 unsigned long flags;
1054 spin_lock_irqsave(&ioc->sas_node_lock, flags);
1055 list_add_tail(&sas_expander->list, &ioc->sas_expander_list);
1056 spin_unlock_irqrestore(&ioc->sas_node_lock, flags);
1060 * _scsih_is_end_device - determines if device is an end device
1061 * @device_info: bitfield providing information about the device.
1064 * Returns 1 if end device.
1067 _scsih_is_end_device(u32 device_info)
1069 if (device_info & MPI2_SAS_DEVICE_INFO_END_DEVICE &&
1070 ((device_info & MPI2_SAS_DEVICE_INFO_SSP_TARGET) |
1071 (device_info & MPI2_SAS_DEVICE_INFO_STP_TARGET) |
1072 (device_info & MPI2_SAS_DEVICE_INFO_SATA_DEVICE)))
1079 * _scsih_scsi_lookup_get - returns scmd entry
1080 * @ioc: per adapter object
1081 * @smid: system request message index
1083 * Returns the smid stored scmd pointer.
1085 static struct scsi_cmnd *
1086 _scsih_scsi_lookup_get(struct MPT3SAS_ADAPTER *ioc, u16 smid)
1088 return ioc->scsi_lookup[smid - 1].scmd;
1092 * _scsih_scsi_lookup_get_clear - returns scmd entry
1093 * @ioc: per adapter object
1094 * @smid: system request message index
1096 * Returns the smid stored scmd pointer.
1097 * Then will derefrence the stored scmd pointer.
1099 static inline struct scsi_cmnd *
1100 _scsih_scsi_lookup_get_clear(struct MPT3SAS_ADAPTER *ioc, u16 smid)
1102 unsigned long flags;
1103 struct scsi_cmnd *scmd;
1105 spin_lock_irqsave(&ioc->scsi_lookup_lock, flags);
1106 scmd = ioc->scsi_lookup[smid - 1].scmd;
1107 ioc->scsi_lookup[smid - 1].scmd = NULL;
1108 spin_unlock_irqrestore(&ioc->scsi_lookup_lock, flags);
1114 * _scsih_scsi_lookup_find_by_scmd - scmd lookup
1115 * @ioc: per adapter object
1116 * @smid: system request message index
1117 * @scmd: pointer to scsi command object
1118 * Context: This function will acquire ioc->scsi_lookup_lock.
1120 * This will search for a scmd pointer in the scsi_lookup array,
1121 * returning the revelent smid. A returned value of zero means invalid.
1124 _scsih_scsi_lookup_find_by_scmd(struct MPT3SAS_ADAPTER *ioc, struct scsi_cmnd
1128 unsigned long flags;
1131 spin_lock_irqsave(&ioc->scsi_lookup_lock, flags);
1133 for (i = 0; i < ioc->scsiio_depth; i++) {
1134 if (ioc->scsi_lookup[i].scmd == scmd) {
1135 smid = ioc->scsi_lookup[i].smid;
1140 spin_unlock_irqrestore(&ioc->scsi_lookup_lock, flags);
1145 * _scsih_scsi_lookup_find_by_target - search for matching channel:id
1146 * @ioc: per adapter object
1149 * Context: This function will acquire ioc->scsi_lookup_lock.
1151 * This will search for a matching channel:id in the scsi_lookup array,
1152 * returning 1 if found.
1155 _scsih_scsi_lookup_find_by_target(struct MPT3SAS_ADAPTER *ioc, int id,
1159 unsigned long flags;
1162 spin_lock_irqsave(&ioc->scsi_lookup_lock, flags);
1164 for (i = 0 ; i < ioc->scsiio_depth; i++) {
1165 if (ioc->scsi_lookup[i].scmd &&
1166 (ioc->scsi_lookup[i].scmd->device->id == id &&
1167 ioc->scsi_lookup[i].scmd->device->channel == channel)) {
1173 spin_unlock_irqrestore(&ioc->scsi_lookup_lock, flags);
1178 * _scsih_scsi_lookup_find_by_lun - search for matching channel:id:lun
1179 * @ioc: per adapter object
1183 * Context: This function will acquire ioc->scsi_lookup_lock.
1185 * This will search for a matching channel:id:lun in the scsi_lookup array,
1186 * returning 1 if found.
1189 _scsih_scsi_lookup_find_by_lun(struct MPT3SAS_ADAPTER *ioc, int id,
1190 unsigned int lun, int channel)
1193 unsigned long flags;
1196 spin_lock_irqsave(&ioc->scsi_lookup_lock, flags);
1198 for (i = 0 ; i < ioc->scsiio_depth; i++) {
1199 if (ioc->scsi_lookup[i].scmd &&
1200 (ioc->scsi_lookup[i].scmd->device->id == id &&
1201 ioc->scsi_lookup[i].scmd->device->channel == channel &&
1202 ioc->scsi_lookup[i].scmd->device->lun == lun)) {
1208 spin_unlock_irqrestore(&ioc->scsi_lookup_lock, flags);
1213 * _scsih_change_queue_depth - setting device queue depth
1214 * @sdev: scsi device struct
1215 * @qdepth: requested queue depth
1217 * Returns queue depth.
1220 _scsih_change_queue_depth(struct scsi_device *sdev, int qdepth)
1222 struct Scsi_Host *shost = sdev->host;
1224 struct MPT3SAS_ADAPTER *ioc = shost_priv(shost);
1225 struct MPT3SAS_DEVICE *sas_device_priv_data;
1226 struct MPT3SAS_TARGET *sas_target_priv_data;
1227 struct _sas_device *sas_device;
1228 unsigned long flags;
1230 max_depth = shost->can_queue;
1232 /* limit max device queue for SATA to 32 */
1233 sas_device_priv_data = sdev->hostdata;
1234 if (!sas_device_priv_data)
1236 sas_target_priv_data = sas_device_priv_data->sas_target;
1237 if (!sas_target_priv_data)
1239 if ((sas_target_priv_data->flags & MPT_TARGET_FLAGS_VOLUME))
1242 spin_lock_irqsave(&ioc->sas_device_lock, flags);
1243 sas_device = __mpt3sas_get_sdev_from_target(ioc, sas_target_priv_data);
1245 if (sas_device->device_info & MPI2_SAS_DEVICE_INFO_SATA_DEVICE)
1246 max_depth = MPT3SAS_SATA_QUEUE_DEPTH;
1248 sas_device_put(sas_device);
1250 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
1254 if (!sdev->tagged_supported)
1256 if (qdepth > max_depth)
1258 return scsi_change_queue_depth(sdev, qdepth);
1262 * _scsih_target_alloc - target add routine
1263 * @starget: scsi target struct
1265 * Returns 0 if ok. Any other return is assumed to be an error and
1266 * the device is ignored.
1269 _scsih_target_alloc(struct scsi_target *starget)
1271 struct Scsi_Host *shost = dev_to_shost(&starget->dev);
1272 struct MPT3SAS_ADAPTER *ioc = shost_priv(shost);
1273 struct MPT3SAS_TARGET *sas_target_priv_data;
1274 struct _sas_device *sas_device;
1275 struct _raid_device *raid_device;
1276 unsigned long flags;
1277 struct sas_rphy *rphy;
1279 sas_target_priv_data = kzalloc(sizeof(*sas_target_priv_data),
1281 if (!sas_target_priv_data)
1284 starget->hostdata = sas_target_priv_data;
1285 sas_target_priv_data->starget = starget;
1286 sas_target_priv_data->handle = MPT3SAS_INVALID_DEVICE_HANDLE;
1289 if (starget->channel == RAID_CHANNEL) {
1290 spin_lock_irqsave(&ioc->raid_device_lock, flags);
1291 raid_device = _scsih_raid_device_find_by_id(ioc, starget->id,
1294 sas_target_priv_data->handle = raid_device->handle;
1295 sas_target_priv_data->sas_address = raid_device->wwid;
1296 sas_target_priv_data->flags |= MPT_TARGET_FLAGS_VOLUME;
1297 raid_device->starget = starget;
1299 spin_unlock_irqrestore(&ioc->raid_device_lock, flags);
1303 /* sas/sata devices */
1304 spin_lock_irqsave(&ioc->sas_device_lock, flags);
1305 rphy = dev_to_rphy(starget->dev.parent);
1306 sas_device = __mpt3sas_get_sdev_by_addr(ioc,
1307 rphy->identify.sas_address);
1310 sas_target_priv_data->handle = sas_device->handle;
1311 sas_target_priv_data->sas_address = sas_device->sas_address;
1312 sas_target_priv_data->sdev = sas_device;
1313 sas_device->starget = starget;
1314 sas_device->id = starget->id;
1315 sas_device->channel = starget->channel;
1316 if (test_bit(sas_device->handle, ioc->pd_handles))
1317 sas_target_priv_data->flags |=
1318 MPT_TARGET_FLAGS_RAID_COMPONENT;
1319 if (sas_device->fast_path)
1320 sas_target_priv_data->flags |= MPT_TARGET_FASTPATH_IO;
1322 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
1328 * _scsih_target_destroy - target destroy routine
1329 * @starget: scsi target struct
1334 _scsih_target_destroy(struct scsi_target *starget)
1336 struct Scsi_Host *shost = dev_to_shost(&starget->dev);
1337 struct MPT3SAS_ADAPTER *ioc = shost_priv(shost);
1338 struct MPT3SAS_TARGET *sas_target_priv_data;
1339 struct _sas_device *sas_device;
1340 struct _raid_device *raid_device;
1341 unsigned long flags;
1342 struct sas_rphy *rphy;
1344 sas_target_priv_data = starget->hostdata;
1345 if (!sas_target_priv_data)
1348 if (starget->channel == RAID_CHANNEL) {
1349 spin_lock_irqsave(&ioc->raid_device_lock, flags);
1350 raid_device = _scsih_raid_device_find_by_id(ioc, starget->id,
1353 raid_device->starget = NULL;
1354 raid_device->sdev = NULL;
1356 spin_unlock_irqrestore(&ioc->raid_device_lock, flags);
1360 spin_lock_irqsave(&ioc->sas_device_lock, flags);
1361 rphy = dev_to_rphy(starget->dev.parent);
1362 sas_device = __mpt3sas_get_sdev_from_target(ioc, sas_target_priv_data);
1363 if (sas_device && (sas_device->starget == starget) &&
1364 (sas_device->id == starget->id) &&
1365 (sas_device->channel == starget->channel))
1366 sas_device->starget = NULL;
1370 * Corresponding get() is in _scsih_target_alloc()
1372 sas_target_priv_data->sdev = NULL;
1373 sas_device_put(sas_device);
1375 sas_device_put(sas_device);
1377 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
1380 kfree(sas_target_priv_data);
1381 starget->hostdata = NULL;
1385 * _scsih_slave_alloc - device add routine
1386 * @sdev: scsi device struct
1388 * Returns 0 if ok. Any other return is assumed to be an error and
1389 * the device is ignored.
1392 _scsih_slave_alloc(struct scsi_device *sdev)
1394 struct Scsi_Host *shost;
1395 struct MPT3SAS_ADAPTER *ioc;
1396 struct MPT3SAS_TARGET *sas_target_priv_data;
1397 struct MPT3SAS_DEVICE *sas_device_priv_data;
1398 struct scsi_target *starget;
1399 struct _raid_device *raid_device;
1400 struct _sas_device *sas_device;
1401 unsigned long flags;
1403 sas_device_priv_data = kzalloc(sizeof(*sas_device_priv_data),
1405 if (!sas_device_priv_data)
1408 sas_device_priv_data->lun = sdev->lun;
1409 sas_device_priv_data->flags = MPT_DEVICE_FLAGS_INIT;
1411 starget = scsi_target(sdev);
1412 sas_target_priv_data = starget->hostdata;
1413 sas_target_priv_data->num_luns++;
1414 sas_device_priv_data->sas_target = sas_target_priv_data;
1415 sdev->hostdata = sas_device_priv_data;
1416 if ((sas_target_priv_data->flags & MPT_TARGET_FLAGS_RAID_COMPONENT))
1417 sdev->no_uld_attach = 1;
1419 shost = dev_to_shost(&starget->dev);
1420 ioc = shost_priv(shost);
1421 if (starget->channel == RAID_CHANNEL) {
1422 spin_lock_irqsave(&ioc->raid_device_lock, flags);
1423 raid_device = _scsih_raid_device_find_by_id(ioc,
1424 starget->id, starget->channel);
1426 raid_device->sdev = sdev; /* raid is single lun */
1427 spin_unlock_irqrestore(&ioc->raid_device_lock, flags);
1430 if (!(sas_target_priv_data->flags & MPT_TARGET_FLAGS_VOLUME)) {
1431 spin_lock_irqsave(&ioc->sas_device_lock, flags);
1432 sas_device = __mpt3sas_get_sdev_by_addr(ioc,
1433 sas_target_priv_data->sas_address);
1434 if (sas_device && (sas_device->starget == NULL)) {
1435 sdev_printk(KERN_INFO, sdev,
1436 "%s : sas_device->starget set to starget @ %d\n",
1437 __func__, __LINE__);
1438 sas_device->starget = starget;
1442 sas_device_put(sas_device);
1444 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
1451 * _scsih_slave_destroy - device destroy routine
1452 * @sdev: scsi device struct
1457 _scsih_slave_destroy(struct scsi_device *sdev)
1459 struct MPT3SAS_TARGET *sas_target_priv_data;
1460 struct scsi_target *starget;
1461 struct Scsi_Host *shost;
1462 struct MPT3SAS_ADAPTER *ioc;
1463 struct _sas_device *sas_device;
1464 unsigned long flags;
1466 if (!sdev->hostdata)
1469 starget = scsi_target(sdev);
1470 sas_target_priv_data = starget->hostdata;
1471 sas_target_priv_data->num_luns--;
1473 shost = dev_to_shost(&starget->dev);
1474 ioc = shost_priv(shost);
1476 if (!(sas_target_priv_data->flags & MPT_TARGET_FLAGS_VOLUME)) {
1477 spin_lock_irqsave(&ioc->sas_device_lock, flags);
1478 sas_device = __mpt3sas_get_sdev_from_target(ioc,
1479 sas_target_priv_data);
1480 if (sas_device && !sas_target_priv_data->num_luns)
1481 sas_device->starget = NULL;
1484 sas_device_put(sas_device);
1486 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
1489 kfree(sdev->hostdata);
1490 sdev->hostdata = NULL;
1494 * _scsih_display_sata_capabilities - sata capabilities
1495 * @ioc: per adapter object
1496 * @handle: device handle
1497 * @sdev: scsi device struct
1500 _scsih_display_sata_capabilities(struct MPT3SAS_ADAPTER *ioc,
1501 u16 handle, struct scsi_device *sdev)
1503 Mpi2ConfigReply_t mpi_reply;
1504 Mpi2SasDevicePage0_t sas_device_pg0;
1509 if ((mpt3sas_config_get_sas_device_pg0(ioc, &mpi_reply, &sas_device_pg0,
1510 MPI2_SAS_DEVICE_PGAD_FORM_HANDLE, handle))) {
1511 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
1512 ioc->name, __FILE__, __LINE__, __func__);
1516 ioc_status = le16_to_cpu(mpi_reply.IOCStatus) &
1517 MPI2_IOCSTATUS_MASK;
1518 if (ioc_status != MPI2_IOCSTATUS_SUCCESS) {
1519 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
1520 ioc->name, __FILE__, __LINE__, __func__);
1524 flags = le16_to_cpu(sas_device_pg0.Flags);
1525 device_info = le32_to_cpu(sas_device_pg0.DeviceInfo);
1527 sdev_printk(KERN_INFO, sdev,
1528 "atapi(%s), ncq(%s), asyn_notify(%s), smart(%s), fua(%s), "
1529 "sw_preserve(%s)\n",
1530 (device_info & MPI2_SAS_DEVICE_INFO_ATAPI_DEVICE) ? "y" : "n",
1531 (flags & MPI2_SAS_DEVICE0_FLAGS_SATA_NCQ_SUPPORTED) ? "y" : "n",
1532 (flags & MPI2_SAS_DEVICE0_FLAGS_SATA_ASYNCHRONOUS_NOTIFY) ? "y" :
1534 (flags & MPI2_SAS_DEVICE0_FLAGS_SATA_SMART_SUPPORTED) ? "y" : "n",
1535 (flags & MPI2_SAS_DEVICE0_FLAGS_SATA_FUA_SUPPORTED) ? "y" : "n",
1536 (flags & MPI2_SAS_DEVICE0_FLAGS_SATA_SW_PRESERVE) ? "y" : "n");
1540 * raid transport support -
1541 * Enabled for SLES11 and newer, in older kernels the driver will panic when
1542 * unloading the driver followed by a load - I beleive that the subroutine
1543 * raid_class_release() is not cleaning up properly.
1547 * _scsih_is_raid - return boolean indicating device is raid volume
1548 * @dev the device struct object
1551 _scsih_is_raid(struct device *dev)
1553 struct scsi_device *sdev = to_scsi_device(dev);
1555 return (sdev->channel == RAID_CHANNEL) ? 1 : 0;
1559 * _scsih_get_resync - get raid volume resync percent complete
1560 * @dev the device struct object
1563 _scsih_get_resync(struct device *dev)
1565 struct scsi_device *sdev = to_scsi_device(dev);
1566 struct MPT3SAS_ADAPTER *ioc = shost_priv(sdev->host);
1567 static struct _raid_device *raid_device;
1568 unsigned long flags;
1569 Mpi2RaidVolPage0_t vol_pg0;
1570 Mpi2ConfigReply_t mpi_reply;
1571 u32 volume_status_flags;
1572 u8 percent_complete;
1575 percent_complete = 0;
1577 spin_lock_irqsave(&ioc->raid_device_lock, flags);
1578 raid_device = _scsih_raid_device_find_by_id(ioc, sdev->id,
1581 handle = raid_device->handle;
1582 percent_complete = raid_device->percent_complete;
1584 spin_unlock_irqrestore(&ioc->raid_device_lock, flags);
1589 if (mpt3sas_config_get_raid_volume_pg0(ioc, &mpi_reply, &vol_pg0,
1590 MPI2_RAID_VOLUME_PGAD_FORM_HANDLE, handle,
1591 sizeof(Mpi2RaidVolPage0_t))) {
1592 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
1593 ioc->name, __FILE__, __LINE__, __func__);
1594 percent_complete = 0;
1598 volume_status_flags = le32_to_cpu(vol_pg0.VolumeStatusFlags);
1599 if (!(volume_status_flags &
1600 MPI2_RAIDVOL0_STATUS_FLAG_RESYNC_IN_PROGRESS))
1601 percent_complete = 0;
1604 raid_set_resync(mpt3sas_raid_template, dev, percent_complete);
1608 * _scsih_get_state - get raid volume level
1609 * @dev the device struct object
1612 _scsih_get_state(struct device *dev)
1614 struct scsi_device *sdev = to_scsi_device(dev);
1615 struct MPT3SAS_ADAPTER *ioc = shost_priv(sdev->host);
1616 static struct _raid_device *raid_device;
1617 unsigned long flags;
1618 Mpi2RaidVolPage0_t vol_pg0;
1619 Mpi2ConfigReply_t mpi_reply;
1621 enum raid_state state = RAID_STATE_UNKNOWN;
1624 spin_lock_irqsave(&ioc->raid_device_lock, flags);
1625 raid_device = _scsih_raid_device_find_by_id(ioc, sdev->id,
1628 handle = raid_device->handle;
1629 spin_unlock_irqrestore(&ioc->raid_device_lock, flags);
1634 if (mpt3sas_config_get_raid_volume_pg0(ioc, &mpi_reply, &vol_pg0,
1635 MPI2_RAID_VOLUME_PGAD_FORM_HANDLE, handle,
1636 sizeof(Mpi2RaidVolPage0_t))) {
1637 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
1638 ioc->name, __FILE__, __LINE__, __func__);
1642 volstate = le32_to_cpu(vol_pg0.VolumeStatusFlags);
1643 if (volstate & MPI2_RAIDVOL0_STATUS_FLAG_RESYNC_IN_PROGRESS) {
1644 state = RAID_STATE_RESYNCING;
1648 switch (vol_pg0.VolumeState) {
1649 case MPI2_RAID_VOL_STATE_OPTIMAL:
1650 case MPI2_RAID_VOL_STATE_ONLINE:
1651 state = RAID_STATE_ACTIVE;
1653 case MPI2_RAID_VOL_STATE_DEGRADED:
1654 state = RAID_STATE_DEGRADED;
1656 case MPI2_RAID_VOL_STATE_FAILED:
1657 case MPI2_RAID_VOL_STATE_MISSING:
1658 state = RAID_STATE_OFFLINE;
1662 raid_set_state(mpt3sas_raid_template, dev, state);
1666 * _scsih_set_level - set raid level
1667 * @sdev: scsi device struct
1668 * @volume_type: volume type
1671 _scsih_set_level(struct scsi_device *sdev, u8 volume_type)
1673 enum raid_level level = RAID_LEVEL_UNKNOWN;
1675 switch (volume_type) {
1676 case MPI2_RAID_VOL_TYPE_RAID0:
1677 level = RAID_LEVEL_0;
1679 case MPI2_RAID_VOL_TYPE_RAID10:
1680 level = RAID_LEVEL_10;
1682 case MPI2_RAID_VOL_TYPE_RAID1E:
1683 level = RAID_LEVEL_1E;
1685 case MPI2_RAID_VOL_TYPE_RAID1:
1686 level = RAID_LEVEL_1;
1690 raid_set_level(mpt3sas_raid_template, &sdev->sdev_gendev, level);
1695 * _scsih_get_volume_capabilities - volume capabilities
1696 * @ioc: per adapter object
1697 * @sas_device: the raid_device object
1699 * Returns 0 for success, else 1
1702 _scsih_get_volume_capabilities(struct MPT3SAS_ADAPTER *ioc,
1703 struct _raid_device *raid_device)
1705 Mpi2RaidVolPage0_t *vol_pg0;
1706 Mpi2RaidPhysDiskPage0_t pd_pg0;
1707 Mpi2SasDevicePage0_t sas_device_pg0;
1708 Mpi2ConfigReply_t mpi_reply;
1712 if ((mpt3sas_config_get_number_pds(ioc, raid_device->handle,
1713 &num_pds)) || !num_pds) {
1714 dfailprintk(ioc, pr_warn(MPT3SAS_FMT
1715 "failure at %s:%d/%s()!\n", ioc->name, __FILE__, __LINE__,
1720 raid_device->num_pds = num_pds;
1721 sz = offsetof(Mpi2RaidVolPage0_t, PhysDisk) + (num_pds *
1722 sizeof(Mpi2RaidVol0PhysDisk_t));
1723 vol_pg0 = kzalloc(sz, GFP_KERNEL);
1725 dfailprintk(ioc, pr_warn(MPT3SAS_FMT
1726 "failure at %s:%d/%s()!\n", ioc->name, __FILE__, __LINE__,
1731 if ((mpt3sas_config_get_raid_volume_pg0(ioc, &mpi_reply, vol_pg0,
1732 MPI2_RAID_VOLUME_PGAD_FORM_HANDLE, raid_device->handle, sz))) {
1733 dfailprintk(ioc, pr_warn(MPT3SAS_FMT
1734 "failure at %s:%d/%s()!\n", ioc->name, __FILE__, __LINE__,
1740 raid_device->volume_type = vol_pg0->VolumeType;
1742 /* figure out what the underlying devices are by
1743 * obtaining the device_info bits for the 1st device
1745 if (!(mpt3sas_config_get_phys_disk_pg0(ioc, &mpi_reply,
1746 &pd_pg0, MPI2_PHYSDISK_PGAD_FORM_PHYSDISKNUM,
1747 vol_pg0->PhysDisk[0].PhysDiskNum))) {
1748 if (!(mpt3sas_config_get_sas_device_pg0(ioc, &mpi_reply,
1749 &sas_device_pg0, MPI2_SAS_DEVICE_PGAD_FORM_HANDLE,
1750 le16_to_cpu(pd_pg0.DevHandle)))) {
1751 raid_device->device_info =
1752 le32_to_cpu(sas_device_pg0.DeviceInfo);
1763 * _scsih_enable_tlr - setting TLR flags
1764 * @ioc: per adapter object
1765 * @sdev: scsi device struct
1767 * Enabling Transaction Layer Retries for tape devices when
1768 * vpd page 0x90 is present
1772 _scsih_enable_tlr(struct MPT3SAS_ADAPTER *ioc, struct scsi_device *sdev)
1776 if (sdev->type != TYPE_TAPE)
1779 if (!(ioc->facts.IOCCapabilities & MPI2_IOCFACTS_CAPABILITY_TLR))
1782 sas_enable_tlr(sdev);
1783 sdev_printk(KERN_INFO, sdev, "TLR %s\n",
1784 sas_is_tlr_enabled(sdev) ? "Enabled" : "Disabled");
1790 * _scsih_slave_configure - device configure routine.
1791 * @sdev: scsi device struct
1793 * Returns 0 if ok. Any other return is assumed to be an error and
1794 * the device is ignored.
1797 _scsih_slave_configure(struct scsi_device *sdev)
1799 struct Scsi_Host *shost = sdev->host;
1800 struct MPT3SAS_ADAPTER *ioc = shost_priv(shost);
1801 struct MPT3SAS_DEVICE *sas_device_priv_data;
1802 struct MPT3SAS_TARGET *sas_target_priv_data;
1803 struct _sas_device *sas_device;
1804 struct _raid_device *raid_device;
1805 unsigned long flags;
1810 u16 handle, volume_handle = 0;
1811 u64 volume_wwid = 0;
1814 sas_device_priv_data = sdev->hostdata;
1815 sas_device_priv_data->configured_lun = 1;
1816 sas_device_priv_data->flags &= ~MPT_DEVICE_FLAGS_INIT;
1817 sas_target_priv_data = sas_device_priv_data->sas_target;
1818 handle = sas_target_priv_data->handle;
1820 /* raid volume handling */
1821 if (sas_target_priv_data->flags & MPT_TARGET_FLAGS_VOLUME) {
1823 spin_lock_irqsave(&ioc->raid_device_lock, flags);
1824 raid_device = _scsih_raid_device_find_by_handle(ioc, handle);
1825 spin_unlock_irqrestore(&ioc->raid_device_lock, flags);
1827 dfailprintk(ioc, pr_warn(MPT3SAS_FMT
1828 "failure at %s:%d/%s()!\n", ioc->name, __FILE__,
1829 __LINE__, __func__));
1833 if (_scsih_get_volume_capabilities(ioc, raid_device)) {
1834 dfailprintk(ioc, pr_warn(MPT3SAS_FMT
1835 "failure at %s:%d/%s()!\n", ioc->name, __FILE__,
1836 __LINE__, __func__));
1841 /* RAID Queue Depth Support
1842 * IS volume = underlying qdepth of drive type, either
1843 * MPT3SAS_SAS_QUEUE_DEPTH or MPT3SAS_SATA_QUEUE_DEPTH
1844 * IM/IME/R10 = 128 (MPT3SAS_RAID_QUEUE_DEPTH)
1846 if (raid_device->device_info &
1847 MPI2_SAS_DEVICE_INFO_SSP_TARGET) {
1848 qdepth = MPT3SAS_SAS_QUEUE_DEPTH;
1851 qdepth = MPT3SAS_SATA_QUEUE_DEPTH;
1852 if (raid_device->device_info &
1853 MPI2_SAS_DEVICE_INFO_SATA_DEVICE)
1859 switch (raid_device->volume_type) {
1860 case MPI2_RAID_VOL_TYPE_RAID0:
1863 case MPI2_RAID_VOL_TYPE_RAID1E:
1864 qdepth = MPT3SAS_RAID_QUEUE_DEPTH;
1865 if (ioc->manu_pg10.OEMIdentifier &&
1866 (le32_to_cpu(ioc->manu_pg10.GenericFlags0) &
1867 MFG10_GF0_R10_DISPLAY) &&
1868 !(raid_device->num_pds % 2))
1873 case MPI2_RAID_VOL_TYPE_RAID1:
1874 qdepth = MPT3SAS_RAID_QUEUE_DEPTH;
1877 case MPI2_RAID_VOL_TYPE_RAID10:
1878 qdepth = MPT3SAS_RAID_QUEUE_DEPTH;
1881 case MPI2_RAID_VOL_TYPE_UNKNOWN:
1883 qdepth = MPT3SAS_RAID_QUEUE_DEPTH;
1888 sdev_printk(KERN_INFO, sdev,
1889 "%s: handle(0x%04x), wwid(0x%016llx), pd_count(%d), type(%s)\n",
1890 r_level, raid_device->handle,
1891 (unsigned long long)raid_device->wwid,
1892 raid_device->num_pds, ds);
1895 _scsih_change_queue_depth(sdev, qdepth);
1897 /* raid transport support */
1898 _scsih_set_level(sdev, raid_device->volume_type);
1902 /* non-raid handling */
1903 if (sas_target_priv_data->flags & MPT_TARGET_FLAGS_RAID_COMPONENT) {
1904 if (mpt3sas_config_get_volume_handle(ioc, handle,
1906 dfailprintk(ioc, pr_warn(MPT3SAS_FMT
1907 "failure at %s:%d/%s()!\n", ioc->name,
1908 __FILE__, __LINE__, __func__));
1911 if (volume_handle && mpt3sas_config_get_volume_wwid(ioc,
1912 volume_handle, &volume_wwid)) {
1913 dfailprintk(ioc, pr_warn(MPT3SAS_FMT
1914 "failure at %s:%d/%s()!\n", ioc->name,
1915 __FILE__, __LINE__, __func__));
1920 spin_lock_irqsave(&ioc->sas_device_lock, flags);
1921 sas_device = __mpt3sas_get_sdev_by_addr(ioc,
1922 sas_device_priv_data->sas_target->sas_address);
1924 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
1925 dfailprintk(ioc, pr_warn(MPT3SAS_FMT
1926 "failure at %s:%d/%s()!\n", ioc->name, __FILE__, __LINE__,
1931 sas_device->volume_handle = volume_handle;
1932 sas_device->volume_wwid = volume_wwid;
1933 if (sas_device->device_info & MPI2_SAS_DEVICE_INFO_SSP_TARGET) {
1934 qdepth = MPT3SAS_SAS_QUEUE_DEPTH;
1938 qdepth = MPT3SAS_SATA_QUEUE_DEPTH;
1939 if (sas_device->device_info & MPI2_SAS_DEVICE_INFO_STP_TARGET)
1941 else if (sas_device->device_info &
1942 MPI2_SAS_DEVICE_INFO_SATA_DEVICE)
1946 sdev_printk(KERN_INFO, sdev, "%s: handle(0x%04x), " \
1947 "sas_addr(0x%016llx), phy(%d), device_name(0x%016llx)\n",
1948 ds, handle, (unsigned long long)sas_device->sas_address,
1949 sas_device->phy, (unsigned long long)sas_device->device_name);
1950 if (sas_device->enclosure_handle != 0)
1951 sdev_printk(KERN_INFO, sdev,
1952 "%s: enclosure_logical_id(0x%016llx), slot(%d)\n",
1953 ds, (unsigned long long)
1954 sas_device->enclosure_logical_id, sas_device->slot);
1955 if (sas_device->connector_name[0] != '\0')
1956 sdev_printk(KERN_INFO, sdev,
1957 "%s: enclosure level(0x%04x), connector name( %s)\n",
1958 ds, sas_device->enclosure_level,
1959 sas_device->connector_name);
1961 sas_device_put(sas_device);
1962 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
1965 _scsih_display_sata_capabilities(ioc, handle, sdev);
1967 _scsih_change_queue_depth(sdev, qdepth);
1970 sas_read_port_mode_page(sdev);
1971 _scsih_enable_tlr(ioc, sdev);
1978 * _scsih_bios_param - fetch head, sector, cylinder info for a disk
1979 * @sdev: scsi device struct
1980 * @bdev: pointer to block device context
1981 * @capacity: device size (in 512 byte sectors)
1982 * @params: three element array to place output:
1983 * params[0] number of heads (max 255)
1984 * params[1] number of sectors (max 63)
1985 * params[2] number of cylinders
1990 _scsih_bios_param(struct scsi_device *sdev, struct block_device *bdev,
1991 sector_t capacity, int params[])
2001 dummy = heads * sectors;
2002 cylinders = capacity;
2003 sector_div(cylinders, dummy);
2006 * Handle extended translation size for logical drives
2009 if ((ulong)capacity >= 0x200000) {
2012 dummy = heads * sectors;
2013 cylinders = capacity;
2014 sector_div(cylinders, dummy);
2019 params[1] = sectors;
2020 params[2] = cylinders;
2026 * _scsih_response_code - translation of device response code
2027 * @ioc: per adapter object
2028 * @response_code: response code returned by the device
2033 _scsih_response_code(struct MPT3SAS_ADAPTER *ioc, u8 response_code)
2037 switch (response_code) {
2038 case MPI2_SCSITASKMGMT_RSP_TM_COMPLETE:
2039 desc = "task management request completed";
2041 case MPI2_SCSITASKMGMT_RSP_INVALID_FRAME:
2042 desc = "invalid frame";
2044 case MPI2_SCSITASKMGMT_RSP_TM_NOT_SUPPORTED:
2045 desc = "task management request not supported";
2047 case MPI2_SCSITASKMGMT_RSP_TM_FAILED:
2048 desc = "task management request failed";
2050 case MPI2_SCSITASKMGMT_RSP_TM_SUCCEEDED:
2051 desc = "task management request succeeded";
2053 case MPI2_SCSITASKMGMT_RSP_TM_INVALID_LUN:
2054 desc = "invalid lun";
2057 desc = "overlapped tag attempted";
2059 case MPI2_SCSITASKMGMT_RSP_IO_QUEUED_ON_IOC:
2060 desc = "task queued, however not sent to target";
2066 pr_warn(MPT3SAS_FMT "response_code(0x%01x): %s\n",
2067 ioc->name, response_code, desc);
2071 * _scsih_tm_done - tm completion routine
2072 * @ioc: per adapter object
2073 * @smid: system request message index
2074 * @msix_index: MSIX table index supplied by the OS
2075 * @reply: reply message frame(lower 32bit addr)
2078 * The callback handler when using scsih_issue_tm.
2080 * Return 1 meaning mf should be freed from _base_interrupt
2081 * 0 means the mf is freed from this function.
2084 _scsih_tm_done(struct MPT3SAS_ADAPTER *ioc, u16 smid, u8 msix_index, u32 reply)
2086 MPI2DefaultReply_t *mpi_reply;
2088 if (ioc->tm_cmds.status == MPT3_CMD_NOT_USED)
2090 if (ioc->tm_cmds.smid != smid)
2092 mpt3sas_base_flush_reply_queues(ioc);
2093 ioc->tm_cmds.status |= MPT3_CMD_COMPLETE;
2094 mpi_reply = mpt3sas_base_get_reply_virt_addr(ioc, reply);
2096 memcpy(ioc->tm_cmds.reply, mpi_reply, mpi_reply->MsgLength*4);
2097 ioc->tm_cmds.status |= MPT3_CMD_REPLY_VALID;
2099 ioc->tm_cmds.status &= ~MPT3_CMD_PENDING;
2100 complete(&ioc->tm_cmds.done);
2105 * mpt3sas_scsih_set_tm_flag - set per target tm_busy
2106 * @ioc: per adapter object
2107 * @handle: device handle
2109 * During taskmangement request, we need to freeze the device queue.
2112 mpt3sas_scsih_set_tm_flag(struct MPT3SAS_ADAPTER *ioc, u16 handle)
2114 struct MPT3SAS_DEVICE *sas_device_priv_data;
2115 struct scsi_device *sdev;
2118 shost_for_each_device(sdev, ioc->shost) {
2121 sas_device_priv_data = sdev->hostdata;
2122 if (!sas_device_priv_data)
2124 if (sas_device_priv_data->sas_target->handle == handle) {
2125 sas_device_priv_data->sas_target->tm_busy = 1;
2127 ioc->ignore_loginfos = 1;
2133 * mpt3sas_scsih_clear_tm_flag - clear per target tm_busy
2134 * @ioc: per adapter object
2135 * @handle: device handle
2137 * During taskmangement request, we need to freeze the device queue.
2140 mpt3sas_scsih_clear_tm_flag(struct MPT3SAS_ADAPTER *ioc, u16 handle)
2142 struct MPT3SAS_DEVICE *sas_device_priv_data;
2143 struct scsi_device *sdev;
2146 shost_for_each_device(sdev, ioc->shost) {
2149 sas_device_priv_data = sdev->hostdata;
2150 if (!sas_device_priv_data)
2152 if (sas_device_priv_data->sas_target->handle == handle) {
2153 sas_device_priv_data->sas_target->tm_busy = 0;
2155 ioc->ignore_loginfos = 0;
2161 * mpt3sas_scsih_issue_tm - main routine for sending tm requests
2162 * @ioc: per adapter struct
2163 * @device_handle: device handle
2164 * @channel: the channel assigned by the OS
2165 * @id: the id assigned by the OS
2167 * @type: MPI2_SCSITASKMGMT_TASKTYPE__XXX (defined in mpi2_init.h)
2168 * @smid_task: smid assigned to the task
2169 * @timeout: timeout in seconds
2170 * @m_type: TM_MUTEX_ON or TM_MUTEX_OFF
2173 * A generic API for sending task management requests to firmware.
2175 * The callback index is set inside `ioc->tm_cb_idx`.
2177 * Return SUCCESS or FAILED.
2180 mpt3sas_scsih_issue_tm(struct MPT3SAS_ADAPTER *ioc, u16 handle, uint channel,
2181 uint id, uint lun, u8 type, u16 smid_task, ulong timeout,
2182 enum mutex_type m_type)
2184 Mpi2SCSITaskManagementRequest_t *mpi_request;
2185 Mpi2SCSITaskManagementReply_t *mpi_reply;
2188 unsigned long timeleft;
2189 struct scsiio_tracker *scsi_lookup = NULL;
2192 if (m_type == TM_MUTEX_ON)
2193 mutex_lock(&ioc->tm_cmds.mutex);
2194 if (ioc->tm_cmds.status != MPT3_CMD_NOT_USED) {
2195 pr_info(MPT3SAS_FMT "%s: tm_cmd busy!!!\n",
2196 __func__, ioc->name);
2201 if (ioc->shost_recovery || ioc->remove_host ||
2202 ioc->pci_error_recovery) {
2203 pr_info(MPT3SAS_FMT "%s: host reset in progress!\n",
2204 __func__, ioc->name);
2209 ioc_state = mpt3sas_base_get_iocstate(ioc, 0);
2210 if (ioc_state & MPI2_DOORBELL_USED) {
2211 dhsprintk(ioc, pr_info(MPT3SAS_FMT
2212 "unexpected doorbell active!\n", ioc->name));
2213 rc = mpt3sas_base_hard_reset_handler(ioc, CAN_SLEEP,
2215 rc = (!rc) ? SUCCESS : FAILED;
2219 if ((ioc_state & MPI2_IOC_STATE_MASK) == MPI2_IOC_STATE_FAULT) {
2220 mpt3sas_base_fault_info(ioc, ioc_state &
2221 MPI2_DOORBELL_DATA_MASK);
2222 rc = mpt3sas_base_hard_reset_handler(ioc, CAN_SLEEP,
2224 rc = (!rc) ? SUCCESS : FAILED;
2228 smid = mpt3sas_base_get_smid_hpr(ioc, ioc->tm_cb_idx);
2230 pr_err(MPT3SAS_FMT "%s: failed obtaining a smid\n",
2231 ioc->name, __func__);
2236 if (type == MPI2_SCSITASKMGMT_TASKTYPE_ABORT_TASK)
2237 scsi_lookup = &ioc->scsi_lookup[smid_task - 1];
2239 dtmprintk(ioc, pr_info(MPT3SAS_FMT
2240 "sending tm: handle(0x%04x), task_type(0x%02x), smid(%d)\n",
2241 ioc->name, handle, type, smid_task));
2242 ioc->tm_cmds.status = MPT3_CMD_PENDING;
2243 mpi_request = mpt3sas_base_get_msg_frame(ioc, smid);
2244 ioc->tm_cmds.smid = smid;
2245 memset(mpi_request, 0, sizeof(Mpi2SCSITaskManagementRequest_t));
2246 memset(ioc->tm_cmds.reply, 0, sizeof(Mpi2SCSITaskManagementReply_t));
2247 mpi_request->Function = MPI2_FUNCTION_SCSI_TASK_MGMT;
2248 mpi_request->DevHandle = cpu_to_le16(handle);
2249 mpi_request->TaskType = type;
2250 mpi_request->TaskMID = cpu_to_le16(smid_task);
2251 int_to_scsilun(lun, (struct scsi_lun *)mpi_request->LUN);
2252 mpt3sas_scsih_set_tm_flag(ioc, handle);
2253 init_completion(&ioc->tm_cmds.done);
2254 mpt3sas_base_put_smid_hi_priority(ioc, smid);
2255 timeleft = wait_for_completion_timeout(&ioc->tm_cmds.done, timeout*HZ);
2256 if (!(ioc->tm_cmds.status & MPT3_CMD_COMPLETE)) {
2257 pr_err(MPT3SAS_FMT "%s: timeout\n",
2258 ioc->name, __func__);
2259 _debug_dump_mf(mpi_request,
2260 sizeof(Mpi2SCSITaskManagementRequest_t)/4);
2261 if (!(ioc->tm_cmds.status & MPT3_CMD_RESET)) {
2262 rc = mpt3sas_base_hard_reset_handler(ioc, CAN_SLEEP,
2264 rc = (!rc) ? SUCCESS : FAILED;
2265 ioc->tm_cmds.status = MPT3_CMD_NOT_USED;
2266 mpt3sas_scsih_clear_tm_flag(ioc, handle);
2271 if (ioc->tm_cmds.status & MPT3_CMD_REPLY_VALID) {
2272 mpt3sas_trigger_master(ioc, MASTER_TRIGGER_TASK_MANAGMENT);
2273 mpi_reply = ioc->tm_cmds.reply;
2274 dtmprintk(ioc, pr_info(MPT3SAS_FMT "complete tm: " \
2275 "ioc_status(0x%04x), loginfo(0x%08x), term_count(0x%08x)\n",
2276 ioc->name, le16_to_cpu(mpi_reply->IOCStatus),
2277 le32_to_cpu(mpi_reply->IOCLogInfo),
2278 le32_to_cpu(mpi_reply->TerminationCount)));
2279 if (ioc->logging_level & MPT_DEBUG_TM) {
2280 _scsih_response_code(ioc, mpi_reply->ResponseCode);
2281 if (mpi_reply->IOCStatus)
2282 _debug_dump_mf(mpi_request,
2283 sizeof(Mpi2SCSITaskManagementRequest_t)/4);
2288 case MPI2_SCSITASKMGMT_TASKTYPE_ABORT_TASK:
2290 if (scsi_lookup->scmd == NULL)
2295 case MPI2_SCSITASKMGMT_TASKTYPE_TARGET_RESET:
2296 if (_scsih_scsi_lookup_find_by_target(ioc, id, channel))
2301 case MPI2_SCSITASKMGMT_TASKTYPE_ABRT_TASK_SET:
2302 case MPI2_SCSITASKMGMT_TASKTYPE_LOGICAL_UNIT_RESET:
2303 if (_scsih_scsi_lookup_find_by_lun(ioc, id, lun, channel))
2308 case MPI2_SCSITASKMGMT_TASKTYPE_QUERY_TASK:
2316 mpt3sas_scsih_clear_tm_flag(ioc, handle);
2317 ioc->tm_cmds.status = MPT3_CMD_NOT_USED;
2318 if (m_type == TM_MUTEX_ON)
2319 mutex_unlock(&ioc->tm_cmds.mutex);
2324 if (m_type == TM_MUTEX_ON)
2325 mutex_unlock(&ioc->tm_cmds.mutex);
2330 * _scsih_tm_display_info - displays info about the device
2331 * @ioc: per adapter struct
2332 * @scmd: pointer to scsi command object
2334 * Called by task management callback handlers.
2337 _scsih_tm_display_info(struct MPT3SAS_ADAPTER *ioc, struct scsi_cmnd *scmd)
2339 struct scsi_target *starget = scmd->device->sdev_target;
2340 struct MPT3SAS_TARGET *priv_target = starget->hostdata;
2341 struct _sas_device *sas_device = NULL;
2342 unsigned long flags;
2343 char *device_str = NULL;
2347 device_str = "volume";
2349 scsi_print_command(scmd);
2350 if (priv_target->flags & MPT_TARGET_FLAGS_VOLUME) {
2351 starget_printk(KERN_INFO, starget,
2352 "%s handle(0x%04x), %s wwid(0x%016llx)\n",
2353 device_str, priv_target->handle,
2354 device_str, (unsigned long long)priv_target->sas_address);
2356 spin_lock_irqsave(&ioc->sas_device_lock, flags);
2357 sas_device = __mpt3sas_get_sdev_from_target(ioc, priv_target);
2359 if (priv_target->flags &
2360 MPT_TARGET_FLAGS_RAID_COMPONENT) {
2361 starget_printk(KERN_INFO, starget,
2362 "volume handle(0x%04x), "
2363 "volume wwid(0x%016llx)\n",
2364 sas_device->volume_handle,
2365 (unsigned long long)sas_device->volume_wwid);
2367 starget_printk(KERN_INFO, starget,
2368 "handle(0x%04x), sas_address(0x%016llx), phy(%d)\n",
2370 (unsigned long long)sas_device->sas_address,
2372 if (sas_device->enclosure_handle != 0)
2373 starget_printk(KERN_INFO, starget,
2374 "enclosure_logical_id(0x%016llx), slot(%d)\n",
2375 (unsigned long long)
2376 sas_device->enclosure_logical_id,
2378 if (sas_device->connector_name)
2379 starget_printk(KERN_INFO, starget,
2380 "enclosure level(0x%04x),connector name(%s)\n",
2381 sas_device->enclosure_level,
2382 sas_device->connector_name);
2384 sas_device_put(sas_device);
2390 * _scsih_abort - eh threads main abort routine
2391 * @scmd: pointer to scsi command object
2393 * Returns SUCCESS if command aborted else FAILED
2396 _scsih_abort(struct scsi_cmnd *scmd)
2398 struct MPT3SAS_ADAPTER *ioc = shost_priv(scmd->device->host);
2399 struct MPT3SAS_DEVICE *sas_device_priv_data;
2404 sdev_printk(KERN_INFO, scmd->device,
2405 "attempting task abort! scmd(%p)\n", scmd);
2406 _scsih_tm_display_info(ioc, scmd);
2408 sas_device_priv_data = scmd->device->hostdata;
2409 if (!sas_device_priv_data || !sas_device_priv_data->sas_target) {
2410 sdev_printk(KERN_INFO, scmd->device,
2411 "device been deleted! scmd(%p)\n", scmd);
2412 scmd->result = DID_NO_CONNECT << 16;
2413 scmd->scsi_done(scmd);
2418 /* search for the command */
2419 smid = _scsih_scsi_lookup_find_by_scmd(ioc, scmd);
2421 scmd->result = DID_RESET << 16;
2426 /* for hidden raid components and volumes this is not supported */
2427 if (sas_device_priv_data->sas_target->flags &
2428 MPT_TARGET_FLAGS_RAID_COMPONENT ||
2429 sas_device_priv_data->sas_target->flags & MPT_TARGET_FLAGS_VOLUME) {
2430 scmd->result = DID_RESET << 16;
2435 mpt3sas_halt_firmware(ioc);
2437 handle = sas_device_priv_data->sas_target->handle;
2438 r = mpt3sas_scsih_issue_tm(ioc, handle, scmd->device->channel,
2439 scmd->device->id, scmd->device->lun,
2440 MPI2_SCSITASKMGMT_TASKTYPE_ABORT_TASK, smid, 30, TM_MUTEX_ON);
2443 sdev_printk(KERN_INFO, scmd->device, "task abort: %s scmd(%p)\n",
2444 ((r == SUCCESS) ? "SUCCESS" : "FAILED"), scmd);
2449 * _scsih_dev_reset - eh threads main device reset routine
2450 * @scmd: pointer to scsi command object
2452 * Returns SUCCESS if command aborted else FAILED
2455 _scsih_dev_reset(struct scsi_cmnd *scmd)
2457 struct MPT3SAS_ADAPTER *ioc = shost_priv(scmd->device->host);
2458 struct MPT3SAS_DEVICE *sas_device_priv_data;
2459 struct _sas_device *sas_device = NULL;
2462 struct scsi_target *starget = scmd->device->sdev_target;
2463 struct MPT3SAS_TARGET *target_priv_data = starget->hostdata;
2465 sdev_printk(KERN_INFO, scmd->device,
2466 "attempting device reset! scmd(%p)\n", scmd);
2467 _scsih_tm_display_info(ioc, scmd);
2469 sas_device_priv_data = scmd->device->hostdata;
2470 if (!sas_device_priv_data || !sas_device_priv_data->sas_target) {
2471 sdev_printk(KERN_INFO, scmd->device,
2472 "device been deleted! scmd(%p)\n", scmd);
2473 scmd->result = DID_NO_CONNECT << 16;
2474 scmd->scsi_done(scmd);
2479 /* for hidden raid components obtain the volume_handle */
2481 if (sas_device_priv_data->sas_target->flags &
2482 MPT_TARGET_FLAGS_RAID_COMPONENT) {
2483 sas_device = mpt3sas_get_sdev_from_target(ioc,
2486 handle = sas_device->volume_handle;
2488 handle = sas_device_priv_data->sas_target->handle;
2491 scmd->result = DID_RESET << 16;
2496 r = mpt3sas_scsih_issue_tm(ioc, handle, scmd->device->channel,
2497 scmd->device->id, scmd->device->lun,
2498 MPI2_SCSITASKMGMT_TASKTYPE_LOGICAL_UNIT_RESET, 0, 30, TM_MUTEX_ON);
2501 sdev_printk(KERN_INFO, scmd->device, "device reset: %s scmd(%p)\n",
2502 ((r == SUCCESS) ? "SUCCESS" : "FAILED"), scmd);
2505 sas_device_put(sas_device);
2511 * _scsih_target_reset - eh threads main target reset routine
2512 * @scmd: pointer to scsi command object
2514 * Returns SUCCESS if command aborted else FAILED
2517 _scsih_target_reset(struct scsi_cmnd *scmd)
2519 struct MPT3SAS_ADAPTER *ioc = shost_priv(scmd->device->host);
2520 struct MPT3SAS_DEVICE *sas_device_priv_data;
2521 struct _sas_device *sas_device = NULL;
2524 struct scsi_target *starget = scmd->device->sdev_target;
2525 struct MPT3SAS_TARGET *target_priv_data = starget->hostdata;
2527 starget_printk(KERN_INFO, starget, "attempting target reset! scmd(%p)\n",
2529 _scsih_tm_display_info(ioc, scmd);
2531 sas_device_priv_data = scmd->device->hostdata;
2532 if (!sas_device_priv_data || !sas_device_priv_data->sas_target) {
2533 starget_printk(KERN_INFO, starget, "target been deleted! scmd(%p)\n",
2535 scmd->result = DID_NO_CONNECT << 16;
2536 scmd->scsi_done(scmd);
2541 /* for hidden raid components obtain the volume_handle */
2543 if (sas_device_priv_data->sas_target->flags &
2544 MPT_TARGET_FLAGS_RAID_COMPONENT) {
2545 sas_device = mpt3sas_get_sdev_from_target(ioc,
2548 handle = sas_device->volume_handle;
2550 handle = sas_device_priv_data->sas_target->handle;
2553 scmd->result = DID_RESET << 16;
2558 r = mpt3sas_scsih_issue_tm(ioc, handle, scmd->device->channel,
2559 scmd->device->id, 0, MPI2_SCSITASKMGMT_TASKTYPE_TARGET_RESET, 0,
2563 starget_printk(KERN_INFO, starget, "target reset: %s scmd(%p)\n",
2564 ((r == SUCCESS) ? "SUCCESS" : "FAILED"), scmd);
2567 sas_device_put(sas_device);
2574 * _scsih_host_reset - eh threads main host reset routine
2575 * @scmd: pointer to scsi command object
2577 * Returns SUCCESS if command aborted else FAILED
2580 _scsih_host_reset(struct scsi_cmnd *scmd)
2582 struct MPT3SAS_ADAPTER *ioc = shost_priv(scmd->device->host);
2585 pr_info(MPT3SAS_FMT "attempting host reset! scmd(%p)\n",
2587 scsi_print_command(scmd);
2589 if (ioc->is_driver_loading) {
2590 pr_info(MPT3SAS_FMT "Blocking the host reset\n",
2596 retval = mpt3sas_base_hard_reset_handler(ioc, CAN_SLEEP,
2598 r = (retval < 0) ? FAILED : SUCCESS;
2600 pr_info(MPT3SAS_FMT "host reset: %s scmd(%p)\n",
2601 ioc->name, ((r == SUCCESS) ? "SUCCESS" : "FAILED"), scmd);
2607 * _scsih_fw_event_add - insert and queue up fw_event
2608 * @ioc: per adapter object
2609 * @fw_event: object describing the event
2610 * Context: This function will acquire ioc->fw_event_lock.
2612 * This adds the firmware event object into link list, then queues it up to
2613 * be processed from user context.
2618 _scsih_fw_event_add(struct MPT3SAS_ADAPTER *ioc, struct fw_event_work *fw_event)
2620 unsigned long flags;
2622 if (ioc->firmware_event_thread == NULL)
2625 spin_lock_irqsave(&ioc->fw_event_lock, flags);
2626 fw_event_work_get(fw_event);
2627 INIT_LIST_HEAD(&fw_event->list);
2628 list_add_tail(&fw_event->list, &ioc->fw_event_list);
2629 INIT_WORK(&fw_event->work, _firmware_event_work);
2630 fw_event_work_get(fw_event);
2631 queue_work(ioc->firmware_event_thread, &fw_event->work);
2632 spin_unlock_irqrestore(&ioc->fw_event_lock, flags);
2636 * _scsih_fw_event_del_from_list - delete fw_event from the list
2637 * @ioc: per adapter object
2638 * @fw_event: object describing the event
2639 * Context: This function will acquire ioc->fw_event_lock.
2641 * If the fw_event is on the fw_event_list, remove it and do a put.
2646 _scsih_fw_event_del_from_list(struct MPT3SAS_ADAPTER *ioc, struct fw_event_work
2649 unsigned long flags;
2651 spin_lock_irqsave(&ioc->fw_event_lock, flags);
2652 if (!list_empty(&fw_event->list)) {
2653 list_del_init(&fw_event->list);
2654 fw_event_work_put(fw_event);
2656 spin_unlock_irqrestore(&ioc->fw_event_lock, flags);
2661 * mpt3sas_send_trigger_data_event - send event for processing trigger data
2662 * @ioc: per adapter object
2663 * @event_data: trigger event data
2668 mpt3sas_send_trigger_data_event(struct MPT3SAS_ADAPTER *ioc,
2669 struct SL_WH_TRIGGERS_EVENT_DATA_T *event_data)
2671 struct fw_event_work *fw_event;
2673 if (ioc->is_driver_loading)
2675 fw_event = alloc_fw_event_work(sizeof(*event_data));
2678 fw_event->event = MPT3SAS_PROCESS_TRIGGER_DIAG;
2679 fw_event->ioc = ioc;
2680 memcpy(fw_event->event_data, event_data, sizeof(*event_data));
2681 _scsih_fw_event_add(ioc, fw_event);
2682 fw_event_work_put(fw_event);
2686 * _scsih_error_recovery_delete_devices - remove devices not responding
2687 * @ioc: per adapter object
2692 _scsih_error_recovery_delete_devices(struct MPT3SAS_ADAPTER *ioc)
2694 struct fw_event_work *fw_event;
2696 if (ioc->is_driver_loading)
2698 fw_event = alloc_fw_event_work(0);
2701 fw_event->event = MPT3SAS_REMOVE_UNRESPONDING_DEVICES;
2702 fw_event->ioc = ioc;
2703 _scsih_fw_event_add(ioc, fw_event);
2704 fw_event_work_put(fw_event);
2708 * mpt3sas_port_enable_complete - port enable completed (fake event)
2709 * @ioc: per adapter object
2714 mpt3sas_port_enable_complete(struct MPT3SAS_ADAPTER *ioc)
2716 struct fw_event_work *fw_event;
2718 fw_event = alloc_fw_event_work(0);
2721 fw_event->event = MPT3SAS_PORT_ENABLE_COMPLETE;
2722 fw_event->ioc = ioc;
2723 _scsih_fw_event_add(ioc, fw_event);
2724 fw_event_work_put(fw_event);
2727 static struct fw_event_work *dequeue_next_fw_event(struct MPT3SAS_ADAPTER *ioc)
2729 unsigned long flags;
2730 struct fw_event_work *fw_event = NULL;
2732 spin_lock_irqsave(&ioc->fw_event_lock, flags);
2733 if (!list_empty(&ioc->fw_event_list)) {
2734 fw_event = list_first_entry(&ioc->fw_event_list,
2735 struct fw_event_work, list);
2736 list_del_init(&fw_event->list);
2738 spin_unlock_irqrestore(&ioc->fw_event_lock, flags);
2744 * _scsih_fw_event_cleanup_queue - cleanup event queue
2745 * @ioc: per adapter object
2747 * Walk the firmware event queue, either killing timers, or waiting
2748 * for outstanding events to complete
2753 _scsih_fw_event_cleanup_queue(struct MPT3SAS_ADAPTER *ioc)
2755 struct fw_event_work *fw_event;
2757 if (list_empty(&ioc->fw_event_list) ||
2758 !ioc->firmware_event_thread || in_interrupt())
2761 while ((fw_event = dequeue_next_fw_event(ioc))) {
2763 * Wait on the fw_event to complete. If this returns 1, then
2764 * the event was never executed, and we need a put for the
2765 * reference the delayed_work had on the fw_event.
2767 * If it did execute, we wait for it to finish, and the put will
2768 * happen from _firmware_event_work()
2770 if (cancel_work_sync(&fw_event->work))
2771 fw_event_work_put(fw_event);
2773 fw_event_work_put(fw_event);
2778 * _scsih_internal_device_block - block the sdev device
2779 * @sdev: per device object
2780 * @sas_device_priv_data : per device driver private data
2782 * make sure device is blocked without error, if not
2786 _scsih_internal_device_block(struct scsi_device *sdev,
2787 struct MPT3SAS_DEVICE *sas_device_priv_data)
2791 sdev_printk(KERN_INFO, sdev, "device_block, handle(0x%04x)\n",
2792 sas_device_priv_data->sas_target->handle);
2793 sas_device_priv_data->block = 1;
2795 r = scsi_internal_device_block(sdev);
2797 sdev_printk(KERN_WARNING, sdev,
2798 "device_block failed with return(%d) for handle(0x%04x)\n",
2799 sas_device_priv_data->sas_target->handle, r);
2803 * _scsih_internal_device_unblock - unblock the sdev device
2804 * @sdev: per device object
2805 * @sas_device_priv_data : per device driver private data
2806 * make sure device is unblocked without error, if not retry
2807 * by blocking and then unblocking
2811 _scsih_internal_device_unblock(struct scsi_device *sdev,
2812 struct MPT3SAS_DEVICE *sas_device_priv_data)
2816 sdev_printk(KERN_WARNING, sdev, "device_unblock and setting to running, "
2817 "handle(0x%04x)\n", sas_device_priv_data->sas_target->handle);
2818 sas_device_priv_data->block = 0;
2819 r = scsi_internal_device_unblock(sdev, SDEV_RUNNING);
2821 /* The device has been set to SDEV_RUNNING by SD layer during
2822 * device addition but the request queue is still stopped by
2823 * our earlier block call. We need to perform a block again
2824 * to get the device to SDEV_BLOCK and then to SDEV_RUNNING */
2826 sdev_printk(KERN_WARNING, sdev,
2827 "device_unblock failed with return(%d) for handle(0x%04x) "
2828 "performing a block followed by an unblock\n",
2829 sas_device_priv_data->sas_target->handle, r);
2830 sas_device_priv_data->block = 1;
2831 r = scsi_internal_device_block(sdev);
2833 sdev_printk(KERN_WARNING, sdev, "retried device_block "
2834 "failed with return(%d) for handle(0x%04x)\n",
2835 sas_device_priv_data->sas_target->handle, r);
2837 sas_device_priv_data->block = 0;
2838 r = scsi_internal_device_unblock(sdev, SDEV_RUNNING);
2840 sdev_printk(KERN_WARNING, sdev, "retried device_unblock"
2841 " failed with return(%d) for handle(0x%04x)\n",
2842 sas_device_priv_data->sas_target->handle, r);
2847 * _scsih_ublock_io_all_device - unblock every device
2848 * @ioc: per adapter object
2850 * change the device state from block to running
2853 _scsih_ublock_io_all_device(struct MPT3SAS_ADAPTER *ioc)
2855 struct MPT3SAS_DEVICE *sas_device_priv_data;
2856 struct scsi_device *sdev;
2858 shost_for_each_device(sdev, ioc->shost) {
2859 sas_device_priv_data = sdev->hostdata;
2860 if (!sas_device_priv_data)
2862 if (!sas_device_priv_data->block)
2865 dewtprintk(ioc, sdev_printk(KERN_INFO, sdev,
2866 "device_running, handle(0x%04x)\n",
2867 sas_device_priv_data->sas_target->handle));
2868 _scsih_internal_device_unblock(sdev, sas_device_priv_data);
2874 * _scsih_ublock_io_device - prepare device to be deleted
2875 * @ioc: per adapter object
2876 * @sas_addr: sas address
2878 * unblock then put device in offline state
2881 _scsih_ublock_io_device(struct MPT3SAS_ADAPTER *ioc, u64 sas_address)
2883 struct MPT3SAS_DEVICE *sas_device_priv_data;
2884 struct scsi_device *sdev;
2886 shost_for_each_device(sdev, ioc->shost) {
2887 sas_device_priv_data = sdev->hostdata;
2888 if (!sas_device_priv_data)
2890 if (sas_device_priv_data->sas_target->sas_address
2893 if (sas_device_priv_data->block)
2894 _scsih_internal_device_unblock(sdev,
2895 sas_device_priv_data);
2900 * _scsih_block_io_all_device - set the device state to SDEV_BLOCK
2901 * @ioc: per adapter object
2902 * @handle: device handle
2904 * During device pull we need to appropiately set the sdev state.
2907 _scsih_block_io_all_device(struct MPT3SAS_ADAPTER *ioc)
2909 struct MPT3SAS_DEVICE *sas_device_priv_data;
2910 struct scsi_device *sdev;
2912 shost_for_each_device(sdev, ioc->shost) {
2913 sas_device_priv_data = sdev->hostdata;
2914 if (!sas_device_priv_data)
2916 if (sas_device_priv_data->block)
2918 _scsih_internal_device_block(sdev, sas_device_priv_data);
2923 * _scsih_block_io_device - set the device state to SDEV_BLOCK
2924 * @ioc: per adapter object
2925 * @handle: device handle
2927 * During device pull we need to appropiately set the sdev state.
2930 _scsih_block_io_device(struct MPT3SAS_ADAPTER *ioc, u16 handle)
2932 struct MPT3SAS_DEVICE *sas_device_priv_data;
2933 struct scsi_device *sdev;
2934 struct _sas_device *sas_device;
2936 sas_device = __mpt3sas_get_sdev_by_handle(ioc, handle);
2940 shost_for_each_device(sdev, ioc->shost) {
2941 sas_device_priv_data = sdev->hostdata;
2942 if (!sas_device_priv_data)
2944 if (sas_device_priv_data->sas_target->handle != handle)
2946 if (sas_device_priv_data->block)
2948 if (sas_device->pend_sas_rphy_add)
2950 _scsih_internal_device_block(sdev, sas_device_priv_data);
2953 sas_device_put(sas_device);
2957 * _scsih_block_io_to_children_attached_to_ex
2958 * @ioc: per adapter object
2959 * @sas_expander: the sas_device object
2961 * This routine set sdev state to SDEV_BLOCK for all devices
2962 * attached to this expander. This function called when expander is
2966 _scsih_block_io_to_children_attached_to_ex(struct MPT3SAS_ADAPTER *ioc,
2967 struct _sas_node *sas_expander)
2969 struct _sas_port *mpt3sas_port;
2970 struct _sas_device *sas_device;
2971 struct _sas_node *expander_sibling;
2972 unsigned long flags;
2977 list_for_each_entry(mpt3sas_port,
2978 &sas_expander->sas_port_list, port_list) {
2979 if (mpt3sas_port->remote_identify.device_type == SAS_END_DEVICE) {
2980 spin_lock_irqsave(&ioc->sas_device_lock, flags);
2981 sas_device = __mpt3sas_get_sdev_by_addr(ioc,
2982 mpt3sas_port->remote_identify.sas_address);
2984 set_bit(sas_device->handle,
2985 ioc->blocking_handles);
2986 sas_device_put(sas_device);
2988 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
2992 list_for_each_entry(mpt3sas_port,
2993 &sas_expander->sas_port_list, port_list) {
2995 if (mpt3sas_port->remote_identify.device_type ==
2996 SAS_EDGE_EXPANDER_DEVICE ||
2997 mpt3sas_port->remote_identify.device_type ==
2998 SAS_FANOUT_EXPANDER_DEVICE) {
3000 mpt3sas_scsih_expander_find_by_sas_address(
3001 ioc, mpt3sas_port->remote_identify.sas_address);
3002 _scsih_block_io_to_children_attached_to_ex(ioc,
3009 * _scsih_block_io_to_children_attached_directly
3010 * @ioc: per adapter object
3011 * @event_data: topology change event data
3013 * This routine set sdev state to SDEV_BLOCK for all devices
3014 * direct attached during device pull.
3017 _scsih_block_io_to_children_attached_directly(struct MPT3SAS_ADAPTER *ioc,
3018 Mpi2EventDataSasTopologyChangeList_t *event_data)
3024 for (i = 0; i < event_data->NumEntries; i++) {
3025 handle = le16_to_cpu(event_data->PHY[i].AttachedDevHandle);
3028 reason_code = event_data->PHY[i].PhyStatus &
3029 MPI2_EVENT_SAS_TOPO_RC_MASK;
3030 if (reason_code == MPI2_EVENT_SAS_TOPO_RC_DELAY_NOT_RESPONDING)
3031 _scsih_block_io_device(ioc, handle);
3036 * _scsih_tm_tr_send - send task management request
3037 * @ioc: per adapter object
3038 * @handle: device handle
3039 * Context: interrupt time.
3041 * This code is to initiate the device removal handshake protocol
3042 * with controller firmware. This function will issue target reset
3043 * using high priority request queue. It will send a sas iounit
3044 * control request (MPI2_SAS_OP_REMOVE_DEVICE) from this completion.
3046 * This is designed to send muliple task management request at the same
3047 * time to the fifo. If the fifo is full, we will append the request,
3048 * and process it in a future completion.
3051 _scsih_tm_tr_send(struct MPT3SAS_ADAPTER *ioc, u16 handle)
3053 Mpi2SCSITaskManagementRequest_t *mpi_request;
3055 struct _sas_device *sas_device = NULL;
3056 struct MPT3SAS_TARGET *sas_target_priv_data = NULL;
3057 u64 sas_address = 0;
3058 unsigned long flags;
3059 struct _tr_list *delayed_tr;
3062 if (ioc->remove_host) {
3063 dewtprintk(ioc, pr_info(MPT3SAS_FMT
3064 "%s: host has been removed: handle(0x%04x)\n",
3065 __func__, ioc->name, handle));
3067 } else if (ioc->pci_error_recovery) {
3068 dewtprintk(ioc, pr_info(MPT3SAS_FMT
3069 "%s: host in pci error recovery: handle(0x%04x)\n",
3070 __func__, ioc->name,
3074 ioc_state = mpt3sas_base_get_iocstate(ioc, 1);
3075 if (ioc_state != MPI2_IOC_STATE_OPERATIONAL) {
3076 dewtprintk(ioc, pr_info(MPT3SAS_FMT
3077 "%s: host is not operational: handle(0x%04x)\n",
3078 __func__, ioc->name,
3083 /* if PD, then return */
3084 if (test_bit(handle, ioc->pd_handles))
3087 spin_lock_irqsave(&ioc->sas_device_lock, flags);
3088 sas_device = __mpt3sas_get_sdev_by_handle(ioc, handle);
3089 if (sas_device && sas_device->starget &&
3090 sas_device->starget->hostdata) {
3091 sas_target_priv_data = sas_device->starget->hostdata;
3092 sas_target_priv_data->deleted = 1;
3093 sas_address = sas_device->sas_address;
3095 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
3097 if (sas_target_priv_data) {
3098 dewtprintk(ioc, pr_info(MPT3SAS_FMT
3099 "setting delete flag: handle(0x%04x), sas_addr(0x%016llx)\n",
3101 (unsigned long long)sas_address));
3102 if (sas_device->enclosure_handle != 0)
3103 dewtprintk(ioc, pr_info(MPT3SAS_FMT
3104 "setting delete flag:enclosure logical id(0x%016llx),"
3105 " slot(%d)\n", ioc->name, (unsigned long long)
3106 sas_device->enclosure_logical_id,
3108 if (sas_device->connector_name)
3109 dewtprintk(ioc, pr_info(MPT3SAS_FMT
3110 "setting delete flag: enclosure level(0x%04x),"
3111 " connector name( %s)\n", ioc->name,
3112 sas_device->enclosure_level,
3113 sas_device->connector_name));
3114 _scsih_ublock_io_device(ioc, sas_address);
3115 sas_target_priv_data->handle = MPT3SAS_INVALID_DEVICE_HANDLE;
3118 smid = mpt3sas_base_get_smid_hpr(ioc, ioc->tm_tr_cb_idx);
3120 delayed_tr = kzalloc(sizeof(*delayed_tr), GFP_ATOMIC);
3123 INIT_LIST_HEAD(&delayed_tr->list);
3124 delayed_tr->handle = handle;
3125 list_add_tail(&delayed_tr->list, &ioc->delayed_tr_list);
3126 dewtprintk(ioc, pr_info(MPT3SAS_FMT
3127 "DELAYED:tr:handle(0x%04x), (open)\n",
3128 ioc->name, handle));
3132 dewtprintk(ioc, pr_info(MPT3SAS_FMT
3133 "tr_send:handle(0x%04x), (open), smid(%d), cb(%d)\n",
3134 ioc->name, handle, smid,
3135 ioc->tm_tr_cb_idx));
3136 mpi_request = mpt3sas_base_get_msg_frame(ioc, smid);
3137 memset(mpi_request, 0, sizeof(Mpi2SCSITaskManagementRequest_t));
3138 mpi_request->Function = MPI2_FUNCTION_SCSI_TASK_MGMT;
3139 mpi_request->DevHandle = cpu_to_le16(handle);
3140 mpi_request->TaskType = MPI2_SCSITASKMGMT_TASKTYPE_TARGET_RESET;
3141 mpt3sas_base_put_smid_hi_priority(ioc, smid);
3142 mpt3sas_trigger_master(ioc, MASTER_TRIGGER_DEVICE_REMOVAL);
3145 sas_device_put(sas_device);
3149 * _scsih_tm_tr_complete -
3150 * @ioc: per adapter object
3151 * @smid: system request message index
3152 * @msix_index: MSIX table index supplied by the OS
3153 * @reply: reply message frame(lower 32bit addr)
3154 * Context: interrupt time.
3156 * This is the target reset completion routine.
3157 * This code is part of the code to initiate the device removal
3158 * handshake protocol with controller firmware.
3159 * It will send a sas iounit control request (MPI2_SAS_OP_REMOVE_DEVICE)
3161 * Return 1 meaning mf should be freed from _base_interrupt
3162 * 0 means the mf is freed from this function.
3165 _scsih_tm_tr_complete(struct MPT3SAS_ADAPTER *ioc, u16 smid, u8 msix_index,
3169 Mpi2SCSITaskManagementRequest_t *mpi_request_tm;
3170 Mpi2SCSITaskManagementReply_t *mpi_reply =
3171 mpt3sas_base_get_reply_virt_addr(ioc, reply);
3172 Mpi2SasIoUnitControlRequest_t *mpi_request;
3176 if (ioc->remove_host) {
3177 dewtprintk(ioc, pr_info(MPT3SAS_FMT
3178 "%s: host has been removed\n", __func__, ioc->name));
3180 } else if (ioc->pci_error_recovery) {
3181 dewtprintk(ioc, pr_info(MPT3SAS_FMT
3182 "%s: host in pci error recovery\n", __func__,
3186 ioc_state = mpt3sas_base_get_iocstate(ioc, 1);
3187 if (ioc_state != MPI2_IOC_STATE_OPERATIONAL) {
3188 dewtprintk(ioc, pr_info(MPT3SAS_FMT
3189 "%s: host is not operational\n", __func__, ioc->name));
3192 if (unlikely(!mpi_reply)) {
3193 pr_err(MPT3SAS_FMT "mpi_reply not valid at %s:%d/%s()!\n",
3194 ioc->name, __FILE__, __LINE__, __func__);
3197 mpi_request_tm = mpt3sas_base_get_msg_frame(ioc, smid);
3198 handle = le16_to_cpu(mpi_request_tm->DevHandle);
3199 if (handle != le16_to_cpu(mpi_reply->DevHandle)) {
3200 dewtprintk(ioc, pr_err(MPT3SAS_FMT
3201 "spurious interrupt: handle(0x%04x:0x%04x), smid(%d)!!!\n",
3203 le16_to_cpu(mpi_reply->DevHandle), smid));
3207 mpt3sas_trigger_master(ioc, MASTER_TRIGGER_TASK_MANAGMENT);
3208 dewtprintk(ioc, pr_info(MPT3SAS_FMT
3209 "tr_complete:handle(0x%04x), (open) smid(%d), ioc_status(0x%04x), "
3210 "loginfo(0x%08x), completed(%d)\n", ioc->name,
3211 handle, smid, le16_to_cpu(mpi_reply->IOCStatus),
3212 le32_to_cpu(mpi_reply->IOCLogInfo),
3213 le32_to_cpu(mpi_reply->TerminationCount)));
3215 smid_sas_ctrl = mpt3sas_base_get_smid(ioc, ioc->tm_sas_control_cb_idx);
3216 if (!smid_sas_ctrl) {
3217 pr_err(MPT3SAS_FMT "%s: failed obtaining a smid\n",
3218 ioc->name, __func__);
3222 dewtprintk(ioc, pr_info(MPT3SAS_FMT
3223 "sc_send:handle(0x%04x), (open), smid(%d), cb(%d)\n",
3224 ioc->name, handle, smid_sas_ctrl,
3225 ioc->tm_sas_control_cb_idx));
3226 mpi_request = mpt3sas_base_get_msg_frame(ioc, smid_sas_ctrl);
3227 memset(mpi_request, 0, sizeof(Mpi2SasIoUnitControlRequest_t));
3228 mpi_request->Function = MPI2_FUNCTION_SAS_IO_UNIT_CONTROL;
3229 mpi_request->Operation = MPI2_SAS_OP_REMOVE_DEVICE;
3230 mpi_request->DevHandle = mpi_request_tm->DevHandle;
3231 mpt3sas_base_put_smid_default(ioc, smid_sas_ctrl);
3233 return _scsih_check_for_pending_tm(ioc, smid);
3238 * _scsih_sas_control_complete - completion routine
3239 * @ioc: per adapter object
3240 * @smid: system request message index
3241 * @msix_index: MSIX table index supplied by the OS
3242 * @reply: reply message frame(lower 32bit addr)
3243 * Context: interrupt time.
3245 * This is the sas iounit control completion routine.
3246 * This code is part of the code to initiate the device removal
3247 * handshake protocol with controller firmware.
3249 * Return 1 meaning mf should be freed from _base_interrupt
3250 * 0 means the mf is freed from this function.
3253 _scsih_sas_control_complete(struct MPT3SAS_ADAPTER *ioc, u16 smid,
3254 u8 msix_index, u32 reply)
3256 Mpi2SasIoUnitControlReply_t *mpi_reply =
3257 mpt3sas_base_get_reply_virt_addr(ioc, reply);
3259 if (likely(mpi_reply)) {
3260 dewtprintk(ioc, pr_info(MPT3SAS_FMT
3261 "sc_complete:handle(0x%04x), (open) "
3262 "smid(%d), ioc_status(0x%04x), loginfo(0x%08x)\n",
3263 ioc->name, le16_to_cpu(mpi_reply->DevHandle), smid,
3264 le16_to_cpu(mpi_reply->IOCStatus),
3265 le32_to_cpu(mpi_reply->IOCLogInfo)));
3267 pr_err(MPT3SAS_FMT "mpi_reply not valid at %s:%d/%s()!\n",
3268 ioc->name, __FILE__, __LINE__, __func__);
3274 * _scsih_tm_tr_volume_send - send target reset request for volumes
3275 * @ioc: per adapter object
3276 * @handle: device handle
3277 * Context: interrupt time.
3279 * This is designed to send muliple task management request at the same
3280 * time to the fifo. If the fifo is full, we will append the request,
3281 * and process it in a future completion.
3284 _scsih_tm_tr_volume_send(struct MPT3SAS_ADAPTER *ioc, u16 handle)
3286 Mpi2SCSITaskManagementRequest_t *mpi_request;
3288 struct _tr_list *delayed_tr;
3290 if (ioc->shost_recovery || ioc->remove_host ||
3291 ioc->pci_error_recovery) {
3292 dewtprintk(ioc, pr_info(MPT3SAS_FMT
3293 "%s: host reset in progress!\n",
3294 __func__, ioc->name));
3298 smid = mpt3sas_base_get_smid_hpr(ioc, ioc->tm_tr_volume_cb_idx);
3300 delayed_tr = kzalloc(sizeof(*delayed_tr), GFP_ATOMIC);
3303 INIT_LIST_HEAD(&delayed_tr->list);
3304 delayed_tr->handle = handle;
3305 list_add_tail(&delayed_tr->list, &ioc->delayed_tr_volume_list);
3306 dewtprintk(ioc, pr_info(MPT3SAS_FMT
3307 "DELAYED:tr:handle(0x%04x), (open)\n",
3308 ioc->name, handle));
3312 dewtprintk(ioc, pr_info(MPT3SAS_FMT
3313 "tr_send:handle(0x%04x), (open), smid(%d), cb(%d)\n",
3314 ioc->name, handle, smid,
3315 ioc->tm_tr_volume_cb_idx));
3316 mpi_request = mpt3sas_base_get_msg_frame(ioc, smid);
3317 memset(mpi_request, 0, sizeof(Mpi2SCSITaskManagementRequest_t));
3318 mpi_request->Function = MPI2_FUNCTION_SCSI_TASK_MGMT;
3319 mpi_request->DevHandle = cpu_to_le16(handle);
3320 mpi_request->TaskType = MPI2_SCSITASKMGMT_TASKTYPE_TARGET_RESET;
3321 mpt3sas_base_put_smid_hi_priority(ioc, smid);
3325 * _scsih_tm_volume_tr_complete - target reset completion
3326 * @ioc: per adapter object
3327 * @smid: system request message index
3328 * @msix_index: MSIX table index supplied by the OS
3329 * @reply: reply message frame(lower 32bit addr)
3330 * Context: interrupt time.
3332 * Return 1 meaning mf should be freed from _base_interrupt
3333 * 0 means the mf is freed from this function.
3336 _scsih_tm_volume_tr_complete(struct MPT3SAS_ADAPTER *ioc, u16 smid,
3337 u8 msix_index, u32 reply)
3340 Mpi2SCSITaskManagementRequest_t *mpi_request_tm;
3341 Mpi2SCSITaskManagementReply_t *mpi_reply =
3342 mpt3sas_base_get_reply_virt_addr(ioc, reply);
3344 if (ioc->shost_recovery || ioc->remove_host ||
3345 ioc->pci_error_recovery) {
3346 dewtprintk(ioc, pr_info(MPT3SAS_FMT
3347 "%s: host reset in progress!\n",
3348 __func__, ioc->name));
3351 if (unlikely(!mpi_reply)) {
3352 pr_err(MPT3SAS_FMT "mpi_reply not valid at %s:%d/%s()!\n",
3353 ioc->name, __FILE__, __LINE__, __func__);
3357 mpi_request_tm = mpt3sas_base_get_msg_frame(ioc, smid);
3358 handle = le16_to_cpu(mpi_request_tm->DevHandle);
3359 if (handle != le16_to_cpu(mpi_reply->DevHandle)) {
3360 dewtprintk(ioc, pr_err(MPT3SAS_FMT
3361 "spurious interrupt: handle(0x%04x:0x%04x), smid(%d)!!!\n",
3363 le16_to_cpu(mpi_reply->DevHandle), smid));
3367 dewtprintk(ioc, pr_info(MPT3SAS_FMT
3368 "tr_complete:handle(0x%04x), (open) smid(%d), ioc_status(0x%04x), "
3369 "loginfo(0x%08x), completed(%d)\n", ioc->name,
3370 handle, smid, le16_to_cpu(mpi_reply->IOCStatus),
3371 le32_to_cpu(mpi_reply->IOCLogInfo),
3372 le32_to_cpu(mpi_reply->TerminationCount)));
3374 return _scsih_check_for_pending_tm(ioc, smid);
3379 * _scsih_check_for_pending_tm - check for pending task management
3380 * @ioc: per adapter object
3381 * @smid: system request message index
3383 * This will check delayed target reset list, and feed the
3386 * Return 1 meaning mf should be freed from _base_interrupt
3387 * 0 means the mf is freed from this function.
3390 _scsih_check_for_pending_tm(struct MPT3SAS_ADAPTER *ioc, u16 smid)
3392 struct _tr_list *delayed_tr;
3394 if (!list_empty(&ioc->delayed_tr_volume_list)) {
3395 delayed_tr = list_entry(ioc->delayed_tr_volume_list.next,
3396 struct _tr_list, list);
3397 mpt3sas_base_free_smid(ioc, smid);
3398 _scsih_tm_tr_volume_send(ioc, delayed_tr->handle);
3399 list_del(&delayed_tr->list);
3404 if (!list_empty(&ioc->delayed_tr_list)) {
3405 delayed_tr = list_entry(ioc->delayed_tr_list.next,
3406 struct _tr_list, list);
3407 mpt3sas_base_free_smid(ioc, smid);
3408 _scsih_tm_tr_send(ioc, delayed_tr->handle);
3409 list_del(&delayed_tr->list);
3418 * _scsih_check_topo_delete_events - sanity check on topo events
3419 * @ioc: per adapter object
3420 * @event_data: the event data payload
3422 * This routine added to better handle cable breaker.
3424 * This handles the case where driver receives multiple expander
3425 * add and delete events in a single shot. When there is a delete event
3426 * the routine will void any pending add events waiting in the event queue.
3431 _scsih_check_topo_delete_events(struct MPT3SAS_ADAPTER *ioc,
3432 Mpi2EventDataSasTopologyChangeList_t *event_data)
3434 struct fw_event_work *fw_event;
3435 Mpi2EventDataSasTopologyChangeList_t *local_event_data;
3436 u16 expander_handle;
3437 struct _sas_node *sas_expander;
3438 unsigned long flags;
3442 for (i = 0 ; i < event_data->NumEntries; i++) {
3443 handle = le16_to_cpu(event_data->PHY[i].AttachedDevHandle);
3446 reason_code = event_data->PHY[i].PhyStatus &
3447 MPI2_EVENT_SAS_TOPO_RC_MASK;
3448 if (reason_code == MPI2_EVENT_SAS_TOPO_RC_TARG_NOT_RESPONDING)
3449 _scsih_tm_tr_send(ioc, handle);
3452 expander_handle = le16_to_cpu(event_data->ExpanderDevHandle);
3453 if (expander_handle < ioc->sas_hba.num_phys) {
3454 _scsih_block_io_to_children_attached_directly(ioc, event_data);
3457 if (event_data->ExpStatus ==
3458 MPI2_EVENT_SAS_TOPO_ES_DELAY_NOT_RESPONDING) {
3459 /* put expander attached devices into blocking state */
3460 spin_lock_irqsave(&ioc->sas_node_lock, flags);
3461 sas_expander = mpt3sas_scsih_expander_find_by_handle(ioc,
3463 _scsih_block_io_to_children_attached_to_ex(ioc, sas_expander);
3464 spin_unlock_irqrestore(&ioc->sas_node_lock, flags);
3466 handle = find_first_bit(ioc->blocking_handles,
3467 ioc->facts.MaxDevHandle);
3468 if (handle < ioc->facts.MaxDevHandle)
3469 _scsih_block_io_device(ioc, handle);
3470 } while (test_and_clear_bit(handle, ioc->blocking_handles));
3471 } else if (event_data->ExpStatus == MPI2_EVENT_SAS_TOPO_ES_RESPONDING)
3472 _scsih_block_io_to_children_attached_directly(ioc, event_data);
3474 if (event_data->ExpStatus != MPI2_EVENT_SAS_TOPO_ES_NOT_RESPONDING)
3477 /* mark ignore flag for pending events */
3478 spin_lock_irqsave(&ioc->fw_event_lock, flags);
3479 list_for_each_entry(fw_event, &ioc->fw_event_list, list) {
3480 if (fw_event->event != MPI2_EVENT_SAS_TOPOLOGY_CHANGE_LIST ||
3483 local_event_data = (Mpi2EventDataSasTopologyChangeList_t *)
3484 fw_event->event_data;
3485 if (local_event_data->ExpStatus ==
3486 MPI2_EVENT_SAS_TOPO_ES_ADDED ||
3487 local_event_data->ExpStatus ==
3488 MPI2_EVENT_SAS_TOPO_ES_RESPONDING) {
3489 if (le16_to_cpu(local_event_data->ExpanderDevHandle) ==
3491 dewtprintk(ioc, pr_info(MPT3SAS_FMT
3492 "setting ignoring flag\n", ioc->name));
3493 fw_event->ignore = 1;
3497 spin_unlock_irqrestore(&ioc->fw_event_lock, flags);
3501 * _scsih_set_volume_delete_flag - setting volume delete flag
3502 * @ioc: per adapter object
3503 * @handle: device handle
3505 * This returns nothing.
3508 _scsih_set_volume_delete_flag(struct MPT3SAS_ADAPTER *ioc, u16 handle)
3510 struct _raid_device *raid_device;
3511 struct MPT3SAS_TARGET *sas_target_priv_data;
3512 unsigned long flags;
3514 spin_lock_irqsave(&ioc->raid_device_lock, flags);
3515 raid_device = _scsih_raid_device_find_by_handle(ioc, handle);
3516 if (raid_device && raid_device->starget &&
3517 raid_device->starget->hostdata) {
3518 sas_target_priv_data =
3519 raid_device->starget->hostdata;
3520 sas_target_priv_data->deleted = 1;
3521 dewtprintk(ioc, pr_info(MPT3SAS_FMT
3522 "setting delete flag: handle(0x%04x), "
3523 "wwid(0x%016llx)\n", ioc->name, handle,
3524 (unsigned long long) raid_device->wwid));
3526 spin_unlock_irqrestore(&ioc->raid_device_lock, flags);
3530 * _scsih_set_volume_handle_for_tr - set handle for target reset to volume
3531 * @handle: input handle
3532 * @a: handle for volume a
3533 * @b: handle for volume b
3535 * IR firmware only supports two raid volumes. The purpose of this
3536 * routine is to set the volume handle in either a or b. When the given
3537 * input handle is non-zero, or when a and b have not been set before.
3540 _scsih_set_volume_handle_for_tr(u16 handle, u16 *a, u16 *b)
3542 if (!handle || handle == *a || handle == *b)
3551 * _scsih_check_ir_config_unhide_events - check for UNHIDE events
3552 * @ioc: per adapter object
3553 * @event_data: the event data payload
3554 * Context: interrupt time.
3556 * This routine will send target reset to volume, followed by target
3557 * resets to the PDs. This is called when a PD has been removed, or
3558 * volume has been deleted or removed. When the target reset is sent
3559 * to volume, the PD target resets need to be queued to start upon
3560 * completion of the volume target reset.
3565 _scsih_check_ir_config_unhide_events(struct MPT3SAS_ADAPTER *ioc,
3566 Mpi2EventDataIrConfigChangeList_t *event_data)
3568 Mpi2EventIrConfigElement_t *element;
3570 u16 handle, volume_handle, a, b;
3571 struct _tr_list *delayed_tr;
3576 /* Volume Resets for Deleted or Removed */
3577 element = (Mpi2EventIrConfigElement_t *)&event_data->ConfigElement[0];
3578 for (i = 0; i < event_data->NumElements; i++, element++) {
3579 if (le32_to_cpu(event_data->Flags) &
3580 MPI2_EVENT_IR_CHANGE_FLAGS_FOREIGN_CONFIG)
3582 if (element->ReasonCode ==
3583 MPI2_EVENT_IR_CHANGE_RC_VOLUME_DELETED ||
3584 element->ReasonCode ==
3585 MPI2_EVENT_IR_CHANGE_RC_REMOVED) {
3586 volume_handle = le16_to_cpu(element->VolDevHandle);
3587 _scsih_set_volume_delete_flag(ioc, volume_handle);
3588 _scsih_set_volume_handle_for_tr(volume_handle, &a, &b);
3592 /* Volume Resets for UNHIDE events */
3593 element = (Mpi2EventIrConfigElement_t *)&event_data->ConfigElement[0];
3594 for (i = 0; i < event_data->NumElements; i++, element++) {
3595 if (le32_to_cpu(event_data->Flags) &
3596 MPI2_EVENT_IR_CHANGE_FLAGS_FOREIGN_CONFIG)
3598 if (element->ReasonCode == MPI2_EVENT_IR_CHANGE_RC_UNHIDE) {
3599 volume_handle = le16_to_cpu(element->VolDevHandle);
3600 _scsih_set_volume_handle_for_tr(volume_handle, &a, &b);
3605 _scsih_tm_tr_volume_send(ioc, a);
3607 _scsih_tm_tr_volume_send(ioc, b);
3609 /* PD target resets */
3610 element = (Mpi2EventIrConfigElement_t *)&event_data->ConfigElement[0];
3611 for (i = 0; i < event_data->NumElements; i++, element++) {
3612 if (element->ReasonCode != MPI2_EVENT_IR_CHANGE_RC_UNHIDE)
3614 handle = le16_to_cpu(element->PhysDiskDevHandle);
3615 volume_handle = le16_to_cpu(element->VolDevHandle);
3616 clear_bit(handle, ioc->pd_handles);
3618 _scsih_tm_tr_send(ioc, handle);
3619 else if (volume_handle == a || volume_handle == b) {
3620 delayed_tr = kzalloc(sizeof(*delayed_tr), GFP_ATOMIC);
3621 BUG_ON(!delayed_tr);
3622 INIT_LIST_HEAD(&delayed_tr->list);
3623 delayed_tr->handle = handle;
3624 list_add_tail(&delayed_tr->list, &ioc->delayed_tr_list);
3625 dewtprintk(ioc, pr_info(MPT3SAS_FMT
3626 "DELAYED:tr:handle(0x%04x), (open)\n", ioc->name,
3629 _scsih_tm_tr_send(ioc, handle);
3635 * _scsih_check_volume_delete_events - set delete flag for volumes
3636 * @ioc: per adapter object
3637 * @event_data: the event data payload
3638 * Context: interrupt time.
3640 * This will handle the case when the cable connected to entire volume is
3641 * pulled. We will take care of setting the deleted flag so normal IO will
3647 _scsih_check_volume_delete_events(struct MPT3SAS_ADAPTER *ioc,
3648 Mpi2EventDataIrVolume_t *event_data)
3652 if (event_data->ReasonCode != MPI2_EVENT_IR_VOLUME_RC_STATE_CHANGED)
3654 state = le32_to_cpu(event_data->NewValue);
3655 if (state == MPI2_RAID_VOL_STATE_MISSING || state ==
3656 MPI2_RAID_VOL_STATE_FAILED)
3657 _scsih_set_volume_delete_flag(ioc,
3658 le16_to_cpu(event_data->VolDevHandle));
3662 * _scsih_temp_threshold_events - display temperature threshold exceeded events
3663 * @ioc: per adapter object
3664 * @event_data: the temp threshold event data
3665 * Context: interrupt time.
3670 _scsih_temp_threshold_events(struct MPT3SAS_ADAPTER *ioc,
3671 Mpi2EventDataTemperature_t *event_data)
3673 if (ioc->temp_sensors_count >= event_data->SensorNum) {
3674 pr_err(MPT3SAS_FMT "Temperature Threshold flags %s%s%s%s"
3675 " exceeded for Sensor: %d !!!\n", ioc->name,
3676 ((le16_to_cpu(event_data->Status) & 0x1) == 1) ? "0 " : " ",
3677 ((le16_to_cpu(event_data->Status) & 0x2) == 2) ? "1 " : " ",
3678 ((le16_to_cpu(event_data->Status) & 0x4) == 4) ? "2 " : " ",
3679 ((le16_to_cpu(event_data->Status) & 0x8) == 8) ? "3 " : " ",
3680 event_data->SensorNum);
3681 pr_err(MPT3SAS_FMT "Current Temp In Celsius: %d\n",
3682 ioc->name, event_data->CurrentTemperature);
3687 * _scsih_flush_running_cmds - completing outstanding commands.
3688 * @ioc: per adapter object
3690 * The flushing out of all pending scmd commands following host reset,
3691 * where all IO is dropped to the floor.
3696 _scsih_flush_running_cmds(struct MPT3SAS_ADAPTER *ioc)
3698 struct scsi_cmnd *scmd;
3702 for (smid = 1; smid <= ioc->scsiio_depth; smid++) {
3703 scmd = _scsih_scsi_lookup_get_clear(ioc, smid);
3707 mpt3sas_base_free_smid(ioc, smid);
3708 scsi_dma_unmap(scmd);
3709 if (ioc->pci_error_recovery)
3710 scmd->result = DID_NO_CONNECT << 16;
3712 scmd->result = DID_RESET << 16;
3713 scmd->scsi_done(scmd);
3715 dtmprintk(ioc, pr_info(MPT3SAS_FMT "completing %d cmds\n",
3720 * _scsih_setup_eedp - setup MPI request for EEDP transfer
3721 * @ioc: per adapter object
3722 * @scmd: pointer to scsi command object
3723 * @mpi_request: pointer to the SCSI_IO reqest message frame
3725 * Supporting protection 1 and 3.
3730 _scsih_setup_eedp(struct MPT3SAS_ADAPTER *ioc, struct scsi_cmnd *scmd,
3731 Mpi2SCSIIORequest_t *mpi_request)
3734 unsigned char prot_op = scsi_get_prot_op(scmd);
3735 unsigned char prot_type = scsi_get_prot_type(scmd);
3736 Mpi25SCSIIORequest_t *mpi_request_3v =
3737 (Mpi25SCSIIORequest_t *)mpi_request;
3739 if (prot_type == SCSI_PROT_DIF_TYPE0 || prot_op == SCSI_PROT_NORMAL)
3742 if (prot_op == SCSI_PROT_READ_STRIP)
3743 eedp_flags = MPI2_SCSIIO_EEDPFLAGS_CHECK_REMOVE_OP;
3744 else if (prot_op == SCSI_PROT_WRITE_INSERT)
3745 eedp_flags = MPI2_SCSIIO_EEDPFLAGS_INSERT_OP;
3749 switch (prot_type) {
3750 case SCSI_PROT_DIF_TYPE1:
3751 case SCSI_PROT_DIF_TYPE2:
3754 * enable ref/guard checking
3755 * auto increment ref tag
3757 eedp_flags |= MPI2_SCSIIO_EEDPFLAGS_INC_PRI_REFTAG |
3758 MPI2_SCSIIO_EEDPFLAGS_CHECK_REFTAG |
3759 MPI2_SCSIIO_EEDPFLAGS_CHECK_GUARD;
3760 mpi_request->CDB.EEDP32.PrimaryReferenceTag =
3761 cpu_to_be32(scsi_get_lba(scmd));
3764 case SCSI_PROT_DIF_TYPE3:
3767 * enable guard checking
3769 eedp_flags |= MPI2_SCSIIO_EEDPFLAGS_CHECK_GUARD;
3774 mpi_request_3v->EEDPBlockSize =
3775 cpu_to_le16(scmd->device->sector_size);
3776 mpi_request->EEDPFlags = cpu_to_le16(eedp_flags);
3780 * _scsih_eedp_error_handling - return sense code for EEDP errors
3781 * @scmd: pointer to scsi command object
3782 * @ioc_status: ioc status
3787 _scsih_eedp_error_handling(struct scsi_cmnd *scmd, u16 ioc_status)
3791 switch (ioc_status) {
3792 case MPI2_IOCSTATUS_EEDP_GUARD_ERROR:
3795 case MPI2_IOCSTATUS_EEDP_APP_TAG_ERROR:
3798 case MPI2_IOCSTATUS_EEDP_REF_TAG_ERROR:
3805 scsi_build_sense_buffer(0, scmd->sense_buffer, ILLEGAL_REQUEST, 0x10,
3807 scmd->result = DRIVER_SENSE << 24 | (DID_ABORT << 16) |
3808 SAM_STAT_CHECK_CONDITION;
3813 * _scsih_qcmd - main scsi request entry point
3814 * @scmd: pointer to scsi command object
3815 * @done: function pointer to be invoked on completion
3817 * The callback index is set inside `ioc->scsi_io_cb_idx`.
3819 * Returns 0 on success. If there's a failure, return either:
3820 * SCSI_MLQUEUE_DEVICE_BUSY if the device queue is full, or
3821 * SCSI_MLQUEUE_HOST_BUSY if the entire host queue is full
3824 _scsih_qcmd(struct Scsi_Host *shost, struct scsi_cmnd *scmd)
3826 struct MPT3SAS_ADAPTER *ioc = shost_priv(shost);
3827 struct MPT3SAS_DEVICE *sas_device_priv_data;
3828 struct MPT3SAS_TARGET *sas_target_priv_data;
3829 Mpi2SCSIIORequest_t *mpi_request;
3834 #ifdef CONFIG_SCSI_MPT3SAS_LOGGING
3835 if (ioc->logging_level & MPT_DEBUG_SCSI)
3836 scsi_print_command(scmd);
3839 sas_device_priv_data = scmd->device->hostdata;
3840 if (!sas_device_priv_data || !sas_device_priv_data->sas_target) {
3841 scmd->result = DID_NO_CONNECT << 16;
3842 scmd->scsi_done(scmd);
3846 if (ioc->pci_error_recovery || ioc->remove_host) {
3847 scmd->result = DID_NO_CONNECT << 16;
3848 scmd->scsi_done(scmd);
3852 sas_target_priv_data = sas_device_priv_data->sas_target;
3854 /* invalid device handle */
3855 handle = sas_target_priv_data->handle;
3856 if (handle == MPT3SAS_INVALID_DEVICE_HANDLE) {
3857 scmd->result = DID_NO_CONNECT << 16;
3858 scmd->scsi_done(scmd);
3863 /* host recovery or link resets sent via IOCTLs */
3864 if (ioc->shost_recovery || ioc->ioc_link_reset_in_progress)
3865 return SCSI_MLQUEUE_HOST_BUSY;
3867 /* device has been deleted */
3868 else if (sas_target_priv_data->deleted) {
3869 scmd->result = DID_NO_CONNECT << 16;
3870 scmd->scsi_done(scmd);
3872 /* device busy with task managment */
3873 } else if (sas_target_priv_data->tm_busy ||
3874 sas_device_priv_data->block)
3875 return SCSI_MLQUEUE_DEVICE_BUSY;
3877 if (scmd->sc_data_direction == DMA_FROM_DEVICE)
3878 mpi_control = MPI2_SCSIIO_CONTROL_READ;
3879 else if (scmd->sc_data_direction == DMA_TO_DEVICE)
3880 mpi_control = MPI2_SCSIIO_CONTROL_WRITE;
3882 mpi_control = MPI2_SCSIIO_CONTROL_NODATATRANSFER;
3885 mpi_control |= MPI2_SCSIIO_CONTROL_SIMPLEQ;
3887 if ((sas_device_priv_data->flags & MPT_DEVICE_TLR_ON) &&
3888 scmd->cmd_len != 32)
3889 mpi_control |= MPI2_SCSIIO_CONTROL_TLR_ON;
3891 smid = mpt3sas_base_get_smid_scsiio(ioc, ioc->scsi_io_cb_idx, scmd);
3893 pr_err(MPT3SAS_FMT "%s: failed obtaining a smid\n",
3894 ioc->name, __func__);
3897 mpi_request = mpt3sas_base_get_msg_frame(ioc, smid);
3898 memset(mpi_request, 0, sizeof(Mpi2SCSIIORequest_t));
3899 _scsih_setup_eedp(ioc, scmd, mpi_request);
3901 if (scmd->cmd_len == 32)
3902 mpi_control |= 4 << MPI2_SCSIIO_CONTROL_ADDCDBLEN_SHIFT;
3903 mpi_request->Function = MPI2_FUNCTION_SCSI_IO_REQUEST;
3904 if (sas_device_priv_data->sas_target->flags &
3905 MPT_TARGET_FLAGS_RAID_COMPONENT)
3906 mpi_request->Function = MPI2_FUNCTION_RAID_SCSI_IO_PASSTHROUGH;
3908 mpi_request->Function = MPI2_FUNCTION_SCSI_IO_REQUEST;
3909 mpi_request->DevHandle = cpu_to_le16(handle);
3910 mpi_request->DataLength = cpu_to_le32(scsi_bufflen(scmd));
3911 mpi_request->Control = cpu_to_le32(mpi_control);
3912 mpi_request->IoFlags = cpu_to_le16(scmd->cmd_len);
3913 mpi_request->MsgFlags = MPI2_SCSIIO_MSGFLAGS_SYSTEM_SENSE_ADDR;
3914 mpi_request->SenseBufferLength = SCSI_SENSE_BUFFERSIZE;
3915 mpi_request->SenseBufferLowAddress =
3916 mpt3sas_base_get_sense_buffer_dma(ioc, smid);
3917 mpi_request->SGLOffset0 = offsetof(Mpi2SCSIIORequest_t, SGL) / 4;
3918 int_to_scsilun(sas_device_priv_data->lun, (struct scsi_lun *)
3920 memcpy(mpi_request->CDB.CDB32, scmd->cmnd, scmd->cmd_len);
3922 if (mpi_request->DataLength) {
3923 if (ioc->build_sg_scmd(ioc, scmd, smid)) {
3924 mpt3sas_base_free_smid(ioc, smid);
3928 ioc->build_zero_len_sge(ioc, &mpi_request->SGL);
3930 if (likely(mpi_request->Function == MPI2_FUNCTION_SCSI_IO_REQUEST)) {
3931 if (sas_target_priv_data->flags & MPT_TARGET_FASTPATH_IO) {
3932 mpi_request->IoFlags = cpu_to_le16(scmd->cmd_len |
3933 MPI25_SCSIIO_IOFLAGS_FAST_PATH);
3934 mpt3sas_base_put_smid_fast_path(ioc, smid, handle);
3936 mpt3sas_base_put_smid_scsi_io(ioc, smid, handle);
3938 mpt3sas_base_put_smid_default(ioc, smid);
3942 return SCSI_MLQUEUE_HOST_BUSY;
3946 * _scsih_normalize_sense - normalize descriptor and fixed format sense data
3947 * @sense_buffer: sense data returned by target
3948 * @data: normalized skey/asc/ascq
3953 _scsih_normalize_sense(char *sense_buffer, struct sense_info *data)
3955 if ((sense_buffer[0] & 0x7F) >= 0x72) {
3956 /* descriptor format */
3957 data->skey = sense_buffer[1] & 0x0F;
3958 data->asc = sense_buffer[2];
3959 data->ascq = sense_buffer[3];
3962 data->skey = sense_buffer[2] & 0x0F;
3963 data->asc = sense_buffer[12];
3964 data->ascq = sense_buffer[13];
3968 #ifdef CONFIG_SCSI_MPT3SAS_LOGGING
3970 * _scsih_scsi_ioc_info - translated non-succesfull SCSI_IO request
3971 * @ioc: per adapter object
3972 * @scmd: pointer to scsi command object
3973 * @mpi_reply: reply mf payload returned from firmware
3975 * scsi_status - SCSI Status code returned from target device
3976 * scsi_state - state info associated with SCSI_IO determined by ioc
3977 * ioc_status - ioc supplied status info
3982 _scsih_scsi_ioc_info(struct MPT3SAS_ADAPTER *ioc, struct scsi_cmnd *scmd,
3983 Mpi2SCSIIOReply_t *mpi_reply, u16 smid)
3987 u16 ioc_status = le16_to_cpu(mpi_reply->IOCStatus) &
3988 MPI2_IOCSTATUS_MASK;
3989 u8 scsi_state = mpi_reply->SCSIState;
3990 u8 scsi_status = mpi_reply->SCSIStatus;
3991 char *desc_ioc_state = NULL;
3992 char *desc_scsi_status = NULL;
3993 char *desc_scsi_state = ioc->tmp_string;
3994 u32 log_info = le32_to_cpu(mpi_reply->IOCLogInfo);
3995 struct _sas_device *sas_device = NULL;
3996 struct scsi_target *starget = scmd->device->sdev_target;
3997 struct MPT3SAS_TARGET *priv_target = starget->hostdata;
3998 char *device_str = NULL;
4002 device_str = "volume";
4004 if (log_info == 0x31170000)
4007 switch (ioc_status) {
4008 case MPI2_IOCSTATUS_SUCCESS:
4009 desc_ioc_state = "success";
4011 case MPI2_IOCSTATUS_INVALID_FUNCTION:
4012 desc_ioc_state = "invalid function";
4014 case MPI2_IOCSTATUS_SCSI_RECOVERED_ERROR:
4015 desc_ioc_state = "scsi recovered error";
4017 case MPI2_IOCSTATUS_SCSI_INVALID_DEVHANDLE:
4018 desc_ioc_state = "scsi invalid dev handle";
4020 case MPI2_IOCSTATUS_SCSI_DEVICE_NOT_THERE:
4021 desc_ioc_state = "scsi device not there";
4023 case MPI2_IOCSTATUS_SCSI_DATA_OVERRUN:
4024 desc_ioc_state = "scsi data overrun";
4026 case MPI2_IOCSTATUS_SCSI_DATA_UNDERRUN:
4027 desc_ioc_state = "scsi data underrun";
4029 case MPI2_IOCSTATUS_SCSI_IO_DATA_ERROR:
4030 desc_ioc_state = "scsi io data error";
4032 case MPI2_IOCSTATUS_SCSI_PROTOCOL_ERROR:
4033 desc_ioc_state = "scsi protocol error";
4035 case MPI2_IOCSTATUS_SCSI_TASK_TERMINATED:
4036 desc_ioc_state = "scsi task terminated";
4038 case MPI2_IOCSTATUS_SCSI_RESIDUAL_MISMATCH:
4039 desc_ioc_state = "scsi residual mismatch";
4041 case MPI2_IOCSTATUS_SCSI_TASK_MGMT_FAILED:
4042 desc_ioc_state = "scsi task mgmt failed";
4044 case MPI2_IOCSTATUS_SCSI_IOC_TERMINATED:
4045 desc_ioc_state = "scsi ioc terminated";
4047 case MPI2_IOCSTATUS_SCSI_EXT_TERMINATED:
4048 desc_ioc_state = "scsi ext terminated";
4050 case MPI2_IOCSTATUS_EEDP_GUARD_ERROR:
4051 desc_ioc_state = "eedp guard error";
4053 case MPI2_IOCSTATUS_EEDP_REF_TAG_ERROR:
4054 desc_ioc_state = "eedp ref tag error";
4056 case MPI2_IOCSTATUS_EEDP_APP_TAG_ERROR:
4057 desc_ioc_state = "eedp app tag error";
4060 desc_ioc_state = "unknown";
4064 switch (scsi_status) {
4065 case MPI2_SCSI_STATUS_GOOD:
4066 desc_scsi_status = "good";
4068 case MPI2_SCSI_STATUS_CHECK_CONDITION:
4069 desc_scsi_status = "check condition";
4071 case MPI2_SCSI_STATUS_CONDITION_MET:
4072 desc_scsi_status = "condition met";
4074 case MPI2_SCSI_STATUS_BUSY:
4075 desc_scsi_status = "busy";
4077 case MPI2_SCSI_STATUS_INTERMEDIATE:
4078 desc_scsi_status = "intermediate";
4080 case MPI2_SCSI_STATUS_INTERMEDIATE_CONDMET:
4081 desc_scsi_status = "intermediate condmet";
4083 case MPI2_SCSI_STATUS_RESERVATION_CONFLICT:
4084 desc_scsi_status = "reservation conflict";
4086 case MPI2_SCSI_STATUS_COMMAND_TERMINATED:
4087 desc_scsi_status = "command terminated";
4089 case MPI2_SCSI_STATUS_TASK_SET_FULL:
4090 desc_scsi_status = "task set full";
4092 case MPI2_SCSI_STATUS_ACA_ACTIVE:
4093 desc_scsi_status = "aca active";
4095 case MPI2_SCSI_STATUS_TASK_ABORTED:
4096 desc_scsi_status = "task aborted";
4099 desc_scsi_status = "unknown";
4103 desc_scsi_state[0] = '\0';
4105 desc_scsi_state = " ";
4106 if (scsi_state & MPI2_SCSI_STATE_RESPONSE_INFO_VALID)
4107 strcat(desc_scsi_state, "response info ");
4108 if (scsi_state & MPI2_SCSI_STATE_TERMINATED)
4109 strcat(desc_scsi_state, "state terminated ");
4110 if (scsi_state & MPI2_SCSI_STATE_NO_SCSI_STATUS)
4111 strcat(desc_scsi_state, "no status ");
4112 if (scsi_state & MPI2_SCSI_STATE_AUTOSENSE_FAILED)
4113 strcat(desc_scsi_state, "autosense failed ");
4114 if (scsi_state & MPI2_SCSI_STATE_AUTOSENSE_VALID)
4115 strcat(desc_scsi_state, "autosense valid ");
4117 scsi_print_command(scmd);
4119 if (priv_target->flags & MPT_TARGET_FLAGS_VOLUME) {
4120 pr_warn(MPT3SAS_FMT "\t%s wwid(0x%016llx)\n", ioc->name,
4121 device_str, (unsigned long long)priv_target->sas_address);
4123 sas_device = mpt3sas_get_sdev_from_target(ioc, priv_target);
4126 "\tsas_address(0x%016llx), phy(%d)\n",
4127 ioc->name, (unsigned long long)
4128 sas_device->sas_address, sas_device->phy);
4129 if (sas_device->enclosure_handle != 0)
4131 "\tenclosure_logical_id(0x%016llx),"
4132 "slot(%d)\n", ioc->name,
4133 (unsigned long long)
4134 sas_device->enclosure_logical_id,
4136 if (sas_device->connector_name[0])
4138 "\tenclosure level(0x%04x),"
4139 " connector name( %s)\n", ioc->name,
4140 sas_device->enclosure_level,
4141 sas_device->connector_name);
4143 sas_device_put(sas_device);
4148 "\thandle(0x%04x), ioc_status(%s)(0x%04x), smid(%d)\n",
4149 ioc->name, le16_to_cpu(mpi_reply->DevHandle),
4150 desc_ioc_state, ioc_status, smid);
4152 "\trequest_len(%d), underflow(%d), resid(%d)\n",
4153 ioc->name, scsi_bufflen(scmd), scmd->underflow,
4154 scsi_get_resid(scmd));
4156 "\ttag(%d), transfer_count(%d), sc->result(0x%08x)\n",
4157 ioc->name, le16_to_cpu(mpi_reply->TaskTag),
4158 le32_to_cpu(mpi_reply->TransferCount), scmd->result);
4160 "\tscsi_status(%s)(0x%02x), scsi_state(%s)(0x%02x)\n",
4161 ioc->name, desc_scsi_status,
4162 scsi_status, desc_scsi_state, scsi_state);
4164 if (scsi_state & MPI2_SCSI_STATE_AUTOSENSE_VALID) {
4165 struct sense_info data;
4166 _scsih_normalize_sense(scmd->sense_buffer, &data);
4168 "\t[sense_key,asc,ascq]: [0x%02x,0x%02x,0x%02x], count(%d)\n",
4169 ioc->name, data.skey,
4170 data.asc, data.ascq, le32_to_cpu(mpi_reply->SenseCount));
4173 if (scsi_state & MPI2_SCSI_STATE_RESPONSE_INFO_VALID) {
4174 response_info = le32_to_cpu(mpi_reply->ResponseInfo);
4175 response_bytes = (u8 *)&response_info;
4176 _scsih_response_code(ioc, response_bytes[0]);
4182 * _scsih_turn_on_pfa_led - illuminate PFA LED
4183 * @ioc: per adapter object
4184 * @handle: device handle
4190 _scsih_turn_on_pfa_led(struct MPT3SAS_ADAPTER *ioc, u16 handle)
4192 Mpi2SepReply_t mpi_reply;
4193 Mpi2SepRequest_t mpi_request;
4194 struct _sas_device *sas_device;
4196 sas_device = mpt3sas_get_sdev_by_handle(ioc, handle);
4200 memset(&mpi_request, 0, sizeof(Mpi2SepRequest_t));
4201 mpi_request.Function = MPI2_FUNCTION_SCSI_ENCLOSURE_PROCESSOR;
4202 mpi_request.Action = MPI2_SEP_REQ_ACTION_WRITE_STATUS;
4203 mpi_request.SlotStatus =
4204 cpu_to_le32(MPI2_SEP_REQ_SLOTSTATUS_PREDICTED_FAULT);
4205 mpi_request.DevHandle = cpu_to_le16(handle);
4206 mpi_request.Flags = MPI2_SEP_REQ_FLAGS_DEVHANDLE_ADDRESS;
4207 if ((mpt3sas_base_scsi_enclosure_processor(ioc, &mpi_reply,
4208 &mpi_request)) != 0) {
4209 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n", ioc->name,
4210 __FILE__, __LINE__, __func__);
4213 sas_device->pfa_led_on = 1;
4215 if (mpi_reply.IOCStatus || mpi_reply.IOCLogInfo) {
4216 dewtprintk(ioc, pr_info(MPT3SAS_FMT
4217 "enclosure_processor: ioc_status (0x%04x), loginfo(0x%08x)\n",
4218 ioc->name, le16_to_cpu(mpi_reply.IOCStatus),
4219 le32_to_cpu(mpi_reply.IOCLogInfo)));
4223 sas_device_put(sas_device);
4226 * _scsih_turn_off_pfa_led - turn off Fault LED
4227 * @ioc: per adapter object
4228 * @sas_device: sas device whose PFA LED has to turned off
4234 _scsih_turn_off_pfa_led(struct MPT3SAS_ADAPTER *ioc,
4235 struct _sas_device *sas_device)
4237 Mpi2SepReply_t mpi_reply;
4238 Mpi2SepRequest_t mpi_request;
4240 memset(&mpi_request, 0, sizeof(Mpi2SepRequest_t));
4241 mpi_request.Function = MPI2_FUNCTION_SCSI_ENCLOSURE_PROCESSOR;
4242 mpi_request.Action = MPI2_SEP_REQ_ACTION_WRITE_STATUS;
4243 mpi_request.SlotStatus = 0;
4244 mpi_request.Slot = cpu_to_le16(sas_device->slot);
4245 mpi_request.DevHandle = 0;
4246 mpi_request.EnclosureHandle = cpu_to_le16(sas_device->enclosure_handle);
4247 mpi_request.Flags = MPI2_SEP_REQ_FLAGS_ENCLOSURE_SLOT_ADDRESS;
4248 if ((mpt3sas_base_scsi_enclosure_processor(ioc, &mpi_reply,
4249 &mpi_request)) != 0) {
4250 printk(MPT3SAS_FMT "failure at %s:%d/%s()!\n", ioc->name,
4251 __FILE__, __LINE__, __func__);
4255 if (mpi_reply.IOCStatus || mpi_reply.IOCLogInfo) {
4256 dewtprintk(ioc, printk(MPT3SAS_FMT
4257 "enclosure_processor: ioc_status (0x%04x), loginfo(0x%08x)\n",
4258 ioc->name, le16_to_cpu(mpi_reply.IOCStatus),
4259 le32_to_cpu(mpi_reply.IOCLogInfo)));
4264 * _scsih_send_event_to_turn_on_pfa_led - fire delayed event
4265 * @ioc: per adapter object
4266 * @handle: device handle
4267 * Context: interrupt.
4272 _scsih_send_event_to_turn_on_pfa_led(struct MPT3SAS_ADAPTER *ioc, u16 handle)
4274 struct fw_event_work *fw_event;
4276 fw_event = alloc_fw_event_work(0);
4279 fw_event->event = MPT3SAS_TURN_ON_PFA_LED;
4280 fw_event->device_handle = handle;
4281 fw_event->ioc = ioc;
4282 _scsih_fw_event_add(ioc, fw_event);
4283 fw_event_work_put(fw_event);
4287 * _scsih_smart_predicted_fault - process smart errors
4288 * @ioc: per adapter object
4289 * @handle: device handle
4290 * Context: interrupt.
4295 _scsih_smart_predicted_fault(struct MPT3SAS_ADAPTER *ioc, u16 handle)
4297 struct scsi_target *starget;
4298 struct MPT3SAS_TARGET *sas_target_priv_data;
4299 Mpi2EventNotificationReply_t *event_reply;
4300 Mpi2EventDataSasDeviceStatusChange_t *event_data;
4301 struct _sas_device *sas_device;
4303 unsigned long flags;
4305 /* only handle non-raid devices */
4306 spin_lock_irqsave(&ioc->sas_device_lock, flags);
4307 sas_device = __mpt3sas_get_sdev_by_handle(ioc, handle);
4311 starget = sas_device->starget;
4312 sas_target_priv_data = starget->hostdata;
4314 if ((sas_target_priv_data->flags & MPT_TARGET_FLAGS_RAID_COMPONENT) ||
4315 ((sas_target_priv_data->flags & MPT_TARGET_FLAGS_VOLUME)))
4318 if (sas_device->enclosure_handle != 0)
4319 starget_printk(KERN_INFO, starget, "predicted fault, "
4320 "enclosure logical id(0x%016llx), slot(%d)\n",
4321 (unsigned long long)sas_device->enclosure_logical_id,
4323 if (sas_device->connector_name[0] != '\0')
4324 starget_printk(KERN_WARNING, starget, "predicted fault, "
4325 "enclosure level(0x%04x), connector name( %s)\n",
4326 sas_device->enclosure_level,
4327 sas_device->connector_name);
4328 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
4330 if (ioc->pdev->subsystem_vendor == PCI_VENDOR_ID_IBM)
4331 _scsih_send_event_to_turn_on_pfa_led(ioc, handle);
4333 /* insert into event log */
4334 sz = offsetof(Mpi2EventNotificationReply_t, EventData) +
4335 sizeof(Mpi2EventDataSasDeviceStatusChange_t);
4336 event_reply = kzalloc(sz, GFP_KERNEL);
4338 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
4339 ioc->name, __FILE__, __LINE__, __func__);
4343 event_reply->Function = MPI2_FUNCTION_EVENT_NOTIFICATION;
4344 event_reply->Event =
4345 cpu_to_le16(MPI2_EVENT_SAS_DEVICE_STATUS_CHANGE);
4346 event_reply->MsgLength = sz/4;
4347 event_reply->EventDataLength =
4348 cpu_to_le16(sizeof(Mpi2EventDataSasDeviceStatusChange_t)/4);
4349 event_data = (Mpi2EventDataSasDeviceStatusChange_t *)
4350 event_reply->EventData;
4351 event_data->ReasonCode = MPI2_EVENT_SAS_DEV_STAT_RC_SMART_DATA;
4352 event_data->ASC = 0x5D;
4353 event_data->DevHandle = cpu_to_le16(handle);
4354 event_data->SASAddress = cpu_to_le64(sas_target_priv_data->sas_address);
4355 mpt3sas_ctl_add_to_event_log(ioc, event_reply);
4359 sas_device_put(sas_device);
4363 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
4368 * _scsih_io_done - scsi request callback
4369 * @ioc: per adapter object
4370 * @smid: system request message index
4371 * @msix_index: MSIX table index supplied by the OS
4372 * @reply: reply message frame(lower 32bit addr)
4374 * Callback handler when using _scsih_qcmd.
4376 * Return 1 meaning mf should be freed from _base_interrupt
4377 * 0 means the mf is freed from this function.
4380 _scsih_io_done(struct MPT3SAS_ADAPTER *ioc, u16 smid, u8 msix_index, u32 reply)
4382 Mpi2SCSIIORequest_t *mpi_request;
4383 Mpi2SCSIIOReply_t *mpi_reply;
4384 struct scsi_cmnd *scmd;
4390 struct MPT3SAS_DEVICE *sas_device_priv_data;
4391 u32 response_code = 0;
4393 mpi_reply = mpt3sas_base_get_reply_virt_addr(ioc, reply);
4394 scmd = _scsih_scsi_lookup_get_clear(ioc, smid);
4398 mpi_request = mpt3sas_base_get_msg_frame(ioc, smid);
4400 if (mpi_reply == NULL) {
4401 scmd->result = DID_OK << 16;
4405 sas_device_priv_data = scmd->device->hostdata;
4406 if (!sas_device_priv_data || !sas_device_priv_data->sas_target ||
4407 sas_device_priv_data->sas_target->deleted) {
4408 scmd->result = DID_NO_CONNECT << 16;
4411 ioc_status = le16_to_cpu(mpi_reply->IOCStatus);
4413 /* turning off TLR */
4414 scsi_state = mpi_reply->SCSIState;
4415 if (scsi_state & MPI2_SCSI_STATE_RESPONSE_INFO_VALID)
4417 le32_to_cpu(mpi_reply->ResponseInfo) & 0xFF;
4418 if (!sas_device_priv_data->tlr_snoop_check) {
4419 sas_device_priv_data->tlr_snoop_check++;
4420 if ((sas_device_priv_data->flags & MPT_DEVICE_TLR_ON) &&
4421 response_code == MPI2_SCSITASKMGMT_RSP_INVALID_FRAME)
4422 sas_device_priv_data->flags &=
4426 xfer_cnt = le32_to_cpu(mpi_reply->TransferCount);
4427 scsi_set_resid(scmd, scsi_bufflen(scmd) - xfer_cnt);
4428 if (ioc_status & MPI2_IOCSTATUS_FLAG_LOG_INFO_AVAILABLE)
4429 log_info = le32_to_cpu(mpi_reply->IOCLogInfo);
4432 ioc_status &= MPI2_IOCSTATUS_MASK;
4433 scsi_status = mpi_reply->SCSIStatus;
4435 if (ioc_status == MPI2_IOCSTATUS_SCSI_DATA_UNDERRUN && xfer_cnt == 0 &&
4436 (scsi_status == MPI2_SCSI_STATUS_BUSY ||
4437 scsi_status == MPI2_SCSI_STATUS_RESERVATION_CONFLICT ||
4438 scsi_status == MPI2_SCSI_STATUS_TASK_SET_FULL)) {
4439 ioc_status = MPI2_IOCSTATUS_SUCCESS;
4442 if (scsi_state & MPI2_SCSI_STATE_AUTOSENSE_VALID) {
4443 struct sense_info data;
4444 const void *sense_data = mpt3sas_base_get_sense_buffer(ioc,
4446 u32 sz = min_t(u32, SCSI_SENSE_BUFFERSIZE,
4447 le32_to_cpu(mpi_reply->SenseCount));
4448 memcpy(scmd->sense_buffer, sense_data, sz);
4449 _scsih_normalize_sense(scmd->sense_buffer, &data);
4450 /* failure prediction threshold exceeded */
4451 if (data.asc == 0x5D)
4452 _scsih_smart_predicted_fault(ioc,
4453 le16_to_cpu(mpi_reply->DevHandle));
4454 mpt3sas_trigger_scsi(ioc, data.skey, data.asc, data.ascq);
4456 #ifdef CONFIG_SCSI_MPT3SAS_LOGGING
4457 if (!(ioc->logging_level & MPT_DEBUG_REPLY) &&
4458 ((scmd->sense_buffer[2] == UNIT_ATTENTION) ||
4459 (scmd->sense_buffer[2] == MEDIUM_ERROR) ||
4460 (scmd->sense_buffer[2] == HARDWARE_ERROR)))
4461 _scsih_scsi_ioc_info(ioc, scmd, mpi_reply, smid);
4464 switch (ioc_status) {
4465 case MPI2_IOCSTATUS_BUSY:
4466 case MPI2_IOCSTATUS_INSUFFICIENT_RESOURCES:
4467 scmd->result = SAM_STAT_BUSY;
4470 case MPI2_IOCSTATUS_SCSI_DEVICE_NOT_THERE:
4471 scmd->result = DID_NO_CONNECT << 16;
4474 case MPI2_IOCSTATUS_SCSI_IOC_TERMINATED:
4475 if (sas_device_priv_data->block) {
4476 scmd->result = DID_TRANSPORT_DISRUPTED << 16;
4479 if (log_info == 0x31110630) {
4480 if (scmd->retries > 2) {
4481 scmd->result = DID_NO_CONNECT << 16;
4482 scsi_device_set_state(scmd->device,
4485 scmd->result = DID_SOFT_ERROR << 16;
4486 scmd->device->expecting_cc_ua = 1;
4489 } else if (log_info == VIRTUAL_IO_FAILED_RETRY) {
4490 scmd->result = DID_RESET << 16;
4493 scmd->result = DID_SOFT_ERROR << 16;
4495 case MPI2_IOCSTATUS_SCSI_TASK_TERMINATED:
4496 case MPI2_IOCSTATUS_SCSI_EXT_TERMINATED:
4497 scmd->result = DID_RESET << 16;
4500 case MPI2_IOCSTATUS_SCSI_RESIDUAL_MISMATCH:
4501 if ((xfer_cnt == 0) || (scmd->underflow > xfer_cnt))
4502 scmd->result = DID_SOFT_ERROR << 16;
4504 scmd->result = (DID_OK << 16) | scsi_status;
4507 case MPI2_IOCSTATUS_SCSI_DATA_UNDERRUN:
4508 scmd->result = (DID_OK << 16) | scsi_status;
4510 if ((scsi_state & MPI2_SCSI_STATE_AUTOSENSE_VALID))
4513 if (xfer_cnt < scmd->underflow) {
4514 if (scsi_status == SAM_STAT_BUSY)
4515 scmd->result = SAM_STAT_BUSY;
4517 scmd->result = DID_SOFT_ERROR << 16;
4518 } else if (scsi_state & (MPI2_SCSI_STATE_AUTOSENSE_FAILED |
4519 MPI2_SCSI_STATE_NO_SCSI_STATUS))
4520 scmd->result = DID_SOFT_ERROR << 16;
4521 else if (scsi_state & MPI2_SCSI_STATE_TERMINATED)
4522 scmd->result = DID_RESET << 16;
4523 else if (!xfer_cnt && scmd->cmnd[0] == REPORT_LUNS) {
4524 mpi_reply->SCSIState = MPI2_SCSI_STATE_AUTOSENSE_VALID;
4525 mpi_reply->SCSIStatus = SAM_STAT_CHECK_CONDITION;
4526 scmd->result = (DRIVER_SENSE << 24) |
4527 SAM_STAT_CHECK_CONDITION;
4528 scmd->sense_buffer[0] = 0x70;
4529 scmd->sense_buffer[2] = ILLEGAL_REQUEST;
4530 scmd->sense_buffer[12] = 0x20;
4531 scmd->sense_buffer[13] = 0;
4535 case MPI2_IOCSTATUS_SCSI_DATA_OVERRUN:
4536 scsi_set_resid(scmd, 0);
4537 case MPI2_IOCSTATUS_SCSI_RECOVERED_ERROR:
4538 case MPI2_IOCSTATUS_SUCCESS:
4539 scmd->result = (DID_OK << 16) | scsi_status;
4540 if (response_code ==
4541 MPI2_SCSITASKMGMT_RSP_INVALID_FRAME ||
4542 (scsi_state & (MPI2_SCSI_STATE_AUTOSENSE_FAILED |
4543 MPI2_SCSI_STATE_NO_SCSI_STATUS)))
4544 scmd->result = DID_SOFT_ERROR << 16;
4545 else if (scsi_state & MPI2_SCSI_STATE_TERMINATED)
4546 scmd->result = DID_RESET << 16;
4549 case MPI2_IOCSTATUS_EEDP_GUARD_ERROR:
4550 case MPI2_IOCSTATUS_EEDP_REF_TAG_ERROR:
4551 case MPI2_IOCSTATUS_EEDP_APP_TAG_ERROR:
4552 _scsih_eedp_error_handling(scmd, ioc_status);
4555 case MPI2_IOCSTATUS_SCSI_PROTOCOL_ERROR:
4556 case MPI2_IOCSTATUS_INVALID_FUNCTION:
4557 case MPI2_IOCSTATUS_INVALID_SGL:
4558 case MPI2_IOCSTATUS_INTERNAL_ERROR:
4559 case MPI2_IOCSTATUS_INVALID_FIELD:
4560 case MPI2_IOCSTATUS_INVALID_STATE:
4561 case MPI2_IOCSTATUS_SCSI_IO_DATA_ERROR:
4562 case MPI2_IOCSTATUS_SCSI_TASK_MGMT_FAILED:
4564 scmd->result = DID_SOFT_ERROR << 16;
4569 #ifdef CONFIG_SCSI_MPT3SAS_LOGGING
4570 if (scmd->result && (ioc->logging_level & MPT_DEBUG_REPLY))
4571 _scsih_scsi_ioc_info(ioc , scmd, mpi_reply, smid);
4576 scsi_dma_unmap(scmd);
4578 scmd->scsi_done(scmd);
4583 * _scsih_sas_host_refresh - refreshing sas host object contents
4584 * @ioc: per adapter object
4587 * During port enable, fw will send topology events for every device. Its
4588 * possible that the handles may change from the previous setting, so this
4589 * code keeping handles updating if changed.
4594 _scsih_sas_host_refresh(struct MPT3SAS_ADAPTER *ioc)
4599 Mpi2ConfigReply_t mpi_reply;
4600 Mpi2SasIOUnitPage0_t *sas_iounit_pg0 = NULL;
4601 u16 attached_handle;
4604 dtmprintk(ioc, pr_info(MPT3SAS_FMT
4605 "updating handles for sas_host(0x%016llx)\n",
4606 ioc->name, (unsigned long long)ioc->sas_hba.sas_address));
4608 sz = offsetof(Mpi2SasIOUnitPage0_t, PhyData) + (ioc->sas_hba.num_phys
4609 * sizeof(Mpi2SasIOUnit0PhyData_t));
4610 sas_iounit_pg0 = kzalloc(sz, GFP_KERNEL);
4611 if (!sas_iounit_pg0) {
4612 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
4613 ioc->name, __FILE__, __LINE__, __func__);
4617 if ((mpt3sas_config_get_sas_iounit_pg0(ioc, &mpi_reply,
4618 sas_iounit_pg0, sz)) != 0)
4620 ioc_status = le16_to_cpu(mpi_reply.IOCStatus) & MPI2_IOCSTATUS_MASK;
4621 if (ioc_status != MPI2_IOCSTATUS_SUCCESS)
4623 for (i = 0; i < ioc->sas_hba.num_phys ; i++) {
4624 link_rate = sas_iounit_pg0->PhyData[i].NegotiatedLinkRate >> 4;
4626 ioc->sas_hba.handle = le16_to_cpu(sas_iounit_pg0->
4627 PhyData[0].ControllerDevHandle);
4628 ioc->sas_hba.phy[i].handle = ioc->sas_hba.handle;
4629 attached_handle = le16_to_cpu(sas_iounit_pg0->PhyData[i].
4631 if (attached_handle && link_rate < MPI2_SAS_NEG_LINK_RATE_1_5)
4632 link_rate = MPI2_SAS_NEG_LINK_RATE_1_5;
4633 mpt3sas_transport_update_links(ioc, ioc->sas_hba.sas_address,
4634 attached_handle, i, link_rate);
4637 kfree(sas_iounit_pg0);
4641 * _scsih_sas_host_add - create sas host object
4642 * @ioc: per adapter object
4644 * Creating host side data object, stored in ioc->sas_hba
4649 _scsih_sas_host_add(struct MPT3SAS_ADAPTER *ioc)
4652 Mpi2ConfigReply_t mpi_reply;
4653 Mpi2SasIOUnitPage0_t *sas_iounit_pg0 = NULL;
4654 Mpi2SasIOUnitPage1_t *sas_iounit_pg1 = NULL;
4655 Mpi2SasPhyPage0_t phy_pg0;
4656 Mpi2SasDevicePage0_t sas_device_pg0;
4657 Mpi2SasEnclosurePage0_t enclosure_pg0;
4660 u8 device_missing_delay;
4662 mpt3sas_config_get_number_hba_phys(ioc, &ioc->sas_hba.num_phys);
4663 if (!ioc->sas_hba.num_phys) {
4664 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
4665 ioc->name, __FILE__, __LINE__, __func__);
4669 /* sas_iounit page 0 */
4670 sz = offsetof(Mpi2SasIOUnitPage0_t, PhyData) + (ioc->sas_hba.num_phys *
4671 sizeof(Mpi2SasIOUnit0PhyData_t));
4672 sas_iounit_pg0 = kzalloc(sz, GFP_KERNEL);
4673 if (!sas_iounit_pg0) {
4674 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
4675 ioc->name, __FILE__, __LINE__, __func__);
4678 if ((mpt3sas_config_get_sas_iounit_pg0(ioc, &mpi_reply,
4679 sas_iounit_pg0, sz))) {
4680 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
4681 ioc->name, __FILE__, __LINE__, __func__);
4684 ioc_status = le16_to_cpu(mpi_reply.IOCStatus) &
4685 MPI2_IOCSTATUS_MASK;
4686 if (ioc_status != MPI2_IOCSTATUS_SUCCESS) {
4687 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
4688 ioc->name, __FILE__, __LINE__, __func__);
4692 /* sas_iounit page 1 */
4693 sz = offsetof(Mpi2SasIOUnitPage1_t, PhyData) + (ioc->sas_hba.num_phys *
4694 sizeof(Mpi2SasIOUnit1PhyData_t));
4695 sas_iounit_pg1 = kzalloc(sz, GFP_KERNEL);
4696 if (!sas_iounit_pg1) {
4697 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
4698 ioc->name, __FILE__, __LINE__, __func__);
4701 if ((mpt3sas_config_get_sas_iounit_pg1(ioc, &mpi_reply,
4702 sas_iounit_pg1, sz))) {
4703 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
4704 ioc->name, __FILE__, __LINE__, __func__);
4707 ioc_status = le16_to_cpu(mpi_reply.IOCStatus) &
4708 MPI2_IOCSTATUS_MASK;
4709 if (ioc_status != MPI2_IOCSTATUS_SUCCESS) {
4710 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
4711 ioc->name, __FILE__, __LINE__, __func__);
4715 ioc->io_missing_delay =
4716 sas_iounit_pg1->IODeviceMissingDelay;
4717 device_missing_delay =
4718 sas_iounit_pg1->ReportDeviceMissingDelay;
4719 if (device_missing_delay & MPI2_SASIOUNIT1_REPORT_MISSING_UNIT_16)
4720 ioc->device_missing_delay = (device_missing_delay &
4721 MPI2_SASIOUNIT1_REPORT_MISSING_TIMEOUT_MASK) * 16;
4723 ioc->device_missing_delay = device_missing_delay &
4724 MPI2_SASIOUNIT1_REPORT_MISSING_TIMEOUT_MASK;
4726 ioc->sas_hba.parent_dev = &ioc->shost->shost_gendev;
4727 ioc->sas_hba.phy = kcalloc(ioc->sas_hba.num_phys,
4728 sizeof(struct _sas_phy), GFP_KERNEL);
4729 if (!ioc->sas_hba.phy) {
4730 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
4731 ioc->name, __FILE__, __LINE__, __func__);
4734 for (i = 0; i < ioc->sas_hba.num_phys ; i++) {
4735 if ((mpt3sas_config_get_phy_pg0(ioc, &mpi_reply, &phy_pg0,
4737 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
4738 ioc->name, __FILE__, __LINE__, __func__);
4741 ioc_status = le16_to_cpu(mpi_reply.IOCStatus) &
4742 MPI2_IOCSTATUS_MASK;
4743 if (ioc_status != MPI2_IOCSTATUS_SUCCESS) {
4744 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
4745 ioc->name, __FILE__, __LINE__, __func__);
4750 ioc->sas_hba.handle = le16_to_cpu(sas_iounit_pg0->
4751 PhyData[0].ControllerDevHandle);
4752 ioc->sas_hba.phy[i].handle = ioc->sas_hba.handle;
4753 ioc->sas_hba.phy[i].phy_id = i;
4754 mpt3sas_transport_add_host_phy(ioc, &ioc->sas_hba.phy[i],
4755 phy_pg0, ioc->sas_hba.parent_dev);
4757 if ((mpt3sas_config_get_sas_device_pg0(ioc, &mpi_reply, &sas_device_pg0,
4758 MPI2_SAS_DEVICE_PGAD_FORM_HANDLE, ioc->sas_hba.handle))) {
4759 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
4760 ioc->name, __FILE__, __LINE__, __func__);
4763 ioc->sas_hba.enclosure_handle =
4764 le16_to_cpu(sas_device_pg0.EnclosureHandle);
4765 ioc->sas_hba.sas_address = le64_to_cpu(sas_device_pg0.SASAddress);
4767 "host_add: handle(0x%04x), sas_addr(0x%016llx), phys(%d)\n",
4768 ioc->name, ioc->sas_hba.handle,
4769 (unsigned long long) ioc->sas_hba.sas_address,
4770 ioc->sas_hba.num_phys) ;
4772 if (ioc->sas_hba.enclosure_handle) {
4773 if (!(mpt3sas_config_get_enclosure_pg0(ioc, &mpi_reply,
4774 &enclosure_pg0, MPI2_SAS_ENCLOS_PGAD_FORM_HANDLE,
4775 ioc->sas_hba.enclosure_handle)))
4776 ioc->sas_hba.enclosure_logical_id =
4777 le64_to_cpu(enclosure_pg0.EnclosureLogicalID);
4781 kfree(sas_iounit_pg1);
4782 kfree(sas_iounit_pg0);
4786 * _scsih_expander_add - creating expander object
4787 * @ioc: per adapter object
4788 * @handle: expander handle
4790 * Creating expander object, stored in ioc->sas_expander_list.
4792 * Return 0 for success, else error.
4795 _scsih_expander_add(struct MPT3SAS_ADAPTER *ioc, u16 handle)
4797 struct _sas_node *sas_expander;
4798 Mpi2ConfigReply_t mpi_reply;
4799 Mpi2ExpanderPage0_t expander_pg0;
4800 Mpi2ExpanderPage1_t expander_pg1;
4801 Mpi2SasEnclosurePage0_t enclosure_pg0;
4804 u64 sas_address, sas_address_parent = 0;
4806 unsigned long flags;
4807 struct _sas_port *mpt3sas_port = NULL;
4814 if (ioc->shost_recovery || ioc->pci_error_recovery)
4817 if ((mpt3sas_config_get_expander_pg0(ioc, &mpi_reply, &expander_pg0,
4818 MPI2_SAS_EXPAND_PGAD_FORM_HNDL, handle))) {
4819 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
4820 ioc->name, __FILE__, __LINE__, __func__);
4824 ioc_status = le16_to_cpu(mpi_reply.IOCStatus) &
4825 MPI2_IOCSTATUS_MASK;
4826 if (ioc_status != MPI2_IOCSTATUS_SUCCESS) {
4827 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
4828 ioc->name, __FILE__, __LINE__, __func__);
4832 /* handle out of order topology events */
4833 parent_handle = le16_to_cpu(expander_pg0.ParentDevHandle);
4834 if (_scsih_get_sas_address(ioc, parent_handle, &sas_address_parent)
4836 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
4837 ioc->name, __FILE__, __LINE__, __func__);
4840 if (sas_address_parent != ioc->sas_hba.sas_address) {
4841 spin_lock_irqsave(&ioc->sas_node_lock, flags);
4842 sas_expander = mpt3sas_scsih_expander_find_by_sas_address(ioc,
4843 sas_address_parent);
4844 spin_unlock_irqrestore(&ioc->sas_node_lock, flags);
4845 if (!sas_expander) {
4846 rc = _scsih_expander_add(ioc, parent_handle);
4852 spin_lock_irqsave(&ioc->sas_node_lock, flags);
4853 sas_address = le64_to_cpu(expander_pg0.SASAddress);
4854 sas_expander = mpt3sas_scsih_expander_find_by_sas_address(ioc,
4856 spin_unlock_irqrestore(&ioc->sas_node_lock, flags);
4861 sas_expander = kzalloc(sizeof(struct _sas_node),
4863 if (!sas_expander) {
4864 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
4865 ioc->name, __FILE__, __LINE__, __func__);
4869 sas_expander->handle = handle;
4870 sas_expander->num_phys = expander_pg0.NumPhys;
4871 sas_expander->sas_address_parent = sas_address_parent;
4872 sas_expander->sas_address = sas_address;
4874 pr_info(MPT3SAS_FMT "expander_add: handle(0x%04x)," \
4875 " parent(0x%04x), sas_addr(0x%016llx), phys(%d)\n", ioc->name,
4876 handle, parent_handle, (unsigned long long)
4877 sas_expander->sas_address, sas_expander->num_phys);
4879 if (!sas_expander->num_phys)
4881 sas_expander->phy = kcalloc(sas_expander->num_phys,
4882 sizeof(struct _sas_phy), GFP_KERNEL);
4883 if (!sas_expander->phy) {
4884 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
4885 ioc->name, __FILE__, __LINE__, __func__);
4890 INIT_LIST_HEAD(&sas_expander->sas_port_list);
4891 mpt3sas_port = mpt3sas_transport_port_add(ioc, handle,
4892 sas_address_parent);
4893 if (!mpt3sas_port) {
4894 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
4895 ioc->name, __FILE__, __LINE__, __func__);
4899 sas_expander->parent_dev = &mpt3sas_port->rphy->dev;
4901 for (i = 0 ; i < sas_expander->num_phys ; i++) {
4902 if ((mpt3sas_config_get_expander_pg1(ioc, &mpi_reply,
4903 &expander_pg1, i, handle))) {
4904 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
4905 ioc->name, __FILE__, __LINE__, __func__);
4909 sas_expander->phy[i].handle = handle;
4910 sas_expander->phy[i].phy_id = i;
4912 if ((mpt3sas_transport_add_expander_phy(ioc,
4913 &sas_expander->phy[i], expander_pg1,
4914 sas_expander->parent_dev))) {
4915 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
4916 ioc->name, __FILE__, __LINE__, __func__);
4922 if (sas_expander->enclosure_handle) {
4923 if (!(mpt3sas_config_get_enclosure_pg0(ioc, &mpi_reply,
4924 &enclosure_pg0, MPI2_SAS_ENCLOS_PGAD_FORM_HANDLE,
4925 sas_expander->enclosure_handle)))
4926 sas_expander->enclosure_logical_id =
4927 le64_to_cpu(enclosure_pg0.EnclosureLogicalID);
4930 _scsih_expander_node_add(ioc, sas_expander);
4936 mpt3sas_transport_port_remove(ioc, sas_expander->sas_address,
4937 sas_address_parent);
4938 kfree(sas_expander);
4943 * mpt3sas_expander_remove - removing expander object
4944 * @ioc: per adapter object
4945 * @sas_address: expander sas_address
4950 mpt3sas_expander_remove(struct MPT3SAS_ADAPTER *ioc, u64 sas_address)
4952 struct _sas_node *sas_expander;
4953 unsigned long flags;
4955 if (ioc->shost_recovery)
4958 spin_lock_irqsave(&ioc->sas_node_lock, flags);
4959 sas_expander = mpt3sas_scsih_expander_find_by_sas_address(ioc,
4962 list_del(&sas_expander->list);
4963 spin_unlock_irqrestore(&ioc->sas_node_lock, flags);
4965 _scsih_expander_node_remove(ioc, sas_expander);
4969 * _scsih_done - internal SCSI_IO callback handler.
4970 * @ioc: per adapter object
4971 * @smid: system request message index
4972 * @msix_index: MSIX table index supplied by the OS
4973 * @reply: reply message frame(lower 32bit addr)
4975 * Callback handler when sending internal generated SCSI_IO.
4976 * The callback index passed is `ioc->scsih_cb_idx`
4978 * Return 1 meaning mf should be freed from _base_interrupt
4979 * 0 means the mf is freed from this function.
4982 _scsih_done(struct MPT3SAS_ADAPTER *ioc, u16 smid, u8 msix_index, u32 reply)
4984 MPI2DefaultReply_t *mpi_reply;
4986 mpi_reply = mpt3sas_base_get_reply_virt_addr(ioc, reply);
4987 if (ioc->scsih_cmds.status == MPT3_CMD_NOT_USED)
4989 if (ioc->scsih_cmds.smid != smid)
4991 ioc->scsih_cmds.status |= MPT3_CMD_COMPLETE;
4993 memcpy(ioc->scsih_cmds.reply, mpi_reply,
4994 mpi_reply->MsgLength*4);
4995 ioc->scsih_cmds.status |= MPT3_CMD_REPLY_VALID;
4997 ioc->scsih_cmds.status &= ~MPT3_CMD_PENDING;
4998 complete(&ioc->scsih_cmds.done);
5005 #define MPT3_MAX_LUNS (255)
5009 * _scsih_check_access_status - check access flags
5010 * @ioc: per adapter object
5011 * @sas_address: sas address
5012 * @handle: sas device handle
5013 * @access_flags: errors returned during discovery of the device
5015 * Return 0 for success, else failure
5018 _scsih_check_access_status(struct MPT3SAS_ADAPTER *ioc, u64 sas_address,
5019 u16 handle, u8 access_status)
5024 switch (access_status) {
5025 case MPI2_SAS_DEVICE0_ASTATUS_NO_ERRORS:
5026 case MPI2_SAS_DEVICE0_ASTATUS_SATA_NEEDS_INITIALIZATION:
5029 case MPI2_SAS_DEVICE0_ASTATUS_SATA_CAPABILITY_FAILED:
5030 desc = "sata capability failed";
5032 case MPI2_SAS_DEVICE0_ASTATUS_SATA_AFFILIATION_CONFLICT:
5033 desc = "sata affiliation conflict";
5035 case MPI2_SAS_DEVICE0_ASTATUS_ROUTE_NOT_ADDRESSABLE:
5036 desc = "route not addressable";
5038 case MPI2_SAS_DEVICE0_ASTATUS_SMP_ERROR_NOT_ADDRESSABLE:
5039 desc = "smp error not addressable";
5041 case MPI2_SAS_DEVICE0_ASTATUS_DEVICE_BLOCKED:
5042 desc = "device blocked";
5044 case MPI2_SAS_DEVICE0_ASTATUS_SATA_INIT_FAILED:
5045 case MPI2_SAS_DEVICE0_ASTATUS_SIF_UNKNOWN:
5046 case MPI2_SAS_DEVICE0_ASTATUS_SIF_AFFILIATION_CONFLICT:
5047 case MPI2_SAS_DEVICE0_ASTATUS_SIF_DIAG:
5048 case MPI2_SAS_DEVICE0_ASTATUS_SIF_IDENTIFICATION:
5049 case MPI2_SAS_DEVICE0_ASTATUS_SIF_CHECK_POWER:
5050 case MPI2_SAS_DEVICE0_ASTATUS_SIF_PIO_SN:
5051 case MPI2_SAS_DEVICE0_ASTATUS_SIF_MDMA_SN:
5052 case MPI2_SAS_DEVICE0_ASTATUS_SIF_UDMA_SN:
5053 case MPI2_SAS_DEVICE0_ASTATUS_SIF_ZONING_VIOLATION:
5054 case MPI2_SAS_DEVICE0_ASTATUS_SIF_NOT_ADDRESSABLE:
5055 case MPI2_SAS_DEVICE0_ASTATUS_SIF_MAX:
5056 desc = "sata initialization failed";
5067 "discovery errors(%s): sas_address(0x%016llx), handle(0x%04x)\n",
5068 ioc->name, desc, (unsigned long long)sas_address, handle);
5073 * _scsih_check_device - checking device responsiveness
5074 * @ioc: per adapter object
5075 * @parent_sas_address: sas address of parent expander or sas host
5076 * @handle: attached device handle
5077 * @phy_numberv: phy number
5078 * @link_rate: new link rate
5083 _scsih_check_device(struct MPT3SAS_ADAPTER *ioc,
5084 u64 parent_sas_address, u16 handle, u8 phy_number, u8 link_rate)
5086 Mpi2ConfigReply_t mpi_reply;
5087 Mpi2SasDevicePage0_t sas_device_pg0;
5088 struct _sas_device *sas_device;
5090 unsigned long flags;
5092 struct scsi_target *starget;
5093 struct MPT3SAS_TARGET *sas_target_priv_data;
5097 if ((mpt3sas_config_get_sas_device_pg0(ioc, &mpi_reply, &sas_device_pg0,
5098 MPI2_SAS_DEVICE_PGAD_FORM_HANDLE, handle)))
5101 ioc_status = le16_to_cpu(mpi_reply.IOCStatus) & MPI2_IOCSTATUS_MASK;
5102 if (ioc_status != MPI2_IOCSTATUS_SUCCESS)
5105 /* wide port handling ~ we need only handle device once for the phy that
5106 * is matched in sas device page zero
5108 if (phy_number != sas_device_pg0.PhyNum)
5111 /* check if this is end device */
5112 device_info = le32_to_cpu(sas_device_pg0.DeviceInfo);
5113 if (!(_scsih_is_end_device(device_info)))
5116 spin_lock_irqsave(&ioc->sas_device_lock, flags);
5117 sas_address = le64_to_cpu(sas_device_pg0.SASAddress);
5118 sas_device = __mpt3sas_get_sdev_by_addr(ioc,
5124 if (unlikely(sas_device->handle != handle)) {
5125 starget = sas_device->starget;
5126 sas_target_priv_data = starget->hostdata;
5127 starget_printk(KERN_INFO, starget,
5128 "handle changed from(0x%04x) to (0x%04x)!!!\n",
5129 sas_device->handle, handle);
5130 sas_target_priv_data->handle = handle;
5131 sas_device->handle = handle;
5132 if (sas_device_pg0.Flags &
5133 MPI2_SAS_DEVICE0_FLAGS_ENCL_LEVEL_VALID) {
5134 sas_device->enclosure_level =
5135 le16_to_cpu(sas_device_pg0.EnclosureLevel);
5136 memcpy(&sas_device->connector_name[0],
5137 &sas_device_pg0.ConnectorName[0], 4);
5139 sas_device->enclosure_level = 0;
5140 sas_device->connector_name[0] = '\0';
5144 /* check if device is present */
5145 if (!(le16_to_cpu(sas_device_pg0.Flags) &
5146 MPI2_SAS_DEVICE0_FLAGS_DEVICE_PRESENT)) {
5148 "device is not present handle(0x%04x), flags!!!\n",
5153 /* check if there were any issues with discovery */
5154 if (_scsih_check_access_status(ioc, sas_address, handle,
5155 sas_device_pg0.AccessStatus))
5158 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
5159 _scsih_ublock_io_device(ioc, sas_address);
5161 sas_device_put(sas_device);
5165 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
5167 sas_device_put(sas_device);
5171 * _scsih_add_device - creating sas device object
5172 * @ioc: per adapter object
5173 * @handle: sas device handle
5174 * @phy_num: phy number end device attached to
5175 * @is_pd: is this hidden raid component
5177 * Creating end device object, stored in ioc->sas_device_list.
5179 * Returns 0 for success, non-zero for failure.
5182 _scsih_add_device(struct MPT3SAS_ADAPTER *ioc, u16 handle, u8 phy_num,
5185 Mpi2ConfigReply_t mpi_reply;
5186 Mpi2SasDevicePage0_t sas_device_pg0;
5187 Mpi2SasEnclosurePage0_t enclosure_pg0;
5188 struct _sas_device *sas_device;
5193 if ((mpt3sas_config_get_sas_device_pg0(ioc, &mpi_reply, &sas_device_pg0,
5194 MPI2_SAS_DEVICE_PGAD_FORM_HANDLE, handle))) {
5195 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
5196 ioc->name, __FILE__, __LINE__, __func__);
5200 ioc_status = le16_to_cpu(mpi_reply.IOCStatus) &
5201 MPI2_IOCSTATUS_MASK;
5202 if (ioc_status != MPI2_IOCSTATUS_SUCCESS) {
5203 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
5204 ioc->name, __FILE__, __LINE__, __func__);
5208 /* check if this is end device */
5209 device_info = le32_to_cpu(sas_device_pg0.DeviceInfo);
5210 if (!(_scsih_is_end_device(device_info)))
5212 sas_address = le64_to_cpu(sas_device_pg0.SASAddress);
5214 /* check if device is present */
5215 if (!(le16_to_cpu(sas_device_pg0.Flags) &
5216 MPI2_SAS_DEVICE0_FLAGS_DEVICE_PRESENT)) {
5217 pr_err(MPT3SAS_FMT "device is not present handle(0x04%x)!!!\n",
5222 /* check if there were any issues with discovery */
5223 if (_scsih_check_access_status(ioc, sas_address, handle,
5224 sas_device_pg0.AccessStatus))
5227 sas_device = mpt3sas_get_sdev_by_addr(ioc, sas_address);
5229 sas_device_put(sas_device);
5233 sas_device = kzalloc(sizeof(struct _sas_device),
5236 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
5237 ioc->name, __FILE__, __LINE__, __func__);
5241 kref_init(&sas_device->refcount);
5242 sas_device->handle = handle;
5243 if (_scsih_get_sas_address(ioc,
5244 le16_to_cpu(sas_device_pg0.ParentDevHandle),
5245 &sas_device->sas_address_parent) != 0)
5246 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
5247 ioc->name, __FILE__, __LINE__, __func__);
5248 sas_device->enclosure_handle =
5249 le16_to_cpu(sas_device_pg0.EnclosureHandle);
5250 if (sas_device->enclosure_handle != 0)
5252 le16_to_cpu(sas_device_pg0.Slot);
5253 sas_device->device_info = device_info;
5254 sas_device->sas_address = sas_address;
5255 sas_device->phy = sas_device_pg0.PhyNum;
5256 sas_device->fast_path = (le16_to_cpu(sas_device_pg0.Flags) &
5257 MPI25_SAS_DEVICE0_FLAGS_FAST_PATH_CAPABLE) ? 1 : 0;
5259 if (sas_device_pg0.Flags & MPI2_SAS_DEVICE0_FLAGS_ENCL_LEVEL_VALID) {
5260 sas_device->enclosure_level =
5261 le16_to_cpu(sas_device_pg0.EnclosureLevel);
5262 memcpy(&sas_device->connector_name[0],
5263 &sas_device_pg0.ConnectorName[0], 4);
5265 sas_device->enclosure_level = 0;
5266 sas_device->connector_name[0] = '\0';
5268 /* get enclosure_logical_id */
5269 if (sas_device->enclosure_handle && !(mpt3sas_config_get_enclosure_pg0(
5270 ioc, &mpi_reply, &enclosure_pg0, MPI2_SAS_ENCLOS_PGAD_FORM_HANDLE,
5271 sas_device->enclosure_handle)))
5272 sas_device->enclosure_logical_id =
5273 le64_to_cpu(enclosure_pg0.EnclosureLogicalID);
5275 /* get device name */
5276 sas_device->device_name = le64_to_cpu(sas_device_pg0.DeviceName);
5278 if (ioc->wait_for_discovery_to_complete)
5279 _scsih_sas_device_init_add(ioc, sas_device);
5281 _scsih_sas_device_add(ioc, sas_device);
5283 sas_device_put(sas_device);
5288 * _scsih_remove_device - removing sas device object
5289 * @ioc: per adapter object
5290 * @sas_device_delete: the sas_device object
5295 _scsih_remove_device(struct MPT3SAS_ADAPTER *ioc,
5296 struct _sas_device *sas_device)
5298 struct MPT3SAS_TARGET *sas_target_priv_data;
5300 if ((ioc->pdev->subsystem_vendor == PCI_VENDOR_ID_IBM) &&
5301 (sas_device->pfa_led_on)) {
5302 _scsih_turn_off_pfa_led(ioc, sas_device);
5303 sas_device->pfa_led_on = 0;
5305 dewtprintk(ioc, pr_info(MPT3SAS_FMT
5306 "%s: enter: handle(0x%04x), sas_addr(0x%016llx)\n",
5307 ioc->name, __func__,
5308 sas_device->handle, (unsigned long long)
5309 sas_device->sas_address));
5310 if (sas_device->enclosure_handle != 0)
5311 dewtprintk(ioc, pr_info(MPT3SAS_FMT
5312 "%s: enter: enclosure logical id(0x%016llx), slot(%d)\n",
5313 ioc->name, __func__,
5314 (unsigned long long)sas_device->enclosure_logical_id,
5316 if (sas_device->connector_name[0] != '\0')
5317 dewtprintk(ioc, pr_info(MPT3SAS_FMT
5318 "%s: enter: enclosure level(0x%04x), connector name( %s)\n",
5319 ioc->name, __func__,
5320 sas_device->enclosure_level,
5321 sas_device->connector_name));
5323 if (sas_device->starget && sas_device->starget->hostdata) {
5324 sas_target_priv_data = sas_device->starget->hostdata;
5325 sas_target_priv_data->deleted = 1;
5326 _scsih_ublock_io_device(ioc, sas_device->sas_address);
5327 sas_target_priv_data->handle =
5328 MPT3SAS_INVALID_DEVICE_HANDLE;
5330 mpt3sas_transport_port_remove(ioc,
5331 sas_device->sas_address,
5332 sas_device->sas_address_parent);
5335 "removing handle(0x%04x), sas_addr(0x%016llx)\n",
5336 ioc->name, sas_device->handle,
5337 (unsigned long long) sas_device->sas_address);
5338 if (sas_device->enclosure_handle != 0)
5340 "removing : enclosure logical id(0x%016llx), slot(%d)\n",
5342 (unsigned long long)sas_device->enclosure_logical_id,
5344 if (sas_device->connector_name[0] != '\0')
5346 "removing enclosure level(0x%04x), connector name( %s)\n",
5347 ioc->name, sas_device->enclosure_level,
5348 sas_device->connector_name);
5350 dewtprintk(ioc, pr_info(MPT3SAS_FMT
5351 "%s: exit: handle(0x%04x), sas_addr(0x%016llx)\n",
5352 ioc->name, __func__,
5353 sas_device->handle, (unsigned long long)
5354 sas_device->sas_address));
5355 if (sas_device->enclosure_handle != 0)
5356 dewtprintk(ioc, pr_info(MPT3SAS_FMT
5357 "%s: exit: enclosure logical id(0x%016llx), slot(%d)\n",
5358 ioc->name, __func__,
5359 (unsigned long long)sas_device->enclosure_logical_id,
5361 if (sas_device->connector_name[0] != '\0')
5362 dewtprintk(ioc, pr_info(MPT3SAS_FMT
5363 "%s: exit: enclosure level(0x%04x), connector name(%s)\n",
5364 ioc->name, __func__, sas_device->enclosure_level,
5365 sas_device->connector_name));
5370 #ifdef CONFIG_SCSI_MPT3SAS_LOGGING
5372 * _scsih_sas_topology_change_event_debug - debug for topology event
5373 * @ioc: per adapter object
5374 * @event_data: event data payload
5378 _scsih_sas_topology_change_event_debug(struct MPT3SAS_ADAPTER *ioc,
5379 Mpi2EventDataSasTopologyChangeList_t *event_data)
5385 char *status_str = NULL;
5386 u8 link_rate, prev_link_rate;
5388 switch (event_data->ExpStatus) {
5389 case MPI2_EVENT_SAS_TOPO_ES_ADDED:
5392 case MPI2_EVENT_SAS_TOPO_ES_NOT_RESPONDING:
5393 status_str = "remove";
5395 case MPI2_EVENT_SAS_TOPO_ES_RESPONDING:
5397 status_str = "responding";
5399 case MPI2_EVENT_SAS_TOPO_ES_DELAY_NOT_RESPONDING:
5400 status_str = "remove delay";
5403 status_str = "unknown status";
5406 pr_info(MPT3SAS_FMT "sas topology change: (%s)\n",
5407 ioc->name, status_str);
5408 pr_info("\thandle(0x%04x), enclosure_handle(0x%04x) " \
5409 "start_phy(%02d), count(%d)\n",
5410 le16_to_cpu(event_data->ExpanderDevHandle),
5411 le16_to_cpu(event_data->EnclosureHandle),
5412 event_data->StartPhyNum, event_data->NumEntries);
5413 for (i = 0; i < event_data->NumEntries; i++) {
5414 handle = le16_to_cpu(event_data->PHY[i].AttachedDevHandle);
5417 phy_number = event_data->StartPhyNum + i;
5418 reason_code = event_data->PHY[i].PhyStatus &
5419 MPI2_EVENT_SAS_TOPO_RC_MASK;
5420 switch (reason_code) {
5421 case MPI2_EVENT_SAS_TOPO_RC_TARG_ADDED:
5422 status_str = "target add";
5424 case MPI2_EVENT_SAS_TOPO_RC_TARG_NOT_RESPONDING:
5425 status_str = "target remove";
5427 case MPI2_EVENT_SAS_TOPO_RC_DELAY_NOT_RESPONDING:
5428 status_str = "delay target remove";
5430 case MPI2_EVENT_SAS_TOPO_RC_PHY_CHANGED:
5431 status_str = "link rate change";
5433 case MPI2_EVENT_SAS_TOPO_RC_NO_CHANGE:
5434 status_str = "target responding";
5437 status_str = "unknown";
5440 link_rate = event_data->PHY[i].LinkRate >> 4;
5441 prev_link_rate = event_data->PHY[i].LinkRate & 0xF;
5442 pr_info("\tphy(%02d), attached_handle(0x%04x): %s:" \
5443 " link rate: new(0x%02x), old(0x%02x)\n", phy_number,
5444 handle, status_str, link_rate, prev_link_rate);
5451 * _scsih_sas_topology_change_event - handle topology changes
5452 * @ioc: per adapter object
5453 * @fw_event: The fw_event_work object
5458 _scsih_sas_topology_change_event(struct MPT3SAS_ADAPTER *ioc,
5459 struct fw_event_work *fw_event)
5462 u16 parent_handle, handle;
5464 u8 phy_number, max_phys;
5465 struct _sas_node *sas_expander;
5467 unsigned long flags;
5468 u8 link_rate, prev_link_rate;
5469 Mpi2EventDataSasTopologyChangeList_t *event_data =
5470 (Mpi2EventDataSasTopologyChangeList_t *)
5471 fw_event->event_data;
5473 #ifdef CONFIG_SCSI_MPT3SAS_LOGGING
5474 if (ioc->logging_level & MPT_DEBUG_EVENT_WORK_TASK)
5475 _scsih_sas_topology_change_event_debug(ioc, event_data);
5478 if (ioc->shost_recovery || ioc->remove_host || ioc->pci_error_recovery)
5481 if (!ioc->sas_hba.num_phys)
5482 _scsih_sas_host_add(ioc);
5484 _scsih_sas_host_refresh(ioc);
5486 if (fw_event->ignore) {
5487 dewtprintk(ioc, pr_info(MPT3SAS_FMT
5488 "ignoring expander event\n", ioc->name));
5492 parent_handle = le16_to_cpu(event_data->ExpanderDevHandle);
5494 /* handle expander add */
5495 if (event_data->ExpStatus == MPI2_EVENT_SAS_TOPO_ES_ADDED)
5496 if (_scsih_expander_add(ioc, parent_handle) != 0)
5499 spin_lock_irqsave(&ioc->sas_node_lock, flags);
5500 sas_expander = mpt3sas_scsih_expander_find_by_handle(ioc,
5503 sas_address = sas_expander->sas_address;
5504 max_phys = sas_expander->num_phys;
5505 } else if (parent_handle < ioc->sas_hba.num_phys) {
5506 sas_address = ioc->sas_hba.sas_address;
5507 max_phys = ioc->sas_hba.num_phys;
5509 spin_unlock_irqrestore(&ioc->sas_node_lock, flags);
5512 spin_unlock_irqrestore(&ioc->sas_node_lock, flags);
5514 /* handle siblings events */
5515 for (i = 0; i < event_data->NumEntries; i++) {
5516 if (fw_event->ignore) {
5517 dewtprintk(ioc, pr_info(MPT3SAS_FMT
5518 "ignoring expander event\n", ioc->name));
5521 if (ioc->remove_host || ioc->pci_error_recovery)
5523 phy_number = event_data->StartPhyNum + i;
5524 if (phy_number >= max_phys)
5526 reason_code = event_data->PHY[i].PhyStatus &
5527 MPI2_EVENT_SAS_TOPO_RC_MASK;
5528 if ((event_data->PHY[i].PhyStatus &
5529 MPI2_EVENT_SAS_TOPO_PHYSTATUS_VACANT) && (reason_code !=
5530 MPI2_EVENT_SAS_TOPO_RC_TARG_NOT_RESPONDING))
5532 handle = le16_to_cpu(event_data->PHY[i].AttachedDevHandle);
5535 link_rate = event_data->PHY[i].LinkRate >> 4;
5536 prev_link_rate = event_data->PHY[i].LinkRate & 0xF;
5537 switch (reason_code) {
5538 case MPI2_EVENT_SAS_TOPO_RC_PHY_CHANGED:
5540 if (ioc->shost_recovery)
5543 if (link_rate == prev_link_rate)
5546 mpt3sas_transport_update_links(ioc, sas_address,
5547 handle, phy_number, link_rate);
5549 if (link_rate < MPI2_SAS_NEG_LINK_RATE_1_5)
5552 _scsih_check_device(ioc, sas_address, handle,
5553 phy_number, link_rate);
5556 case MPI2_EVENT_SAS_TOPO_RC_TARG_ADDED:
5558 if (ioc->shost_recovery)
5561 mpt3sas_transport_update_links(ioc, sas_address,
5562 handle, phy_number, link_rate);
5564 _scsih_add_device(ioc, handle, phy_number, 0);
5567 case MPI2_EVENT_SAS_TOPO_RC_TARG_NOT_RESPONDING:
5569 _scsih_device_remove_by_handle(ioc, handle);
5574 /* handle expander removal */
5575 if (event_data->ExpStatus == MPI2_EVENT_SAS_TOPO_ES_NOT_RESPONDING &&
5577 mpt3sas_expander_remove(ioc, sas_address);
5582 #ifdef CONFIG_SCSI_MPT3SAS_LOGGING
5584 * _scsih_sas_device_status_change_event_debug - debug for device event
5585 * @event_data: event data payload
5591 _scsih_sas_device_status_change_event_debug(struct MPT3SAS_ADAPTER *ioc,
5592 Mpi2EventDataSasDeviceStatusChange_t *event_data)
5594 char *reason_str = NULL;
5596 switch (event_data->ReasonCode) {
5597 case MPI2_EVENT_SAS_DEV_STAT_RC_SMART_DATA:
5598 reason_str = "smart data";
5600 case MPI2_EVENT_SAS_DEV_STAT_RC_UNSUPPORTED:
5601 reason_str = "unsupported device discovered";
5603 case MPI2_EVENT_SAS_DEV_STAT_RC_INTERNAL_DEVICE_RESET:
5604 reason_str = "internal device reset";
5606 case MPI2_EVENT_SAS_DEV_STAT_RC_TASK_ABORT_INTERNAL:
5607 reason_str = "internal task abort";
5609 case MPI2_EVENT_SAS_DEV_STAT_RC_ABORT_TASK_SET_INTERNAL:
5610 reason_str = "internal task abort set";
5612 case MPI2_EVENT_SAS_DEV_STAT_RC_CLEAR_TASK_SET_INTERNAL:
5613 reason_str = "internal clear task set";
5615 case MPI2_EVENT_SAS_DEV_STAT_RC_QUERY_TASK_INTERNAL:
5616 reason_str = "internal query task";
5618 case MPI2_EVENT_SAS_DEV_STAT_RC_SATA_INIT_FAILURE:
5619 reason_str = "sata init failure";
5621 case MPI2_EVENT_SAS_DEV_STAT_RC_CMP_INTERNAL_DEV_RESET:
5622 reason_str = "internal device reset complete";
5624 case MPI2_EVENT_SAS_DEV_STAT_RC_CMP_TASK_ABORT_INTERNAL:
5625 reason_str = "internal task abort complete";
5627 case MPI2_EVENT_SAS_DEV_STAT_RC_ASYNC_NOTIFICATION:
5628 reason_str = "internal async notification";
5630 case MPI2_EVENT_SAS_DEV_STAT_RC_EXPANDER_REDUCED_FUNCTIONALITY:
5631 reason_str = "expander reduced functionality";
5633 case MPI2_EVENT_SAS_DEV_STAT_RC_CMP_EXPANDER_REDUCED_FUNCTIONALITY:
5634 reason_str = "expander reduced functionality complete";
5637 reason_str = "unknown reason";
5640 pr_info(MPT3SAS_FMT "device status change: (%s)\n"
5641 "\thandle(0x%04x), sas address(0x%016llx), tag(%d)",
5642 ioc->name, reason_str, le16_to_cpu(event_data->DevHandle),
5643 (unsigned long long)le64_to_cpu(event_data->SASAddress),
5644 le16_to_cpu(event_data->TaskTag));
5645 if (event_data->ReasonCode == MPI2_EVENT_SAS_DEV_STAT_RC_SMART_DATA)
5646 pr_info(MPT3SAS_FMT ", ASC(0x%x), ASCQ(0x%x)\n", ioc->name,
5647 event_data->ASC, event_data->ASCQ);
5653 * _scsih_sas_device_status_change_event - handle device status change
5654 * @ioc: per adapter object
5655 * @fw_event: The fw_event_work object
5661 _scsih_sas_device_status_change_event(struct MPT3SAS_ADAPTER *ioc,
5662 struct fw_event_work *fw_event)
5664 struct MPT3SAS_TARGET *target_priv_data;
5665 struct _sas_device *sas_device;
5667 unsigned long flags;
5668 Mpi2EventDataSasDeviceStatusChange_t *event_data =
5669 (Mpi2EventDataSasDeviceStatusChange_t *)
5670 fw_event->event_data;
5672 #ifdef CONFIG_SCSI_MPT3SAS_LOGGING
5673 if (ioc->logging_level & MPT_DEBUG_EVENT_WORK_TASK)
5674 _scsih_sas_device_status_change_event_debug(ioc,
5678 /* In MPI Revision K (0xC), the internal device reset complete was
5679 * implemented, so avoid setting tm_busy flag for older firmware.
5681 if ((ioc->facts.HeaderVersion >> 8) < 0xC)
5684 if (event_data->ReasonCode !=
5685 MPI2_EVENT_SAS_DEV_STAT_RC_INTERNAL_DEVICE_RESET &&
5686 event_data->ReasonCode !=
5687 MPI2_EVENT_SAS_DEV_STAT_RC_CMP_INTERNAL_DEV_RESET)
5690 spin_lock_irqsave(&ioc->sas_device_lock, flags);
5691 sas_address = le64_to_cpu(event_data->SASAddress);
5692 sas_device = __mpt3sas_get_sdev_by_addr(ioc, sas_address);
5694 if (!sas_device || !sas_device->starget)
5697 target_priv_data = sas_device->starget->hostdata;
5698 if (!target_priv_data)
5701 if (event_data->ReasonCode ==
5702 MPI2_EVENT_SAS_DEV_STAT_RC_INTERNAL_DEVICE_RESET)
5703 target_priv_data->tm_busy = 1;
5705 target_priv_data->tm_busy = 0;
5709 sas_device_put(sas_device);
5711 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
5714 #ifdef CONFIG_SCSI_MPT3SAS_LOGGING
5716 * _scsih_sas_enclosure_dev_status_change_event_debug - debug for enclosure
5718 * @ioc: per adapter object
5719 * @event_data: event data payload
5725 _scsih_sas_enclosure_dev_status_change_event_debug(struct MPT3SAS_ADAPTER *ioc,
5726 Mpi2EventDataSasEnclDevStatusChange_t *event_data)
5728 char *reason_str = NULL;
5730 switch (event_data->ReasonCode) {
5731 case MPI2_EVENT_SAS_ENCL_RC_ADDED:
5732 reason_str = "enclosure add";
5734 case MPI2_EVENT_SAS_ENCL_RC_NOT_RESPONDING:
5735 reason_str = "enclosure remove";
5738 reason_str = "unknown reason";
5742 pr_info(MPT3SAS_FMT "enclosure status change: (%s)\n"
5743 "\thandle(0x%04x), enclosure logical id(0x%016llx)"
5744 " number slots(%d)\n", ioc->name, reason_str,
5745 le16_to_cpu(event_data->EnclosureHandle),
5746 (unsigned long long)le64_to_cpu(event_data->EnclosureLogicalID),
5747 le16_to_cpu(event_data->StartSlot));
5752 * _scsih_sas_enclosure_dev_status_change_event - handle enclosure events
5753 * @ioc: per adapter object
5754 * @fw_event: The fw_event_work object
5760 _scsih_sas_enclosure_dev_status_change_event(struct MPT3SAS_ADAPTER *ioc,
5761 struct fw_event_work *fw_event)
5763 #ifdef CONFIG_SCSI_MPT3SAS_LOGGING
5764 if (ioc->logging_level & MPT_DEBUG_EVENT_WORK_TASK)
5765 _scsih_sas_enclosure_dev_status_change_event_debug(ioc,
5766 (Mpi2EventDataSasEnclDevStatusChange_t *)
5767 fw_event->event_data);
5772 * _scsih_sas_broadcast_primitive_event - handle broadcast events
5773 * @ioc: per adapter object
5774 * @fw_event: The fw_event_work object
5780 _scsih_sas_broadcast_primitive_event(struct MPT3SAS_ADAPTER *ioc,
5781 struct fw_event_work *fw_event)
5783 struct scsi_cmnd *scmd;
5784 struct scsi_device *sdev;
5787 struct MPT3SAS_DEVICE *sas_device_priv_data;
5788 u32 termination_count;
5790 Mpi2SCSITaskManagementReply_t *mpi_reply;
5791 Mpi2EventDataSasBroadcastPrimitive_t *event_data =
5792 (Mpi2EventDataSasBroadcastPrimitive_t *)
5793 fw_event->event_data;
5795 unsigned long flags;
5798 u8 task_abort_retries;
5800 mutex_lock(&ioc->tm_cmds.mutex);
5802 "%s: enter: phy number(%d), width(%d)\n",
5803 ioc->name, __func__, event_data->PhyNum,
5804 event_data->PortWidth);
5806 _scsih_block_io_all_device(ioc);
5808 spin_lock_irqsave(&ioc->scsi_lookup_lock, flags);
5809 mpi_reply = ioc->tm_cmds.reply;
5810 broadcast_aen_retry:
5812 /* sanity checks for retrying this loop */
5813 if (max_retries++ == 5) {
5814 dewtprintk(ioc, pr_info(MPT3SAS_FMT "%s: giving up\n",
5815 ioc->name, __func__));
5817 } else if (max_retries > 1)
5818 dewtprintk(ioc, pr_info(MPT3SAS_FMT "%s: %d retry\n",
5819 ioc->name, __func__, max_retries - 1));
5821 termination_count = 0;
5823 for (smid = 1; smid <= ioc->scsiio_depth; smid++) {
5824 if (ioc->shost_recovery)
5826 scmd = _scsih_scsi_lookup_get(ioc, smid);
5829 sdev = scmd->device;
5830 sas_device_priv_data = sdev->hostdata;
5831 if (!sas_device_priv_data || !sas_device_priv_data->sas_target)
5833 /* skip hidden raid components */
5834 if (sas_device_priv_data->sas_target->flags &
5835 MPT_TARGET_FLAGS_RAID_COMPONENT)
5838 if (sas_device_priv_data->sas_target->flags &
5839 MPT_TARGET_FLAGS_VOLUME)
5842 handle = sas_device_priv_data->sas_target->handle;
5843 lun = sas_device_priv_data->lun;
5846 if (ioc->shost_recovery)
5849 spin_unlock_irqrestore(&ioc->scsi_lookup_lock, flags);
5850 r = mpt3sas_scsih_issue_tm(ioc, handle, 0, 0, lun,
5851 MPI2_SCSITASKMGMT_TASKTYPE_QUERY_TASK, smid, 30,
5854 sdev_printk(KERN_WARNING, sdev,
5855 "mpt3sas_scsih_issue_tm: FAILED when sending "
5856 "QUERY_TASK: scmd(%p)\n", scmd);
5857 spin_lock_irqsave(&ioc->scsi_lookup_lock, flags);
5858 goto broadcast_aen_retry;
5860 ioc_status = le16_to_cpu(mpi_reply->IOCStatus)
5861 & MPI2_IOCSTATUS_MASK;
5862 if (ioc_status != MPI2_IOCSTATUS_SUCCESS) {
5863 sdev_printk(KERN_WARNING, sdev,
5864 "query task: FAILED with IOCSTATUS(0x%04x), scmd(%p)\n",
5866 spin_lock_irqsave(&ioc->scsi_lookup_lock, flags);
5867 goto broadcast_aen_retry;
5870 /* see if IO is still owned by IOC and target */
5871 if (mpi_reply->ResponseCode ==
5872 MPI2_SCSITASKMGMT_RSP_TM_SUCCEEDED ||
5873 mpi_reply->ResponseCode ==
5874 MPI2_SCSITASKMGMT_RSP_IO_QUEUED_ON_IOC) {
5875 spin_lock_irqsave(&ioc->scsi_lookup_lock, flags);
5878 task_abort_retries = 0;
5880 if (task_abort_retries++ == 60) {
5881 dewtprintk(ioc, pr_info(MPT3SAS_FMT
5882 "%s: ABORT_TASK: giving up\n", ioc->name,
5884 spin_lock_irqsave(&ioc->scsi_lookup_lock, flags);
5885 goto broadcast_aen_retry;
5888 if (ioc->shost_recovery)
5891 r = mpt3sas_scsih_issue_tm(ioc, handle, sdev->channel, sdev->id,
5892 sdev->lun, MPI2_SCSITASKMGMT_TASKTYPE_ABORT_TASK, smid, 30,
5895 sdev_printk(KERN_WARNING, sdev,
5896 "mpt3sas_scsih_issue_tm: ABORT_TASK: FAILED : "
5897 "scmd(%p)\n", scmd);
5901 if (task_abort_retries > 1)
5902 sdev_printk(KERN_WARNING, sdev,
5903 "mpt3sas_scsih_issue_tm: ABORT_TASK: RETRIES (%d):"
5905 task_abort_retries - 1, scmd);
5907 termination_count += le32_to_cpu(mpi_reply->TerminationCount);
5908 spin_lock_irqsave(&ioc->scsi_lookup_lock, flags);
5911 if (ioc->broadcast_aen_pending) {
5912 dewtprintk(ioc, pr_info(MPT3SAS_FMT
5913 "%s: loop back due to pending AEN\n",
5914 ioc->name, __func__));
5915 ioc->broadcast_aen_pending = 0;
5916 goto broadcast_aen_retry;
5920 spin_unlock_irqrestore(&ioc->scsi_lookup_lock, flags);
5923 dewtprintk(ioc, pr_info(MPT3SAS_FMT
5924 "%s - exit, query_count = %d termination_count = %d\n",
5925 ioc->name, __func__, query_count, termination_count));
5927 ioc->broadcast_aen_busy = 0;
5928 if (!ioc->shost_recovery)
5929 _scsih_ublock_io_all_device(ioc);
5930 mutex_unlock(&ioc->tm_cmds.mutex);
5934 * _scsih_sas_discovery_event - handle discovery events
5935 * @ioc: per adapter object
5936 * @fw_event: The fw_event_work object
5942 _scsih_sas_discovery_event(struct MPT3SAS_ADAPTER *ioc,
5943 struct fw_event_work *fw_event)
5945 Mpi2EventDataSasDiscovery_t *event_data =
5946 (Mpi2EventDataSasDiscovery_t *) fw_event->event_data;
5948 #ifdef CONFIG_SCSI_MPT3SAS_LOGGING
5949 if (ioc->logging_level & MPT_DEBUG_EVENT_WORK_TASK) {
5950 pr_info(MPT3SAS_FMT "discovery event: (%s)", ioc->name,
5951 (event_data->ReasonCode == MPI2_EVENT_SAS_DISC_RC_STARTED) ?
5953 if (event_data->DiscoveryStatus)
5954 pr_info("discovery_status(0x%08x)",
5955 le32_to_cpu(event_data->DiscoveryStatus));
5960 if (event_data->ReasonCode == MPI2_EVENT_SAS_DISC_RC_STARTED &&
5961 !ioc->sas_hba.num_phys) {
5962 if (disable_discovery > 0 && ioc->shost_recovery) {
5963 /* Wait for the reset to complete */
5964 while (ioc->shost_recovery)
5967 _scsih_sas_host_add(ioc);
5972 * _scsih_ir_fastpath - turn on fastpath for IR physdisk
5973 * @ioc: per adapter object
5974 * @handle: device handle for physical disk
5975 * @phys_disk_num: physical disk number
5977 * Return 0 for success, else failure.
5980 _scsih_ir_fastpath(struct MPT3SAS_ADAPTER *ioc, u16 handle, u8 phys_disk_num)
5982 Mpi2RaidActionRequest_t *mpi_request;
5983 Mpi2RaidActionReply_t *mpi_reply;
5991 mutex_lock(&ioc->scsih_cmds.mutex);
5993 if (ioc->scsih_cmds.status != MPT3_CMD_NOT_USED) {
5994 pr_err(MPT3SAS_FMT "%s: scsih_cmd in use\n",
5995 ioc->name, __func__);
5999 ioc->scsih_cmds.status = MPT3_CMD_PENDING;
6001 smid = mpt3sas_base_get_smid(ioc, ioc->scsih_cb_idx);
6003 pr_err(MPT3SAS_FMT "%s: failed obtaining a smid\n",
6004 ioc->name, __func__);
6005 ioc->scsih_cmds.status = MPT3_CMD_NOT_USED;
6010 mpi_request = mpt3sas_base_get_msg_frame(ioc, smid);
6011 ioc->scsih_cmds.smid = smid;
6012 memset(mpi_request, 0, sizeof(Mpi2RaidActionRequest_t));
6014 mpi_request->Function = MPI2_FUNCTION_RAID_ACTION;
6015 mpi_request->Action = MPI2_RAID_ACTION_PHYSDISK_HIDDEN;
6016 mpi_request->PhysDiskNum = phys_disk_num;
6018 dewtprintk(ioc, pr_info(MPT3SAS_FMT "IR RAID_ACTION: turning fast "\
6019 "path on for handle(0x%04x), phys_disk_num (0x%02x)\n", ioc->name,
6020 handle, phys_disk_num));
6022 init_completion(&ioc->scsih_cmds.done);
6023 mpt3sas_base_put_smid_default(ioc, smid);
6024 wait_for_completion_timeout(&ioc->scsih_cmds.done, 10*HZ);
6026 if (!(ioc->scsih_cmds.status & MPT3_CMD_COMPLETE)) {
6027 pr_err(MPT3SAS_FMT "%s: timeout\n",
6028 ioc->name, __func__);
6029 if (!(ioc->scsih_cmds.status & MPT3_CMD_RESET))
6035 if (ioc->scsih_cmds.status & MPT3_CMD_REPLY_VALID) {
6037 mpi_reply = ioc->scsih_cmds.reply;
6038 ioc_status = le16_to_cpu(mpi_reply->IOCStatus);
6039 if (ioc_status & MPI2_IOCSTATUS_FLAG_LOG_INFO_AVAILABLE)
6040 log_info = le32_to_cpu(mpi_reply->IOCLogInfo);
6043 ioc_status &= MPI2_IOCSTATUS_MASK;
6044 if (ioc_status != MPI2_IOCSTATUS_SUCCESS) {
6045 dewtprintk(ioc, pr_info(MPT3SAS_FMT
6046 "IR RAID_ACTION: failed: ioc_status(0x%04x), "
6047 "loginfo(0x%08x)!!!\n", ioc->name, ioc_status,
6051 dewtprintk(ioc, pr_info(MPT3SAS_FMT
6052 "IR RAID_ACTION: completed successfully\n",
6057 ioc->scsih_cmds.status = MPT3_CMD_NOT_USED;
6058 mutex_unlock(&ioc->scsih_cmds.mutex);
6061 mpt3sas_base_hard_reset_handler(ioc, CAN_SLEEP,
6067 * _scsih_reprobe_lun - reprobing lun
6068 * @sdev: scsi device struct
6069 * @no_uld_attach: sdev->no_uld_attach flag setting
6073 _scsih_reprobe_lun(struct scsi_device *sdev, void *no_uld_attach)
6076 sdev->no_uld_attach = no_uld_attach ? 1 : 0;
6077 sdev_printk(KERN_INFO, sdev, "%s raid component\n",
6078 sdev->no_uld_attach ? "hidding" : "exposing");
6079 rc = scsi_device_reprobe(sdev);
6083 * _scsih_sas_volume_add - add new volume
6084 * @ioc: per adapter object
6085 * @element: IR config element data
6091 _scsih_sas_volume_add(struct MPT3SAS_ADAPTER *ioc,
6092 Mpi2EventIrConfigElement_t *element)
6094 struct _raid_device *raid_device;
6095 unsigned long flags;
6097 u16 handle = le16_to_cpu(element->VolDevHandle);
6100 mpt3sas_config_get_volume_wwid(ioc, handle, &wwid);
6103 "failure at %s:%d/%s()!\n", ioc->name,
6104 __FILE__, __LINE__, __func__);
6108 spin_lock_irqsave(&ioc->raid_device_lock, flags);
6109 raid_device = _scsih_raid_device_find_by_wwid(ioc, wwid);
6110 spin_unlock_irqrestore(&ioc->raid_device_lock, flags);
6115 raid_device = kzalloc(sizeof(struct _raid_device), GFP_KERNEL);
6118 "failure at %s:%d/%s()!\n", ioc->name,
6119 __FILE__, __LINE__, __func__);
6123 raid_device->id = ioc->sas_id++;
6124 raid_device->channel = RAID_CHANNEL;
6125 raid_device->handle = handle;
6126 raid_device->wwid = wwid;
6127 _scsih_raid_device_add(ioc, raid_device);
6128 if (!ioc->wait_for_discovery_to_complete) {
6129 rc = scsi_add_device(ioc->shost, RAID_CHANNEL,
6130 raid_device->id, 0);
6132 _scsih_raid_device_remove(ioc, raid_device);
6134 spin_lock_irqsave(&ioc->raid_device_lock, flags);
6135 _scsih_determine_boot_device(ioc, raid_device, 1);
6136 spin_unlock_irqrestore(&ioc->raid_device_lock, flags);
6141 * _scsih_sas_volume_delete - delete volume
6142 * @ioc: per adapter object
6143 * @handle: volume device handle
6149 _scsih_sas_volume_delete(struct MPT3SAS_ADAPTER *ioc, u16 handle)
6151 struct _raid_device *raid_device;
6152 unsigned long flags;
6153 struct MPT3SAS_TARGET *sas_target_priv_data;
6154 struct scsi_target *starget = NULL;
6156 spin_lock_irqsave(&ioc->raid_device_lock, flags);
6157 raid_device = _scsih_raid_device_find_by_handle(ioc, handle);
6159 if (raid_device->starget) {
6160 starget = raid_device->starget;
6161 sas_target_priv_data = starget->hostdata;
6162 sas_target_priv_data->deleted = 1;
6164 pr_info(MPT3SAS_FMT "removing handle(0x%04x), wwid(0x%016llx)\n",
6165 ioc->name, raid_device->handle,
6166 (unsigned long long) raid_device->wwid);
6167 list_del(&raid_device->list);
6170 spin_unlock_irqrestore(&ioc->raid_device_lock, flags);
6172 scsi_remove_target(&starget->dev);
6176 * _scsih_sas_pd_expose - expose pd component to /dev/sdX
6177 * @ioc: per adapter object
6178 * @element: IR config element data
6184 _scsih_sas_pd_expose(struct MPT3SAS_ADAPTER *ioc,
6185 Mpi2EventIrConfigElement_t *element)
6187 struct _sas_device *sas_device;
6188 struct scsi_target *starget = NULL;
6189 struct MPT3SAS_TARGET *sas_target_priv_data;
6190 unsigned long flags;
6191 u16 handle = le16_to_cpu(element->PhysDiskDevHandle);
6193 spin_lock_irqsave(&ioc->sas_device_lock, flags);
6194 sas_device = __mpt3sas_get_sdev_by_handle(ioc, handle);
6196 sas_device->volume_handle = 0;
6197 sas_device->volume_wwid = 0;
6198 clear_bit(handle, ioc->pd_handles);
6199 if (sas_device->starget && sas_device->starget->hostdata) {
6200 starget = sas_device->starget;
6201 sas_target_priv_data = starget->hostdata;
6202 sas_target_priv_data->flags &=
6203 ~MPT_TARGET_FLAGS_RAID_COMPONENT;
6206 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
6210 /* exposing raid component */
6212 starget_for_each_device(starget, NULL, _scsih_reprobe_lun);
6214 sas_device_put(sas_device);
6218 * _scsih_sas_pd_hide - hide pd component from /dev/sdX
6219 * @ioc: per adapter object
6220 * @element: IR config element data
6226 _scsih_sas_pd_hide(struct MPT3SAS_ADAPTER *ioc,
6227 Mpi2EventIrConfigElement_t *element)
6229 struct _sas_device *sas_device;
6230 struct scsi_target *starget = NULL;
6231 struct MPT3SAS_TARGET *sas_target_priv_data;
6232 unsigned long flags;
6233 u16 handle = le16_to_cpu(element->PhysDiskDevHandle);
6234 u16 volume_handle = 0;
6235 u64 volume_wwid = 0;
6237 mpt3sas_config_get_volume_handle(ioc, handle, &volume_handle);
6239 mpt3sas_config_get_volume_wwid(ioc, volume_handle,
6242 spin_lock_irqsave(&ioc->sas_device_lock, flags);
6243 sas_device = __mpt3sas_get_sdev_by_handle(ioc, handle);
6245 set_bit(handle, ioc->pd_handles);
6246 if (sas_device->starget && sas_device->starget->hostdata) {
6247 starget = sas_device->starget;
6248 sas_target_priv_data = starget->hostdata;
6249 sas_target_priv_data->flags |=
6250 MPT_TARGET_FLAGS_RAID_COMPONENT;
6251 sas_device->volume_handle = volume_handle;
6252 sas_device->volume_wwid = volume_wwid;
6255 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
6259 /* hiding raid component */
6260 _scsih_ir_fastpath(ioc, handle, element->PhysDiskNum);
6262 starget_for_each_device(starget, (void *)1, _scsih_reprobe_lun);
6264 sas_device_put(sas_device);
6268 * _scsih_sas_pd_delete - delete pd component
6269 * @ioc: per adapter object
6270 * @element: IR config element data
6276 _scsih_sas_pd_delete(struct MPT3SAS_ADAPTER *ioc,
6277 Mpi2EventIrConfigElement_t *element)
6279 u16 handle = le16_to_cpu(element->PhysDiskDevHandle);
6281 _scsih_device_remove_by_handle(ioc, handle);
6285 * _scsih_sas_pd_add - remove pd component
6286 * @ioc: per adapter object
6287 * @element: IR config element data
6293 _scsih_sas_pd_add(struct MPT3SAS_ADAPTER *ioc,
6294 Mpi2EventIrConfigElement_t *element)
6296 struct _sas_device *sas_device;
6297 u16 handle = le16_to_cpu(element->PhysDiskDevHandle);
6298 Mpi2ConfigReply_t mpi_reply;
6299 Mpi2SasDevicePage0_t sas_device_pg0;
6304 set_bit(handle, ioc->pd_handles);
6306 sas_device = mpt3sas_get_sdev_by_handle(ioc, handle);
6308 _scsih_ir_fastpath(ioc, handle, element->PhysDiskNum);
6309 sas_device_put(sas_device);
6313 if ((mpt3sas_config_get_sas_device_pg0(ioc, &mpi_reply, &sas_device_pg0,
6314 MPI2_SAS_DEVICE_PGAD_FORM_HANDLE, handle))) {
6315 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
6316 ioc->name, __FILE__, __LINE__, __func__);
6320 ioc_status = le16_to_cpu(mpi_reply.IOCStatus) &
6321 MPI2_IOCSTATUS_MASK;
6322 if (ioc_status != MPI2_IOCSTATUS_SUCCESS) {
6323 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
6324 ioc->name, __FILE__, __LINE__, __func__);
6328 parent_handle = le16_to_cpu(sas_device_pg0.ParentDevHandle);
6329 if (!_scsih_get_sas_address(ioc, parent_handle, &sas_address))
6330 mpt3sas_transport_update_links(ioc, sas_address, handle,
6331 sas_device_pg0.PhyNum, MPI2_SAS_NEG_LINK_RATE_1_5);
6333 _scsih_ir_fastpath(ioc, handle, element->PhysDiskNum);
6334 _scsih_add_device(ioc, handle, 0, 1);
6337 #ifdef CONFIG_SCSI_MPT3SAS_LOGGING
6339 * _scsih_sas_ir_config_change_event_debug - debug for IR Config Change events
6340 * @ioc: per adapter object
6341 * @event_data: event data payload
6347 _scsih_sas_ir_config_change_event_debug(struct MPT3SAS_ADAPTER *ioc,
6348 Mpi2EventDataIrConfigChangeList_t *event_data)
6350 Mpi2EventIrConfigElement_t *element;
6353 char *reason_str = NULL, *element_str = NULL;
6355 element = (Mpi2EventIrConfigElement_t *)&event_data->ConfigElement[0];
6357 pr_info(MPT3SAS_FMT "raid config change: (%s), elements(%d)\n",
6358 ioc->name, (le32_to_cpu(event_data->Flags) &
6359 MPI2_EVENT_IR_CHANGE_FLAGS_FOREIGN_CONFIG) ?
6360 "foreign" : "native", event_data->NumElements);
6361 for (i = 0; i < event_data->NumElements; i++, element++) {
6362 switch (element->ReasonCode) {
6363 case MPI2_EVENT_IR_CHANGE_RC_ADDED:
6366 case MPI2_EVENT_IR_CHANGE_RC_REMOVED:
6367 reason_str = "remove";
6369 case MPI2_EVENT_IR_CHANGE_RC_NO_CHANGE:
6370 reason_str = "no change";
6372 case MPI2_EVENT_IR_CHANGE_RC_HIDE:
6373 reason_str = "hide";
6375 case MPI2_EVENT_IR_CHANGE_RC_UNHIDE:
6376 reason_str = "unhide";
6378 case MPI2_EVENT_IR_CHANGE_RC_VOLUME_CREATED:
6379 reason_str = "volume_created";
6381 case MPI2_EVENT_IR_CHANGE_RC_VOLUME_DELETED:
6382 reason_str = "volume_deleted";
6384 case MPI2_EVENT_IR_CHANGE_RC_PD_CREATED:
6385 reason_str = "pd_created";
6387 case MPI2_EVENT_IR_CHANGE_RC_PD_DELETED:
6388 reason_str = "pd_deleted";
6391 reason_str = "unknown reason";
6394 element_type = le16_to_cpu(element->ElementFlags) &
6395 MPI2_EVENT_IR_CHANGE_EFLAGS_ELEMENT_TYPE_MASK;
6396 switch (element_type) {
6397 case MPI2_EVENT_IR_CHANGE_EFLAGS_VOLUME_ELEMENT:
6398 element_str = "volume";
6400 case MPI2_EVENT_IR_CHANGE_EFLAGS_VOLPHYSDISK_ELEMENT:
6401 element_str = "phys disk";
6403 case MPI2_EVENT_IR_CHANGE_EFLAGS_HOTSPARE_ELEMENT:
6404 element_str = "hot spare";
6407 element_str = "unknown element";
6410 pr_info("\t(%s:%s), vol handle(0x%04x), " \
6411 "pd handle(0x%04x), pd num(0x%02x)\n", element_str,
6412 reason_str, le16_to_cpu(element->VolDevHandle),
6413 le16_to_cpu(element->PhysDiskDevHandle),
6414 element->PhysDiskNum);
6420 * _scsih_sas_ir_config_change_event - handle ir configuration change events
6421 * @ioc: per adapter object
6422 * @fw_event: The fw_event_work object
6428 _scsih_sas_ir_config_change_event(struct MPT3SAS_ADAPTER *ioc,
6429 struct fw_event_work *fw_event)
6431 Mpi2EventIrConfigElement_t *element;
6434 Mpi2EventDataIrConfigChangeList_t *event_data =
6435 (Mpi2EventDataIrConfigChangeList_t *)
6436 fw_event->event_data;
6438 #ifdef CONFIG_SCSI_MPT3SAS_LOGGING
6439 if (ioc->logging_level & MPT_DEBUG_EVENT_WORK_TASK)
6440 _scsih_sas_ir_config_change_event_debug(ioc, event_data);
6444 foreign_config = (le32_to_cpu(event_data->Flags) &
6445 MPI2_EVENT_IR_CHANGE_FLAGS_FOREIGN_CONFIG) ? 1 : 0;
6447 element = (Mpi2EventIrConfigElement_t *)&event_data->ConfigElement[0];
6448 if (ioc->shost_recovery) {
6450 for (i = 0; i < event_data->NumElements; i++, element++) {
6451 if (element->ReasonCode == MPI2_EVENT_IR_CHANGE_RC_HIDE)
6452 _scsih_ir_fastpath(ioc,
6453 le16_to_cpu(element->PhysDiskDevHandle),
6454 element->PhysDiskNum);
6458 for (i = 0; i < event_data->NumElements; i++, element++) {
6460 switch (element->ReasonCode) {
6461 case MPI2_EVENT_IR_CHANGE_RC_VOLUME_CREATED:
6462 case MPI2_EVENT_IR_CHANGE_RC_ADDED:
6463 if (!foreign_config)
6464 _scsih_sas_volume_add(ioc, element);
6466 case MPI2_EVENT_IR_CHANGE_RC_VOLUME_DELETED:
6467 case MPI2_EVENT_IR_CHANGE_RC_REMOVED:
6468 if (!foreign_config)
6469 _scsih_sas_volume_delete(ioc,
6470 le16_to_cpu(element->VolDevHandle));
6472 case MPI2_EVENT_IR_CHANGE_RC_PD_CREATED:
6473 _scsih_sas_pd_hide(ioc, element);
6475 case MPI2_EVENT_IR_CHANGE_RC_PD_DELETED:
6476 _scsih_sas_pd_expose(ioc, element);
6478 case MPI2_EVENT_IR_CHANGE_RC_HIDE:
6479 _scsih_sas_pd_add(ioc, element);
6481 case MPI2_EVENT_IR_CHANGE_RC_UNHIDE:
6482 _scsih_sas_pd_delete(ioc, element);
6489 * _scsih_sas_ir_volume_event - IR volume event
6490 * @ioc: per adapter object
6491 * @fw_event: The fw_event_work object
6497 _scsih_sas_ir_volume_event(struct MPT3SAS_ADAPTER *ioc,
6498 struct fw_event_work *fw_event)
6501 unsigned long flags;
6502 struct _raid_device *raid_device;
6506 Mpi2EventDataIrVolume_t *event_data =
6507 (Mpi2EventDataIrVolume_t *) fw_event->event_data;
6509 if (ioc->shost_recovery)
6512 if (event_data->ReasonCode != MPI2_EVENT_IR_VOLUME_RC_STATE_CHANGED)
6515 handle = le16_to_cpu(event_data->VolDevHandle);
6516 state = le32_to_cpu(event_data->NewValue);
6517 dewtprintk(ioc, pr_info(MPT3SAS_FMT
6518 "%s: handle(0x%04x), old(0x%08x), new(0x%08x)\n",
6519 ioc->name, __func__, handle,
6520 le32_to_cpu(event_data->PreviousValue), state));
6522 case MPI2_RAID_VOL_STATE_MISSING:
6523 case MPI2_RAID_VOL_STATE_FAILED:
6524 _scsih_sas_volume_delete(ioc, handle);
6527 case MPI2_RAID_VOL_STATE_ONLINE:
6528 case MPI2_RAID_VOL_STATE_DEGRADED:
6529 case MPI2_RAID_VOL_STATE_OPTIMAL:
6531 spin_lock_irqsave(&ioc->raid_device_lock, flags);
6532 raid_device = _scsih_raid_device_find_by_handle(ioc, handle);
6533 spin_unlock_irqrestore(&ioc->raid_device_lock, flags);
6538 mpt3sas_config_get_volume_wwid(ioc, handle, &wwid);
6541 "failure at %s:%d/%s()!\n", ioc->name,
6542 __FILE__, __LINE__, __func__);
6546 raid_device = kzalloc(sizeof(struct _raid_device), GFP_KERNEL);
6549 "failure at %s:%d/%s()!\n", ioc->name,
6550 __FILE__, __LINE__, __func__);
6554 raid_device->id = ioc->sas_id++;
6555 raid_device->channel = RAID_CHANNEL;
6556 raid_device->handle = handle;
6557 raid_device->wwid = wwid;
6558 _scsih_raid_device_add(ioc, raid_device);
6559 rc = scsi_add_device(ioc->shost, RAID_CHANNEL,
6560 raid_device->id, 0);
6562 _scsih_raid_device_remove(ioc, raid_device);
6565 case MPI2_RAID_VOL_STATE_INITIALIZING:
6572 * _scsih_sas_ir_physical_disk_event - PD event
6573 * @ioc: per adapter object
6574 * @fw_event: The fw_event_work object
6580 _scsih_sas_ir_physical_disk_event(struct MPT3SAS_ADAPTER *ioc,
6581 struct fw_event_work *fw_event)
6583 u16 handle, parent_handle;
6585 struct _sas_device *sas_device;
6586 Mpi2ConfigReply_t mpi_reply;
6587 Mpi2SasDevicePage0_t sas_device_pg0;
6589 Mpi2EventDataIrPhysicalDisk_t *event_data =
6590 (Mpi2EventDataIrPhysicalDisk_t *) fw_event->event_data;
6593 if (ioc->shost_recovery)
6596 if (event_data->ReasonCode != MPI2_EVENT_IR_PHYSDISK_RC_STATE_CHANGED)
6599 handle = le16_to_cpu(event_data->PhysDiskDevHandle);
6600 state = le32_to_cpu(event_data->NewValue);
6602 dewtprintk(ioc, pr_info(MPT3SAS_FMT
6603 "%s: handle(0x%04x), old(0x%08x), new(0x%08x)\n",
6604 ioc->name, __func__, handle,
6605 le32_to_cpu(event_data->PreviousValue), state));
6607 case MPI2_RAID_PD_STATE_ONLINE:
6608 case MPI2_RAID_PD_STATE_DEGRADED:
6609 case MPI2_RAID_PD_STATE_REBUILDING:
6610 case MPI2_RAID_PD_STATE_OPTIMAL:
6611 case MPI2_RAID_PD_STATE_HOT_SPARE:
6613 set_bit(handle, ioc->pd_handles);
6615 sas_device = mpt3sas_get_sdev_by_handle(ioc, handle);
6617 sas_device_put(sas_device);
6621 if ((mpt3sas_config_get_sas_device_pg0(ioc, &mpi_reply,
6622 &sas_device_pg0, MPI2_SAS_DEVICE_PGAD_FORM_HANDLE,
6624 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
6625 ioc->name, __FILE__, __LINE__, __func__);
6629 ioc_status = le16_to_cpu(mpi_reply.IOCStatus) &
6630 MPI2_IOCSTATUS_MASK;
6631 if (ioc_status != MPI2_IOCSTATUS_SUCCESS) {
6632 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
6633 ioc->name, __FILE__, __LINE__, __func__);
6637 parent_handle = le16_to_cpu(sas_device_pg0.ParentDevHandle);
6638 if (!_scsih_get_sas_address(ioc, parent_handle, &sas_address))
6639 mpt3sas_transport_update_links(ioc, sas_address, handle,
6640 sas_device_pg0.PhyNum, MPI2_SAS_NEG_LINK_RATE_1_5);
6642 _scsih_add_device(ioc, handle, 0, 1);
6646 case MPI2_RAID_PD_STATE_OFFLINE:
6647 case MPI2_RAID_PD_STATE_NOT_CONFIGURED:
6648 case MPI2_RAID_PD_STATE_NOT_COMPATIBLE:
6654 #ifdef CONFIG_SCSI_MPT3SAS_LOGGING
6656 * _scsih_sas_ir_operation_status_event_debug - debug for IR op event
6657 * @ioc: per adapter object
6658 * @event_data: event data payload
6664 _scsih_sas_ir_operation_status_event_debug(struct MPT3SAS_ADAPTER *ioc,
6665 Mpi2EventDataIrOperationStatus_t *event_data)
6667 char *reason_str = NULL;
6669 switch (event_data->RAIDOperation) {
6670 case MPI2_EVENT_IR_RAIDOP_RESYNC:
6671 reason_str = "resync";
6673 case MPI2_EVENT_IR_RAIDOP_ONLINE_CAP_EXPANSION:
6674 reason_str = "online capacity expansion";
6676 case MPI2_EVENT_IR_RAIDOP_CONSISTENCY_CHECK:
6677 reason_str = "consistency check";
6679 case MPI2_EVENT_IR_RAIDOP_BACKGROUND_INIT:
6680 reason_str = "background init";
6682 case MPI2_EVENT_IR_RAIDOP_MAKE_DATA_CONSISTENT:
6683 reason_str = "make data consistent";
6690 pr_info(MPT3SAS_FMT "raid operational status: (%s)" \
6691 "\thandle(0x%04x), percent complete(%d)\n",
6692 ioc->name, reason_str,
6693 le16_to_cpu(event_data->VolDevHandle),
6694 event_data->PercentComplete);
6699 * _scsih_sas_ir_operation_status_event - handle RAID operation events
6700 * @ioc: per adapter object
6701 * @fw_event: The fw_event_work object
6707 _scsih_sas_ir_operation_status_event(struct MPT3SAS_ADAPTER *ioc,
6708 struct fw_event_work *fw_event)
6710 Mpi2EventDataIrOperationStatus_t *event_data =
6711 (Mpi2EventDataIrOperationStatus_t *)
6712 fw_event->event_data;
6713 static struct _raid_device *raid_device;
6714 unsigned long flags;
6717 #ifdef CONFIG_SCSI_MPT3SAS_LOGGING
6718 if (ioc->logging_level & MPT_DEBUG_EVENT_WORK_TASK)
6719 _scsih_sas_ir_operation_status_event_debug(ioc,
6723 /* code added for raid transport support */
6724 if (event_data->RAIDOperation == MPI2_EVENT_IR_RAIDOP_RESYNC) {
6726 spin_lock_irqsave(&ioc->raid_device_lock, flags);
6727 handle = le16_to_cpu(event_data->VolDevHandle);
6728 raid_device = _scsih_raid_device_find_by_handle(ioc, handle);
6730 raid_device->percent_complete =
6731 event_data->PercentComplete;
6732 spin_unlock_irqrestore(&ioc->raid_device_lock, flags);
6737 * _scsih_prep_device_scan - initialize parameters prior to device scan
6738 * @ioc: per adapter object
6740 * Set the deleted flag prior to device scan. If the device is found during
6741 * the scan, then we clear the deleted flag.
6744 _scsih_prep_device_scan(struct MPT3SAS_ADAPTER *ioc)
6746 struct MPT3SAS_DEVICE *sas_device_priv_data;
6747 struct scsi_device *sdev;
6749 shost_for_each_device(sdev, ioc->shost) {
6750 sas_device_priv_data = sdev->hostdata;
6751 if (sas_device_priv_data && sas_device_priv_data->sas_target)
6752 sas_device_priv_data->sas_target->deleted = 1;
6757 * _scsih_mark_responding_sas_device - mark a sas_devices as responding
6758 * @ioc: per adapter object
6759 * @sas_device_pg0: SAS Device page 0
6761 * After host reset, find out whether devices are still responding.
6762 * Used in _scsih_remove_unresponsive_sas_devices.
6767 _scsih_mark_responding_sas_device(struct MPT3SAS_ADAPTER *ioc,
6768 Mpi2SasDevicePage0_t *sas_device_pg0)
6770 struct MPT3SAS_TARGET *sas_target_priv_data = NULL;
6771 struct scsi_target *starget;
6772 struct _sas_device *sas_device;
6773 unsigned long flags;
6775 spin_lock_irqsave(&ioc->sas_device_lock, flags);
6776 list_for_each_entry(sas_device, &ioc->sas_device_list, list) {
6777 if ((sas_device->sas_address == sas_device_pg0->SASAddress) &&
6778 (sas_device->slot == sas_device_pg0->Slot)) {
6779 sas_device->responding = 1;
6780 starget = sas_device->starget;
6781 if (starget && starget->hostdata) {
6782 sas_target_priv_data = starget->hostdata;
6783 sas_target_priv_data->tm_busy = 0;
6784 sas_target_priv_data->deleted = 0;
6786 sas_target_priv_data = NULL;
6788 starget_printk(KERN_INFO, starget,
6789 "handle(0x%04x), sas_addr(0x%016llx)\n",
6790 sas_device_pg0->DevHandle,
6791 (unsigned long long)
6792 sas_device->sas_address);
6794 if (sas_device->enclosure_handle != 0)
6795 starget_printk(KERN_INFO, starget,
6796 "enclosure logical id(0x%016llx),"
6798 (unsigned long long)
6799 sas_device->enclosure_logical_id,
6802 if (sas_device_pg0->Flags &
6803 MPI2_SAS_DEVICE0_FLAGS_ENCL_LEVEL_VALID) {
6804 sas_device->enclosure_level =
6805 le16_to_cpu(sas_device_pg0->EnclosureLevel);
6806 memcpy(&sas_device->connector_name[0],
6807 &sas_device_pg0->ConnectorName[0], 4);
6809 sas_device->enclosure_level = 0;
6810 sas_device->connector_name[0] = '\0';
6813 if (sas_device->handle == sas_device_pg0->DevHandle)
6815 pr_info("\thandle changed from(0x%04x)!!!\n",
6816 sas_device->handle);
6817 sas_device->handle = sas_device_pg0->DevHandle;
6818 if (sas_target_priv_data)
6819 sas_target_priv_data->handle =
6820 sas_device_pg0->DevHandle;
6825 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
6829 * _scsih_search_responding_sas_devices -
6830 * @ioc: per adapter object
6832 * After host reset, find out whether devices are still responding.
6838 _scsih_search_responding_sas_devices(struct MPT3SAS_ADAPTER *ioc)
6840 Mpi2SasDevicePage0_t sas_device_pg0;
6841 Mpi2ConfigReply_t mpi_reply;
6846 pr_info(MPT3SAS_FMT "search for end-devices: start\n", ioc->name);
6848 if (list_empty(&ioc->sas_device_list))
6852 while (!(mpt3sas_config_get_sas_device_pg0(ioc, &mpi_reply,
6853 &sas_device_pg0, MPI2_SAS_DEVICE_PGAD_FORM_GET_NEXT_HANDLE,
6855 ioc_status = le16_to_cpu(mpi_reply.IOCStatus) &
6856 MPI2_IOCSTATUS_MASK;
6857 if (ioc_status != MPI2_IOCSTATUS_SUCCESS)
6859 handle = sas_device_pg0.DevHandle =
6860 le16_to_cpu(sas_device_pg0.DevHandle);
6861 device_info = le32_to_cpu(sas_device_pg0.DeviceInfo);
6862 if (!(_scsih_is_end_device(device_info)))
6864 sas_device_pg0.SASAddress =
6865 le64_to_cpu(sas_device_pg0.SASAddress);
6866 sas_device_pg0.Slot = le16_to_cpu(sas_device_pg0.Slot);
6867 _scsih_mark_responding_sas_device(ioc, &sas_device_pg0);
6871 pr_info(MPT3SAS_FMT "search for end-devices: complete\n",
6876 * _scsih_mark_responding_raid_device - mark a raid_device as responding
6877 * @ioc: per adapter object
6878 * @wwid: world wide identifier for raid volume
6879 * @handle: device handle
6881 * After host reset, find out whether devices are still responding.
6882 * Used in _scsih_remove_unresponsive_raid_devices.
6887 _scsih_mark_responding_raid_device(struct MPT3SAS_ADAPTER *ioc, u64 wwid,
6890 struct MPT3SAS_TARGET *sas_target_priv_data;
6891 struct scsi_target *starget;
6892 struct _raid_device *raid_device;
6893 unsigned long flags;
6895 spin_lock_irqsave(&ioc->raid_device_lock, flags);
6896 list_for_each_entry(raid_device, &ioc->raid_device_list, list) {
6897 if (raid_device->wwid == wwid && raid_device->starget) {
6898 starget = raid_device->starget;
6899 if (starget && starget->hostdata) {
6900 sas_target_priv_data = starget->hostdata;
6901 sas_target_priv_data->deleted = 0;
6903 sas_target_priv_data = NULL;
6904 raid_device->responding = 1;
6905 spin_unlock_irqrestore(&ioc->raid_device_lock, flags);
6906 starget_printk(KERN_INFO, raid_device->starget,
6907 "handle(0x%04x), wwid(0x%016llx)\n", handle,
6908 (unsigned long long)raid_device->wwid);
6909 spin_lock_irqsave(&ioc->raid_device_lock, flags);
6910 if (raid_device->handle == handle) {
6911 spin_unlock_irqrestore(&ioc->raid_device_lock,
6915 pr_info("\thandle changed from(0x%04x)!!!\n",
6916 raid_device->handle);
6917 raid_device->handle = handle;
6918 if (sas_target_priv_data)
6919 sas_target_priv_data->handle = handle;
6920 spin_unlock_irqrestore(&ioc->raid_device_lock, flags);
6924 spin_unlock_irqrestore(&ioc->raid_device_lock, flags);
6928 * _scsih_search_responding_raid_devices -
6929 * @ioc: per adapter object
6931 * After host reset, find out whether devices are still responding.
6937 _scsih_search_responding_raid_devices(struct MPT3SAS_ADAPTER *ioc)
6939 Mpi2RaidVolPage1_t volume_pg1;
6940 Mpi2RaidVolPage0_t volume_pg0;
6941 Mpi2RaidPhysDiskPage0_t pd_pg0;
6942 Mpi2ConfigReply_t mpi_reply;
6947 if (!ioc->ir_firmware)
6950 pr_info(MPT3SAS_FMT "search for raid volumes: start\n",
6953 if (list_empty(&ioc->raid_device_list))
6957 while (!(mpt3sas_config_get_raid_volume_pg1(ioc, &mpi_reply,
6958 &volume_pg1, MPI2_RAID_VOLUME_PGAD_FORM_GET_NEXT_HANDLE, handle))) {
6959 ioc_status = le16_to_cpu(mpi_reply.IOCStatus) &
6960 MPI2_IOCSTATUS_MASK;
6961 if (ioc_status != MPI2_IOCSTATUS_SUCCESS)
6963 handle = le16_to_cpu(volume_pg1.DevHandle);
6965 if (mpt3sas_config_get_raid_volume_pg0(ioc, &mpi_reply,
6966 &volume_pg0, MPI2_RAID_VOLUME_PGAD_FORM_HANDLE, handle,
6967 sizeof(Mpi2RaidVolPage0_t)))
6970 if (volume_pg0.VolumeState == MPI2_RAID_VOL_STATE_OPTIMAL ||
6971 volume_pg0.VolumeState == MPI2_RAID_VOL_STATE_ONLINE ||
6972 volume_pg0.VolumeState == MPI2_RAID_VOL_STATE_DEGRADED)
6973 _scsih_mark_responding_raid_device(ioc,
6974 le64_to_cpu(volume_pg1.WWID), handle);
6977 /* refresh the pd_handles */
6978 phys_disk_num = 0xFF;
6979 memset(ioc->pd_handles, 0, ioc->pd_handles_sz);
6980 while (!(mpt3sas_config_get_phys_disk_pg0(ioc, &mpi_reply,
6981 &pd_pg0, MPI2_PHYSDISK_PGAD_FORM_GET_NEXT_PHYSDISKNUM,
6983 ioc_status = le16_to_cpu(mpi_reply.IOCStatus) &
6984 MPI2_IOCSTATUS_MASK;
6985 if (ioc_status != MPI2_IOCSTATUS_SUCCESS)
6987 phys_disk_num = pd_pg0.PhysDiskNum;
6988 handle = le16_to_cpu(pd_pg0.DevHandle);
6989 set_bit(handle, ioc->pd_handles);
6992 pr_info(MPT3SAS_FMT "search for responding raid volumes: complete\n",
6997 * _scsih_mark_responding_expander - mark a expander as responding
6998 * @ioc: per adapter object
6999 * @sas_address: sas address
7002 * After host reset, find out whether devices are still responding.
7003 * Used in _scsih_remove_unresponsive_expanders.
7008 _scsih_mark_responding_expander(struct MPT3SAS_ADAPTER *ioc, u64 sas_address,
7011 struct _sas_node *sas_expander;
7012 unsigned long flags;
7015 spin_lock_irqsave(&ioc->sas_node_lock, flags);
7016 list_for_each_entry(sas_expander, &ioc->sas_expander_list, list) {
7017 if (sas_expander->sas_address != sas_address)
7019 sas_expander->responding = 1;
7020 if (sas_expander->handle == handle)
7022 pr_info("\texpander(0x%016llx): handle changed" \
7023 " from(0x%04x) to (0x%04x)!!!\n",
7024 (unsigned long long)sas_expander->sas_address,
7025 sas_expander->handle, handle);
7026 sas_expander->handle = handle;
7027 for (i = 0 ; i < sas_expander->num_phys ; i++)
7028 sas_expander->phy[i].handle = handle;
7032 spin_unlock_irqrestore(&ioc->sas_node_lock, flags);
7036 * _scsih_search_responding_expanders -
7037 * @ioc: per adapter object
7039 * After host reset, find out whether devices are still responding.
7045 _scsih_search_responding_expanders(struct MPT3SAS_ADAPTER *ioc)
7047 Mpi2ExpanderPage0_t expander_pg0;
7048 Mpi2ConfigReply_t mpi_reply;
7053 pr_info(MPT3SAS_FMT "search for expanders: start\n", ioc->name);
7055 if (list_empty(&ioc->sas_expander_list))
7059 while (!(mpt3sas_config_get_expander_pg0(ioc, &mpi_reply, &expander_pg0,
7060 MPI2_SAS_EXPAND_PGAD_FORM_GET_NEXT_HNDL, handle))) {
7062 ioc_status = le16_to_cpu(mpi_reply.IOCStatus) &
7063 MPI2_IOCSTATUS_MASK;
7064 if (ioc_status != MPI2_IOCSTATUS_SUCCESS)
7067 handle = le16_to_cpu(expander_pg0.DevHandle);
7068 sas_address = le64_to_cpu(expander_pg0.SASAddress);
7069 pr_info("\texpander present: handle(0x%04x), sas_addr(0x%016llx)\n",
7071 (unsigned long long)sas_address);
7072 _scsih_mark_responding_expander(ioc, sas_address, handle);
7076 pr_info(MPT3SAS_FMT "search for expanders: complete\n", ioc->name);
7080 * _scsih_remove_unresponding_sas_devices - removing unresponding devices
7081 * @ioc: per adapter object
7086 _scsih_remove_unresponding_sas_devices(struct MPT3SAS_ADAPTER *ioc)
7088 struct _sas_device *sas_device, *sas_device_next;
7089 struct _sas_node *sas_expander, *sas_expander_next;
7090 struct _raid_device *raid_device, *raid_device_next;
7091 struct list_head tmp_list;
7092 unsigned long flags;
7095 pr_info(MPT3SAS_FMT "removing unresponding devices: start\n",
7098 /* removing unresponding end devices */
7099 pr_info(MPT3SAS_FMT "removing unresponding devices: end-devices\n",
7103 * Iterate, pulling off devices marked as non-responding. We become the
7104 * owner for the reference the list had on any object we prune.
7106 spin_lock_irqsave(&ioc->sas_device_lock, flags);
7107 list_for_each_entry_safe(sas_device, sas_device_next,
7108 &ioc->sas_device_list, list) {
7109 if (!sas_device->responding)
7110 list_move_tail(&sas_device->list, &head);
7112 sas_device->responding = 0;
7114 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
7117 * Now, uninitialize and remove the unresponding devices we pruned.
7119 list_for_each_entry_safe(sas_device, sas_device_next, &head, list) {
7120 _scsih_remove_device(ioc, sas_device);
7121 list_del_init(&sas_device->list);
7122 sas_device_put(sas_device);
7125 /* removing unresponding volumes */
7126 if (ioc->ir_firmware) {
7127 pr_info(MPT3SAS_FMT "removing unresponding devices: volumes\n",
7129 list_for_each_entry_safe(raid_device, raid_device_next,
7130 &ioc->raid_device_list, list) {
7131 if (!raid_device->responding)
7132 _scsih_sas_volume_delete(ioc,
7133 raid_device->handle);
7135 raid_device->responding = 0;
7139 /* removing unresponding expanders */
7140 pr_info(MPT3SAS_FMT "removing unresponding devices: expanders\n",
7142 spin_lock_irqsave(&ioc->sas_node_lock, flags);
7143 INIT_LIST_HEAD(&tmp_list);
7144 list_for_each_entry_safe(sas_expander, sas_expander_next,
7145 &ioc->sas_expander_list, list) {
7146 if (!sas_expander->responding)
7147 list_move_tail(&sas_expander->list, &tmp_list);
7149 sas_expander->responding = 0;
7151 spin_unlock_irqrestore(&ioc->sas_node_lock, flags);
7152 list_for_each_entry_safe(sas_expander, sas_expander_next, &tmp_list,
7154 list_del(&sas_expander->list);
7155 _scsih_expander_node_remove(ioc, sas_expander);
7158 pr_info(MPT3SAS_FMT "removing unresponding devices: complete\n",
7161 /* unblock devices */
7162 _scsih_ublock_io_all_device(ioc);
7166 _scsih_refresh_expander_links(struct MPT3SAS_ADAPTER *ioc,
7167 struct _sas_node *sas_expander, u16 handle)
7169 Mpi2ExpanderPage1_t expander_pg1;
7170 Mpi2ConfigReply_t mpi_reply;
7173 for (i = 0 ; i < sas_expander->num_phys ; i++) {
7174 if ((mpt3sas_config_get_expander_pg1(ioc, &mpi_reply,
7175 &expander_pg1, i, handle))) {
7176 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
7177 ioc->name, __FILE__, __LINE__, __func__);
7181 mpt3sas_transport_update_links(ioc, sas_expander->sas_address,
7182 le16_to_cpu(expander_pg1.AttachedDevHandle), i,
7183 expander_pg1.NegotiatedLinkRate >> 4);
7188 * _scsih_scan_for_devices_after_reset - scan for devices after host reset
7189 * @ioc: per adapter object
7194 _scsih_scan_for_devices_after_reset(struct MPT3SAS_ADAPTER *ioc)
7196 Mpi2ExpanderPage0_t expander_pg0;
7197 Mpi2SasDevicePage0_t sas_device_pg0;
7198 Mpi2RaidVolPage1_t volume_pg1;
7199 Mpi2RaidVolPage0_t volume_pg0;
7200 Mpi2RaidPhysDiskPage0_t pd_pg0;
7201 Mpi2EventIrConfigElement_t element;
7202 Mpi2ConfigReply_t mpi_reply;
7205 u16 handle, parent_handle;
7207 struct _sas_device *sas_device;
7208 struct _sas_node *expander_device;
7209 static struct _raid_device *raid_device;
7211 unsigned long flags;
7213 pr_info(MPT3SAS_FMT "scan devices: start\n", ioc->name);
7215 _scsih_sas_host_refresh(ioc);
7217 pr_info(MPT3SAS_FMT "\tscan devices: expanders start\n", ioc->name);
7221 while (!(mpt3sas_config_get_expander_pg0(ioc, &mpi_reply, &expander_pg0,
7222 MPI2_SAS_EXPAND_PGAD_FORM_GET_NEXT_HNDL, handle))) {
7223 ioc_status = le16_to_cpu(mpi_reply.IOCStatus) &
7224 MPI2_IOCSTATUS_MASK;
7225 if (ioc_status != MPI2_IOCSTATUS_SUCCESS) {
7226 pr_info(MPT3SAS_FMT "\tbreak from expander scan: " \
7227 "ioc_status(0x%04x), loginfo(0x%08x)\n",
7228 ioc->name, ioc_status,
7229 le32_to_cpu(mpi_reply.IOCLogInfo));
7232 handle = le16_to_cpu(expander_pg0.DevHandle);
7233 spin_lock_irqsave(&ioc->sas_node_lock, flags);
7234 expander_device = mpt3sas_scsih_expander_find_by_sas_address(
7235 ioc, le64_to_cpu(expander_pg0.SASAddress));
7236 spin_unlock_irqrestore(&ioc->sas_node_lock, flags);
7237 if (expander_device)
7238 _scsih_refresh_expander_links(ioc, expander_device,
7241 pr_info(MPT3SAS_FMT "\tBEFORE adding expander: " \
7242 "handle (0x%04x), sas_addr(0x%016llx)\n", ioc->name,
7243 handle, (unsigned long long)
7244 le64_to_cpu(expander_pg0.SASAddress));
7245 _scsih_expander_add(ioc, handle);
7246 pr_info(MPT3SAS_FMT "\tAFTER adding expander: " \
7247 "handle (0x%04x), sas_addr(0x%016llx)\n", ioc->name,
7248 handle, (unsigned long long)
7249 le64_to_cpu(expander_pg0.SASAddress));
7253 pr_info(MPT3SAS_FMT "\tscan devices: expanders complete\n",
7256 if (!ioc->ir_firmware)
7259 pr_info(MPT3SAS_FMT "\tscan devices: phys disk start\n", ioc->name);
7262 phys_disk_num = 0xFF;
7263 while (!(mpt3sas_config_get_phys_disk_pg0(ioc, &mpi_reply,
7264 &pd_pg0, MPI2_PHYSDISK_PGAD_FORM_GET_NEXT_PHYSDISKNUM,
7266 ioc_status = le16_to_cpu(mpi_reply.IOCStatus) &
7267 MPI2_IOCSTATUS_MASK;
7268 if (ioc_status != MPI2_IOCSTATUS_SUCCESS) {
7269 pr_info(MPT3SAS_FMT "\tbreak from phys disk scan: "\
7270 "ioc_status(0x%04x), loginfo(0x%08x)\n",
7271 ioc->name, ioc_status,
7272 le32_to_cpu(mpi_reply.IOCLogInfo));
7275 phys_disk_num = pd_pg0.PhysDiskNum;
7276 handle = le16_to_cpu(pd_pg0.DevHandle);
7277 sas_device = mpt3sas_get_sdev_by_handle(ioc, handle);
7279 sas_device_put(sas_device);
7282 if (mpt3sas_config_get_sas_device_pg0(ioc, &mpi_reply,
7283 &sas_device_pg0, MPI2_SAS_DEVICE_PGAD_FORM_HANDLE,
7286 ioc_status = le16_to_cpu(mpi_reply.IOCStatus) &
7287 MPI2_IOCSTATUS_MASK;
7288 if (ioc_status != MPI2_IOCSTATUS_SUCCESS) {
7289 pr_info(MPT3SAS_FMT "\tbreak from phys disk scan " \
7290 "ioc_status(0x%04x), loginfo(0x%08x)\n",
7291 ioc->name, ioc_status,
7292 le32_to_cpu(mpi_reply.IOCLogInfo));
7295 parent_handle = le16_to_cpu(sas_device_pg0.ParentDevHandle);
7296 if (!_scsih_get_sas_address(ioc, parent_handle,
7298 pr_info(MPT3SAS_FMT "\tBEFORE adding phys disk: " \
7299 " handle (0x%04x), sas_addr(0x%016llx)\n",
7300 ioc->name, handle, (unsigned long long)
7301 le64_to_cpu(sas_device_pg0.SASAddress));
7302 mpt3sas_transport_update_links(ioc, sas_address,
7303 handle, sas_device_pg0.PhyNum,
7304 MPI2_SAS_NEG_LINK_RATE_1_5);
7305 set_bit(handle, ioc->pd_handles);
7307 /* This will retry adding the end device.
7308 * _scsih_add_device() will decide on retries and
7309 * return "1" when it should be retried
7311 while (_scsih_add_device(ioc, handle, retry_count++,
7315 pr_info(MPT3SAS_FMT "\tAFTER adding phys disk: " \
7316 " handle (0x%04x), sas_addr(0x%016llx)\n",
7317 ioc->name, handle, (unsigned long long)
7318 le64_to_cpu(sas_device_pg0.SASAddress));
7322 pr_info(MPT3SAS_FMT "\tscan devices: phys disk complete\n",
7325 pr_info(MPT3SAS_FMT "\tscan devices: volumes start\n", ioc->name);
7329 while (!(mpt3sas_config_get_raid_volume_pg1(ioc, &mpi_reply,
7330 &volume_pg1, MPI2_RAID_VOLUME_PGAD_FORM_GET_NEXT_HANDLE, handle))) {
7331 ioc_status = le16_to_cpu(mpi_reply.IOCStatus) &
7332 MPI2_IOCSTATUS_MASK;
7333 if (ioc_status != MPI2_IOCSTATUS_SUCCESS) {
7334 pr_info(MPT3SAS_FMT "\tbreak from volume scan: " \
7335 "ioc_status(0x%04x), loginfo(0x%08x)\n",
7336 ioc->name, ioc_status,
7337 le32_to_cpu(mpi_reply.IOCLogInfo));
7340 handle = le16_to_cpu(volume_pg1.DevHandle);
7341 spin_lock_irqsave(&ioc->raid_device_lock, flags);
7342 raid_device = _scsih_raid_device_find_by_wwid(ioc,
7343 le64_to_cpu(volume_pg1.WWID));
7344 spin_unlock_irqrestore(&ioc->raid_device_lock, flags);
7347 if (mpt3sas_config_get_raid_volume_pg0(ioc, &mpi_reply,
7348 &volume_pg0, MPI2_RAID_VOLUME_PGAD_FORM_HANDLE, handle,
7349 sizeof(Mpi2RaidVolPage0_t)))
7351 ioc_status = le16_to_cpu(mpi_reply.IOCStatus) &
7352 MPI2_IOCSTATUS_MASK;
7353 if (ioc_status != MPI2_IOCSTATUS_SUCCESS) {
7354 pr_info(MPT3SAS_FMT "\tbreak from volume scan: " \
7355 "ioc_status(0x%04x), loginfo(0x%08x)\n",
7356 ioc->name, ioc_status,
7357 le32_to_cpu(mpi_reply.IOCLogInfo));
7360 if (volume_pg0.VolumeState == MPI2_RAID_VOL_STATE_OPTIMAL ||
7361 volume_pg0.VolumeState == MPI2_RAID_VOL_STATE_ONLINE ||
7362 volume_pg0.VolumeState == MPI2_RAID_VOL_STATE_DEGRADED) {
7363 memset(&element, 0, sizeof(Mpi2EventIrConfigElement_t));
7364 element.ReasonCode = MPI2_EVENT_IR_CHANGE_RC_ADDED;
7365 element.VolDevHandle = volume_pg1.DevHandle;
7367 "\tBEFORE adding volume: handle (0x%04x)\n",
7368 ioc->name, volume_pg1.DevHandle);
7369 _scsih_sas_volume_add(ioc, &element);
7371 "\tAFTER adding volume: handle (0x%04x)\n",
7372 ioc->name, volume_pg1.DevHandle);
7376 pr_info(MPT3SAS_FMT "\tscan devices: volumes complete\n",
7381 pr_info(MPT3SAS_FMT "\tscan devices: end devices start\n",
7386 while (!(mpt3sas_config_get_sas_device_pg0(ioc, &mpi_reply,
7387 &sas_device_pg0, MPI2_SAS_DEVICE_PGAD_FORM_GET_NEXT_HANDLE,
7389 ioc_status = le16_to_cpu(mpi_reply.IOCStatus) &
7390 MPI2_IOCSTATUS_MASK;
7391 if (ioc_status != MPI2_IOCSTATUS_SUCCESS) {
7392 pr_info(MPT3SAS_FMT "\tbreak from end device scan:"\
7393 " ioc_status(0x%04x), loginfo(0x%08x)\n",
7394 ioc->name, ioc_status,
7395 le32_to_cpu(mpi_reply.IOCLogInfo));
7398 handle = le16_to_cpu(sas_device_pg0.DevHandle);
7399 if (!(_scsih_is_end_device(
7400 le32_to_cpu(sas_device_pg0.DeviceInfo))))
7402 sas_device = mpt3sas_get_sdev_by_addr(ioc,
7403 le64_to_cpu(sas_device_pg0.SASAddress));
7405 sas_device_put(sas_device);
7408 parent_handle = le16_to_cpu(sas_device_pg0.ParentDevHandle);
7409 if (!_scsih_get_sas_address(ioc, parent_handle, &sas_address)) {
7410 pr_info(MPT3SAS_FMT "\tBEFORE adding end device: " \
7411 "handle (0x%04x), sas_addr(0x%016llx)\n", ioc->name,
7412 handle, (unsigned long long)
7413 le64_to_cpu(sas_device_pg0.SASAddress));
7414 mpt3sas_transport_update_links(ioc, sas_address, handle,
7415 sas_device_pg0.PhyNum, MPI2_SAS_NEG_LINK_RATE_1_5);
7417 /* This will retry adding the end device.
7418 * _scsih_add_device() will decide on retries and
7419 * return "1" when it should be retried
7421 while (_scsih_add_device(ioc, handle, retry_count++,
7425 pr_info(MPT3SAS_FMT "\tAFTER adding end device: " \
7426 "handle (0x%04x), sas_addr(0x%016llx)\n", ioc->name,
7427 handle, (unsigned long long)
7428 le64_to_cpu(sas_device_pg0.SASAddress));
7431 pr_info(MPT3SAS_FMT "\tscan devices: end devices complete\n",
7434 pr_info(MPT3SAS_FMT "scan devices: complete\n", ioc->name);
7437 * mpt3sas_scsih_reset_handler - reset callback handler (for scsih)
7438 * @ioc: per adapter object
7439 * @reset_phase: phase
7441 * The handler for doing any required cleanup or initialization.
7443 * The reset phase can be MPT3_IOC_PRE_RESET, MPT3_IOC_AFTER_RESET,
7444 * MPT3_IOC_DONE_RESET
7449 mpt3sas_scsih_reset_handler(struct MPT3SAS_ADAPTER *ioc, int reset_phase)
7451 switch (reset_phase) {
7452 case MPT3_IOC_PRE_RESET:
7453 dtmprintk(ioc, pr_info(MPT3SAS_FMT
7454 "%s: MPT3_IOC_PRE_RESET\n", ioc->name, __func__));
7456 case MPT3_IOC_AFTER_RESET:
7457 dtmprintk(ioc, pr_info(MPT3SAS_FMT
7458 "%s: MPT3_IOC_AFTER_RESET\n", ioc->name, __func__));
7459 if (ioc->scsih_cmds.status & MPT3_CMD_PENDING) {
7460 ioc->scsih_cmds.status |= MPT3_CMD_RESET;
7461 mpt3sas_base_free_smid(ioc, ioc->scsih_cmds.smid);
7462 complete(&ioc->scsih_cmds.done);
7464 if (ioc->tm_cmds.status & MPT3_CMD_PENDING) {
7465 ioc->tm_cmds.status |= MPT3_CMD_RESET;
7466 mpt3sas_base_free_smid(ioc, ioc->tm_cmds.smid);
7467 complete(&ioc->tm_cmds.done);
7470 _scsih_fw_event_cleanup_queue(ioc);
7471 _scsih_flush_running_cmds(ioc);
7473 case MPT3_IOC_DONE_RESET:
7474 dtmprintk(ioc, pr_info(MPT3SAS_FMT
7475 "%s: MPT3_IOC_DONE_RESET\n", ioc->name, __func__));
7476 if ((!ioc->is_driver_loading) && !(disable_discovery > 0 &&
7477 !ioc->sas_hba.num_phys)) {
7478 _scsih_prep_device_scan(ioc);
7479 _scsih_search_responding_sas_devices(ioc);
7480 _scsih_search_responding_raid_devices(ioc);
7481 _scsih_search_responding_expanders(ioc);
7482 _scsih_error_recovery_delete_devices(ioc);
7489 * _mpt3sas_fw_work - delayed task for processing firmware events
7490 * @ioc: per adapter object
7491 * @fw_event: The fw_event_work object
7497 _mpt3sas_fw_work(struct MPT3SAS_ADAPTER *ioc, struct fw_event_work *fw_event)
7499 _scsih_fw_event_del_from_list(ioc, fw_event);
7501 /* the queue is being flushed so ignore this event */
7502 if (ioc->remove_host || ioc->pci_error_recovery) {
7503 fw_event_work_put(fw_event);
7507 switch (fw_event->event) {
7508 case MPT3SAS_PROCESS_TRIGGER_DIAG:
7509 mpt3sas_process_trigger_data(ioc,
7510 (struct SL_WH_TRIGGERS_EVENT_DATA_T *)
7511 fw_event->event_data);
7513 case MPT3SAS_REMOVE_UNRESPONDING_DEVICES:
7514 while (scsi_host_in_recovery(ioc->shost) ||
7515 ioc->shost_recovery) {
7517 * If we're unloading, bail. Otherwise, this can become
7520 if (ioc->remove_host)
7525 _scsih_remove_unresponding_sas_devices(ioc);
7526 _scsih_scan_for_devices_after_reset(ioc);
7528 case MPT3SAS_PORT_ENABLE_COMPLETE:
7529 ioc->start_scan = 0;
7530 if (missing_delay[0] != -1 && missing_delay[1] != -1)
7531 mpt3sas_base_update_missing_delay(ioc, missing_delay[0],
7533 dewtprintk(ioc, pr_info(MPT3SAS_FMT
7534 "port enable: complete from worker thread\n",
7537 case MPT3SAS_TURN_ON_PFA_LED:
7538 _scsih_turn_on_pfa_led(ioc, fw_event->device_handle);
7540 case MPI2_EVENT_SAS_TOPOLOGY_CHANGE_LIST:
7541 _scsih_sas_topology_change_event(ioc, fw_event);
7543 case MPI2_EVENT_SAS_DEVICE_STATUS_CHANGE:
7544 _scsih_sas_device_status_change_event(ioc, fw_event);
7546 case MPI2_EVENT_SAS_DISCOVERY:
7547 _scsih_sas_discovery_event(ioc, fw_event);
7549 case MPI2_EVENT_SAS_BROADCAST_PRIMITIVE:
7550 _scsih_sas_broadcast_primitive_event(ioc, fw_event);
7552 case MPI2_EVENT_SAS_ENCL_DEVICE_STATUS_CHANGE:
7553 _scsih_sas_enclosure_dev_status_change_event(ioc,
7556 case MPI2_EVENT_IR_CONFIGURATION_CHANGE_LIST:
7557 _scsih_sas_ir_config_change_event(ioc, fw_event);
7559 case MPI2_EVENT_IR_VOLUME:
7560 _scsih_sas_ir_volume_event(ioc, fw_event);
7562 case MPI2_EVENT_IR_PHYSICAL_DISK:
7563 _scsih_sas_ir_physical_disk_event(ioc, fw_event);
7565 case MPI2_EVENT_IR_OPERATION_STATUS:
7566 _scsih_sas_ir_operation_status_event(ioc, fw_event);
7570 fw_event_work_put(fw_event);
7574 * _firmware_event_work
7575 * @ioc: per adapter object
7576 * @work: The fw_event_work object
7579 * wrappers for the work thread handling firmware events
7585 _firmware_event_work(struct work_struct *work)
7587 struct fw_event_work *fw_event = container_of(work,
7588 struct fw_event_work, work);
7590 _mpt3sas_fw_work(fw_event->ioc, fw_event);
7594 * mpt3sas_scsih_event_callback - firmware event handler (called at ISR time)
7595 * @ioc: per adapter object
7596 * @msix_index: MSIX table index supplied by the OS
7597 * @reply: reply message frame(lower 32bit addr)
7598 * Context: interrupt.
7600 * This function merely adds a new work task into ioc->firmware_event_thread.
7601 * The tasks are worked from _firmware_event_work in user context.
7603 * Return 1 meaning mf should be freed from _base_interrupt
7604 * 0 means the mf is freed from this function.
7607 mpt3sas_scsih_event_callback(struct MPT3SAS_ADAPTER *ioc, u8 msix_index,
7610 struct fw_event_work *fw_event;
7611 Mpi2EventNotificationReply_t *mpi_reply;
7615 /* events turned off due to host reset or driver unloading */
7616 if (ioc->remove_host || ioc->pci_error_recovery)
7619 mpi_reply = mpt3sas_base_get_reply_virt_addr(ioc, reply);
7621 if (unlikely(!mpi_reply)) {
7622 pr_err(MPT3SAS_FMT "mpi_reply not valid at %s:%d/%s()!\n",
7623 ioc->name, __FILE__, __LINE__, __func__);
7627 event = le16_to_cpu(mpi_reply->Event);
7629 if (event != MPI2_EVENT_LOG_ENTRY_ADDED)
7630 mpt3sas_trigger_event(ioc, event, 0);
7634 case MPI2_EVENT_SAS_BROADCAST_PRIMITIVE:
7636 Mpi2EventDataSasBroadcastPrimitive_t *baen_data =
7637 (Mpi2EventDataSasBroadcastPrimitive_t *)
7638 mpi_reply->EventData;
7640 if (baen_data->Primitive !=
7641 MPI2_EVENT_PRIMITIVE_ASYNCHRONOUS_EVENT)
7644 if (ioc->broadcast_aen_busy) {
7645 ioc->broadcast_aen_pending++;
7648 ioc->broadcast_aen_busy = 1;
7652 case MPI2_EVENT_SAS_TOPOLOGY_CHANGE_LIST:
7653 _scsih_check_topo_delete_events(ioc,
7654 (Mpi2EventDataSasTopologyChangeList_t *)
7655 mpi_reply->EventData);
7657 case MPI2_EVENT_IR_CONFIGURATION_CHANGE_LIST:
7658 _scsih_check_ir_config_unhide_events(ioc,
7659 (Mpi2EventDataIrConfigChangeList_t *)
7660 mpi_reply->EventData);
7662 case MPI2_EVENT_IR_VOLUME:
7663 _scsih_check_volume_delete_events(ioc,
7664 (Mpi2EventDataIrVolume_t *)
7665 mpi_reply->EventData);
7668 case MPI2_EVENT_SAS_DEVICE_STATUS_CHANGE:
7669 case MPI2_EVENT_IR_OPERATION_STATUS:
7670 case MPI2_EVENT_SAS_DISCOVERY:
7671 case MPI2_EVENT_SAS_ENCL_DEVICE_STATUS_CHANGE:
7672 case MPI2_EVENT_IR_PHYSICAL_DISK:
7675 case MPI2_EVENT_TEMP_THRESHOLD:
7676 _scsih_temp_threshold_events(ioc,
7677 (Mpi2EventDataTemperature_t *)
7678 mpi_reply->EventData);
7681 default: /* ignore the rest */
7685 sz = le16_to_cpu(mpi_reply->EventDataLength) * 4;
7686 fw_event = alloc_fw_event_work(sz);
7688 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
7689 ioc->name, __FILE__, __LINE__, __func__);
7693 memcpy(fw_event->event_data, mpi_reply->EventData, sz);
7694 fw_event->ioc = ioc;
7695 fw_event->VF_ID = mpi_reply->VF_ID;
7696 fw_event->VP_ID = mpi_reply->VP_ID;
7697 fw_event->event = event;
7698 _scsih_fw_event_add(ioc, fw_event);
7699 fw_event_work_put(fw_event);
7703 /* shost template */
7704 static struct scsi_host_template scsih_driver_template = {
7705 .module = THIS_MODULE,
7706 .name = "Fusion MPT SAS Host",
7707 .proc_name = MPT3SAS_DRIVER_NAME,
7708 .queuecommand = _scsih_qcmd,
7709 .target_alloc = _scsih_target_alloc,
7710 .slave_alloc = _scsih_slave_alloc,
7711 .slave_configure = _scsih_slave_configure,
7712 .target_destroy = _scsih_target_destroy,
7713 .slave_destroy = _scsih_slave_destroy,
7714 .scan_finished = _scsih_scan_finished,
7715 .scan_start = _scsih_scan_start,
7716 .change_queue_depth = _scsih_change_queue_depth,
7717 .eh_abort_handler = _scsih_abort,
7718 .eh_device_reset_handler = _scsih_dev_reset,
7719 .eh_target_reset_handler = _scsih_target_reset,
7720 .eh_host_reset_handler = _scsih_host_reset,
7721 .bios_param = _scsih_bios_param,
7724 .sg_tablesize = MPT3SAS_SG_DEPTH,
7725 .max_sectors = 32767,
7727 .use_clustering = ENABLE_CLUSTERING,
7728 .shost_attrs = mpt3sas_host_attrs,
7729 .sdev_attrs = mpt3sas_dev_attrs,
7730 .track_queue_depth = 1,
7734 * _scsih_expander_node_remove - removing expander device from list.
7735 * @ioc: per adapter object
7736 * @sas_expander: the sas_device object
7737 * Context: Calling function should acquire ioc->sas_node_lock.
7739 * Removing object and freeing associated memory from the
7740 * ioc->sas_expander_list.
7745 _scsih_expander_node_remove(struct MPT3SAS_ADAPTER *ioc,
7746 struct _sas_node *sas_expander)
7748 struct _sas_port *mpt3sas_port, *next;
7750 /* remove sibling ports attached to this expander */
7751 list_for_each_entry_safe(mpt3sas_port, next,
7752 &sas_expander->sas_port_list, port_list) {
7753 if (ioc->shost_recovery)
7755 if (mpt3sas_port->remote_identify.device_type ==
7757 mpt3sas_device_remove_by_sas_address(ioc,
7758 mpt3sas_port->remote_identify.sas_address);
7759 else if (mpt3sas_port->remote_identify.device_type ==
7760 SAS_EDGE_EXPANDER_DEVICE ||
7761 mpt3sas_port->remote_identify.device_type ==
7762 SAS_FANOUT_EXPANDER_DEVICE)
7763 mpt3sas_expander_remove(ioc,
7764 mpt3sas_port->remote_identify.sas_address);
7767 mpt3sas_transport_port_remove(ioc, sas_expander->sas_address,
7768 sas_expander->sas_address_parent);
7771 "expander_remove: handle(0x%04x), sas_addr(0x%016llx)\n",
7773 sas_expander->handle, (unsigned long long)
7774 sas_expander->sas_address);
7776 kfree(sas_expander->phy);
7777 kfree(sas_expander);
7781 * _scsih_ir_shutdown - IR shutdown notification
7782 * @ioc: per adapter object
7784 * Sending RAID Action to alert the Integrated RAID subsystem of the IOC that
7785 * the host system is shutting down.
7790 _scsih_ir_shutdown(struct MPT3SAS_ADAPTER *ioc)
7792 Mpi2RaidActionRequest_t *mpi_request;
7793 Mpi2RaidActionReply_t *mpi_reply;
7796 /* is IR firmware build loaded ? */
7797 if (!ioc->ir_firmware)
7800 /* are there any volumes ? */
7801 if (list_empty(&ioc->raid_device_list))
7804 mutex_lock(&ioc->scsih_cmds.mutex);
7806 if (ioc->scsih_cmds.status != MPT3_CMD_NOT_USED) {
7807 pr_err(MPT3SAS_FMT "%s: scsih_cmd in use\n",
7808 ioc->name, __func__);
7811 ioc->scsih_cmds.status = MPT3_CMD_PENDING;
7813 smid = mpt3sas_base_get_smid(ioc, ioc->scsih_cb_idx);
7815 pr_err(MPT3SAS_FMT "%s: failed obtaining a smid\n",
7816 ioc->name, __func__);
7817 ioc->scsih_cmds.status = MPT3_CMD_NOT_USED;
7821 mpi_request = mpt3sas_base_get_msg_frame(ioc, smid);
7822 ioc->scsih_cmds.smid = smid;
7823 memset(mpi_request, 0, sizeof(Mpi2RaidActionRequest_t));
7825 mpi_request->Function = MPI2_FUNCTION_RAID_ACTION;
7826 mpi_request->Action = MPI2_RAID_ACTION_SYSTEM_SHUTDOWN_INITIATED;
7828 pr_info(MPT3SAS_FMT "IR shutdown (sending)\n", ioc->name);
7829 init_completion(&ioc->scsih_cmds.done);
7830 mpt3sas_base_put_smid_default(ioc, smid);
7831 wait_for_completion_timeout(&ioc->scsih_cmds.done, 10*HZ);
7833 if (!(ioc->scsih_cmds.status & MPT3_CMD_COMPLETE)) {
7834 pr_err(MPT3SAS_FMT "%s: timeout\n",
7835 ioc->name, __func__);
7839 if (ioc->scsih_cmds.status & MPT3_CMD_REPLY_VALID) {
7840 mpi_reply = ioc->scsih_cmds.reply;
7842 "IR shutdown (complete): ioc_status(0x%04x), loginfo(0x%08x)\n",
7843 ioc->name, le16_to_cpu(mpi_reply->IOCStatus),
7844 le32_to_cpu(mpi_reply->IOCLogInfo));
7848 ioc->scsih_cmds.status = MPT3_CMD_NOT_USED;
7849 mutex_unlock(&ioc->scsih_cmds.mutex);
7853 * _scsih_remove - detach and remove add host
7854 * @pdev: PCI device struct
7856 * Routine called when unloading the driver.
7859 static void _scsih_remove(struct pci_dev *pdev)
7861 struct Scsi_Host *shost = pci_get_drvdata(pdev);
7862 struct MPT3SAS_ADAPTER *ioc = shost_priv(shost);
7863 struct _sas_port *mpt3sas_port, *next_port;
7864 struct _raid_device *raid_device, *next;
7865 struct MPT3SAS_TARGET *sas_target_priv_data;
7866 struct workqueue_struct *wq;
7867 unsigned long flags;
7869 ioc->remove_host = 1;
7870 _scsih_fw_event_cleanup_queue(ioc);
7872 spin_lock_irqsave(&ioc->fw_event_lock, flags);
7873 wq = ioc->firmware_event_thread;
7874 ioc->firmware_event_thread = NULL;
7875 spin_unlock_irqrestore(&ioc->fw_event_lock, flags);
7877 destroy_workqueue(wq);
7879 /* release all the volumes */
7880 _scsih_ir_shutdown(ioc);
7881 list_for_each_entry_safe(raid_device, next, &ioc->raid_device_list,
7883 if (raid_device->starget) {
7884 sas_target_priv_data =
7885 raid_device->starget->hostdata;
7886 sas_target_priv_data->deleted = 1;
7887 scsi_remove_target(&raid_device->starget->dev);
7889 pr_info(MPT3SAS_FMT "removing handle(0x%04x), wwid(0x%016llx)\n",
7890 ioc->name, raid_device->handle,
7891 (unsigned long long) raid_device->wwid);
7892 _scsih_raid_device_remove(ioc, raid_device);
7895 /* free ports attached to the sas_host */
7896 list_for_each_entry_safe(mpt3sas_port, next_port,
7897 &ioc->sas_hba.sas_port_list, port_list) {
7898 if (mpt3sas_port->remote_identify.device_type ==
7900 mpt3sas_device_remove_by_sas_address(ioc,
7901 mpt3sas_port->remote_identify.sas_address);
7902 else if (mpt3sas_port->remote_identify.device_type ==
7903 SAS_EDGE_EXPANDER_DEVICE ||
7904 mpt3sas_port->remote_identify.device_type ==
7905 SAS_FANOUT_EXPANDER_DEVICE)
7906 mpt3sas_expander_remove(ioc,
7907 mpt3sas_port->remote_identify.sas_address);
7910 /* free phys attached to the sas_host */
7911 if (ioc->sas_hba.num_phys) {
7912 kfree(ioc->sas_hba.phy);
7913 ioc->sas_hba.phy = NULL;
7914 ioc->sas_hba.num_phys = 0;
7917 sas_remove_host(shost);
7918 scsi_remove_host(shost);
7919 mpt3sas_base_detach(ioc);
7920 list_del(&ioc->list);
7921 scsi_host_put(shost);
7925 * _scsih_shutdown - routine call during system shutdown
7926 * @pdev: PCI device struct
7931 _scsih_shutdown(struct pci_dev *pdev)
7933 struct Scsi_Host *shost = pci_get_drvdata(pdev);
7934 struct MPT3SAS_ADAPTER *ioc = shost_priv(shost);
7935 struct workqueue_struct *wq;
7936 unsigned long flags;
7938 ioc->remove_host = 1;
7939 _scsih_fw_event_cleanup_queue(ioc);
7941 spin_lock_irqsave(&ioc->fw_event_lock, flags);
7942 wq = ioc->firmware_event_thread;
7943 ioc->firmware_event_thread = NULL;
7944 spin_unlock_irqrestore(&ioc->fw_event_lock, flags);
7946 destroy_workqueue(wq);
7948 _scsih_ir_shutdown(ioc);
7949 mpt3sas_base_detach(ioc);
7954 * _scsih_probe_boot_devices - reports 1st device
7955 * @ioc: per adapter object
7957 * If specified in bios page 2, this routine reports the 1st
7958 * device scsi-ml or sas transport for persistent boot device
7959 * purposes. Please refer to function _scsih_determine_boot_device()
7962 _scsih_probe_boot_devices(struct MPT3SAS_ADAPTER *ioc)
7966 struct _sas_device *sas_device;
7967 struct _raid_device *raid_device;
7969 u64 sas_address_parent;
7971 unsigned long flags;
7974 /* no Bios, return immediately */
7975 if (!ioc->bios_pg3.BiosVersion)
7980 if (ioc->req_boot_device.device) {
7981 device = ioc->req_boot_device.device;
7982 is_raid = ioc->req_boot_device.is_raid;
7983 } else if (ioc->req_alt_boot_device.device) {
7984 device = ioc->req_alt_boot_device.device;
7985 is_raid = ioc->req_alt_boot_device.is_raid;
7986 } else if (ioc->current_boot_device.device) {
7987 device = ioc->current_boot_device.device;
7988 is_raid = ioc->current_boot_device.is_raid;
7995 raid_device = device;
7996 rc = scsi_add_device(ioc->shost, RAID_CHANNEL,
7997 raid_device->id, 0);
7999 _scsih_raid_device_remove(ioc, raid_device);
8001 spin_lock_irqsave(&ioc->sas_device_lock, flags);
8002 sas_device = device;
8003 handle = sas_device->handle;
8004 sas_address_parent = sas_device->sas_address_parent;
8005 sas_address = sas_device->sas_address;
8006 list_move_tail(&sas_device->list, &ioc->sas_device_list);
8007 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
8009 if (!mpt3sas_transport_port_add(ioc, handle,
8010 sas_address_parent)) {
8011 _scsih_sas_device_remove(ioc, sas_device);
8012 } else if (!sas_device->starget) {
8013 if (!ioc->is_driver_loading) {
8014 mpt3sas_transport_port_remove(ioc,
8016 sas_address_parent);
8017 _scsih_sas_device_remove(ioc, sas_device);
8024 * _scsih_probe_raid - reporting raid volumes to scsi-ml
8025 * @ioc: per adapter object
8027 * Called during initial loading of the driver.
8030 _scsih_probe_raid(struct MPT3SAS_ADAPTER *ioc)
8032 struct _raid_device *raid_device, *raid_next;
8035 list_for_each_entry_safe(raid_device, raid_next,
8036 &ioc->raid_device_list, list) {
8037 if (raid_device->starget)
8039 rc = scsi_add_device(ioc->shost, RAID_CHANNEL,
8040 raid_device->id, 0);
8042 _scsih_raid_device_remove(ioc, raid_device);
8046 static struct _sas_device *get_next_sas_device(struct MPT3SAS_ADAPTER *ioc)
8048 struct _sas_device *sas_device = NULL;
8049 unsigned long flags;
8051 spin_lock_irqsave(&ioc->sas_device_lock, flags);
8052 if (!list_empty(&ioc->sas_device_init_list)) {
8053 sas_device = list_first_entry(&ioc->sas_device_init_list,
8054 struct _sas_device, list);
8055 sas_device_get(sas_device);
8057 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
8062 static void sas_device_make_active(struct MPT3SAS_ADAPTER *ioc,
8063 struct _sas_device *sas_device)
8065 unsigned long flags;
8067 spin_lock_irqsave(&ioc->sas_device_lock, flags);
8070 * Since we dropped the lock during the call to port_add(), we need to
8071 * be careful here that somebody else didn't move or delete this item
8072 * while we were busy with other things.
8074 * If it was on the list, we need a put() for the reference the list
8075 * had. Either way, we need a get() for the destination list.
8077 if (!list_empty(&sas_device->list)) {
8078 list_del_init(&sas_device->list);
8079 sas_device_put(sas_device);
8082 sas_device_get(sas_device);
8083 list_add_tail(&sas_device->list, &ioc->sas_device_list);
8085 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
8089 * _scsih_probe_sas - reporting sas devices to sas transport
8090 * @ioc: per adapter object
8092 * Called during initial loading of the driver.
8095 _scsih_probe_sas(struct MPT3SAS_ADAPTER *ioc)
8097 struct _sas_device *sas_device;
8099 while ((sas_device = get_next_sas_device(ioc))) {
8100 if (!mpt3sas_transport_port_add(ioc, sas_device->handle,
8101 sas_device->sas_address_parent)) {
8102 _scsih_sas_device_remove(ioc, sas_device);
8103 sas_device_put(sas_device);
8105 } else if (!sas_device->starget) {
8107 * When asyn scanning is enabled, its not possible to
8108 * remove devices while scanning is turned on due to an
8109 * oops in scsi_sysfs_add_sdev()->add_device()->
8110 * sysfs_addrm_start()
8112 if (!ioc->is_driver_loading) {
8113 mpt3sas_transport_port_remove(ioc,
8114 sas_device->sas_address,
8115 sas_device->sas_address_parent);
8116 _scsih_sas_device_remove(ioc, sas_device);
8117 sas_device_put(sas_device);
8122 sas_device_make_active(ioc, sas_device);
8123 sas_device_put(sas_device);
8128 * _scsih_probe_devices - probing for devices
8129 * @ioc: per adapter object
8131 * Called during initial loading of the driver.
8134 _scsih_probe_devices(struct MPT3SAS_ADAPTER *ioc)
8136 u16 volume_mapping_flags;
8138 if (!(ioc->facts.ProtocolFlags & MPI2_IOCFACTS_PROTOCOL_SCSI_INITIATOR))
8139 return; /* return when IOC doesn't support initiator mode */
8141 _scsih_probe_boot_devices(ioc);
8143 if (ioc->ir_firmware) {
8144 volume_mapping_flags =
8145 le16_to_cpu(ioc->ioc_pg8.IRVolumeMappingFlags) &
8146 MPI2_IOCPAGE8_IRFLAGS_MASK_VOLUME_MAPPING_MODE;
8147 if (volume_mapping_flags ==
8148 MPI2_IOCPAGE8_IRFLAGS_LOW_VOLUME_MAPPING) {
8149 _scsih_probe_raid(ioc);
8150 _scsih_probe_sas(ioc);
8152 _scsih_probe_sas(ioc);
8153 _scsih_probe_raid(ioc);
8156 _scsih_probe_sas(ioc);
8160 * _scsih_scan_start - scsi lld callback for .scan_start
8161 * @shost: SCSI host pointer
8163 * The shost has the ability to discover targets on its own instead
8164 * of scanning the entire bus. In our implemention, we will kick off
8165 * firmware discovery.
8168 _scsih_scan_start(struct Scsi_Host *shost)
8170 struct MPT3SAS_ADAPTER *ioc = shost_priv(shost);
8172 if (diag_buffer_enable != -1 && diag_buffer_enable != 0)
8173 mpt3sas_enable_diag_buffer(ioc, diag_buffer_enable);
8175 if (disable_discovery > 0)
8178 ioc->start_scan = 1;
8179 rc = mpt3sas_port_enable(ioc);
8182 pr_info(MPT3SAS_FMT "port enable: FAILED\n", ioc->name);
8186 * _scsih_scan_finished - scsi lld callback for .scan_finished
8187 * @shost: SCSI host pointer
8188 * @time: elapsed time of the scan in jiffies
8190 * This function will be called periodicallyn until it returns 1 with the
8191 * scsi_host and the elapsed time of the scan in jiffies. In our implemention,
8192 * we wait for firmware discovery to complete, then return 1.
8195 _scsih_scan_finished(struct Scsi_Host *shost, unsigned long time)
8197 struct MPT3SAS_ADAPTER *ioc = shost_priv(shost);
8199 if (disable_discovery > 0) {
8200 ioc->is_driver_loading = 0;
8201 ioc->wait_for_discovery_to_complete = 0;
8205 if (time >= (300 * HZ)) {
8206 ioc->base_cmds.status = MPT3_CMD_NOT_USED;
8208 "port enable: FAILED with timeout (timeout=300s)\n",
8210 ioc->is_driver_loading = 0;
8214 if (ioc->start_scan)
8217 if (ioc->start_scan_failed) {
8219 "port enable: FAILED with (ioc_status=0x%08x)\n",
8220 ioc->name, ioc->start_scan_failed);
8221 ioc->is_driver_loading = 0;
8222 ioc->wait_for_discovery_to_complete = 0;
8223 ioc->remove_host = 1;
8227 pr_info(MPT3SAS_FMT "port enable: SUCCESS\n", ioc->name);
8228 ioc->base_cmds.status = MPT3_CMD_NOT_USED;
8230 if (ioc->wait_for_discovery_to_complete) {
8231 ioc->wait_for_discovery_to_complete = 0;
8232 _scsih_probe_devices(ioc);
8234 mpt3sas_base_start_watchdog(ioc);
8235 ioc->is_driver_loading = 0;
8240 * _scsih_probe - attach and add scsi host
8241 * @pdev: PCI device struct
8242 * @id: pci device id
8244 * Returns 0 success, anything else error.
8247 _scsih_probe(struct pci_dev *pdev, const struct pci_device_id *id)
8249 struct MPT3SAS_ADAPTER *ioc;
8250 struct Scsi_Host *shost;
8253 shost = scsi_host_alloc(&scsih_driver_template,
8254 sizeof(struct MPT3SAS_ADAPTER));
8258 /* init local params */
8259 ioc = shost_priv(shost);
8260 memset(ioc, 0, sizeof(struct MPT3SAS_ADAPTER));
8261 INIT_LIST_HEAD(&ioc->list);
8262 list_add_tail(&ioc->list, &mpt3sas_ioc_list);
8264 ioc->id = mpt_ids++;
8265 sprintf(ioc->name, "%s%d", MPT3SAS_DRIVER_NAME, ioc->id);
8267 ioc->scsi_io_cb_idx = scsi_io_cb_idx;
8268 ioc->tm_cb_idx = tm_cb_idx;
8269 ioc->ctl_cb_idx = ctl_cb_idx;
8270 ioc->base_cb_idx = base_cb_idx;
8271 ioc->port_enable_cb_idx = port_enable_cb_idx;
8272 ioc->transport_cb_idx = transport_cb_idx;
8273 ioc->scsih_cb_idx = scsih_cb_idx;
8274 ioc->config_cb_idx = config_cb_idx;
8275 ioc->tm_tr_cb_idx = tm_tr_cb_idx;
8276 ioc->tm_tr_volume_cb_idx = tm_tr_volume_cb_idx;
8277 ioc->tm_sas_control_cb_idx = tm_sas_control_cb_idx;
8278 ioc->logging_level = logging_level;
8279 ioc->schedule_dead_ioc_flush_running_cmds = &_scsih_flush_running_cmds;
8280 /* misc semaphores and spin locks */
8281 mutex_init(&ioc->reset_in_progress_mutex);
8282 spin_lock_init(&ioc->ioc_reset_in_progress_lock);
8283 spin_lock_init(&ioc->scsi_lookup_lock);
8284 spin_lock_init(&ioc->sas_device_lock);
8285 spin_lock_init(&ioc->sas_node_lock);
8286 spin_lock_init(&ioc->fw_event_lock);
8287 spin_lock_init(&ioc->raid_device_lock);
8288 spin_lock_init(&ioc->diag_trigger_lock);
8290 INIT_LIST_HEAD(&ioc->sas_device_list);
8291 INIT_LIST_HEAD(&ioc->sas_device_init_list);
8292 INIT_LIST_HEAD(&ioc->sas_expander_list);
8293 INIT_LIST_HEAD(&ioc->fw_event_list);
8294 INIT_LIST_HEAD(&ioc->raid_device_list);
8295 INIT_LIST_HEAD(&ioc->sas_hba.sas_port_list);
8296 INIT_LIST_HEAD(&ioc->delayed_tr_list);
8297 INIT_LIST_HEAD(&ioc->delayed_tr_volume_list);
8298 INIT_LIST_HEAD(&ioc->reply_queue_list);
8300 /* init shost parameters */
8301 shost->max_cmd_len = 32;
8302 shost->max_lun = max_lun;
8303 shost->transportt = mpt3sas_transport_template;
8304 shost->unique_id = ioc->id;
8306 if (max_sectors != 0xFFFF) {
8307 if (max_sectors < 64) {
8308 shost->max_sectors = 64;
8309 pr_warn(MPT3SAS_FMT "Invalid value %d passed " \
8310 "for max_sectors, range is 64 to 32767. Assigning "
8311 "value of 64.\n", ioc->name, max_sectors);
8312 } else if (max_sectors > 32767) {
8313 shost->max_sectors = 32767;
8314 pr_warn(MPT3SAS_FMT "Invalid value %d passed " \
8315 "for max_sectors, range is 64 to 32767. Assigning "
8316 "default value of 32767.\n", ioc->name,
8319 shost->max_sectors = max_sectors & 0xFFFE;
8321 "The max_sectors value is set to %d\n",
8322 ioc->name, shost->max_sectors);
8326 /* register EEDP capabilities with SCSI layer */
8328 scsi_host_set_prot(shost, prot_mask);
8330 scsi_host_set_prot(shost, SHOST_DIF_TYPE1_PROTECTION
8331 | SHOST_DIF_TYPE2_PROTECTION
8332 | SHOST_DIF_TYPE3_PROTECTION);
8334 scsi_host_set_guard(shost, SHOST_DIX_GUARD_CRC);
8337 snprintf(ioc->firmware_event_name, sizeof(ioc->firmware_event_name),
8338 "fw_event%d", ioc->id);
8339 ioc->firmware_event_thread = alloc_ordered_workqueue(
8340 ioc->firmware_event_name, WQ_MEM_RECLAIM);
8341 if (!ioc->firmware_event_thread) {
8342 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
8343 ioc->name, __FILE__, __LINE__, __func__);
8345 goto out_thread_fail;
8348 ioc->is_driver_loading = 1;
8349 if ((mpt3sas_base_attach(ioc))) {
8350 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
8351 ioc->name, __FILE__, __LINE__, __func__);
8353 goto out_attach_fail;
8355 rv = scsi_add_host(shost, &pdev->dev);
8357 pr_err(MPT3SAS_FMT "failure at %s:%d/%s()!\n",
8358 ioc->name, __FILE__, __LINE__, __func__);
8359 goto out_add_shost_fail;
8362 scsi_scan_host(shost);
8365 mpt3sas_base_detach(ioc);
8367 destroy_workqueue(ioc->firmware_event_thread);
8369 list_del(&ioc->list);
8370 scsi_host_put(shost);
8376 * _scsih_suspend - power management suspend main entry point
8377 * @pdev: PCI device struct
8378 * @state: PM state change to (usually PCI_D3)
8380 * Returns 0 success, anything else error.
8383 _scsih_suspend(struct pci_dev *pdev, pm_message_t state)
8385 struct Scsi_Host *shost = pci_get_drvdata(pdev);
8386 struct MPT3SAS_ADAPTER *ioc = shost_priv(shost);
8387 pci_power_t device_state;
8389 mpt3sas_base_stop_watchdog(ioc);
8390 flush_scheduled_work();
8391 scsi_block_requests(shost);
8392 device_state = pci_choose_state(pdev, state);
8394 "pdev=0x%p, slot=%s, entering operating state [D%d]\n",
8395 ioc->name, pdev, pci_name(pdev), device_state);
8397 pci_save_state(pdev);
8398 mpt3sas_base_free_resources(ioc);
8399 pci_set_power_state(pdev, device_state);
8404 * _scsih_resume - power management resume main entry point
8405 * @pdev: PCI device struct
8407 * Returns 0 success, anything else error.
8410 _scsih_resume(struct pci_dev *pdev)
8412 struct Scsi_Host *shost = pci_get_drvdata(pdev);
8413 struct MPT3SAS_ADAPTER *ioc = shost_priv(shost);
8414 pci_power_t device_state = pdev->current_state;
8418 "pdev=0x%p, slot=%s, previous operating state [D%d]\n",
8419 ioc->name, pdev, pci_name(pdev), device_state);
8421 pci_set_power_state(pdev, PCI_D0);
8422 pci_enable_wake(pdev, PCI_D0, 0);
8423 pci_restore_state(pdev);
8425 r = mpt3sas_base_map_resources(ioc);
8429 mpt3sas_base_hard_reset_handler(ioc, CAN_SLEEP, SOFT_RESET);
8430 scsi_unblock_requests(shost);
8431 mpt3sas_base_start_watchdog(ioc);
8434 #endif /* CONFIG_PM */
8437 * _scsih_pci_error_detected - Called when a PCI error is detected.
8438 * @pdev: PCI device struct
8439 * @state: PCI channel state
8441 * Description: Called when a PCI error is detected.
8444 * PCI_ERS_RESULT_NEED_RESET or PCI_ERS_RESULT_DISCONNECT
8446 static pci_ers_result_t
8447 _scsih_pci_error_detected(struct pci_dev *pdev, pci_channel_state_t state)
8449 struct Scsi_Host *shost = pci_get_drvdata(pdev);
8450 struct MPT3SAS_ADAPTER *ioc = shost_priv(shost);
8452 pr_info(MPT3SAS_FMT "PCI error: detected callback, state(%d)!!\n",
8456 case pci_channel_io_normal:
8457 return PCI_ERS_RESULT_CAN_RECOVER;
8458 case pci_channel_io_frozen:
8459 /* Fatal error, prepare for slot reset */
8460 ioc->pci_error_recovery = 1;
8461 scsi_block_requests(ioc->shost);
8462 mpt3sas_base_stop_watchdog(ioc);
8463 mpt3sas_base_free_resources(ioc);
8464 return PCI_ERS_RESULT_NEED_RESET;
8465 case pci_channel_io_perm_failure:
8466 /* Permanent error, prepare for device removal */
8467 ioc->pci_error_recovery = 1;
8468 mpt3sas_base_stop_watchdog(ioc);
8469 _scsih_flush_running_cmds(ioc);
8470 return PCI_ERS_RESULT_DISCONNECT;
8472 return PCI_ERS_RESULT_NEED_RESET;
8476 * _scsih_pci_slot_reset - Called when PCI slot has been reset.
8477 * @pdev: PCI device struct
8479 * Description: This routine is called by the pci error recovery
8480 * code after the PCI slot has been reset, just before we
8481 * should resume normal operations.
8483 static pci_ers_result_t
8484 _scsih_pci_slot_reset(struct pci_dev *pdev)
8486 struct Scsi_Host *shost = pci_get_drvdata(pdev);
8487 struct MPT3SAS_ADAPTER *ioc = shost_priv(shost);
8490 pr_info(MPT3SAS_FMT "PCI error: slot reset callback!!\n",
8493 ioc->pci_error_recovery = 0;
8495 pci_restore_state(pdev);
8496 rc = mpt3sas_base_map_resources(ioc);
8498 return PCI_ERS_RESULT_DISCONNECT;
8500 rc = mpt3sas_base_hard_reset_handler(ioc, CAN_SLEEP,
8503 pr_warn(MPT3SAS_FMT "hard reset: %s\n", ioc->name,
8504 (rc == 0) ? "success" : "failed");
8507 return PCI_ERS_RESULT_RECOVERED;
8509 return PCI_ERS_RESULT_DISCONNECT;
8513 * _scsih_pci_resume() - resume normal ops after PCI reset
8514 * @pdev: pointer to PCI device
8516 * Called when the error recovery driver tells us that its
8517 * OK to resume normal operation. Use completion to allow
8518 * halted scsi ops to resume.
8521 _scsih_pci_resume(struct pci_dev *pdev)
8523 struct Scsi_Host *shost = pci_get_drvdata(pdev);
8524 struct MPT3SAS_ADAPTER *ioc = shost_priv(shost);
8526 pr_info(MPT3SAS_FMT "PCI error: resume callback!!\n", ioc->name);
8528 pci_cleanup_aer_uncorrect_error_status(pdev);
8529 mpt3sas_base_start_watchdog(ioc);
8530 scsi_unblock_requests(ioc->shost);
8534 * _scsih_pci_mmio_enabled - Enable MMIO and dump debug registers
8535 * @pdev: pointer to PCI device
8537 static pci_ers_result_t
8538 _scsih_pci_mmio_enabled(struct pci_dev *pdev)
8540 struct Scsi_Host *shost = pci_get_drvdata(pdev);
8541 struct MPT3SAS_ADAPTER *ioc = shost_priv(shost);
8543 pr_info(MPT3SAS_FMT "PCI error: mmio enabled callback!!\n",
8546 /* TODO - dump whatever for debugging purposes */
8548 /* Request a slot reset. */
8549 return PCI_ERS_RESULT_NEED_RESET;
8552 /* raid transport support */
8553 static struct raid_function_template mpt3sas_raid_functions = {
8554 .cookie = &scsih_driver_template,
8555 .is_raid = _scsih_is_raid,
8556 .get_resync = _scsih_get_resync,
8557 .get_state = _scsih_get_state,
8560 static struct pci_error_handlers _scsih_err_handler = {
8561 .error_detected = _scsih_pci_error_detected,
8562 .mmio_enabled = _scsih_pci_mmio_enabled,
8563 .slot_reset = _scsih_pci_slot_reset,
8564 .resume = _scsih_pci_resume,
8567 static struct pci_driver scsih_driver = {
8568 .name = MPT3SAS_DRIVER_NAME,
8569 .id_table = scsih_pci_table,
8570 .probe = _scsih_probe,
8571 .remove = _scsih_remove,
8572 .shutdown = _scsih_shutdown,
8573 .err_handler = &_scsih_err_handler,
8575 .suspend = _scsih_suspend,
8576 .resume = _scsih_resume,
8582 * _scsih_init - main entry point for this driver.
8584 * Returns 0 success, anything else error.
8593 pr_info("%s version %s loaded\n", MPT3SAS_DRIVER_NAME,
8594 MPT3SAS_DRIVER_VERSION);
8596 mpt3sas_transport_template =
8597 sas_attach_transport(&mpt3sas_transport_functions);
8598 if (!mpt3sas_transport_template)
8601 /* raid transport support */
8602 mpt3sas_raid_template = raid_class_attach(&mpt3sas_raid_functions);
8603 if (!mpt3sas_raid_template) {
8604 sas_release_transport(mpt3sas_transport_template);
8608 mpt3sas_base_initialize_callback_handler();
8610 /* queuecommand callback hander */
8611 scsi_io_cb_idx = mpt3sas_base_register_callback_handler(_scsih_io_done);
8613 /* task managment callback handler */
8614 tm_cb_idx = mpt3sas_base_register_callback_handler(_scsih_tm_done);
8616 /* base internal commands callback handler */
8617 base_cb_idx = mpt3sas_base_register_callback_handler(mpt3sas_base_done);
8618 port_enable_cb_idx = mpt3sas_base_register_callback_handler(
8619 mpt3sas_port_enable_done);
8621 /* transport internal commands callback handler */
8622 transport_cb_idx = mpt3sas_base_register_callback_handler(
8623 mpt3sas_transport_done);
8625 /* scsih internal commands callback handler */
8626 scsih_cb_idx = mpt3sas_base_register_callback_handler(_scsih_done);
8628 /* configuration page API internal commands callback handler */
8629 config_cb_idx = mpt3sas_base_register_callback_handler(
8630 mpt3sas_config_done);
8632 /* ctl module callback handler */
8633 ctl_cb_idx = mpt3sas_base_register_callback_handler(mpt3sas_ctl_done);
8635 tm_tr_cb_idx = mpt3sas_base_register_callback_handler(
8636 _scsih_tm_tr_complete);
8638 tm_tr_volume_cb_idx = mpt3sas_base_register_callback_handler(
8639 _scsih_tm_volume_tr_complete);
8641 tm_sas_control_cb_idx = mpt3sas_base_register_callback_handler(
8642 _scsih_sas_control_complete);
8646 error = pci_register_driver(&scsih_driver);
8648 /* raid transport support */
8649 raid_class_release(mpt3sas_raid_template);
8650 sas_release_transport(mpt3sas_transport_template);
8657 * _scsih_exit - exit point for this driver (when it is a module).
8659 * Returns 0 success, anything else error.
8664 pr_info("mpt3sas version %s unloading\n",
8665 MPT3SAS_DRIVER_VERSION);
8669 pci_unregister_driver(&scsih_driver);
8672 mpt3sas_base_release_callback_handler(scsi_io_cb_idx);
8673 mpt3sas_base_release_callback_handler(tm_cb_idx);
8674 mpt3sas_base_release_callback_handler(base_cb_idx);
8675 mpt3sas_base_release_callback_handler(port_enable_cb_idx);
8676 mpt3sas_base_release_callback_handler(transport_cb_idx);
8677 mpt3sas_base_release_callback_handler(scsih_cb_idx);
8678 mpt3sas_base_release_callback_handler(config_cb_idx);
8679 mpt3sas_base_release_callback_handler(ctl_cb_idx);
8681 mpt3sas_base_release_callback_handler(tm_tr_cb_idx);
8682 mpt3sas_base_release_callback_handler(tm_tr_volume_cb_idx);
8683 mpt3sas_base_release_callback_handler(tm_sas_control_cb_idx);
8685 /* raid transport support */
8686 raid_class_release(mpt3sas_raid_template);
8687 sas_release_transport(mpt3sas_transport_template);
8690 module_init(_scsih_init);
8691 module_exit(_scsih_exit);