xref: /openbmc/linux/drivers/scsi/3w-sas.c (revision 023e41632e065d49bcbe31b3c4b336217f96a271)
1 /*
2    3w-sas.c -- LSI 3ware SAS/SATA-RAID Controller device driver for Linux.
3 
4    Written By: Adam Radford <aradford@gmail.com>
5 
6    Copyright (C) 2009 LSI 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; version 2 of the License.
11 
12    This program is distributed in the hope that it will be useful,
13    but WITHOUT ANY WARRANTY; without even the implied warranty of
14    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15    GNU General Public License for more details.
16 
17    NO WARRANTY
18    THE PROGRAM IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OR
19    CONDITIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED INCLUDING, WITHOUT
20    LIMITATION, ANY WARRANTIES OR CONDITIONS OF TITLE, NON-INFRINGEMENT,
21    MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Each Recipient is
22    solely responsible for determining the appropriateness of using and
23    distributing the Program and assumes all risks associated with its
24    exercise of rights under this Agreement, including but not limited to
25    the risks and costs of program errors, damage to or loss of data,
26    programs or equipment, and unavailability or interruption of operations.
27 
28    DISCLAIMER OF LIABILITY
29    NEITHER RECIPIENT NOR ANY CONTRIBUTORS SHALL HAVE ANY LIABILITY FOR ANY
30    DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
31    DAMAGES (INCLUDING WITHOUT LIMITATION LOST PROFITS), HOWEVER CAUSED AND
32    ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
33    TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
34    USE OR DISTRIBUTION OF THE PROGRAM OR THE EXERCISE OF ANY RIGHTS GRANTED
35    HEREUNDER, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGES
36 
37    You should have received a copy of the GNU General Public License
38    along with this program; if not, write to the Free Software
39    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
40 
41    Controllers supported by this driver:
42 
43    LSI 3ware 9750 6Gb/s SAS/SATA-RAID
44 
45    Bugs/Comments/Suggestions should be mailed to:
46    aradford@gmail.com
47 
48    History
49    -------
50    3.26.02.000 - Initial driver release.
51 */
52 
53 #include <linux/module.h>
54 #include <linux/reboot.h>
55 #include <linux/spinlock.h>
56 #include <linux/interrupt.h>
57 #include <linux/moduleparam.h>
58 #include <linux/errno.h>
59 #include <linux/types.h>
60 #include <linux/delay.h>
61 #include <linux/pci.h>
62 #include <linux/time.h>
63 #include <linux/mutex.h>
64 #include <linux/slab.h>
65 #include <asm/io.h>
66 #include <asm/irq.h>
67 #include <linux/uaccess.h>
68 #include <scsi/scsi.h>
69 #include <scsi/scsi_host.h>
70 #include <scsi/scsi_tcq.h>
71 #include <scsi/scsi_cmnd.h>
72 #include "3w-sas.h"
73 
74 /* Globals */
75 #define TW_DRIVER_VERSION "3.26.02.000"
76 static DEFINE_MUTEX(twl_chrdev_mutex);
77 static TW_Device_Extension *twl_device_extension_list[TW_MAX_SLOT];
78 static unsigned int twl_device_extension_count;
79 static int twl_major = -1;
80 extern struct timezone sys_tz;
81 
82 /* Module parameters */
83 MODULE_AUTHOR ("LSI");
84 MODULE_DESCRIPTION ("LSI 3ware SAS/SATA-RAID Linux Driver");
85 MODULE_LICENSE("GPL");
86 MODULE_VERSION(TW_DRIVER_VERSION);
87 
88 static int use_msi;
89 module_param(use_msi, int, S_IRUGO);
90 MODULE_PARM_DESC(use_msi, "Use Message Signaled Interrupts. Default: 0");
91 
92 /* Function prototypes */
93 static int twl_reset_device_extension(TW_Device_Extension *tw_dev, int ioctl_reset);
94 
95 /* Functions */
96 
97 /* This function returns AENs through sysfs */
98 static ssize_t twl_sysfs_aen_read(struct file *filp, struct kobject *kobj,
99 				  struct bin_attribute *bin_attr,
100 				  char *outbuf, loff_t offset, size_t count)
101 {
102 	struct device *dev = container_of(kobj, struct device, kobj);
103 	struct Scsi_Host *shost = class_to_shost(dev);
104 	TW_Device_Extension *tw_dev = (TW_Device_Extension *)shost->hostdata;
105 	unsigned long flags = 0;
106 	ssize_t ret;
107 
108 	if (!capable(CAP_SYS_ADMIN))
109 		return -EACCES;
110 
111 	spin_lock_irqsave(tw_dev->host->host_lock, flags);
112 	ret = memory_read_from_buffer(outbuf, count, &offset, tw_dev->event_queue[0], sizeof(TW_Event) * TW_Q_LENGTH);
113 	spin_unlock_irqrestore(tw_dev->host->host_lock, flags);
114 
115 	return ret;
116 } /* End twl_sysfs_aen_read() */
117 
118 /* aen_read sysfs attribute initializer */
119 static struct bin_attribute twl_sysfs_aen_read_attr = {
120 	.attr = {
121 		.name = "3ware_aen_read",
122 		.mode = S_IRUSR,
123 	},
124 	.size = 0,
125 	.read = twl_sysfs_aen_read
126 };
127 
128 /* This function returns driver compatibility info through sysfs */
129 static ssize_t twl_sysfs_compat_info(struct file *filp, struct kobject *kobj,
130 				     struct bin_attribute *bin_attr,
131 				     char *outbuf, loff_t offset, size_t count)
132 {
133 	struct device *dev = container_of(kobj, struct device, kobj);
134 	struct Scsi_Host *shost = class_to_shost(dev);
135 	TW_Device_Extension *tw_dev = (TW_Device_Extension *)shost->hostdata;
136 	unsigned long flags = 0;
137 	ssize_t ret;
138 
139 	if (!capable(CAP_SYS_ADMIN))
140 		return -EACCES;
141 
142 	spin_lock_irqsave(tw_dev->host->host_lock, flags);
143 	ret = memory_read_from_buffer(outbuf, count, &offset, &tw_dev->tw_compat_info, sizeof(TW_Compatibility_Info));
144 	spin_unlock_irqrestore(tw_dev->host->host_lock, flags);
145 
146 	return ret;
147 } /* End twl_sysfs_compat_info() */
148 
149 /* compat_info sysfs attribute initializer */
150 static struct bin_attribute twl_sysfs_compat_info_attr = {
151 	.attr = {
152 		.name = "3ware_compat_info",
153 		.mode = S_IRUSR,
154 	},
155 	.size = 0,
156 	.read = twl_sysfs_compat_info
157 };
158 
159 /* Show some statistics about the card */
160 static ssize_t twl_show_stats(struct device *dev,
161 			      struct device_attribute *attr, char *buf)
162 {
163 	struct Scsi_Host *host = class_to_shost(dev);
164 	TW_Device_Extension *tw_dev = (TW_Device_Extension *)host->hostdata;
165 	unsigned long flags = 0;
166 	ssize_t len;
167 
168 	spin_lock_irqsave(tw_dev->host->host_lock, flags);
169 	len = snprintf(buf, PAGE_SIZE, "3w-sas Driver version: %s\n"
170 		       "Current commands posted:   %4d\n"
171 		       "Max commands posted:       %4d\n"
172 		       "Last sgl length:           %4d\n"
173 		       "Max sgl length:            %4d\n"
174 		       "Last sector count:         %4d\n"
175 		       "Max sector count:          %4d\n"
176 		       "SCSI Host Resets:          %4d\n"
177 		       "AEN's:                     %4d\n",
178 		       TW_DRIVER_VERSION,
179 		       tw_dev->posted_request_count,
180 		       tw_dev->max_posted_request_count,
181 		       tw_dev->sgl_entries,
182 		       tw_dev->max_sgl_entries,
183 		       tw_dev->sector_count,
184 		       tw_dev->max_sector_count,
185 		       tw_dev->num_resets,
186 		       tw_dev->aen_count);
187 	spin_unlock_irqrestore(tw_dev->host->host_lock, flags);
188 	return len;
189 } /* End twl_show_stats() */
190 
191 /* stats sysfs attribute initializer */
192 static struct device_attribute twl_host_stats_attr = {
193 	.attr = {
194 		.name = 	"3ware_stats",
195 		.mode =		S_IRUGO,
196 	},
197 	.show = twl_show_stats
198 };
199 
200 /* Host attributes initializer */
201 static struct device_attribute *twl_host_attrs[] = {
202 	&twl_host_stats_attr,
203 	NULL,
204 };
205 
206 /* This function will look up an AEN severity string */
207 static char *twl_aen_severity_lookup(unsigned char severity_code)
208 {
209 	char *retval = NULL;
210 
211 	if ((severity_code < (unsigned char) TW_AEN_SEVERITY_ERROR) ||
212 	    (severity_code > (unsigned char) TW_AEN_SEVERITY_DEBUG))
213 		goto out;
214 
215 	retval = twl_aen_severity_table[severity_code];
216 out:
217 	return retval;
218 } /* End twl_aen_severity_lookup() */
219 
220 /* This function will queue an event */
221 static void twl_aen_queue_event(TW_Device_Extension *tw_dev, TW_Command_Apache_Header *header)
222 {
223 	u32 local_time;
224 	TW_Event *event;
225 	unsigned short aen;
226 	char host[16];
227 	char *error_str;
228 
229 	tw_dev->aen_count++;
230 
231 	/* Fill out event info */
232 	event = tw_dev->event_queue[tw_dev->error_index];
233 
234 	host[0] = '\0';
235 	if (tw_dev->host)
236 		sprintf(host, " scsi%d:", tw_dev->host->host_no);
237 
238 	aen = le16_to_cpu(header->status_block.error);
239 	memset(event, 0, sizeof(TW_Event));
240 
241 	event->severity = TW_SEV_OUT(header->status_block.severity__reserved);
242 	/* event->time_stamp_sec overflows in y2106 */
243 	local_time = (u32)(ktime_get_real_seconds() - (sys_tz.tz_minuteswest * 60));
244 	event->time_stamp_sec = local_time;
245 	event->aen_code = aen;
246 	event->retrieved = TW_AEN_NOT_RETRIEVED;
247 	event->sequence_id = tw_dev->error_sequence_id;
248 	tw_dev->error_sequence_id++;
249 
250 	/* Check for embedded error string */
251 	error_str = &(header->err_specific_desc[strlen(header->err_specific_desc)+1]);
252 
253 	header->err_specific_desc[sizeof(header->err_specific_desc) - 1] = '\0';
254 	event->parameter_len = strlen(header->err_specific_desc);
255 	memcpy(event->parameter_data, header->err_specific_desc, event->parameter_len + 1 + strlen(error_str));
256 	if (event->severity != TW_AEN_SEVERITY_DEBUG)
257 		printk(KERN_WARNING "3w-sas:%s AEN: %s (0x%02X:0x%04X): %s:%s.\n",
258 		       host,
259 		       twl_aen_severity_lookup(TW_SEV_OUT(header->status_block.severity__reserved)),
260 		       TW_MESSAGE_SOURCE_CONTROLLER_EVENT, aen, error_str,
261 		       header->err_specific_desc);
262 	else
263 		tw_dev->aen_count--;
264 
265 	tw_dev->error_index = (tw_dev->error_index + 1 ) % TW_Q_LENGTH;
266 } /* End twl_aen_queue_event() */
267 
268 /* This function will attempt to post a command packet to the board */
269 static int twl_post_command_packet(TW_Device_Extension *tw_dev, int request_id)
270 {
271 	dma_addr_t command_que_value;
272 
273 	command_que_value = tw_dev->command_packet_phys[request_id];
274 	command_que_value += TW_COMMAND_OFFSET;
275 
276 	/* First write upper 4 bytes */
277 	writel((u32)((u64)command_que_value >> 32), TWL_HIBQPH_REG_ADDR(tw_dev));
278 	/* Then the lower 4 bytes */
279 	writel((u32)(command_que_value | TWL_PULL_MODE), TWL_HIBQPL_REG_ADDR(tw_dev));
280 
281 	tw_dev->state[request_id] = TW_S_POSTED;
282 	tw_dev->posted_request_count++;
283 	if (tw_dev->posted_request_count > tw_dev->max_posted_request_count)
284 		tw_dev->max_posted_request_count = tw_dev->posted_request_count;
285 
286 	return 0;
287 } /* End twl_post_command_packet() */
288 
289 /* This function hands scsi cdb's to the firmware */
290 static int twl_scsiop_execute_scsi(TW_Device_Extension *tw_dev, int request_id,
291 				   unsigned char *cdb, int use_sg,
292 				   TW_SG_Entry_ISO *sglistarg)
293 {
294 	TW_Command_Full *full_command_packet;
295 	TW_Command_Apache *command_packet;
296 	int i, sg_count;
297 	struct scsi_cmnd *srb = NULL;
298 	struct scatterlist *sglist = NULL, *sg;
299 	int retval = 1;
300 
301 	if (tw_dev->srb[request_id]) {
302 		srb = tw_dev->srb[request_id];
303 		if (scsi_sglist(srb))
304 			sglist = scsi_sglist(srb);
305 	}
306 
307 	/* Initialize command packet */
308 	full_command_packet = tw_dev->command_packet_virt[request_id];
309 	full_command_packet->header.header_desc.size_header = 128;
310 	full_command_packet->header.status_block.error = 0;
311 	full_command_packet->header.status_block.severity__reserved = 0;
312 
313 	command_packet = &full_command_packet->command.newcommand;
314 	command_packet->status = 0;
315 	command_packet->opcode__reserved = TW_OPRES_IN(0, TW_OP_EXECUTE_SCSI);
316 
317 	/* We forced 16 byte cdb use earlier */
318 	if (!cdb)
319 		memcpy(command_packet->cdb, srb->cmnd, TW_MAX_CDB_LEN);
320 	else
321 		memcpy(command_packet->cdb, cdb, TW_MAX_CDB_LEN);
322 
323 	if (srb) {
324 		command_packet->unit = srb->device->id;
325 		command_packet->request_id__lunl =
326 			cpu_to_le16(TW_REQ_LUN_IN(srb->device->lun, request_id));
327 	} else {
328 		command_packet->request_id__lunl =
329 			cpu_to_le16(TW_REQ_LUN_IN(0, request_id));
330 		command_packet->unit = 0;
331 	}
332 
333 	command_packet->sgl_offset = 16;
334 
335 	if (!sglistarg) {
336 		/* Map sglist from scsi layer to cmd packet */
337 		if (scsi_sg_count(srb)) {
338 			sg_count = scsi_dma_map(srb);
339 			if (sg_count <= 0)
340 				goto out;
341 
342 			scsi_for_each_sg(srb, sg, sg_count, i) {
343 				command_packet->sg_list[i].address = TW_CPU_TO_SGL(sg_dma_address(sg));
344 				command_packet->sg_list[i].length = TW_CPU_TO_SGL(sg_dma_len(sg));
345 			}
346 			command_packet->sgl_entries__lunh = cpu_to_le16(TW_REQ_LUN_IN((srb->device->lun >> 4), scsi_sg_count(tw_dev->srb[request_id])));
347 		}
348 	} else {
349 		/* Internal cdb post */
350 		for (i = 0; i < use_sg; i++) {
351 			command_packet->sg_list[i].address = TW_CPU_TO_SGL(sglistarg[i].address);
352 			command_packet->sg_list[i].length = TW_CPU_TO_SGL(sglistarg[i].length);
353 		}
354 		command_packet->sgl_entries__lunh = cpu_to_le16(TW_REQ_LUN_IN(0, use_sg));
355 	}
356 
357 	/* Update some stats */
358 	if (srb) {
359 		tw_dev->sector_count = scsi_bufflen(srb) / 512;
360 		if (tw_dev->sector_count > tw_dev->max_sector_count)
361 			tw_dev->max_sector_count = tw_dev->sector_count;
362 		tw_dev->sgl_entries = scsi_sg_count(srb);
363 		if (tw_dev->sgl_entries > tw_dev->max_sgl_entries)
364 			tw_dev->max_sgl_entries = tw_dev->sgl_entries;
365 	}
366 
367 	/* Now post the command to the board */
368 	retval = twl_post_command_packet(tw_dev, request_id);
369 
370 out:
371 	return retval;
372 } /* End twl_scsiop_execute_scsi() */
373 
374 /* This function will read the aen queue from the isr */
375 static int twl_aen_read_queue(TW_Device_Extension *tw_dev, int request_id)
376 {
377 	unsigned char cdb[TW_MAX_CDB_LEN];
378 	TW_SG_Entry_ISO sglist[1];
379 	TW_Command_Full *full_command_packet;
380 	int retval = 1;
381 
382 	full_command_packet = tw_dev->command_packet_virt[request_id];
383 	memset(full_command_packet, 0, sizeof(TW_Command_Full));
384 
385 	/* Initialize cdb */
386 	memset(&cdb, 0, TW_MAX_CDB_LEN);
387 	cdb[0] = REQUEST_SENSE; /* opcode */
388 	cdb[4] = TW_ALLOCATION_LENGTH; /* allocation length */
389 
390 	/* Initialize sglist */
391 	memset(&sglist, 0, sizeof(TW_SG_Entry_ISO));
392 	sglist[0].length = TW_SECTOR_SIZE;
393 	sglist[0].address = tw_dev->generic_buffer_phys[request_id];
394 
395 	/* Mark internal command */
396 	tw_dev->srb[request_id] = NULL;
397 
398 	/* Now post the command packet */
399 	if (twl_scsiop_execute_scsi(tw_dev, request_id, cdb, 1, sglist)) {
400 		TW_PRINTK(tw_dev->host, TW_DRIVER, 0x2, "Post failed while reading AEN queue");
401 		goto out;
402 	}
403 	retval = 0;
404 out:
405 	return retval;
406 } /* End twl_aen_read_queue() */
407 
408 /* This function will sync firmware time with the host time */
409 static void twl_aen_sync_time(TW_Device_Extension *tw_dev, int request_id)
410 {
411 	u32 schedulertime;
412 	TW_Command_Full *full_command_packet;
413 	TW_Command *command_packet;
414 	TW_Param_Apache *param;
415 	time64_t local_time;
416 
417 	/* Fill out the command packet */
418 	full_command_packet = tw_dev->command_packet_virt[request_id];
419 	memset(full_command_packet, 0, sizeof(TW_Command_Full));
420 	command_packet = &full_command_packet->command.oldcommand;
421 	command_packet->opcode__sgloffset = TW_OPSGL_IN(2, TW_OP_SET_PARAM);
422 	command_packet->request_id = request_id;
423 	command_packet->byte8_offset.param.sgl[0].address = TW_CPU_TO_SGL(tw_dev->generic_buffer_phys[request_id]);
424 	command_packet->byte8_offset.param.sgl[0].length = TW_CPU_TO_SGL(TW_SECTOR_SIZE);
425 	command_packet->size = TW_COMMAND_SIZE;
426 	command_packet->byte6_offset.parameter_count = cpu_to_le16(1);
427 
428 	/* Setup the param */
429 	param = (TW_Param_Apache *)tw_dev->generic_buffer_virt[request_id];
430 	memset(param, 0, TW_SECTOR_SIZE);
431 	param->table_id = cpu_to_le16(TW_TIMEKEEP_TABLE | 0x8000); /* Controller time keep table */
432 	param->parameter_id = cpu_to_le16(0x3); /* SchedulerTime */
433 	param->parameter_size_bytes = cpu_to_le16(4);
434 
435 	/* Convert system time in UTC to local time seconds since last
436            Sunday 12:00AM */
437 	local_time = (ktime_get_real_seconds() - (sys_tz.tz_minuteswest * 60));
438 	div_u64_rem(local_time - (3 * 86400), 604800, &schedulertime);
439 	schedulertime = cpu_to_le32(schedulertime);
440 
441 	memcpy(param->data, &schedulertime, sizeof(u32));
442 
443 	/* Mark internal command */
444 	tw_dev->srb[request_id] = NULL;
445 
446 	/* Now post the command */
447 	twl_post_command_packet(tw_dev, request_id);
448 } /* End twl_aen_sync_time() */
449 
450 /* This function will assign an available request id */
451 static void twl_get_request_id(TW_Device_Extension *tw_dev, int *request_id)
452 {
453 	*request_id = tw_dev->free_queue[tw_dev->free_head];
454 	tw_dev->free_head = (tw_dev->free_head + 1) % TW_Q_LENGTH;
455 	tw_dev->state[*request_id] = TW_S_STARTED;
456 } /* End twl_get_request_id() */
457 
458 /* This function will free a request id */
459 static void twl_free_request_id(TW_Device_Extension *tw_dev, int request_id)
460 {
461 	tw_dev->free_queue[tw_dev->free_tail] = request_id;
462 	tw_dev->state[request_id] = TW_S_FINISHED;
463 	tw_dev->free_tail = (tw_dev->free_tail + 1) % TW_Q_LENGTH;
464 } /* End twl_free_request_id() */
465 
466 /* This function will complete an aen request from the isr */
467 static int twl_aen_complete(TW_Device_Extension *tw_dev, int request_id)
468 {
469 	TW_Command_Full *full_command_packet;
470 	TW_Command *command_packet;
471 	TW_Command_Apache_Header *header;
472 	unsigned short aen;
473 	int retval = 1;
474 
475 	header = (TW_Command_Apache_Header *)tw_dev->generic_buffer_virt[request_id];
476 	tw_dev->posted_request_count--;
477 	aen = le16_to_cpu(header->status_block.error);
478 	full_command_packet = tw_dev->command_packet_virt[request_id];
479 	command_packet = &full_command_packet->command.oldcommand;
480 
481 	/* First check for internal completion of set param for time sync */
482 	if (TW_OP_OUT(command_packet->opcode__sgloffset) == TW_OP_SET_PARAM) {
483 		/* Keep reading the queue in case there are more aen's */
484 		if (twl_aen_read_queue(tw_dev, request_id))
485 			goto out2;
486 	        else {
487 			retval = 0;
488 			goto out;
489 		}
490 	}
491 
492 	switch (aen) {
493 	case TW_AEN_QUEUE_EMPTY:
494 		/* Quit reading the queue if this is the last one */
495 		break;
496 	case TW_AEN_SYNC_TIME_WITH_HOST:
497 		twl_aen_sync_time(tw_dev, request_id);
498 		retval = 0;
499 		goto out;
500 	default:
501 		twl_aen_queue_event(tw_dev, header);
502 
503 		/* If there are more aen's, keep reading the queue */
504 		if (twl_aen_read_queue(tw_dev, request_id))
505 			goto out2;
506 		else {
507 			retval = 0;
508 			goto out;
509 		}
510 	}
511 	retval = 0;
512 out2:
513 	tw_dev->state[request_id] = TW_S_COMPLETED;
514 	twl_free_request_id(tw_dev, request_id);
515 	clear_bit(TW_IN_ATTENTION_LOOP, &tw_dev->flags);
516 out:
517 	return retval;
518 } /* End twl_aen_complete() */
519 
520 /* This function will poll for a response */
521 static int twl_poll_response(TW_Device_Extension *tw_dev, int request_id, int seconds)
522 {
523 	unsigned long before;
524 	dma_addr_t mfa;
525 	u32 regh, regl;
526 	u32 response;
527 	int retval = 1;
528 	int found = 0;
529 
530 	before = jiffies;
531 
532 	while (!found) {
533 		if (sizeof(dma_addr_t) > 4) {
534 			regh = readl(TWL_HOBQPH_REG_ADDR(tw_dev));
535 			regl = readl(TWL_HOBQPL_REG_ADDR(tw_dev));
536 			mfa = ((u64)regh << 32) | regl;
537 		} else
538 			mfa = readl(TWL_HOBQPL_REG_ADDR(tw_dev));
539 
540 		response = (u32)mfa;
541 
542 		if (TW_RESID_OUT(response) == request_id)
543 			found = 1;
544 
545 		if (time_after(jiffies, before + HZ * seconds))
546 			goto out;
547 
548 		msleep(50);
549 	}
550 	retval = 0;
551 out:
552 	return retval;
553 } /* End twl_poll_response() */
554 
555 /* This function will drain the aen queue */
556 static int twl_aen_drain_queue(TW_Device_Extension *tw_dev, int no_check_reset)
557 {
558 	int request_id = 0;
559 	unsigned char cdb[TW_MAX_CDB_LEN];
560 	TW_SG_Entry_ISO sglist[1];
561 	int finished = 0, count = 0;
562 	TW_Command_Full *full_command_packet;
563 	TW_Command_Apache_Header *header;
564 	unsigned short aen;
565 	int first_reset = 0, queue = 0, retval = 1;
566 
567 	if (no_check_reset)
568 		first_reset = 0;
569 	else
570 		first_reset = 1;
571 
572 	full_command_packet = tw_dev->command_packet_virt[request_id];
573 	memset(full_command_packet, 0, sizeof(TW_Command_Full));
574 
575 	/* Initialize cdb */
576 	memset(&cdb, 0, TW_MAX_CDB_LEN);
577 	cdb[0] = REQUEST_SENSE; /* opcode */
578 	cdb[4] = TW_ALLOCATION_LENGTH; /* allocation length */
579 
580 	/* Initialize sglist */
581 	memset(&sglist, 0, sizeof(TW_SG_Entry_ISO));
582 	sglist[0].length = TW_SECTOR_SIZE;
583 	sglist[0].address = tw_dev->generic_buffer_phys[request_id];
584 
585 	/* Mark internal command */
586 	tw_dev->srb[request_id] = NULL;
587 
588 	do {
589 		/* Send command to the board */
590 		if (twl_scsiop_execute_scsi(tw_dev, request_id, cdb, 1, sglist)) {
591 			TW_PRINTK(tw_dev->host, TW_DRIVER, 0x3, "Error posting request sense");
592 			goto out;
593 		}
594 
595 		/* Now poll for completion */
596 		if (twl_poll_response(tw_dev, request_id, 30)) {
597 			TW_PRINTK(tw_dev->host, TW_DRIVER, 0x4, "No valid response while draining AEN queue");
598 			tw_dev->posted_request_count--;
599 			goto out;
600 		}
601 
602 		tw_dev->posted_request_count--;
603 		header = (TW_Command_Apache_Header *)tw_dev->generic_buffer_virt[request_id];
604 		aen = le16_to_cpu(header->status_block.error);
605 		queue = 0;
606 		count++;
607 
608 		switch (aen) {
609 		case TW_AEN_QUEUE_EMPTY:
610 			if (first_reset != 1)
611 				goto out;
612 			else
613 				finished = 1;
614 			break;
615 		case TW_AEN_SOFT_RESET:
616 			if (first_reset == 0)
617 				first_reset = 1;
618 			else
619 				queue = 1;
620 			break;
621 		case TW_AEN_SYNC_TIME_WITH_HOST:
622 			break;
623 		default:
624 			queue = 1;
625 		}
626 
627 		/* Now queue an event info */
628 		if (queue)
629 			twl_aen_queue_event(tw_dev, header);
630 	} while ((finished == 0) && (count < TW_MAX_AEN_DRAIN));
631 
632 	if (count == TW_MAX_AEN_DRAIN)
633 		goto out;
634 
635 	retval = 0;
636 out:
637 	tw_dev->state[request_id] = TW_S_INITIAL;
638 	return retval;
639 } /* End twl_aen_drain_queue() */
640 
641 /* This function will allocate memory and check if it is correctly aligned */
642 static int twl_allocate_memory(TW_Device_Extension *tw_dev, int size, int which)
643 {
644 	int i;
645 	dma_addr_t dma_handle;
646 	unsigned long *cpu_addr;
647 	int retval = 1;
648 
649 	cpu_addr = dma_alloc_coherent(&tw_dev->tw_pci_dev->dev,
650 				      size * TW_Q_LENGTH, &dma_handle,
651 				      GFP_KERNEL);
652 	if (!cpu_addr) {
653 		TW_PRINTK(tw_dev->host, TW_DRIVER, 0x5, "Memory allocation failed");
654 		goto out;
655 	}
656 
657 	for (i = 0; i < TW_Q_LENGTH; i++) {
658 		switch(which) {
659 		case 0:
660 			tw_dev->command_packet_phys[i] = dma_handle+(i*size);
661 			tw_dev->command_packet_virt[i] = (TW_Command_Full *)((unsigned char *)cpu_addr + (i*size));
662 			break;
663 		case 1:
664 			tw_dev->generic_buffer_phys[i] = dma_handle+(i*size);
665 			tw_dev->generic_buffer_virt[i] = (unsigned long *)((unsigned char *)cpu_addr + (i*size));
666 			break;
667 		case 2:
668 			tw_dev->sense_buffer_phys[i] = dma_handle+(i*size);
669 			tw_dev->sense_buffer_virt[i] = (TW_Command_Apache_Header *)((unsigned char *)cpu_addr + (i*size));
670 			break;
671 		}
672 	}
673 	retval = 0;
674 out:
675 	return retval;
676 } /* End twl_allocate_memory() */
677 
678 /* This function will load the request id and various sgls for ioctls */
679 static void twl_load_sgl(TW_Device_Extension *tw_dev, TW_Command_Full *full_command_packet, int request_id, dma_addr_t dma_handle, int length)
680 {
681 	TW_Command *oldcommand;
682 	TW_Command_Apache *newcommand;
683 	TW_SG_Entry_ISO *sgl;
684 	unsigned int pae = 0;
685 
686 	if ((sizeof(long) < 8) && (sizeof(dma_addr_t) > 4))
687 		pae = 1;
688 
689 	if (TW_OP_OUT(full_command_packet->command.newcommand.opcode__reserved) == TW_OP_EXECUTE_SCSI) {
690 		newcommand = &full_command_packet->command.newcommand;
691 		newcommand->request_id__lunl =
692 			cpu_to_le16(TW_REQ_LUN_IN(TW_LUN_OUT(newcommand->request_id__lunl), request_id));
693 		if (length) {
694 			newcommand->sg_list[0].address = TW_CPU_TO_SGL(dma_handle + sizeof(TW_Ioctl_Buf_Apache) - 1);
695 			newcommand->sg_list[0].length = TW_CPU_TO_SGL(length);
696 		}
697 		newcommand->sgl_entries__lunh =
698 			cpu_to_le16(TW_REQ_LUN_IN(TW_LUN_OUT(newcommand->sgl_entries__lunh), length ? 1 : 0));
699 	} else {
700 		oldcommand = &full_command_packet->command.oldcommand;
701 		oldcommand->request_id = request_id;
702 
703 		if (TW_SGL_OUT(oldcommand->opcode__sgloffset)) {
704 			/* Load the sg list */
705 			sgl = (TW_SG_Entry_ISO *)((u32 *)oldcommand+oldcommand->size - (sizeof(TW_SG_Entry_ISO)/4) + pae + (sizeof(dma_addr_t) > 4 ? 1 : 0));
706 			sgl->address = TW_CPU_TO_SGL(dma_handle + sizeof(TW_Ioctl_Buf_Apache) - 1);
707 			sgl->length = TW_CPU_TO_SGL(length);
708 			oldcommand->size += pae;
709 			oldcommand->size += sizeof(dma_addr_t) > 4 ? 1 : 0;
710 		}
711 	}
712 } /* End twl_load_sgl() */
713 
714 /* This function handles ioctl for the character device
715    This interface is used by smartmontools open source software */
716 static long twl_chrdev_ioctl(struct file *file, unsigned int cmd, unsigned long arg)
717 {
718 	long timeout;
719 	unsigned long *cpu_addr, data_buffer_length_adjusted = 0, flags = 0;
720 	dma_addr_t dma_handle;
721 	int request_id = 0;
722 	TW_Ioctl_Driver_Command driver_command;
723 	struct inode *inode = file_inode(file);
724 	TW_Ioctl_Buf_Apache *tw_ioctl;
725 	TW_Command_Full *full_command_packet;
726 	TW_Device_Extension *tw_dev = twl_device_extension_list[iminor(inode)];
727 	int retval = -EFAULT;
728 	void __user *argp = (void __user *)arg;
729 
730 	mutex_lock(&twl_chrdev_mutex);
731 
732 	/* Only let one of these through at a time */
733 	if (mutex_lock_interruptible(&tw_dev->ioctl_lock)) {
734 		retval = -EINTR;
735 		goto out;
736 	}
737 
738 	/* First copy down the driver command */
739 	if (copy_from_user(&driver_command, argp, sizeof(TW_Ioctl_Driver_Command)))
740 		goto out2;
741 
742 	/* Check data buffer size */
743 	if (driver_command.buffer_length > TW_MAX_SECTORS * 2048) {
744 		retval = -EINVAL;
745 		goto out2;
746 	}
747 
748 	/* Hardware can only do multiple of 512 byte transfers */
749 	data_buffer_length_adjusted = (driver_command.buffer_length + 511) & ~511;
750 
751 	/* Now allocate ioctl buf memory */
752 	cpu_addr = dma_alloc_coherent(&tw_dev->tw_pci_dev->dev, data_buffer_length_adjusted+sizeof(TW_Ioctl_Buf_Apache) - 1, &dma_handle, GFP_KERNEL);
753 	if (!cpu_addr) {
754 		retval = -ENOMEM;
755 		goto out2;
756 	}
757 
758 	tw_ioctl = (TW_Ioctl_Buf_Apache *)cpu_addr;
759 
760 	/* Now copy down the entire ioctl */
761 	if (copy_from_user(tw_ioctl, argp, driver_command.buffer_length + sizeof(TW_Ioctl_Buf_Apache) - 1))
762 		goto out3;
763 
764 	/* See which ioctl we are doing */
765 	switch (cmd) {
766 	case TW_IOCTL_FIRMWARE_PASS_THROUGH:
767 		spin_lock_irqsave(tw_dev->host->host_lock, flags);
768 		twl_get_request_id(tw_dev, &request_id);
769 
770 		/* Flag internal command */
771 		tw_dev->srb[request_id] = NULL;
772 
773 		/* Flag chrdev ioctl */
774 		tw_dev->chrdev_request_id = request_id;
775 
776 		full_command_packet = (TW_Command_Full *)&tw_ioctl->firmware_command;
777 
778 		/* Load request id and sglist for both command types */
779 		twl_load_sgl(tw_dev, full_command_packet, request_id, dma_handle, data_buffer_length_adjusted);
780 
781 		memcpy(tw_dev->command_packet_virt[request_id], &(tw_ioctl->firmware_command), sizeof(TW_Command_Full));
782 
783 		/* Now post the command packet to the controller */
784 		twl_post_command_packet(tw_dev, request_id);
785 		spin_unlock_irqrestore(tw_dev->host->host_lock, flags);
786 
787 		timeout = TW_IOCTL_CHRDEV_TIMEOUT*HZ;
788 
789 		/* Now wait for command to complete */
790 		timeout = wait_event_timeout(tw_dev->ioctl_wqueue, tw_dev->chrdev_request_id == TW_IOCTL_CHRDEV_FREE, timeout);
791 
792 		/* We timed out, and didn't get an interrupt */
793 		if (tw_dev->chrdev_request_id != TW_IOCTL_CHRDEV_FREE) {
794 			/* Now we need to reset the board */
795 			printk(KERN_WARNING "3w-sas: scsi%d: WARNING: (0x%02X:0x%04X): Character ioctl (0x%x) timed out, resetting card.\n",
796 			       tw_dev->host->host_no, TW_DRIVER, 0x6,
797 			       cmd);
798 			retval = -EIO;
799 			twl_reset_device_extension(tw_dev, 1);
800 			goto out3;
801 		}
802 
803 		/* Now copy in the command packet response */
804 		memcpy(&(tw_ioctl->firmware_command), tw_dev->command_packet_virt[request_id], sizeof(TW_Command_Full));
805 
806 		/* Now complete the io */
807 		spin_lock_irqsave(tw_dev->host->host_lock, flags);
808 		tw_dev->posted_request_count--;
809 		tw_dev->state[request_id] = TW_S_COMPLETED;
810 		twl_free_request_id(tw_dev, request_id);
811 		spin_unlock_irqrestore(tw_dev->host->host_lock, flags);
812 		break;
813 	default:
814 		retval = -ENOTTY;
815 		goto out3;
816 	}
817 
818 	/* Now copy the entire response to userspace */
819 	if (copy_to_user(argp, tw_ioctl, sizeof(TW_Ioctl_Buf_Apache) + driver_command.buffer_length - 1) == 0)
820 		retval = 0;
821 out3:
822 	/* Now free ioctl buf memory */
823 	dma_free_coherent(&tw_dev->tw_pci_dev->dev, data_buffer_length_adjusted+sizeof(TW_Ioctl_Buf_Apache) - 1, cpu_addr, dma_handle);
824 out2:
825 	mutex_unlock(&tw_dev->ioctl_lock);
826 out:
827 	mutex_unlock(&twl_chrdev_mutex);
828 	return retval;
829 } /* End twl_chrdev_ioctl() */
830 
831 /* This function handles open for the character device */
832 static int twl_chrdev_open(struct inode *inode, struct file *file)
833 {
834 	unsigned int minor_number;
835 	int retval = -ENODEV;
836 
837 	if (!capable(CAP_SYS_ADMIN)) {
838 		retval = -EACCES;
839 		goto out;
840 	}
841 
842 	minor_number = iminor(inode);
843 	if (minor_number >= twl_device_extension_count)
844 		goto out;
845 	retval = 0;
846 out:
847 	return retval;
848 } /* End twl_chrdev_open() */
849 
850 /* File operations struct for character device */
851 static const struct file_operations twl_fops = {
852 	.owner		= THIS_MODULE,
853 	.unlocked_ioctl	= twl_chrdev_ioctl,
854 	.open		= twl_chrdev_open,
855 	.release	= NULL,
856 	.llseek		= noop_llseek,
857 };
858 
859 /* This function passes sense data from firmware to scsi layer */
860 static int twl_fill_sense(TW_Device_Extension *tw_dev, int i, int request_id, int copy_sense, int print_host)
861 {
862 	TW_Command_Apache_Header *header;
863 	TW_Command_Full *full_command_packet;
864 	unsigned short error;
865 	char *error_str;
866 	int retval = 1;
867 
868 	header = tw_dev->sense_buffer_virt[i];
869 	full_command_packet = tw_dev->command_packet_virt[request_id];
870 
871 	/* Get embedded firmware error string */
872 	error_str = &(header->err_specific_desc[strlen(header->err_specific_desc) + 1]);
873 
874 	/* Don't print error for Logical unit not supported during rollcall */
875 	error = le16_to_cpu(header->status_block.error);
876 	if ((error != TW_ERROR_LOGICAL_UNIT_NOT_SUPPORTED) && (error != TW_ERROR_UNIT_OFFLINE) && (error != TW_ERROR_INVALID_FIELD_IN_CDB)) {
877 		if (print_host)
878 			printk(KERN_WARNING "3w-sas: scsi%d: ERROR: (0x%02X:0x%04X): %s:%s.\n",
879 			       tw_dev->host->host_no,
880 			       TW_MESSAGE_SOURCE_CONTROLLER_ERROR,
881 			       header->status_block.error,
882 			       error_str,
883 			       header->err_specific_desc);
884 		else
885 			printk(KERN_WARNING "3w-sas: ERROR: (0x%02X:0x%04X): %s:%s.\n",
886 			       TW_MESSAGE_SOURCE_CONTROLLER_ERROR,
887 			       header->status_block.error,
888 			       error_str,
889 			       header->err_specific_desc);
890 	}
891 
892 	if (copy_sense) {
893 		memcpy(tw_dev->srb[request_id]->sense_buffer, header->sense_data, TW_SENSE_DATA_LENGTH);
894 		tw_dev->srb[request_id]->result = (full_command_packet->command.newcommand.status << 1);
895 		goto out;
896 	}
897 out:
898 	return retval;
899 } /* End twl_fill_sense() */
900 
901 /* This function will free up device extension resources */
902 static void twl_free_device_extension(TW_Device_Extension *tw_dev)
903 {
904 	if (tw_dev->command_packet_virt[0])
905 		dma_free_coherent(&tw_dev->tw_pci_dev->dev,
906 				    sizeof(TW_Command_Full)*TW_Q_LENGTH,
907 				    tw_dev->command_packet_virt[0],
908 				    tw_dev->command_packet_phys[0]);
909 
910 	if (tw_dev->generic_buffer_virt[0])
911 		dma_free_coherent(&tw_dev->tw_pci_dev->dev,
912 				    TW_SECTOR_SIZE*TW_Q_LENGTH,
913 				    tw_dev->generic_buffer_virt[0],
914 				    tw_dev->generic_buffer_phys[0]);
915 
916 	if (tw_dev->sense_buffer_virt[0])
917 		dma_free_coherent(&tw_dev->tw_pci_dev->dev,
918 				    sizeof(TW_Command_Apache_Header)*
919 				    TW_Q_LENGTH,
920 				    tw_dev->sense_buffer_virt[0],
921 				    tw_dev->sense_buffer_phys[0]);
922 
923 	kfree(tw_dev->event_queue[0]);
924 } /* End twl_free_device_extension() */
925 
926 /* This function will get parameter table entries from the firmware */
927 static void *twl_get_param(TW_Device_Extension *tw_dev, int request_id, int table_id, int parameter_id, int parameter_size_bytes)
928 {
929 	TW_Command_Full *full_command_packet;
930 	TW_Command *command_packet;
931 	TW_Param_Apache *param;
932 	void *retval = NULL;
933 
934 	/* Setup the command packet */
935 	full_command_packet = tw_dev->command_packet_virt[request_id];
936 	memset(full_command_packet, 0, sizeof(TW_Command_Full));
937 	command_packet = &full_command_packet->command.oldcommand;
938 
939 	command_packet->opcode__sgloffset = TW_OPSGL_IN(2, TW_OP_GET_PARAM);
940 	command_packet->size              = TW_COMMAND_SIZE;
941 	command_packet->request_id        = request_id;
942 	command_packet->byte6_offset.block_count = cpu_to_le16(1);
943 
944 	/* Now setup the param */
945 	param = (TW_Param_Apache *)tw_dev->generic_buffer_virt[request_id];
946 	memset(param, 0, TW_SECTOR_SIZE);
947 	param->table_id = cpu_to_le16(table_id | 0x8000);
948 	param->parameter_id = cpu_to_le16(parameter_id);
949 	param->parameter_size_bytes = cpu_to_le16(parameter_size_bytes);
950 
951 	command_packet->byte8_offset.param.sgl[0].address = TW_CPU_TO_SGL(tw_dev->generic_buffer_phys[request_id]);
952 	command_packet->byte8_offset.param.sgl[0].length = TW_CPU_TO_SGL(TW_SECTOR_SIZE);
953 
954 	/* Post the command packet to the board */
955 	twl_post_command_packet(tw_dev, request_id);
956 
957 	/* Poll for completion */
958 	if (twl_poll_response(tw_dev, request_id, 30))
959 		TW_PRINTK(tw_dev->host, TW_DRIVER, 0x7, "No valid response during get param")
960 	else
961 		retval = (void *)&(param->data[0]);
962 
963 	tw_dev->posted_request_count--;
964 	tw_dev->state[request_id] = TW_S_INITIAL;
965 
966 	return retval;
967 } /* End twl_get_param() */
968 
969 /* This function will send an initconnection command to controller */
970 static int twl_initconnection(TW_Device_Extension *tw_dev, int message_credits,
971  			      u32 set_features, unsigned short current_fw_srl,
972 			      unsigned short current_fw_arch_id,
973 			      unsigned short current_fw_branch,
974 			      unsigned short current_fw_build,
975 			      unsigned short *fw_on_ctlr_srl,
976 			      unsigned short *fw_on_ctlr_arch_id,
977 			      unsigned short *fw_on_ctlr_branch,
978 			      unsigned short *fw_on_ctlr_build,
979 			      u32 *init_connect_result)
980 {
981 	TW_Command_Full *full_command_packet;
982 	TW_Initconnect *tw_initconnect;
983 	int request_id = 0, retval = 1;
984 
985 	/* Initialize InitConnection command packet */
986 	full_command_packet = tw_dev->command_packet_virt[request_id];
987 	memset(full_command_packet, 0, sizeof(TW_Command_Full));
988 	full_command_packet->header.header_desc.size_header = 128;
989 
990 	tw_initconnect = (TW_Initconnect *)&full_command_packet->command.oldcommand;
991 	tw_initconnect->opcode__reserved = TW_OPRES_IN(0, TW_OP_INIT_CONNECTION);
992 	tw_initconnect->request_id = request_id;
993 	tw_initconnect->message_credits = cpu_to_le16(message_credits);
994 	tw_initconnect->features = set_features;
995 
996 	/* Turn on 64-bit sgl support if we need to */
997 	tw_initconnect->features |= sizeof(dma_addr_t) > 4 ? 1 : 0;
998 
999 	tw_initconnect->features = cpu_to_le32(tw_initconnect->features);
1000 
1001 	if (set_features & TW_EXTENDED_INIT_CONNECT) {
1002 		tw_initconnect->size = TW_INIT_COMMAND_PACKET_SIZE_EXTENDED;
1003 		tw_initconnect->fw_srl = cpu_to_le16(current_fw_srl);
1004 		tw_initconnect->fw_arch_id = cpu_to_le16(current_fw_arch_id);
1005 		tw_initconnect->fw_branch = cpu_to_le16(current_fw_branch);
1006 		tw_initconnect->fw_build = cpu_to_le16(current_fw_build);
1007 	} else
1008 		tw_initconnect->size = TW_INIT_COMMAND_PACKET_SIZE;
1009 
1010 	/* Send command packet to the board */
1011 	twl_post_command_packet(tw_dev, request_id);
1012 
1013 	/* Poll for completion */
1014 	if (twl_poll_response(tw_dev, request_id, 30)) {
1015 		TW_PRINTK(tw_dev->host, TW_DRIVER, 0x8, "No valid response during init connection");
1016 	} else {
1017 		if (set_features & TW_EXTENDED_INIT_CONNECT) {
1018 			*fw_on_ctlr_srl = le16_to_cpu(tw_initconnect->fw_srl);
1019 			*fw_on_ctlr_arch_id = le16_to_cpu(tw_initconnect->fw_arch_id);
1020 			*fw_on_ctlr_branch = le16_to_cpu(tw_initconnect->fw_branch);
1021 			*fw_on_ctlr_build = le16_to_cpu(tw_initconnect->fw_build);
1022 			*init_connect_result = le32_to_cpu(tw_initconnect->result);
1023 		}
1024 		retval = 0;
1025 	}
1026 
1027 	tw_dev->posted_request_count--;
1028 	tw_dev->state[request_id] = TW_S_INITIAL;
1029 
1030 	return retval;
1031 } /* End twl_initconnection() */
1032 
1033 /* This function will initialize the fields of a device extension */
1034 static int twl_initialize_device_extension(TW_Device_Extension *tw_dev)
1035 {
1036 	int i, retval = 1;
1037 
1038 	/* Initialize command packet buffers */
1039 	if (twl_allocate_memory(tw_dev, sizeof(TW_Command_Full), 0)) {
1040 		TW_PRINTK(tw_dev->host, TW_DRIVER, 0x9, "Command packet memory allocation failed");
1041 		goto out;
1042 	}
1043 
1044 	/* Initialize generic buffer */
1045 	if (twl_allocate_memory(tw_dev, TW_SECTOR_SIZE, 1)) {
1046 		TW_PRINTK(tw_dev->host, TW_DRIVER, 0xa, "Generic memory allocation failed");
1047 		goto out;
1048 	}
1049 
1050 	/* Allocate sense buffers */
1051 	if (twl_allocate_memory(tw_dev, sizeof(TW_Command_Apache_Header), 2)) {
1052 		TW_PRINTK(tw_dev->host, TW_DRIVER, 0xb, "Sense buffer allocation failed");
1053 		goto out;
1054 	}
1055 
1056 	/* Allocate event info space */
1057 	tw_dev->event_queue[0] = kcalloc(TW_Q_LENGTH, sizeof(TW_Event), GFP_KERNEL);
1058 	if (!tw_dev->event_queue[0]) {
1059 		TW_PRINTK(tw_dev->host, TW_DRIVER, 0xc, "Event info memory allocation failed");
1060 		goto out;
1061 	}
1062 
1063 	for (i = 0; i < TW_Q_LENGTH; i++) {
1064 		tw_dev->event_queue[i] = (TW_Event *)((unsigned char *)tw_dev->event_queue[0] + (i * sizeof(TW_Event)));
1065 		tw_dev->free_queue[i] = i;
1066 		tw_dev->state[i] = TW_S_INITIAL;
1067 	}
1068 
1069 	tw_dev->free_head = TW_Q_START;
1070 	tw_dev->free_tail = TW_Q_START;
1071 	tw_dev->error_sequence_id = 1;
1072 	tw_dev->chrdev_request_id = TW_IOCTL_CHRDEV_FREE;
1073 
1074 	mutex_init(&tw_dev->ioctl_lock);
1075 	init_waitqueue_head(&tw_dev->ioctl_wqueue);
1076 
1077 	retval = 0;
1078 out:
1079 	return retval;
1080 } /* End twl_initialize_device_extension() */
1081 
1082 /* This function will handle attention interrupts */
1083 static int twl_handle_attention_interrupt(TW_Device_Extension *tw_dev)
1084 {
1085 	int retval = 1;
1086 	u32 request_id, doorbell;
1087 
1088 	/* Read doorbell status */
1089 	doorbell = readl(TWL_HOBDB_REG_ADDR(tw_dev));
1090 
1091 	/* Check for controller errors */
1092 	if (doorbell & TWL_DOORBELL_CONTROLLER_ERROR) {
1093 		TW_PRINTK(tw_dev->host, TW_DRIVER, 0xd, "Microcontroller Error: clearing");
1094 		goto out;
1095 	}
1096 
1097 	/* Check if we need to perform an AEN drain */
1098 	if (doorbell & TWL_DOORBELL_ATTENTION_INTERRUPT) {
1099 		if (!(test_and_set_bit(TW_IN_ATTENTION_LOOP, &tw_dev->flags))) {
1100 			twl_get_request_id(tw_dev, &request_id);
1101 			if (twl_aen_read_queue(tw_dev, request_id)) {
1102 				tw_dev->state[request_id] = TW_S_COMPLETED;
1103 				twl_free_request_id(tw_dev, request_id);
1104 				clear_bit(TW_IN_ATTENTION_LOOP, &tw_dev->flags);
1105 			}
1106 		}
1107 	}
1108 
1109 	retval = 0;
1110 out:
1111 	/* Clear doorbell interrupt */
1112 	TWL_CLEAR_DB_INTERRUPT(tw_dev);
1113 
1114 	/* Make sure the clear was flushed by reading it back */
1115 	readl(TWL_HOBDBC_REG_ADDR(tw_dev));
1116 
1117 	return retval;
1118 } /* End twl_handle_attention_interrupt() */
1119 
1120 /* Interrupt service routine */
1121 static irqreturn_t twl_interrupt(int irq, void *dev_instance)
1122 {
1123 	TW_Device_Extension *tw_dev = (TW_Device_Extension *)dev_instance;
1124 	int i, handled = 0, error = 0;
1125 	dma_addr_t mfa = 0;
1126 	u32 reg, regl, regh, response, request_id = 0;
1127 	struct scsi_cmnd *cmd;
1128 	TW_Command_Full *full_command_packet;
1129 
1130 	spin_lock(tw_dev->host->host_lock);
1131 
1132 	/* Read host interrupt status */
1133 	reg = readl(TWL_HISTAT_REG_ADDR(tw_dev));
1134 
1135 	/* Check if this is our interrupt, otherwise bail */
1136 	if (!(reg & TWL_HISTATUS_VALID_INTERRUPT))
1137 		goto twl_interrupt_bail;
1138 
1139 	handled = 1;
1140 
1141 	/* If we are resetting, bail */
1142 	if (test_bit(TW_IN_RESET, &tw_dev->flags))
1143 		goto twl_interrupt_bail;
1144 
1145 	/* Attention interrupt */
1146 	if (reg & TWL_HISTATUS_ATTENTION_INTERRUPT) {
1147 		if (twl_handle_attention_interrupt(tw_dev)) {
1148 			TWL_MASK_INTERRUPTS(tw_dev);
1149 			goto twl_interrupt_bail;
1150 		}
1151 	}
1152 
1153 	/* Response interrupt */
1154 	while (reg & TWL_HISTATUS_RESPONSE_INTERRUPT) {
1155 		if (sizeof(dma_addr_t) > 4) {
1156 			regh = readl(TWL_HOBQPH_REG_ADDR(tw_dev));
1157 			regl = readl(TWL_HOBQPL_REG_ADDR(tw_dev));
1158 			mfa = ((u64)regh << 32) | regl;
1159 		} else
1160 			mfa = readl(TWL_HOBQPL_REG_ADDR(tw_dev));
1161 
1162 		error = 0;
1163 		response = (u32)mfa;
1164 
1165 		/* Check for command packet error */
1166 		if (!TW_NOTMFA_OUT(response)) {
1167 			for (i=0;i<TW_Q_LENGTH;i++) {
1168 				if (tw_dev->sense_buffer_phys[i] == mfa) {
1169 					request_id = le16_to_cpu(tw_dev->sense_buffer_virt[i]->header_desc.request_id);
1170 					if (tw_dev->srb[request_id] != NULL)
1171 						error = twl_fill_sense(tw_dev, i, request_id, 1, 1);
1172 					else {
1173 						/* Skip ioctl error prints */
1174 						if (request_id != tw_dev->chrdev_request_id)
1175 							error = twl_fill_sense(tw_dev, i, request_id, 0, 1);
1176 						else
1177 							memcpy(tw_dev->command_packet_virt[request_id], tw_dev->sense_buffer_virt[i], sizeof(TW_Command_Apache_Header));
1178 					}
1179 
1180 					/* Now re-post the sense buffer */
1181 					writel((u32)((u64)tw_dev->sense_buffer_phys[i] >> 32), TWL_HOBQPH_REG_ADDR(tw_dev));
1182 					writel((u32)tw_dev->sense_buffer_phys[i], TWL_HOBQPL_REG_ADDR(tw_dev));
1183 					break;
1184 				}
1185 			}
1186 		} else
1187 			request_id = TW_RESID_OUT(response);
1188 
1189 		full_command_packet = tw_dev->command_packet_virt[request_id];
1190 
1191 		/* Check for correct state */
1192 		if (tw_dev->state[request_id] != TW_S_POSTED) {
1193 			if (tw_dev->srb[request_id] != NULL) {
1194 				TW_PRINTK(tw_dev->host, TW_DRIVER, 0xe, "Received a request id that wasn't posted");
1195 				TWL_MASK_INTERRUPTS(tw_dev);
1196 				goto twl_interrupt_bail;
1197 			}
1198 		}
1199 
1200 		/* Check for internal command completion */
1201 		if (tw_dev->srb[request_id] == NULL) {
1202 			if (request_id != tw_dev->chrdev_request_id) {
1203 				if (twl_aen_complete(tw_dev, request_id))
1204 					TW_PRINTK(tw_dev->host, TW_DRIVER, 0xf, "Error completing AEN during attention interrupt");
1205 			} else {
1206 				tw_dev->chrdev_request_id = TW_IOCTL_CHRDEV_FREE;
1207 				wake_up(&tw_dev->ioctl_wqueue);
1208 			}
1209 		} else {
1210 			cmd = tw_dev->srb[request_id];
1211 
1212 			if (!error)
1213 				cmd->result = (DID_OK << 16);
1214 
1215 			/* Report residual bytes for single sgl */
1216 			if ((scsi_sg_count(cmd) <= 1) && (full_command_packet->command.newcommand.status == 0)) {
1217 				if (full_command_packet->command.newcommand.sg_list[0].length < scsi_bufflen(tw_dev->srb[request_id]))
1218 					scsi_set_resid(cmd, scsi_bufflen(cmd) - full_command_packet->command.newcommand.sg_list[0].length);
1219 			}
1220 
1221 			/* Now complete the io */
1222 			scsi_dma_unmap(cmd);
1223 			cmd->scsi_done(cmd);
1224 			tw_dev->state[request_id] = TW_S_COMPLETED;
1225 			twl_free_request_id(tw_dev, request_id);
1226 			tw_dev->posted_request_count--;
1227 		}
1228 
1229 		/* Check for another response interrupt */
1230 		reg = readl(TWL_HISTAT_REG_ADDR(tw_dev));
1231 	}
1232 
1233 twl_interrupt_bail:
1234 	spin_unlock(tw_dev->host->host_lock);
1235 	return IRQ_RETVAL(handled);
1236 } /* End twl_interrupt() */
1237 
1238 /* This function will poll for a register change */
1239 static int twl_poll_register(TW_Device_Extension *tw_dev, void *reg, u32 value, u32 result, int seconds)
1240 {
1241 	unsigned long before;
1242 	int retval = 1;
1243 	u32 reg_value;
1244 
1245 	reg_value = readl(reg);
1246 	before = jiffies;
1247 
1248         while ((reg_value & value) != result) {
1249 		reg_value = readl(reg);
1250 		if (time_after(jiffies, before + HZ * seconds))
1251 			goto out;
1252 		msleep(50);
1253 	}
1254 	retval = 0;
1255 out:
1256 	return retval;
1257 } /* End twl_poll_register() */
1258 
1259 /* This function will reset a controller */
1260 static int twl_reset_sequence(TW_Device_Extension *tw_dev, int soft_reset)
1261 {
1262 	int retval = 1;
1263 	int i = 0;
1264 	u32 status = 0;
1265 	unsigned short fw_on_ctlr_srl = 0, fw_on_ctlr_arch_id = 0;
1266 	unsigned short fw_on_ctlr_branch = 0, fw_on_ctlr_build = 0;
1267 	u32 init_connect_result = 0;
1268 	int tries = 0;
1269 	int do_soft_reset = soft_reset;
1270 
1271 	while (tries < TW_MAX_RESET_TRIES) {
1272 		/* Do a soft reset if one is needed */
1273 		if (do_soft_reset) {
1274 			TWL_SOFT_RESET(tw_dev);
1275 
1276 			/* Make sure controller is in a good state */
1277 			if (twl_poll_register(tw_dev, TWL_SCRPD3_REG_ADDR(tw_dev), TWL_CONTROLLER_READY, 0x0, 30)) {
1278 				TW_PRINTK(tw_dev->host, TW_DRIVER, 0x10, "Controller never went non-ready during reset sequence");
1279 				tries++;
1280 				continue;
1281 			}
1282 			if (twl_poll_register(tw_dev, TWL_SCRPD3_REG_ADDR(tw_dev), TWL_CONTROLLER_READY, TWL_CONTROLLER_READY, 60)) {
1283 				TW_PRINTK(tw_dev->host, TW_DRIVER, 0x11, "Controller not ready during reset sequence");
1284 				tries++;
1285 				continue;
1286 			}
1287 		}
1288 
1289 		/* Initconnect */
1290 		if (twl_initconnection(tw_dev, TW_INIT_MESSAGE_CREDITS,
1291 				       TW_EXTENDED_INIT_CONNECT, TW_CURRENT_DRIVER_SRL,
1292 				       TW_9750_ARCH_ID, TW_CURRENT_DRIVER_BRANCH,
1293 				       TW_CURRENT_DRIVER_BUILD, &fw_on_ctlr_srl,
1294 				       &fw_on_ctlr_arch_id, &fw_on_ctlr_branch,
1295 				       &fw_on_ctlr_build, &init_connect_result)) {
1296 			TW_PRINTK(tw_dev->host, TW_DRIVER, 0x12, "Initconnection failed while checking SRL");
1297 			do_soft_reset = 1;
1298 			tries++;
1299 			continue;
1300 		}
1301 
1302 		/* Load sense buffers */
1303 		while (i < TW_Q_LENGTH) {
1304 			writel((u32)((u64)tw_dev->sense_buffer_phys[i] >> 32), TWL_HOBQPH_REG_ADDR(tw_dev));
1305 			writel((u32)tw_dev->sense_buffer_phys[i], TWL_HOBQPL_REG_ADDR(tw_dev));
1306 
1307 			/* Check status for over-run after each write */
1308 			status = readl(TWL_STATUS_REG_ADDR(tw_dev));
1309 			if (!(status & TWL_STATUS_OVERRUN_SUBMIT))
1310 			    i++;
1311 		}
1312 
1313 		/* Now check status */
1314 		status = readl(TWL_STATUS_REG_ADDR(tw_dev));
1315 		if (status) {
1316 			TW_PRINTK(tw_dev->host, TW_DRIVER, 0x13, "Bad controller status after loading sense buffers");
1317 			do_soft_reset = 1;
1318 			tries++;
1319 			continue;
1320 		}
1321 
1322 		/* Drain the AEN queue */
1323 		if (twl_aen_drain_queue(tw_dev, soft_reset)) {
1324 			TW_PRINTK(tw_dev->host, TW_DRIVER, 0x14, "AEN drain failed during reset sequence");
1325 			do_soft_reset = 1;
1326 			tries++;
1327 			continue;
1328 		}
1329 
1330 		/* Load rest of compatibility struct */
1331 		strncpy(tw_dev->tw_compat_info.driver_version, TW_DRIVER_VERSION, strlen(TW_DRIVER_VERSION));
1332 		tw_dev->tw_compat_info.driver_srl_high = TW_CURRENT_DRIVER_SRL;
1333 		tw_dev->tw_compat_info.driver_branch_high = TW_CURRENT_DRIVER_BRANCH;
1334 		tw_dev->tw_compat_info.driver_build_high = TW_CURRENT_DRIVER_BUILD;
1335 		tw_dev->tw_compat_info.driver_srl_low = TW_BASE_FW_SRL;
1336 		tw_dev->tw_compat_info.driver_branch_low = TW_BASE_FW_BRANCH;
1337 		tw_dev->tw_compat_info.driver_build_low = TW_BASE_FW_BUILD;
1338 		tw_dev->tw_compat_info.fw_on_ctlr_srl = fw_on_ctlr_srl;
1339 		tw_dev->tw_compat_info.fw_on_ctlr_branch = fw_on_ctlr_branch;
1340 		tw_dev->tw_compat_info.fw_on_ctlr_build = fw_on_ctlr_build;
1341 
1342 		/* If we got here, controller is in a good state */
1343 		retval = 0;
1344 		goto out;
1345 	}
1346 out:
1347 	return retval;
1348 } /* End twl_reset_sequence() */
1349 
1350 /* This function will reset a device extension */
1351 static int twl_reset_device_extension(TW_Device_Extension *tw_dev, int ioctl_reset)
1352 {
1353 	int i = 0, retval = 1;
1354 	unsigned long flags = 0;
1355 
1356 	/* Block SCSI requests while we are resetting */
1357 	if (ioctl_reset)
1358 		scsi_block_requests(tw_dev->host);
1359 
1360 	set_bit(TW_IN_RESET, &tw_dev->flags);
1361 	TWL_MASK_INTERRUPTS(tw_dev);
1362 	TWL_CLEAR_DB_INTERRUPT(tw_dev);
1363 
1364 	spin_lock_irqsave(tw_dev->host->host_lock, flags);
1365 
1366 	/* Abort all requests that are in progress */
1367 	for (i = 0; i < TW_Q_LENGTH; i++) {
1368 		if ((tw_dev->state[i] != TW_S_FINISHED) &&
1369 		    (tw_dev->state[i] != TW_S_INITIAL) &&
1370 		    (tw_dev->state[i] != TW_S_COMPLETED)) {
1371 			struct scsi_cmnd *cmd = tw_dev->srb[i];
1372 
1373 			if (cmd) {
1374 				cmd->result = (DID_RESET << 16);
1375 				scsi_dma_unmap(cmd);
1376 				cmd->scsi_done(cmd);
1377 			}
1378 		}
1379 	}
1380 
1381 	/* Reset queues and counts */
1382 	for (i = 0; i < TW_Q_LENGTH; i++) {
1383 		tw_dev->free_queue[i] = i;
1384 		tw_dev->state[i] = TW_S_INITIAL;
1385 	}
1386 	tw_dev->free_head = TW_Q_START;
1387 	tw_dev->free_tail = TW_Q_START;
1388 	tw_dev->posted_request_count = 0;
1389 
1390 	spin_unlock_irqrestore(tw_dev->host->host_lock, flags);
1391 
1392 	if (twl_reset_sequence(tw_dev, 1))
1393 		goto out;
1394 
1395 	TWL_UNMASK_INTERRUPTS(tw_dev);
1396 
1397 	clear_bit(TW_IN_RESET, &tw_dev->flags);
1398 	tw_dev->chrdev_request_id = TW_IOCTL_CHRDEV_FREE;
1399 
1400 	retval = 0;
1401 out:
1402 	if (ioctl_reset)
1403 		scsi_unblock_requests(tw_dev->host);
1404 	return retval;
1405 } /* End twl_reset_device_extension() */
1406 
1407 /* This funciton returns unit geometry in cylinders/heads/sectors */
1408 static int twl_scsi_biosparam(struct scsi_device *sdev, struct block_device *bdev, sector_t capacity, int geom[])
1409 {
1410 	int heads, sectors;
1411 	TW_Device_Extension *tw_dev;
1412 
1413 	tw_dev = (TW_Device_Extension *)sdev->host->hostdata;
1414 
1415 	if (capacity >= 0x200000) {
1416 		heads = 255;
1417 		sectors = 63;
1418 	} else {
1419 		heads = 64;
1420 		sectors = 32;
1421 	}
1422 
1423 	geom[0] = heads;
1424 	geom[1] = sectors;
1425 	geom[2] = sector_div(capacity, heads * sectors); /* cylinders */
1426 
1427 	return 0;
1428 } /* End twl_scsi_biosparam() */
1429 
1430 /* This is the new scsi eh reset function */
1431 static int twl_scsi_eh_reset(struct scsi_cmnd *SCpnt)
1432 {
1433 	TW_Device_Extension *tw_dev = NULL;
1434 	int retval = FAILED;
1435 
1436 	tw_dev = (TW_Device_Extension *)SCpnt->device->host->hostdata;
1437 
1438 	tw_dev->num_resets++;
1439 
1440 	sdev_printk(KERN_WARNING, SCpnt->device,
1441 		"WARNING: (0x%02X:0x%04X): Command (0x%x) timed out, resetting card.\n",
1442 		TW_DRIVER, 0x2c, SCpnt->cmnd[0]);
1443 
1444 	/* Make sure we are not issuing an ioctl or resetting from ioctl */
1445 	mutex_lock(&tw_dev->ioctl_lock);
1446 
1447 	/* Now reset the card and some of the device extension data */
1448 	if (twl_reset_device_extension(tw_dev, 0)) {
1449 		TW_PRINTK(tw_dev->host, TW_DRIVER, 0x15, "Controller reset failed during scsi host reset");
1450 		goto out;
1451 	}
1452 
1453 	retval = SUCCESS;
1454 out:
1455 	mutex_unlock(&tw_dev->ioctl_lock);
1456 	return retval;
1457 } /* End twl_scsi_eh_reset() */
1458 
1459 /* This is the main scsi queue function to handle scsi opcodes */
1460 static int twl_scsi_queue_lck(struct scsi_cmnd *SCpnt, void (*done)(struct scsi_cmnd *))
1461 {
1462 	int request_id, retval;
1463 	TW_Device_Extension *tw_dev = (TW_Device_Extension *)SCpnt->device->host->hostdata;
1464 
1465 	/* If we are resetting due to timed out ioctl, report as busy */
1466 	if (test_bit(TW_IN_RESET, &tw_dev->flags)) {
1467 		retval = SCSI_MLQUEUE_HOST_BUSY;
1468 		goto out;
1469 	}
1470 
1471 	/* Save done function into scsi_cmnd struct */
1472 	SCpnt->scsi_done = done;
1473 
1474 	/* Get a free request id */
1475 	twl_get_request_id(tw_dev, &request_id);
1476 
1477 	/* Save the scsi command for use by the ISR */
1478 	tw_dev->srb[request_id] = SCpnt;
1479 
1480 	retval = twl_scsiop_execute_scsi(tw_dev, request_id, NULL, 0, NULL);
1481 	if (retval) {
1482 		tw_dev->state[request_id] = TW_S_COMPLETED;
1483 		twl_free_request_id(tw_dev, request_id);
1484 		SCpnt->result = (DID_ERROR << 16);
1485 		done(SCpnt);
1486 		retval = 0;
1487 	}
1488 out:
1489 	return retval;
1490 } /* End twl_scsi_queue() */
1491 
1492 static DEF_SCSI_QCMD(twl_scsi_queue)
1493 
1494 /* This function tells the controller to shut down */
1495 static void __twl_shutdown(TW_Device_Extension *tw_dev)
1496 {
1497 	/* Disable interrupts */
1498 	TWL_MASK_INTERRUPTS(tw_dev);
1499 
1500 	/* Free up the IRQ */
1501 	free_irq(tw_dev->tw_pci_dev->irq, tw_dev);
1502 
1503 	printk(KERN_WARNING "3w-sas: Shutting down host %d.\n", tw_dev->host->host_no);
1504 
1505 	/* Tell the card we are shutting down */
1506 	if (twl_initconnection(tw_dev, 1, 0, 0, 0, 0, 0, NULL, NULL, NULL, NULL, NULL)) {
1507 		TW_PRINTK(tw_dev->host, TW_DRIVER, 0x16, "Connection shutdown failed");
1508 	} else {
1509 		printk(KERN_WARNING "3w-sas: Shutdown complete.\n");
1510 	}
1511 
1512 	/* Clear doorbell interrupt just before exit */
1513 	TWL_CLEAR_DB_INTERRUPT(tw_dev);
1514 } /* End __twl_shutdown() */
1515 
1516 /* Wrapper for __twl_shutdown */
1517 static void twl_shutdown(struct pci_dev *pdev)
1518 {
1519 	struct Scsi_Host *host = pci_get_drvdata(pdev);
1520 	TW_Device_Extension *tw_dev;
1521 
1522 	if (!host)
1523 		return;
1524 
1525 	tw_dev = (TW_Device_Extension *)host->hostdata;
1526 
1527 	if (tw_dev->online)
1528 		__twl_shutdown(tw_dev);
1529 } /* End twl_shutdown() */
1530 
1531 /* This function configures unit settings when a unit is coming on-line */
1532 static int twl_slave_configure(struct scsi_device *sdev)
1533 {
1534 	/* Force 60 second timeout */
1535 	blk_queue_rq_timeout(sdev->request_queue, 60 * HZ);
1536 
1537 	return 0;
1538 } /* End twl_slave_configure() */
1539 
1540 /* scsi_host_template initializer */
1541 static struct scsi_host_template driver_template = {
1542 	.module			= THIS_MODULE,
1543 	.name			= "3w-sas",
1544 	.queuecommand		= twl_scsi_queue,
1545 	.eh_host_reset_handler	= twl_scsi_eh_reset,
1546 	.bios_param		= twl_scsi_biosparam,
1547 	.change_queue_depth	= scsi_change_queue_depth,
1548 	.can_queue		= TW_Q_LENGTH-2,
1549 	.slave_configure	= twl_slave_configure,
1550 	.this_id		= -1,
1551 	.sg_tablesize		= TW_LIBERATOR_MAX_SGL_LENGTH,
1552 	.max_sectors		= TW_MAX_SECTORS,
1553 	.cmd_per_lun		= TW_MAX_CMDS_PER_LUN,
1554 	.shost_attrs		= twl_host_attrs,
1555 	.emulated		= 1,
1556 	.no_write_same		= 1,
1557 };
1558 
1559 /* This function will probe and initialize a card */
1560 static int twl_probe(struct pci_dev *pdev, const struct pci_device_id *dev_id)
1561 {
1562 	struct Scsi_Host *host = NULL;
1563 	TW_Device_Extension *tw_dev;
1564 	int retval = -ENODEV;
1565 	int *ptr_phycount, phycount=0;
1566 
1567 	retval = pci_enable_device(pdev);
1568 	if (retval) {
1569 		TW_PRINTK(host, TW_DRIVER, 0x17, "Failed to enable pci device");
1570 		goto out_disable_device;
1571 	}
1572 
1573 	pci_set_master(pdev);
1574 	pci_try_set_mwi(pdev);
1575 
1576 	retval = dma_set_mask_and_coherent(&pdev->dev, DMA_BIT_MASK(64));
1577 	if (retval)
1578 		retval = dma_set_mask_and_coherent(&pdev->dev, DMA_BIT_MASK(32));
1579 	if (retval) {
1580 		TW_PRINTK(host, TW_DRIVER, 0x18, "Failed to set dma mask");
1581 		retval = -ENODEV;
1582 		goto out_disable_device;
1583 	}
1584 
1585 	host = scsi_host_alloc(&driver_template, sizeof(TW_Device_Extension));
1586 	if (!host) {
1587 		TW_PRINTK(host, TW_DRIVER, 0x19, "Failed to allocate memory for device extension");
1588 		retval = -ENOMEM;
1589 		goto out_disable_device;
1590 	}
1591 	tw_dev = shost_priv(host);
1592 
1593 	/* Save values to device extension */
1594 	tw_dev->host = host;
1595 	tw_dev->tw_pci_dev = pdev;
1596 
1597 	if (twl_initialize_device_extension(tw_dev)) {
1598 		TW_PRINTK(tw_dev->host, TW_DRIVER, 0x1a, "Failed to initialize device extension");
1599 		retval = -ENOMEM;
1600 		goto out_free_device_extension;
1601 	}
1602 
1603 	/* Request IO regions */
1604 	retval = pci_request_regions(pdev, "3w-sas");
1605 	if (retval) {
1606 		TW_PRINTK(tw_dev->host, TW_DRIVER, 0x1b, "Failed to get mem region");
1607 		goto out_free_device_extension;
1608 	}
1609 
1610 	/* Save base address, use region 1 */
1611 	tw_dev->base_addr = pci_iomap(pdev, 1, 0);
1612 	if (!tw_dev->base_addr) {
1613 		TW_PRINTK(tw_dev->host, TW_DRIVER, 0x1c, "Failed to ioremap");
1614 		retval = -ENOMEM;
1615 		goto out_release_mem_region;
1616 	}
1617 
1618 	/* Disable interrupts on the card */
1619 	TWL_MASK_INTERRUPTS(tw_dev);
1620 
1621 	/* Initialize the card */
1622 	if (twl_reset_sequence(tw_dev, 0)) {
1623 		TW_PRINTK(tw_dev->host, TW_DRIVER, 0x1d, "Controller reset failed during probe");
1624 		retval = -ENOMEM;
1625 		goto out_iounmap;
1626 	}
1627 
1628 	/* Set host specific parameters */
1629 	host->max_id = TW_MAX_UNITS;
1630 	host->max_cmd_len = TW_MAX_CDB_LEN;
1631 	host->max_lun = TW_MAX_LUNS;
1632 	host->max_channel = 0;
1633 
1634 	/* Register the card with the kernel SCSI layer */
1635 	retval = scsi_add_host(host, &pdev->dev);
1636 	if (retval) {
1637 		TW_PRINTK(tw_dev->host, TW_DRIVER, 0x1e, "scsi add host failed");
1638 		goto out_iounmap;
1639 	}
1640 
1641 	pci_set_drvdata(pdev, host);
1642 
1643 	printk(KERN_WARNING "3w-sas: scsi%d: Found an LSI 3ware %s Controller at 0x%llx, IRQ: %d.\n",
1644 	       host->host_no,
1645 	       (char *)twl_get_param(tw_dev, 1, TW_VERSION_TABLE,
1646 				     TW_PARAM_MODEL, TW_PARAM_MODEL_LENGTH),
1647 	       (u64)pci_resource_start(pdev, 1), pdev->irq);
1648 
1649 	ptr_phycount = twl_get_param(tw_dev, 2, TW_PARAM_PHY_SUMMARY_TABLE,
1650 				     TW_PARAM_PHYCOUNT, TW_PARAM_PHYCOUNT_LENGTH);
1651 	if (ptr_phycount)
1652 		phycount = le32_to_cpu(*(int *)ptr_phycount);
1653 
1654 	printk(KERN_WARNING "3w-sas: scsi%d: Firmware %s, BIOS %s, Phys: %d.\n",
1655 	       host->host_no,
1656 	       (char *)twl_get_param(tw_dev, 1, TW_VERSION_TABLE,
1657 				     TW_PARAM_FWVER, TW_PARAM_FWVER_LENGTH),
1658 	       (char *)twl_get_param(tw_dev, 2, TW_VERSION_TABLE,
1659 				     TW_PARAM_BIOSVER, TW_PARAM_BIOSVER_LENGTH),
1660 	       phycount);
1661 
1662 	/* Try to enable MSI */
1663 	if (use_msi && !pci_enable_msi(pdev))
1664 		set_bit(TW_USING_MSI, &tw_dev->flags);
1665 
1666 	/* Now setup the interrupt handler */
1667 	retval = request_irq(pdev->irq, twl_interrupt, IRQF_SHARED, "3w-sas", tw_dev);
1668 	if (retval) {
1669 		TW_PRINTK(tw_dev->host, TW_DRIVER, 0x1f, "Error requesting IRQ");
1670 		goto out_remove_host;
1671 	}
1672 
1673 	twl_device_extension_list[twl_device_extension_count] = tw_dev;
1674 	twl_device_extension_count++;
1675 
1676 	/* Re-enable interrupts on the card */
1677 	TWL_UNMASK_INTERRUPTS(tw_dev);
1678 
1679 	/* Finally, scan the host */
1680 	scsi_scan_host(host);
1681 
1682 	/* Add sysfs binary files */
1683 	if (sysfs_create_bin_file(&host->shost_dev.kobj, &twl_sysfs_aen_read_attr))
1684 		TW_PRINTK(tw_dev->host, TW_DRIVER, 0x20, "Failed to create sysfs binary file: 3ware_aen_read");
1685 	if (sysfs_create_bin_file(&host->shost_dev.kobj, &twl_sysfs_compat_info_attr))
1686 		TW_PRINTK(tw_dev->host, TW_DRIVER, 0x21, "Failed to create sysfs binary file: 3ware_compat_info");
1687 
1688 	if (twl_major == -1) {
1689 		if ((twl_major = register_chrdev (0, "twl", &twl_fops)) < 0)
1690 			TW_PRINTK(host, TW_DRIVER, 0x22, "Failed to register character device");
1691 	}
1692 	tw_dev->online = 1;
1693 	return 0;
1694 
1695 out_remove_host:
1696 	if (test_bit(TW_USING_MSI, &tw_dev->flags))
1697 		pci_disable_msi(pdev);
1698 	scsi_remove_host(host);
1699 out_iounmap:
1700 	iounmap(tw_dev->base_addr);
1701 out_release_mem_region:
1702 	pci_release_regions(pdev);
1703 out_free_device_extension:
1704 	twl_free_device_extension(tw_dev);
1705 	scsi_host_put(host);
1706 out_disable_device:
1707 	pci_disable_device(pdev);
1708 
1709 	return retval;
1710 } /* End twl_probe() */
1711 
1712 /* This function is called to remove a device */
1713 static void twl_remove(struct pci_dev *pdev)
1714 {
1715 	struct Scsi_Host *host = pci_get_drvdata(pdev);
1716 	TW_Device_Extension *tw_dev;
1717 
1718 	if (!host)
1719 		return;
1720 
1721 	tw_dev = (TW_Device_Extension *)host->hostdata;
1722 
1723 	if (!tw_dev->online)
1724 		return;
1725 
1726 	/* Remove sysfs binary files */
1727 	sysfs_remove_bin_file(&host->shost_dev.kobj, &twl_sysfs_aen_read_attr);
1728 	sysfs_remove_bin_file(&host->shost_dev.kobj, &twl_sysfs_compat_info_attr);
1729 
1730 	scsi_remove_host(tw_dev->host);
1731 
1732 	/* Unregister character device */
1733 	if (twl_major >= 0) {
1734 		unregister_chrdev(twl_major, "twl");
1735 		twl_major = -1;
1736 	}
1737 
1738 	/* Shutdown the card */
1739 	__twl_shutdown(tw_dev);
1740 
1741 	/* Disable MSI if enabled */
1742 	if (test_bit(TW_USING_MSI, &tw_dev->flags))
1743 		pci_disable_msi(pdev);
1744 
1745 	/* Free IO remapping */
1746 	iounmap(tw_dev->base_addr);
1747 
1748 	/* Free up the mem region */
1749 	pci_release_regions(pdev);
1750 
1751 	/* Free up device extension resources */
1752 	twl_free_device_extension(tw_dev);
1753 
1754 	scsi_host_put(tw_dev->host);
1755 	pci_disable_device(pdev);
1756 	twl_device_extension_count--;
1757 } /* End twl_remove() */
1758 
1759 #ifdef CONFIG_PM
1760 /* This function is called on PCI suspend */
1761 static int twl_suspend(struct pci_dev *pdev, pm_message_t state)
1762 {
1763 	struct Scsi_Host *host = pci_get_drvdata(pdev);
1764 	TW_Device_Extension *tw_dev = (TW_Device_Extension *)host->hostdata;
1765 
1766 	printk(KERN_WARNING "3w-sas: Suspending host %d.\n", tw_dev->host->host_no);
1767 	/* Disable interrupts */
1768 	TWL_MASK_INTERRUPTS(tw_dev);
1769 
1770 	free_irq(tw_dev->tw_pci_dev->irq, tw_dev);
1771 
1772 	/* Tell the card we are shutting down */
1773 	if (twl_initconnection(tw_dev, 1, 0, 0, 0, 0, 0, NULL, NULL, NULL, NULL, NULL)) {
1774 		TW_PRINTK(tw_dev->host, TW_DRIVER, 0x23, "Connection shutdown failed during suspend");
1775 	} else {
1776 		printk(KERN_WARNING "3w-sas: Suspend complete.\n");
1777 	}
1778 
1779 	/* Clear doorbell interrupt */
1780 	TWL_CLEAR_DB_INTERRUPT(tw_dev);
1781 
1782 	pci_save_state(pdev);
1783 	pci_disable_device(pdev);
1784 	pci_set_power_state(pdev, pci_choose_state(pdev, state));
1785 
1786 	return 0;
1787 } /* End twl_suspend() */
1788 
1789 /* This function is called on PCI resume */
1790 static int twl_resume(struct pci_dev *pdev)
1791 {
1792 	int retval = 0;
1793 	struct Scsi_Host *host = pci_get_drvdata(pdev);
1794 	TW_Device_Extension *tw_dev = (TW_Device_Extension *)host->hostdata;
1795 
1796 	printk(KERN_WARNING "3w-sas: Resuming host %d.\n", tw_dev->host->host_no);
1797 	pci_set_power_state(pdev, PCI_D0);
1798 	pci_enable_wake(pdev, PCI_D0, 0);
1799 	pci_restore_state(pdev);
1800 
1801 	retval = pci_enable_device(pdev);
1802 	if (retval) {
1803 		TW_PRINTK(tw_dev->host, TW_DRIVER, 0x24, "Enable device failed during resume");
1804 		return retval;
1805 	}
1806 
1807 	pci_set_master(pdev);
1808 	pci_try_set_mwi(pdev);
1809 
1810 	retval = dma_set_mask_and_coherent(&pdev->dev, DMA_BIT_MASK(64));
1811 	if (retval)
1812 		retval = dma_set_mask_and_coherent(&pdev->dev, DMA_BIT_MASK(32));
1813 	if (retval) {
1814 		TW_PRINTK(host, TW_DRIVER, 0x25, "Failed to set dma mask during resume");
1815 		retval = -ENODEV;
1816 		goto out_disable_device;
1817 	}
1818 
1819 	/* Initialize the card */
1820 	if (twl_reset_sequence(tw_dev, 0)) {
1821 		retval = -ENODEV;
1822 		goto out_disable_device;
1823 	}
1824 
1825 	/* Now setup the interrupt handler */
1826 	retval = request_irq(pdev->irq, twl_interrupt, IRQF_SHARED, "3w-sas", tw_dev);
1827 	if (retval) {
1828 		TW_PRINTK(tw_dev->host, TW_DRIVER, 0x26, "Error requesting IRQ during resume");
1829 		retval = -ENODEV;
1830 		goto out_disable_device;
1831 	}
1832 
1833 	/* Now enable MSI if enabled */
1834 	if (test_bit(TW_USING_MSI, &tw_dev->flags))
1835 		pci_enable_msi(pdev);
1836 
1837 	/* Re-enable interrupts on the card */
1838 	TWL_UNMASK_INTERRUPTS(tw_dev);
1839 
1840 	printk(KERN_WARNING "3w-sas: Resume complete.\n");
1841 	return 0;
1842 
1843 out_disable_device:
1844 	scsi_remove_host(host);
1845 	pci_disable_device(pdev);
1846 
1847 	return retval;
1848 } /* End twl_resume() */
1849 #endif
1850 
1851 /* PCI Devices supported by this driver */
1852 static struct pci_device_id twl_pci_tbl[] = {
1853 	{ PCI_VDEVICE(3WARE, PCI_DEVICE_ID_3WARE_9750) },
1854 	{ }
1855 };
1856 MODULE_DEVICE_TABLE(pci, twl_pci_tbl);
1857 
1858 /* pci_driver initializer */
1859 static struct pci_driver twl_driver = {
1860 	.name		= "3w-sas",
1861 	.id_table	= twl_pci_tbl,
1862 	.probe		= twl_probe,
1863 	.remove		= twl_remove,
1864 #ifdef CONFIG_PM
1865 	.suspend	= twl_suspend,
1866 	.resume		= twl_resume,
1867 #endif
1868 	.shutdown	= twl_shutdown
1869 };
1870 
1871 /* This function is called on driver initialization */
1872 static int __init twl_init(void)
1873 {
1874 	printk(KERN_INFO "LSI 3ware SAS/SATA-RAID Controller device driver for Linux v%s.\n", TW_DRIVER_VERSION);
1875 
1876 	return pci_register_driver(&twl_driver);
1877 } /* End twl_init() */
1878 
1879 /* This function is called on driver exit */
1880 static void __exit twl_exit(void)
1881 {
1882 	pci_unregister_driver(&twl_driver);
1883 } /* End twl_exit() */
1884 
1885 module_init(twl_init);
1886 module_exit(twl_exit);
1887 
1888