igb: cleanup igb_netpoll to be more friendly with napi & GRO
[linux-2.6] / drivers / scsi / ipr.c
1 /*
2  * ipr.c -- driver for IBM Power Linux RAID adapters
3  *
4  * Written By: Brian King <brking@us.ibm.com>, IBM Corporation
5  *
6  * Copyright (C) 2003, 2004 IBM Corporation
7  *
8  * This program is free software; you can redistribute it and/or modify
9  * it under the terms of the GNU General Public License as published by
10  * the Free Software Foundation; either version 2 of the License, or
11  * (at your option) any later version.
12  *
13  * This program is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16  * GNU General Public License for more details.
17  *
18  * You should have received a copy of the GNU General Public License
19  * along with this program; if not, write to the Free Software
20  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
21  *
22  */
23
24 /*
25  * Notes:
26  *
27  * This driver is used to control the following SCSI adapters:
28  *
29  * IBM iSeries: 5702, 5703, 2780, 5709, 570A, 570B
30  *
31  * IBM pSeries: PCI-X Dual Channel Ultra 320 SCSI RAID Adapter
32  *              PCI-X Dual Channel Ultra 320 SCSI Adapter
33  *              PCI-X Dual Channel Ultra 320 SCSI RAID Enablement Card
34  *              Embedded SCSI adapter on p615 and p655 systems
35  *
36  * Supported Hardware Features:
37  *      - Ultra 320 SCSI controller
38  *      - PCI-X host interface
39  *      - Embedded PowerPC RISC Processor and Hardware XOR DMA Engine
40  *      - Non-Volatile Write Cache
41  *      - Supports attachment of non-RAID disks, tape, and optical devices
42  *      - RAID Levels 0, 5, 10
43  *      - Hot spare
44  *      - Background Parity Checking
45  *      - Background Data Scrubbing
46  *      - Ability to increase the capacity of an existing RAID 5 disk array
47  *              by adding disks
48  *
49  * Driver Features:
50  *      - Tagged command queuing
51  *      - Adapter microcode download
52  *      - PCI hot plug
53  *      - SCSI device hot plug
54  *
55  */
56
57 #include <linux/fs.h>
58 #include <linux/init.h>
59 #include <linux/types.h>
60 #include <linux/errno.h>
61 #include <linux/kernel.h>
62 #include <linux/ioport.h>
63 #include <linux/delay.h>
64 #include <linux/pci.h>
65 #include <linux/wait.h>
66 #include <linux/spinlock.h>
67 #include <linux/sched.h>
68 #include <linux/interrupt.h>
69 #include <linux/blkdev.h>
70 #include <linux/firmware.h>
71 #include <linux/module.h>
72 #include <linux/moduleparam.h>
73 #include <linux/libata.h>
74 #include <linux/hdreg.h>
75 #include <asm/io.h>
76 #include <asm/irq.h>
77 #include <asm/processor.h>
78 #include <scsi/scsi.h>
79 #include <scsi/scsi_host.h>
80 #include <scsi/scsi_tcq.h>
81 #include <scsi/scsi_eh.h>
82 #include <scsi/scsi_cmnd.h>
83 #include "ipr.h"
84
85 /*
86  *   Global Data
87  */
88 static LIST_HEAD(ipr_ioa_head);
89 static unsigned int ipr_log_level = IPR_DEFAULT_LOG_LEVEL;
90 static unsigned int ipr_max_speed = 1;
91 static int ipr_testmode = 0;
92 static unsigned int ipr_fastfail = 0;
93 static unsigned int ipr_transop_timeout = 0;
94 static unsigned int ipr_enable_cache = 1;
95 static unsigned int ipr_debug = 0;
96 static unsigned int ipr_dual_ioa_raid = 1;
97 static DEFINE_SPINLOCK(ipr_driver_lock);
98
99 /* This table describes the differences between DMA controller chips */
100 static const struct ipr_chip_cfg_t ipr_chip_cfg[] = {
101         { /* Gemstone, Citrine, Obsidian, and Obsidian-E */
102                 .mailbox = 0x0042C,
103                 .cache_line_size = 0x20,
104                 {
105                         .set_interrupt_mask_reg = 0x0022C,
106                         .clr_interrupt_mask_reg = 0x00230,
107                         .sense_interrupt_mask_reg = 0x0022C,
108                         .clr_interrupt_reg = 0x00228,
109                         .sense_interrupt_reg = 0x00224,
110                         .ioarrin_reg = 0x00404,
111                         .sense_uproc_interrupt_reg = 0x00214,
112                         .set_uproc_interrupt_reg = 0x00214,
113                         .clr_uproc_interrupt_reg = 0x00218
114                 }
115         },
116         { /* Snipe and Scamp */
117                 .mailbox = 0x0052C,
118                 .cache_line_size = 0x20,
119                 {
120                         .set_interrupt_mask_reg = 0x00288,
121                         .clr_interrupt_mask_reg = 0x0028C,
122                         .sense_interrupt_mask_reg = 0x00288,
123                         .clr_interrupt_reg = 0x00284,
124                         .sense_interrupt_reg = 0x00280,
125                         .ioarrin_reg = 0x00504,
126                         .sense_uproc_interrupt_reg = 0x00290,
127                         .set_uproc_interrupt_reg = 0x00290,
128                         .clr_uproc_interrupt_reg = 0x00294
129                 }
130         },
131 };
132
133 static const struct ipr_chip_t ipr_chip[] = {
134         { PCI_VENDOR_ID_MYLEX, PCI_DEVICE_ID_IBM_GEMSTONE, &ipr_chip_cfg[0] },
135         { PCI_VENDOR_ID_IBM, PCI_DEVICE_ID_IBM_CITRINE, &ipr_chip_cfg[0] },
136         { PCI_VENDOR_ID_ADAPTEC2, PCI_DEVICE_ID_ADAPTEC2_OBSIDIAN, &ipr_chip_cfg[0] },
137         { PCI_VENDOR_ID_IBM, PCI_DEVICE_ID_IBM_OBSIDIAN, &ipr_chip_cfg[0] },
138         { PCI_VENDOR_ID_IBM, PCI_DEVICE_ID_IBM_OBSIDIAN_E, &ipr_chip_cfg[0] },
139         { PCI_VENDOR_ID_IBM, PCI_DEVICE_ID_IBM_SNIPE, &ipr_chip_cfg[1] },
140         { PCI_VENDOR_ID_ADAPTEC2, PCI_DEVICE_ID_ADAPTEC2_SCAMP, &ipr_chip_cfg[1] }
141 };
142
143 static int ipr_max_bus_speeds [] = {
144         IPR_80MBs_SCSI_RATE, IPR_U160_SCSI_RATE, IPR_U320_SCSI_RATE
145 };
146
147 MODULE_AUTHOR("Brian King <brking@us.ibm.com>");
148 MODULE_DESCRIPTION("IBM Power RAID SCSI Adapter Driver");
149 module_param_named(max_speed, ipr_max_speed, uint, 0);
150 MODULE_PARM_DESC(max_speed, "Maximum bus speed (0-2). Default: 1=U160. Speeds: 0=80 MB/s, 1=U160, 2=U320");
151 module_param_named(log_level, ipr_log_level, uint, 0);
152 MODULE_PARM_DESC(log_level, "Set to 0 - 4 for increasing verbosity of device driver");
153 module_param_named(testmode, ipr_testmode, int, 0);
154 MODULE_PARM_DESC(testmode, "DANGEROUS!!! Allows unsupported configurations");
155 module_param_named(fastfail, ipr_fastfail, int, 0);
156 MODULE_PARM_DESC(fastfail, "Reduce timeouts and retries");
157 module_param_named(transop_timeout, ipr_transop_timeout, int, 0);
158 MODULE_PARM_DESC(transop_timeout, "Time in seconds to wait for adapter to come operational (default: 300)");
159 module_param_named(enable_cache, ipr_enable_cache, int, 0);
160 MODULE_PARM_DESC(enable_cache, "Enable adapter's non-volatile write cache (default: 1)");
161 module_param_named(debug, ipr_debug, int, 0);
162 MODULE_PARM_DESC(debug, "Enable device driver debugging logging. Set to 1 to enable. (default: 0)");
163 module_param_named(dual_ioa_raid, ipr_dual_ioa_raid, int, 0);
164 MODULE_PARM_DESC(dual_ioa_raid, "Enable dual adapter RAID support. Set to 1 to enable. (default: 1)");
165 MODULE_LICENSE("GPL");
166 MODULE_VERSION(IPR_DRIVER_VERSION);
167
168 /*  A constant array of IOASCs/URCs/Error Messages */
169 static const
170 struct ipr_error_table_t ipr_error_table[] = {
171         {0x00000000, 1, IPR_DEFAULT_LOG_LEVEL,
172         "8155: An unknown error was received"},
173         {0x00330000, 0, 0,
174         "Soft underlength error"},
175         {0x005A0000, 0, 0,
176         "Command to be cancelled not found"},
177         {0x00808000, 0, 0,
178         "Qualified success"},
179         {0x01080000, 1, IPR_DEFAULT_LOG_LEVEL,
180         "FFFE: Soft device bus error recovered by the IOA"},
181         {0x01088100, 0, IPR_DEFAULT_LOG_LEVEL,
182         "4101: Soft device bus fabric error"},
183         {0x01170600, 0, IPR_DEFAULT_LOG_LEVEL,
184         "FFF9: Device sector reassign successful"},
185         {0x01170900, 0, IPR_DEFAULT_LOG_LEVEL,
186         "FFF7: Media error recovered by device rewrite procedures"},
187         {0x01180200, 0, IPR_DEFAULT_LOG_LEVEL,
188         "7001: IOA sector reassignment successful"},
189         {0x01180500, 0, IPR_DEFAULT_LOG_LEVEL,
190         "FFF9: Soft media error. Sector reassignment recommended"},
191         {0x01180600, 0, IPR_DEFAULT_LOG_LEVEL,
192         "FFF7: Media error recovered by IOA rewrite procedures"},
193         {0x01418000, 0, IPR_DEFAULT_LOG_LEVEL,
194         "FF3D: Soft PCI bus error recovered by the IOA"},
195         {0x01440000, 1, IPR_DEFAULT_LOG_LEVEL,
196         "FFF6: Device hardware error recovered by the IOA"},
197         {0x01448100, 0, IPR_DEFAULT_LOG_LEVEL,
198         "FFF6: Device hardware error recovered by the device"},
199         {0x01448200, 1, IPR_DEFAULT_LOG_LEVEL,
200         "FF3D: Soft IOA error recovered by the IOA"},
201         {0x01448300, 0, IPR_DEFAULT_LOG_LEVEL,
202         "FFFA: Undefined device response recovered by the IOA"},
203         {0x014A0000, 1, IPR_DEFAULT_LOG_LEVEL,
204         "FFF6: Device bus error, message or command phase"},
205         {0x014A8000, 0, IPR_DEFAULT_LOG_LEVEL,
206         "FFFE: Task Management Function failed"},
207         {0x015D0000, 0, IPR_DEFAULT_LOG_LEVEL,
208         "FFF6: Failure prediction threshold exceeded"},
209         {0x015D9200, 0, IPR_DEFAULT_LOG_LEVEL,
210         "8009: Impending cache battery pack failure"},
211         {0x02040400, 0, 0,
212         "34FF: Disk device format in progress"},
213         {0x02048000, 0, IPR_DEFAULT_LOG_LEVEL,
214         "9070: IOA requested reset"},
215         {0x023F0000, 0, 0,
216         "Synchronization required"},
217         {0x024E0000, 0, 0,
218         "No ready, IOA shutdown"},
219         {0x025A0000, 0, 0,
220         "Not ready, IOA has been shutdown"},
221         {0x02670100, 0, IPR_DEFAULT_LOG_LEVEL,
222         "3020: Storage subsystem configuration error"},
223         {0x03110B00, 0, 0,
224         "FFF5: Medium error, data unreadable, recommend reassign"},
225         {0x03110C00, 0, 0,
226         "7000: Medium error, data unreadable, do not reassign"},
227         {0x03310000, 0, IPR_DEFAULT_LOG_LEVEL,
228         "FFF3: Disk media format bad"},
229         {0x04050000, 0, IPR_DEFAULT_LOG_LEVEL,
230         "3002: Addressed device failed to respond to selection"},
231         {0x04080000, 1, IPR_DEFAULT_LOG_LEVEL,
232         "3100: Device bus error"},
233         {0x04080100, 0, IPR_DEFAULT_LOG_LEVEL,
234         "3109: IOA timed out a device command"},
235         {0x04088000, 0, 0,
236         "3120: SCSI bus is not operational"},
237         {0x04088100, 0, IPR_DEFAULT_LOG_LEVEL,
238         "4100: Hard device bus fabric error"},
239         {0x04118000, 0, IPR_DEFAULT_LOG_LEVEL,
240         "9000: IOA reserved area data check"},
241         {0x04118100, 0, IPR_DEFAULT_LOG_LEVEL,
242         "9001: IOA reserved area invalid data pattern"},
243         {0x04118200, 0, IPR_DEFAULT_LOG_LEVEL,
244         "9002: IOA reserved area LRC error"},
245         {0x04320000, 0, IPR_DEFAULT_LOG_LEVEL,
246         "102E: Out of alternate sectors for disk storage"},
247         {0x04330000, 1, IPR_DEFAULT_LOG_LEVEL,
248         "FFF4: Data transfer underlength error"},
249         {0x04338000, 1, IPR_DEFAULT_LOG_LEVEL,
250         "FFF4: Data transfer overlength error"},
251         {0x043E0100, 0, IPR_DEFAULT_LOG_LEVEL,
252         "3400: Logical unit failure"},
253         {0x04408500, 0, IPR_DEFAULT_LOG_LEVEL,
254         "FFF4: Device microcode is corrupt"},
255         {0x04418000, 1, IPR_DEFAULT_LOG_LEVEL,
256         "8150: PCI bus error"},
257         {0x04430000, 1, 0,
258         "Unsupported device bus message received"},
259         {0x04440000, 1, IPR_DEFAULT_LOG_LEVEL,
260         "FFF4: Disk device problem"},
261         {0x04448200, 1, IPR_DEFAULT_LOG_LEVEL,
262         "8150: Permanent IOA failure"},
263         {0x04448300, 0, IPR_DEFAULT_LOG_LEVEL,
264         "3010: Disk device returned wrong response to IOA"},
265         {0x04448400, 0, IPR_DEFAULT_LOG_LEVEL,
266         "8151: IOA microcode error"},
267         {0x04448500, 0, 0,
268         "Device bus status error"},
269         {0x04448600, 0, IPR_DEFAULT_LOG_LEVEL,
270         "8157: IOA error requiring IOA reset to recover"},
271         {0x04448700, 0, 0,
272         "ATA device status error"},
273         {0x04490000, 0, 0,
274         "Message reject received from the device"},
275         {0x04449200, 0, IPR_DEFAULT_LOG_LEVEL,
276         "8008: A permanent cache battery pack failure occurred"},
277         {0x0444A000, 0, IPR_DEFAULT_LOG_LEVEL,
278         "9090: Disk unit has been modified after the last known status"},
279         {0x0444A200, 0, IPR_DEFAULT_LOG_LEVEL,
280         "9081: IOA detected device error"},
281         {0x0444A300, 0, IPR_DEFAULT_LOG_LEVEL,
282         "9082: IOA detected device error"},
283         {0x044A0000, 1, IPR_DEFAULT_LOG_LEVEL,
284         "3110: Device bus error, message or command phase"},
285         {0x044A8000, 1, IPR_DEFAULT_LOG_LEVEL,
286         "3110: SAS Command / Task Management Function failed"},
287         {0x04670400, 0, IPR_DEFAULT_LOG_LEVEL,
288         "9091: Incorrect hardware configuration change has been detected"},
289         {0x04678000, 0, IPR_DEFAULT_LOG_LEVEL,
290         "9073: Invalid multi-adapter configuration"},
291         {0x04678100, 0, IPR_DEFAULT_LOG_LEVEL,
292         "4010: Incorrect connection between cascaded expanders"},
293         {0x04678200, 0, IPR_DEFAULT_LOG_LEVEL,
294         "4020: Connections exceed IOA design limits"},
295         {0x04678300, 0, IPR_DEFAULT_LOG_LEVEL,
296         "4030: Incorrect multipath connection"},
297         {0x04679000, 0, IPR_DEFAULT_LOG_LEVEL,
298         "4110: Unsupported enclosure function"},
299         {0x046E0000, 0, IPR_DEFAULT_LOG_LEVEL,
300         "FFF4: Command to logical unit failed"},
301         {0x05240000, 1, 0,
302         "Illegal request, invalid request type or request packet"},
303         {0x05250000, 0, 0,
304         "Illegal request, invalid resource handle"},
305         {0x05258000, 0, 0,
306         "Illegal request, commands not allowed to this device"},
307         {0x05258100, 0, 0,
308         "Illegal request, command not allowed to a secondary adapter"},
309         {0x05260000, 0, 0,
310         "Illegal request, invalid field in parameter list"},
311         {0x05260100, 0, 0,
312         "Illegal request, parameter not supported"},
313         {0x05260200, 0, 0,
314         "Illegal request, parameter value invalid"},
315         {0x052C0000, 0, 0,
316         "Illegal request, command sequence error"},
317         {0x052C8000, 1, 0,
318         "Illegal request, dual adapter support not enabled"},
319         {0x06040500, 0, IPR_DEFAULT_LOG_LEVEL,
320         "9031: Array protection temporarily suspended, protection resuming"},
321         {0x06040600, 0, IPR_DEFAULT_LOG_LEVEL,
322         "9040: Array protection temporarily suspended, protection resuming"},
323         {0x06288000, 0, IPR_DEFAULT_LOG_LEVEL,
324         "3140: Device bus not ready to ready transition"},
325         {0x06290000, 0, IPR_DEFAULT_LOG_LEVEL,
326         "FFFB: SCSI bus was reset"},
327         {0x06290500, 0, 0,
328         "FFFE: SCSI bus transition to single ended"},
329         {0x06290600, 0, 0,
330         "FFFE: SCSI bus transition to LVD"},
331         {0x06298000, 0, IPR_DEFAULT_LOG_LEVEL,
332         "FFFB: SCSI bus was reset by another initiator"},
333         {0x063F0300, 0, IPR_DEFAULT_LOG_LEVEL,
334         "3029: A device replacement has occurred"},
335         {0x064C8000, 0, IPR_DEFAULT_LOG_LEVEL,
336         "9051: IOA cache data exists for a missing or failed device"},
337         {0x064C8100, 0, IPR_DEFAULT_LOG_LEVEL,
338         "9055: Auxiliary cache IOA contains cache data needed by the primary IOA"},
339         {0x06670100, 0, IPR_DEFAULT_LOG_LEVEL,
340         "9025: Disk unit is not supported at its physical location"},
341         {0x06670600, 0, IPR_DEFAULT_LOG_LEVEL,
342         "3020: IOA detected a SCSI bus configuration error"},
343         {0x06678000, 0, IPR_DEFAULT_LOG_LEVEL,
344         "3150: SCSI bus configuration error"},
345         {0x06678100, 0, IPR_DEFAULT_LOG_LEVEL,
346         "9074: Asymmetric advanced function disk configuration"},
347         {0x06678300, 0, IPR_DEFAULT_LOG_LEVEL,
348         "4040: Incomplete multipath connection between IOA and enclosure"},
349         {0x06678400, 0, IPR_DEFAULT_LOG_LEVEL,
350         "4041: Incomplete multipath connection between enclosure and device"},
351         {0x06678500, 0, IPR_DEFAULT_LOG_LEVEL,
352         "9075: Incomplete multipath connection between IOA and remote IOA"},
353         {0x06678600, 0, IPR_DEFAULT_LOG_LEVEL,
354         "9076: Configuration error, missing remote IOA"},
355         {0x06679100, 0, IPR_DEFAULT_LOG_LEVEL,
356         "4050: Enclosure does not support a required multipath function"},
357         {0x06690200, 0, IPR_DEFAULT_LOG_LEVEL,
358         "9041: Array protection temporarily suspended"},
359         {0x06698200, 0, IPR_DEFAULT_LOG_LEVEL,
360         "9042: Corrupt array parity detected on specified device"},
361         {0x066B0200, 0, IPR_DEFAULT_LOG_LEVEL,
362         "9030: Array no longer protected due to missing or failed disk unit"},
363         {0x066B8000, 0, IPR_DEFAULT_LOG_LEVEL,
364         "9071: Link operational transition"},
365         {0x066B8100, 0, IPR_DEFAULT_LOG_LEVEL,
366         "9072: Link not operational transition"},
367         {0x066B8200, 0, IPR_DEFAULT_LOG_LEVEL,
368         "9032: Array exposed but still protected"},
369         {0x066B8300, 0, IPR_DEFAULT_LOG_LEVEL + 1,
370         "70DD: Device forced failed by disrupt device command"},
371         {0x066B9100, 0, IPR_DEFAULT_LOG_LEVEL,
372         "4061: Multipath redundancy level got better"},
373         {0x066B9200, 0, IPR_DEFAULT_LOG_LEVEL,
374         "4060: Multipath redundancy level got worse"},
375         {0x07270000, 0, 0,
376         "Failure due to other device"},
377         {0x07278000, 0, IPR_DEFAULT_LOG_LEVEL,
378         "9008: IOA does not support functions expected by devices"},
379         {0x07278100, 0, IPR_DEFAULT_LOG_LEVEL,
380         "9010: Cache data associated with attached devices cannot be found"},
381         {0x07278200, 0, IPR_DEFAULT_LOG_LEVEL,
382         "9011: Cache data belongs to devices other than those attached"},
383         {0x07278400, 0, IPR_DEFAULT_LOG_LEVEL,
384         "9020: Array missing 2 or more devices with only 1 device present"},
385         {0x07278500, 0, IPR_DEFAULT_LOG_LEVEL,
386         "9021: Array missing 2 or more devices with 2 or more devices present"},
387         {0x07278600, 0, IPR_DEFAULT_LOG_LEVEL,
388         "9022: Exposed array is missing a required device"},
389         {0x07278700, 0, IPR_DEFAULT_LOG_LEVEL,
390         "9023: Array member(s) not at required physical locations"},
391         {0x07278800, 0, IPR_DEFAULT_LOG_LEVEL,
392         "9024: Array not functional due to present hardware configuration"},
393         {0x07278900, 0, IPR_DEFAULT_LOG_LEVEL,
394         "9026: Array not functional due to present hardware configuration"},
395         {0x07278A00, 0, IPR_DEFAULT_LOG_LEVEL,
396         "9027: Array is missing a device and parity is out of sync"},
397         {0x07278B00, 0, IPR_DEFAULT_LOG_LEVEL,
398         "9028: Maximum number of arrays already exist"},
399         {0x07278C00, 0, IPR_DEFAULT_LOG_LEVEL,
400         "9050: Required cache data cannot be located for a disk unit"},
401         {0x07278D00, 0, IPR_DEFAULT_LOG_LEVEL,
402         "9052: Cache data exists for a device that has been modified"},
403         {0x07278F00, 0, IPR_DEFAULT_LOG_LEVEL,
404         "9054: IOA resources not available due to previous problems"},
405         {0x07279100, 0, IPR_DEFAULT_LOG_LEVEL,
406         "9092: Disk unit requires initialization before use"},
407         {0x07279200, 0, IPR_DEFAULT_LOG_LEVEL,
408         "9029: Incorrect hardware configuration change has been detected"},
409         {0x07279600, 0, IPR_DEFAULT_LOG_LEVEL,
410         "9060: One or more disk pairs are missing from an array"},
411         {0x07279700, 0, IPR_DEFAULT_LOG_LEVEL,
412         "9061: One or more disks are missing from an array"},
413         {0x07279800, 0, IPR_DEFAULT_LOG_LEVEL,
414         "9062: One or more disks are missing from an array"},
415         {0x07279900, 0, IPR_DEFAULT_LOG_LEVEL,
416         "9063: Maximum number of functional arrays has been exceeded"},
417         {0x0B260000, 0, 0,
418         "Aborted command, invalid descriptor"},
419         {0x0B5A0000, 0, 0,
420         "Command terminated by host"}
421 };
422
423 static const struct ipr_ses_table_entry ipr_ses_table[] = {
424         { "2104-DL1        ", "XXXXXXXXXXXXXXXX", 80 },
425         { "2104-TL1        ", "XXXXXXXXXXXXXXXX", 80 },
426         { "HSBP07M P U2SCSI", "XXXXXXXXXXXXXXXX", 80 }, /* Hidive 7 slot */
427         { "HSBP05M P U2SCSI", "XXXXXXXXXXXXXXXX", 80 }, /* Hidive 5 slot */
428         { "HSBP05M S U2SCSI", "XXXXXXXXXXXXXXXX", 80 }, /* Bowtie */
429         { "HSBP06E ASU2SCSI", "XXXXXXXXXXXXXXXX", 80 }, /* MartinFenning */
430         { "2104-DU3        ", "XXXXXXXXXXXXXXXX", 160 },
431         { "2104-TU3        ", "XXXXXXXXXXXXXXXX", 160 },
432         { "HSBP04C RSU2SCSI", "XXXXXXX*XXXXXXXX", 160 },
433         { "HSBP06E RSU2SCSI", "XXXXXXX*XXXXXXXX", 160 },
434         { "St  V1S2        ", "XXXXXXXXXXXXXXXX", 160 },
435         { "HSBPD4M  PU3SCSI", "XXXXXXX*XXXXXXXX", 160 },
436         { "VSBPD1H   U3SCSI", "XXXXXXX*XXXXXXXX", 160 }
437 };
438
439 /*
440  *  Function Prototypes
441  */
442 static int ipr_reset_alert(struct ipr_cmnd *);
443 static void ipr_process_ccn(struct ipr_cmnd *);
444 static void ipr_process_error(struct ipr_cmnd *);
445 static void ipr_reset_ioa_job(struct ipr_cmnd *);
446 static void ipr_initiate_ioa_reset(struct ipr_ioa_cfg *,
447                                    enum ipr_shutdown_type);
448
449 #ifdef CONFIG_SCSI_IPR_TRACE
450 /**
451  * ipr_trc_hook - Add a trace entry to the driver trace
452  * @ipr_cmd:    ipr command struct
453  * @type:               trace type
454  * @add_data:   additional data
455  *
456  * Return value:
457  *      none
458  **/
459 static void ipr_trc_hook(struct ipr_cmnd *ipr_cmd,
460                          u8 type, u32 add_data)
461 {
462         struct ipr_trace_entry *trace_entry;
463         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
464
465         trace_entry = &ioa_cfg->trace[ioa_cfg->trace_index++];
466         trace_entry->time = jiffies;
467         trace_entry->op_code = ipr_cmd->ioarcb.cmd_pkt.cdb[0];
468         trace_entry->type = type;
469         trace_entry->ata_op_code = ipr_cmd->ioarcb.add_data.u.regs.command;
470         trace_entry->cmd_index = ipr_cmd->cmd_index & 0xff;
471         trace_entry->res_handle = ipr_cmd->ioarcb.res_handle;
472         trace_entry->u.add_data = add_data;
473 }
474 #else
475 #define ipr_trc_hook(ipr_cmd, type, add_data) do { } while(0)
476 #endif
477
478 /**
479  * ipr_reinit_ipr_cmnd - Re-initialize an IPR Cmnd block for reuse
480  * @ipr_cmd:    ipr command struct
481  *
482  * Return value:
483  *      none
484  **/
485 static void ipr_reinit_ipr_cmnd(struct ipr_cmnd *ipr_cmd)
486 {
487         struct ipr_ioarcb *ioarcb = &ipr_cmd->ioarcb;
488         struct ipr_ioasa *ioasa = &ipr_cmd->ioasa;
489         dma_addr_t dma_addr = be32_to_cpu(ioarcb->ioarcb_host_pci_addr);
490
491         memset(&ioarcb->cmd_pkt, 0, sizeof(struct ipr_cmd_pkt));
492         ioarcb->write_data_transfer_length = 0;
493         ioarcb->read_data_transfer_length = 0;
494         ioarcb->write_ioadl_len = 0;
495         ioarcb->read_ioadl_len = 0;
496         ioarcb->write_ioadl_addr =
497                 cpu_to_be32(dma_addr + offsetof(struct ipr_cmnd, ioadl));
498         ioarcb->read_ioadl_addr = ioarcb->write_ioadl_addr;
499         ioasa->ioasc = 0;
500         ioasa->residual_data_len = 0;
501         ioasa->u.gata.status = 0;
502
503         ipr_cmd->scsi_cmd = NULL;
504         ipr_cmd->qc = NULL;
505         ipr_cmd->sense_buffer[0] = 0;
506         ipr_cmd->dma_use_sg = 0;
507 }
508
509 /**
510  * ipr_init_ipr_cmnd - Initialize an IPR Cmnd block
511  * @ipr_cmd:    ipr command struct
512  *
513  * Return value:
514  *      none
515  **/
516 static void ipr_init_ipr_cmnd(struct ipr_cmnd *ipr_cmd)
517 {
518         ipr_reinit_ipr_cmnd(ipr_cmd);
519         ipr_cmd->u.scratch = 0;
520         ipr_cmd->sibling = NULL;
521         init_timer(&ipr_cmd->timer);
522 }
523
524 /**
525  * ipr_get_free_ipr_cmnd - Get a free IPR Cmnd block
526  * @ioa_cfg:    ioa config struct
527  *
528  * Return value:
529  *      pointer to ipr command struct
530  **/
531 static
532 struct ipr_cmnd *ipr_get_free_ipr_cmnd(struct ipr_ioa_cfg *ioa_cfg)
533 {
534         struct ipr_cmnd *ipr_cmd;
535
536         ipr_cmd = list_entry(ioa_cfg->free_q.next, struct ipr_cmnd, queue);
537         list_del(&ipr_cmd->queue);
538         ipr_init_ipr_cmnd(ipr_cmd);
539
540         return ipr_cmd;
541 }
542
543 /**
544  * ipr_mask_and_clear_interrupts - Mask all and clear specified interrupts
545  * @ioa_cfg:    ioa config struct
546  * @clr_ints:     interrupts to clear
547  *
548  * This function masks all interrupts on the adapter, then clears the
549  * interrupts specified in the mask
550  *
551  * Return value:
552  *      none
553  **/
554 static void ipr_mask_and_clear_interrupts(struct ipr_ioa_cfg *ioa_cfg,
555                                           u32 clr_ints)
556 {
557         volatile u32 int_reg;
558
559         /* Stop new interrupts */
560         ioa_cfg->allow_interrupts = 0;
561
562         /* Set interrupt mask to stop all new interrupts */
563         writel(~0, ioa_cfg->regs.set_interrupt_mask_reg);
564
565         /* Clear any pending interrupts */
566         writel(clr_ints, ioa_cfg->regs.clr_interrupt_reg);
567         int_reg = readl(ioa_cfg->regs.sense_interrupt_reg);
568 }
569
570 /**
571  * ipr_save_pcix_cmd_reg - Save PCI-X command register
572  * @ioa_cfg:    ioa config struct
573  *
574  * Return value:
575  *      0 on success / -EIO on failure
576  **/
577 static int ipr_save_pcix_cmd_reg(struct ipr_ioa_cfg *ioa_cfg)
578 {
579         int pcix_cmd_reg = pci_find_capability(ioa_cfg->pdev, PCI_CAP_ID_PCIX);
580
581         if (pcix_cmd_reg == 0)
582                 return 0;
583
584         if (pci_read_config_word(ioa_cfg->pdev, pcix_cmd_reg + PCI_X_CMD,
585                                  &ioa_cfg->saved_pcix_cmd_reg) != PCIBIOS_SUCCESSFUL) {
586                 dev_err(&ioa_cfg->pdev->dev, "Failed to save PCI-X command register\n");
587                 return -EIO;
588         }
589
590         ioa_cfg->saved_pcix_cmd_reg |= PCI_X_CMD_DPERR_E | PCI_X_CMD_ERO;
591         return 0;
592 }
593
594 /**
595  * ipr_set_pcix_cmd_reg - Setup PCI-X command register
596  * @ioa_cfg:    ioa config struct
597  *
598  * Return value:
599  *      0 on success / -EIO on failure
600  **/
601 static int ipr_set_pcix_cmd_reg(struct ipr_ioa_cfg *ioa_cfg)
602 {
603         int pcix_cmd_reg = pci_find_capability(ioa_cfg->pdev, PCI_CAP_ID_PCIX);
604
605         if (pcix_cmd_reg) {
606                 if (pci_write_config_word(ioa_cfg->pdev, pcix_cmd_reg + PCI_X_CMD,
607                                           ioa_cfg->saved_pcix_cmd_reg) != PCIBIOS_SUCCESSFUL) {
608                         dev_err(&ioa_cfg->pdev->dev, "Failed to setup PCI-X command register\n");
609                         return -EIO;
610                 }
611         }
612
613         return 0;
614 }
615
616 /**
617  * ipr_sata_eh_done - done function for aborted SATA commands
618  * @ipr_cmd:    ipr command struct
619  *
620  * This function is invoked for ops generated to SATA
621  * devices which are being aborted.
622  *
623  * Return value:
624  *      none
625  **/
626 static void ipr_sata_eh_done(struct ipr_cmnd *ipr_cmd)
627 {
628         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
629         struct ata_queued_cmd *qc = ipr_cmd->qc;
630         struct ipr_sata_port *sata_port = qc->ap->private_data;
631
632         qc->err_mask |= AC_ERR_OTHER;
633         sata_port->ioasa.status |= ATA_BUSY;
634         list_add_tail(&ipr_cmd->queue, &ioa_cfg->free_q);
635         ata_qc_complete(qc);
636 }
637
638 /**
639  * ipr_scsi_eh_done - mid-layer done function for aborted ops
640  * @ipr_cmd:    ipr command struct
641  *
642  * This function is invoked by the interrupt handler for
643  * ops generated by the SCSI mid-layer which are being aborted.
644  *
645  * Return value:
646  *      none
647  **/
648 static void ipr_scsi_eh_done(struct ipr_cmnd *ipr_cmd)
649 {
650         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
651         struct scsi_cmnd *scsi_cmd = ipr_cmd->scsi_cmd;
652
653         scsi_cmd->result |= (DID_ERROR << 16);
654
655         scsi_dma_unmap(ipr_cmd->scsi_cmd);
656         scsi_cmd->scsi_done(scsi_cmd);
657         list_add_tail(&ipr_cmd->queue, &ioa_cfg->free_q);
658 }
659
660 /**
661  * ipr_fail_all_ops - Fails all outstanding ops.
662  * @ioa_cfg:    ioa config struct
663  *
664  * This function fails all outstanding ops.
665  *
666  * Return value:
667  *      none
668  **/
669 static void ipr_fail_all_ops(struct ipr_ioa_cfg *ioa_cfg)
670 {
671         struct ipr_cmnd *ipr_cmd, *temp;
672
673         ENTER;
674         list_for_each_entry_safe(ipr_cmd, temp, &ioa_cfg->pending_q, queue) {
675                 list_del(&ipr_cmd->queue);
676
677                 ipr_cmd->ioasa.ioasc = cpu_to_be32(IPR_IOASC_IOA_WAS_RESET);
678                 ipr_cmd->ioasa.ilid = cpu_to_be32(IPR_DRIVER_ILID);
679
680                 if (ipr_cmd->scsi_cmd)
681                         ipr_cmd->done = ipr_scsi_eh_done;
682                 else if (ipr_cmd->qc)
683                         ipr_cmd->done = ipr_sata_eh_done;
684
685                 ipr_trc_hook(ipr_cmd, IPR_TRACE_FINISH, IPR_IOASC_IOA_WAS_RESET);
686                 del_timer(&ipr_cmd->timer);
687                 ipr_cmd->done(ipr_cmd);
688         }
689
690         LEAVE;
691 }
692
693 /**
694  * ipr_do_req -  Send driver initiated requests.
695  * @ipr_cmd:            ipr command struct
696  * @done:                       done function
697  * @timeout_func:       timeout function
698  * @timeout:            timeout value
699  *
700  * This function sends the specified command to the adapter with the
701  * timeout given. The done function is invoked on command completion.
702  *
703  * Return value:
704  *      none
705  **/
706 static void ipr_do_req(struct ipr_cmnd *ipr_cmd,
707                        void (*done) (struct ipr_cmnd *),
708                        void (*timeout_func) (struct ipr_cmnd *), u32 timeout)
709 {
710         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
711
712         list_add_tail(&ipr_cmd->queue, &ioa_cfg->pending_q);
713
714         ipr_cmd->done = done;
715
716         ipr_cmd->timer.data = (unsigned long) ipr_cmd;
717         ipr_cmd->timer.expires = jiffies + timeout;
718         ipr_cmd->timer.function = (void (*)(unsigned long))timeout_func;
719
720         add_timer(&ipr_cmd->timer);
721
722         ipr_trc_hook(ipr_cmd, IPR_TRACE_START, 0);
723
724         mb();
725         writel(be32_to_cpu(ipr_cmd->ioarcb.ioarcb_host_pci_addr),
726                ioa_cfg->regs.ioarrin_reg);
727 }
728
729 /**
730  * ipr_internal_cmd_done - Op done function for an internally generated op.
731  * @ipr_cmd:    ipr command struct
732  *
733  * This function is the op done function for an internally generated,
734  * blocking op. It simply wakes the sleeping thread.
735  *
736  * Return value:
737  *      none
738  **/
739 static void ipr_internal_cmd_done(struct ipr_cmnd *ipr_cmd)
740 {
741         if (ipr_cmd->sibling)
742                 ipr_cmd->sibling = NULL;
743         else
744                 complete(&ipr_cmd->completion);
745 }
746
747 /**
748  * ipr_send_blocking_cmd - Send command and sleep on its completion.
749  * @ipr_cmd:    ipr command struct
750  * @timeout_func:       function to invoke if command times out
751  * @timeout:    timeout
752  *
753  * Return value:
754  *      none
755  **/
756 static void ipr_send_blocking_cmd(struct ipr_cmnd *ipr_cmd,
757                                   void (*timeout_func) (struct ipr_cmnd *ipr_cmd),
758                                   u32 timeout)
759 {
760         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
761
762         init_completion(&ipr_cmd->completion);
763         ipr_do_req(ipr_cmd, ipr_internal_cmd_done, timeout_func, timeout);
764
765         spin_unlock_irq(ioa_cfg->host->host_lock);
766         wait_for_completion(&ipr_cmd->completion);
767         spin_lock_irq(ioa_cfg->host->host_lock);
768 }
769
770 /**
771  * ipr_send_hcam - Send an HCAM to the adapter.
772  * @ioa_cfg:    ioa config struct
773  * @type:               HCAM type
774  * @hostrcb:    hostrcb struct
775  *
776  * This function will send a Host Controlled Async command to the adapter.
777  * If HCAMs are currently not allowed to be issued to the adapter, it will
778  * place the hostrcb on the free queue.
779  *
780  * Return value:
781  *      none
782  **/
783 static void ipr_send_hcam(struct ipr_ioa_cfg *ioa_cfg, u8 type,
784                           struct ipr_hostrcb *hostrcb)
785 {
786         struct ipr_cmnd *ipr_cmd;
787         struct ipr_ioarcb *ioarcb;
788
789         if (ioa_cfg->allow_cmds) {
790                 ipr_cmd = ipr_get_free_ipr_cmnd(ioa_cfg);
791                 list_add_tail(&ipr_cmd->queue, &ioa_cfg->pending_q);
792                 list_add_tail(&hostrcb->queue, &ioa_cfg->hostrcb_pending_q);
793
794                 ipr_cmd->u.hostrcb = hostrcb;
795                 ioarcb = &ipr_cmd->ioarcb;
796
797                 ioarcb->res_handle = cpu_to_be32(IPR_IOA_RES_HANDLE);
798                 ioarcb->cmd_pkt.request_type = IPR_RQTYPE_HCAM;
799                 ioarcb->cmd_pkt.cdb[0] = IPR_HOST_CONTROLLED_ASYNC;
800                 ioarcb->cmd_pkt.cdb[1] = type;
801                 ioarcb->cmd_pkt.cdb[7] = (sizeof(hostrcb->hcam) >> 8) & 0xff;
802                 ioarcb->cmd_pkt.cdb[8] = sizeof(hostrcb->hcam) & 0xff;
803
804                 ioarcb->read_data_transfer_length = cpu_to_be32(sizeof(hostrcb->hcam));
805                 ioarcb->read_ioadl_len = cpu_to_be32(sizeof(struct ipr_ioadl_desc));
806                 ipr_cmd->ioadl[0].flags_and_data_len =
807                         cpu_to_be32(IPR_IOADL_FLAGS_READ_LAST | sizeof(hostrcb->hcam));
808                 ipr_cmd->ioadl[0].address = cpu_to_be32(hostrcb->hostrcb_dma);
809
810                 if (type == IPR_HCAM_CDB_OP_CODE_CONFIG_CHANGE)
811                         ipr_cmd->done = ipr_process_ccn;
812                 else
813                         ipr_cmd->done = ipr_process_error;
814
815                 ipr_trc_hook(ipr_cmd, IPR_TRACE_START, IPR_IOA_RES_ADDR);
816
817                 mb();
818                 writel(be32_to_cpu(ipr_cmd->ioarcb.ioarcb_host_pci_addr),
819                        ioa_cfg->regs.ioarrin_reg);
820         } else {
821                 list_add_tail(&hostrcb->queue, &ioa_cfg->hostrcb_free_q);
822         }
823 }
824
825 /**
826  * ipr_init_res_entry - Initialize a resource entry struct.
827  * @res:        resource entry struct
828  *
829  * Return value:
830  *      none
831  **/
832 static void ipr_init_res_entry(struct ipr_resource_entry *res)
833 {
834         res->needs_sync_complete = 0;
835         res->in_erp = 0;
836         res->add_to_ml = 0;
837         res->del_from_ml = 0;
838         res->resetting_device = 0;
839         res->sdev = NULL;
840         res->sata_port = NULL;
841 }
842
843 /**
844  * ipr_handle_config_change - Handle a config change from the adapter
845  * @ioa_cfg:    ioa config struct
846  * @hostrcb:    hostrcb
847  *
848  * Return value:
849  *      none
850  **/
851 static void ipr_handle_config_change(struct ipr_ioa_cfg *ioa_cfg,
852                               struct ipr_hostrcb *hostrcb)
853 {
854         struct ipr_resource_entry *res = NULL;
855         struct ipr_config_table_entry *cfgte;
856         u32 is_ndn = 1;
857
858         cfgte = &hostrcb->hcam.u.ccn.cfgte;
859
860         list_for_each_entry(res, &ioa_cfg->used_res_q, queue) {
861                 if (!memcmp(&res->cfgte.res_addr, &cfgte->res_addr,
862                             sizeof(cfgte->res_addr))) {
863                         is_ndn = 0;
864                         break;
865                 }
866         }
867
868         if (is_ndn) {
869                 if (list_empty(&ioa_cfg->free_res_q)) {
870                         ipr_send_hcam(ioa_cfg,
871                                       IPR_HCAM_CDB_OP_CODE_CONFIG_CHANGE,
872                                       hostrcb);
873                         return;
874                 }
875
876                 res = list_entry(ioa_cfg->free_res_q.next,
877                                  struct ipr_resource_entry, queue);
878
879                 list_del(&res->queue);
880                 ipr_init_res_entry(res);
881                 list_add_tail(&res->queue, &ioa_cfg->used_res_q);
882         }
883
884         memcpy(&res->cfgte, cfgte, sizeof(struct ipr_config_table_entry));
885
886         if (hostrcb->hcam.notify_type == IPR_HOST_RCB_NOTIF_TYPE_REM_ENTRY) {
887                 if (res->sdev) {
888                         res->del_from_ml = 1;
889                         res->cfgte.res_handle = IPR_INVALID_RES_HANDLE;
890                         if (ioa_cfg->allow_ml_add_del)
891                                 schedule_work(&ioa_cfg->work_q);
892                 } else
893                         list_move_tail(&res->queue, &ioa_cfg->free_res_q);
894         } else if (!res->sdev) {
895                 res->add_to_ml = 1;
896                 if (ioa_cfg->allow_ml_add_del)
897                         schedule_work(&ioa_cfg->work_q);
898         }
899
900         ipr_send_hcam(ioa_cfg, IPR_HCAM_CDB_OP_CODE_CONFIG_CHANGE, hostrcb);
901 }
902
903 /**
904  * ipr_process_ccn - Op done function for a CCN.
905  * @ipr_cmd:    ipr command struct
906  *
907  * This function is the op done function for a configuration
908  * change notification host controlled async from the adapter.
909  *
910  * Return value:
911  *      none
912  **/
913 static void ipr_process_ccn(struct ipr_cmnd *ipr_cmd)
914 {
915         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
916         struct ipr_hostrcb *hostrcb = ipr_cmd->u.hostrcb;
917         u32 ioasc = be32_to_cpu(ipr_cmd->ioasa.ioasc);
918
919         list_del(&hostrcb->queue);
920         list_add_tail(&ipr_cmd->queue, &ioa_cfg->free_q);
921
922         if (ioasc) {
923                 if (ioasc != IPR_IOASC_IOA_WAS_RESET)
924                         dev_err(&ioa_cfg->pdev->dev,
925                                 "Host RCB failed with IOASC: 0x%08X\n", ioasc);
926
927                 ipr_send_hcam(ioa_cfg, IPR_HCAM_CDB_OP_CODE_CONFIG_CHANGE, hostrcb);
928         } else {
929                 ipr_handle_config_change(ioa_cfg, hostrcb);
930         }
931 }
932
933 /**
934  * strip_and_pad_whitespace - Strip and pad trailing whitespace.
935  * @i:          index into buffer
936  * @buf:                string to modify
937  *
938  * This function will strip all trailing whitespace, pad the end
939  * of the string with a single space, and NULL terminate the string.
940  *
941  * Return value:
942  *      new length of string
943  **/
944 static int strip_and_pad_whitespace(int i, char *buf)
945 {
946         while (i && buf[i] == ' ')
947                 i--;
948         buf[i+1] = ' ';
949         buf[i+2] = '\0';
950         return i + 2;
951 }
952
953 /**
954  * ipr_log_vpd_compact - Log the passed extended VPD compactly.
955  * @prefix:             string to print at start of printk
956  * @hostrcb:    hostrcb pointer
957  * @vpd:                vendor/product id/sn struct
958  *
959  * Return value:
960  *      none
961  **/
962 static void ipr_log_vpd_compact(char *prefix, struct ipr_hostrcb *hostrcb,
963                                 struct ipr_vpd *vpd)
964 {
965         char buffer[IPR_VENDOR_ID_LEN + IPR_PROD_ID_LEN + IPR_SERIAL_NUM_LEN + 3];
966         int i = 0;
967
968         memcpy(buffer, vpd->vpids.vendor_id, IPR_VENDOR_ID_LEN);
969         i = strip_and_pad_whitespace(IPR_VENDOR_ID_LEN - 1, buffer);
970
971         memcpy(&buffer[i], vpd->vpids.product_id, IPR_PROD_ID_LEN);
972         i = strip_and_pad_whitespace(i + IPR_PROD_ID_LEN - 1, buffer);
973
974         memcpy(&buffer[i], vpd->sn, IPR_SERIAL_NUM_LEN);
975         buffer[IPR_SERIAL_NUM_LEN + i] = '\0';
976
977         ipr_hcam_err(hostrcb, "%s VPID/SN: %s\n", prefix, buffer);
978 }
979
980 /**
981  * ipr_log_vpd - Log the passed VPD to the error log.
982  * @vpd:                vendor/product id/sn struct
983  *
984  * Return value:
985  *      none
986  **/
987 static void ipr_log_vpd(struct ipr_vpd *vpd)
988 {
989         char buffer[IPR_VENDOR_ID_LEN + IPR_PROD_ID_LEN
990                     + IPR_SERIAL_NUM_LEN];
991
992         memcpy(buffer, vpd->vpids.vendor_id, IPR_VENDOR_ID_LEN);
993         memcpy(buffer + IPR_VENDOR_ID_LEN, vpd->vpids.product_id,
994                IPR_PROD_ID_LEN);
995         buffer[IPR_VENDOR_ID_LEN + IPR_PROD_ID_LEN] = '\0';
996         ipr_err("Vendor/Product ID: %s\n", buffer);
997
998         memcpy(buffer, vpd->sn, IPR_SERIAL_NUM_LEN);
999         buffer[IPR_SERIAL_NUM_LEN] = '\0';
1000         ipr_err("    Serial Number: %s\n", buffer);
1001 }
1002
1003 /**
1004  * ipr_log_ext_vpd_compact - Log the passed extended VPD compactly.
1005  * @prefix:             string to print at start of printk
1006  * @hostrcb:    hostrcb pointer
1007  * @vpd:                vendor/product id/sn/wwn struct
1008  *
1009  * Return value:
1010  *      none
1011  **/
1012 static void ipr_log_ext_vpd_compact(char *prefix, struct ipr_hostrcb *hostrcb,
1013                                     struct ipr_ext_vpd *vpd)
1014 {
1015         ipr_log_vpd_compact(prefix, hostrcb, &vpd->vpd);
1016         ipr_hcam_err(hostrcb, "%s WWN: %08X%08X\n", prefix,
1017                      be32_to_cpu(vpd->wwid[0]), be32_to_cpu(vpd->wwid[1]));
1018 }
1019
1020 /**
1021  * ipr_log_ext_vpd - Log the passed extended VPD to the error log.
1022  * @vpd:                vendor/product id/sn/wwn struct
1023  *
1024  * Return value:
1025  *      none
1026  **/
1027 static void ipr_log_ext_vpd(struct ipr_ext_vpd *vpd)
1028 {
1029         ipr_log_vpd(&vpd->vpd);
1030         ipr_err("    WWN: %08X%08X\n", be32_to_cpu(vpd->wwid[0]),
1031                 be32_to_cpu(vpd->wwid[1]));
1032 }
1033
1034 /**
1035  * ipr_log_enhanced_cache_error - Log a cache error.
1036  * @ioa_cfg:    ioa config struct
1037  * @hostrcb:    hostrcb struct
1038  *
1039  * Return value:
1040  *      none
1041  **/
1042 static void ipr_log_enhanced_cache_error(struct ipr_ioa_cfg *ioa_cfg,
1043                                          struct ipr_hostrcb *hostrcb)
1044 {
1045         struct ipr_hostrcb_type_12_error *error =
1046                 &hostrcb->hcam.u.error.u.type_12_error;
1047
1048         ipr_err("-----Current Configuration-----\n");
1049         ipr_err("Cache Directory Card Information:\n");
1050         ipr_log_ext_vpd(&error->ioa_vpd);
1051         ipr_err("Adapter Card Information:\n");
1052         ipr_log_ext_vpd(&error->cfc_vpd);
1053
1054         ipr_err("-----Expected Configuration-----\n");
1055         ipr_err("Cache Directory Card Information:\n");
1056         ipr_log_ext_vpd(&error->ioa_last_attached_to_cfc_vpd);
1057         ipr_err("Adapter Card Information:\n");
1058         ipr_log_ext_vpd(&error->cfc_last_attached_to_ioa_vpd);
1059
1060         ipr_err("Additional IOA Data: %08X %08X %08X\n",
1061                      be32_to_cpu(error->ioa_data[0]),
1062                      be32_to_cpu(error->ioa_data[1]),
1063                      be32_to_cpu(error->ioa_data[2]));
1064 }
1065
1066 /**
1067  * ipr_log_cache_error - Log a cache error.
1068  * @ioa_cfg:    ioa config struct
1069  * @hostrcb:    hostrcb struct
1070  *
1071  * Return value:
1072  *      none
1073  **/
1074 static void ipr_log_cache_error(struct ipr_ioa_cfg *ioa_cfg,
1075                                 struct ipr_hostrcb *hostrcb)
1076 {
1077         struct ipr_hostrcb_type_02_error *error =
1078                 &hostrcb->hcam.u.error.u.type_02_error;
1079
1080         ipr_err("-----Current Configuration-----\n");
1081         ipr_err("Cache Directory Card Information:\n");
1082         ipr_log_vpd(&error->ioa_vpd);
1083         ipr_err("Adapter Card Information:\n");
1084         ipr_log_vpd(&error->cfc_vpd);
1085
1086         ipr_err("-----Expected Configuration-----\n");
1087         ipr_err("Cache Directory Card Information:\n");
1088         ipr_log_vpd(&error->ioa_last_attached_to_cfc_vpd);
1089         ipr_err("Adapter Card Information:\n");
1090         ipr_log_vpd(&error->cfc_last_attached_to_ioa_vpd);
1091
1092         ipr_err("Additional IOA Data: %08X %08X %08X\n",
1093                      be32_to_cpu(error->ioa_data[0]),
1094                      be32_to_cpu(error->ioa_data[1]),
1095                      be32_to_cpu(error->ioa_data[2]));
1096 }
1097
1098 /**
1099  * ipr_log_enhanced_config_error - Log a configuration error.
1100  * @ioa_cfg:    ioa config struct
1101  * @hostrcb:    hostrcb struct
1102  *
1103  * Return value:
1104  *      none
1105  **/
1106 static void ipr_log_enhanced_config_error(struct ipr_ioa_cfg *ioa_cfg,
1107                                           struct ipr_hostrcb *hostrcb)
1108 {
1109         int errors_logged, i;
1110         struct ipr_hostrcb_device_data_entry_enhanced *dev_entry;
1111         struct ipr_hostrcb_type_13_error *error;
1112
1113         error = &hostrcb->hcam.u.error.u.type_13_error;
1114         errors_logged = be32_to_cpu(error->errors_logged);
1115
1116         ipr_err("Device Errors Detected/Logged: %d/%d\n",
1117                 be32_to_cpu(error->errors_detected), errors_logged);
1118
1119         dev_entry = error->dev;
1120
1121         for (i = 0; i < errors_logged; i++, dev_entry++) {
1122                 ipr_err_separator;
1123
1124                 ipr_phys_res_err(ioa_cfg, dev_entry->dev_res_addr, "Device %d", i + 1);
1125                 ipr_log_ext_vpd(&dev_entry->vpd);
1126
1127                 ipr_err("-----New Device Information-----\n");
1128                 ipr_log_ext_vpd(&dev_entry->new_vpd);
1129
1130                 ipr_err("Cache Directory Card Information:\n");
1131                 ipr_log_ext_vpd(&dev_entry->ioa_last_with_dev_vpd);
1132
1133                 ipr_err("Adapter Card Information:\n");
1134                 ipr_log_ext_vpd(&dev_entry->cfc_last_with_dev_vpd);
1135         }
1136 }
1137
1138 /**
1139  * ipr_log_config_error - Log a configuration error.
1140  * @ioa_cfg:    ioa config struct
1141  * @hostrcb:    hostrcb struct
1142  *
1143  * Return value:
1144  *      none
1145  **/
1146 static void ipr_log_config_error(struct ipr_ioa_cfg *ioa_cfg,
1147                                  struct ipr_hostrcb *hostrcb)
1148 {
1149         int errors_logged, i;
1150         struct ipr_hostrcb_device_data_entry *dev_entry;
1151         struct ipr_hostrcb_type_03_error *error;
1152
1153         error = &hostrcb->hcam.u.error.u.type_03_error;
1154         errors_logged = be32_to_cpu(error->errors_logged);
1155
1156         ipr_err("Device Errors Detected/Logged: %d/%d\n",
1157                 be32_to_cpu(error->errors_detected), errors_logged);
1158
1159         dev_entry = error->dev;
1160
1161         for (i = 0; i < errors_logged; i++, dev_entry++) {
1162                 ipr_err_separator;
1163
1164                 ipr_phys_res_err(ioa_cfg, dev_entry->dev_res_addr, "Device %d", i + 1);
1165                 ipr_log_vpd(&dev_entry->vpd);
1166
1167                 ipr_err("-----New Device Information-----\n");
1168                 ipr_log_vpd(&dev_entry->new_vpd);
1169
1170                 ipr_err("Cache Directory Card Information:\n");
1171                 ipr_log_vpd(&dev_entry->ioa_last_with_dev_vpd);
1172
1173                 ipr_err("Adapter Card Information:\n");
1174                 ipr_log_vpd(&dev_entry->cfc_last_with_dev_vpd);
1175
1176                 ipr_err("Additional IOA Data: %08X %08X %08X %08X %08X\n",
1177                         be32_to_cpu(dev_entry->ioa_data[0]),
1178                         be32_to_cpu(dev_entry->ioa_data[1]),
1179                         be32_to_cpu(dev_entry->ioa_data[2]),
1180                         be32_to_cpu(dev_entry->ioa_data[3]),
1181                         be32_to_cpu(dev_entry->ioa_data[4]));
1182         }
1183 }
1184
1185 /**
1186  * ipr_log_enhanced_array_error - Log an array configuration error.
1187  * @ioa_cfg:    ioa config struct
1188  * @hostrcb:    hostrcb struct
1189  *
1190  * Return value:
1191  *      none
1192  **/
1193 static void ipr_log_enhanced_array_error(struct ipr_ioa_cfg *ioa_cfg,
1194                                          struct ipr_hostrcb *hostrcb)
1195 {
1196         int i, num_entries;
1197         struct ipr_hostrcb_type_14_error *error;
1198         struct ipr_hostrcb_array_data_entry_enhanced *array_entry;
1199         const u8 zero_sn[IPR_SERIAL_NUM_LEN] = { [0 ... IPR_SERIAL_NUM_LEN-1] = '0' };
1200
1201         error = &hostrcb->hcam.u.error.u.type_14_error;
1202
1203         ipr_err_separator;
1204
1205         ipr_err("RAID %s Array Configuration: %d:%d:%d:%d\n",
1206                 error->protection_level,
1207                 ioa_cfg->host->host_no,
1208                 error->last_func_vset_res_addr.bus,
1209                 error->last_func_vset_res_addr.target,
1210                 error->last_func_vset_res_addr.lun);
1211
1212         ipr_err_separator;
1213
1214         array_entry = error->array_member;
1215         num_entries = min_t(u32, be32_to_cpu(error->num_entries),
1216                             sizeof(error->array_member));
1217
1218         for (i = 0; i < num_entries; i++, array_entry++) {
1219                 if (!memcmp(array_entry->vpd.vpd.sn, zero_sn, IPR_SERIAL_NUM_LEN))
1220                         continue;
1221
1222                 if (be32_to_cpu(error->exposed_mode_adn) == i)
1223                         ipr_err("Exposed Array Member %d:\n", i);
1224                 else
1225                         ipr_err("Array Member %d:\n", i);
1226
1227                 ipr_log_ext_vpd(&array_entry->vpd);
1228                 ipr_phys_res_err(ioa_cfg, array_entry->dev_res_addr, "Current Location");
1229                 ipr_phys_res_err(ioa_cfg, array_entry->expected_dev_res_addr,
1230                                  "Expected Location");
1231
1232                 ipr_err_separator;
1233         }
1234 }
1235
1236 /**
1237  * ipr_log_array_error - Log an array configuration error.
1238  * @ioa_cfg:    ioa config struct
1239  * @hostrcb:    hostrcb struct
1240  *
1241  * Return value:
1242  *      none
1243  **/
1244 static void ipr_log_array_error(struct ipr_ioa_cfg *ioa_cfg,
1245                                 struct ipr_hostrcb *hostrcb)
1246 {
1247         int i;
1248         struct ipr_hostrcb_type_04_error *error;
1249         struct ipr_hostrcb_array_data_entry *array_entry;
1250         const u8 zero_sn[IPR_SERIAL_NUM_LEN] = { [0 ... IPR_SERIAL_NUM_LEN-1] = '0' };
1251
1252         error = &hostrcb->hcam.u.error.u.type_04_error;
1253
1254         ipr_err_separator;
1255
1256         ipr_err("RAID %s Array Configuration: %d:%d:%d:%d\n",
1257                 error->protection_level,
1258                 ioa_cfg->host->host_no,
1259                 error->last_func_vset_res_addr.bus,
1260                 error->last_func_vset_res_addr.target,
1261                 error->last_func_vset_res_addr.lun);
1262
1263         ipr_err_separator;
1264
1265         array_entry = error->array_member;
1266
1267         for (i = 0; i < 18; i++) {
1268                 if (!memcmp(array_entry->vpd.sn, zero_sn, IPR_SERIAL_NUM_LEN))
1269                         continue;
1270
1271                 if (be32_to_cpu(error->exposed_mode_adn) == i)
1272                         ipr_err("Exposed Array Member %d:\n", i);
1273                 else
1274                         ipr_err("Array Member %d:\n", i);
1275
1276                 ipr_log_vpd(&array_entry->vpd);
1277
1278                 ipr_phys_res_err(ioa_cfg, array_entry->dev_res_addr, "Current Location");
1279                 ipr_phys_res_err(ioa_cfg, array_entry->expected_dev_res_addr,
1280                                  "Expected Location");
1281
1282                 ipr_err_separator;
1283
1284                 if (i == 9)
1285                         array_entry = error->array_member2;
1286                 else
1287                         array_entry++;
1288         }
1289 }
1290
1291 /**
1292  * ipr_log_hex_data - Log additional hex IOA error data.
1293  * @ioa_cfg:    ioa config struct
1294  * @data:               IOA error data
1295  * @len:                data length
1296  *
1297  * Return value:
1298  *      none
1299  **/
1300 static void ipr_log_hex_data(struct ipr_ioa_cfg *ioa_cfg, u32 *data, int len)
1301 {
1302         int i;
1303
1304         if (len == 0)
1305                 return;
1306
1307         if (ioa_cfg->log_level <= IPR_DEFAULT_LOG_LEVEL)
1308                 len = min_t(int, len, IPR_DEFAULT_MAX_ERROR_DUMP);
1309
1310         for (i = 0; i < len / 4; i += 4) {
1311                 ipr_err("%08X: %08X %08X %08X %08X\n", i*4,
1312                         be32_to_cpu(data[i]),
1313                         be32_to_cpu(data[i+1]),
1314                         be32_to_cpu(data[i+2]),
1315                         be32_to_cpu(data[i+3]));
1316         }
1317 }
1318
1319 /**
1320  * ipr_log_enhanced_dual_ioa_error - Log an enhanced dual adapter error.
1321  * @ioa_cfg:    ioa config struct
1322  * @hostrcb:    hostrcb struct
1323  *
1324  * Return value:
1325  *      none
1326  **/
1327 static void ipr_log_enhanced_dual_ioa_error(struct ipr_ioa_cfg *ioa_cfg,
1328                                             struct ipr_hostrcb *hostrcb)
1329 {
1330         struct ipr_hostrcb_type_17_error *error;
1331
1332         error = &hostrcb->hcam.u.error.u.type_17_error;
1333         error->failure_reason[sizeof(error->failure_reason) - 1] = '\0';
1334         strstrip(error->failure_reason);
1335
1336         ipr_hcam_err(hostrcb, "%s [PRC: %08X]\n", error->failure_reason,
1337                      be32_to_cpu(hostrcb->hcam.u.error.prc));
1338         ipr_log_ext_vpd_compact("Remote IOA", hostrcb, &error->vpd);
1339         ipr_log_hex_data(ioa_cfg, error->data,
1340                          be32_to_cpu(hostrcb->hcam.length) -
1341                          (offsetof(struct ipr_hostrcb_error, u) +
1342                           offsetof(struct ipr_hostrcb_type_17_error, data)));
1343 }
1344
1345 /**
1346  * ipr_log_dual_ioa_error - Log a dual adapter error.
1347  * @ioa_cfg:    ioa config struct
1348  * @hostrcb:    hostrcb struct
1349  *
1350  * Return value:
1351  *      none
1352  **/
1353 static void ipr_log_dual_ioa_error(struct ipr_ioa_cfg *ioa_cfg,
1354                                    struct ipr_hostrcb *hostrcb)
1355 {
1356         struct ipr_hostrcb_type_07_error *error;
1357
1358         error = &hostrcb->hcam.u.error.u.type_07_error;
1359         error->failure_reason[sizeof(error->failure_reason) - 1] = '\0';
1360         strstrip(error->failure_reason);
1361
1362         ipr_hcam_err(hostrcb, "%s [PRC: %08X]\n", error->failure_reason,
1363                      be32_to_cpu(hostrcb->hcam.u.error.prc));
1364         ipr_log_vpd_compact("Remote IOA", hostrcb, &error->vpd);
1365         ipr_log_hex_data(ioa_cfg, error->data,
1366                          be32_to_cpu(hostrcb->hcam.length) -
1367                          (offsetof(struct ipr_hostrcb_error, u) +
1368                           offsetof(struct ipr_hostrcb_type_07_error, data)));
1369 }
1370
1371 static const struct {
1372         u8 active;
1373         char *desc;
1374 } path_active_desc[] = {
1375         { IPR_PATH_NO_INFO, "Path" },
1376         { IPR_PATH_ACTIVE, "Active path" },
1377         { IPR_PATH_NOT_ACTIVE, "Inactive path" }
1378 };
1379
1380 static const struct {
1381         u8 state;
1382         char *desc;
1383 } path_state_desc[] = {
1384         { IPR_PATH_STATE_NO_INFO, "has no path state information available" },
1385         { IPR_PATH_HEALTHY, "is healthy" },
1386         { IPR_PATH_DEGRADED, "is degraded" },
1387         { IPR_PATH_FAILED, "is failed" }
1388 };
1389
1390 /**
1391  * ipr_log_fabric_path - Log a fabric path error
1392  * @hostrcb:    hostrcb struct
1393  * @fabric:             fabric descriptor
1394  *
1395  * Return value:
1396  *      none
1397  **/
1398 static void ipr_log_fabric_path(struct ipr_hostrcb *hostrcb,
1399                                 struct ipr_hostrcb_fabric_desc *fabric)
1400 {
1401         int i, j;
1402         u8 path_state = fabric->path_state;
1403         u8 active = path_state & IPR_PATH_ACTIVE_MASK;
1404         u8 state = path_state & IPR_PATH_STATE_MASK;
1405
1406         for (i = 0; i < ARRAY_SIZE(path_active_desc); i++) {
1407                 if (path_active_desc[i].active != active)
1408                         continue;
1409
1410                 for (j = 0; j < ARRAY_SIZE(path_state_desc); j++) {
1411                         if (path_state_desc[j].state != state)
1412                                 continue;
1413
1414                         if (fabric->cascaded_expander == 0xff && fabric->phy == 0xff) {
1415                                 ipr_hcam_err(hostrcb, "%s %s: IOA Port=%d\n",
1416                                              path_active_desc[i].desc, path_state_desc[j].desc,
1417                                              fabric->ioa_port);
1418                         } else if (fabric->cascaded_expander == 0xff) {
1419                                 ipr_hcam_err(hostrcb, "%s %s: IOA Port=%d, Phy=%d\n",
1420                                              path_active_desc[i].desc, path_state_desc[j].desc,
1421                                              fabric->ioa_port, fabric->phy);
1422                         } else if (fabric->phy == 0xff) {
1423                                 ipr_hcam_err(hostrcb, "%s %s: IOA Port=%d, Cascade=%d\n",
1424                                              path_active_desc[i].desc, path_state_desc[j].desc,
1425                                              fabric->ioa_port, fabric->cascaded_expander);
1426                         } else {
1427                                 ipr_hcam_err(hostrcb, "%s %s: IOA Port=%d, Cascade=%d, Phy=%d\n",
1428                                              path_active_desc[i].desc, path_state_desc[j].desc,
1429                                              fabric->ioa_port, fabric->cascaded_expander, fabric->phy);
1430                         }
1431                         return;
1432                 }
1433         }
1434
1435         ipr_err("Path state=%02X IOA Port=%d Cascade=%d Phy=%d\n", path_state,
1436                 fabric->ioa_port, fabric->cascaded_expander, fabric->phy);
1437 }
1438
1439 static const struct {
1440         u8 type;
1441         char *desc;
1442 } path_type_desc[] = {
1443         { IPR_PATH_CFG_IOA_PORT, "IOA port" },
1444         { IPR_PATH_CFG_EXP_PORT, "Expander port" },
1445         { IPR_PATH_CFG_DEVICE_PORT, "Device port" },
1446         { IPR_PATH_CFG_DEVICE_LUN, "Device LUN" }
1447 };
1448
1449 static const struct {
1450         u8 status;
1451         char *desc;
1452 } path_status_desc[] = {
1453         { IPR_PATH_CFG_NO_PROB, "Functional" },
1454         { IPR_PATH_CFG_DEGRADED, "Degraded" },
1455         { IPR_PATH_CFG_FAILED, "Failed" },
1456         { IPR_PATH_CFG_SUSPECT, "Suspect" },
1457         { IPR_PATH_NOT_DETECTED, "Missing" },
1458         { IPR_PATH_INCORRECT_CONN, "Incorrectly connected" }
1459 };
1460
1461 static const char *link_rate[] = {
1462         "unknown",
1463         "disabled",
1464         "phy reset problem",
1465         "spinup hold",
1466         "port selector",
1467         "unknown",
1468         "unknown",
1469         "unknown",
1470         "1.5Gbps",
1471         "3.0Gbps",
1472         "unknown",
1473         "unknown",
1474         "unknown",
1475         "unknown",
1476         "unknown",
1477         "unknown"
1478 };
1479
1480 /**
1481  * ipr_log_path_elem - Log a fabric path element.
1482  * @hostrcb:    hostrcb struct
1483  * @cfg:                fabric path element struct
1484  *
1485  * Return value:
1486  *      none
1487  **/
1488 static void ipr_log_path_elem(struct ipr_hostrcb *hostrcb,
1489                               struct ipr_hostrcb_config_element *cfg)
1490 {
1491         int i, j;
1492         u8 type = cfg->type_status & IPR_PATH_CFG_TYPE_MASK;
1493         u8 status = cfg->type_status & IPR_PATH_CFG_STATUS_MASK;
1494
1495         if (type == IPR_PATH_CFG_NOT_EXIST)
1496                 return;
1497
1498         for (i = 0; i < ARRAY_SIZE(path_type_desc); i++) {
1499                 if (path_type_desc[i].type != type)
1500                         continue;
1501
1502                 for (j = 0; j < ARRAY_SIZE(path_status_desc); j++) {
1503                         if (path_status_desc[j].status != status)
1504                                 continue;
1505
1506                         if (type == IPR_PATH_CFG_IOA_PORT) {
1507                                 ipr_hcam_err(hostrcb, "%s %s: Phy=%d, Link rate=%s, WWN=%08X%08X\n",
1508                                              path_status_desc[j].desc, path_type_desc[i].desc,
1509                                              cfg->phy, link_rate[cfg->link_rate & IPR_PHY_LINK_RATE_MASK],
1510                                              be32_to_cpu(cfg->wwid[0]), be32_to_cpu(cfg->wwid[1]));
1511                         } else {
1512                                 if (cfg->cascaded_expander == 0xff && cfg->phy == 0xff) {
1513                                         ipr_hcam_err(hostrcb, "%s %s: Link rate=%s, WWN=%08X%08X\n",
1514                                                      path_status_desc[j].desc, path_type_desc[i].desc,
1515                                                      link_rate[cfg->link_rate & IPR_PHY_LINK_RATE_MASK],
1516                                                      be32_to_cpu(cfg->wwid[0]), be32_to_cpu(cfg->wwid[1]));
1517                                 } else if (cfg->cascaded_expander == 0xff) {
1518                                         ipr_hcam_err(hostrcb, "%s %s: Phy=%d, Link rate=%s, "
1519                                                      "WWN=%08X%08X\n", path_status_desc[j].desc,
1520                                                      path_type_desc[i].desc, cfg->phy,
1521                                                      link_rate[cfg->link_rate & IPR_PHY_LINK_RATE_MASK],
1522                                                      be32_to_cpu(cfg->wwid[0]), be32_to_cpu(cfg->wwid[1]));
1523                                 } else if (cfg->phy == 0xff) {
1524                                         ipr_hcam_err(hostrcb, "%s %s: Cascade=%d, Link rate=%s, "
1525                                                      "WWN=%08X%08X\n", path_status_desc[j].desc,
1526                                                      path_type_desc[i].desc, cfg->cascaded_expander,
1527                                                      link_rate[cfg->link_rate & IPR_PHY_LINK_RATE_MASK],
1528                                                      be32_to_cpu(cfg->wwid[0]), be32_to_cpu(cfg->wwid[1]));
1529                                 } else {
1530                                         ipr_hcam_err(hostrcb, "%s %s: Cascade=%d, Phy=%d, Link rate=%s "
1531                                                      "WWN=%08X%08X\n", path_status_desc[j].desc,
1532                                                      path_type_desc[i].desc, cfg->cascaded_expander, cfg->phy,
1533                                                      link_rate[cfg->link_rate & IPR_PHY_LINK_RATE_MASK],
1534                                                      be32_to_cpu(cfg->wwid[0]), be32_to_cpu(cfg->wwid[1]));
1535                                 }
1536                         }
1537                         return;
1538                 }
1539         }
1540
1541         ipr_hcam_err(hostrcb, "Path element=%02X: Cascade=%d Phy=%d Link rate=%s "
1542                      "WWN=%08X%08X\n", cfg->type_status, cfg->cascaded_expander, cfg->phy,
1543                      link_rate[cfg->link_rate & IPR_PHY_LINK_RATE_MASK],
1544                      be32_to_cpu(cfg->wwid[0]), be32_to_cpu(cfg->wwid[1]));
1545 }
1546
1547 /**
1548  * ipr_log_fabric_error - Log a fabric error.
1549  * @ioa_cfg:    ioa config struct
1550  * @hostrcb:    hostrcb struct
1551  *
1552  * Return value:
1553  *      none
1554  **/
1555 static void ipr_log_fabric_error(struct ipr_ioa_cfg *ioa_cfg,
1556                                  struct ipr_hostrcb *hostrcb)
1557 {
1558         struct ipr_hostrcb_type_20_error *error;
1559         struct ipr_hostrcb_fabric_desc *fabric;
1560         struct ipr_hostrcb_config_element *cfg;
1561         int i, add_len;
1562
1563         error = &hostrcb->hcam.u.error.u.type_20_error;
1564         error->failure_reason[sizeof(error->failure_reason) - 1] = '\0';
1565         ipr_hcam_err(hostrcb, "%s\n", error->failure_reason);
1566
1567         add_len = be32_to_cpu(hostrcb->hcam.length) -
1568                 (offsetof(struct ipr_hostrcb_error, u) +
1569                  offsetof(struct ipr_hostrcb_type_20_error, desc));
1570
1571         for (i = 0, fabric = error->desc; i < error->num_entries; i++) {
1572                 ipr_log_fabric_path(hostrcb, fabric);
1573                 for_each_fabric_cfg(fabric, cfg)
1574                         ipr_log_path_elem(hostrcb, cfg);
1575
1576                 add_len -= be16_to_cpu(fabric->length);
1577                 fabric = (struct ipr_hostrcb_fabric_desc *)
1578                         ((unsigned long)fabric + be16_to_cpu(fabric->length));
1579         }
1580
1581         ipr_log_hex_data(ioa_cfg, (u32 *)fabric, add_len);
1582 }
1583
1584 /**
1585  * ipr_log_generic_error - Log an adapter error.
1586  * @ioa_cfg:    ioa config struct
1587  * @hostrcb:    hostrcb struct
1588  *
1589  * Return value:
1590  *      none
1591  **/
1592 static void ipr_log_generic_error(struct ipr_ioa_cfg *ioa_cfg,
1593                                   struct ipr_hostrcb *hostrcb)
1594 {
1595         ipr_log_hex_data(ioa_cfg, hostrcb->hcam.u.raw.data,
1596                          be32_to_cpu(hostrcb->hcam.length));
1597 }
1598
1599 /**
1600  * ipr_get_error - Find the specfied IOASC in the ipr_error_table.
1601  * @ioasc:      IOASC
1602  *
1603  * This function will return the index of into the ipr_error_table
1604  * for the specified IOASC. If the IOASC is not in the table,
1605  * 0 will be returned, which points to the entry used for unknown errors.
1606  *
1607  * Return value:
1608  *      index into the ipr_error_table
1609  **/
1610 static u32 ipr_get_error(u32 ioasc)
1611 {
1612         int i;
1613
1614         for (i = 0; i < ARRAY_SIZE(ipr_error_table); i++)
1615                 if (ipr_error_table[i].ioasc == (ioasc & IPR_IOASC_IOASC_MASK))
1616                         return i;
1617
1618         return 0;
1619 }
1620
1621 /**
1622  * ipr_handle_log_data - Log an adapter error.
1623  * @ioa_cfg:    ioa config struct
1624  * @hostrcb:    hostrcb struct
1625  *
1626  * This function logs an adapter error to the system.
1627  *
1628  * Return value:
1629  *      none
1630  **/
1631 static void ipr_handle_log_data(struct ipr_ioa_cfg *ioa_cfg,
1632                                 struct ipr_hostrcb *hostrcb)
1633 {
1634         u32 ioasc;
1635         int error_index;
1636
1637         if (hostrcb->hcam.notify_type != IPR_HOST_RCB_NOTIF_TYPE_ERROR_LOG_ENTRY)
1638                 return;
1639
1640         if (hostrcb->hcam.notifications_lost == IPR_HOST_RCB_NOTIFICATIONS_LOST)
1641                 dev_err(&ioa_cfg->pdev->dev, "Error notifications lost\n");
1642
1643         ioasc = be32_to_cpu(hostrcb->hcam.u.error.failing_dev_ioasc);
1644
1645         if (ioasc == IPR_IOASC_BUS_WAS_RESET ||
1646             ioasc == IPR_IOASC_BUS_WAS_RESET_BY_OTHER) {
1647                 /* Tell the midlayer we had a bus reset so it will handle the UA properly */
1648                 scsi_report_bus_reset(ioa_cfg->host,
1649                                       hostrcb->hcam.u.error.failing_dev_res_addr.bus);
1650         }
1651
1652         error_index = ipr_get_error(ioasc);
1653
1654         if (!ipr_error_table[error_index].log_hcam)
1655                 return;
1656
1657         ipr_hcam_err(hostrcb, "%s\n", ipr_error_table[error_index].error);
1658
1659         /* Set indication we have logged an error */
1660         ioa_cfg->errors_logged++;
1661
1662         if (ioa_cfg->log_level < ipr_error_table[error_index].log_hcam)
1663                 return;
1664         if (be32_to_cpu(hostrcb->hcam.length) > sizeof(hostrcb->hcam.u.raw))
1665                 hostrcb->hcam.length = cpu_to_be32(sizeof(hostrcb->hcam.u.raw));
1666
1667         switch (hostrcb->hcam.overlay_id) {
1668         case IPR_HOST_RCB_OVERLAY_ID_2:
1669                 ipr_log_cache_error(ioa_cfg, hostrcb);
1670                 break;
1671         case IPR_HOST_RCB_OVERLAY_ID_3:
1672                 ipr_log_config_error(ioa_cfg, hostrcb);
1673                 break;
1674         case IPR_HOST_RCB_OVERLAY_ID_4:
1675         case IPR_HOST_RCB_OVERLAY_ID_6:
1676                 ipr_log_array_error(ioa_cfg, hostrcb);
1677                 break;
1678         case IPR_HOST_RCB_OVERLAY_ID_7:
1679                 ipr_log_dual_ioa_error(ioa_cfg, hostrcb);
1680                 break;
1681         case IPR_HOST_RCB_OVERLAY_ID_12:
1682                 ipr_log_enhanced_cache_error(ioa_cfg, hostrcb);
1683                 break;
1684         case IPR_HOST_RCB_OVERLAY_ID_13:
1685                 ipr_log_enhanced_config_error(ioa_cfg, hostrcb);
1686                 break;
1687         case IPR_HOST_RCB_OVERLAY_ID_14:
1688         case IPR_HOST_RCB_OVERLAY_ID_16:
1689                 ipr_log_enhanced_array_error(ioa_cfg, hostrcb);
1690                 break;
1691         case IPR_HOST_RCB_OVERLAY_ID_17:
1692                 ipr_log_enhanced_dual_ioa_error(ioa_cfg, hostrcb);
1693                 break;
1694         case IPR_HOST_RCB_OVERLAY_ID_20:
1695                 ipr_log_fabric_error(ioa_cfg, hostrcb);
1696                 break;
1697         case IPR_HOST_RCB_OVERLAY_ID_1:
1698         case IPR_HOST_RCB_OVERLAY_ID_DEFAULT:
1699         default:
1700                 ipr_log_generic_error(ioa_cfg, hostrcb);
1701                 break;
1702         }
1703 }
1704
1705 /**
1706  * ipr_process_error - Op done function for an adapter error log.
1707  * @ipr_cmd:    ipr command struct
1708  *
1709  * This function is the op done function for an error log host
1710  * controlled async from the adapter. It will log the error and
1711  * send the HCAM back to the adapter.
1712  *
1713  * Return value:
1714  *      none
1715  **/
1716 static void ipr_process_error(struct ipr_cmnd *ipr_cmd)
1717 {
1718         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
1719         struct ipr_hostrcb *hostrcb = ipr_cmd->u.hostrcb;
1720         u32 ioasc = be32_to_cpu(ipr_cmd->ioasa.ioasc);
1721         u32 fd_ioasc = be32_to_cpu(hostrcb->hcam.u.error.failing_dev_ioasc);
1722
1723         list_del(&hostrcb->queue);
1724         list_add_tail(&ipr_cmd->queue, &ioa_cfg->free_q);
1725
1726         if (!ioasc) {
1727                 ipr_handle_log_data(ioa_cfg, hostrcb);
1728                 if (fd_ioasc == IPR_IOASC_NR_IOA_RESET_REQUIRED)
1729                         ipr_initiate_ioa_reset(ioa_cfg, IPR_SHUTDOWN_ABBREV);
1730         } else if (ioasc != IPR_IOASC_IOA_WAS_RESET) {
1731                 dev_err(&ioa_cfg->pdev->dev,
1732                         "Host RCB failed with IOASC: 0x%08X\n", ioasc);
1733         }
1734
1735         ipr_send_hcam(ioa_cfg, IPR_HCAM_CDB_OP_CODE_LOG_DATA, hostrcb);
1736 }
1737
1738 /**
1739  * ipr_timeout -  An internally generated op has timed out.
1740  * @ipr_cmd:    ipr command struct
1741  *
1742  * This function blocks host requests and initiates an
1743  * adapter reset.
1744  *
1745  * Return value:
1746  *      none
1747  **/
1748 static void ipr_timeout(struct ipr_cmnd *ipr_cmd)
1749 {
1750         unsigned long lock_flags = 0;
1751         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
1752
1753         ENTER;
1754         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
1755
1756         ioa_cfg->errors_logged++;
1757         dev_err(&ioa_cfg->pdev->dev,
1758                 "Adapter being reset due to command timeout.\n");
1759
1760         if (WAIT_FOR_DUMP == ioa_cfg->sdt_state)
1761                 ioa_cfg->sdt_state = GET_DUMP;
1762
1763         if (!ioa_cfg->in_reset_reload || ioa_cfg->reset_cmd == ipr_cmd)
1764                 ipr_initiate_ioa_reset(ioa_cfg, IPR_SHUTDOWN_NONE);
1765
1766         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
1767         LEAVE;
1768 }
1769
1770 /**
1771  * ipr_oper_timeout -  Adapter timed out transitioning to operational
1772  * @ipr_cmd:    ipr command struct
1773  *
1774  * This function blocks host requests and initiates an
1775  * adapter reset.
1776  *
1777  * Return value:
1778  *      none
1779  **/
1780 static void ipr_oper_timeout(struct ipr_cmnd *ipr_cmd)
1781 {
1782         unsigned long lock_flags = 0;
1783         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
1784
1785         ENTER;
1786         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
1787
1788         ioa_cfg->errors_logged++;
1789         dev_err(&ioa_cfg->pdev->dev,
1790                 "Adapter timed out transitioning to operational.\n");
1791
1792         if (WAIT_FOR_DUMP == ioa_cfg->sdt_state)
1793                 ioa_cfg->sdt_state = GET_DUMP;
1794
1795         if (!ioa_cfg->in_reset_reload || ioa_cfg->reset_cmd == ipr_cmd) {
1796                 if (ipr_fastfail)
1797                         ioa_cfg->reset_retries += IPR_NUM_RESET_RELOAD_RETRIES;
1798                 ipr_initiate_ioa_reset(ioa_cfg, IPR_SHUTDOWN_NONE);
1799         }
1800
1801         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
1802         LEAVE;
1803 }
1804
1805 /**
1806  * ipr_reset_reload - Reset/Reload the IOA
1807  * @ioa_cfg:            ioa config struct
1808  * @shutdown_type:      shutdown type
1809  *
1810  * This function resets the adapter and re-initializes it.
1811  * This function assumes that all new host commands have been stopped.
1812  * Return value:
1813  *      SUCCESS / FAILED
1814  **/
1815 static int ipr_reset_reload(struct ipr_ioa_cfg *ioa_cfg,
1816                             enum ipr_shutdown_type shutdown_type)
1817 {
1818         if (!ioa_cfg->in_reset_reload)
1819                 ipr_initiate_ioa_reset(ioa_cfg, shutdown_type);
1820
1821         spin_unlock_irq(ioa_cfg->host->host_lock);
1822         wait_event(ioa_cfg->reset_wait_q, !ioa_cfg->in_reset_reload);
1823         spin_lock_irq(ioa_cfg->host->host_lock);
1824
1825         /* If we got hit with a host reset while we were already resetting
1826          the adapter for some reason, and the reset failed. */
1827         if (ioa_cfg->ioa_is_dead) {
1828                 ipr_trace;
1829                 return FAILED;
1830         }
1831
1832         return SUCCESS;
1833 }
1834
1835 /**
1836  * ipr_find_ses_entry - Find matching SES in SES table
1837  * @res:        resource entry struct of SES
1838  *
1839  * Return value:
1840  *      pointer to SES table entry / NULL on failure
1841  **/
1842 static const struct ipr_ses_table_entry *
1843 ipr_find_ses_entry(struct ipr_resource_entry *res)
1844 {
1845         int i, j, matches;
1846         const struct ipr_ses_table_entry *ste = ipr_ses_table;
1847
1848         for (i = 0; i < ARRAY_SIZE(ipr_ses_table); i++, ste++) {
1849                 for (j = 0, matches = 0; j < IPR_PROD_ID_LEN; j++) {
1850                         if (ste->compare_product_id_byte[j] == 'X') {
1851                                 if (res->cfgte.std_inq_data.vpids.product_id[j] == ste->product_id[j])
1852                                         matches++;
1853                                 else
1854                                         break;
1855                         } else
1856                                 matches++;
1857                 }
1858
1859                 if (matches == IPR_PROD_ID_LEN)
1860                         return ste;
1861         }
1862
1863         return NULL;
1864 }
1865
1866 /**
1867  * ipr_get_max_scsi_speed - Determine max SCSI speed for a given bus
1868  * @ioa_cfg:    ioa config struct
1869  * @bus:                SCSI bus
1870  * @bus_width:  bus width
1871  *
1872  * Return value:
1873  *      SCSI bus speed in units of 100KHz, 1600 is 160 MHz
1874  *      For a 2-byte wide SCSI bus, the maximum transfer speed is
1875  *      twice the maximum transfer rate (e.g. for a wide enabled bus,
1876  *      max 160MHz = max 320MB/sec).
1877  **/
1878 static u32 ipr_get_max_scsi_speed(struct ipr_ioa_cfg *ioa_cfg, u8 bus, u8 bus_width)
1879 {
1880         struct ipr_resource_entry *res;
1881         const struct ipr_ses_table_entry *ste;
1882         u32 max_xfer_rate = IPR_MAX_SCSI_RATE(bus_width);
1883
1884         /* Loop through each config table entry in the config table buffer */
1885         list_for_each_entry(res, &ioa_cfg->used_res_q, queue) {
1886                 if (!(IPR_IS_SES_DEVICE(res->cfgte.std_inq_data)))
1887                         continue;
1888
1889                 if (bus != res->cfgte.res_addr.bus)
1890                         continue;
1891
1892                 if (!(ste = ipr_find_ses_entry(res)))
1893                         continue;
1894
1895                 max_xfer_rate = (ste->max_bus_speed_limit * 10) / (bus_width / 8);
1896         }
1897
1898         return max_xfer_rate;
1899 }
1900
1901 /**
1902  * ipr_wait_iodbg_ack - Wait for an IODEBUG ACK from the IOA
1903  * @ioa_cfg:            ioa config struct
1904  * @max_delay:          max delay in micro-seconds to wait
1905  *
1906  * Waits for an IODEBUG ACK from the IOA, doing busy looping.
1907  *
1908  * Return value:
1909  *      0 on success / other on failure
1910  **/
1911 static int ipr_wait_iodbg_ack(struct ipr_ioa_cfg *ioa_cfg, int max_delay)
1912 {
1913         volatile u32 pcii_reg;
1914         int delay = 1;
1915
1916         /* Read interrupt reg until IOA signals IO Debug Acknowledge */
1917         while (delay < max_delay) {
1918                 pcii_reg = readl(ioa_cfg->regs.sense_interrupt_reg);
1919
1920                 if (pcii_reg & IPR_PCII_IO_DEBUG_ACKNOWLEDGE)
1921                         return 0;
1922
1923                 /* udelay cannot be used if delay is more than a few milliseconds */
1924                 if ((delay / 1000) > MAX_UDELAY_MS)
1925                         mdelay(delay / 1000);
1926                 else
1927                         udelay(delay);
1928
1929                 delay += delay;
1930         }
1931         return -EIO;
1932 }
1933
1934 /**
1935  * ipr_get_ldump_data_section - Dump IOA memory
1936  * @ioa_cfg:                    ioa config struct
1937  * @start_addr:                 adapter address to dump
1938  * @dest:                               destination kernel buffer
1939  * @length_in_words:    length to dump in 4 byte words
1940  *
1941  * Return value:
1942  *      0 on success / -EIO on failure
1943  **/
1944 static int ipr_get_ldump_data_section(struct ipr_ioa_cfg *ioa_cfg,
1945                                       u32 start_addr,
1946                                       __be32 *dest, u32 length_in_words)
1947 {
1948         volatile u32 temp_pcii_reg;
1949         int i, delay = 0;
1950
1951         /* Write IOA interrupt reg starting LDUMP state  */
1952         writel((IPR_UPROCI_RESET_ALERT | IPR_UPROCI_IO_DEBUG_ALERT),
1953                ioa_cfg->regs.set_uproc_interrupt_reg);
1954
1955         /* Wait for IO debug acknowledge */
1956         if (ipr_wait_iodbg_ack(ioa_cfg,
1957                                IPR_LDUMP_MAX_LONG_ACK_DELAY_IN_USEC)) {
1958                 dev_err(&ioa_cfg->pdev->dev,
1959                         "IOA dump long data transfer timeout\n");
1960                 return -EIO;
1961         }
1962
1963         /* Signal LDUMP interlocked - clear IO debug ack */
1964         writel(IPR_PCII_IO_DEBUG_ACKNOWLEDGE,
1965                ioa_cfg->regs.clr_interrupt_reg);
1966
1967         /* Write Mailbox with starting address */
1968         writel(start_addr, ioa_cfg->ioa_mailbox);
1969
1970         /* Signal address valid - clear IOA Reset alert */
1971         writel(IPR_UPROCI_RESET_ALERT,
1972                ioa_cfg->regs.clr_uproc_interrupt_reg);
1973
1974         for (i = 0; i < length_in_words; i++) {
1975                 /* Wait for IO debug acknowledge */
1976                 if (ipr_wait_iodbg_ack(ioa_cfg,
1977                                        IPR_LDUMP_MAX_SHORT_ACK_DELAY_IN_USEC)) {
1978                         dev_err(&ioa_cfg->pdev->dev,
1979                                 "IOA dump short data transfer timeout\n");
1980                         return -EIO;
1981                 }
1982
1983                 /* Read data from mailbox and increment destination pointer */
1984                 *dest = cpu_to_be32(readl(ioa_cfg->ioa_mailbox));
1985                 dest++;
1986
1987                 /* For all but the last word of data, signal data received */
1988                 if (i < (length_in_words - 1)) {
1989                         /* Signal dump data received - Clear IO debug Ack */
1990                         writel(IPR_PCII_IO_DEBUG_ACKNOWLEDGE,
1991                                ioa_cfg->regs.clr_interrupt_reg);
1992                 }
1993         }
1994
1995         /* Signal end of block transfer. Set reset alert then clear IO debug ack */
1996         writel(IPR_UPROCI_RESET_ALERT,
1997                ioa_cfg->regs.set_uproc_interrupt_reg);
1998
1999         writel(IPR_UPROCI_IO_DEBUG_ALERT,
2000                ioa_cfg->regs.clr_uproc_interrupt_reg);
2001
2002         /* Signal dump data received - Clear IO debug Ack */
2003         writel(IPR_PCII_IO_DEBUG_ACKNOWLEDGE,
2004                ioa_cfg->regs.clr_interrupt_reg);
2005
2006         /* Wait for IOA to signal LDUMP exit - IOA reset alert will be cleared */
2007         while (delay < IPR_LDUMP_MAX_SHORT_ACK_DELAY_IN_USEC) {
2008                 temp_pcii_reg =
2009                     readl(ioa_cfg->regs.sense_uproc_interrupt_reg);
2010
2011                 if (!(temp_pcii_reg & IPR_UPROCI_RESET_ALERT))
2012                         return 0;
2013
2014                 udelay(10);
2015                 delay += 10;
2016         }
2017
2018         return 0;
2019 }
2020
2021 #ifdef CONFIG_SCSI_IPR_DUMP
2022 /**
2023  * ipr_sdt_copy - Copy Smart Dump Table to kernel buffer
2024  * @ioa_cfg:            ioa config struct
2025  * @pci_address:        adapter address
2026  * @length:                     length of data to copy
2027  *
2028  * Copy data from PCI adapter to kernel buffer.
2029  * Note: length MUST be a 4 byte multiple
2030  * Return value:
2031  *      0 on success / other on failure
2032  **/
2033 static int ipr_sdt_copy(struct ipr_ioa_cfg *ioa_cfg,
2034                         unsigned long pci_address, u32 length)
2035 {
2036         int bytes_copied = 0;
2037         int cur_len, rc, rem_len, rem_page_len;
2038         __be32 *page;
2039         unsigned long lock_flags = 0;
2040         struct ipr_ioa_dump *ioa_dump = &ioa_cfg->dump->ioa_dump;
2041
2042         while (bytes_copied < length &&
2043                (ioa_dump->hdr.len + bytes_copied) < IPR_MAX_IOA_DUMP_SIZE) {
2044                 if (ioa_dump->page_offset >= PAGE_SIZE ||
2045                     ioa_dump->page_offset == 0) {
2046                         page = (__be32 *)__get_free_page(GFP_ATOMIC);
2047
2048                         if (!page) {
2049                                 ipr_trace;
2050                                 return bytes_copied;
2051                         }
2052
2053                         ioa_dump->page_offset = 0;
2054                         ioa_dump->ioa_data[ioa_dump->next_page_index] = page;
2055                         ioa_dump->next_page_index++;
2056                 } else
2057                         page = ioa_dump->ioa_data[ioa_dump->next_page_index - 1];
2058
2059                 rem_len = length - bytes_copied;
2060                 rem_page_len = PAGE_SIZE - ioa_dump->page_offset;
2061                 cur_len = min(rem_len, rem_page_len);
2062
2063                 spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
2064                 if (ioa_cfg->sdt_state == ABORT_DUMP) {
2065                         rc = -EIO;
2066                 } else {
2067                         rc = ipr_get_ldump_data_section(ioa_cfg,
2068                                                         pci_address + bytes_copied,
2069                                                         &page[ioa_dump->page_offset / 4],
2070                                                         (cur_len / sizeof(u32)));
2071                 }
2072                 spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
2073
2074                 if (!rc) {
2075                         ioa_dump->page_offset += cur_len;
2076                         bytes_copied += cur_len;
2077                 } else {
2078                         ipr_trace;
2079                         break;
2080                 }
2081                 schedule();
2082         }
2083
2084         return bytes_copied;
2085 }
2086
2087 /**
2088  * ipr_init_dump_entry_hdr - Initialize a dump entry header.
2089  * @hdr:        dump entry header struct
2090  *
2091  * Return value:
2092  *      nothing
2093  **/
2094 static void ipr_init_dump_entry_hdr(struct ipr_dump_entry_header *hdr)
2095 {
2096         hdr->eye_catcher = IPR_DUMP_EYE_CATCHER;
2097         hdr->num_elems = 1;
2098         hdr->offset = sizeof(*hdr);
2099         hdr->status = IPR_DUMP_STATUS_SUCCESS;
2100 }
2101
2102 /**
2103  * ipr_dump_ioa_type_data - Fill in the adapter type in the dump.
2104  * @ioa_cfg:    ioa config struct
2105  * @driver_dump:        driver dump struct
2106  *
2107  * Return value:
2108  *      nothing
2109  **/
2110 static void ipr_dump_ioa_type_data(struct ipr_ioa_cfg *ioa_cfg,
2111                                    struct ipr_driver_dump *driver_dump)
2112 {
2113         struct ipr_inquiry_page3 *ucode_vpd = &ioa_cfg->vpd_cbs->page3_data;
2114
2115         ipr_init_dump_entry_hdr(&driver_dump->ioa_type_entry.hdr);
2116         driver_dump->ioa_type_entry.hdr.len =
2117                 sizeof(struct ipr_dump_ioa_type_entry) -
2118                 sizeof(struct ipr_dump_entry_header);
2119         driver_dump->ioa_type_entry.hdr.data_type = IPR_DUMP_DATA_TYPE_BINARY;
2120         driver_dump->ioa_type_entry.hdr.id = IPR_DUMP_DRIVER_TYPE_ID;
2121         driver_dump->ioa_type_entry.type = ioa_cfg->type;
2122         driver_dump->ioa_type_entry.fw_version = (ucode_vpd->major_release << 24) |
2123                 (ucode_vpd->card_type << 16) | (ucode_vpd->minor_release[0] << 8) |
2124                 ucode_vpd->minor_release[1];
2125         driver_dump->hdr.num_entries++;
2126 }
2127
2128 /**
2129  * ipr_dump_version_data - Fill in the driver version in the dump.
2130  * @ioa_cfg:    ioa config struct
2131  * @driver_dump:        driver dump struct
2132  *
2133  * Return value:
2134  *      nothing
2135  **/
2136 static void ipr_dump_version_data(struct ipr_ioa_cfg *ioa_cfg,
2137                                   struct ipr_driver_dump *driver_dump)
2138 {
2139         ipr_init_dump_entry_hdr(&driver_dump->version_entry.hdr);
2140         driver_dump->version_entry.hdr.len =
2141                 sizeof(struct ipr_dump_version_entry) -
2142                 sizeof(struct ipr_dump_entry_header);
2143         driver_dump->version_entry.hdr.data_type = IPR_DUMP_DATA_TYPE_ASCII;
2144         driver_dump->version_entry.hdr.id = IPR_DUMP_DRIVER_VERSION_ID;
2145         strcpy(driver_dump->version_entry.version, IPR_DRIVER_VERSION);
2146         driver_dump->hdr.num_entries++;
2147 }
2148
2149 /**
2150  * ipr_dump_trace_data - Fill in the IOA trace in the dump.
2151  * @ioa_cfg:    ioa config struct
2152  * @driver_dump:        driver dump struct
2153  *
2154  * Return value:
2155  *      nothing
2156  **/
2157 static void ipr_dump_trace_data(struct ipr_ioa_cfg *ioa_cfg,
2158                                    struct ipr_driver_dump *driver_dump)
2159 {
2160         ipr_init_dump_entry_hdr(&driver_dump->trace_entry.hdr);
2161         driver_dump->trace_entry.hdr.len =
2162                 sizeof(struct ipr_dump_trace_entry) -
2163                 sizeof(struct ipr_dump_entry_header);
2164         driver_dump->trace_entry.hdr.data_type = IPR_DUMP_DATA_TYPE_BINARY;
2165         driver_dump->trace_entry.hdr.id = IPR_DUMP_TRACE_ID;
2166         memcpy(driver_dump->trace_entry.trace, ioa_cfg->trace, IPR_TRACE_SIZE);
2167         driver_dump->hdr.num_entries++;
2168 }
2169
2170 /**
2171  * ipr_dump_location_data - Fill in the IOA location in the dump.
2172  * @ioa_cfg:    ioa config struct
2173  * @driver_dump:        driver dump struct
2174  *
2175  * Return value:
2176  *      nothing
2177  **/
2178 static void ipr_dump_location_data(struct ipr_ioa_cfg *ioa_cfg,
2179                                    struct ipr_driver_dump *driver_dump)
2180 {
2181         ipr_init_dump_entry_hdr(&driver_dump->location_entry.hdr);
2182         driver_dump->location_entry.hdr.len =
2183                 sizeof(struct ipr_dump_location_entry) -
2184                 sizeof(struct ipr_dump_entry_header);
2185         driver_dump->location_entry.hdr.data_type = IPR_DUMP_DATA_TYPE_ASCII;
2186         driver_dump->location_entry.hdr.id = IPR_DUMP_LOCATION_ID;
2187         strcpy(driver_dump->location_entry.location, dev_name(&ioa_cfg->pdev->dev));
2188         driver_dump->hdr.num_entries++;
2189 }
2190
2191 /**
2192  * ipr_get_ioa_dump - Perform a dump of the driver and adapter.
2193  * @ioa_cfg:    ioa config struct
2194  * @dump:               dump struct
2195  *
2196  * Return value:
2197  *      nothing
2198  **/
2199 static void ipr_get_ioa_dump(struct ipr_ioa_cfg *ioa_cfg, struct ipr_dump *dump)
2200 {
2201         unsigned long start_addr, sdt_word;
2202         unsigned long lock_flags = 0;
2203         struct ipr_driver_dump *driver_dump = &dump->driver_dump;
2204         struct ipr_ioa_dump *ioa_dump = &dump->ioa_dump;
2205         u32 num_entries, start_off, end_off;
2206         u32 bytes_to_copy, bytes_copied, rc;
2207         struct ipr_sdt *sdt;
2208         int i;
2209
2210         ENTER;
2211
2212         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
2213
2214         if (ioa_cfg->sdt_state != GET_DUMP) {
2215                 spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
2216                 return;
2217         }
2218
2219         start_addr = readl(ioa_cfg->ioa_mailbox);
2220
2221         if (!ipr_sdt_is_fmt2(start_addr)) {
2222                 dev_err(&ioa_cfg->pdev->dev,
2223                         "Invalid dump table format: %lx\n", start_addr);
2224                 spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
2225                 return;
2226         }
2227
2228         dev_err(&ioa_cfg->pdev->dev, "Dump of IOA initiated\n");
2229
2230         driver_dump->hdr.eye_catcher = IPR_DUMP_EYE_CATCHER;
2231
2232         /* Initialize the overall dump header */
2233         driver_dump->hdr.len = sizeof(struct ipr_driver_dump);
2234         driver_dump->hdr.num_entries = 1;
2235         driver_dump->hdr.first_entry_offset = sizeof(struct ipr_dump_header);
2236         driver_dump->hdr.status = IPR_DUMP_STATUS_SUCCESS;
2237         driver_dump->hdr.os = IPR_DUMP_OS_LINUX;
2238         driver_dump->hdr.driver_name = IPR_DUMP_DRIVER_NAME;
2239
2240         ipr_dump_version_data(ioa_cfg, driver_dump);
2241         ipr_dump_location_data(ioa_cfg, driver_dump);
2242         ipr_dump_ioa_type_data(ioa_cfg, driver_dump);
2243         ipr_dump_trace_data(ioa_cfg, driver_dump);
2244
2245         /* Update dump_header */
2246         driver_dump->hdr.len += sizeof(struct ipr_dump_entry_header);
2247
2248         /* IOA Dump entry */
2249         ipr_init_dump_entry_hdr(&ioa_dump->hdr);
2250         ioa_dump->format = IPR_SDT_FMT2;
2251         ioa_dump->hdr.len = 0;
2252         ioa_dump->hdr.data_type = IPR_DUMP_DATA_TYPE_BINARY;
2253         ioa_dump->hdr.id = IPR_DUMP_IOA_DUMP_ID;
2254
2255         /* First entries in sdt are actually a list of dump addresses and
2256          lengths to gather the real dump data.  sdt represents the pointer
2257          to the ioa generated dump table.  Dump data will be extracted based
2258          on entries in this table */
2259         sdt = &ioa_dump->sdt;
2260
2261         rc = ipr_get_ldump_data_section(ioa_cfg, start_addr, (__be32 *)sdt,
2262                                         sizeof(struct ipr_sdt) / sizeof(__be32));
2263
2264         /* Smart Dump table is ready to use and the first entry is valid */
2265         if (rc || (be32_to_cpu(sdt->hdr.state) != IPR_FMT2_SDT_READY_TO_USE)) {
2266                 dev_err(&ioa_cfg->pdev->dev,
2267                         "Dump of IOA failed. Dump table not valid: %d, %X.\n",
2268                         rc, be32_to_cpu(sdt->hdr.state));
2269                 driver_dump->hdr.status = IPR_DUMP_STATUS_FAILED;
2270                 ioa_cfg->sdt_state = DUMP_OBTAINED;
2271                 spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
2272                 return;
2273         }
2274
2275         num_entries = be32_to_cpu(sdt->hdr.num_entries_used);
2276
2277         if (num_entries > IPR_NUM_SDT_ENTRIES)
2278                 num_entries = IPR_NUM_SDT_ENTRIES;
2279
2280         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
2281
2282         for (i = 0; i < num_entries; i++) {
2283                 if (ioa_dump->hdr.len > IPR_MAX_IOA_DUMP_SIZE) {
2284                         driver_dump->hdr.status = IPR_DUMP_STATUS_QUAL_SUCCESS;
2285                         break;
2286                 }
2287
2288                 if (sdt->entry[i].flags & IPR_SDT_VALID_ENTRY) {
2289                         sdt_word = be32_to_cpu(sdt->entry[i].bar_str_offset);
2290                         start_off = sdt_word & IPR_FMT2_MBX_ADDR_MASK;
2291                         end_off = be32_to_cpu(sdt->entry[i].end_offset);
2292
2293                         if (ipr_sdt_is_fmt2(sdt_word) && sdt_word) {
2294                                 bytes_to_copy = end_off - start_off;
2295                                 if (bytes_to_copy > IPR_MAX_IOA_DUMP_SIZE) {
2296                                         sdt->entry[i].flags &= ~IPR_SDT_VALID_ENTRY;
2297                                         continue;
2298                                 }
2299
2300                                 /* Copy data from adapter to driver buffers */
2301                                 bytes_copied = ipr_sdt_copy(ioa_cfg, sdt_word,
2302                                                             bytes_to_copy);
2303
2304                                 ioa_dump->hdr.len += bytes_copied;
2305
2306                                 if (bytes_copied != bytes_to_copy) {
2307                                         driver_dump->hdr.status = IPR_DUMP_STATUS_QUAL_SUCCESS;
2308                                         break;
2309                                 }
2310                         }
2311                 }
2312         }
2313
2314         dev_err(&ioa_cfg->pdev->dev, "Dump of IOA completed.\n");
2315
2316         /* Update dump_header */
2317         driver_dump->hdr.len += ioa_dump->hdr.len;
2318         wmb();
2319         ioa_cfg->sdt_state = DUMP_OBTAINED;
2320         LEAVE;
2321 }
2322
2323 #else
2324 #define ipr_get_ioa_dump(ioa_cfg, dump) do { } while(0)
2325 #endif
2326
2327 /**
2328  * ipr_release_dump - Free adapter dump memory
2329  * @kref:       kref struct
2330  *
2331  * Return value:
2332  *      nothing
2333  **/
2334 static void ipr_release_dump(struct kref *kref)
2335 {
2336         struct ipr_dump *dump = container_of(kref,struct ipr_dump,kref);
2337         struct ipr_ioa_cfg *ioa_cfg = dump->ioa_cfg;
2338         unsigned long lock_flags = 0;
2339         int i;
2340
2341         ENTER;
2342         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
2343         ioa_cfg->dump = NULL;
2344         ioa_cfg->sdt_state = INACTIVE;
2345         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
2346
2347         for (i = 0; i < dump->ioa_dump.next_page_index; i++)
2348                 free_page((unsigned long) dump->ioa_dump.ioa_data[i]);
2349
2350         kfree(dump);
2351         LEAVE;
2352 }
2353
2354 /**
2355  * ipr_worker_thread - Worker thread
2356  * @work:               ioa config struct
2357  *
2358  * Called at task level from a work thread. This function takes care
2359  * of adding and removing device from the mid-layer as configuration
2360  * changes are detected by the adapter.
2361  *
2362  * Return value:
2363  *      nothing
2364  **/
2365 static void ipr_worker_thread(struct work_struct *work)
2366 {
2367         unsigned long lock_flags;
2368         struct ipr_resource_entry *res;
2369         struct scsi_device *sdev;
2370         struct ipr_dump *dump;
2371         struct ipr_ioa_cfg *ioa_cfg =
2372                 container_of(work, struct ipr_ioa_cfg, work_q);
2373         u8 bus, target, lun;
2374         int did_work;
2375
2376         ENTER;
2377         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
2378
2379         if (ioa_cfg->sdt_state == GET_DUMP) {
2380                 dump = ioa_cfg->dump;
2381                 if (!dump) {
2382                         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
2383                         return;
2384                 }
2385                 kref_get(&dump->kref);
2386                 spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
2387                 ipr_get_ioa_dump(ioa_cfg, dump);
2388                 kref_put(&dump->kref, ipr_release_dump);
2389
2390                 spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
2391                 if (ioa_cfg->sdt_state == DUMP_OBTAINED)
2392                         ipr_initiate_ioa_reset(ioa_cfg, IPR_SHUTDOWN_NONE);
2393                 spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
2394                 return;
2395         }
2396
2397 restart:
2398         do {
2399                 did_work = 0;
2400                 if (!ioa_cfg->allow_cmds || !ioa_cfg->allow_ml_add_del) {
2401                         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
2402                         return;
2403                 }
2404
2405                 list_for_each_entry(res, &ioa_cfg->used_res_q, queue) {
2406                         if (res->del_from_ml && res->sdev) {
2407                                 did_work = 1;
2408                                 sdev = res->sdev;
2409                                 if (!scsi_device_get(sdev)) {
2410                                         list_move_tail(&res->queue, &ioa_cfg->free_res_q);
2411                                         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
2412                                         scsi_remove_device(sdev);
2413                                         scsi_device_put(sdev);
2414                                         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
2415                                 }
2416                                 break;
2417                         }
2418                 }
2419         } while(did_work);
2420
2421         list_for_each_entry(res, &ioa_cfg->used_res_q, queue) {
2422                 if (res->add_to_ml) {
2423                         bus = res->cfgte.res_addr.bus;
2424                         target = res->cfgte.res_addr.target;
2425                         lun = res->cfgte.res_addr.lun;
2426                         res->add_to_ml = 0;
2427                         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
2428                         scsi_add_device(ioa_cfg->host, bus, target, lun);
2429                         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
2430                         goto restart;
2431                 }
2432         }
2433
2434         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
2435         kobject_uevent(&ioa_cfg->host->shost_dev.kobj, KOBJ_CHANGE);
2436         LEAVE;
2437 }
2438
2439 #ifdef CONFIG_SCSI_IPR_TRACE
2440 /**
2441  * ipr_read_trace - Dump the adapter trace
2442  * @kobj:               kobject struct
2443  * @bin_attr:           bin_attribute struct
2444  * @buf:                buffer
2445  * @off:                offset
2446  * @count:              buffer size
2447  *
2448  * Return value:
2449  *      number of bytes printed to buffer
2450  **/
2451 static ssize_t ipr_read_trace(struct kobject *kobj,
2452                               struct bin_attribute *bin_attr,
2453                               char *buf, loff_t off, size_t count)
2454 {
2455         struct device *dev = container_of(kobj, struct device, kobj);
2456         struct Scsi_Host *shost = class_to_shost(dev);
2457         struct ipr_ioa_cfg *ioa_cfg = (struct ipr_ioa_cfg *)shost->hostdata;
2458         unsigned long lock_flags = 0;
2459         ssize_t ret;
2460
2461         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
2462         ret = memory_read_from_buffer(buf, count, &off, ioa_cfg->trace,
2463                                 IPR_TRACE_SIZE);
2464         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
2465
2466         return ret;
2467 }
2468
2469 static struct bin_attribute ipr_trace_attr = {
2470         .attr = {
2471                 .name = "trace",
2472                 .mode = S_IRUGO,
2473         },
2474         .size = 0,
2475         .read = ipr_read_trace,
2476 };
2477 #endif
2478
2479 static const struct {
2480         enum ipr_cache_state state;
2481         char *name;
2482 } cache_state [] = {
2483         { CACHE_NONE, "none" },
2484         { CACHE_DISABLED, "disabled" },
2485         { CACHE_ENABLED, "enabled" }
2486 };
2487
2488 /**
2489  * ipr_show_write_caching - Show the write caching attribute
2490  * @dev:        device struct
2491  * @buf:        buffer
2492  *
2493  * Return value:
2494  *      number of bytes printed to buffer
2495  **/
2496 static ssize_t ipr_show_write_caching(struct device *dev,
2497                                       struct device_attribute *attr, char *buf)
2498 {
2499         struct Scsi_Host *shost = class_to_shost(dev);
2500         struct ipr_ioa_cfg *ioa_cfg = (struct ipr_ioa_cfg *)shost->hostdata;
2501         unsigned long lock_flags = 0;
2502         int i, len = 0;
2503
2504         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
2505         for (i = 0; i < ARRAY_SIZE(cache_state); i++) {
2506                 if (cache_state[i].state == ioa_cfg->cache_state) {
2507                         len = snprintf(buf, PAGE_SIZE, "%s\n", cache_state[i].name);
2508                         break;
2509                 }
2510         }
2511         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
2512         return len;
2513 }
2514
2515
2516 /**
2517  * ipr_store_write_caching - Enable/disable adapter write cache
2518  * @dev:        device struct
2519  * @buf:        buffer
2520  * @count:      buffer size
2521  *
2522  * This function will enable/disable adapter write cache.
2523  *
2524  * Return value:
2525  *      count on success / other on failure
2526  **/
2527 static ssize_t ipr_store_write_caching(struct device *dev,
2528                                        struct device_attribute *attr,
2529                                        const char *buf, size_t count)
2530 {
2531         struct Scsi_Host *shost = class_to_shost(dev);
2532         struct ipr_ioa_cfg *ioa_cfg = (struct ipr_ioa_cfg *)shost->hostdata;
2533         unsigned long lock_flags = 0;
2534         enum ipr_cache_state new_state = CACHE_INVALID;
2535         int i;
2536
2537         if (!capable(CAP_SYS_ADMIN))
2538                 return -EACCES;
2539         if (ioa_cfg->cache_state == CACHE_NONE)
2540                 return -EINVAL;
2541
2542         for (i = 0; i < ARRAY_SIZE(cache_state); i++) {
2543                 if (!strncmp(cache_state[i].name, buf, strlen(cache_state[i].name))) {
2544                         new_state = cache_state[i].state;
2545                         break;
2546                 }
2547         }
2548
2549         if (new_state != CACHE_DISABLED && new_state != CACHE_ENABLED)
2550                 return -EINVAL;
2551
2552         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
2553         if (ioa_cfg->cache_state == new_state) {
2554                 spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
2555                 return count;
2556         }
2557
2558         ioa_cfg->cache_state = new_state;
2559         dev_info(&ioa_cfg->pdev->dev, "%s adapter write cache.\n",
2560                  new_state == CACHE_ENABLED ? "Enabling" : "Disabling");
2561         if (!ioa_cfg->in_reset_reload)
2562                 ipr_initiate_ioa_reset(ioa_cfg, IPR_SHUTDOWN_NORMAL);
2563         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
2564         wait_event(ioa_cfg->reset_wait_q, !ioa_cfg->in_reset_reload);
2565
2566         return count;
2567 }
2568
2569 static struct device_attribute ipr_ioa_cache_attr = {
2570         .attr = {
2571                 .name =         "write_cache",
2572                 .mode =         S_IRUGO | S_IWUSR,
2573         },
2574         .show = ipr_show_write_caching,
2575         .store = ipr_store_write_caching
2576 };
2577
2578 /**
2579  * ipr_show_fw_version - Show the firmware version
2580  * @dev:        class device struct
2581  * @buf:        buffer
2582  *
2583  * Return value:
2584  *      number of bytes printed to buffer
2585  **/
2586 static ssize_t ipr_show_fw_version(struct device *dev,
2587                                    struct device_attribute *attr, char *buf)
2588 {
2589         struct Scsi_Host *shost = class_to_shost(dev);
2590         struct ipr_ioa_cfg *ioa_cfg = (struct ipr_ioa_cfg *)shost->hostdata;
2591         struct ipr_inquiry_page3 *ucode_vpd = &ioa_cfg->vpd_cbs->page3_data;
2592         unsigned long lock_flags = 0;
2593         int len;
2594
2595         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
2596         len = snprintf(buf, PAGE_SIZE, "%02X%02X%02X%02X\n",
2597                        ucode_vpd->major_release, ucode_vpd->card_type,
2598                        ucode_vpd->minor_release[0],
2599                        ucode_vpd->minor_release[1]);
2600         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
2601         return len;
2602 }
2603
2604 static struct device_attribute ipr_fw_version_attr = {
2605         .attr = {
2606                 .name =         "fw_version",
2607                 .mode =         S_IRUGO,
2608         },
2609         .show = ipr_show_fw_version,
2610 };
2611
2612 /**
2613  * ipr_show_log_level - Show the adapter's error logging level
2614  * @dev:        class device struct
2615  * @buf:        buffer
2616  *
2617  * Return value:
2618  *      number of bytes printed to buffer
2619  **/
2620 static ssize_t ipr_show_log_level(struct device *dev,
2621                                    struct device_attribute *attr, char *buf)
2622 {
2623         struct Scsi_Host *shost = class_to_shost(dev);
2624         struct ipr_ioa_cfg *ioa_cfg = (struct ipr_ioa_cfg *)shost->hostdata;
2625         unsigned long lock_flags = 0;
2626         int len;
2627
2628         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
2629         len = snprintf(buf, PAGE_SIZE, "%d\n", ioa_cfg->log_level);
2630         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
2631         return len;
2632 }
2633
2634 /**
2635  * ipr_store_log_level - Change the adapter's error logging level
2636  * @dev:        class device struct
2637  * @buf:        buffer
2638  *
2639  * Return value:
2640  *      number of bytes printed to buffer
2641  **/
2642 static ssize_t ipr_store_log_level(struct device *dev,
2643                                    struct device_attribute *attr,
2644                                    const char *buf, size_t count)
2645 {
2646         struct Scsi_Host *shost = class_to_shost(dev);
2647         struct ipr_ioa_cfg *ioa_cfg = (struct ipr_ioa_cfg *)shost->hostdata;
2648         unsigned long lock_flags = 0;
2649
2650         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
2651         ioa_cfg->log_level = simple_strtoul(buf, NULL, 10);
2652         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
2653         return strlen(buf);
2654 }
2655
2656 static struct device_attribute ipr_log_level_attr = {
2657         .attr = {
2658                 .name =         "log_level",
2659                 .mode =         S_IRUGO | S_IWUSR,
2660         },
2661         .show = ipr_show_log_level,
2662         .store = ipr_store_log_level
2663 };
2664
2665 /**
2666  * ipr_store_diagnostics - IOA Diagnostics interface
2667  * @dev:        device struct
2668  * @buf:        buffer
2669  * @count:      buffer size
2670  *
2671  * This function will reset the adapter and wait a reasonable
2672  * amount of time for any errors that the adapter might log.
2673  *
2674  * Return value:
2675  *      count on success / other on failure
2676  **/
2677 static ssize_t ipr_store_diagnostics(struct device *dev,
2678                                      struct device_attribute *attr,
2679                                      const char *buf, size_t count)
2680 {
2681         struct Scsi_Host *shost = class_to_shost(dev);
2682         struct ipr_ioa_cfg *ioa_cfg = (struct ipr_ioa_cfg *)shost->hostdata;
2683         unsigned long lock_flags = 0;
2684         int rc = count;
2685
2686         if (!capable(CAP_SYS_ADMIN))
2687                 return -EACCES;
2688
2689         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
2690         while(ioa_cfg->in_reset_reload) {
2691                 spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
2692                 wait_event(ioa_cfg->reset_wait_q, !ioa_cfg->in_reset_reload);
2693                 spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
2694         }
2695
2696         ioa_cfg->errors_logged = 0;
2697         ipr_initiate_ioa_reset(ioa_cfg, IPR_SHUTDOWN_NORMAL);
2698
2699         if (ioa_cfg->in_reset_reload) {
2700                 spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
2701                 wait_event(ioa_cfg->reset_wait_q, !ioa_cfg->in_reset_reload);
2702
2703                 /* Wait for a second for any errors to be logged */
2704                 msleep(1000);
2705         } else {
2706                 spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
2707                 return -EIO;
2708         }
2709
2710         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
2711         if (ioa_cfg->in_reset_reload || ioa_cfg->errors_logged)
2712                 rc = -EIO;
2713         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
2714
2715         return rc;
2716 }
2717
2718 static struct device_attribute ipr_diagnostics_attr = {
2719         .attr = {
2720                 .name =         "run_diagnostics",
2721                 .mode =         S_IWUSR,
2722         },
2723         .store = ipr_store_diagnostics
2724 };
2725
2726 /**
2727  * ipr_show_adapter_state - Show the adapter's state
2728  * @class_dev:  device struct
2729  * @buf:        buffer
2730  *
2731  * Return value:
2732  *      number of bytes printed to buffer
2733  **/
2734 static ssize_t ipr_show_adapter_state(struct device *dev,
2735                                       struct device_attribute *attr, char *buf)
2736 {
2737         struct Scsi_Host *shost = class_to_shost(dev);
2738         struct ipr_ioa_cfg *ioa_cfg = (struct ipr_ioa_cfg *)shost->hostdata;
2739         unsigned long lock_flags = 0;
2740         int len;
2741
2742         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
2743         if (ioa_cfg->ioa_is_dead)
2744                 len = snprintf(buf, PAGE_SIZE, "offline\n");
2745         else
2746                 len = snprintf(buf, PAGE_SIZE, "online\n");
2747         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
2748         return len;
2749 }
2750
2751 /**
2752  * ipr_store_adapter_state - Change adapter state
2753  * @dev:        device struct
2754  * @buf:        buffer
2755  * @count:      buffer size
2756  *
2757  * This function will change the adapter's state.
2758  *
2759  * Return value:
2760  *      count on success / other on failure
2761  **/
2762 static ssize_t ipr_store_adapter_state(struct device *dev,
2763                                        struct device_attribute *attr,
2764                                        const char *buf, size_t count)
2765 {
2766         struct Scsi_Host *shost = class_to_shost(dev);
2767         struct ipr_ioa_cfg *ioa_cfg = (struct ipr_ioa_cfg *)shost->hostdata;
2768         unsigned long lock_flags;
2769         int result = count;
2770
2771         if (!capable(CAP_SYS_ADMIN))
2772                 return -EACCES;
2773
2774         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
2775         if (ioa_cfg->ioa_is_dead && !strncmp(buf, "online", 6)) {
2776                 ioa_cfg->ioa_is_dead = 0;
2777                 ioa_cfg->reset_retries = 0;
2778                 ioa_cfg->in_ioa_bringdown = 0;
2779                 ipr_initiate_ioa_reset(ioa_cfg, IPR_SHUTDOWN_NONE);
2780         }
2781         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
2782         wait_event(ioa_cfg->reset_wait_q, !ioa_cfg->in_reset_reload);
2783
2784         return result;
2785 }
2786
2787 static struct device_attribute ipr_ioa_state_attr = {
2788         .attr = {
2789                 .name =         "online_state",
2790                 .mode =         S_IRUGO | S_IWUSR,
2791         },
2792         .show = ipr_show_adapter_state,
2793         .store = ipr_store_adapter_state
2794 };
2795
2796 /**
2797  * ipr_store_reset_adapter - Reset the adapter
2798  * @dev:        device struct
2799  * @buf:        buffer
2800  * @count:      buffer size
2801  *
2802  * This function will reset the adapter.
2803  *
2804  * Return value:
2805  *      count on success / other on failure
2806  **/
2807 static ssize_t ipr_store_reset_adapter(struct device *dev,
2808                                        struct device_attribute *attr,
2809                                        const char *buf, size_t count)
2810 {
2811         struct Scsi_Host *shost = class_to_shost(dev);
2812         struct ipr_ioa_cfg *ioa_cfg = (struct ipr_ioa_cfg *)shost->hostdata;
2813         unsigned long lock_flags;
2814         int result = count;
2815
2816         if (!capable(CAP_SYS_ADMIN))
2817                 return -EACCES;
2818
2819         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
2820         if (!ioa_cfg->in_reset_reload)
2821                 ipr_initiate_ioa_reset(ioa_cfg, IPR_SHUTDOWN_NORMAL);
2822         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
2823         wait_event(ioa_cfg->reset_wait_q, !ioa_cfg->in_reset_reload);
2824
2825         return result;
2826 }
2827
2828 static struct device_attribute ipr_ioa_reset_attr = {
2829         .attr = {
2830                 .name =         "reset_host",
2831                 .mode =         S_IWUSR,
2832         },
2833         .store = ipr_store_reset_adapter
2834 };
2835
2836 /**
2837  * ipr_alloc_ucode_buffer - Allocates a microcode download buffer
2838  * @buf_len:            buffer length
2839  *
2840  * Allocates a DMA'able buffer in chunks and assembles a scatter/gather
2841  * list to use for microcode download
2842  *
2843  * Return value:
2844  *      pointer to sglist / NULL on failure
2845  **/
2846 static struct ipr_sglist *ipr_alloc_ucode_buffer(int buf_len)
2847 {
2848         int sg_size, order, bsize_elem, num_elem, i, j;
2849         struct ipr_sglist *sglist;
2850         struct scatterlist *scatterlist;
2851         struct page *page;
2852
2853         /* Get the minimum size per scatter/gather element */
2854         sg_size = buf_len / (IPR_MAX_SGLIST - 1);
2855
2856         /* Get the actual size per element */
2857         order = get_order(sg_size);
2858
2859         /* Determine the actual number of bytes per element */
2860         bsize_elem = PAGE_SIZE * (1 << order);
2861
2862         /* Determine the actual number of sg entries needed */
2863         if (buf_len % bsize_elem)
2864                 num_elem = (buf_len / bsize_elem) + 1;
2865         else
2866                 num_elem = buf_len / bsize_elem;
2867
2868         /* Allocate a scatter/gather list for the DMA */
2869         sglist = kzalloc(sizeof(struct ipr_sglist) +
2870                          (sizeof(struct scatterlist) * (num_elem - 1)),
2871                          GFP_KERNEL);
2872
2873         if (sglist == NULL) {
2874                 ipr_trace;
2875                 return NULL;
2876         }
2877
2878         scatterlist = sglist->scatterlist;
2879         sg_init_table(scatterlist, num_elem);
2880
2881         sglist->order = order;
2882         sglist->num_sg = num_elem;
2883
2884         /* Allocate a bunch of sg elements */
2885         for (i = 0; i < num_elem; i++) {
2886                 page = alloc_pages(GFP_KERNEL, order);
2887                 if (!page) {
2888                         ipr_trace;
2889
2890                         /* Free up what we already allocated */
2891                         for (j = i - 1; j >= 0; j--)
2892                                 __free_pages(sg_page(&scatterlist[j]), order);
2893                         kfree(sglist);
2894                         return NULL;
2895                 }
2896
2897                 sg_set_page(&scatterlist[i], page, 0, 0);
2898         }
2899
2900         return sglist;
2901 }
2902
2903 /**
2904  * ipr_free_ucode_buffer - Frees a microcode download buffer
2905  * @p_dnld:             scatter/gather list pointer
2906  *
2907  * Free a DMA'able ucode download buffer previously allocated with
2908  * ipr_alloc_ucode_buffer
2909  *
2910  * Return value:
2911  *      nothing
2912  **/
2913 static void ipr_free_ucode_buffer(struct ipr_sglist *sglist)
2914 {
2915         int i;
2916
2917         for (i = 0; i < sglist->num_sg; i++)
2918                 __free_pages(sg_page(&sglist->scatterlist[i]), sglist->order);
2919
2920         kfree(sglist);
2921 }
2922
2923 /**
2924  * ipr_copy_ucode_buffer - Copy user buffer to kernel buffer
2925  * @sglist:             scatter/gather list pointer
2926  * @buffer:             buffer pointer
2927  * @len:                buffer length
2928  *
2929  * Copy a microcode image from a user buffer into a buffer allocated by
2930  * ipr_alloc_ucode_buffer
2931  *
2932  * Return value:
2933  *      0 on success / other on failure
2934  **/
2935 static int ipr_copy_ucode_buffer(struct ipr_sglist *sglist,
2936                                  u8 *buffer, u32 len)
2937 {
2938         int bsize_elem, i, result = 0;
2939         struct scatterlist *scatterlist;
2940         void *kaddr;
2941
2942         /* Determine the actual number of bytes per element */
2943         bsize_elem = PAGE_SIZE * (1 << sglist->order);
2944
2945         scatterlist = sglist->scatterlist;
2946
2947         for (i = 0; i < (len / bsize_elem); i++, buffer += bsize_elem) {
2948                 struct page *page = sg_page(&scatterlist[i]);
2949
2950                 kaddr = kmap(page);
2951                 memcpy(kaddr, buffer, bsize_elem);
2952                 kunmap(page);
2953
2954                 scatterlist[i].length = bsize_elem;
2955
2956                 if (result != 0) {
2957                         ipr_trace;
2958                         return result;
2959                 }
2960         }
2961
2962         if (len % bsize_elem) {
2963                 struct page *page = sg_page(&scatterlist[i]);
2964
2965                 kaddr = kmap(page);
2966                 memcpy(kaddr, buffer, len % bsize_elem);
2967                 kunmap(page);
2968
2969                 scatterlist[i].length = len % bsize_elem;
2970         }
2971
2972         sglist->buffer_len = len;
2973         return result;
2974 }
2975
2976 /**
2977  * ipr_build_ucode_ioadl - Build a microcode download IOADL
2978  * @ipr_cmd:    ipr command struct
2979  * @sglist:             scatter/gather list
2980  *
2981  * Builds a microcode download IOA data list (IOADL).
2982  *
2983  **/
2984 static void ipr_build_ucode_ioadl(struct ipr_cmnd *ipr_cmd,
2985                                   struct ipr_sglist *sglist)
2986 {
2987         struct ipr_ioarcb *ioarcb = &ipr_cmd->ioarcb;
2988         struct ipr_ioadl_desc *ioadl = ipr_cmd->ioadl;
2989         struct scatterlist *scatterlist = sglist->scatterlist;
2990         int i;
2991
2992         ipr_cmd->dma_use_sg = sglist->num_dma_sg;
2993         ioarcb->cmd_pkt.flags_hi |= IPR_FLAGS_HI_WRITE_NOT_READ;
2994         ioarcb->write_data_transfer_length = cpu_to_be32(sglist->buffer_len);
2995         ioarcb->write_ioadl_len =
2996                 cpu_to_be32(sizeof(struct ipr_ioadl_desc) * ipr_cmd->dma_use_sg);
2997
2998         for (i = 0; i < ipr_cmd->dma_use_sg; i++) {
2999                 ioadl[i].flags_and_data_len =
3000                         cpu_to_be32(IPR_IOADL_FLAGS_WRITE | sg_dma_len(&scatterlist[i]));
3001                 ioadl[i].address =
3002                         cpu_to_be32(sg_dma_address(&scatterlist[i]));
3003         }
3004
3005         ioadl[i-1].flags_and_data_len |=
3006                 cpu_to_be32(IPR_IOADL_FLAGS_LAST);
3007 }
3008
3009 /**
3010  * ipr_update_ioa_ucode - Update IOA's microcode
3011  * @ioa_cfg:    ioa config struct
3012  * @sglist:             scatter/gather list
3013  *
3014  * Initiate an adapter reset to update the IOA's microcode
3015  *
3016  * Return value:
3017  *      0 on success / -EIO on failure
3018  **/
3019 static int ipr_update_ioa_ucode(struct ipr_ioa_cfg *ioa_cfg,
3020                                 struct ipr_sglist *sglist)
3021 {
3022         unsigned long lock_flags;
3023
3024         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
3025         while(ioa_cfg->in_reset_reload) {
3026                 spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
3027                 wait_event(ioa_cfg->reset_wait_q, !ioa_cfg->in_reset_reload);
3028                 spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
3029         }
3030
3031         if (ioa_cfg->ucode_sglist) {
3032                 spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
3033                 dev_err(&ioa_cfg->pdev->dev,
3034                         "Microcode download already in progress\n");
3035                 return -EIO;
3036         }
3037
3038         sglist->num_dma_sg = pci_map_sg(ioa_cfg->pdev, sglist->scatterlist,
3039                                         sglist->num_sg, DMA_TO_DEVICE);
3040
3041         if (!sglist->num_dma_sg) {
3042                 spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
3043                 dev_err(&ioa_cfg->pdev->dev,
3044                         "Failed to map microcode download buffer!\n");
3045                 return -EIO;
3046         }
3047
3048         ioa_cfg->ucode_sglist = sglist;
3049         ipr_initiate_ioa_reset(ioa_cfg, IPR_SHUTDOWN_NORMAL);
3050         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
3051         wait_event(ioa_cfg->reset_wait_q, !ioa_cfg->in_reset_reload);
3052
3053         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
3054         ioa_cfg->ucode_sglist = NULL;
3055         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
3056         return 0;
3057 }
3058
3059 /**
3060  * ipr_store_update_fw - Update the firmware on the adapter
3061  * @class_dev:  device struct
3062  * @buf:        buffer
3063  * @count:      buffer size
3064  *
3065  * This function will update the firmware on the adapter.
3066  *
3067  * Return value:
3068  *      count on success / other on failure
3069  **/
3070 static ssize_t ipr_store_update_fw(struct device *dev,
3071                                    struct device_attribute *attr,
3072                                    const char *buf, size_t count)
3073 {
3074         struct Scsi_Host *shost = class_to_shost(dev);
3075         struct ipr_ioa_cfg *ioa_cfg = (struct ipr_ioa_cfg *)shost->hostdata;
3076         struct ipr_ucode_image_header *image_hdr;
3077         const struct firmware *fw_entry;
3078         struct ipr_sglist *sglist;
3079         char fname[100];
3080         char *src;
3081         int len, result, dnld_size;
3082
3083         if (!capable(CAP_SYS_ADMIN))
3084                 return -EACCES;
3085
3086         len = snprintf(fname, 99, "%s", buf);
3087         fname[len-1] = '\0';
3088
3089         if(request_firmware(&fw_entry, fname, &ioa_cfg->pdev->dev)) {
3090                 dev_err(&ioa_cfg->pdev->dev, "Firmware file %s not found\n", fname);
3091                 return -EIO;
3092         }
3093
3094         image_hdr = (struct ipr_ucode_image_header *)fw_entry->data;
3095
3096         if (be32_to_cpu(image_hdr->header_length) > fw_entry->size ||
3097             (ioa_cfg->vpd_cbs->page3_data.card_type &&
3098              ioa_cfg->vpd_cbs->page3_data.card_type != image_hdr->card_type)) {
3099                 dev_err(&ioa_cfg->pdev->dev, "Invalid microcode buffer\n");
3100                 release_firmware(fw_entry);
3101                 return -EINVAL;
3102         }
3103
3104         src = (u8 *)image_hdr + be32_to_cpu(image_hdr->header_length);
3105         dnld_size = fw_entry->size - be32_to_cpu(image_hdr->header_length);
3106         sglist = ipr_alloc_ucode_buffer(dnld_size);
3107
3108         if (!sglist) {
3109                 dev_err(&ioa_cfg->pdev->dev, "Microcode buffer allocation failed\n");
3110                 release_firmware(fw_entry);
3111                 return -ENOMEM;
3112         }
3113
3114         result = ipr_copy_ucode_buffer(sglist, src, dnld_size);
3115
3116         if (result) {
3117                 dev_err(&ioa_cfg->pdev->dev,
3118                         "Microcode buffer copy to DMA buffer failed\n");
3119                 goto out;
3120         }
3121
3122         result = ipr_update_ioa_ucode(ioa_cfg, sglist);
3123
3124         if (!result)
3125                 result = count;
3126 out:
3127         ipr_free_ucode_buffer(sglist);
3128         release_firmware(fw_entry);
3129         return result;
3130 }
3131
3132 static struct device_attribute ipr_update_fw_attr = {
3133         .attr = {
3134                 .name =         "update_fw",
3135                 .mode =         S_IWUSR,
3136         },
3137         .store = ipr_store_update_fw
3138 };
3139
3140 static struct device_attribute *ipr_ioa_attrs[] = {
3141         &ipr_fw_version_attr,
3142         &ipr_log_level_attr,
3143         &ipr_diagnostics_attr,
3144         &ipr_ioa_state_attr,
3145         &ipr_ioa_reset_attr,
3146         &ipr_update_fw_attr,
3147         &ipr_ioa_cache_attr,
3148         NULL,
3149 };
3150
3151 #ifdef CONFIG_SCSI_IPR_DUMP
3152 /**
3153  * ipr_read_dump - Dump the adapter
3154  * @kobj:               kobject struct
3155  * @bin_attr:           bin_attribute struct
3156  * @buf:                buffer
3157  * @off:                offset
3158  * @count:              buffer size
3159  *
3160  * Return value:
3161  *      number of bytes printed to buffer
3162  **/
3163 static ssize_t ipr_read_dump(struct kobject *kobj,
3164                              struct bin_attribute *bin_attr,
3165                              char *buf, loff_t off, size_t count)
3166 {
3167         struct device *cdev = container_of(kobj, struct device, kobj);
3168         struct Scsi_Host *shost = class_to_shost(cdev);
3169         struct ipr_ioa_cfg *ioa_cfg = (struct ipr_ioa_cfg *)shost->hostdata;
3170         struct ipr_dump *dump;
3171         unsigned long lock_flags = 0;
3172         char *src;
3173         int len;
3174         size_t rc = count;
3175
3176         if (!capable(CAP_SYS_ADMIN))
3177                 return -EACCES;
3178
3179         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
3180         dump = ioa_cfg->dump;
3181
3182         if (ioa_cfg->sdt_state != DUMP_OBTAINED || !dump) {
3183                 spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
3184                 return 0;
3185         }
3186         kref_get(&dump->kref);
3187         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
3188
3189         if (off > dump->driver_dump.hdr.len) {
3190                 kref_put(&dump->kref, ipr_release_dump);
3191                 return 0;
3192         }
3193
3194         if (off + count > dump->driver_dump.hdr.len) {
3195                 count = dump->driver_dump.hdr.len - off;
3196                 rc = count;
3197         }
3198
3199         if (count && off < sizeof(dump->driver_dump)) {
3200                 if (off + count > sizeof(dump->driver_dump))
3201                         len = sizeof(dump->driver_dump) - off;
3202                 else
3203                         len = count;
3204                 src = (u8 *)&dump->driver_dump + off;
3205                 memcpy(buf, src, len);
3206                 buf += len;
3207                 off += len;
3208                 count -= len;
3209         }
3210
3211         off -= sizeof(dump->driver_dump);
3212
3213         if (count && off < offsetof(struct ipr_ioa_dump, ioa_data)) {
3214                 if (off + count > offsetof(struct ipr_ioa_dump, ioa_data))
3215                         len = offsetof(struct ipr_ioa_dump, ioa_data) - off;
3216                 else
3217                         len = count;
3218                 src = (u8 *)&dump->ioa_dump + off;
3219                 memcpy(buf, src, len);
3220                 buf += len;
3221                 off += len;
3222                 count -= len;
3223         }
3224
3225         off -= offsetof(struct ipr_ioa_dump, ioa_data);
3226
3227         while (count) {
3228                 if ((off & PAGE_MASK) != ((off + count) & PAGE_MASK))
3229                         len = PAGE_ALIGN(off) - off;
3230                 else
3231                         len = count;
3232                 src = (u8 *)dump->ioa_dump.ioa_data[(off & PAGE_MASK) >> PAGE_SHIFT];
3233                 src += off & ~PAGE_MASK;
3234                 memcpy(buf, src, len);
3235                 buf += len;
3236                 off += len;
3237                 count -= len;
3238         }
3239
3240         kref_put(&dump->kref, ipr_release_dump);
3241         return rc;
3242 }
3243
3244 /**
3245  * ipr_alloc_dump - Prepare for adapter dump
3246  * @ioa_cfg:    ioa config struct
3247  *
3248  * Return value:
3249  *      0 on success / other on failure
3250  **/
3251 static int ipr_alloc_dump(struct ipr_ioa_cfg *ioa_cfg)
3252 {
3253         struct ipr_dump *dump;
3254         unsigned long lock_flags = 0;
3255
3256         dump = kzalloc(sizeof(struct ipr_dump), GFP_KERNEL);
3257
3258         if (!dump) {
3259                 ipr_err("Dump memory allocation failed\n");
3260                 return -ENOMEM;
3261         }
3262
3263         kref_init(&dump->kref);
3264         dump->ioa_cfg = ioa_cfg;
3265
3266         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
3267
3268         if (INACTIVE != ioa_cfg->sdt_state) {
3269                 spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
3270                 kfree(dump);
3271                 return 0;
3272         }
3273
3274         ioa_cfg->dump = dump;
3275         ioa_cfg->sdt_state = WAIT_FOR_DUMP;
3276         if (ioa_cfg->ioa_is_dead && !ioa_cfg->dump_taken) {
3277                 ioa_cfg->dump_taken = 1;
3278                 schedule_work(&ioa_cfg->work_q);
3279         }
3280         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
3281
3282         return 0;
3283 }
3284
3285 /**
3286  * ipr_free_dump - Free adapter dump memory
3287  * @ioa_cfg:    ioa config struct
3288  *
3289  * Return value:
3290  *      0 on success / other on failure
3291  **/
3292 static int ipr_free_dump(struct ipr_ioa_cfg *ioa_cfg)
3293 {
3294         struct ipr_dump *dump;
3295         unsigned long lock_flags = 0;
3296
3297         ENTER;
3298
3299         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
3300         dump = ioa_cfg->dump;
3301         if (!dump) {
3302                 spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
3303                 return 0;
3304         }
3305
3306         ioa_cfg->dump = NULL;
3307         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
3308
3309         kref_put(&dump->kref, ipr_release_dump);
3310
3311         LEAVE;
3312         return 0;
3313 }
3314
3315 /**
3316  * ipr_write_dump - Setup dump state of adapter
3317  * @kobj:               kobject struct
3318  * @bin_attr:           bin_attribute struct
3319  * @buf:                buffer
3320  * @off:                offset
3321  * @count:              buffer size
3322  *
3323  * Return value:
3324  *      number of bytes printed to buffer
3325  **/
3326 static ssize_t ipr_write_dump(struct kobject *kobj,
3327                               struct bin_attribute *bin_attr,
3328                               char *buf, loff_t off, size_t count)
3329 {
3330         struct device *cdev = container_of(kobj, struct device, kobj);
3331         struct Scsi_Host *shost = class_to_shost(cdev);
3332         struct ipr_ioa_cfg *ioa_cfg = (struct ipr_ioa_cfg *)shost->hostdata;
3333         int rc;
3334
3335         if (!capable(CAP_SYS_ADMIN))
3336                 return -EACCES;
3337
3338         if (buf[0] == '1')
3339                 rc = ipr_alloc_dump(ioa_cfg);
3340         else if (buf[0] == '0')
3341                 rc = ipr_free_dump(ioa_cfg);
3342         else
3343                 return -EINVAL;
3344
3345         if (rc)
3346                 return rc;
3347         else
3348                 return count;
3349 }
3350
3351 static struct bin_attribute ipr_dump_attr = {
3352         .attr = {
3353                 .name = "dump",
3354                 .mode = S_IRUSR | S_IWUSR,
3355         },
3356         .size = 0,
3357         .read = ipr_read_dump,
3358         .write = ipr_write_dump
3359 };
3360 #else
3361 static int ipr_free_dump(struct ipr_ioa_cfg *ioa_cfg) { return 0; };
3362 #endif
3363
3364 /**
3365  * ipr_change_queue_depth - Change the device's queue depth
3366  * @sdev:       scsi device struct
3367  * @qdepth:     depth to set
3368  *
3369  * Return value:
3370  *      actual depth set
3371  **/
3372 static int ipr_change_queue_depth(struct scsi_device *sdev, int qdepth)
3373 {
3374         struct ipr_ioa_cfg *ioa_cfg = (struct ipr_ioa_cfg *)sdev->host->hostdata;
3375         struct ipr_resource_entry *res;
3376         unsigned long lock_flags = 0;
3377
3378         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
3379         res = (struct ipr_resource_entry *)sdev->hostdata;
3380
3381         if (res && ipr_is_gata(res) && qdepth > IPR_MAX_CMD_PER_ATA_LUN)
3382                 qdepth = IPR_MAX_CMD_PER_ATA_LUN;
3383         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
3384
3385         scsi_adjust_queue_depth(sdev, scsi_get_tag_type(sdev), qdepth);
3386         return sdev->queue_depth;
3387 }
3388
3389 /**
3390  * ipr_change_queue_type - Change the device's queue type
3391  * @dsev:               scsi device struct
3392  * @tag_type:   type of tags to use
3393  *
3394  * Return value:
3395  *      actual queue type set
3396  **/
3397 static int ipr_change_queue_type(struct scsi_device *sdev, int tag_type)
3398 {
3399         struct ipr_ioa_cfg *ioa_cfg = (struct ipr_ioa_cfg *)sdev->host->hostdata;
3400         struct ipr_resource_entry *res;
3401         unsigned long lock_flags = 0;
3402
3403         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
3404         res = (struct ipr_resource_entry *)sdev->hostdata;
3405
3406         if (res) {
3407                 if (ipr_is_gscsi(res) && sdev->tagged_supported) {
3408                         /*
3409                          * We don't bother quiescing the device here since the
3410                          * adapter firmware does it for us.
3411                          */
3412                         scsi_set_tag_type(sdev, tag_type);
3413
3414                         if (tag_type)
3415                                 scsi_activate_tcq(sdev, sdev->queue_depth);
3416                         else
3417                                 scsi_deactivate_tcq(sdev, sdev->queue_depth);
3418                 } else
3419                         tag_type = 0;
3420         } else
3421                 tag_type = 0;
3422
3423         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
3424         return tag_type;
3425 }
3426
3427 /**
3428  * ipr_show_adapter_handle - Show the adapter's resource handle for this device
3429  * @dev:        device struct
3430  * @buf:        buffer
3431  *
3432  * Return value:
3433  *      number of bytes printed to buffer
3434  **/
3435 static ssize_t ipr_show_adapter_handle(struct device *dev, struct device_attribute *attr, char *buf)
3436 {
3437         struct scsi_device *sdev = to_scsi_device(dev);
3438         struct ipr_ioa_cfg *ioa_cfg = (struct ipr_ioa_cfg *)sdev->host->hostdata;
3439         struct ipr_resource_entry *res;
3440         unsigned long lock_flags = 0;
3441         ssize_t len = -ENXIO;
3442
3443         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
3444         res = (struct ipr_resource_entry *)sdev->hostdata;
3445         if (res)
3446                 len = snprintf(buf, PAGE_SIZE, "%08X\n", res->cfgte.res_handle);
3447         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
3448         return len;
3449 }
3450
3451 static struct device_attribute ipr_adapter_handle_attr = {
3452         .attr = {
3453                 .name =         "adapter_handle",
3454                 .mode =         S_IRUSR,
3455         },
3456         .show = ipr_show_adapter_handle
3457 };
3458
3459 static struct device_attribute *ipr_dev_attrs[] = {
3460         &ipr_adapter_handle_attr,
3461         NULL,
3462 };
3463
3464 /**
3465  * ipr_biosparam - Return the HSC mapping
3466  * @sdev:                       scsi device struct
3467  * @block_device:       block device pointer
3468  * @capacity:           capacity of the device
3469  * @parm:                       Array containing returned HSC values.
3470  *
3471  * This function generates the HSC parms that fdisk uses.
3472  * We want to make sure we return something that places partitions
3473  * on 4k boundaries for best performance with the IOA.
3474  *
3475  * Return value:
3476  *      0 on success
3477  **/
3478 static int ipr_biosparam(struct scsi_device *sdev,
3479                          struct block_device *block_device,
3480                          sector_t capacity, int *parm)
3481 {
3482         int heads, sectors;
3483         sector_t cylinders;
3484
3485         heads = 128;
3486         sectors = 32;
3487
3488         cylinders = capacity;
3489         sector_div(cylinders, (128 * 32));
3490
3491         /* return result */
3492         parm[0] = heads;
3493         parm[1] = sectors;
3494         parm[2] = cylinders;
3495
3496         return 0;
3497 }
3498
3499 /**
3500  * ipr_find_starget - Find target based on bus/target.
3501  * @starget:    scsi target struct
3502  *
3503  * Return value:
3504  *      resource entry pointer if found / NULL if not found
3505  **/
3506 static struct ipr_resource_entry *ipr_find_starget(struct scsi_target *starget)
3507 {
3508         struct Scsi_Host *shost = dev_to_shost(&starget->dev);
3509         struct ipr_ioa_cfg *ioa_cfg = (struct ipr_ioa_cfg *) shost->hostdata;
3510         struct ipr_resource_entry *res;
3511
3512         list_for_each_entry(res, &ioa_cfg->used_res_q, queue) {
3513                 if ((res->cfgte.res_addr.bus == starget->channel) &&
3514                     (res->cfgte.res_addr.target == starget->id) &&
3515                     (res->cfgte.res_addr.lun == 0)) {
3516                         return res;
3517                 }
3518         }
3519
3520         return NULL;
3521 }
3522
3523 static struct ata_port_info sata_port_info;
3524
3525 /**
3526  * ipr_target_alloc - Prepare for commands to a SCSI target
3527  * @starget:    scsi target struct
3528  *
3529  * If the device is a SATA device, this function allocates an
3530  * ATA port with libata, else it does nothing.
3531  *
3532  * Return value:
3533  *      0 on success / non-0 on failure
3534  **/
3535 static int ipr_target_alloc(struct scsi_target *starget)
3536 {
3537         struct Scsi_Host *shost = dev_to_shost(&starget->dev);
3538         struct ipr_ioa_cfg *ioa_cfg = (struct ipr_ioa_cfg *) shost->hostdata;
3539         struct ipr_sata_port *sata_port;
3540         struct ata_port *ap;
3541         struct ipr_resource_entry *res;
3542         unsigned long lock_flags;
3543
3544         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
3545         res = ipr_find_starget(starget);
3546         starget->hostdata = NULL;
3547
3548         if (res && ipr_is_gata(res)) {
3549                 spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
3550                 sata_port = kzalloc(sizeof(*sata_port), GFP_KERNEL);
3551                 if (!sata_port)
3552                         return -ENOMEM;
3553
3554                 ap = ata_sas_port_alloc(&ioa_cfg->ata_host, &sata_port_info, shost);
3555                 if (ap) {
3556                         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
3557                         sata_port->ioa_cfg = ioa_cfg;
3558                         sata_port->ap = ap;
3559                         sata_port->res = res;
3560
3561                         res->sata_port = sata_port;
3562                         ap->private_data = sata_port;
3563                         starget->hostdata = sata_port;
3564                 } else {
3565                         kfree(sata_port);
3566                         return -ENOMEM;
3567                 }
3568         }
3569         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
3570
3571         return 0;
3572 }
3573
3574 /**
3575  * ipr_target_destroy - Destroy a SCSI target
3576  * @starget:    scsi target struct
3577  *
3578  * If the device was a SATA device, this function frees the libata
3579  * ATA port, else it does nothing.
3580  *
3581  **/
3582 static void ipr_target_destroy(struct scsi_target *starget)
3583 {
3584         struct ipr_sata_port *sata_port = starget->hostdata;
3585
3586         if (sata_port) {
3587                 starget->hostdata = NULL;
3588                 ata_sas_port_destroy(sata_port->ap);
3589                 kfree(sata_port);
3590         }
3591 }
3592
3593 /**
3594  * ipr_find_sdev - Find device based on bus/target/lun.
3595  * @sdev:       scsi device struct
3596  *
3597  * Return value:
3598  *      resource entry pointer if found / NULL if not found
3599  **/
3600 static struct ipr_resource_entry *ipr_find_sdev(struct scsi_device *sdev)
3601 {
3602         struct ipr_ioa_cfg *ioa_cfg = (struct ipr_ioa_cfg *) sdev->host->hostdata;
3603         struct ipr_resource_entry *res;
3604
3605         list_for_each_entry(res, &ioa_cfg->used_res_q, queue) {
3606                 if ((res->cfgte.res_addr.bus == sdev->channel) &&
3607                     (res->cfgte.res_addr.target == sdev->id) &&
3608                     (res->cfgte.res_addr.lun == sdev->lun))
3609                         return res;
3610         }
3611
3612         return NULL;
3613 }
3614
3615 /**
3616  * ipr_slave_destroy - Unconfigure a SCSI device
3617  * @sdev:       scsi device struct
3618  *
3619  * Return value:
3620  *      nothing
3621  **/
3622 static void ipr_slave_destroy(struct scsi_device *sdev)
3623 {
3624         struct ipr_resource_entry *res;
3625         struct ipr_ioa_cfg *ioa_cfg;
3626         unsigned long lock_flags = 0;
3627
3628         ioa_cfg = (struct ipr_ioa_cfg *) sdev->host->hostdata;
3629
3630         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
3631         res = (struct ipr_resource_entry *) sdev->hostdata;
3632         if (res) {
3633                 if (res->sata_port)
3634                         ata_port_disable(res->sata_port->ap);
3635                 sdev->hostdata = NULL;
3636                 res->sdev = NULL;
3637                 res->sata_port = NULL;
3638         }
3639         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
3640 }
3641
3642 /**
3643  * ipr_slave_configure - Configure a SCSI device
3644  * @sdev:       scsi device struct
3645  *
3646  * This function configures the specified scsi device.
3647  *
3648  * Return value:
3649  *      0 on success
3650  **/
3651 static int ipr_slave_configure(struct scsi_device *sdev)
3652 {
3653         struct ipr_ioa_cfg *ioa_cfg = (struct ipr_ioa_cfg *) sdev->host->hostdata;
3654         struct ipr_resource_entry *res;
3655         unsigned long lock_flags = 0;
3656
3657         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
3658         res = sdev->hostdata;
3659         if (res) {
3660                 if (ipr_is_af_dasd_device(res))
3661                         sdev->type = TYPE_RAID;
3662                 if (ipr_is_af_dasd_device(res) || ipr_is_ioa_resource(res)) {
3663                         sdev->scsi_level = 4;
3664                         sdev->no_uld_attach = 1;
3665                 }
3666                 if (ipr_is_vset_device(res)) {
3667                         blk_queue_rq_timeout(sdev->request_queue,
3668                                              IPR_VSET_RW_TIMEOUT);
3669                         blk_queue_max_sectors(sdev->request_queue, IPR_VSET_MAX_SECTORS);
3670                 }
3671                 if (ipr_is_vset_device(res) || ipr_is_scsi_disk(res))
3672                         sdev->allow_restart = 1;
3673                 if (ipr_is_gata(res) && res->sata_port) {
3674                         scsi_adjust_queue_depth(sdev, 0, IPR_MAX_CMD_PER_ATA_LUN);
3675                         ata_sas_slave_configure(sdev, res->sata_port->ap);
3676                 } else {
3677                         scsi_adjust_queue_depth(sdev, 0, sdev->host->cmd_per_lun);
3678                 }
3679         }
3680         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
3681         return 0;
3682 }
3683
3684 /**
3685  * ipr_ata_slave_alloc - Prepare for commands to a SATA device
3686  * @sdev:       scsi device struct
3687  *
3688  * This function initializes an ATA port so that future commands
3689  * sent through queuecommand will work.
3690  *
3691  * Return value:
3692  *      0 on success
3693  **/
3694 static int ipr_ata_slave_alloc(struct scsi_device *sdev)
3695 {
3696         struct ipr_sata_port *sata_port = NULL;
3697         int rc = -ENXIO;
3698
3699         ENTER;
3700         if (sdev->sdev_target)
3701                 sata_port = sdev->sdev_target->hostdata;
3702         if (sata_port)
3703                 rc = ata_sas_port_init(sata_port->ap);
3704         if (rc)
3705                 ipr_slave_destroy(sdev);
3706
3707         LEAVE;
3708         return rc;
3709 }
3710
3711 /**
3712  * ipr_slave_alloc - Prepare for commands to a device.
3713  * @sdev:       scsi device struct
3714  *
3715  * This function saves a pointer to the resource entry
3716  * in the scsi device struct if the device exists. We
3717  * can then use this pointer in ipr_queuecommand when
3718  * handling new commands.
3719  *
3720  * Return value:
3721  *      0 on success / -ENXIO if device does not exist
3722  **/
3723 static int ipr_slave_alloc(struct scsi_device *sdev)
3724 {
3725         struct ipr_ioa_cfg *ioa_cfg = (struct ipr_ioa_cfg *) sdev->host->hostdata;
3726         struct ipr_resource_entry *res;
3727         unsigned long lock_flags;
3728         int rc = -ENXIO;
3729
3730         sdev->hostdata = NULL;
3731
3732         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
3733
3734         res = ipr_find_sdev(sdev);
3735         if (res) {
3736                 res->sdev = sdev;
3737                 res->add_to_ml = 0;
3738                 res->in_erp = 0;
3739                 sdev->hostdata = res;
3740                 if (!ipr_is_naca_model(res))
3741                         res->needs_sync_complete = 1;
3742                 rc = 0;
3743                 if (ipr_is_gata(res)) {
3744                         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
3745                         return ipr_ata_slave_alloc(sdev);
3746                 }
3747         }
3748
3749         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
3750
3751         return rc;
3752 }
3753
3754 /**
3755  * ipr_eh_host_reset - Reset the host adapter
3756  * @scsi_cmd:   scsi command struct
3757  *
3758  * Return value:
3759  *      SUCCESS / FAILED
3760  **/
3761 static int __ipr_eh_host_reset(struct scsi_cmnd * scsi_cmd)
3762 {
3763         struct ipr_ioa_cfg *ioa_cfg;
3764         int rc;
3765
3766         ENTER;
3767         ioa_cfg = (struct ipr_ioa_cfg *) scsi_cmd->device->host->hostdata;
3768
3769         dev_err(&ioa_cfg->pdev->dev,
3770                 "Adapter being reset as a result of error recovery.\n");
3771
3772         if (WAIT_FOR_DUMP == ioa_cfg->sdt_state)
3773                 ioa_cfg->sdt_state = GET_DUMP;
3774
3775         rc = ipr_reset_reload(ioa_cfg, IPR_SHUTDOWN_ABBREV);
3776
3777         LEAVE;
3778         return rc;
3779 }
3780
3781 static int ipr_eh_host_reset(struct scsi_cmnd * cmd)
3782 {
3783         int rc;
3784
3785         spin_lock_irq(cmd->device->host->host_lock);
3786         rc = __ipr_eh_host_reset(cmd);
3787         spin_unlock_irq(cmd->device->host->host_lock);
3788
3789         return rc;
3790 }
3791
3792 /**
3793  * ipr_device_reset - Reset the device
3794  * @ioa_cfg:    ioa config struct
3795  * @res:                resource entry struct
3796  *
3797  * This function issues a device reset to the affected device.
3798  * If the device is a SCSI device, a LUN reset will be sent
3799  * to the device first. If that does not work, a target reset
3800  * will be sent. If the device is a SATA device, a PHY reset will
3801  * be sent.
3802  *
3803  * Return value:
3804  *      0 on success / non-zero on failure
3805  **/
3806 static int ipr_device_reset(struct ipr_ioa_cfg *ioa_cfg,
3807                             struct ipr_resource_entry *res)
3808 {
3809         struct ipr_cmnd *ipr_cmd;
3810         struct ipr_ioarcb *ioarcb;
3811         struct ipr_cmd_pkt *cmd_pkt;
3812         struct ipr_ioarcb_ata_regs *regs;
3813         u32 ioasc;
3814
3815         ENTER;
3816         ipr_cmd = ipr_get_free_ipr_cmnd(ioa_cfg);
3817         ioarcb = &ipr_cmd->ioarcb;
3818         cmd_pkt = &ioarcb->cmd_pkt;
3819         regs = &ioarcb->add_data.u.regs;
3820
3821         ioarcb->res_handle = res->cfgte.res_handle;
3822         cmd_pkt->request_type = IPR_RQTYPE_IOACMD;
3823         cmd_pkt->cdb[0] = IPR_RESET_DEVICE;
3824         if (ipr_is_gata(res)) {
3825                 cmd_pkt->cdb[2] = IPR_ATA_PHY_RESET;
3826                 ioarcb->add_cmd_parms_len = cpu_to_be32(sizeof(regs->flags));
3827                 regs->flags |= IPR_ATA_FLAG_STATUS_ON_GOOD_COMPLETION;
3828         }
3829
3830         ipr_send_blocking_cmd(ipr_cmd, ipr_timeout, IPR_DEVICE_RESET_TIMEOUT);
3831         ioasc = be32_to_cpu(ipr_cmd->ioasa.ioasc);
3832         list_add_tail(&ipr_cmd->queue, &ioa_cfg->free_q);
3833         if (ipr_is_gata(res) && res->sata_port && ioasc != IPR_IOASC_IOA_WAS_RESET)
3834                 memcpy(&res->sata_port->ioasa, &ipr_cmd->ioasa.u.gata,
3835                        sizeof(struct ipr_ioasa_gata));
3836
3837         LEAVE;
3838         return (IPR_IOASC_SENSE_KEY(ioasc) ? -EIO : 0);
3839 }
3840
3841 /**
3842  * ipr_sata_reset - Reset the SATA port
3843  * @link:       SATA link to reset
3844  * @classes:    class of the attached device
3845  *
3846  * This function issues a SATA phy reset to the affected ATA link.
3847  *
3848  * Return value:
3849  *      0 on success / non-zero on failure
3850  **/
3851 static int ipr_sata_reset(struct ata_link *link, unsigned int *classes,
3852                                 unsigned long deadline)
3853 {
3854         struct ipr_sata_port *sata_port = link->ap->private_data;
3855         struct ipr_ioa_cfg *ioa_cfg = sata_port->ioa_cfg;
3856         struct ipr_resource_entry *res;
3857         unsigned long lock_flags = 0;
3858         int rc = -ENXIO;
3859
3860         ENTER;
3861         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
3862         while(ioa_cfg->in_reset_reload) {
3863                 spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
3864                 wait_event(ioa_cfg->reset_wait_q, !ioa_cfg->in_reset_reload);
3865                 spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
3866         }
3867
3868         res = sata_port->res;
3869         if (res) {
3870                 rc = ipr_device_reset(ioa_cfg, res);
3871                 switch(res->cfgte.proto) {
3872                 case IPR_PROTO_SATA:
3873                 case IPR_PROTO_SAS_STP:
3874                         *classes = ATA_DEV_ATA;
3875                         break;
3876                 case IPR_PROTO_SATA_ATAPI:
3877                 case IPR_PROTO_SAS_STP_ATAPI:
3878                         *classes = ATA_DEV_ATAPI;
3879                         break;
3880                 default:
3881                         *classes = ATA_DEV_UNKNOWN;
3882                         break;
3883                 };
3884         }
3885
3886         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
3887         LEAVE;
3888         return rc;
3889 }
3890
3891 /**
3892  * ipr_eh_dev_reset - Reset the device
3893  * @scsi_cmd:   scsi command struct
3894  *
3895  * This function issues a device reset to the affected device.
3896  * A LUN reset will be sent to the device first. If that does
3897  * not work, a target reset will be sent.
3898  *
3899  * Return value:
3900  *      SUCCESS / FAILED
3901  **/
3902 static int __ipr_eh_dev_reset(struct scsi_cmnd * scsi_cmd)
3903 {
3904         struct ipr_cmnd *ipr_cmd;
3905         struct ipr_ioa_cfg *ioa_cfg;
3906         struct ipr_resource_entry *res;
3907         struct ata_port *ap;
3908         int rc = 0;
3909
3910         ENTER;
3911         ioa_cfg = (struct ipr_ioa_cfg *) scsi_cmd->device->host->hostdata;
3912         res = scsi_cmd->device->hostdata;
3913
3914         if (!res)
3915                 return FAILED;
3916
3917         /*
3918          * If we are currently going through reset/reload, return failed. This will force the
3919          * mid-layer to call ipr_eh_host_reset, which will then go to sleep and wait for the
3920          * reset to complete
3921          */
3922         if (ioa_cfg->in_reset_reload)
3923                 return FAILED;
3924         if (ioa_cfg->ioa_is_dead)
3925                 return FAILED;
3926
3927         list_for_each_entry(ipr_cmd, &ioa_cfg->pending_q, queue) {
3928                 if (ipr_cmd->ioarcb.res_handle == res->cfgte.res_handle) {
3929                         if (ipr_cmd->scsi_cmd)
3930                                 ipr_cmd->done = ipr_scsi_eh_done;
3931                         if (ipr_cmd->qc)
3932                                 ipr_cmd->done = ipr_sata_eh_done;
3933                         if (ipr_cmd->qc && !(ipr_cmd->qc->flags & ATA_QCFLAG_FAILED)) {
3934                                 ipr_cmd->qc->err_mask |= AC_ERR_TIMEOUT;
3935                                 ipr_cmd->qc->flags |= ATA_QCFLAG_FAILED;
3936                         }
3937                 }
3938         }
3939
3940         res->resetting_device = 1;
3941         scmd_printk(KERN_ERR, scsi_cmd, "Resetting device\n");
3942
3943         if (ipr_is_gata(res) && res->sata_port) {
3944                 ap = res->sata_port->ap;
3945                 spin_unlock_irq(scsi_cmd->device->host->host_lock);
3946                 ata_std_error_handler(ap);
3947                 spin_lock_irq(scsi_cmd->device->host->host_lock);
3948
3949                 list_for_each_entry(ipr_cmd, &ioa_cfg->pending_q, queue) {
3950                         if (ipr_cmd->ioarcb.res_handle == res->cfgte.res_handle) {
3951                                 rc = -EIO;
3952                                 break;
3953                         }
3954                 }
3955         } else
3956                 rc = ipr_device_reset(ioa_cfg, res);
3957         res->resetting_device = 0;
3958
3959         LEAVE;
3960         return (rc ? FAILED : SUCCESS);
3961 }
3962
3963 static int ipr_eh_dev_reset(struct scsi_cmnd * cmd)
3964 {
3965         int rc;
3966
3967         spin_lock_irq(cmd->device->host->host_lock);
3968         rc = __ipr_eh_dev_reset(cmd);
3969         spin_unlock_irq(cmd->device->host->host_lock);
3970
3971         return rc;
3972 }
3973
3974 /**
3975  * ipr_bus_reset_done - Op done function for bus reset.
3976  * @ipr_cmd:    ipr command struct
3977  *
3978  * This function is the op done function for a bus reset
3979  *
3980  * Return value:
3981  *      none
3982  **/
3983 static void ipr_bus_reset_done(struct ipr_cmnd *ipr_cmd)
3984 {
3985         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
3986         struct ipr_resource_entry *res;
3987
3988         ENTER;
3989         list_for_each_entry(res, &ioa_cfg->used_res_q, queue) {
3990                 if (!memcmp(&res->cfgte.res_handle, &ipr_cmd->ioarcb.res_handle,
3991                             sizeof(res->cfgte.res_handle))) {
3992                         scsi_report_bus_reset(ioa_cfg->host, res->cfgte.res_addr.bus);
3993                         break;
3994                 }
3995         }
3996
3997         /*
3998          * If abort has not completed, indicate the reset has, else call the
3999          * abort's done function to wake the sleeping eh thread
4000          */
4001         if (ipr_cmd->sibling->sibling)
4002                 ipr_cmd->sibling->sibling = NULL;
4003         else
4004                 ipr_cmd->sibling->done(ipr_cmd->sibling);
4005
4006         list_add_tail(&ipr_cmd->queue, &ioa_cfg->free_q);
4007         LEAVE;
4008 }
4009
4010 /**
4011  * ipr_abort_timeout - An abort task has timed out
4012  * @ipr_cmd:    ipr command struct
4013  *
4014  * This function handles when an abort task times out. If this
4015  * happens we issue a bus reset since we have resources tied
4016  * up that must be freed before returning to the midlayer.
4017  *
4018  * Return value:
4019  *      none
4020  **/
4021 static void ipr_abort_timeout(struct ipr_cmnd *ipr_cmd)
4022 {
4023         struct ipr_cmnd *reset_cmd;
4024         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
4025         struct ipr_cmd_pkt *cmd_pkt;
4026         unsigned long lock_flags = 0;
4027
4028         ENTER;
4029         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
4030         if (ipr_cmd->completion.done || ioa_cfg->in_reset_reload) {
4031                 spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
4032                 return;
4033         }
4034
4035         sdev_printk(KERN_ERR, ipr_cmd->u.sdev, "Abort timed out. Resetting bus.\n");
4036         reset_cmd = ipr_get_free_ipr_cmnd(ioa_cfg);
4037         ipr_cmd->sibling = reset_cmd;
4038         reset_cmd->sibling = ipr_cmd;
4039         reset_cmd->ioarcb.res_handle = ipr_cmd->ioarcb.res_handle;
4040         cmd_pkt = &reset_cmd->ioarcb.cmd_pkt;
4041         cmd_pkt->request_type = IPR_RQTYPE_IOACMD;
4042         cmd_pkt->cdb[0] = IPR_RESET_DEVICE;
4043         cmd_pkt->cdb[2] = IPR_RESET_TYPE_SELECT | IPR_BUS_RESET;
4044
4045         ipr_do_req(reset_cmd, ipr_bus_reset_done, ipr_timeout, IPR_DEVICE_RESET_TIMEOUT);
4046         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
4047         LEAVE;
4048 }
4049
4050 /**
4051  * ipr_cancel_op - Cancel specified op
4052  * @scsi_cmd:   scsi command struct
4053  *
4054  * This function cancels specified op.
4055  *
4056  * Return value:
4057  *      SUCCESS / FAILED
4058  **/
4059 static int ipr_cancel_op(struct scsi_cmnd * scsi_cmd)
4060 {
4061         struct ipr_cmnd *ipr_cmd;
4062         struct ipr_ioa_cfg *ioa_cfg;
4063         struct ipr_resource_entry *res;
4064         struct ipr_cmd_pkt *cmd_pkt;
4065         u32 ioasc;
4066         int op_found = 0;
4067
4068         ENTER;
4069         ioa_cfg = (struct ipr_ioa_cfg *)scsi_cmd->device->host->hostdata;
4070         res = scsi_cmd->device->hostdata;
4071
4072         /* If we are currently going through reset/reload, return failed.
4073          * This will force the mid-layer to call ipr_eh_host_reset,
4074          * which will then go to sleep and wait for the reset to complete
4075          */
4076         if (ioa_cfg->in_reset_reload || ioa_cfg->ioa_is_dead)
4077                 return FAILED;
4078         if (!res || !ipr_is_gscsi(res))
4079                 return FAILED;
4080
4081         list_for_each_entry(ipr_cmd, &ioa_cfg->pending_q, queue) {
4082                 if (ipr_cmd->scsi_cmd == scsi_cmd) {
4083                         ipr_cmd->done = ipr_scsi_eh_done;
4084                         op_found = 1;
4085                         break;
4086                 }
4087         }
4088
4089         if (!op_found)
4090                 return SUCCESS;
4091
4092         ipr_cmd = ipr_get_free_ipr_cmnd(ioa_cfg);
4093         ipr_cmd->ioarcb.res_handle = res->cfgte.res_handle;
4094         cmd_pkt = &ipr_cmd->ioarcb.cmd_pkt;
4095         cmd_pkt->request_type = IPR_RQTYPE_IOACMD;
4096         cmd_pkt->cdb[0] = IPR_CANCEL_ALL_REQUESTS;
4097         ipr_cmd->u.sdev = scsi_cmd->device;
4098
4099         scmd_printk(KERN_ERR, scsi_cmd, "Aborting command: %02X\n",
4100                     scsi_cmd->cmnd[0]);
4101         ipr_send_blocking_cmd(ipr_cmd, ipr_abort_timeout, IPR_CANCEL_ALL_TIMEOUT);
4102         ioasc = be32_to_cpu(ipr_cmd->ioasa.ioasc);
4103
4104         /*
4105          * If the abort task timed out and we sent a bus reset, we will get
4106          * one the following responses to the abort
4107          */
4108         if (ioasc == IPR_IOASC_BUS_WAS_RESET || ioasc == IPR_IOASC_SYNC_REQUIRED) {
4109                 ioasc = 0;
4110                 ipr_trace;
4111         }
4112
4113         list_add_tail(&ipr_cmd->queue, &ioa_cfg->free_q);
4114         if (!ipr_is_naca_model(res))
4115                 res->needs_sync_complete = 1;
4116
4117         LEAVE;
4118         return (IPR_IOASC_SENSE_KEY(ioasc) ? FAILED : SUCCESS);
4119 }
4120
4121 /**
4122  * ipr_eh_abort - Abort a single op
4123  * @scsi_cmd:   scsi command struct
4124  *
4125  * Return value:
4126  *      SUCCESS / FAILED
4127  **/
4128 static int ipr_eh_abort(struct scsi_cmnd * scsi_cmd)
4129 {
4130         unsigned long flags;
4131         int rc;
4132
4133         ENTER;
4134
4135         spin_lock_irqsave(scsi_cmd->device->host->host_lock, flags);
4136         rc = ipr_cancel_op(scsi_cmd);
4137         spin_unlock_irqrestore(scsi_cmd->device->host->host_lock, flags);
4138
4139         LEAVE;
4140         return rc;
4141 }
4142
4143 /**
4144  * ipr_handle_other_interrupt - Handle "other" interrupts
4145  * @ioa_cfg:    ioa config struct
4146  * @int_reg:    interrupt register
4147  *
4148  * Return value:
4149  *      IRQ_NONE / IRQ_HANDLED
4150  **/
4151 static irqreturn_t ipr_handle_other_interrupt(struct ipr_ioa_cfg *ioa_cfg,
4152                                               volatile u32 int_reg)
4153 {
4154         irqreturn_t rc = IRQ_HANDLED;
4155
4156         if (int_reg & IPR_PCII_IOA_TRANS_TO_OPER) {
4157                 /* Mask the interrupt */
4158                 writel(IPR_PCII_IOA_TRANS_TO_OPER, ioa_cfg->regs.set_interrupt_mask_reg);
4159
4160                 /* Clear the interrupt */
4161                 writel(IPR_PCII_IOA_TRANS_TO_OPER, ioa_cfg->regs.clr_interrupt_reg);
4162                 int_reg = readl(ioa_cfg->regs.sense_interrupt_reg);
4163
4164                 list_del(&ioa_cfg->reset_cmd->queue);
4165                 del_timer(&ioa_cfg->reset_cmd->timer);
4166                 ipr_reset_ioa_job(ioa_cfg->reset_cmd);
4167         } else {
4168                 if (int_reg & IPR_PCII_IOA_UNIT_CHECKED)
4169                         ioa_cfg->ioa_unit_checked = 1;
4170                 else
4171                         dev_err(&ioa_cfg->pdev->dev,
4172                                 "Permanent IOA failure. 0x%08X\n", int_reg);
4173
4174                 if (WAIT_FOR_DUMP == ioa_cfg->sdt_state)
4175                         ioa_cfg->sdt_state = GET_DUMP;
4176
4177                 ipr_mask_and_clear_interrupts(ioa_cfg, ~0);
4178                 ipr_initiate_ioa_reset(ioa_cfg, IPR_SHUTDOWN_NONE);
4179         }
4180
4181         return rc;
4182 }
4183
4184 /**
4185  * ipr_isr - Interrupt service routine
4186  * @irq:        irq number
4187  * @devp:       pointer to ioa config struct
4188  *
4189  * Return value:
4190  *      IRQ_NONE / IRQ_HANDLED
4191  **/
4192 static irqreturn_t ipr_isr(int irq, void *devp)
4193 {
4194         struct ipr_ioa_cfg *ioa_cfg = (struct ipr_ioa_cfg *)devp;
4195         unsigned long lock_flags = 0;
4196         volatile u32 int_reg, int_mask_reg;
4197         u32 ioasc;
4198         u16 cmd_index;
4199         struct ipr_cmnd *ipr_cmd;
4200         irqreturn_t rc = IRQ_NONE;
4201
4202         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
4203
4204         /* If interrupts are disabled, ignore the interrupt */
4205         if (!ioa_cfg->allow_interrupts) {
4206                 spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
4207                 return IRQ_NONE;
4208         }
4209
4210         int_mask_reg = readl(ioa_cfg->regs.sense_interrupt_mask_reg);
4211         int_reg = readl(ioa_cfg->regs.sense_interrupt_reg) & ~int_mask_reg;
4212
4213         /* If an interrupt on the adapter did not occur, ignore it */
4214         if (unlikely((int_reg & IPR_PCII_OPER_INTERRUPTS) == 0)) {
4215                 spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
4216                 return IRQ_NONE;
4217         }
4218
4219         while (1) {
4220                 ipr_cmd = NULL;
4221
4222                 while ((be32_to_cpu(*ioa_cfg->hrrq_curr) & IPR_HRRQ_TOGGLE_BIT) ==
4223                        ioa_cfg->toggle_bit) {
4224
4225                         cmd_index = (be32_to_cpu(*ioa_cfg->hrrq_curr) &
4226                                      IPR_HRRQ_REQ_RESP_HANDLE_MASK) >> IPR_HRRQ_REQ_RESP_HANDLE_SHIFT;
4227
4228                         if (unlikely(cmd_index >= IPR_NUM_CMD_BLKS)) {
4229                                 ioa_cfg->errors_logged++;
4230                                 dev_err(&ioa_cfg->pdev->dev, "Invalid response handle from IOA\n");
4231
4232                                 if (WAIT_FOR_DUMP == ioa_cfg->sdt_state)
4233                                         ioa_cfg->sdt_state = GET_DUMP;
4234
4235                                 ipr_initiate_ioa_reset(ioa_cfg, IPR_SHUTDOWN_NONE);
4236                                 spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
4237                                 return IRQ_HANDLED;
4238                         }
4239
4240                         ipr_cmd = ioa_cfg->ipr_cmnd_list[cmd_index];
4241
4242                         ioasc = be32_to_cpu(ipr_cmd->ioasa.ioasc);
4243
4244                         ipr_trc_hook(ipr_cmd, IPR_TRACE_FINISH, ioasc);
4245
4246                         list_del(&ipr_cmd->queue);
4247                         del_timer(&ipr_cmd->timer);
4248                         ipr_cmd->done(ipr_cmd);
4249
4250                         rc = IRQ_HANDLED;
4251
4252                         if (ioa_cfg->hrrq_curr < ioa_cfg->hrrq_end) {
4253                                 ioa_cfg->hrrq_curr++;
4254                         } else {
4255                                 ioa_cfg->hrrq_curr = ioa_cfg->hrrq_start;
4256                                 ioa_cfg->toggle_bit ^= 1u;
4257                         }
4258                 }
4259
4260                 if (ipr_cmd != NULL) {
4261                         /* Clear the PCI interrupt */
4262                         writel(IPR_PCII_HRRQ_UPDATED, ioa_cfg->regs.clr_interrupt_reg);
4263                         int_reg = readl(ioa_cfg->regs.sense_interrupt_reg) & ~int_mask_reg;
4264                 } else
4265                         break;
4266         }
4267
4268         if (unlikely(rc == IRQ_NONE))
4269                 rc = ipr_handle_other_interrupt(ioa_cfg, int_reg);
4270
4271         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
4272         return rc;
4273 }
4274
4275 /**
4276  * ipr_build_ioadl - Build a scatter/gather list and map the buffer
4277  * @ioa_cfg:    ioa config struct
4278  * @ipr_cmd:    ipr command struct
4279  *
4280  * Return value:
4281  *      0 on success / -1 on failure
4282  **/
4283 static int ipr_build_ioadl(struct ipr_ioa_cfg *ioa_cfg,
4284                            struct ipr_cmnd *ipr_cmd)
4285 {
4286         int i, nseg;
4287         struct scatterlist *sg;
4288         u32 length;
4289         u32 ioadl_flags = 0;
4290         struct scsi_cmnd *scsi_cmd = ipr_cmd->scsi_cmd;
4291         struct ipr_ioarcb *ioarcb = &ipr_cmd->ioarcb;
4292         struct ipr_ioadl_desc *ioadl = ipr_cmd->ioadl;
4293
4294         length = scsi_bufflen(scsi_cmd);
4295         if (!length)
4296                 return 0;
4297
4298         nseg = scsi_dma_map(scsi_cmd);
4299         if (nseg < 0) {
4300                 dev_err(&ioa_cfg->pdev->dev, "pci_map_sg failed!\n");
4301                 return -1;
4302         }
4303
4304         ipr_cmd->dma_use_sg = nseg;
4305
4306         if (scsi_cmd->sc_data_direction == DMA_TO_DEVICE) {
4307                 ioadl_flags = IPR_IOADL_FLAGS_WRITE;
4308                 ioarcb->cmd_pkt.flags_hi |= IPR_FLAGS_HI_WRITE_NOT_READ;
4309                 ioarcb->write_data_transfer_length = cpu_to_be32(length);
4310                 ioarcb->write_ioadl_len =
4311                         cpu_to_be32(sizeof(struct ipr_ioadl_desc) * ipr_cmd->dma_use_sg);
4312         } else if (scsi_cmd->sc_data_direction == DMA_FROM_DEVICE) {
4313                 ioadl_flags = IPR_IOADL_FLAGS_READ;
4314                 ioarcb->read_data_transfer_length = cpu_to_be32(length);
4315                 ioarcb->read_ioadl_len =
4316                         cpu_to_be32(sizeof(struct ipr_ioadl_desc) * ipr_cmd->dma_use_sg);
4317         }
4318
4319         if (ipr_cmd->dma_use_sg <= ARRAY_SIZE(ioarcb->add_data.u.ioadl)) {
4320                 ioadl = ioarcb->add_data.u.ioadl;
4321                 ioarcb->write_ioadl_addr =
4322                         cpu_to_be32(be32_to_cpu(ioarcb->ioarcb_host_pci_addr) +
4323                                     offsetof(struct ipr_ioarcb, add_data));
4324                 ioarcb->read_ioadl_addr = ioarcb->write_ioadl_addr;
4325         }
4326
4327         scsi_for_each_sg(scsi_cmd, sg, ipr_cmd->dma_use_sg, i) {
4328                 ioadl[i].flags_and_data_len =
4329                         cpu_to_be32(ioadl_flags | sg_dma_len(sg));
4330                 ioadl[i].address = cpu_to_be32(sg_dma_address(sg));
4331         }
4332
4333         ioadl[i-1].flags_and_data_len |= cpu_to_be32(IPR_IOADL_FLAGS_LAST);
4334         return 0;
4335 }
4336
4337 /**
4338  * ipr_get_task_attributes - Translate SPI Q-Tag to task attributes
4339  * @scsi_cmd:   scsi command struct
4340  *
4341  * Return value:
4342  *      task attributes
4343  **/
4344 static u8 ipr_get_task_attributes(struct scsi_cmnd *scsi_cmd)
4345 {
4346         u8 tag[2];
4347         u8 rc = IPR_FLAGS_LO_UNTAGGED_TASK;
4348
4349         if (scsi_populate_tag_msg(scsi_cmd, tag)) {
4350                 switch (tag[0]) {
4351                 case MSG_SIMPLE_TAG:
4352                         rc = IPR_FLAGS_LO_SIMPLE_TASK;
4353                         break;
4354                 case MSG_HEAD_TAG:
4355                         rc = IPR_FLAGS_LO_HEAD_OF_Q_TASK;
4356                         break;
4357                 case MSG_ORDERED_TAG:
4358                         rc = IPR_FLAGS_LO_ORDERED_TASK;
4359                         break;
4360                 };
4361         }
4362
4363         return rc;
4364 }
4365
4366 /**
4367  * ipr_erp_done - Process completion of ERP for a device
4368  * @ipr_cmd:            ipr command struct
4369  *
4370  * This function copies the sense buffer into the scsi_cmd
4371  * struct and pushes the scsi_done function.
4372  *
4373  * Return value:
4374  *      nothing
4375  **/
4376 static void ipr_erp_done(struct ipr_cmnd *ipr_cmd)
4377 {
4378         struct scsi_cmnd *scsi_cmd = ipr_cmd->scsi_cmd;
4379         struct ipr_resource_entry *res = scsi_cmd->device->hostdata;
4380         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
4381         u32 ioasc = be32_to_cpu(ipr_cmd->ioasa.ioasc);
4382
4383         if (IPR_IOASC_SENSE_KEY(ioasc) > 0) {
4384                 scsi_cmd->result |= (DID_ERROR << 16);
4385                 scmd_printk(KERN_ERR, scsi_cmd,
4386                             "Request Sense failed with IOASC: 0x%08X\n", ioasc);
4387         } else {
4388                 memcpy(scsi_cmd->sense_buffer, ipr_cmd->sense_buffer,
4389                        SCSI_SENSE_BUFFERSIZE);
4390         }
4391
4392         if (res) {
4393                 if (!ipr_is_naca_model(res))
4394                         res->needs_sync_complete = 1;
4395                 res->in_erp = 0;
4396         }
4397         scsi_dma_unmap(ipr_cmd->scsi_cmd);
4398         list_add_tail(&ipr_cmd->queue, &ioa_cfg->free_q);
4399         scsi_cmd->scsi_done(scsi_cmd);
4400 }
4401
4402 /**
4403  * ipr_reinit_ipr_cmnd_for_erp - Re-initialize a cmnd block to be used for ERP
4404  * @ipr_cmd:    ipr command struct
4405  *
4406  * Return value:
4407  *      none
4408  **/
4409 static void ipr_reinit_ipr_cmnd_for_erp(struct ipr_cmnd *ipr_cmd)
4410 {
4411         struct ipr_ioarcb *ioarcb = &ipr_cmd->ioarcb;
4412         struct ipr_ioasa *ioasa = &ipr_cmd->ioasa;
4413         dma_addr_t dma_addr = be32_to_cpu(ioarcb->ioarcb_host_pci_addr);
4414
4415         memset(&ioarcb->cmd_pkt, 0, sizeof(struct ipr_cmd_pkt));
4416         ioarcb->write_data_transfer_length = 0;
4417         ioarcb->read_data_transfer_length = 0;
4418         ioarcb->write_ioadl_len = 0;
4419         ioarcb->read_ioadl_len = 0;
4420         ioasa->ioasc = 0;
4421         ioasa->residual_data_len = 0;
4422         ioarcb->write_ioadl_addr =
4423                 cpu_to_be32(dma_addr + offsetof(struct ipr_cmnd, ioadl));
4424         ioarcb->read_ioadl_addr = ioarcb->write_ioadl_addr;
4425 }
4426
4427 /**
4428  * ipr_erp_request_sense - Send request sense to a device
4429  * @ipr_cmd:    ipr command struct
4430  *
4431  * This function sends a request sense to a device as a result
4432  * of a check condition.
4433  *
4434  * Return value:
4435  *      nothing
4436  **/
4437 static void ipr_erp_request_sense(struct ipr_cmnd *ipr_cmd)
4438 {
4439         struct ipr_cmd_pkt *cmd_pkt = &ipr_cmd->ioarcb.cmd_pkt;
4440         u32 ioasc = be32_to_cpu(ipr_cmd->ioasa.ioasc);
4441
4442         if (IPR_IOASC_SENSE_KEY(ioasc) > 0) {
4443                 ipr_erp_done(ipr_cmd);
4444                 return;
4445         }
4446
4447         ipr_reinit_ipr_cmnd_for_erp(ipr_cmd);
4448
4449         cmd_pkt->request_type = IPR_RQTYPE_SCSICDB;
4450         cmd_pkt->cdb[0] = REQUEST_SENSE;
4451         cmd_pkt->cdb[4] = SCSI_SENSE_BUFFERSIZE;
4452         cmd_pkt->flags_hi |= IPR_FLAGS_HI_SYNC_OVERRIDE;
4453         cmd_pkt->flags_hi |= IPR_FLAGS_HI_NO_ULEN_CHK;
4454         cmd_pkt->timeout = cpu_to_be16(IPR_REQUEST_SENSE_TIMEOUT / HZ);
4455
4456         ipr_cmd->ioadl[0].flags_and_data_len =
4457                 cpu_to_be32(IPR_IOADL_FLAGS_READ_LAST | SCSI_SENSE_BUFFERSIZE);
4458         ipr_cmd->ioadl[0].address =
4459                 cpu_to_be32(ipr_cmd->sense_buffer_dma);
4460
4461         ipr_cmd->ioarcb.read_ioadl_len =
4462                 cpu_to_be32(sizeof(struct ipr_ioadl_desc));
4463         ipr_cmd->ioarcb.read_data_transfer_length =
4464                 cpu_to_be32(SCSI_SENSE_BUFFERSIZE);
4465
4466         ipr_do_req(ipr_cmd, ipr_erp_done, ipr_timeout,
4467                    IPR_REQUEST_SENSE_TIMEOUT * 2);
4468 }
4469
4470 /**
4471  * ipr_erp_cancel_all - Send cancel all to a device
4472  * @ipr_cmd:    ipr command struct
4473  *
4474  * This function sends a cancel all to a device to clear the
4475  * queue. If we are running TCQ on the device, QERR is set to 1,
4476  * which means all outstanding ops have been dropped on the floor.
4477  * Cancel all will return them to us.
4478  *
4479  * Return value:
4480  *      nothing
4481  **/
4482 static void ipr_erp_cancel_all(struct ipr_cmnd *ipr_cmd)
4483 {
4484         struct scsi_cmnd *scsi_cmd = ipr_cmd->scsi_cmd;
4485         struct ipr_resource_entry *res = scsi_cmd->device->hostdata;
4486         struct ipr_cmd_pkt *cmd_pkt;
4487
4488         res->in_erp = 1;
4489
4490         ipr_reinit_ipr_cmnd_for_erp(ipr_cmd);
4491
4492         if (!scsi_get_tag_type(scsi_cmd->device)) {
4493                 ipr_erp_request_sense(ipr_cmd);
4494                 return;
4495         }
4496
4497         cmd_pkt = &ipr_cmd->ioarcb.cmd_pkt;
4498         cmd_pkt->request_type = IPR_RQTYPE_IOACMD;
4499         cmd_pkt->cdb[0] = IPR_CANCEL_ALL_REQUESTS;
4500
4501         ipr_do_req(ipr_cmd, ipr_erp_request_sense, ipr_timeout,
4502                    IPR_CANCEL_ALL_TIMEOUT);
4503 }
4504
4505 /**
4506  * ipr_dump_ioasa - Dump contents of IOASA
4507  * @ioa_cfg:    ioa config struct
4508  * @ipr_cmd:    ipr command struct
4509  * @res:                resource entry struct
4510  *
4511  * This function is invoked by the interrupt handler when ops
4512  * fail. It will log the IOASA if appropriate. Only called
4513  * for GPDD ops.
4514  *
4515  * Return value:
4516  *      none
4517  **/
4518 static void ipr_dump_ioasa(struct ipr_ioa_cfg *ioa_cfg,
4519                            struct ipr_cmnd *ipr_cmd, struct ipr_resource_entry *res)
4520 {
4521         int i;
4522         u16 data_len;
4523         u32 ioasc, fd_ioasc;
4524         struct ipr_ioasa *ioasa = &ipr_cmd->ioasa;
4525         __be32 *ioasa_data = (__be32 *)ioasa;
4526         int error_index;
4527
4528         ioasc = be32_to_cpu(ioasa->ioasc) & IPR_IOASC_IOASC_MASK;
4529         fd_ioasc = be32_to_cpu(ioasa->fd_ioasc) & IPR_IOASC_IOASC_MASK;
4530
4531         if (0 == ioasc)
4532                 return;
4533
4534         if (ioa_cfg->log_level < IPR_DEFAULT_LOG_LEVEL)
4535                 return;
4536
4537         if (ioasc == IPR_IOASC_BUS_WAS_RESET && fd_ioasc)
4538                 error_index = ipr_get_error(fd_ioasc);
4539         else
4540                 error_index = ipr_get_error(ioasc);
4541
4542         if (ioa_cfg->log_level < IPR_MAX_LOG_LEVEL) {
4543                 /* Don't log an error if the IOA already logged one */
4544                 if (ioasa->ilid != 0)
4545                         return;
4546
4547                 if (!ipr_is_gscsi(res))
4548                         return;
4549
4550                 if (ipr_error_table[error_index].log_ioasa == 0)
4551                         return;
4552         }
4553
4554         ipr_res_err(ioa_cfg, res, "%s\n", ipr_error_table[error_index].error);
4555
4556         if (sizeof(struct ipr_ioasa) < be16_to_cpu(ioasa->ret_stat_len))
4557                 data_len = sizeof(struct ipr_ioasa);
4558         else
4559                 data_len = be16_to_cpu(ioasa->ret_stat_len);
4560
4561         ipr_err("IOASA Dump:\n");
4562
4563         for (i = 0; i < data_len / 4; i += 4) {
4564                 ipr_err("%08X: %08X %08X %08X %08X\n", i*4,
4565                         be32_to_cpu(ioasa_data[i]),
4566                         be32_to_cpu(ioasa_data[i+1]),
4567                         be32_to_cpu(ioasa_data[i+2]),
4568                         be32_to_cpu(ioasa_data[i+3]));
4569         }
4570 }
4571
4572 /**
4573  * ipr_gen_sense - Generate SCSI sense data from an IOASA
4574  * @ioasa:              IOASA
4575  * @sense_buf:  sense data buffer
4576  *
4577  * Return value:
4578  *      none
4579  **/
4580 static void ipr_gen_sense(struct ipr_cmnd *ipr_cmd)
4581 {
4582         u32 failing_lba;
4583         u8 *sense_buf = ipr_cmd->scsi_cmd->sense_buffer;
4584         struct ipr_resource_entry *res = ipr_cmd->scsi_cmd->device->hostdata;
4585         struct ipr_ioasa *ioasa = &ipr_cmd->ioasa;
4586         u32 ioasc = be32_to_cpu(ioasa->ioasc);
4587
4588         memset(sense_buf, 0, SCSI_SENSE_BUFFERSIZE);
4589
4590         if (ioasc >= IPR_FIRST_DRIVER_IOASC)
4591                 return;
4592
4593         ipr_cmd->scsi_cmd->result = SAM_STAT_CHECK_CONDITION;
4594
4595         if (ipr_is_vset_device(res) &&
4596             ioasc == IPR_IOASC_MED_DO_NOT_REALLOC &&
4597             ioasa->u.vset.failing_lba_hi != 0) {
4598                 sense_buf[0] = 0x72;
4599                 sense_buf[1] = IPR_IOASC_SENSE_KEY(ioasc);
4600                 sense_buf[2] = IPR_IOASC_SENSE_CODE(ioasc);
4601                 sense_buf[3] = IPR_IOASC_SENSE_QUAL(ioasc);
4602
4603                 sense_buf[7] = 12;
4604                 sense_buf[8] = 0;
4605                 sense_buf[9] = 0x0A;
4606                 sense_buf[10] = 0x80;
4607
4608                 failing_lba = be32_to_cpu(ioasa->u.vset.failing_lba_hi);
4609
4610                 sense_buf[12] = (failing_lba & 0xff000000) >> 24;
4611                 sense_buf[13] = (failing_lba & 0x00ff0000) >> 16;
4612                 sense_buf[14] = (failing_lba & 0x0000ff00) >> 8;
4613                 sense_buf[15] = failing_lba & 0x000000ff;
4614
4615                 failing_lba = be32_to_cpu(ioasa->u.vset.failing_lba_lo);
4616
4617                 sense_buf[16] = (failing_lba & 0xff000000) >> 24;
4618                 sense_buf[17] = (failing_lba & 0x00ff0000) >> 16;
4619                 sense_buf[18] = (failing_lba & 0x0000ff00) >> 8;
4620                 sense_buf[19] = failing_lba & 0x000000ff;
4621         } else {
4622                 sense_buf[0] = 0x70;
4623                 sense_buf[2] = IPR_IOASC_SENSE_KEY(ioasc);
4624                 sense_buf[12] = IPR_IOASC_SENSE_CODE(ioasc);
4625                 sense_buf[13] = IPR_IOASC_SENSE_QUAL(ioasc);
4626
4627                 /* Illegal request */
4628                 if ((IPR_IOASC_SENSE_KEY(ioasc) == 0x05) &&
4629                     (be32_to_cpu(ioasa->ioasc_specific) & IPR_FIELD_POINTER_VALID)) {
4630                         sense_buf[7] = 10;      /* additional length */
4631
4632                         /* IOARCB was in error */
4633                         if (IPR_IOASC_SENSE_CODE(ioasc) == 0x24)
4634                                 sense_buf[15] = 0xC0;
4635                         else    /* Parameter data was invalid */
4636                                 sense_buf[15] = 0x80;
4637
4638                         sense_buf[16] =
4639                             ((IPR_FIELD_POINTER_MASK &
4640                               be32_to_cpu(ioasa->ioasc_specific)) >> 8) & 0xff;
4641                         sense_buf[17] =
4642                             (IPR_FIELD_POINTER_MASK &
4643                              be32_to_cpu(ioasa->ioasc_specific)) & 0xff;
4644                 } else {
4645                         if (ioasc == IPR_IOASC_MED_DO_NOT_REALLOC) {
4646                                 if (ipr_is_vset_device(res))
4647                                         failing_lba = be32_to_cpu(ioasa->u.vset.failing_lba_lo);
4648                                 else
4649                                         failing_lba = be32_to_cpu(ioasa->u.dasd.failing_lba);
4650
4651                                 sense_buf[0] |= 0x80;   /* Or in the Valid bit */
4652                                 sense_buf[3] = (failing_lba & 0xff000000) >> 24;
4653                                 sense_buf[4] = (failing_lba & 0x00ff0000) >> 16;
4654                                 sense_buf[5] = (failing_lba & 0x0000ff00) >> 8;
4655                                 sense_buf[6] = failing_lba & 0x000000ff;
4656                         }
4657
4658                         sense_buf[7] = 6;       /* additional length */
4659                 }
4660         }
4661 }
4662
4663 /**
4664  * ipr_get_autosense - Copy autosense data to sense buffer
4665  * @ipr_cmd:    ipr command struct
4666  *
4667  * This function copies the autosense buffer to the buffer
4668  * in the scsi_cmd, if there is autosense available.
4669  *
4670  * Return value:
4671  *      1 if autosense was available / 0 if not
4672  **/
4673 static int ipr_get_autosense(struct ipr_cmnd *ipr_cmd)
4674 {
4675         struct ipr_ioasa *ioasa = &ipr_cmd->ioasa;
4676
4677         if ((be32_to_cpu(ioasa->ioasc_specific) & IPR_AUTOSENSE_VALID) == 0)
4678                 return 0;
4679
4680         memcpy(ipr_cmd->scsi_cmd->sense_buffer, ioasa->auto_sense.data,
4681                min_t(u16, be16_to_cpu(ioasa->auto_sense.auto_sense_len),
4682                    SCSI_SENSE_BUFFERSIZE));
4683         return 1;
4684 }
4685
4686 /**
4687  * ipr_erp_start - Process an error response for a SCSI op
4688  * @ioa_cfg:    ioa config struct
4689  * @ipr_cmd:    ipr command struct
4690  *
4691  * This function determines whether or not to initiate ERP
4692  * on the affected device.
4693  *
4694  * Return value:
4695  *      nothing
4696  **/
4697 static void ipr_erp_start(struct ipr_ioa_cfg *ioa_cfg,
4698                               struct ipr_cmnd *ipr_cmd)
4699 {
4700         struct scsi_cmnd *scsi_cmd = ipr_cmd->scsi_cmd;
4701         struct ipr_resource_entry *res = scsi_cmd->device->hostdata;
4702         u32 ioasc = be32_to_cpu(ipr_cmd->ioasa.ioasc);
4703         u32 masked_ioasc = ioasc & IPR_IOASC_IOASC_MASK;
4704
4705         if (!res) {
4706                 ipr_scsi_eh_done(ipr_cmd);
4707                 return;
4708         }
4709
4710         if (!ipr_is_gscsi(res) && masked_ioasc != IPR_IOASC_HW_DEV_BUS_STATUS)
4711                 ipr_gen_sense(ipr_cmd);
4712
4713         ipr_dump_ioasa(ioa_cfg, ipr_cmd, res);
4714
4715         switch (masked_ioasc) {
4716         case IPR_IOASC_ABORTED_CMD_TERM_BY_HOST:
4717                 if (ipr_is_naca_model(res))
4718                         scsi_cmd->result |= (DID_ABORT << 16);
4719                 else
4720                         scsi_cmd->result |= (DID_IMM_RETRY << 16);
4721                 break;
4722         case IPR_IOASC_IR_RESOURCE_HANDLE:
4723         case IPR_IOASC_IR_NO_CMDS_TO_2ND_IOA:
4724                 scsi_cmd->result |= (DID_NO_CONNECT << 16);
4725                 break;
4726         case IPR_IOASC_HW_SEL_TIMEOUT:
4727                 scsi_cmd->result |= (DID_NO_CONNECT << 16);
4728                 if (!ipr_is_naca_model(res))
4729                         res->needs_sync_complete = 1;
4730                 break;
4731         case IPR_IOASC_SYNC_REQUIRED:
4732                 if (!res->in_erp)
4733                         res->needs_sync_complete = 1;
4734                 scsi_cmd->result |= (DID_IMM_RETRY << 16);
4735                 break;
4736         case IPR_IOASC_MED_DO_NOT_REALLOC: /* prevent retries */
4737         case IPR_IOASA_IR_DUAL_IOA_DISABLED:
4738                 scsi_cmd->result |= (DID_PASSTHROUGH << 16);
4739                 break;
4740         case IPR_IOASC_BUS_WAS_RESET:
4741         case IPR_IOASC_BUS_WAS_RESET_BY_OTHER:
4742                 /*
4743                  * Report the bus reset and ask for a retry. The device
4744                  * will give CC/UA the next command.
4745                  */
4746                 if (!res->resetting_device)
4747                         scsi_report_bus_reset(ioa_cfg->host, scsi_cmd->device->channel);
4748                 scsi_cmd->result |= (DID_ERROR << 16);
4749                 if (!ipr_is_naca_model(res))
4750                         res->needs_sync_complete = 1;
4751                 break;
4752         case IPR_IOASC_HW_DEV_BUS_STATUS:
4753                 scsi_cmd->result |= IPR_IOASC_SENSE_STATUS(ioasc);
4754                 if (IPR_IOASC_SENSE_STATUS(ioasc) == SAM_STAT_CHECK_CONDITION) {
4755                         if (!ipr_get_autosense(ipr_cmd)) {
4756                                 if (!ipr_is_naca_model(res)) {
4757                                         ipr_erp_cancel_all(ipr_cmd);
4758                                         return;
4759                                 }
4760                         }
4761                 }
4762                 if (!ipr_is_naca_model(res))
4763                         res->needs_sync_complete = 1;
4764                 break;
4765         case IPR_IOASC_NR_INIT_CMD_REQUIRED:
4766                 break;
4767         default:
4768                 if (IPR_IOASC_SENSE_KEY(ioasc) > RECOVERED_ERROR)
4769                         scsi_cmd->result |= (DID_ERROR << 16);
4770                 if (!ipr_is_vset_device(res) && !ipr_is_naca_model(res))
4771                         res->needs_sync_complete = 1;
4772                 break;
4773         }
4774
4775         scsi_dma_unmap(ipr_cmd->scsi_cmd);
4776         list_add_tail(&ipr_cmd->queue, &ioa_cfg->free_q);
4777         scsi_cmd->scsi_done(scsi_cmd);
4778 }
4779
4780 /**
4781  * ipr_scsi_done - mid-layer done function
4782  * @ipr_cmd:    ipr command struct
4783  *
4784  * This function is invoked by the interrupt handler for
4785  * ops generated by the SCSI mid-layer
4786  *
4787  * Return value:
4788  *      none
4789  **/
4790 static void ipr_scsi_done(struct ipr_cmnd *ipr_cmd)
4791 {
4792         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
4793         struct scsi_cmnd *scsi_cmd = ipr_cmd->scsi_cmd;
4794         u32 ioasc = be32_to_cpu(ipr_cmd->ioasa.ioasc);
4795
4796         scsi_set_resid(scsi_cmd, be32_to_cpu(ipr_cmd->ioasa.residual_data_len));
4797
4798         if (likely(IPR_IOASC_SENSE_KEY(ioasc) == 0)) {
4799                 scsi_dma_unmap(ipr_cmd->scsi_cmd);
4800                 list_add_tail(&ipr_cmd->queue, &ioa_cfg->free_q);
4801                 scsi_cmd->scsi_done(scsi_cmd);
4802         } else
4803                 ipr_erp_start(ioa_cfg, ipr_cmd);
4804 }
4805
4806 /**
4807  * ipr_queuecommand - Queue a mid-layer request
4808  * @scsi_cmd:   scsi command struct
4809  * @done:               done function
4810  *
4811  * This function queues a request generated by the mid-layer.
4812  *
4813  * Return value:
4814  *      0 on success
4815  *      SCSI_MLQUEUE_DEVICE_BUSY if device is busy
4816  *      SCSI_MLQUEUE_HOST_BUSY if host is busy
4817  **/
4818 static int ipr_queuecommand(struct scsi_cmnd *scsi_cmd,
4819                             void (*done) (struct scsi_cmnd *))
4820 {
4821         struct ipr_ioa_cfg *ioa_cfg;
4822         struct ipr_resource_entry *res;
4823         struct ipr_ioarcb *ioarcb;
4824         struct ipr_cmnd *ipr_cmd;
4825         int rc = 0;
4826
4827         scsi_cmd->scsi_done = done;
4828         ioa_cfg = (struct ipr_ioa_cfg *)scsi_cmd->device->host->hostdata;
4829         res = scsi_cmd->device->hostdata;
4830         scsi_cmd->result = (DID_OK << 16);
4831
4832         /*
4833          * We are currently blocking all devices due to a host reset
4834          * We have told the host to stop giving us new requests, but
4835          * ERP ops don't count. FIXME
4836          */
4837         if (unlikely(!ioa_cfg->allow_cmds && !ioa_cfg->ioa_is_dead))
4838                 return SCSI_MLQUEUE_HOST_BUSY;
4839
4840         /*
4841          * FIXME - Create scsi_set_host_offline interface
4842          *  and the ioa_is_dead check can be removed
4843          */
4844         if (unlikely(ioa_cfg->ioa_is_dead || !res)) {
4845                 memset(scsi_cmd->sense_buffer, 0, SCSI_SENSE_BUFFERSIZE);
4846                 scsi_cmd->result = (DID_NO_CONNECT << 16);
4847                 scsi_cmd->scsi_done(scsi_cmd);
4848                 return 0;
4849         }
4850
4851         if (ipr_is_gata(res) && res->sata_port)
4852                 return ata_sas_queuecmd(scsi_cmd, done, res->sata_port->ap);
4853
4854         ipr_cmd = ipr_get_free_ipr_cmnd(ioa_cfg);
4855         ioarcb = &ipr_cmd->ioarcb;
4856         list_add_tail(&ipr_cmd->queue, &ioa_cfg->pending_q);
4857
4858         memcpy(ioarcb->cmd_pkt.cdb, scsi_cmd->cmnd, scsi_cmd->cmd_len);
4859         ipr_cmd->scsi_cmd = scsi_cmd;
4860         ioarcb->res_handle = res->cfgte.res_handle;
4861         ipr_cmd->done = ipr_scsi_done;
4862         ipr_trc_hook(ipr_cmd, IPR_TRACE_START, IPR_GET_PHYS_LOC(res->cfgte.res_addr));
4863
4864         if (ipr_is_gscsi(res) || ipr_is_vset_device(res)) {
4865                 if (scsi_cmd->underflow == 0)
4866                         ioarcb->cmd_pkt.flags_hi |= IPR_FLAGS_HI_NO_ULEN_CHK;
4867
4868                 if (res->needs_sync_complete) {
4869                         ioarcb->cmd_pkt.flags_hi |= IPR_FLAGS_HI_SYNC_COMPLETE;
4870                         res->needs_sync_complete = 0;
4871                 }
4872
4873                 ioarcb->cmd_pkt.flags_hi |= IPR_FLAGS_HI_NO_LINK_DESC;
4874                 ioarcb->cmd_pkt.flags_lo |= IPR_FLAGS_LO_DELAY_AFTER_RST;
4875                 ioarcb->cmd_pkt.flags_lo |= IPR_FLAGS_LO_ALIGNED_BFR;
4876                 ioarcb->cmd_pkt.flags_lo |= ipr_get_task_attributes(scsi_cmd);
4877         }
4878
4879         if (scsi_cmd->cmnd[0] >= 0xC0 &&
4880             (!ipr_is_gscsi(res) || scsi_cmd->cmnd[0] == IPR_QUERY_RSRC_STATE))
4881                 ioarcb->cmd_pkt.request_type = IPR_RQTYPE_IOACMD;
4882
4883         if (likely(rc == 0))
4884                 rc = ipr_build_ioadl(ioa_cfg, ipr_cmd);
4885
4886         if (likely(rc == 0)) {
4887                 mb();
4888                 writel(be32_to_cpu(ipr_cmd->ioarcb.ioarcb_host_pci_addr),
4889                        ioa_cfg->regs.ioarrin_reg);
4890         } else {
4891                  list_move_tail(&ipr_cmd->queue, &ioa_cfg->free_q);
4892                  return SCSI_MLQUEUE_HOST_BUSY;
4893         }
4894
4895         return 0;
4896 }
4897
4898 /**
4899  * ipr_ioctl - IOCTL handler
4900  * @sdev:       scsi device struct
4901  * @cmd:        IOCTL cmd
4902  * @arg:        IOCTL arg
4903  *
4904  * Return value:
4905  *      0 on success / other on failure
4906  **/
4907 static int ipr_ioctl(struct scsi_device *sdev, int cmd, void __user *arg)
4908 {
4909         struct ipr_resource_entry *res;
4910
4911         res = (struct ipr_resource_entry *)sdev->hostdata;
4912         if (res && ipr_is_gata(res)) {
4913                 if (cmd == HDIO_GET_IDENTITY)
4914                         return -ENOTTY;
4915                 return ata_sas_scsi_ioctl(res->sata_port->ap, sdev, cmd, arg);
4916         }
4917
4918         return -EINVAL;
4919 }
4920
4921 /**
4922  * ipr_info - Get information about the card/driver
4923  * @scsi_host:  scsi host struct
4924  *
4925  * Return value:
4926  *      pointer to buffer with description string
4927  **/
4928 static const char * ipr_ioa_info(struct Scsi_Host *host)
4929 {
4930         static char buffer[512];
4931         struct ipr_ioa_cfg *ioa_cfg;
4932         unsigned long lock_flags = 0;
4933
4934         ioa_cfg = (struct ipr_ioa_cfg *) host->hostdata;
4935
4936         spin_lock_irqsave(host->host_lock, lock_flags);
4937         sprintf(buffer, "IBM %X Storage Adapter", ioa_cfg->type);
4938         spin_unlock_irqrestore(host->host_lock, lock_flags);
4939
4940         return buffer;
4941 }
4942
4943 static struct scsi_host_template driver_template = {
4944         .module = THIS_MODULE,
4945         .name = "IPR",
4946         .info = ipr_ioa_info,
4947         .ioctl = ipr_ioctl,
4948         .queuecommand = ipr_queuecommand,
4949         .eh_abort_handler = ipr_eh_abort,
4950         .eh_device_reset_handler = ipr_eh_dev_reset,
4951         .eh_host_reset_handler = ipr_eh_host_reset,
4952         .slave_alloc = ipr_slave_alloc,
4953         .slave_configure = ipr_slave_configure,
4954         .slave_destroy = ipr_slave_destroy,
4955         .target_alloc = ipr_target_alloc,
4956         .target_destroy = ipr_target_destroy,
4957         .change_queue_depth = ipr_change_queue_depth,
4958         .change_queue_type = ipr_change_queue_type,
4959         .bios_param = ipr_biosparam,
4960         .can_queue = IPR_MAX_COMMANDS,
4961         .this_id = -1,
4962         .sg_tablesize = IPR_MAX_SGLIST,
4963         .max_sectors = IPR_IOA_MAX_SECTORS,
4964         .cmd_per_lun = IPR_MAX_CMD_PER_LUN,
4965         .use_clustering = ENABLE_CLUSTERING,
4966         .shost_attrs = ipr_ioa_attrs,
4967         .sdev_attrs = ipr_dev_attrs,
4968         .proc_name = IPR_NAME
4969 };
4970
4971 /**
4972  * ipr_ata_phy_reset - libata phy_reset handler
4973  * @ap:         ata port to reset
4974  *
4975  **/
4976 static void ipr_ata_phy_reset(struct ata_port *ap)
4977 {
4978         unsigned long flags;
4979         struct ipr_sata_port *sata_port = ap->private_data;
4980         struct ipr_resource_entry *res = sata_port->res;
4981         struct ipr_ioa_cfg *ioa_cfg = sata_port->ioa_cfg;
4982         int rc;
4983
4984         ENTER;
4985         spin_lock_irqsave(ioa_cfg->host->host_lock, flags);
4986         while(ioa_cfg->in_reset_reload) {
4987                 spin_unlock_irqrestore(ioa_cfg->host->host_lock, flags);
4988                 wait_event(ioa_cfg->reset_wait_q, !ioa_cfg->in_reset_reload);
4989                 spin_lock_irqsave(ioa_cfg->host->host_lock, flags);
4990         }
4991
4992         if (!ioa_cfg->allow_cmds)
4993                 goto out_unlock;
4994
4995         rc = ipr_device_reset(ioa_cfg, res);
4996
4997         if (rc) {
4998                 ata_port_disable(ap);
4999                 goto out_unlock;
5000         }
5001
5002         switch(res->cfgte.proto) {
5003         case IPR_PROTO_SATA:
5004         case IPR_PROTO_SAS_STP:
5005                 ap->link.device[0].class = ATA_DEV_ATA;
5006                 break;
5007         case IPR_PROTO_SATA_ATAPI:
5008         case IPR_PROTO_SAS_STP_ATAPI:
5009                 ap->link.device[0].class = ATA_DEV_ATAPI;
5010                 break;
5011         default:
5012                 ap->link.device[0].class = ATA_DEV_UNKNOWN;
5013                 ata_port_disable(ap);
5014                 break;
5015         };
5016
5017 out_unlock:
5018         spin_unlock_irqrestore(ioa_cfg->host->host_lock, flags);
5019         LEAVE;
5020 }
5021
5022 /**
5023  * ipr_ata_post_internal - Cleanup after an internal command
5024  * @qc: ATA queued command
5025  *
5026  * Return value:
5027  *      none
5028  **/
5029 static void ipr_ata_post_internal(struct ata_queued_cmd *qc)
5030 {
5031         struct ipr_sata_port *sata_port = qc->ap->private_data;
5032         struct ipr_ioa_cfg *ioa_cfg = sata_port->ioa_cfg;
5033         struct ipr_cmnd *ipr_cmd;
5034         unsigned long flags;
5035
5036         spin_lock_irqsave(ioa_cfg->host->host_lock, flags);
5037         while(ioa_cfg->in_reset_reload) {
5038                 spin_unlock_irqrestore(ioa_cfg->host->host_lock, flags);
5039                 wait_event(ioa_cfg->reset_wait_q, !ioa_cfg->in_reset_reload);
5040                 spin_lock_irqsave(ioa_cfg->host->host_lock, flags);
5041         }
5042
5043         list_for_each_entry(ipr_cmd, &ioa_cfg->pending_q, queue) {
5044                 if (ipr_cmd->qc == qc) {
5045                         ipr_device_reset(ioa_cfg, sata_port->res);
5046                         break;
5047                 }
5048         }
5049         spin_unlock_irqrestore(ioa_cfg->host->host_lock, flags);
5050 }
5051
5052 /**
5053  * ipr_copy_sata_tf - Copy a SATA taskfile to an IOA data structure
5054  * @regs:       destination
5055  * @tf: source ATA taskfile
5056  *
5057  * Return value:
5058  *      none
5059  **/
5060 static void ipr_copy_sata_tf(struct ipr_ioarcb_ata_regs *regs,
5061                              struct ata_taskfile *tf)
5062 {
5063         regs->feature = tf->feature;
5064         regs->nsect = tf->nsect;
5065         regs->lbal = tf->lbal;
5066         regs->lbam = tf->lbam;
5067         regs->lbah = tf->lbah;
5068         regs->device = tf->device;
5069         regs->command = tf->command;
5070         regs->hob_feature = tf->hob_feature;
5071         regs->hob_nsect = tf->hob_nsect;
5072         regs->hob_lbal = tf->hob_lbal;
5073         regs->hob_lbam = tf->hob_lbam;
5074         regs->hob_lbah = tf->hob_lbah;
5075         regs->ctl = tf->ctl;
5076 }
5077
5078 /**
5079  * ipr_sata_done - done function for SATA commands
5080  * @ipr_cmd:    ipr command struct
5081  *
5082  * This function is invoked by the interrupt handler for
5083  * ops generated by the SCSI mid-layer to SATA devices
5084  *
5085  * Return value:
5086  *      none
5087  **/
5088 static void ipr_sata_done(struct ipr_cmnd *ipr_cmd)
5089 {
5090         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
5091         struct ata_queued_cmd *qc = ipr_cmd->qc;
5092         struct ipr_sata_port *sata_port = qc->ap->private_data;
5093         struct ipr_resource_entry *res = sata_port->res;
5094         u32 ioasc = be32_to_cpu(ipr_cmd->ioasa.ioasc);
5095
5096         memcpy(&sata_port->ioasa, &ipr_cmd->ioasa.u.gata,
5097                sizeof(struct ipr_ioasa_gata));
5098         ipr_dump_ioasa(ioa_cfg, ipr_cmd, res);
5099
5100         if (be32_to_cpu(ipr_cmd->ioasa.ioasc_specific) & IPR_ATA_DEVICE_WAS_RESET)
5101                 scsi_report_device_reset(ioa_cfg->host, res->cfgte.res_addr.bus,
5102                                          res->cfgte.res_addr.target);
5103
5104         if (IPR_IOASC_SENSE_KEY(ioasc) > RECOVERED_ERROR)
5105                 qc->err_mask |= __ac_err_mask(ipr_cmd->ioasa.u.gata.status);
5106         else
5107                 qc->err_mask |= ac_err_mask(ipr_cmd->ioasa.u.gata.status);
5108         list_add_tail(&ipr_cmd->queue, &ioa_cfg->free_q);
5109         ata_qc_complete(qc);
5110 }
5111
5112 /**
5113  * ipr_build_ata_ioadl - Build an ATA scatter/gather list
5114  * @ipr_cmd:    ipr command struct
5115  * @qc:         ATA queued command
5116  *
5117  **/
5118 static void ipr_build_ata_ioadl(struct ipr_cmnd *ipr_cmd,
5119                                 struct ata_queued_cmd *qc)
5120 {
5121         u32 ioadl_flags = 0;
5122         struct ipr_ioarcb *ioarcb = &ipr_cmd->ioarcb;
5123         struct ipr_ioadl_desc *ioadl = ipr_cmd->ioadl;
5124         struct ipr_ioadl_desc *last_ioadl = NULL;
5125         int len = qc->nbytes;
5126         struct scatterlist *sg;
5127         unsigned int si;
5128
5129         if (len == 0)
5130                 return;
5131
5132         if (qc->dma_dir == DMA_TO_DEVICE) {
5133                 ioadl_flags = IPR_IOADL_FLAGS_WRITE;
5134                 ioarcb->cmd_pkt.flags_hi |= IPR_FLAGS_HI_WRITE_NOT_READ;
5135                 ioarcb->write_data_transfer_length = cpu_to_be32(len);
5136                 ioarcb->write_ioadl_len =
5137                         cpu_to_be32(sizeof(struct ipr_ioadl_desc) * ipr_cmd->dma_use_sg);
5138         } else if (qc->dma_dir == DMA_FROM_DEVICE) {
5139                 ioadl_flags = IPR_IOADL_FLAGS_READ;
5140                 ioarcb->read_data_transfer_length = cpu_to_be32(len);
5141                 ioarcb->read_ioadl_len =
5142                         cpu_to_be32(sizeof(struct ipr_ioadl_desc) * ipr_cmd->dma_use_sg);
5143         }
5144
5145         for_each_sg(qc->sg, sg, qc->n_elem, si) {
5146                 ioadl->flags_and_data_len = cpu_to_be32(ioadl_flags | sg_dma_len(sg));
5147                 ioadl->address = cpu_to_be32(sg_dma_address(sg));
5148
5149                 last_ioadl = ioadl;
5150                 ioadl++;
5151         }
5152
5153         if (likely(last_ioadl))
5154                 last_ioadl->flags_and_data_len |= cpu_to_be32(IPR_IOADL_FLAGS_LAST);
5155 }
5156
5157 /**
5158  * ipr_qc_issue - Issue a SATA qc to a device
5159  * @qc: queued command
5160  *
5161  * Return value:
5162  *      0 if success
5163  **/
5164 static unsigned int ipr_qc_issue(struct ata_queued_cmd *qc)
5165 {
5166         struct ata_port *ap = qc->ap;
5167         struct ipr_sata_port *sata_port = ap->private_data;
5168         struct ipr_resource_entry *res = sata_port->res;
5169         struct ipr_ioa_cfg *ioa_cfg = sata_port->ioa_cfg;
5170         struct ipr_cmnd *ipr_cmd;
5171         struct ipr_ioarcb *ioarcb;
5172         struct ipr_ioarcb_ata_regs *regs;
5173
5174         if (unlikely(!ioa_cfg->allow_cmds || ioa_cfg->ioa_is_dead))
5175                 return AC_ERR_SYSTEM;
5176
5177         ipr_cmd = ipr_get_free_ipr_cmnd(ioa_cfg);
5178         ioarcb = &ipr_cmd->ioarcb;
5179         regs = &ioarcb->add_data.u.regs;
5180
5181         memset(&ioarcb->add_data, 0, sizeof(ioarcb->add_data));
5182         ioarcb->add_cmd_parms_len = cpu_to_be32(sizeof(ioarcb->add_data.u.regs));
5183
5184         list_add_tail(&ipr_cmd->queue, &ioa_cfg->pending_q);
5185         ipr_cmd->qc = qc;
5186         ipr_cmd->done = ipr_sata_done;
5187         ipr_cmd->ioarcb.res_handle = res->cfgte.res_handle;
5188         ioarcb->cmd_pkt.request_type = IPR_RQTYPE_ATA_PASSTHRU;
5189         ioarcb->cmd_pkt.flags_hi |= IPR_FLAGS_HI_NO_LINK_DESC;
5190         ioarcb->cmd_pkt.flags_hi |= IPR_FLAGS_HI_NO_ULEN_CHK;
5191         ipr_cmd->dma_use_sg = qc->n_elem;
5192
5193         ipr_build_ata_ioadl(ipr_cmd, qc);
5194         regs->flags |= IPR_ATA_FLAG_STATUS_ON_GOOD_COMPLETION;
5195         ipr_copy_sata_tf(regs, &qc->tf);
5196         memcpy(ioarcb->cmd_pkt.cdb, qc->cdb, IPR_MAX_CDB_LEN);
5197         ipr_trc_hook(ipr_cmd, IPR_TRACE_START, IPR_GET_PHYS_LOC(res->cfgte.res_addr));
5198
5199         switch (qc->tf.protocol) {
5200         case ATA_PROT_NODATA:
5201         case ATA_PROT_PIO:
5202                 break;
5203
5204         case ATA_PROT_DMA:
5205                 regs->flags |= IPR_ATA_FLAG_XFER_TYPE_DMA;
5206                 break;
5207
5208         case ATAPI_PROT_PIO:
5209         case ATAPI_PROT_NODATA:
5210                 regs->flags |= IPR_ATA_FLAG_PACKET_CMD;
5211                 break;
5212
5213         case ATAPI_PROT_DMA:
5214                 regs->flags |= IPR_ATA_FLAG_PACKET_CMD;
5215                 regs->flags |= IPR_ATA_FLAG_XFER_TYPE_DMA;
5216                 break;
5217
5218         default:
5219                 WARN_ON(1);
5220                 return AC_ERR_INVALID;
5221         }
5222
5223         mb();
5224         writel(be32_to_cpu(ioarcb->ioarcb_host_pci_addr),
5225                ioa_cfg->regs.ioarrin_reg);
5226         return 0;
5227 }
5228
5229 /**
5230  * ipr_qc_fill_rtf - Read result TF
5231  * @qc: ATA queued command
5232  *
5233  * Return value:
5234  *      true
5235  **/
5236 static bool ipr_qc_fill_rtf(struct ata_queued_cmd *qc)
5237 {
5238         struct ipr_sata_port *sata_port = qc->ap->private_data;
5239         struct ipr_ioasa_gata *g = &sata_port->ioasa;
5240         struct ata_taskfile *tf = &qc->result_tf;
5241
5242         tf->feature = g->error;
5243         tf->nsect = g->nsect;
5244         tf->lbal = g->lbal;
5245         tf->lbam = g->lbam;
5246         tf->lbah = g->lbah;
5247         tf->device = g->device;
5248         tf->command = g->status;
5249         tf->hob_nsect = g->hob_nsect;
5250         tf->hob_lbal = g->hob_lbal;
5251         tf->hob_lbam = g->hob_lbam;
5252         tf->hob_lbah = g->hob_lbah;
5253         tf->ctl = g->alt_status;
5254
5255         return true;
5256 }
5257
5258 static struct ata_port_operations ipr_sata_ops = {
5259         .phy_reset = ipr_ata_phy_reset,
5260         .hardreset = ipr_sata_reset,
5261         .post_internal_cmd = ipr_ata_post_internal,
5262         .qc_prep = ata_noop_qc_prep,
5263         .qc_issue = ipr_qc_issue,
5264         .qc_fill_rtf = ipr_qc_fill_rtf,
5265         .port_start = ata_sas_port_start,
5266         .port_stop = ata_sas_port_stop
5267 };
5268
5269 static struct ata_port_info sata_port_info = {
5270         .flags  = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY | ATA_FLAG_SATA_RESET |
5271         ATA_FLAG_MMIO | ATA_FLAG_PIO_DMA,
5272         .pio_mask       = 0x10, /* pio4 */
5273         .mwdma_mask = 0x07,
5274         .udma_mask      = 0x7f, /* udma0-6 */
5275         .port_ops       = &ipr_sata_ops
5276 };
5277
5278 #ifdef CONFIG_PPC_PSERIES
5279 static const u16 ipr_blocked_processors[] = {
5280         PV_NORTHSTAR,
5281         PV_PULSAR,
5282         PV_POWER4,
5283         PV_ICESTAR,
5284         PV_SSTAR,
5285         PV_POWER4p,
5286         PV_630,
5287         PV_630p
5288 };
5289
5290 /**
5291  * ipr_invalid_adapter - Determine if this adapter is supported on this hardware
5292  * @ioa_cfg:    ioa cfg struct
5293  *
5294  * Adapters that use Gemstone revision < 3.1 do not work reliably on
5295  * certain pSeries hardware. This function determines if the given
5296  * adapter is in one of these confgurations or not.
5297  *
5298  * Return value:
5299  *      1 if adapter is not supported / 0 if adapter is supported
5300  **/
5301 static int ipr_invalid_adapter(struct ipr_ioa_cfg *ioa_cfg)
5302 {
5303         int i;
5304
5305         if ((ioa_cfg->type == 0x5702) && (ioa_cfg->pdev->revision < 4)) {
5306                 for (i = 0; i < ARRAY_SIZE(ipr_blocked_processors); i++){
5307                         if (__is_processor(ipr_blocked_processors[i]))
5308                                 return 1;
5309                 }
5310         }
5311         return 0;
5312 }
5313 #else
5314 #define ipr_invalid_adapter(ioa_cfg) 0
5315 #endif
5316
5317 /**
5318  * ipr_ioa_bringdown_done - IOA bring down completion.
5319  * @ipr_cmd:    ipr command struct
5320  *
5321  * This function processes the completion of an adapter bring down.
5322  * It wakes any reset sleepers.
5323  *
5324  * Return value:
5325  *      IPR_RC_JOB_RETURN
5326  **/
5327 static int ipr_ioa_bringdown_done(struct ipr_cmnd *ipr_cmd)
5328 {
5329         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
5330
5331         ENTER;
5332         ioa_cfg->in_reset_reload = 0;
5333         ioa_cfg->reset_retries = 0;
5334         list_add_tail(&ipr_cmd->queue, &ioa_cfg->free_q);
5335         wake_up_all(&ioa_cfg->reset_wait_q);
5336
5337         spin_unlock_irq(ioa_cfg->host->host_lock);
5338         scsi_unblock_requests(ioa_cfg->host);
5339         spin_lock_irq(ioa_cfg->host->host_lock);
5340         LEAVE;
5341
5342         return IPR_RC_JOB_RETURN;
5343 }
5344
5345 /**
5346  * ipr_ioa_reset_done - IOA reset completion.
5347  * @ipr_cmd:    ipr command struct
5348  *
5349  * This function processes the completion of an adapter reset.
5350  * It schedules any necessary mid-layer add/removes and
5351  * wakes any reset sleepers.
5352  *
5353  * Return value:
5354  *      IPR_RC_JOB_RETURN
5355  **/
5356 static int ipr_ioa_reset_done(struct ipr_cmnd *ipr_cmd)
5357 {
5358         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
5359         struct ipr_resource_entry *res;
5360         struct ipr_hostrcb *hostrcb, *temp;
5361         int i = 0;
5362
5363         ENTER;
5364         ioa_cfg->in_reset_reload = 0;
5365         ioa_cfg->allow_cmds = 1;
5366         ioa_cfg->reset_cmd = NULL;
5367         ioa_cfg->doorbell |= IPR_RUNTIME_RESET;
5368
5369         list_for_each_entry(res, &ioa_cfg->used_res_q, queue) {
5370                 if (ioa_cfg->allow_ml_add_del && (res->add_to_ml || res->del_from_ml)) {
5371                         ipr_trace;
5372                         break;
5373                 }
5374         }
5375         schedule_work(&ioa_cfg->work_q);
5376
5377         list_for_each_entry_safe(hostrcb, temp, &ioa_cfg->hostrcb_free_q, queue) {
5378                 list_del(&hostrcb->queue);
5379                 if (i++ < IPR_NUM_LOG_HCAMS)
5380                         ipr_send_hcam(ioa_cfg, IPR_HCAM_CDB_OP_CODE_LOG_DATA, hostrcb);
5381                 else
5382                         ipr_send_hcam(ioa_cfg, IPR_HCAM_CDB_OP_CODE_CONFIG_CHANGE, hostrcb);
5383         }
5384
5385         scsi_report_bus_reset(ioa_cfg->host, IPR_VSET_BUS);
5386         dev_info(&ioa_cfg->pdev->dev, "IOA initialized.\n");
5387
5388         ioa_cfg->reset_retries = 0;
5389         list_add_tail(&ipr_cmd->queue, &ioa_cfg->free_q);
5390         wake_up_all(&ioa_cfg->reset_wait_q);
5391
5392         spin_unlock(ioa_cfg->host->host_lock);
5393         scsi_unblock_requests(ioa_cfg->host);
5394         spin_lock(ioa_cfg->host->host_lock);
5395
5396         if (!ioa_cfg->allow_cmds)
5397                 scsi_block_requests(ioa_cfg->host);
5398
5399         LEAVE;
5400         return IPR_RC_JOB_RETURN;
5401 }
5402
5403 /**
5404  * ipr_set_sup_dev_dflt - Initialize a Set Supported Device buffer
5405  * @supported_dev:      supported device struct
5406  * @vpids:                      vendor product id struct
5407  *
5408  * Return value:
5409  *      none
5410  **/
5411 static void ipr_set_sup_dev_dflt(struct ipr_supported_device *supported_dev,
5412                                  struct ipr_std_inq_vpids *vpids)
5413 {
5414         memset(supported_dev, 0, sizeof(struct ipr_supported_device));
5415         memcpy(&supported_dev->vpids, vpids, sizeof(struct ipr_std_inq_vpids));
5416         supported_dev->num_records = 1;
5417         supported_dev->data_length =
5418                 cpu_to_be16(sizeof(struct ipr_supported_device));
5419         supported_dev->reserved = 0;
5420 }
5421
5422 /**
5423  * ipr_set_supported_devs - Send Set Supported Devices for a device
5424  * @ipr_cmd:    ipr command struct
5425  *
5426  * This function send a Set Supported Devices to the adapter
5427  *
5428  * Return value:
5429  *      IPR_RC_JOB_CONTINUE / IPR_RC_JOB_RETURN
5430  **/
5431 static int ipr_set_supported_devs(struct ipr_cmnd *ipr_cmd)
5432 {
5433         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
5434         struct ipr_supported_device *supp_dev = &ioa_cfg->vpd_cbs->supp_dev;
5435         struct ipr_ioadl_desc *ioadl = ipr_cmd->ioadl;
5436         struct ipr_ioarcb *ioarcb = &ipr_cmd->ioarcb;
5437         struct ipr_resource_entry *res = ipr_cmd->u.res;
5438
5439         ipr_cmd->job_step = ipr_ioa_reset_done;
5440
5441         list_for_each_entry_continue(res, &ioa_cfg->used_res_q, queue) {
5442                 if (!ipr_is_scsi_disk(res))
5443                         continue;
5444
5445                 ipr_cmd->u.res = res;
5446                 ipr_set_sup_dev_dflt(supp_dev, &res->cfgte.std_inq_data.vpids);
5447
5448                 ioarcb->res_handle = cpu_to_be32(IPR_IOA_RES_HANDLE);
5449                 ioarcb->cmd_pkt.flags_hi |= IPR_FLAGS_HI_WRITE_NOT_READ;
5450                 ioarcb->cmd_pkt.request_type = IPR_RQTYPE_IOACMD;
5451
5452                 ioarcb->cmd_pkt.cdb[0] = IPR_SET_SUPPORTED_DEVICES;
5453                 ioarcb->cmd_pkt.cdb[7] = (sizeof(struct ipr_supported_device) >> 8) & 0xff;
5454                 ioarcb->cmd_pkt.cdb[8] = sizeof(struct ipr_supported_device) & 0xff;
5455
5456                 ioadl->flags_and_data_len = cpu_to_be32(IPR_IOADL_FLAGS_WRITE_LAST |
5457                                                         sizeof(struct ipr_supported_device));
5458                 ioadl->address = cpu_to_be32(ioa_cfg->vpd_cbs_dma +
5459                                              offsetof(struct ipr_misc_cbs, supp_dev));
5460                 ioarcb->write_ioadl_len = cpu_to_be32(sizeof(struct ipr_ioadl_desc));
5461                 ioarcb->write_data_transfer_length =
5462                         cpu_to_be32(sizeof(struct ipr_supported_device));
5463
5464                 ipr_do_req(ipr_cmd, ipr_reset_ioa_job, ipr_timeout,
5465                            IPR_SET_SUP_DEVICE_TIMEOUT);
5466
5467                 ipr_cmd->job_step = ipr_set_supported_devs;
5468                 return IPR_RC_JOB_RETURN;
5469         }
5470
5471         return IPR_RC_JOB_CONTINUE;
5472 }
5473
5474 /**
5475  * ipr_setup_write_cache - Disable write cache if needed
5476  * @ipr_cmd:    ipr command struct
5477  *
5478  * This function sets up adapters write cache to desired setting
5479  *
5480  * Return value:
5481  *      IPR_RC_JOB_CONTINUE / IPR_RC_JOB_RETURN
5482  **/
5483 static int ipr_setup_write_cache(struct ipr_cmnd *ipr_cmd)
5484 {
5485         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
5486
5487         ipr_cmd->job_step = ipr_set_supported_devs;
5488         ipr_cmd->u.res = list_entry(ioa_cfg->used_res_q.next,
5489                                     struct ipr_resource_entry, queue);
5490
5491         if (ioa_cfg->cache_state != CACHE_DISABLED)
5492                 return IPR_RC_JOB_CONTINUE;
5493
5494         ipr_cmd->ioarcb.res_handle = cpu_to_be32(IPR_IOA_RES_HANDLE);
5495         ipr_cmd->ioarcb.cmd_pkt.request_type = IPR_RQTYPE_IOACMD;
5496         ipr_cmd->ioarcb.cmd_pkt.cdb[0] = IPR_IOA_SHUTDOWN;
5497         ipr_cmd->ioarcb.cmd_pkt.cdb[1] = IPR_SHUTDOWN_PREPARE_FOR_NORMAL;
5498
5499         ipr_do_req(ipr_cmd, ipr_reset_ioa_job, ipr_timeout, IPR_INTERNAL_TIMEOUT);
5500
5501         return IPR_RC_JOB_RETURN;
5502 }
5503
5504 /**
5505  * ipr_get_mode_page - Locate specified mode page
5506  * @mode_pages: mode page buffer
5507  * @page_code:  page code to find
5508  * @len:                minimum required length for mode page
5509  *
5510  * Return value:
5511  *      pointer to mode page / NULL on failure
5512  **/
5513 static void *ipr_get_mode_page(struct ipr_mode_pages *mode_pages,
5514                                u32 page_code, u32 len)
5515 {
5516         struct ipr_mode_page_hdr *mode_hdr;
5517         u32 page_length;
5518         u32 length;
5519
5520         if (!mode_pages || (mode_pages->hdr.length == 0))
5521                 return NULL;
5522
5523         length = (mode_pages->hdr.length + 1) - 4 - mode_pages->hdr.block_desc_len;
5524         mode_hdr = (struct ipr_mode_page_hdr *)
5525                 (mode_pages->data + mode_pages->hdr.block_desc_len);
5526
5527         while (length) {
5528                 if (IPR_GET_MODE_PAGE_CODE(mode_hdr) == page_code) {
5529                         if (mode_hdr->page_length >= (len - sizeof(struct ipr_mode_page_hdr)))
5530                                 return mode_hdr;
5531                         break;
5532                 } else {
5533                         page_length = (sizeof(struct ipr_mode_page_hdr) +
5534                                        mode_hdr->page_length);
5535                         length -= page_length;
5536                         mode_hdr = (struct ipr_mode_page_hdr *)
5537                                 ((unsigned long)mode_hdr + page_length);
5538                 }
5539         }
5540         return NULL;
5541 }
5542
5543 /**
5544  * ipr_check_term_power - Check for term power errors
5545  * @ioa_cfg:    ioa config struct
5546  * @mode_pages: IOAFP mode pages buffer
5547  *
5548  * Check the IOAFP's mode page 28 for term power errors
5549  *
5550  * Return value:
5551  *      nothing
5552  **/
5553 static void ipr_check_term_power(struct ipr_ioa_cfg *ioa_cfg,
5554                                  struct ipr_mode_pages *mode_pages)
5555 {
5556         int i;
5557         int entry_length;
5558         struct ipr_dev_bus_entry *bus;
5559         struct ipr_mode_page28 *mode_page;
5560
5561         mode_page = ipr_get_mode_page(mode_pages, 0x28,
5562                                       sizeof(struct ipr_mode_page28));
5563
5564         entry_length = mode_page->entry_length;
5565
5566         bus = mode_page->bus;
5567
5568         for (i = 0; i < mode_page->num_entries; i++) {
5569                 if (bus->flags & IPR_SCSI_ATTR_NO_TERM_PWR) {
5570                         dev_err(&ioa_cfg->pdev->dev,
5571                                 "Term power is absent on scsi bus %d\n",
5572                                 bus->res_addr.bus);
5573                 }
5574
5575                 bus = (struct ipr_dev_bus_entry *)((char *)bus + entry_length);
5576         }
5577 }
5578
5579 /**
5580  * ipr_scsi_bus_speed_limit - Limit the SCSI speed based on SES table
5581  * @ioa_cfg:    ioa config struct
5582  *
5583  * Looks through the config table checking for SES devices. If
5584  * the SES device is in the SES table indicating a maximum SCSI
5585  * bus speed, the speed is limited for the bus.
5586  *
5587  * Return value:
5588  *      none
5589  **/
5590 static void ipr_scsi_bus_speed_limit(struct ipr_ioa_cfg *ioa_cfg)
5591 {
5592         u32 max_xfer_rate;
5593         int i;
5594
5595         for (i = 0; i < IPR_MAX_NUM_BUSES; i++) {
5596                 max_xfer_rate = ipr_get_max_scsi_speed(ioa_cfg, i,
5597                                                        ioa_cfg->bus_attr[i].bus_width);
5598
5599                 if (max_xfer_rate < ioa_cfg->bus_attr[i].max_xfer_rate)
5600                         ioa_cfg->bus_attr[i].max_xfer_rate = max_xfer_rate;
5601         }
5602 }
5603
5604 /**
5605  * ipr_modify_ioafp_mode_page_28 - Modify IOAFP Mode Page 28
5606  * @ioa_cfg:    ioa config struct
5607  * @mode_pages: mode page 28 buffer
5608  *
5609  * Updates mode page 28 based on driver configuration
5610  *
5611  * Return value:
5612  *      none
5613  **/
5614 static void ipr_modify_ioafp_mode_page_28(struct ipr_ioa_cfg *ioa_cfg,
5615                                                 struct ipr_mode_pages *mode_pages)
5616 {
5617         int i, entry_length;
5618         struct ipr_dev_bus_entry *bus;
5619         struct ipr_bus_attributes *bus_attr;
5620         struct ipr_mode_page28 *mode_page;
5621
5622         mode_page = ipr_get_mode_page(mode_pages, 0x28,
5623                                       sizeof(struct ipr_mode_page28));
5624
5625         entry_length = mode_page->entry_length;
5626
5627         /* Loop for each device bus entry */
5628         for (i = 0, bus = mode_page->bus;
5629              i < mode_page->num_entries;
5630              i++, bus = (struct ipr_dev_bus_entry *)((u8 *)bus + entry_length)) {
5631                 if (bus->res_addr.bus > IPR_MAX_NUM_BUSES) {
5632                         dev_err(&ioa_cfg->pdev->dev,
5633                                 "Invalid resource address reported: 0x%08X\n",
5634                                 IPR_GET_PHYS_LOC(bus->res_addr));
5635                         continue;
5636                 }
5637
5638                 bus_attr = &ioa_cfg->bus_attr[i];
5639                 bus->extended_reset_delay = IPR_EXTENDED_RESET_DELAY;
5640                 bus->bus_width = bus_attr->bus_width;
5641                 bus->max_xfer_rate = cpu_to_be32(bus_attr->max_xfer_rate);
5642                 bus->flags &= ~IPR_SCSI_ATTR_QAS_MASK;
5643                 if (bus_attr->qas_enabled)
5644                         bus->flags |= IPR_SCSI_ATTR_ENABLE_QAS;
5645                 else
5646                         bus->flags |= IPR_SCSI_ATTR_DISABLE_QAS;
5647         }
5648 }
5649
5650 /**
5651  * ipr_build_mode_select - Build a mode select command
5652  * @ipr_cmd:    ipr command struct
5653  * @res_handle: resource handle to send command to
5654  * @parm:               Byte 2 of Mode Sense command
5655  * @dma_addr:   DMA buffer address
5656  * @xfer_len:   data transfer length
5657  *
5658  * Return value:
5659  *      none
5660  **/
5661 static void ipr_build_mode_select(struct ipr_cmnd *ipr_cmd,
5662                                   __be32 res_handle, u8 parm, u32 dma_addr,
5663                                   u8 xfer_len)
5664 {
5665         struct ipr_ioadl_desc *ioadl = ipr_cmd->ioadl;
5666         struct ipr_ioarcb *ioarcb = &ipr_cmd->ioarcb;
5667
5668         ioarcb->res_handle = res_handle;
5669         ioarcb->cmd_pkt.request_type = IPR_RQTYPE_SCSICDB;
5670         ioarcb->cmd_pkt.flags_hi |= IPR_FLAGS_HI_WRITE_NOT_READ;
5671         ioarcb->cmd_pkt.cdb[0] = MODE_SELECT;
5672         ioarcb->cmd_pkt.cdb[1] = parm;
5673         ioarcb->cmd_pkt.cdb[4] = xfer_len;
5674
5675         ioadl->flags_and_data_len =
5676                 cpu_to_be32(IPR_IOADL_FLAGS_WRITE_LAST | xfer_len);
5677         ioadl->address = cpu_to_be32(dma_addr);
5678         ioarcb->write_ioadl_len = cpu_to_be32(sizeof(struct ipr_ioadl_desc));
5679         ioarcb->write_data_transfer_length = cpu_to_be32(xfer_len);
5680 }
5681
5682 /**
5683  * ipr_ioafp_mode_select_page28 - Issue Mode Select Page 28 to IOA
5684  * @ipr_cmd:    ipr command struct
5685  *
5686  * This function sets up the SCSI bus attributes and sends
5687  * a Mode Select for Page 28 to activate them.
5688  *
5689  * Return value:
5690  *      IPR_RC_JOB_RETURN
5691  **/
5692 static int ipr_ioafp_mode_select_page28(struct ipr_cmnd *ipr_cmd)
5693 {
5694         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
5695         struct ipr_mode_pages *mode_pages = &ioa_cfg->vpd_cbs->mode_pages;
5696         int length;
5697
5698         ENTER;
5699         ipr_scsi_bus_speed_limit(ioa_cfg);
5700         ipr_check_term_power(ioa_cfg, mode_pages);
5701         ipr_modify_ioafp_mode_page_28(ioa_cfg, mode_pages);
5702         length = mode_pages->hdr.length + 1;
5703         mode_pages->hdr.length = 0;
5704
5705         ipr_build_mode_select(ipr_cmd, cpu_to_be32(IPR_IOA_RES_HANDLE), 0x11,
5706                               ioa_cfg->vpd_cbs_dma + offsetof(struct ipr_misc_cbs, mode_pages),
5707                               length);
5708
5709         ipr_cmd->job_step = ipr_setup_write_cache;
5710         ipr_do_req(ipr_cmd, ipr_reset_ioa_job, ipr_timeout, IPR_INTERNAL_TIMEOUT);
5711
5712         LEAVE;
5713         return IPR_RC_JOB_RETURN;
5714 }
5715
5716 /**
5717  * ipr_build_mode_sense - Builds a mode sense command
5718  * @ipr_cmd:    ipr command struct
5719  * @res:                resource entry struct
5720  * @parm:               Byte 2 of mode sense command
5721  * @dma_addr:   DMA address of mode sense buffer
5722  * @xfer_len:   Size of DMA buffer
5723  *
5724  * Return value:
5725  *      none
5726  **/
5727 static void ipr_build_mode_sense(struct ipr_cmnd *ipr_cmd,
5728                                  __be32 res_handle,
5729                                  u8 parm, u32 dma_addr, u8 xfer_len)
5730 {
5731         struct ipr_ioadl_desc *ioadl = ipr_cmd->ioadl;
5732         struct ipr_ioarcb *ioarcb = &ipr_cmd->ioarcb;
5733
5734         ioarcb->res_handle = res_handle;
5735         ioarcb->cmd_pkt.cdb[0] = MODE_SENSE;
5736         ioarcb->cmd_pkt.cdb[2] = parm;
5737         ioarcb->cmd_pkt.cdb[4] = xfer_len;
5738         ioarcb->cmd_pkt.request_type = IPR_RQTYPE_SCSICDB;
5739
5740         ioadl->flags_and_data_len =
5741                 cpu_to_be32(IPR_IOADL_FLAGS_READ_LAST | xfer_len);
5742         ioadl->address = cpu_to_be32(dma_addr);
5743         ioarcb->read_ioadl_len = cpu_to_be32(sizeof(struct ipr_ioadl_desc));
5744         ioarcb->read_data_transfer_length = cpu_to_be32(xfer_len);
5745 }
5746
5747 /**
5748  * ipr_reset_cmd_failed - Handle failure of IOA reset command
5749  * @ipr_cmd:    ipr command struct
5750  *
5751  * This function handles the failure of an IOA bringup command.
5752  *
5753  * Return value:
5754  *      IPR_RC_JOB_RETURN
5755  **/
5756 static int ipr_reset_cmd_failed(struct ipr_cmnd *ipr_cmd)
5757 {
5758         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
5759         u32 ioasc = be32_to_cpu(ipr_cmd->ioasa.ioasc);
5760
5761         dev_err(&ioa_cfg->pdev->dev,
5762                 "0x%02X failed with IOASC: 0x%08X\n",
5763                 ipr_cmd->ioarcb.cmd_pkt.cdb[0], ioasc);
5764
5765         ipr_initiate_ioa_reset(ioa_cfg, IPR_SHUTDOWN_NONE);
5766         list_add_tail(&ipr_cmd->queue, &ioa_cfg->free_q);
5767         return IPR_RC_JOB_RETURN;
5768 }
5769
5770 /**
5771  * ipr_reset_mode_sense_failed - Handle failure of IOAFP mode sense
5772  * @ipr_cmd:    ipr command struct
5773  *
5774  * This function handles the failure of a Mode Sense to the IOAFP.
5775  * Some adapters do not handle all mode pages.
5776  *
5777  * Return value:
5778  *      IPR_RC_JOB_CONTINUE / IPR_RC_JOB_RETURN
5779  **/
5780 static int ipr_reset_mode_sense_failed(struct ipr_cmnd *ipr_cmd)
5781 {
5782         u32 ioasc = be32_to_cpu(ipr_cmd->ioasa.ioasc);
5783
5784         if (ioasc == IPR_IOASC_IR_INVALID_REQ_TYPE_OR_PKT) {
5785                 ipr_cmd->job_step = ipr_setup_write_cache;
5786                 return IPR_RC_JOB_CONTINUE;
5787         }
5788
5789         return ipr_reset_cmd_failed(ipr_cmd);
5790 }
5791
5792 /**
5793  * ipr_ioafp_mode_sense_page28 - Issue Mode Sense Page 28 to IOA
5794  * @ipr_cmd:    ipr command struct
5795  *
5796  * This function send a Page 28 mode sense to the IOA to
5797  * retrieve SCSI bus attributes.
5798  *
5799  * Return value:
5800  *      IPR_RC_JOB_RETURN
5801  **/
5802 static int ipr_ioafp_mode_sense_page28(struct ipr_cmnd *ipr_cmd)
5803 {
5804         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
5805
5806         ENTER;
5807         ipr_build_mode_sense(ipr_cmd, cpu_to_be32(IPR_IOA_RES_HANDLE),
5808                              0x28, ioa_cfg->vpd_cbs_dma +
5809                              offsetof(struct ipr_misc_cbs, mode_pages),
5810                              sizeof(struct ipr_mode_pages));
5811
5812         ipr_cmd->job_step = ipr_ioafp_mode_select_page28;
5813         ipr_cmd->job_step_failed = ipr_reset_mode_sense_failed;
5814
5815         ipr_do_req(ipr_cmd, ipr_reset_ioa_job, ipr_timeout, IPR_INTERNAL_TIMEOUT);
5816
5817         LEAVE;
5818         return IPR_RC_JOB_RETURN;
5819 }
5820
5821 /**
5822  * ipr_ioafp_mode_select_page24 - Issue Mode Select to IOA
5823  * @ipr_cmd:    ipr command struct
5824  *
5825  * This function enables dual IOA RAID support if possible.
5826  *
5827  * Return value:
5828  *      IPR_RC_JOB_RETURN
5829  **/
5830 static int ipr_ioafp_mode_select_page24(struct ipr_cmnd *ipr_cmd)
5831 {
5832         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
5833         struct ipr_mode_pages *mode_pages = &ioa_cfg->vpd_cbs->mode_pages;
5834         struct ipr_mode_page24 *mode_page;
5835         int length;
5836
5837         ENTER;
5838         mode_page = ipr_get_mode_page(mode_pages, 0x24,
5839                                       sizeof(struct ipr_mode_page24));
5840
5841         if (mode_page)
5842                 mode_page->flags |= IPR_ENABLE_DUAL_IOA_AF;
5843
5844         length = mode_pages->hdr.length + 1;
5845         mode_pages->hdr.length = 0;
5846
5847         ipr_build_mode_select(ipr_cmd, cpu_to_be32(IPR_IOA_RES_HANDLE), 0x11,
5848                               ioa_cfg->vpd_cbs_dma + offsetof(struct ipr_misc_cbs, mode_pages),
5849                               length);
5850
5851         ipr_cmd->job_step = ipr_ioafp_mode_sense_page28;
5852         ipr_do_req(ipr_cmd, ipr_reset_ioa_job, ipr_timeout, IPR_INTERNAL_TIMEOUT);
5853
5854         LEAVE;
5855         return IPR_RC_JOB_RETURN;
5856 }
5857
5858 /**
5859  * ipr_reset_mode_sense_page24_failed - Handle failure of IOAFP mode sense
5860  * @ipr_cmd:    ipr command struct
5861  *
5862  * This function handles the failure of a Mode Sense to the IOAFP.
5863  * Some adapters do not handle all mode pages.
5864  *
5865  * Return value:
5866  *      IPR_RC_JOB_CONTINUE / IPR_RC_JOB_RETURN
5867  **/
5868 static int ipr_reset_mode_sense_page24_failed(struct ipr_cmnd *ipr_cmd)
5869 {
5870         u32 ioasc = be32_to_cpu(ipr_cmd->ioasa.ioasc);
5871
5872         if (ioasc == IPR_IOASC_IR_INVALID_REQ_TYPE_OR_PKT) {
5873                 ipr_cmd->job_step = ipr_ioafp_mode_sense_page28;
5874                 return IPR_RC_JOB_CONTINUE;
5875         }
5876
5877         return ipr_reset_cmd_failed(ipr_cmd);
5878 }
5879
5880 /**
5881  * ipr_ioafp_mode_sense_page24 - Issue Page 24 Mode Sense to IOA
5882  * @ipr_cmd:    ipr command struct
5883  *
5884  * This function send a mode sense to the IOA to retrieve
5885  * the IOA Advanced Function Control mode page.
5886  *
5887  * Return value:
5888  *      IPR_RC_JOB_RETURN
5889  **/
5890 static int ipr_ioafp_mode_sense_page24(struct ipr_cmnd *ipr_cmd)
5891 {
5892         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
5893
5894         ENTER;
5895         ipr_build_mode_sense(ipr_cmd, cpu_to_be32(IPR_IOA_RES_HANDLE),
5896                              0x24, ioa_cfg->vpd_cbs_dma +
5897                              offsetof(struct ipr_misc_cbs, mode_pages),
5898                              sizeof(struct ipr_mode_pages));
5899
5900         ipr_cmd->job_step = ipr_ioafp_mode_select_page24;
5901         ipr_cmd->job_step_failed = ipr_reset_mode_sense_page24_failed;
5902
5903         ipr_do_req(ipr_cmd, ipr_reset_ioa_job, ipr_timeout, IPR_INTERNAL_TIMEOUT);
5904
5905         LEAVE;
5906         return IPR_RC_JOB_RETURN;
5907 }
5908
5909 /**
5910  * ipr_init_res_table - Initialize the resource table
5911  * @ipr_cmd:    ipr command struct
5912  *
5913  * This function looks through the existing resource table, comparing
5914  * it with the config table. This function will take care of old/new
5915  * devices and schedule adding/removing them from the mid-layer
5916  * as appropriate.
5917  *
5918  * Return value:
5919  *      IPR_RC_JOB_CONTINUE
5920  **/
5921 static int ipr_init_res_table(struct ipr_cmnd *ipr_cmd)
5922 {
5923         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
5924         struct ipr_resource_entry *res, *temp;
5925         struct ipr_config_table_entry *cfgte;
5926         int found, i;
5927         LIST_HEAD(old_res);
5928
5929         ENTER;
5930         if (ioa_cfg->cfg_table->hdr.flags & IPR_UCODE_DOWNLOAD_REQ)
5931                 dev_err(&ioa_cfg->pdev->dev, "Microcode download required\n");
5932
5933         list_for_each_entry_safe(res, temp, &ioa_cfg->used_res_q, queue)
5934                 list_move_tail(&res->queue, &old_res);
5935
5936         for (i = 0; i < ioa_cfg->cfg_table->hdr.num_entries; i++) {
5937                 cfgte = &ioa_cfg->cfg_table->dev[i];
5938                 found = 0;
5939
5940                 list_for_each_entry_safe(res, temp, &old_res, queue) {
5941                         if (!memcmp(&res->cfgte.res_addr,
5942                                     &cfgte->res_addr, sizeof(cfgte->res_addr))) {
5943                                 list_move_tail(&res->queue, &ioa_cfg->used_res_q);
5944                                 found = 1;
5945                                 break;
5946                         }
5947                 }
5948
5949                 if (!found) {
5950                         if (list_empty(&ioa_cfg->free_res_q)) {
5951                                 dev_err(&ioa_cfg->pdev->dev, "Too many devices attached\n");
5952                                 break;
5953                         }
5954
5955                         found = 1;
5956                         res = list_entry(ioa_cfg->free_res_q.next,
5957                                          struct ipr_resource_entry, queue);
5958                         list_move_tail(&res->queue, &ioa_cfg->used_res_q);
5959                         ipr_init_res_entry(res);
5960                         res->add_to_ml = 1;
5961                 }
5962
5963                 if (found)
5964                         memcpy(&res->cfgte, cfgte, sizeof(struct ipr_config_table_entry));
5965         }
5966
5967         list_for_each_entry_safe(res, temp, &old_res, queue) {
5968                 if (res->sdev) {
5969                         res->del_from_ml = 1;
5970                         res->cfgte.res_handle = IPR_INVALID_RES_HANDLE;
5971                         list_move_tail(&res->queue, &ioa_cfg->used_res_q);
5972                 } else {
5973                         list_move_tail(&res->queue, &ioa_cfg->free_res_q);
5974                 }
5975         }
5976
5977         if (ioa_cfg->dual_raid && ipr_dual_ioa_raid)
5978                 ipr_cmd->job_step = ipr_ioafp_mode_sense_page24;
5979         else
5980                 ipr_cmd->job_step = ipr_ioafp_mode_sense_page28;
5981
5982         LEAVE;
5983         return IPR_RC_JOB_CONTINUE;
5984 }
5985
5986 /**
5987  * ipr_ioafp_query_ioa_cfg - Send a Query IOA Config to the adapter.
5988  * @ipr_cmd:    ipr command struct
5989  *
5990  * This function sends a Query IOA Configuration command
5991  * to the adapter to retrieve the IOA configuration table.
5992  *
5993  * Return value:
5994  *      IPR_RC_JOB_RETURN
5995  **/
5996 static int ipr_ioafp_query_ioa_cfg(struct ipr_cmnd *ipr_cmd)
5997 {
5998         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
5999         struct ipr_ioarcb *ioarcb = &ipr_cmd->ioarcb;
6000         struct ipr_ioadl_desc *ioadl = ipr_cmd->ioadl;
6001         struct ipr_inquiry_page3 *ucode_vpd = &ioa_cfg->vpd_cbs->page3_data;
6002         struct ipr_inquiry_cap *cap = &ioa_cfg->vpd_cbs->cap;
6003
6004         ENTER;
6005         if (cap->cap & IPR_CAP_DUAL_IOA_RAID)
6006                 ioa_cfg->dual_raid = 1;
6007         dev_info(&ioa_cfg->pdev->dev, "Adapter firmware version: %02X%02X%02X%02X\n",
6008                  ucode_vpd->major_release, ucode_vpd->card_type,
6009                  ucode_vpd->minor_release[0], ucode_vpd->minor_release[1]);
6010         ioarcb->cmd_pkt.request_type = IPR_RQTYPE_IOACMD;
6011         ioarcb->res_handle = cpu_to_be32(IPR_IOA_RES_HANDLE);
6012
6013         ioarcb->cmd_pkt.cdb[0] = IPR_QUERY_IOA_CONFIG;
6014         ioarcb->cmd_pkt.cdb[7] = (sizeof(struct ipr_config_table) >> 8) & 0xff;
6015         ioarcb->cmd_pkt.cdb[8] = sizeof(struct ipr_config_table) & 0xff;
6016
6017         ioarcb->read_ioadl_len = cpu_to_be32(sizeof(struct ipr_ioadl_desc));
6018         ioarcb->read_data_transfer_length =
6019                 cpu_to_be32(sizeof(struct ipr_config_table));
6020
6021         ioadl->address = cpu_to_be32(ioa_cfg->cfg_table_dma);
6022         ioadl->flags_and_data_len =
6023                 cpu_to_be32(IPR_IOADL_FLAGS_READ_LAST | sizeof(struct ipr_config_table));
6024
6025         ipr_cmd->job_step = ipr_init_res_table;
6026
6027         ipr_do_req(ipr_cmd, ipr_reset_ioa_job, ipr_timeout, IPR_INTERNAL_TIMEOUT);
6028
6029         LEAVE;
6030         return IPR_RC_JOB_RETURN;
6031 }
6032
6033 /**
6034  * ipr_ioafp_inquiry - Send an Inquiry to the adapter.
6035  * @ipr_cmd:    ipr command struct
6036  *
6037  * This utility function sends an inquiry to the adapter.
6038  *
6039  * Return value:
6040  *      none
6041  **/
6042 static void ipr_ioafp_inquiry(struct ipr_cmnd *ipr_cmd, u8 flags, u8 page,
6043                               u32 dma_addr, u8 xfer_len)
6044 {
6045         struct ipr_ioarcb *ioarcb = &ipr_cmd->ioarcb;
6046         struct ipr_ioadl_desc *ioadl = ipr_cmd->ioadl;
6047
6048         ENTER;
6049         ioarcb->cmd_pkt.request_type = IPR_RQTYPE_SCSICDB;
6050         ioarcb->res_handle = cpu_to_be32(IPR_IOA_RES_HANDLE);
6051
6052         ioarcb->cmd_pkt.cdb[0] = INQUIRY;
6053         ioarcb->cmd_pkt.cdb[1] = flags;
6054         ioarcb->cmd_pkt.cdb[2] = page;
6055         ioarcb->cmd_pkt.cdb[4] = xfer_len;
6056
6057         ioarcb->read_ioadl_len = cpu_to_be32(sizeof(struct ipr_ioadl_desc));
6058         ioarcb->read_data_transfer_length = cpu_to_be32(xfer_len);
6059
6060         ioadl->address = cpu_to_be32(dma_addr);
6061         ioadl->flags_and_data_len =
6062                 cpu_to_be32(IPR_IOADL_FLAGS_READ_LAST | xfer_len);
6063
6064         ipr_do_req(ipr_cmd, ipr_reset_ioa_job, ipr_timeout, IPR_INTERNAL_TIMEOUT);
6065         LEAVE;
6066 }
6067
6068 /**
6069  * ipr_inquiry_page_supported - Is the given inquiry page supported
6070  * @page0:              inquiry page 0 buffer
6071  * @page:               page code.
6072  *
6073  * This function determines if the specified inquiry page is supported.
6074  *
6075  * Return value:
6076  *      1 if page is supported / 0 if not
6077  **/
6078 static int ipr_inquiry_page_supported(struct ipr_inquiry_page0 *page0, u8 page)
6079 {
6080         int i;
6081
6082         for (i = 0; i < min_t(u8, page0->len, IPR_INQUIRY_PAGE0_ENTRIES); i++)
6083                 if (page0->page[i] == page)
6084                         return 1;
6085
6086         return 0;
6087 }
6088
6089 /**
6090  * ipr_ioafp_cap_inquiry - Send a Page 0xD0 Inquiry to the adapter.
6091  * @ipr_cmd:    ipr command struct
6092  *
6093  * This function sends a Page 0xD0 inquiry to the adapter
6094  * to retrieve adapter capabilities.
6095  *
6096  * Return value:
6097  *      IPR_RC_JOB_CONTINUE / IPR_RC_JOB_RETURN
6098  **/
6099 static int ipr_ioafp_cap_inquiry(struct ipr_cmnd *ipr_cmd)
6100 {
6101         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
6102         struct ipr_inquiry_page0 *page0 = &ioa_cfg->vpd_cbs->page0_data;
6103         struct ipr_inquiry_cap *cap = &ioa_cfg->vpd_cbs->cap;
6104
6105         ENTER;
6106         ipr_cmd->job_step = ipr_ioafp_query_ioa_cfg;
6107         memset(cap, 0, sizeof(*cap));
6108
6109         if (ipr_inquiry_page_supported(page0, 0xD0)) {
6110                 ipr_ioafp_inquiry(ipr_cmd, 1, 0xD0,
6111                                   ioa_cfg->vpd_cbs_dma + offsetof(struct ipr_misc_cbs, cap),
6112                                   sizeof(struct ipr_inquiry_cap));
6113                 return IPR_RC_JOB_RETURN;
6114         }
6115
6116         LEAVE;
6117         return IPR_RC_JOB_CONTINUE;
6118 }
6119
6120 /**
6121  * ipr_ioafp_page3_inquiry - Send a Page 3 Inquiry to the adapter.
6122  * @ipr_cmd:    ipr command struct
6123  *
6124  * This function sends a Page 3 inquiry to the adapter
6125  * to retrieve software VPD information.
6126  *
6127  * Return value:
6128  *      IPR_RC_JOB_CONTINUE / IPR_RC_JOB_RETURN
6129  **/
6130 static int ipr_ioafp_page3_inquiry(struct ipr_cmnd *ipr_cmd)
6131 {
6132         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
6133         struct ipr_inquiry_page0 *page0 = &ioa_cfg->vpd_cbs->page0_data;
6134
6135         ENTER;
6136
6137         if (!ipr_inquiry_page_supported(page0, 1))
6138                 ioa_cfg->cache_state = CACHE_NONE;
6139
6140         ipr_cmd->job_step = ipr_ioafp_cap_inquiry;
6141
6142         ipr_ioafp_inquiry(ipr_cmd, 1, 3,
6143                           ioa_cfg->vpd_cbs_dma + offsetof(struct ipr_misc_cbs, page3_data),
6144                           sizeof(struct ipr_inquiry_page3));
6145
6146         LEAVE;
6147         return IPR_RC_JOB_RETURN;
6148 }
6149
6150 /**
6151  * ipr_ioafp_page0_inquiry - Send a Page 0 Inquiry to the adapter.
6152  * @ipr_cmd:    ipr command struct
6153  *
6154  * This function sends a Page 0 inquiry to the adapter
6155  * to retrieve supported inquiry pages.
6156  *
6157  * Return value:
6158  *      IPR_RC_JOB_CONTINUE / IPR_RC_JOB_RETURN
6159  **/
6160 static int ipr_ioafp_page0_inquiry(struct ipr_cmnd *ipr_cmd)
6161 {
6162         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
6163         char type[5];
6164
6165         ENTER;
6166
6167         /* Grab the type out of the VPD and store it away */
6168         memcpy(type, ioa_cfg->vpd_cbs->ioa_vpd.std_inq_data.vpids.product_id, 4);
6169         type[4] = '\0';
6170         ioa_cfg->type = simple_strtoul((char *)type, NULL, 16);
6171
6172         ipr_cmd->job_step = ipr_ioafp_page3_inquiry;
6173
6174         ipr_ioafp_inquiry(ipr_cmd, 1, 0,
6175                           ioa_cfg->vpd_cbs_dma + offsetof(struct ipr_misc_cbs, page0_data),
6176                           sizeof(struct ipr_inquiry_page0));
6177
6178         LEAVE;
6179         return IPR_RC_JOB_RETURN;
6180 }
6181
6182 /**
6183  * ipr_ioafp_std_inquiry - Send a Standard Inquiry to the adapter.
6184  * @ipr_cmd:    ipr command struct
6185  *
6186  * This function sends a standard inquiry to the adapter.
6187  *
6188  * Return value:
6189  *      IPR_RC_JOB_RETURN
6190  **/
6191 static int ipr_ioafp_std_inquiry(struct ipr_cmnd *ipr_cmd)
6192 {
6193         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
6194
6195         ENTER;
6196         ipr_cmd->job_step = ipr_ioafp_page0_inquiry;
6197
6198         ipr_ioafp_inquiry(ipr_cmd, 0, 0,
6199                           ioa_cfg->vpd_cbs_dma + offsetof(struct ipr_misc_cbs, ioa_vpd),
6200                           sizeof(struct ipr_ioa_vpd));
6201
6202         LEAVE;
6203         return IPR_RC_JOB_RETURN;
6204 }
6205
6206 /**
6207  * ipr_ioafp_indentify_hrrq - Send Identify Host RRQ.
6208  * @ipr_cmd:    ipr command struct
6209  *
6210  * This function send an Identify Host Request Response Queue
6211  * command to establish the HRRQ with the adapter.
6212  *
6213  * Return value:
6214  *      IPR_RC_JOB_RETURN
6215  **/
6216 static int ipr_ioafp_indentify_hrrq(struct ipr_cmnd *ipr_cmd)
6217 {
6218         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
6219         struct ipr_ioarcb *ioarcb = &ipr_cmd->ioarcb;
6220
6221         ENTER;
6222         dev_info(&ioa_cfg->pdev->dev, "Starting IOA initialization sequence.\n");
6223
6224         ioarcb->cmd_pkt.cdb[0] = IPR_ID_HOST_RR_Q;
6225         ioarcb->res_handle = cpu_to_be32(IPR_IOA_RES_HANDLE);
6226
6227         ioarcb->cmd_pkt.request_type = IPR_RQTYPE_IOACMD;
6228         ioarcb->cmd_pkt.cdb[2] =
6229                 ((u32) ioa_cfg->host_rrq_dma >> 24) & 0xff;
6230         ioarcb->cmd_pkt.cdb[3] =
6231                 ((u32) ioa_cfg->host_rrq_dma >> 16) & 0xff;
6232         ioarcb->cmd_pkt.cdb[4] =
6233                 ((u32) ioa_cfg->host_rrq_dma >> 8) & 0xff;
6234         ioarcb->cmd_pkt.cdb[5] =
6235                 ((u32) ioa_cfg->host_rrq_dma) & 0xff;
6236         ioarcb->cmd_pkt.cdb[7] =
6237                 ((sizeof(u32) * IPR_NUM_CMD_BLKS) >> 8) & 0xff;
6238         ioarcb->cmd_pkt.cdb[8] =
6239                 (sizeof(u32) * IPR_NUM_CMD_BLKS) & 0xff;
6240
6241         ipr_cmd->job_step = ipr_ioafp_std_inquiry;
6242
6243         ipr_do_req(ipr_cmd, ipr_reset_ioa_job, ipr_timeout, IPR_INTERNAL_TIMEOUT);
6244
6245         LEAVE;
6246         return IPR_RC_JOB_RETURN;
6247 }
6248
6249 /**
6250  * ipr_reset_timer_done - Adapter reset timer function
6251  * @ipr_cmd:    ipr command struct
6252  *
6253  * Description: This function is used in adapter reset processing
6254  * for timing events. If the reset_cmd pointer in the IOA
6255  * config struct is not this adapter's we are doing nested
6256  * resets and fail_all_ops will take care of freeing the
6257  * command block.
6258  *
6259  * Return value:
6260  *      none
6261  **/
6262 static void ipr_reset_timer_done(struct ipr_cmnd *ipr_cmd)
6263 {
6264         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
6265         unsigned long lock_flags = 0;
6266
6267         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
6268
6269         if (ioa_cfg->reset_cmd == ipr_cmd) {
6270                 list_del(&ipr_cmd->queue);
6271                 ipr_cmd->done(ipr_cmd);
6272         }
6273
6274         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
6275 }
6276
6277 /**
6278  * ipr_reset_start_timer - Start a timer for adapter reset job
6279  * @ipr_cmd:    ipr command struct
6280  * @timeout:    timeout value
6281  *
6282  * Description: This function is used in adapter reset processing
6283  * for timing events. If the reset_cmd pointer in the IOA
6284  * config struct is not this adapter's we are doing nested
6285  * resets and fail_all_ops will take care of freeing the
6286  * command block.
6287  *
6288  * Return value:
6289  *      none
6290  **/
6291 static void ipr_reset_start_timer(struct ipr_cmnd *ipr_cmd,
6292                                   unsigned long timeout)
6293 {
6294         list_add_tail(&ipr_cmd->queue, &ipr_cmd->ioa_cfg->pending_q);
6295         ipr_cmd->done = ipr_reset_ioa_job;
6296
6297         ipr_cmd->timer.data = (unsigned long) ipr_cmd;
6298         ipr_cmd->timer.expires = jiffies + timeout;
6299         ipr_cmd->timer.function = (void (*)(unsigned long))ipr_reset_timer_done;
6300         add_timer(&ipr_cmd->timer);
6301 }
6302
6303 /**
6304  * ipr_init_ioa_mem - Initialize ioa_cfg control block
6305  * @ioa_cfg:    ioa cfg struct
6306  *
6307  * Return value:
6308  *      nothing
6309  **/
6310 static void ipr_init_ioa_mem(struct ipr_ioa_cfg *ioa_cfg)
6311 {
6312         memset(ioa_cfg->host_rrq, 0, sizeof(u32) * IPR_NUM_CMD_BLKS);
6313
6314         /* Initialize Host RRQ pointers */
6315         ioa_cfg->hrrq_start = ioa_cfg->host_rrq;
6316         ioa_cfg->hrrq_end = &ioa_cfg->host_rrq[IPR_NUM_CMD_BLKS - 1];
6317         ioa_cfg->hrrq_curr = ioa_cfg->hrrq_start;
6318         ioa_cfg->toggle_bit = 1;
6319
6320         /* Zero out config table */
6321         memset(ioa_cfg->cfg_table, 0, sizeof(struct ipr_config_table));
6322 }
6323
6324 /**
6325  * ipr_reset_enable_ioa - Enable the IOA following a reset.
6326  * @ipr_cmd:    ipr command struct
6327  *
6328  * This function reinitializes some control blocks and
6329  * enables destructive diagnostics on the adapter.
6330  *
6331  * Return value:
6332  *      IPR_RC_JOB_RETURN
6333  **/
6334 static int ipr_reset_enable_ioa(struct ipr_cmnd *ipr_cmd)
6335 {
6336         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
6337         volatile u32 int_reg;
6338
6339         ENTER;
6340         ipr_cmd->job_step = ipr_ioafp_indentify_hrrq;
6341         ipr_init_ioa_mem(ioa_cfg);
6342
6343         ioa_cfg->allow_interrupts = 1;
6344         int_reg = readl(ioa_cfg->regs.sense_interrupt_reg);
6345
6346         if (int_reg & IPR_PCII_IOA_TRANS_TO_OPER) {
6347                 writel((IPR_PCII_ERROR_INTERRUPTS | IPR_PCII_HRRQ_UPDATED),
6348                        ioa_cfg->regs.clr_interrupt_mask_reg);
6349                 int_reg = readl(ioa_cfg->regs.sense_interrupt_mask_reg);
6350                 return IPR_RC_JOB_CONTINUE;
6351         }
6352
6353         /* Enable destructive diagnostics on IOA */
6354         writel(ioa_cfg->doorbell, ioa_cfg->regs.set_uproc_interrupt_reg);
6355
6356         writel(IPR_PCII_OPER_INTERRUPTS, ioa_cfg->regs.clr_interrupt_mask_reg);
6357         int_reg = readl(ioa_cfg->regs.sense_interrupt_mask_reg);
6358
6359         dev_info(&ioa_cfg->pdev->dev, "Initializing IOA.\n");
6360
6361         ipr_cmd->timer.data = (unsigned long) ipr_cmd;
6362         ipr_cmd->timer.expires = jiffies + (ioa_cfg->transop_timeout * HZ);
6363         ipr_cmd->timer.function = (void (*)(unsigned long))ipr_oper_timeout;
6364         ipr_cmd->done = ipr_reset_ioa_job;
6365         add_timer(&ipr_cmd->timer);
6366         list_add_tail(&ipr_cmd->queue, &ioa_cfg->pending_q);
6367
6368         LEAVE;
6369         return IPR_RC_JOB_RETURN;
6370 }
6371
6372 /**
6373  * ipr_reset_wait_for_dump - Wait for a dump to timeout.
6374  * @ipr_cmd:    ipr command struct
6375  *
6376  * This function is invoked when an adapter dump has run out
6377  * of processing time.
6378  *
6379  * Return value:
6380  *      IPR_RC_JOB_CONTINUE
6381  **/
6382 static int ipr_reset_wait_for_dump(struct ipr_cmnd *ipr_cmd)
6383 {
6384         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
6385
6386         if (ioa_cfg->sdt_state == GET_DUMP)
6387                 ioa_cfg->sdt_state = ABORT_DUMP;
6388
6389         ipr_cmd->job_step = ipr_reset_alert;
6390
6391         return IPR_RC_JOB_CONTINUE;
6392 }
6393
6394 /**
6395  * ipr_unit_check_no_data - Log a unit check/no data error log
6396  * @ioa_cfg:            ioa config struct
6397  *
6398  * Logs an error indicating the adapter unit checked, but for some
6399  * reason, we were unable to fetch the unit check buffer.
6400  *
6401  * Return value:
6402  *      nothing
6403  **/
6404 static void ipr_unit_check_no_data(struct ipr_ioa_cfg *ioa_cfg)
6405 {
6406         ioa_cfg->errors_logged++;
6407         dev_err(&ioa_cfg->pdev->dev, "IOA unit check with no data\n");
6408 }
6409
6410 /**
6411  * ipr_get_unit_check_buffer - Get the unit check buffer from the IOA
6412  * @ioa_cfg:            ioa config struct
6413  *
6414  * Fetches the unit check buffer from the adapter by clocking the data
6415  * through the mailbox register.
6416  *
6417  * Return value:
6418  *      nothing
6419  **/
6420 static void ipr_get_unit_check_buffer(struct ipr_ioa_cfg *ioa_cfg)
6421 {
6422         unsigned long mailbox;
6423         struct ipr_hostrcb *hostrcb;
6424         struct ipr_uc_sdt sdt;
6425         int rc, length;
6426         u32 ioasc;
6427
6428         mailbox = readl(ioa_cfg->ioa_mailbox);
6429
6430         if (!ipr_sdt_is_fmt2(mailbox)) {
6431                 ipr_unit_check_no_data(ioa_cfg);
6432                 return;
6433         }
6434
6435         memset(&sdt, 0, sizeof(struct ipr_uc_sdt));
6436         rc = ipr_get_ldump_data_section(ioa_cfg, mailbox, (__be32 *) &sdt,
6437                                         (sizeof(struct ipr_uc_sdt)) / sizeof(__be32));
6438
6439         if (rc || (be32_to_cpu(sdt.hdr.state) != IPR_FMT2_SDT_READY_TO_USE) ||
6440             !(sdt.entry[0].flags & IPR_SDT_VALID_ENTRY)) {
6441                 ipr_unit_check_no_data(ioa_cfg);
6442                 return;
6443         }
6444
6445         /* Find length of the first sdt entry (UC buffer) */
6446         length = (be32_to_cpu(sdt.entry[0].end_offset) -
6447                   be32_to_cpu(sdt.entry[0].bar_str_offset)) & IPR_FMT2_MBX_ADDR_MASK;
6448
6449         hostrcb = list_entry(ioa_cfg->hostrcb_free_q.next,
6450                              struct ipr_hostrcb, queue);
6451         list_del(&hostrcb->queue);
6452         memset(&hostrcb->hcam, 0, sizeof(hostrcb->hcam));
6453
6454         rc = ipr_get_ldump_data_section(ioa_cfg,
6455                                         be32_to_cpu(sdt.entry[0].bar_str_offset),
6456                                         (__be32 *)&hostrcb->hcam,
6457                                         min(length, (int)sizeof(hostrcb->hcam)) / sizeof(__be32));
6458
6459         if (!rc) {
6460                 ipr_handle_log_data(ioa_cfg, hostrcb);
6461                 ioasc = be32_to_cpu(hostrcb->hcam.u.error.failing_dev_ioasc);
6462                 if (ioasc == IPR_IOASC_NR_IOA_RESET_REQUIRED &&
6463                     ioa_cfg->sdt_state == GET_DUMP)
6464                         ioa_cfg->sdt_state = WAIT_FOR_DUMP;
6465         } else
6466                 ipr_unit_check_no_data(ioa_cfg);
6467
6468         list_add_tail(&hostrcb->queue, &ioa_cfg->hostrcb_free_q);
6469 }
6470
6471 /**
6472  * ipr_reset_restore_cfg_space - Restore PCI config space.
6473  * @ipr_cmd:    ipr command struct
6474  *
6475  * Description: This function restores the saved PCI config space of
6476  * the adapter, fails all outstanding ops back to the callers, and
6477  * fetches the dump/unit check if applicable to this reset.
6478  *
6479  * Return value:
6480  *      IPR_RC_JOB_CONTINUE / IPR_RC_JOB_RETURN
6481  **/
6482 static int ipr_reset_restore_cfg_space(struct ipr_cmnd *ipr_cmd)
6483 {
6484         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
6485         int rc;
6486
6487         ENTER;
6488         rc = pci_restore_state(ioa_cfg->pdev);
6489
6490         if (rc != PCIBIOS_SUCCESSFUL) {
6491                 ipr_cmd->ioasa.ioasc = cpu_to_be32(IPR_IOASC_PCI_ACCESS_ERROR);
6492                 return IPR_RC_JOB_CONTINUE;
6493         }
6494
6495         if (ipr_set_pcix_cmd_reg(ioa_cfg)) {
6496                 ipr_cmd->ioasa.ioasc = cpu_to_be32(IPR_IOASC_PCI_ACCESS_ERROR);
6497                 return IPR_RC_JOB_CONTINUE;
6498         }
6499
6500         ipr_fail_all_ops(ioa_cfg);
6501
6502         if (ioa_cfg->ioa_unit_checked) {
6503                 ioa_cfg->ioa_unit_checked = 0;
6504                 ipr_get_unit_check_buffer(ioa_cfg);
6505                 ipr_cmd->job_step = ipr_reset_alert;
6506                 ipr_reset_start_timer(ipr_cmd, 0);
6507                 return IPR_RC_JOB_RETURN;
6508         }
6509
6510         if (ioa_cfg->in_ioa_bringdown) {
6511                 ipr_cmd->job_step = ipr_ioa_bringdown_done;
6512         } else {
6513                 ipr_cmd->job_step = ipr_reset_enable_ioa;
6514
6515                 if (GET_DUMP == ioa_cfg->sdt_state) {
6516                         ipr_reset_start_timer(ipr_cmd, IPR_DUMP_TIMEOUT);
6517                         ipr_cmd->job_step = ipr_reset_wait_for_dump;
6518                         schedule_work(&ioa_cfg->work_q);
6519                         return IPR_RC_JOB_RETURN;
6520                 }
6521         }
6522
6523         ENTER;
6524         return IPR_RC_JOB_CONTINUE;
6525 }
6526
6527 /**
6528  * ipr_reset_bist_done - BIST has completed on the adapter.
6529  * @ipr_cmd:    ipr command struct
6530  *
6531  * Description: Unblock config space and resume the reset process.
6532  *
6533  * Return value:
6534  *      IPR_RC_JOB_CONTINUE
6535  **/
6536 static int ipr_reset_bist_done(struct ipr_cmnd *ipr_cmd)
6537 {
6538         ENTER;
6539         pci_unblock_user_cfg_access(ipr_cmd->ioa_cfg->pdev);
6540         ipr_cmd->job_step = ipr_reset_restore_cfg_space;
6541         LEAVE;
6542         return IPR_RC_JOB_CONTINUE;
6543 }
6544
6545 /**
6546  * ipr_reset_start_bist - Run BIST on the adapter.
6547  * @ipr_cmd:    ipr command struct
6548  *
6549  * Description: This function runs BIST on the adapter, then delays 2 seconds.
6550  *
6551  * Return value:
6552  *      IPR_RC_JOB_CONTINUE / IPR_RC_JOB_RETURN
6553  **/
6554 static int ipr_reset_start_bist(struct ipr_cmnd *ipr_cmd)
6555 {
6556         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
6557         int rc;
6558
6559         ENTER;
6560         pci_block_user_cfg_access(ioa_cfg->pdev);
6561         rc = pci_write_config_byte(ioa_cfg->pdev, PCI_BIST, PCI_BIST_START);
6562
6563         if (rc != PCIBIOS_SUCCESSFUL) {
6564                 pci_unblock_user_cfg_access(ipr_cmd->ioa_cfg->pdev);
6565                 ipr_cmd->ioasa.ioasc = cpu_to_be32(IPR_IOASC_PCI_ACCESS_ERROR);
6566                 rc = IPR_RC_JOB_CONTINUE;
6567         } else {
6568                 ipr_cmd->job_step = ipr_reset_bist_done;
6569                 ipr_reset_start_timer(ipr_cmd, IPR_WAIT_FOR_BIST_TIMEOUT);
6570                 rc = IPR_RC_JOB_RETURN;
6571         }
6572
6573         LEAVE;
6574         return rc;
6575 }
6576
6577 /**
6578  * ipr_reset_slot_reset_done - Clear PCI reset to the adapter
6579  * @ipr_cmd:    ipr command struct
6580  *
6581  * Description: This clears PCI reset to the adapter and delays two seconds.
6582  *
6583  * Return value:
6584  *      IPR_RC_JOB_RETURN
6585  **/
6586 static int ipr_reset_slot_reset_done(struct ipr_cmnd *ipr_cmd)
6587 {
6588         ENTER;
6589         pci_set_pcie_reset_state(ipr_cmd->ioa_cfg->pdev, pcie_deassert_reset);
6590         ipr_cmd->job_step = ipr_reset_bist_done;
6591         ipr_reset_start_timer(ipr_cmd, IPR_WAIT_FOR_BIST_TIMEOUT);
6592         LEAVE;
6593         return IPR_RC_JOB_RETURN;
6594 }
6595
6596 /**
6597  * ipr_reset_slot_reset - Reset the PCI slot of the adapter.
6598  * @ipr_cmd:    ipr command struct
6599  *
6600  * Description: This asserts PCI reset to the adapter.
6601  *
6602  * Return value:
6603  *      IPR_RC_JOB_RETURN
6604  **/
6605 static int ipr_reset_slot_reset(struct ipr_cmnd *ipr_cmd)
6606 {
6607         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
6608         struct pci_dev *pdev = ioa_cfg->pdev;
6609
6610         ENTER;
6611         pci_block_user_cfg_access(pdev);
6612         pci_set_pcie_reset_state(pdev, pcie_warm_reset);
6613         ipr_cmd->job_step = ipr_reset_slot_reset_done;
6614         ipr_reset_start_timer(ipr_cmd, IPR_PCI_RESET_TIMEOUT);
6615         LEAVE;
6616         return IPR_RC_JOB_RETURN;
6617 }
6618
6619 /**
6620  * ipr_reset_allowed - Query whether or not IOA can be reset
6621  * @ioa_cfg:    ioa config struct
6622  *
6623  * Return value:
6624  *      0 if reset not allowed / non-zero if reset is allowed
6625  **/
6626 static int ipr_reset_allowed(struct ipr_ioa_cfg *ioa_cfg)
6627 {
6628         volatile u32 temp_reg;
6629
6630         temp_reg = readl(ioa_cfg->regs.sense_interrupt_reg);
6631         return ((temp_reg & IPR_PCII_CRITICAL_OPERATION) == 0);
6632 }
6633
6634 /**
6635  * ipr_reset_wait_to_start_bist - Wait for permission to reset IOA.
6636  * @ipr_cmd:    ipr command struct
6637  *
6638  * Description: This function waits for adapter permission to run BIST,
6639  * then runs BIST. If the adapter does not give permission after a
6640  * reasonable time, we will reset the adapter anyway. The impact of
6641  * resetting the adapter without warning the adapter is the risk of
6642  * losing the persistent error log on the adapter. If the adapter is
6643  * reset while it is writing to the flash on the adapter, the flash
6644  * segment will have bad ECC and be zeroed.
6645  *
6646  * Return value:
6647  *      IPR_RC_JOB_CONTINUE / IPR_RC_JOB_RETURN
6648  **/
6649 static int ipr_reset_wait_to_start_bist(struct ipr_cmnd *ipr_cmd)
6650 {
6651         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
6652         int rc = IPR_RC_JOB_RETURN;
6653
6654         if (!ipr_reset_allowed(ioa_cfg) && ipr_cmd->u.time_left) {
6655                 ipr_cmd->u.time_left -= IPR_CHECK_FOR_RESET_TIMEOUT;
6656                 ipr_reset_start_timer(ipr_cmd, IPR_CHECK_FOR_RESET_TIMEOUT);
6657         } else {
6658                 ipr_cmd->job_step = ioa_cfg->reset;
6659                 rc = IPR_RC_JOB_CONTINUE;
6660         }
6661
6662         return rc;
6663 }
6664
6665 /**
6666  * ipr_reset_alert_part2 - Alert the adapter of a pending reset
6667  * @ipr_cmd:    ipr command struct
6668  *
6669  * Description: This function alerts the adapter that it will be reset.
6670  * If memory space is not currently enabled, proceed directly
6671  * to running BIST on the adapter. The timer must always be started
6672  * so we guarantee we do not run BIST from ipr_isr.
6673  *
6674  * Return value:
6675  *      IPR_RC_JOB_RETURN
6676  **/
6677 static int ipr_reset_alert(struct ipr_cmnd *ipr_cmd)
6678 {
6679         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
6680         u16 cmd_reg;
6681         int rc;
6682
6683         ENTER;
6684         rc = pci_read_config_word(ioa_cfg->pdev, PCI_COMMAND, &cmd_reg);
6685
6686         if ((rc == PCIBIOS_SUCCESSFUL) && (cmd_reg & PCI_COMMAND_MEMORY)) {
6687                 ipr_mask_and_clear_interrupts(ioa_cfg, ~0);
6688                 writel(IPR_UPROCI_RESET_ALERT, ioa_cfg->regs.set_uproc_interrupt_reg);
6689                 ipr_cmd->job_step = ipr_reset_wait_to_start_bist;
6690         } else {
6691                 ipr_cmd->job_step = ioa_cfg->reset;
6692         }
6693
6694         ipr_cmd->u.time_left = IPR_WAIT_FOR_RESET_TIMEOUT;
6695         ipr_reset_start_timer(ipr_cmd, IPR_CHECK_FOR_RESET_TIMEOUT);
6696
6697         LEAVE;
6698         return IPR_RC_JOB_RETURN;
6699 }
6700
6701 /**
6702  * ipr_reset_ucode_download_done - Microcode download completion
6703  * @ipr_cmd:    ipr command struct
6704  *
6705  * Description: This function unmaps the microcode download buffer.
6706  *
6707  * Return value:
6708  *      IPR_RC_JOB_CONTINUE
6709  **/
6710 static int ipr_reset_ucode_download_done(struct ipr_cmnd *ipr_cmd)
6711 {
6712         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
6713         struct ipr_sglist *sglist = ioa_cfg->ucode_sglist;
6714
6715         pci_unmap_sg(ioa_cfg->pdev, sglist->scatterlist,
6716                      sglist->num_sg, DMA_TO_DEVICE);
6717
6718         ipr_cmd->job_step = ipr_reset_alert;
6719         return IPR_RC_JOB_CONTINUE;
6720 }
6721
6722 /**
6723  * ipr_reset_ucode_download - Download microcode to the adapter
6724  * @ipr_cmd:    ipr command struct
6725  *
6726  * Description: This function checks to see if it there is microcode
6727  * to download to the adapter. If there is, a download is performed.
6728  *
6729  * Return value:
6730  *      IPR_RC_JOB_CONTINUE / IPR_RC_JOB_RETURN
6731  **/
6732 static int ipr_reset_ucode_download(struct ipr_cmnd *ipr_cmd)
6733 {
6734         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
6735         struct ipr_sglist *sglist = ioa_cfg->ucode_sglist;
6736
6737         ENTER;
6738         ipr_cmd->job_step = ipr_reset_alert;
6739
6740         if (!sglist)
6741                 return IPR_RC_JOB_CONTINUE;
6742
6743         ipr_cmd->ioarcb.res_handle = cpu_to_be32(IPR_IOA_RES_HANDLE);
6744         ipr_cmd->ioarcb.cmd_pkt.request_type = IPR_RQTYPE_SCSICDB;
6745         ipr_cmd->ioarcb.cmd_pkt.cdb[0] = WRITE_BUFFER;
6746         ipr_cmd->ioarcb.cmd_pkt.cdb[1] = IPR_WR_BUF_DOWNLOAD_AND_SAVE;
6747         ipr_cmd->ioarcb.cmd_pkt.cdb[6] = (sglist->buffer_len & 0xff0000) >> 16;
6748         ipr_cmd->ioarcb.cmd_pkt.cdb[7] = (sglist->buffer_len & 0x00ff00) >> 8;
6749         ipr_cmd->ioarcb.cmd_pkt.cdb[8] = sglist->buffer_len & 0x0000ff;
6750
6751         ipr_build_ucode_ioadl(ipr_cmd, sglist);
6752         ipr_cmd->job_step = ipr_reset_ucode_download_done;
6753
6754         ipr_do_req(ipr_cmd, ipr_reset_ioa_job, ipr_timeout,
6755                    IPR_WRITE_BUFFER_TIMEOUT);
6756
6757         LEAVE;
6758         return IPR_RC_JOB_RETURN;
6759 }
6760
6761 /**
6762  * ipr_reset_shutdown_ioa - Shutdown the adapter
6763  * @ipr_cmd:    ipr command struct
6764  *
6765  * Description: This function issues an adapter shutdown of the
6766  * specified type to the specified adapter as part of the
6767  * adapter reset job.
6768  *
6769  * Return value:
6770  *      IPR_RC_JOB_CONTINUE / IPR_RC_JOB_RETURN
6771  **/
6772 static int ipr_reset_shutdown_ioa(struct ipr_cmnd *ipr_cmd)
6773 {
6774         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
6775         enum ipr_shutdown_type shutdown_type = ipr_cmd->u.shutdown_type;
6776         unsigned long timeout;
6777         int rc = IPR_RC_JOB_CONTINUE;
6778
6779         ENTER;
6780         if (shutdown_type != IPR_SHUTDOWN_NONE && !ioa_cfg->ioa_is_dead) {
6781                 ipr_cmd->ioarcb.res_handle = cpu_to_be32(IPR_IOA_RES_HANDLE);
6782                 ipr_cmd->ioarcb.cmd_pkt.request_type = IPR_RQTYPE_IOACMD;
6783                 ipr_cmd->ioarcb.cmd_pkt.cdb[0] = IPR_IOA_SHUTDOWN;
6784                 ipr_cmd->ioarcb.cmd_pkt.cdb[1] = shutdown_type;
6785
6786                 if (shutdown_type == IPR_SHUTDOWN_NORMAL)
6787                         timeout = IPR_SHUTDOWN_TIMEOUT;
6788                 else if (shutdown_type == IPR_SHUTDOWN_PREPARE_FOR_NORMAL)
6789                         timeout = IPR_INTERNAL_TIMEOUT;
6790                 else if (ioa_cfg->dual_raid && ipr_dual_ioa_raid)
6791                         timeout = IPR_DUAL_IOA_ABBR_SHUTDOWN_TO;
6792                 else
6793                         timeout = IPR_ABBREV_SHUTDOWN_TIMEOUT;
6794
6795                 ipr_do_req(ipr_cmd, ipr_reset_ioa_job, ipr_timeout, timeout);
6796
6797                 rc = IPR_RC_JOB_RETURN;
6798                 ipr_cmd->job_step = ipr_reset_ucode_download;
6799         } else
6800                 ipr_cmd->job_step = ipr_reset_alert;
6801
6802         LEAVE;
6803         return rc;
6804 }
6805
6806 /**
6807  * ipr_reset_ioa_job - Adapter reset job
6808  * @ipr_cmd:    ipr command struct
6809  *
6810  * Description: This function is the job router for the adapter reset job.
6811  *
6812  * Return value:
6813  *      none
6814  **/
6815 static void ipr_reset_ioa_job(struct ipr_cmnd *ipr_cmd)
6816 {
6817         u32 rc, ioasc;
6818         struct ipr_ioa_cfg *ioa_cfg = ipr_cmd->ioa_cfg;
6819
6820         do {
6821                 ioasc = be32_to_cpu(ipr_cmd->ioasa.ioasc);
6822
6823                 if (ioa_cfg->reset_cmd != ipr_cmd) {
6824                         /*
6825                          * We are doing nested adapter resets and this is
6826                          * not the current reset job.
6827                          */
6828                         list_add_tail(&ipr_cmd->queue, &ioa_cfg->free_q);
6829                         return;
6830                 }
6831
6832                 if (IPR_IOASC_SENSE_KEY(ioasc)) {
6833                         rc = ipr_cmd->job_step_failed(ipr_cmd);
6834                         if (rc == IPR_RC_JOB_RETURN)
6835                                 return;
6836                 }
6837
6838                 ipr_reinit_ipr_cmnd(ipr_cmd);
6839                 ipr_cmd->job_step_failed = ipr_reset_cmd_failed;
6840                 rc = ipr_cmd->job_step(ipr_cmd);
6841         } while(rc == IPR_RC_JOB_CONTINUE);
6842 }
6843
6844 /**
6845  * _ipr_initiate_ioa_reset - Initiate an adapter reset
6846  * @ioa_cfg:            ioa config struct
6847  * @job_step:           first job step of reset job
6848  * @shutdown_type:      shutdown type
6849  *
6850  * Description: This function will initiate the reset of the given adapter
6851  * starting at the selected job step.
6852  * If the caller needs to wait on the completion of the reset,
6853  * the caller must sleep on the reset_wait_q.
6854  *
6855  * Return value:
6856  *      none
6857  **/
6858 static void _ipr_initiate_ioa_reset(struct ipr_ioa_cfg *ioa_cfg,
6859                                     int (*job_step) (struct ipr_cmnd *),
6860                                     enum ipr_shutdown_type shutdown_type)
6861 {
6862         struct ipr_cmnd *ipr_cmd;
6863
6864         ioa_cfg->in_reset_reload = 1;
6865         ioa_cfg->allow_cmds = 0;
6866         scsi_block_requests(ioa_cfg->host);
6867
6868         ipr_cmd = ipr_get_free_ipr_cmnd(ioa_cfg);
6869         ioa_cfg->reset_cmd = ipr_cmd;
6870         ipr_cmd->job_step = job_step;
6871         ipr_cmd->u.shutdown_type = shutdown_type;
6872
6873         ipr_reset_ioa_job(ipr_cmd);
6874 }
6875
6876 /**
6877  * ipr_initiate_ioa_reset - Initiate an adapter reset
6878  * @ioa_cfg:            ioa config struct
6879  * @shutdown_type:      shutdown type
6880  *
6881  * Description: This function will initiate the reset of the given adapter.
6882  * If the caller needs to wait on the completion of the reset,
6883  * the caller must sleep on the reset_wait_q.
6884  *
6885  * Return value:
6886  *      none
6887  **/
6888 static void ipr_initiate_ioa_reset(struct ipr_ioa_cfg *ioa_cfg,
6889                                    enum ipr_shutdown_type shutdown_type)
6890 {
6891         if (ioa_cfg->ioa_is_dead)
6892                 return;
6893
6894         if (ioa_cfg->in_reset_reload && ioa_cfg->sdt_state == GET_DUMP)
6895                 ioa_cfg->sdt_state = ABORT_DUMP;
6896
6897         if (ioa_cfg->reset_retries++ >= IPR_NUM_RESET_RELOAD_RETRIES) {
6898                 dev_err(&ioa_cfg->pdev->dev,
6899                         "IOA taken offline - error recovery failed\n");
6900
6901                 ioa_cfg->reset_retries = 0;
6902                 ioa_cfg->ioa_is_dead = 1;
6903
6904                 if (ioa_cfg->in_ioa_bringdown) {
6905                         ioa_cfg->reset_cmd = NULL;
6906                         ioa_cfg->in_reset_reload = 0;
6907                         ipr_fail_all_ops(ioa_cfg);
6908                         wake_up_all(&ioa_cfg->reset_wait_q);
6909
6910                         spin_unlock_irq(ioa_cfg->host->host_lock);
6911                         scsi_unblock_requests(ioa_cfg->host);
6912                         spin_lock_irq(ioa_cfg->host->host_lock);
6913                         return;
6914                 } else {
6915                         ioa_cfg->in_ioa_bringdown = 1;
6916                         shutdown_type = IPR_SHUTDOWN_NONE;
6917                 }
6918         }
6919
6920         _ipr_initiate_ioa_reset(ioa_cfg, ipr_reset_shutdown_ioa,
6921                                 shutdown_type);
6922 }
6923
6924 /**
6925  * ipr_reset_freeze - Hold off all I/O activity
6926  * @ipr_cmd:    ipr command struct
6927  *
6928  * Description: If the PCI slot is frozen, hold off all I/O
6929  * activity; then, as soon as the slot is available again,
6930  * initiate an adapter reset.
6931  */
6932 static int ipr_reset_freeze(struct ipr_cmnd *ipr_cmd)
6933 {
6934         /* Disallow new interrupts, avoid loop */
6935         ipr_cmd->ioa_cfg->allow_interrupts = 0;
6936         list_add_tail(&ipr_cmd->queue, &ipr_cmd->ioa_cfg->pending_q);
6937         ipr_cmd->done = ipr_reset_ioa_job;
6938         return IPR_RC_JOB_RETURN;
6939 }
6940
6941 /**
6942  * ipr_pci_frozen - Called when slot has experienced a PCI bus error.
6943  * @pdev:       PCI device struct
6944  *
6945  * Description: This routine is called to tell us that the PCI bus
6946  * is down. Can't do anything here, except put the device driver
6947  * into a holding pattern, waiting for the PCI bus to come back.
6948  */
6949 static void ipr_pci_frozen(struct pci_dev *pdev)
6950 {
6951         unsigned long flags = 0;
6952         struct ipr_ioa_cfg *ioa_cfg = pci_get_drvdata(pdev);
6953
6954         spin_lock_irqsave(ioa_cfg->host->host_lock, flags);
6955         _ipr_initiate_ioa_reset(ioa_cfg, ipr_reset_freeze, IPR_SHUTDOWN_NONE);
6956         spin_unlock_irqrestore(ioa_cfg->host->host_lock, flags);
6957 }
6958
6959 /**
6960  * ipr_pci_slot_reset - Called when PCI slot has been reset.
6961  * @pdev:       PCI device struct
6962  *
6963  * Description: This routine is called by the pci error recovery
6964  * code after the PCI slot has been reset, just before we
6965  * should resume normal operations.
6966  */
6967 static pci_ers_result_t ipr_pci_slot_reset(struct pci_dev *pdev)
6968 {
6969         unsigned long flags = 0;
6970         struct ipr_ioa_cfg *ioa_cfg = pci_get_drvdata(pdev);
6971
6972         spin_lock_irqsave(ioa_cfg->host->host_lock, flags);
6973         if (ioa_cfg->needs_warm_reset)
6974                 ipr_initiate_ioa_reset(ioa_cfg, IPR_SHUTDOWN_NONE);
6975         else
6976                 _ipr_initiate_ioa_reset(ioa_cfg, ipr_reset_restore_cfg_space,
6977                                         IPR_SHUTDOWN_NONE);
6978         spin_unlock_irqrestore(ioa_cfg->host->host_lock, flags);
6979         return PCI_ERS_RESULT_RECOVERED;
6980 }
6981
6982 /**
6983  * ipr_pci_perm_failure - Called when PCI slot is dead for good.
6984  * @pdev:       PCI device struct
6985  *
6986  * Description: This routine is called when the PCI bus has
6987  * permanently failed.
6988  */
6989 static void ipr_pci_perm_failure(struct pci_dev *pdev)
6990 {
6991         unsigned long flags = 0;
6992         struct ipr_ioa_cfg *ioa_cfg = pci_get_drvdata(pdev);
6993
6994         spin_lock_irqsave(ioa_cfg->host->host_lock, flags);
6995         if (ioa_cfg->sdt_state == WAIT_FOR_DUMP)
6996                 ioa_cfg->sdt_state = ABORT_DUMP;
6997         ioa_cfg->reset_retries = IPR_NUM_RESET_RELOAD_RETRIES;
6998         ioa_cfg->in_ioa_bringdown = 1;
6999         ipr_initiate_ioa_reset(ioa_cfg, IPR_SHUTDOWN_NONE);
7000         spin_unlock_irqrestore(ioa_cfg->host->host_lock, flags);
7001 }
7002
7003 /**
7004  * ipr_pci_error_detected - Called when a PCI error is detected.
7005  * @pdev:       PCI device struct
7006  * @state:      PCI channel state
7007  *
7008  * Description: Called when a PCI error is detected.
7009  *
7010  * Return value:
7011  *      PCI_ERS_RESULT_NEED_RESET or PCI_ERS_RESULT_DISCONNECT
7012  */
7013 static pci_ers_result_t ipr_pci_error_detected(struct pci_dev *pdev,
7014                                                pci_channel_state_t state)
7015 {
7016         switch (state) {
7017         case pci_channel_io_frozen:
7018                 ipr_pci_frozen(pdev);
7019                 return PCI_ERS_RESULT_NEED_RESET;
7020         case pci_channel_io_perm_failure:
7021                 ipr_pci_perm_failure(pdev);
7022                 return PCI_ERS_RESULT_DISCONNECT;
7023                 break;
7024         default:
7025                 break;
7026         }
7027         return PCI_ERS_RESULT_NEED_RESET;
7028 }
7029
7030 /**
7031  * ipr_probe_ioa_part2 - Initializes IOAs found in ipr_probe_ioa(..)
7032  * @ioa_cfg:    ioa cfg struct
7033  *
7034  * Description: This is the second phase of adapter intialization
7035  * This function takes care of initilizing the adapter to the point
7036  * where it can accept new commands.
7037
7038  * Return value:
7039  *      0 on success / -EIO on failure
7040  **/
7041 static int __devinit ipr_probe_ioa_part2(struct ipr_ioa_cfg *ioa_cfg)
7042 {
7043         int rc = 0;
7044         unsigned long host_lock_flags = 0;
7045
7046         ENTER;
7047         spin_lock_irqsave(ioa_cfg->host->host_lock, host_lock_flags);
7048         dev_dbg(&ioa_cfg->pdev->dev, "ioa_cfg adx: 0x%p\n", ioa_cfg);
7049         if (ioa_cfg->needs_hard_reset) {
7050                 ioa_cfg->needs_hard_reset = 0;
7051                 ipr_initiate_ioa_reset(ioa_cfg, IPR_SHUTDOWN_NONE);
7052         } else
7053                 _ipr_initiate_ioa_reset(ioa_cfg, ipr_reset_enable_ioa,
7054                                         IPR_SHUTDOWN_NONE);
7055
7056         spin_unlock_irqrestore(ioa_cfg->host->host_lock, host_lock_flags);
7057         wait_event(ioa_cfg->reset_wait_q, !ioa_cfg->in_reset_reload);
7058         spin_lock_irqsave(ioa_cfg->host->host_lock, host_lock_flags);
7059
7060         if (ioa_cfg->ioa_is_dead) {
7061                 rc = -EIO;
7062         } else if (ipr_invalid_adapter(ioa_cfg)) {
7063                 if (!ipr_testmode)
7064                         rc = -EIO;
7065
7066                 dev_err(&ioa_cfg->pdev->dev,
7067                         "Adapter not supported in this hardware configuration.\n");
7068         }
7069
7070         spin_unlock_irqrestore(ioa_cfg->host->host_lock, host_lock_flags);
7071
7072         LEAVE;
7073         return rc;
7074 }
7075
7076 /**
7077  * ipr_free_cmd_blks - Frees command blocks allocated for an adapter
7078  * @ioa_cfg:    ioa config struct
7079  *
7080  * Return value:
7081  *      none
7082  **/
7083 static void ipr_free_cmd_blks(struct ipr_ioa_cfg *ioa_cfg)
7084 {
7085         int i;
7086
7087         for (i = 0; i < IPR_NUM_CMD_BLKS; i++) {
7088                 if (ioa_cfg->ipr_cmnd_list[i])
7089                         pci_pool_free(ioa_cfg->ipr_cmd_pool,
7090                                       ioa_cfg->ipr_cmnd_list[i],
7091                                       ioa_cfg->ipr_cmnd_list_dma[i]);
7092
7093                 ioa_cfg->ipr_cmnd_list[i] = NULL;
7094         }
7095
7096         if (ioa_cfg->ipr_cmd_pool)
7097                 pci_pool_destroy (ioa_cfg->ipr_cmd_pool);
7098
7099         ioa_cfg->ipr_cmd_pool = NULL;
7100 }
7101
7102 /**
7103  * ipr_free_mem - Frees memory allocated for an adapter
7104  * @ioa_cfg:    ioa cfg struct
7105  *
7106  * Return value:
7107  *      nothing
7108  **/
7109 static void ipr_free_mem(struct ipr_ioa_cfg *ioa_cfg)
7110 {
7111         int i;
7112
7113         kfree(ioa_cfg->res_entries);
7114         pci_free_consistent(ioa_cfg->pdev, sizeof(struct ipr_misc_cbs),
7115                             ioa_cfg->vpd_cbs, ioa_cfg->vpd_cbs_dma);
7116         ipr_free_cmd_blks(ioa_cfg);
7117         pci_free_consistent(ioa_cfg->pdev, sizeof(u32) * IPR_NUM_CMD_BLKS,
7118                             ioa_cfg->host_rrq, ioa_cfg->host_rrq_dma);
7119         pci_free_consistent(ioa_cfg->pdev, sizeof(struct ipr_config_table),
7120                             ioa_cfg->cfg_table,
7121                             ioa_cfg->cfg_table_dma);
7122
7123         for (i = 0; i < IPR_NUM_HCAMS; i++) {
7124                 pci_free_consistent(ioa_cfg->pdev,
7125                                     sizeof(struct ipr_hostrcb),
7126                                     ioa_cfg->hostrcb[i],
7127                                     ioa_cfg->hostrcb_dma[i]);
7128         }
7129
7130         ipr_free_dump(ioa_cfg);
7131         kfree(ioa_cfg->trace);
7132 }
7133
7134 /**
7135  * ipr_free_all_resources - Free all allocated resources for an adapter.
7136  * @ipr_cmd:    ipr command struct
7137  *
7138  * This function frees all allocated resources for the
7139  * specified adapter.
7140  *
7141  * Return value:
7142  *      none
7143  **/
7144 static void ipr_free_all_resources(struct ipr_ioa_cfg *ioa_cfg)
7145 {
7146         struct pci_dev *pdev = ioa_cfg->pdev;
7147
7148         ENTER;
7149         free_irq(pdev->irq, ioa_cfg);
7150         iounmap(ioa_cfg->hdw_dma_regs);
7151         pci_release_regions(pdev);
7152         ipr_free_mem(ioa_cfg);
7153         scsi_host_put(ioa_cfg->host);
7154         pci_disable_device(pdev);
7155         LEAVE;
7156 }
7157
7158 /**
7159  * ipr_alloc_cmd_blks - Allocate command blocks for an adapter
7160  * @ioa_cfg:    ioa config struct
7161  *
7162  * Return value:
7163  *      0 on success / -ENOMEM on allocation failure
7164  **/
7165 static int __devinit ipr_alloc_cmd_blks(struct ipr_ioa_cfg *ioa_cfg)
7166 {
7167         struct ipr_cmnd *ipr_cmd;
7168         struct ipr_ioarcb *ioarcb;
7169         dma_addr_t dma_addr;
7170         int i;
7171
7172         ioa_cfg->ipr_cmd_pool = pci_pool_create (IPR_NAME, ioa_cfg->pdev,
7173                                                  sizeof(struct ipr_cmnd), 8, 0);
7174
7175         if (!ioa_cfg->ipr_cmd_pool)
7176                 return -ENOMEM;
7177
7178         for (i = 0; i < IPR_NUM_CMD_BLKS; i++) {
7179                 ipr_cmd = pci_pool_alloc (ioa_cfg->ipr_cmd_pool, GFP_KERNEL, &dma_addr);
7180
7181                 if (!ipr_cmd) {
7182                         ipr_free_cmd_blks(ioa_cfg);
7183                         return -ENOMEM;
7184                 }
7185
7186                 memset(ipr_cmd, 0, sizeof(*ipr_cmd));
7187                 ioa_cfg->ipr_cmnd_list[i] = ipr_cmd;
7188                 ioa_cfg->ipr_cmnd_list_dma[i] = dma_addr;
7189
7190                 ioarcb = &ipr_cmd->ioarcb;
7191                 ioarcb->ioarcb_host_pci_addr = cpu_to_be32(dma_addr);
7192                 ioarcb->host_response_handle = cpu_to_be32(i << 2);
7193                 ioarcb->write_ioadl_addr =
7194                         cpu_to_be32(dma_addr + offsetof(struct ipr_cmnd, ioadl));
7195                 ioarcb->read_ioadl_addr = ioarcb->write_ioadl_addr;
7196                 ioarcb->ioasa_host_pci_addr =
7197                         cpu_to_be32(dma_addr + offsetof(struct ipr_cmnd, ioasa));
7198                 ioarcb->ioasa_len = cpu_to_be16(sizeof(struct ipr_ioasa));
7199                 ipr_cmd->cmd_index = i;
7200                 ipr_cmd->ioa_cfg = ioa_cfg;
7201                 ipr_cmd->sense_buffer_dma = dma_addr +
7202                         offsetof(struct ipr_cmnd, sense_buffer);
7203
7204                 list_add_tail(&ipr_cmd->queue, &ioa_cfg->free_q);
7205         }
7206
7207         return 0;
7208 }
7209
7210 /**
7211  * ipr_alloc_mem - Allocate memory for an adapter
7212  * @ioa_cfg:    ioa config struct
7213  *
7214  * Return value:
7215  *      0 on success / non-zero for error
7216  **/
7217 static int __devinit ipr_alloc_mem(struct ipr_ioa_cfg *ioa_cfg)
7218 {
7219         struct pci_dev *pdev = ioa_cfg->pdev;
7220         int i, rc = -ENOMEM;
7221
7222         ENTER;
7223         ioa_cfg->res_entries = kzalloc(sizeof(struct ipr_resource_entry) *
7224                                        IPR_MAX_PHYSICAL_DEVS, GFP_KERNEL);
7225
7226         if (!ioa_cfg->res_entries)
7227                 goto out;
7228
7229         for (i = 0; i < IPR_MAX_PHYSICAL_DEVS; i++)
7230                 list_add_tail(&ioa_cfg->res_entries[i].queue, &ioa_cfg->free_res_q);
7231
7232         ioa_cfg->vpd_cbs = pci_alloc_consistent(ioa_cfg->pdev,
7233                                                 sizeof(struct ipr_misc_cbs),
7234                                                 &ioa_cfg->vpd_cbs_dma);
7235
7236         if (!ioa_cfg->vpd_cbs)
7237                 goto out_free_res_entries;
7238
7239         if (ipr_alloc_cmd_blks(ioa_cfg))
7240                 goto out_free_vpd_cbs;
7241
7242         ioa_cfg->host_rrq = pci_alloc_consistent(ioa_cfg->pdev,
7243                                                  sizeof(u32) * IPR_NUM_CMD_BLKS,
7244                                                  &ioa_cfg->host_rrq_dma);
7245
7246         if (!ioa_cfg->host_rrq)
7247                 goto out_ipr_free_cmd_blocks;
7248
7249         ioa_cfg->cfg_table = pci_alloc_consistent(ioa_cfg->pdev,
7250                                                   sizeof(struct ipr_config_table),
7251                                                   &ioa_cfg->cfg_table_dma);
7252
7253         if (!ioa_cfg->cfg_table)
7254                 goto out_free_host_rrq;
7255
7256         for (i = 0; i < IPR_NUM_HCAMS; i++) {
7257                 ioa_cfg->hostrcb[i] = pci_alloc_consistent(ioa_cfg->pdev,
7258                                                            sizeof(struct ipr_hostrcb),
7259                                                            &ioa_cfg->hostrcb_dma[i]);
7260
7261                 if (!ioa_cfg->hostrcb[i])
7262                         goto out_free_hostrcb_dma;
7263
7264                 ioa_cfg->hostrcb[i]->hostrcb_dma =
7265                         ioa_cfg->hostrcb_dma[i] + offsetof(struct ipr_hostrcb, hcam);
7266                 ioa_cfg->hostrcb[i]->ioa_cfg = ioa_cfg;
7267                 list_add_tail(&ioa_cfg->hostrcb[i]->queue, &ioa_cfg->hostrcb_free_q);
7268         }
7269
7270         ioa_cfg->trace = kzalloc(sizeof(struct ipr_trace_entry) *
7271                                  IPR_NUM_TRACE_ENTRIES, GFP_KERNEL);
7272
7273         if (!ioa_cfg->trace)
7274                 goto out_free_hostrcb_dma;
7275
7276         rc = 0;
7277 out:
7278         LEAVE;
7279         return rc;
7280
7281 out_free_hostrcb_dma:
7282         while (i-- > 0) {
7283                 pci_free_consistent(pdev, sizeof(struct ipr_hostrcb),
7284                                     ioa_cfg->hostrcb[i],
7285                                     ioa_cfg->hostrcb_dma[i]);
7286         }
7287         pci_free_consistent(pdev, sizeof(struct ipr_config_table),
7288                             ioa_cfg->cfg_table, ioa_cfg->cfg_table_dma);
7289 out_free_host_rrq:
7290         pci_free_consistent(pdev, sizeof(u32) * IPR_NUM_CMD_BLKS,
7291                             ioa_cfg->host_rrq, ioa_cfg->host_rrq_dma);
7292 out_ipr_free_cmd_blocks:
7293         ipr_free_cmd_blks(ioa_cfg);
7294 out_free_vpd_cbs:
7295         pci_free_consistent(pdev, sizeof(struct ipr_misc_cbs),
7296                             ioa_cfg->vpd_cbs, ioa_cfg->vpd_cbs_dma);
7297 out_free_res_entries:
7298         kfree(ioa_cfg->res_entries);
7299         goto out;
7300 }
7301
7302 /**
7303  * ipr_initialize_bus_attr - Initialize SCSI bus attributes to default values
7304  * @ioa_cfg:    ioa config struct
7305  *
7306  * Return value:
7307  *      none
7308  **/
7309 static void __devinit ipr_initialize_bus_attr(struct ipr_ioa_cfg *ioa_cfg)
7310 {
7311         int i;
7312
7313         for (i = 0; i < IPR_MAX_NUM_BUSES; i++) {
7314                 ioa_cfg->bus_attr[i].bus = i;
7315                 ioa_cfg->bus_attr[i].qas_enabled = 0;
7316                 ioa_cfg->bus_attr[i].bus_width = IPR_DEFAULT_BUS_WIDTH;
7317                 if (ipr_max_speed < ARRAY_SIZE(ipr_max_bus_speeds))
7318                         ioa_cfg->bus_attr[i].max_xfer_rate = ipr_max_bus_speeds[ipr_max_speed];
7319                 else
7320                         ioa_cfg->bus_attr[i].max_xfer_rate = IPR_U160_SCSI_RATE;
7321         }
7322 }
7323
7324 /**
7325  * ipr_init_ioa_cfg - Initialize IOA config struct
7326  * @ioa_cfg:    ioa config struct
7327  * @host:               scsi host struct
7328  * @pdev:               PCI dev struct
7329  *
7330  * Return value:
7331  *      none
7332  **/
7333 static void __devinit ipr_init_ioa_cfg(struct ipr_ioa_cfg *ioa_cfg,
7334                                        struct Scsi_Host *host, struct pci_dev *pdev)
7335 {
7336         const struct ipr_interrupt_offsets *p;
7337         struct ipr_interrupts *t;
7338         void __iomem *base;
7339
7340         ioa_cfg->host = host;
7341         ioa_cfg->pdev = pdev;
7342         ioa_cfg->log_level = ipr_log_level;
7343         ioa_cfg->doorbell = IPR_DOORBELL;
7344         sprintf(ioa_cfg->eye_catcher, IPR_EYECATCHER);
7345         sprintf(ioa_cfg->trace_start, IPR_TRACE_START_LABEL);
7346         sprintf(ioa_cfg->ipr_free_label, IPR_FREEQ_LABEL);
7347         sprintf(ioa_cfg->ipr_pending_label, IPR_PENDQ_LABEL);
7348         sprintf(ioa_cfg->cfg_table_start, IPR_CFG_TBL_START);
7349         sprintf(ioa_cfg->resource_table_label, IPR_RES_TABLE_LABEL);
7350         sprintf(ioa_cfg->ipr_hcam_label, IPR_HCAM_LABEL);
7351         sprintf(ioa_cfg->ipr_cmd_label, IPR_CMD_LABEL);
7352
7353         INIT_LIST_HEAD(&ioa_cfg->free_q);
7354         INIT_LIST_HEAD(&ioa_cfg->pending_q);
7355         INIT_LIST_HEAD(&ioa_cfg->hostrcb_free_q);
7356         INIT_LIST_HEAD(&ioa_cfg->hostrcb_pending_q);
7357         INIT_LIST_HEAD(&ioa_cfg->free_res_q);
7358         INIT_LIST_HEAD(&ioa_cfg->used_res_q);
7359         INIT_WORK(&ioa_cfg->work_q, ipr_worker_thread);
7360         init_waitqueue_head(&ioa_cfg->reset_wait_q);
7361         ioa_cfg->sdt_state = INACTIVE;
7362         if (ipr_enable_cache)
7363                 ioa_cfg->cache_state = CACHE_ENABLED;
7364         else
7365                 ioa_cfg->cache_state = CACHE_DISABLED;
7366
7367         ipr_initialize_bus_attr(ioa_cfg);
7368
7369         host->max_id = IPR_MAX_NUM_TARGETS_PER_BUS;
7370         host->max_lun = IPR_MAX_NUM_LUNS_PER_TARGET;
7371         host->max_channel = IPR_MAX_BUS_TO_SCAN;
7372         host->unique_id = host->host_no;
7373         host->max_cmd_len = IPR_MAX_CDB_LEN;
7374         pci_set_drvdata(pdev, ioa_cfg);
7375
7376         p = &ioa_cfg->chip_cfg->regs;
7377         t = &ioa_cfg->regs;
7378         base = ioa_cfg->hdw_dma_regs;
7379
7380         t->set_interrupt_mask_reg = base + p->set_interrupt_mask_reg;
7381         t->clr_interrupt_mask_reg = base + p->clr_interrupt_mask_reg;
7382         t->sense_interrupt_mask_reg = base + p->sense_interrupt_mask_reg;
7383         t->clr_interrupt_reg = base + p->clr_interrupt_reg;
7384         t->sense_interrupt_reg = base + p->sense_interrupt_reg;
7385         t->ioarrin_reg = base + p->ioarrin_reg;
7386         t->sense_uproc_interrupt_reg = base + p->sense_uproc_interrupt_reg;
7387         t->set_uproc_interrupt_reg = base + p->set_uproc_interrupt_reg;
7388         t->clr_uproc_interrupt_reg = base + p->clr_uproc_interrupt_reg;
7389 }
7390
7391 /**
7392  * ipr_get_chip_cfg - Find adapter chip configuration
7393  * @dev_id:             PCI device id struct
7394  *
7395  * Return value:
7396  *      ptr to chip config on success / NULL on failure
7397  **/
7398 static const struct ipr_chip_cfg_t * __devinit
7399 ipr_get_chip_cfg(const struct pci_device_id *dev_id)
7400 {
7401         int i;
7402
7403         for (i = 0; i < ARRAY_SIZE(ipr_chip); i++)
7404                 if (ipr_chip[i].vendor == dev_id->vendor &&
7405                     ipr_chip[i].device == dev_id->device)
7406                         return ipr_chip[i].cfg;
7407         return NULL;
7408 }
7409
7410 /**
7411  * ipr_probe_ioa - Allocates memory and does first stage of initialization
7412  * @pdev:               PCI device struct
7413  * @dev_id:             PCI device id struct
7414  *
7415  * Return value:
7416  *      0 on success / non-zero on failure
7417  **/
7418 static int __devinit ipr_probe_ioa(struct pci_dev *pdev,
7419                                    const struct pci_device_id *dev_id)
7420 {
7421         struct ipr_ioa_cfg *ioa_cfg;
7422         struct Scsi_Host *host;
7423         unsigned long ipr_regs_pci;
7424         void __iomem *ipr_regs;
7425         int rc = PCIBIOS_SUCCESSFUL;
7426         volatile u32 mask, uproc, interrupts;
7427
7428         ENTER;
7429
7430         if ((rc = pci_enable_device(pdev))) {
7431                 dev_err(&pdev->dev, "Cannot enable adapter\n");
7432                 goto out;
7433         }
7434
7435         dev_info(&pdev->dev, "Found IOA with IRQ: %d\n", pdev->irq);
7436
7437         host = scsi_host_alloc(&driver_template, sizeof(*ioa_cfg));
7438
7439         if (!host) {
7440                 dev_err(&pdev->dev, "call to scsi_host_alloc failed!\n");
7441                 rc = -ENOMEM;
7442                 goto out_disable;
7443         }
7444
7445         ioa_cfg = (struct ipr_ioa_cfg *)host->hostdata;
7446         memset(ioa_cfg, 0, sizeof(struct ipr_ioa_cfg));
7447         ata_host_init(&ioa_cfg->ata_host, &pdev->dev,
7448                       sata_port_info.flags, &ipr_sata_ops);
7449
7450         ioa_cfg->chip_cfg = ipr_get_chip_cfg(dev_id);
7451
7452         if (!ioa_cfg->chip_cfg) {
7453                 dev_err(&pdev->dev, "Unknown adapter chipset 0x%04X 0x%04X\n",
7454                         dev_id->vendor, dev_id->device);
7455                 goto out_scsi_host_put;
7456         }
7457
7458         if (ipr_transop_timeout)
7459                 ioa_cfg->transop_timeout = ipr_transop_timeout;
7460         else if (dev_id->driver_data & IPR_USE_LONG_TRANSOP_TIMEOUT)
7461                 ioa_cfg->transop_timeout = IPR_LONG_OPERATIONAL_TIMEOUT;
7462         else
7463                 ioa_cfg->transop_timeout = IPR_OPERATIONAL_TIMEOUT;
7464
7465         ioa_cfg->revid = pdev->revision;
7466
7467         ipr_regs_pci = pci_resource_start(pdev, 0);
7468
7469         rc = pci_request_regions(pdev, IPR_NAME);
7470         if (rc < 0) {
7471                 dev_err(&pdev->dev,
7472                         "Couldn't register memory range of registers\n");
7473                 goto out_scsi_host_put;
7474         }
7475
7476         ipr_regs = pci_ioremap_bar(pdev, 0);
7477
7478         if (!ipr_regs) {
7479                 dev_err(&pdev->dev,
7480                         "Couldn't map memory range of registers\n");
7481                 rc = -ENOMEM;
7482                 goto out_release_regions;
7483         }
7484
7485         ioa_cfg->hdw_dma_regs = ipr_regs;
7486         ioa_cfg->hdw_dma_regs_pci = ipr_regs_pci;
7487         ioa_cfg->ioa_mailbox = ioa_cfg->chip_cfg->mailbox + ipr_regs;
7488
7489         ipr_init_ioa_cfg(ioa_cfg, host, pdev);
7490
7491         pci_set_master(pdev);
7492
7493         rc = pci_set_dma_mask(pdev, DMA_32BIT_MASK);
7494         if (rc < 0) {
7495                 dev_err(&pdev->dev, "Failed to set PCI DMA mask\n");
7496                 goto cleanup_nomem;
7497         }
7498
7499         rc = pci_write_config_byte(pdev, PCI_CACHE_LINE_SIZE,
7500                                    ioa_cfg->chip_cfg->cache_line_size);
7501
7502         if (rc != PCIBIOS_SUCCESSFUL) {
7503                 dev_err(&pdev->dev, "Write of cache line size failed\n");
7504                 rc = -EIO;
7505                 goto cleanup_nomem;
7506         }
7507
7508         /* Save away PCI config space for use following IOA reset */
7509         rc = pci_save_state(pdev);
7510
7511         if (rc != PCIBIOS_SUCCESSFUL) {
7512                 dev_err(&pdev->dev, "Failed to save PCI config space\n");
7513                 rc = -EIO;
7514                 goto cleanup_nomem;
7515         }
7516
7517         if ((rc = ipr_save_pcix_cmd_reg(ioa_cfg)))
7518                 goto cleanup_nomem;
7519
7520         if ((rc = ipr_set_pcix_cmd_reg(ioa_cfg)))
7521                 goto cleanup_nomem;
7522
7523         rc = ipr_alloc_mem(ioa_cfg);
7524         if (rc < 0) {
7525                 dev_err(&pdev->dev,
7526                         "Couldn't allocate enough memory for device driver!\n");
7527                 goto cleanup_nomem;
7528         }
7529
7530         /*
7531          * If HRRQ updated interrupt is not masked, or reset alert is set,
7532          * the card is in an unknown state and needs a hard reset
7533          */
7534         mask = readl(ioa_cfg->regs.sense_interrupt_mask_reg);
7535         interrupts = readl(ioa_cfg->regs.sense_interrupt_reg);
7536         uproc = readl(ioa_cfg->regs.sense_uproc_interrupt_reg);
7537         if ((mask & IPR_PCII_HRRQ_UPDATED) == 0 || (uproc & IPR_UPROCI_RESET_ALERT))
7538                 ioa_cfg->needs_hard_reset = 1;
7539         if (interrupts & IPR_PCII_ERROR_INTERRUPTS)
7540                 ioa_cfg->needs_hard_reset = 1;
7541         if (interrupts & IPR_PCII_IOA_UNIT_CHECKED)
7542                 ioa_cfg->ioa_unit_checked = 1;
7543
7544         ipr_mask_and_clear_interrupts(ioa_cfg, ~IPR_PCII_IOA_TRANS_TO_OPER);
7545         rc = request_irq(pdev->irq, ipr_isr, IRQF_SHARED, IPR_NAME, ioa_cfg);
7546
7547         if (rc) {
7548                 dev_err(&pdev->dev, "Couldn't register IRQ %d! rc=%d\n",
7549                         pdev->irq, rc);
7550                 goto cleanup_nolog;
7551         }
7552
7553         if ((dev_id->driver_data & IPR_USE_PCI_WARM_RESET) ||
7554             (dev_id->device == PCI_DEVICE_ID_IBM_OBSIDIAN_E && !ioa_cfg->revid)) {
7555                 ioa_cfg->needs_warm_reset = 1;
7556                 ioa_cfg->reset = ipr_reset_slot_reset;
7557         } else
7558                 ioa_cfg->reset = ipr_reset_start_bist;
7559
7560         spin_lock(&ipr_driver_lock);
7561         list_add_tail(&ioa_cfg->queue, &ipr_ioa_head);
7562         spin_unlock(&ipr_driver_lock);
7563
7564         LEAVE;
7565 out:
7566         return rc;
7567
7568 cleanup_nolog:
7569         ipr_free_mem(ioa_cfg);
7570 cleanup_nomem:
7571         iounmap(ipr_regs);
7572 out_release_regions:
7573         pci_release_regions(pdev);
7574 out_scsi_host_put:
7575         scsi_host_put(host);
7576 out_disable:
7577         pci_disable_device(pdev);
7578         goto out;
7579 }
7580
7581 /**
7582  * ipr_scan_vsets - Scans for VSET devices
7583  * @ioa_cfg:    ioa config struct
7584  *
7585  * Description: Since the VSET resources do not follow SAM in that we can have
7586  * sparse LUNs with no LUN 0, we have to scan for these ourselves.
7587  *
7588  * Return value:
7589  *      none
7590  **/
7591 static void ipr_scan_vsets(struct ipr_ioa_cfg *ioa_cfg)
7592 {
7593         int target, lun;
7594
7595         for (target = 0; target < IPR_MAX_NUM_TARGETS_PER_BUS; target++)
7596                 for (lun = 0; lun < IPR_MAX_NUM_VSET_LUNS_PER_TARGET; lun++ )
7597                         scsi_add_device(ioa_cfg->host, IPR_VSET_BUS, target, lun);
7598 }
7599
7600 /**
7601  * ipr_initiate_ioa_bringdown - Bring down an adapter
7602  * @ioa_cfg:            ioa config struct
7603  * @shutdown_type:      shutdown type
7604  *
7605  * Description: This function will initiate bringing down the adapter.
7606  * This consists of issuing an IOA shutdown to the adapter
7607  * to flush the cache, and running BIST.
7608  * If the caller needs to wait on the completion of the reset,
7609  * the caller must sleep on the reset_wait_q.
7610  *
7611  * Return value:
7612  *      none
7613  **/
7614 static void ipr_initiate_ioa_bringdown(struct ipr_ioa_cfg *ioa_cfg,
7615                                        enum ipr_shutdown_type shutdown_type)
7616 {
7617         ENTER;
7618         if (ioa_cfg->sdt_state == WAIT_FOR_DUMP)
7619                 ioa_cfg->sdt_state = ABORT_DUMP;
7620         ioa_cfg->reset_retries = 0;
7621         ioa_cfg->in_ioa_bringdown = 1;
7622         ipr_initiate_ioa_reset(ioa_cfg, shutdown_type);
7623         LEAVE;
7624 }
7625
7626 /**
7627  * __ipr_remove - Remove a single adapter
7628  * @pdev:       pci device struct
7629  *
7630  * Adapter hot plug remove entry point.
7631  *
7632  * Return value:
7633  *      none
7634  **/
7635 static void __ipr_remove(struct pci_dev *pdev)
7636 {
7637         unsigned long host_lock_flags = 0;
7638         struct ipr_ioa_cfg *ioa_cfg = pci_get_drvdata(pdev);
7639         ENTER;
7640
7641         spin_lock_irqsave(ioa_cfg->host->host_lock, host_lock_flags);
7642         while(ioa_cfg->in_reset_reload) {
7643                 spin_unlock_irqrestore(ioa_cfg->host->host_lock, host_lock_flags);
7644                 wait_event(ioa_cfg->reset_wait_q, !ioa_cfg->in_reset_reload);
7645                 spin_lock_irqsave(ioa_cfg->host->host_lock, host_lock_flags);
7646         }
7647
7648         ipr_initiate_ioa_bringdown(ioa_cfg, IPR_SHUTDOWN_NORMAL);
7649
7650         spin_unlock_irqrestore(ioa_cfg->host->host_lock, host_lock_flags);
7651         wait_event(ioa_cfg->reset_wait_q, !ioa_cfg->in_reset_reload);
7652         flush_scheduled_work();
7653         spin_lock_irqsave(ioa_cfg->host->host_lock, host_lock_flags);
7654
7655         spin_lock(&ipr_driver_lock);
7656         list_del(&ioa_cfg->queue);
7657         spin_unlock(&ipr_driver_lock);
7658
7659         if (ioa_cfg->sdt_state == ABORT_DUMP)
7660                 ioa_cfg->sdt_state = WAIT_FOR_DUMP;
7661         spin_unlock_irqrestore(ioa_cfg->host->host_lock, host_lock_flags);
7662
7663         ipr_free_all_resources(ioa_cfg);
7664
7665         LEAVE;
7666 }
7667
7668 /**
7669  * ipr_remove - IOA hot plug remove entry point
7670  * @pdev:       pci device struct
7671  *
7672  * Adapter hot plug remove entry point.
7673  *
7674  * Return value:
7675  *      none
7676  **/
7677 static void ipr_remove(struct pci_dev *pdev)
7678 {
7679         struct ipr_ioa_cfg *ioa_cfg = pci_get_drvdata(pdev);
7680
7681         ENTER;
7682
7683         ipr_remove_trace_file(&ioa_cfg->host->shost_dev.kobj,
7684                               &ipr_trace_attr);
7685         ipr_remove_dump_file(&ioa_cfg->host->shost_dev.kobj,
7686                              &ipr_dump_attr);
7687         scsi_remove_host(ioa_cfg->host);
7688
7689         __ipr_remove(pdev);
7690
7691         LEAVE;
7692 }
7693
7694 /**
7695  * ipr_probe - Adapter hot plug add entry point
7696  *
7697  * Return value:
7698  *      0 on success / non-zero on failure
7699  **/
7700 static int __devinit ipr_probe(struct pci_dev *pdev,
7701                                const struct pci_device_id *dev_id)
7702 {
7703         struct ipr_ioa_cfg *ioa_cfg;
7704         int rc;
7705
7706         rc = ipr_probe_ioa(pdev, dev_id);
7707
7708         if (rc)
7709                 return rc;
7710
7711         ioa_cfg = pci_get_drvdata(pdev);
7712         rc = ipr_probe_ioa_part2(ioa_cfg);
7713
7714         if (rc) {
7715                 __ipr_remove(pdev);
7716                 return rc;
7717         }
7718
7719         rc = scsi_add_host(ioa_cfg->host, &pdev->dev);
7720
7721         if (rc) {
7722                 __ipr_remove(pdev);
7723                 return rc;
7724         }
7725
7726         rc = ipr_create_trace_file(&ioa_cfg->host->shost_dev.kobj,
7727                                    &ipr_trace_attr);
7728
7729         if (rc) {
7730                 scsi_remove_host(ioa_cfg->host);
7731                 __ipr_remove(pdev);
7732                 return rc;
7733         }
7734
7735         rc = ipr_create_dump_file(&ioa_cfg->host->shost_dev.kobj,
7736                                    &ipr_dump_attr);
7737
7738         if (rc) {
7739                 ipr_remove_trace_file(&ioa_cfg->host->shost_dev.kobj,
7740                                       &ipr_trace_attr);
7741                 scsi_remove_host(ioa_cfg->host);
7742                 __ipr_remove(pdev);
7743                 return rc;
7744         }
7745
7746         scsi_scan_host(ioa_cfg->host);
7747         ipr_scan_vsets(ioa_cfg);
7748         scsi_add_device(ioa_cfg->host, IPR_IOA_BUS, IPR_IOA_TARGET, IPR_IOA_LUN);
7749         ioa_cfg->allow_ml_add_del = 1;
7750         ioa_cfg->host->max_channel = IPR_VSET_BUS;
7751         schedule_work(&ioa_cfg->work_q);
7752         return 0;
7753 }
7754
7755 /**
7756  * ipr_shutdown - Shutdown handler.
7757  * @pdev:       pci device struct
7758  *
7759  * This function is invoked upon system shutdown/reboot. It will issue
7760  * an adapter shutdown to the adapter to flush the write cache.
7761  *
7762  * Return value:
7763  *      none
7764  **/
7765 static void ipr_shutdown(struct pci_dev *pdev)
7766 {
7767         struct ipr_ioa_cfg *ioa_cfg = pci_get_drvdata(pdev);
7768         unsigned long lock_flags = 0;
7769
7770         spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
7771         while(ioa_cfg->in_reset_reload) {
7772                 spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
7773                 wait_event(ioa_cfg->reset_wait_q, !ioa_cfg->in_reset_reload);
7774                 spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags);
7775         }
7776
7777         ipr_initiate_ioa_bringdown(ioa_cfg, IPR_SHUTDOWN_NORMAL);
7778         spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags);
7779         wait_event(ioa_cfg->reset_wait_q, !ioa_cfg->in_reset_reload);
7780 }
7781
7782 static struct pci_device_id ipr_pci_table[] __devinitdata = {
7783         { PCI_VENDOR_ID_MYLEX, PCI_DEVICE_ID_IBM_GEMSTONE,
7784                 PCI_VENDOR_ID_IBM, IPR_SUBS_DEV_ID_5702, 0, 0, 0 },
7785         { PCI_VENDOR_ID_MYLEX, PCI_DEVICE_ID_IBM_GEMSTONE,
7786                 PCI_VENDOR_ID_IBM, IPR_SUBS_DEV_ID_5703, 0, 0, 0 },
7787         { PCI_VENDOR_ID_MYLEX, PCI_DEVICE_ID_IBM_GEMSTONE,
7788                 PCI_VENDOR_ID_IBM, IPR_SUBS_DEV_ID_573D, 0, 0, 0 },
7789         { PCI_VENDOR_ID_MYLEX, PCI_DEVICE_ID_IBM_GEMSTONE,
7790                 PCI_VENDOR_ID_IBM, IPR_SUBS_DEV_ID_573E, 0, 0, 0 },
7791         { PCI_VENDOR_ID_IBM, PCI_DEVICE_ID_IBM_CITRINE,
7792                 PCI_VENDOR_ID_IBM, IPR_SUBS_DEV_ID_571B, 0, 0, 0 },
7793         { PCI_VENDOR_ID_IBM, PCI_DEVICE_ID_IBM_CITRINE,
7794                 PCI_VENDOR_ID_IBM, IPR_SUBS_DEV_ID_572E, 0, 0, 0 },
7795         { PCI_VENDOR_ID_IBM, PCI_DEVICE_ID_IBM_CITRINE,
7796                 PCI_VENDOR_ID_IBM, IPR_SUBS_DEV_ID_571A, 0, 0, 0 },
7797         { PCI_VENDOR_ID_IBM, PCI_DEVICE_ID_IBM_CITRINE,
7798                 PCI_VENDOR_ID_IBM, IPR_SUBS_DEV_ID_575B, 0, 0,
7799                 IPR_USE_LONG_TRANSOP_TIMEOUT },
7800         { PCI_VENDOR_ID_ADAPTEC2, PCI_DEVICE_ID_ADAPTEC2_OBSIDIAN,
7801               PCI_VENDOR_ID_IBM, IPR_SUBS_DEV_ID_572A, 0, 0, 0 },
7802         { PCI_VENDOR_ID_ADAPTEC2, PCI_DEVICE_ID_ADAPTEC2_OBSIDIAN,
7803               PCI_VENDOR_ID_IBM, IPR_SUBS_DEV_ID_572B, 0, 0,
7804               IPR_USE_LONG_TRANSOP_TIMEOUT },
7805         { PCI_VENDOR_ID_ADAPTEC2, PCI_DEVICE_ID_ADAPTEC2_OBSIDIAN,
7806               PCI_VENDOR_ID_IBM, IPR_SUBS_DEV_ID_575C, 0, 0,
7807               IPR_USE_LONG_TRANSOP_TIMEOUT },
7808         { PCI_VENDOR_ID_IBM, PCI_DEVICE_ID_IBM_OBSIDIAN,
7809               PCI_VENDOR_ID_IBM, IPR_SUBS_DEV_ID_572A, 0, 0, 0 },
7810         { PCI_VENDOR_ID_IBM, PCI_DEVICE_ID_IBM_OBSIDIAN,
7811               PCI_VENDOR_ID_IBM, IPR_SUBS_DEV_ID_572B, 0, 0,
7812               IPR_USE_LONG_TRANSOP_TIMEOUT},
7813         { PCI_VENDOR_ID_IBM, PCI_DEVICE_ID_IBM_OBSIDIAN,
7814               PCI_VENDOR_ID_IBM, IPR_SUBS_DEV_ID_575C, 0, 0,
7815               IPR_USE_LONG_TRANSOP_TIMEOUT },
7816         { PCI_VENDOR_ID_IBM, PCI_DEVICE_ID_IBM_OBSIDIAN_E,
7817               PCI_VENDOR_ID_IBM, IPR_SUBS_DEV_ID_574E, 0, 0,
7818               IPR_USE_LONG_TRANSOP_TIMEOUT },
7819         { PCI_VENDOR_ID_IBM, PCI_DEVICE_ID_IBM_OBSIDIAN_E,
7820               PCI_VENDOR_ID_IBM, IPR_SUBS_DEV_ID_575D, 0, 0,
7821               IPR_USE_LONG_TRANSOP_TIMEOUT },
7822         { PCI_VENDOR_ID_IBM, PCI_DEVICE_ID_IBM_OBSIDIAN_E,
7823               PCI_VENDOR_ID_IBM, IPR_SUBS_DEV_ID_57B3, 0, 0, 0 },
7824         { PCI_VENDOR_ID_IBM, PCI_DEVICE_ID_IBM_OBSIDIAN_E,
7825               PCI_VENDOR_ID_IBM, IPR_SUBS_DEV_ID_57B7, 0, 0,
7826               IPR_USE_LONG_TRANSOP_TIMEOUT | IPR_USE_PCI_WARM_RESET },
7827         { PCI_VENDOR_ID_IBM, PCI_DEVICE_ID_IBM_SNIPE,
7828                 PCI_VENDOR_ID_IBM, IPR_SUBS_DEV_ID_2780, 0, 0, 0 },
7829         { PCI_VENDOR_ID_ADAPTEC2, PCI_DEVICE_ID_ADAPTEC2_SCAMP,
7830                 PCI_VENDOR_ID_IBM, IPR_SUBS_DEV_ID_571E, 0, 0, 0 },
7831         { PCI_VENDOR_ID_ADAPTEC2, PCI_DEVICE_ID_ADAPTEC2_SCAMP,
7832                 PCI_VENDOR_ID_IBM, IPR_SUBS_DEV_ID_571F, 0, 0,
7833                 IPR_USE_LONG_TRANSOP_TIMEOUT },
7834         { PCI_VENDOR_ID_ADAPTEC2, PCI_DEVICE_ID_ADAPTEC2_SCAMP,
7835                 PCI_VENDOR_ID_IBM, IPR_SUBS_DEV_ID_572F, 0, 0,
7836                 IPR_USE_LONG_TRANSOP_TIMEOUT },
7837         { PCI_VENDOR_ID_IBM, PCI_DEVICE_ID_IBM_SCAMP_E,
7838                 PCI_VENDOR_ID_IBM, IPR_SUBS_DEV_ID_574D, 0, 0,
7839                 IPR_USE_LONG_TRANSOP_TIMEOUT },
7840         { }
7841 };
7842 MODULE_DEVICE_TABLE(pci, ipr_pci_table);
7843
7844 static struct pci_error_handlers ipr_err_handler = {
7845         .error_detected = ipr_pci_error_detected,
7846         .slot_reset = ipr_pci_slot_reset,
7847 };
7848
7849 static struct pci_driver ipr_driver = {
7850         .name = IPR_NAME,
7851         .id_table = ipr_pci_table,
7852         .probe = ipr_probe,
7853         .remove = ipr_remove,
7854         .shutdown = ipr_shutdown,
7855         .err_handler = &ipr_err_handler,
7856 };
7857
7858 /**
7859  * ipr_init - Module entry point
7860  *
7861  * Return value:
7862  *      0 on success / negative value on failure
7863  **/
7864 static int __init ipr_init(void)
7865 {
7866         ipr_info("IBM Power RAID SCSI Device Driver version: %s %s\n",
7867                  IPR_DRIVER_VERSION, IPR_DRIVER_DATE);
7868
7869         return pci_register_driver(&ipr_driver);
7870 }
7871
7872 /**
7873  * ipr_exit - Module unload
7874  *
7875  * Module unload entry point.
7876  *
7877  * Return value:
7878  *      none
7879  **/
7880 static void __exit ipr_exit(void)
7881 {
7882         pci_unregister_driver(&ipr_driver);
7883 }
7884
7885 module_init(ipr_init);
7886 module_exit(ipr_exit);