blob: 306f46b85a5522aff952da4fe6e0759a86b2a651 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/* aha152x.c -- Adaptec AHA-152x driver
2 * Author: Jürgen E. Fischer, fischer@norbit.de
3 * Copyright 1993-2004 Jürgen E. Fischer
4 *
5 * This program is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License as published by the
7 * Free Software Foundation; either version 2, or (at your option) any
8 * later version.
9 *
10 * This program is distributed in the hope that it will be useful, but
11 * WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * General Public License for more details.
14 *
15 *
16 * $Id: aha152x.c,v 2.7 2004/01/24 11:42:59 fischer Exp $
17 *
18 * $Log: aha152x.c,v $
19 * Revision 2.7 2004/01/24 11:42:59 fischer
20 * - gather code that is not used by PCMCIA at the end
21 * - move request_region for !PCMCIA case to detection
22 * - migration to new scsi host api (remove legacy code)
23 * - free host scribble before scsi_done
24 * - fix error handling
25 * - one isapnp device added to id_table
26 *
27 * Revision 2.6 2003/10/30 20:52:47 fischer
28 * - interfaces changes for kernel 2.6
29 * - aha152x_probe_one introduced for pcmcia stub
30 * - fixed pnpdev handling
31 * - instead of allocation a new one, reuse command for request sense after check condition and reset
32 * - fixes race in is_complete
33 *
34 * Revision 2.5 2002/04/14 11:24:53 fischer
35 * - isapnp support
36 * - abort fixed
37 * - 2.5 support
38 *
39 * Revision 2.4 2000/12/16 12:53:56 fischer
40 * - allow REQUEST SENSE to be queued
41 * - handle shared PCI interrupts
42 *
43 * Revision 2.3 2000/11/04 16:40:26 fischer
44 * - handle data overruns
45 * - extend timeout for data phases
46 *
47 * Revision 2.2 2000/08/08 19:54:53 fischer
48 * - minor changes
49 *
50 * Revision 2.1 2000/05/17 16:23:17 fischer
51 * - signature update
52 * - fix for data out w/o scatter gather
53 *
54 * Revision 2.0 1999/12/25 15:07:32 fischer
55 * - interrupt routine completly reworked
56 * - basic support for new eh code
57 *
58 * Revision 1.21 1999/11/10 23:46:36 fischer
59 * - default to synchronous operation
60 * - synchronous negotiation fixed
61 * - added timeout to loops
62 * - debugging output can be controlled through procfs
63 *
64 * Revision 1.20 1999/11/07 18:37:31 fischer
65 * - synchronous operation works
66 * - resid support for sg driver
67 *
68 * Revision 1.19 1999/11/02 22:39:59 fischer
69 * - moved leading comments to README.aha152x
70 * - new additional module parameters
71 * - updates for 2.3
72 * - support for the Tripace TC1550 controller
73 * - interrupt handling changed
74 *
75 * Revision 1.18 1996/09/07 20:10:40 fischer
76 * - fixed can_queue handling (multiple outstanding commands working again)
77 *
78 * Revision 1.17 1996/08/17 16:05:14 fischer
79 * - biosparam improved
80 * - interrupt verification
81 * - updated documentation
82 * - cleanups
83 *
84 * Revision 1.16 1996/06/09 00:04:56 root
85 * - added configuration symbols for insmod (aha152x/aha152x1)
86 *
87 * Revision 1.15 1996/04/30 14:52:06 fischer
88 * - proc info fixed
89 * - support for extended translation for >1GB disks
90 *
91 * Revision 1.14 1996/01/17 15:11:20 fischer
92 * - fixed lockup in MESSAGE IN phase after reconnection
93 *
94 * Revision 1.13 1996/01/09 02:15:53 fischer
95 * - some cleanups
96 * - moved request_irq behind controller initialization
97 * (to avoid spurious interrupts)
98 *
99 * Revision 1.12 1995/12/16 12:26:07 fischer
100 * - barrier()s added
101 * - configurable RESET delay added
102 *
103 * Revision 1.11 1995/12/06 21:18:35 fischer
104 * - some minor updates
105 *
106 * Revision 1.10 1995/07/22 19:18:45 fischer
107 * - support for 2 controllers
108 * - started synchronous data transfers (not working yet)
109 *
110 * Revision 1.9 1995/03/18 09:20:24 root
111 * - patches for PCMCIA and modules
112 *
113 * Revision 1.8 1995/01/21 22:07:19 root
114 * - snarf_region => request_region
115 * - aha152x_intr interface change
116 *
117 * Revision 1.7 1995/01/02 23:19:36 root
118 * - updated COMMAND_SIZE to cmd_len
119 * - changed sti() to restore_flags()
120 * - fixed some #ifdef which generated warnings
121 *
122 * Revision 1.6 1994/11/24 20:35:27 root
123 * - problem with odd number of bytes in fifo fixed
124 *
125 * Revision 1.5 1994/10/30 14:39:56 root
126 * - abort code fixed
127 * - debugging improved
128 *
129 * Revision 1.4 1994/09/12 11:33:01 root
130 * - irqaction to request_irq
131 * - abortion updated
132 *
133 * Revision 1.3 1994/08/04 13:53:05 root
134 * - updates for mid-level-driver changes
135 * - accept unexpected BUSFREE phase as error condition
136 * - parity check now configurable
137 *
138 * Revision 1.2 1994/07/03 12:56:36 root
139 * - cleaned up debugging code
140 * - more tweaking on reset delays
141 * - updated abort/reset code (pretty untested...)
142 *
143 * Revision 1.1 1994/05/28 21:18:49 root
144 * - update for mid-level interface change (abort-reset)
145 * - delays after resets adjusted for some slow devices
146 *
147 * Revision 1.0 1994/03/25 12:52:00 root
148 * - Fixed "more data than expected" problem
149 * - added new BIOS signatures
150 *
151 * Revision 0.102 1994/01/31 20:44:12 root
152 * - minor changes in insw/outsw handling
153 *
154 * Revision 0.101 1993/12/13 01:16:27 root
155 * - fixed STATUS phase (non-GOOD stati were dropped sometimes;
156 * fixes problems with CD-ROM sector size detection & media change)
157 *
158 * Revision 0.100 1993/12/10 16:58:47 root
159 * - fix for unsuccessful selections in case of non-continuous id assignments
160 * on the scsi bus.
161 *
162 * Revision 0.99 1993/10/24 16:19:59 root
163 * - fixed DATA IN (rare read errors gone)
164 *
165 * Revision 0.98 1993/10/17 12:54:44 root
166 * - fixed some recent fixes (shame on me)
167 * - moved initialization of scratch area to aha152x_queue
168 *
169 * Revision 0.97 1993/10/09 18:53:53 root
170 * - DATA IN fixed. Rarely left data in the fifo.
171 *
172 * Revision 0.96 1993/10/03 00:53:59 root
173 * - minor changes on DATA IN
174 *
175 * Revision 0.95 1993/09/24 10:36:01 root
176 * - change handling of MSGI after reselection
177 * - fixed sti/cli
178 * - minor changes
179 *
180 * Revision 0.94 1993/09/18 14:08:22 root
181 * - fixed bug in multiple outstanding command code
182 * - changed detection
183 * - support for kernel command line configuration
184 * - reset corrected
185 * - changed message handling
186 *
187 * Revision 0.93 1993/09/15 20:41:19 root
188 * - fixed bugs with multiple outstanding commands
189 *
190 * Revision 0.92 1993/09/13 02:46:33 root
191 * - multiple outstanding commands work (no problems with IBM drive)
192 *
193 * Revision 0.91 1993/09/12 20:51:46 root
194 * added multiple outstanding commands
195 * (some problem with this $%&? IBM device remain)
196 *
197 * Revision 0.9 1993/09/12 11:11:22 root
198 * - corrected auto-configuration
199 * - changed the auto-configuration (added some '#define's)
200 * - added support for dis-/reconnection
201 *
202 * Revision 0.8 1993/09/06 23:09:39 root
203 * - added support for the drive activity light
204 * - minor changes
205 *
206 * Revision 0.7 1993/09/05 14:30:15 root
207 * - improved phase detection
208 * - now using the new snarf_region code of 0.99pl13
209 *
210 * Revision 0.6 1993/09/02 11:01:38 root
211 * first public release; added some signatures and biosparam()
212 *
213 * Revision 0.5 1993/08/30 10:23:30 root
214 * fixed timing problems with my IBM drive
215 *
216 * Revision 0.4 1993/08/29 14:06:52 root
217 * fixed some problems with timeouts due incomplete commands
218 *
219 * Revision 0.3 1993/08/28 15:55:03 root
220 * writing data works too. mounted and worked on a dos partition
221 *
222 * Revision 0.2 1993/08/27 22:42:07 root
223 * reading data works. Mounted a msdos partition.
224 *
225 * Revision 0.1 1993/08/25 13:38:30 root
226 * first "damn thing doesn't work" version
227 *
228 * Revision 0.0 1993/08/14 19:54:25 root
229 * empty function bodies; detect() works.
230 *
231 *
232 **************************************************************************
233
234 see Documentation/scsi/aha152x.txt for configuration details
235
236 **************************************************************************/
237
238#include <linux/module.h>
239#include <linux/sched.h>
240#include <asm/irq.h>
Matthew Wilcox53d5ed62006-10-11 01:22:01 -0700241#include <linux/io.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -0700242#include <linux/blkdev.h>
243#include <asm/system.h>
244#include <linux/errno.h>
245#include <linux/string.h>
246#include <linux/wait.h>
247#include <linux/ioport.h>
248#include <linux/delay.h>
249#include <linux/proc_fs.h>
250#include <linux/interrupt.h>
251#include <linux/init.h>
252#include <linux/kernel.h>
253#include <linux/isapnp.h>
254#include <linux/spinlock.h>
255#include <linux/workqueue.h>
James Bottomley5fcda422006-09-14 17:04:58 -0500256#include <linux/list.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -0700257#include <asm/semaphore.h>
258#include <scsi/scsicam.h>
259
260#include "scsi.h"
db9dff32005-04-03 14:53:59 -0500261#include <scsi/scsi_dbg.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -0700262#include <scsi/scsi_host.h>
Matthew Wilcox1abfd372005-12-15 16:22:01 -0500263#include <scsi/scsi_transport_spi.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -0700264#include "aha152x.h"
265
James Bottomley5fcda422006-09-14 17:04:58 -0500266static LIST_HEAD(aha152x_host_list);
267
Linus Torvalds1da177e2005-04-16 15:20:36 -0700268
269/* DEFINES */
270
271/* For PCMCIA cards, always use AUTOCONF */
272#if defined(PCMCIA) || defined(MODULE)
273#if !defined(AUTOCONF)
274#define AUTOCONF
275#endif
276#endif
277
278#if !defined(AUTOCONF) && !defined(SETUP0)
279#error define AUTOCONF or SETUP0
280#endif
281
282#if defined(AHA152X_DEBUG)
283#define DEBUG_DEFAULT debug_eh
284
285#define DPRINTK(when,msgs...) \
286 do { if(HOSTDATA(shpnt)->debug & (when)) printk(msgs); } while(0)
287
288#define DO_LOCK(flags) \
289 do { \
290 if(spin_is_locked(&QLOCK)) { \
291 DPRINTK(debug_intr, DEBUG_LEAD "(%s:%d) already locked at %s:%d\n", CMDINFO(CURRENT_SC), __FUNCTION__, __LINE__, QLOCKER, QLOCKERL); \
292 } \
293 DPRINTK(debug_locks, DEBUG_LEAD "(%s:%d) locking\n", CMDINFO(CURRENT_SC), __FUNCTION__, __LINE__); \
294 spin_lock_irqsave(&QLOCK,flags); \
295 DPRINTK(debug_locks, DEBUG_LEAD "(%s:%d) locked\n", CMDINFO(CURRENT_SC), __FUNCTION__, __LINE__); \
296 QLOCKER=__FUNCTION__; \
297 QLOCKERL=__LINE__; \
298 } while(0)
299
300#define DO_UNLOCK(flags) \
301 do { \
302 DPRINTK(debug_locks, DEBUG_LEAD "(%s:%d) unlocking (locked at %s:%d)\n", CMDINFO(CURRENT_SC), __FUNCTION__, __LINE__, QLOCKER, QLOCKERL); \
303 spin_unlock_irqrestore(&QLOCK,flags); \
304 DPRINTK(debug_locks, DEBUG_LEAD "(%s:%d) unlocked\n", CMDINFO(CURRENT_SC), __FUNCTION__, __LINE__); \
305 QLOCKER="(not locked)"; \
306 QLOCKERL=0; \
307 } while(0)
308
309#else
310#define DPRINTK(when,msgs...)
311#define DO_LOCK(flags) spin_lock_irqsave(&QLOCK,flags)
312#define DO_UNLOCK(flags) spin_unlock_irqrestore(&QLOCK,flags)
313#endif
314
315#define LEAD "(scsi%d:%d:%d) "
316#define WARN_LEAD KERN_WARNING LEAD
317#define INFO_LEAD KERN_INFO LEAD
318#define NOTE_LEAD KERN_NOTICE LEAD
319#define ERR_LEAD KERN_ERR LEAD
320#define DEBUG_LEAD KERN_DEBUG LEAD
321#define CMDINFO(cmd) \
322 (cmd) ? ((cmd)->device->host->host_no) : -1, \
323 (cmd) ? ((cmd)->device->id & 0x0f) : -1, \
324 (cmd) ? ((cmd)->device->lun & 0x07) : -1
325
326#define DELAY_DEFAULT 1000
327
328#if defined(PCMCIA)
329#define IRQ_MIN 0
330#define IRQ_MAX 16
331#else
332#define IRQ_MIN 9
333#if defined(__PPC)
334#define IRQ_MAX (NR_IRQS-1)
335#else
336#define IRQ_MAX 12
337#endif
338#endif
339
340enum {
341 not_issued = 0x0001, /* command not yet issued */
342 selecting = 0x0002, /* target is beeing selected */
343 identified = 0x0004, /* IDENTIFY was sent */
344 disconnected = 0x0008, /* target disconnected */
345 completed = 0x0010, /* target sent COMMAND COMPLETE */
346 aborted = 0x0020, /* ABORT was sent */
347 resetted = 0x0040, /* BUS DEVICE RESET was sent */
348 spiordy = 0x0080, /* waiting for SPIORDY to raise */
349 syncneg = 0x0100, /* synchronous negotiation in progress */
350 aborting = 0x0200, /* ABORT is pending */
351 resetting = 0x0400, /* BUS DEVICE RESET is pending */
352 check_condition = 0x0800, /* requesting sense after CHECK CONDITION */
353};
354
355MODULE_AUTHOR("Jürgen Fischer");
356MODULE_DESCRIPTION(AHA152X_REVID);
357MODULE_LICENSE("GPL");
358
359#if !defined(PCMCIA)
360#if defined(MODULE)
361static int io[] = {0, 0};
362module_param_array(io, int, NULL, 0);
363MODULE_PARM_DESC(io,"base io address of controller");
364
365static int irq[] = {0, 0};
366module_param_array(irq, int, NULL, 0);
367MODULE_PARM_DESC(irq,"interrupt for controller");
368
369static int scsiid[] = {7, 7};
370module_param_array(scsiid, int, NULL, 0);
371MODULE_PARM_DESC(scsiid,"scsi id of controller");
372
373static int reconnect[] = {1, 1};
374module_param_array(reconnect, int, NULL, 0);
375MODULE_PARM_DESC(reconnect,"allow targets to disconnect");
376
377static int parity[] = {1, 1};
378module_param_array(parity, int, NULL, 0);
379MODULE_PARM_DESC(parity,"use scsi parity");
380
381static int sync[] = {1, 1};
382module_param_array(sync, int, NULL, 0);
383MODULE_PARM_DESC(sync,"use synchronous transfers");
384
385static int delay[] = {DELAY_DEFAULT, DELAY_DEFAULT};
386module_param_array(delay, int, NULL, 0);
387MODULE_PARM_DESC(delay,"scsi reset delay");
388
389static int exttrans[] = {0, 0};
390module_param_array(exttrans, int, NULL, 0);
391MODULE_PARM_DESC(exttrans,"use extended translation");
392
393#if !defined(AHA152X_DEBUG)
394static int aha152x[] = {0, 11, 7, 1, 1, 0, DELAY_DEFAULT, 0};
395module_param_array(aha152x, int, NULL, 0);
396MODULE_PARM_DESC(aha152x, "parameters for first controller");
397
398static int aha152x1[] = {0, 11, 7, 1, 1, 0, DELAY_DEFAULT, 0};
399module_param_array(aha152x1, int, NULL, 0);
400MODULE_PARM_DESC(aha152x1, "parameters for second controller");
401#else
402static int debug[] = {DEBUG_DEFAULT, DEBUG_DEFAULT};
403module_param_array(debug, int, NULL, 0);
404MODULE_PARM_DESC(debug, "flags for driver debugging");
405
406static int aha152x[] = {0, 11, 7, 1, 1, 1, DELAY_DEFAULT, 0, DEBUG_DEFAULT};
407module_param_array(aha152x, int, NULL, 0);
408MODULE_PARM_DESC(aha152x, "parameters for first controller");
409
410static int aha152x1[] = {0, 11, 7, 1, 1, 1, DELAY_DEFAULT, 0, DEBUG_DEFAULT};
411module_param_array(aha152x1, int, NULL, 0);
412MODULE_PARM_DESC(aha152x1, "parameters for second controller");
413#endif /* !defined(AHA152X_DEBUG) */
414#endif /* MODULE */
415
416#ifdef __ISAPNP__
417static struct isapnp_device_id id_table[] __devinitdata = {
418 { ISAPNP_ANY_ID, ISAPNP_ANY_ID,
419 ISAPNP_VENDOR('A','D','P'), ISAPNP_FUNCTION(0x1505), 0 },
420 { ISAPNP_ANY_ID, ISAPNP_ANY_ID,
421 ISAPNP_VENDOR('A','D','P'), ISAPNP_FUNCTION(0x1530), 0 },
422 { ISAPNP_DEVICE_SINGLE_END, }
423};
424MODULE_DEVICE_TABLE(isapnp, id_table);
425#endif /* ISAPNP */
426
427#endif /* !PCMCIA */
428
Christoph Hellwigd0be4a7d2005-10-31 18:31:40 +0100429static struct scsi_host_template aha152x_driver_template;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700430
431/*
432 * internal states of the host
433 *
434 */
435enum aha152x_state {
436 idle=0,
437 unknown,
438 seldo,
439 seldi,
440 selto,
441 busfree,
442 msgo,
443 cmd,
444 msgi,
445 status,
446 datai,
447 datao,
448 parerr,
449 rsti,
450 maxstate
451};
452
453/*
454 * current state information of the host
455 *
456 */
457struct aha152x_hostdata {
458 Scsi_Cmnd *issue_SC;
459 /* pending commands to issue */
460
461 Scsi_Cmnd *current_SC;
462 /* current command on the bus */
463
464 Scsi_Cmnd *disconnected_SC;
465 /* commands that disconnected */
466
467 Scsi_Cmnd *done_SC;
468 /* command that was completed */
469
470 spinlock_t lock;
471 /* host lock */
472
473#if defined(AHA152X_DEBUG)
474 const char *locker;
475 /* which function has the lock */
476 int lockerl; /* where did it get it */
477
478 int debug; /* current debugging setting */
479#endif
480
481#if defined(AHA152X_STAT)
482 int total_commands;
483 int disconnections;
484 int busfree_without_any_action;
485 int busfree_without_old_command;
486 int busfree_without_new_command;
487 int busfree_without_done_command;
488 int busfree_with_check_condition;
489 int count[maxstate];
490 int count_trans[maxstate];
491 unsigned long time[maxstate];
492#endif
493
494 int commands; /* current number of commands */
495
496 int reconnect; /* disconnection allowed */
497 int parity; /* parity checking enabled */
498 int synchronous; /* synchronous transferes enabled */
499 int delay; /* reset out delay */
500 int ext_trans; /* extended translation enabled */
501
502 int swint; /* software-interrupt was fired during detect() */
503 int service; /* bh needs to be run */
504 int in_intr; /* bh is running */
505
506 /* current state,
507 previous state,
508 last state different from current state */
509 enum aha152x_state state, prevstate, laststate;
510
511 int target;
512 /* reconnecting target */
513
514 unsigned char syncrate[8];
515 /* current synchronous transfer agreements */
516
517 unsigned char syncneg[8];
518 /* 0: no negotiation;
519 * 1: negotiation in progress;
520 * 2: negotiation completed
521 */
522
523 int cmd_i;
524 /* number of sent bytes of current command */
525
526 int msgi_len;
527 /* number of received message bytes */
528 unsigned char msgi[256];
529 /* received message bytes */
530
531 int msgo_i, msgo_len;
532 /* number of sent bytes and length of current messages */
533 unsigned char msgo[256];
534 /* pending messages */
535
536 int data_len;
537 /* number of sent/received bytes in dataphase */
538
539 unsigned long io_port0;
540 unsigned long io_port1;
541
542#ifdef __ISAPNP__
543 struct pnp_dev *pnpdev;
544#endif
James Bottomley5fcda422006-09-14 17:04:58 -0500545 struct list_head host_list;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700546};
547
548
549/*
550 * host specific command extension
551 *
552 */
553struct aha152x_scdata {
554 Scsi_Cmnd *next; /* next sc in queue */
555 struct semaphore *sem; /* semaphore to block on */
Christoph Hellwig5e13cdf2006-07-08 20:39:30 +0200556 unsigned char cmd_len;
557 unsigned char cmnd[MAX_COMMAND_SIZE];
558 unsigned short use_sg;
559 unsigned request_bufflen;
560 void *request_buffer;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700561};
562
563
564/* access macros for hostdata */
565
566#define HOSTDATA(shpnt) ((struct aha152x_hostdata *) &shpnt->hostdata)
567
568#define HOSTNO ((shpnt)->host_no)
569
570#define CURRENT_SC (HOSTDATA(shpnt)->current_SC)
571#define DONE_SC (HOSTDATA(shpnt)->done_SC)
572#define ISSUE_SC (HOSTDATA(shpnt)->issue_SC)
573#define DISCONNECTED_SC (HOSTDATA(shpnt)->disconnected_SC)
574#define QLOCK (HOSTDATA(shpnt)->lock)
575#define QLOCKER (HOSTDATA(shpnt)->locker)
576#define QLOCKERL (HOSTDATA(shpnt)->lockerl)
577
578#define STATE (HOSTDATA(shpnt)->state)
579#define PREVSTATE (HOSTDATA(shpnt)->prevstate)
580#define LASTSTATE (HOSTDATA(shpnt)->laststate)
581
582#define RECONN_TARGET (HOSTDATA(shpnt)->target)
583
584#define CMD_I (HOSTDATA(shpnt)->cmd_i)
585
586#define MSGO(i) (HOSTDATA(shpnt)->msgo[i])
587#define MSGO_I (HOSTDATA(shpnt)->msgo_i)
588#define MSGOLEN (HOSTDATA(shpnt)->msgo_len)
589#define ADDMSGO(x) (MSGOLEN<256 ? (void)(MSGO(MSGOLEN++)=x) : aha152x_error(shpnt,"MSGO overflow"))
590
591#define MSGI(i) (HOSTDATA(shpnt)->msgi[i])
592#define MSGILEN (HOSTDATA(shpnt)->msgi_len)
593#define ADDMSGI(x) (MSGILEN<256 ? (void)(MSGI(MSGILEN++)=x) : aha152x_error(shpnt,"MSGI overflow"))
594
595#define DATA_LEN (HOSTDATA(shpnt)->data_len)
596
597#define SYNCRATE (HOSTDATA(shpnt)->syncrate[CURRENT_SC->device->id])
598#define SYNCNEG (HOSTDATA(shpnt)->syncneg[CURRENT_SC->device->id])
599
600#define DELAY (HOSTDATA(shpnt)->delay)
601#define EXT_TRANS (HOSTDATA(shpnt)->ext_trans)
602#define TC1550 (HOSTDATA(shpnt)->tc1550)
603#define RECONNECT (HOSTDATA(shpnt)->reconnect)
604#define PARITY (HOSTDATA(shpnt)->parity)
605#define SYNCHRONOUS (HOSTDATA(shpnt)->synchronous)
606
607#define HOSTIOPORT0 (HOSTDATA(shpnt)->io_port0)
608#define HOSTIOPORT1 (HOSTDATA(shpnt)->io_port1)
609
610#define SCDATA(SCpnt) ((struct aha152x_scdata *) (SCpnt)->host_scribble)
611#define SCNEXT(SCpnt) SCDATA(SCpnt)->next
612#define SCSEM(SCpnt) SCDATA(SCpnt)->sem
613
614#define SG_ADDRESS(buffer) ((char *) (page_address((buffer)->page)+(buffer)->offset))
615
616/* state handling */
617static void seldi_run(struct Scsi_Host *shpnt);
618static void seldo_run(struct Scsi_Host *shpnt);
619static void selto_run(struct Scsi_Host *shpnt);
620static void busfree_run(struct Scsi_Host *shpnt);
621
622static void msgo_init(struct Scsi_Host *shpnt);
623static void msgo_run(struct Scsi_Host *shpnt);
624static void msgo_end(struct Scsi_Host *shpnt);
625
626static void cmd_init(struct Scsi_Host *shpnt);
627static void cmd_run(struct Scsi_Host *shpnt);
628static void cmd_end(struct Scsi_Host *shpnt);
629
630static void datai_init(struct Scsi_Host *shpnt);
631static void datai_run(struct Scsi_Host *shpnt);
632static void datai_end(struct Scsi_Host *shpnt);
633
634static void datao_init(struct Scsi_Host *shpnt);
635static void datao_run(struct Scsi_Host *shpnt);
636static void datao_end(struct Scsi_Host *shpnt);
637
638static void status_run(struct Scsi_Host *shpnt);
639
640static void msgi_run(struct Scsi_Host *shpnt);
641static void msgi_end(struct Scsi_Host *shpnt);
642
643static void parerr_run(struct Scsi_Host *shpnt);
644static void rsti_run(struct Scsi_Host *shpnt);
645
646static void is_complete(struct Scsi_Host *shpnt);
647
648/*
649 * driver states
650 *
651 */
652static struct {
653 char *name;
654 void (*init)(struct Scsi_Host *);
655 void (*run)(struct Scsi_Host *);
656 void (*end)(struct Scsi_Host *);
657 int spio;
658} states[] = {
659 { "idle", NULL, NULL, NULL, 0},
660 { "unknown", NULL, NULL, NULL, 0},
661 { "seldo", NULL, seldo_run, NULL, 0},
662 { "seldi", NULL, seldi_run, NULL, 0},
663 { "selto", NULL, selto_run, NULL, 0},
664 { "busfree", NULL, busfree_run, NULL, 0},
665 { "msgo", msgo_init, msgo_run, msgo_end, 1},
666 { "cmd", cmd_init, cmd_run, cmd_end, 1},
667 { "msgi", NULL, msgi_run, msgi_end, 1},
668 { "status", NULL, status_run, NULL, 1},
669 { "datai", datai_init, datai_run, datai_end, 0},
670 { "datao", datao_init, datao_run, datao_end, 0},
671 { "parerr", NULL, parerr_run, NULL, 0},
672 { "rsti", NULL, rsti_run, NULL, 0},
673};
674
675/* setup & interrupt */
David Howells7d12e782006-10-05 14:55:46 +0100676static irqreturn_t intr(int irq, void *dev_id);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700677static void reset_ports(struct Scsi_Host *shpnt);
678static void aha152x_error(struct Scsi_Host *shpnt, char *msg);
679static void done(struct Scsi_Host *shpnt, int error);
680
681/* diagnostics */
682static void disp_ports(struct Scsi_Host *shpnt);
683static void show_command(Scsi_Cmnd * ptr);
684static void show_queues(struct Scsi_Host *shpnt);
685static void disp_enintr(struct Scsi_Host *shpnt);
686
687
688/*
689 * queue services:
690 *
691 */
692static inline void append_SC(Scsi_Cmnd **SC, Scsi_Cmnd *new_SC)
693{
694 Scsi_Cmnd *end;
695
696 SCNEXT(new_SC) = NULL;
697 if (!*SC)
698 *SC = new_SC;
699 else {
700 for (end = *SC; SCNEXT(end); end = SCNEXT(end))
701 ;
702 SCNEXT(end) = new_SC;
703 }
704}
705
706static inline Scsi_Cmnd *remove_first_SC(Scsi_Cmnd ** SC)
707{
708 Scsi_Cmnd *ptr;
709
710 ptr = *SC;
711 if (ptr) {
712 *SC = SCNEXT(*SC);
713 SCNEXT(ptr)=NULL;
714 }
715 return ptr;
716}
717
718static inline Scsi_Cmnd *remove_lun_SC(Scsi_Cmnd ** SC, int target, int lun)
719{
720 Scsi_Cmnd *ptr, *prev;
721
722 for (ptr = *SC, prev = NULL;
723 ptr && ((ptr->device->id != target) || (ptr->device->lun != lun));
724 prev = ptr, ptr = SCNEXT(ptr))
725 ;
726
727 if (ptr) {
728 if (prev)
729 SCNEXT(prev) = SCNEXT(ptr);
730 else
731 *SC = SCNEXT(ptr);
732
733 SCNEXT(ptr)=NULL;
734 }
735
736 return ptr;
737}
738
739static inline Scsi_Cmnd *remove_SC(Scsi_Cmnd **SC, Scsi_Cmnd *SCp)
740{
741 Scsi_Cmnd *ptr, *prev;
742
743 for (ptr = *SC, prev = NULL;
744 ptr && SCp!=ptr;
745 prev = ptr, ptr = SCNEXT(ptr))
746 ;
747
748 if (ptr) {
749 if (prev)
750 SCNEXT(prev) = SCNEXT(ptr);
751 else
752 *SC = SCNEXT(ptr);
753
754 SCNEXT(ptr)=NULL;
755 }
756
757 return ptr;
758}
759
David Howells7d12e782006-10-05 14:55:46 +0100760static irqreturn_t swintr(int irqno, void *dev_id)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700761{
Jeff Garzikc7bec5a2006-10-06 15:00:58 -0400762 struct Scsi_Host *shpnt = dev_id;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700763
764 HOSTDATA(shpnt)->swint++;
765
766 SETPORT(DMACNTRL0, INTEN);
767 return IRQ_HANDLED;
768}
769
770struct Scsi_Host *aha152x_probe_one(struct aha152x_setup *setup)
771{
772 struct Scsi_Host *shpnt;
773
774 shpnt = scsi_host_alloc(&aha152x_driver_template, sizeof(struct aha152x_hostdata));
775 if (!shpnt) {
776 printk(KERN_ERR "aha152x: scsi_host_alloc failed\n");
777 return NULL;
778 }
779
Linus Torvalds1da177e2005-04-16 15:20:36 -0700780 memset(HOSTDATA(shpnt), 0, sizeof *HOSTDATA(shpnt));
James Bottomley5fcda422006-09-14 17:04:58 -0500781 INIT_LIST_HEAD(&HOSTDATA(shpnt)->host_list);
782
783 /* need to have host registered before triggering any interrupt */
784 list_add_tail(&HOSTDATA(shpnt)->host_list, &aha152x_host_list);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700785
786 shpnt->io_port = setup->io_port;
787 shpnt->n_io_port = IO_RANGE;
788 shpnt->irq = setup->irq;
789
790 if (!setup->tc1550) {
791 HOSTIOPORT0 = setup->io_port;
792 HOSTIOPORT1 = setup->io_port;
793 } else {
794 HOSTIOPORT0 = setup->io_port+0x10;
795 HOSTIOPORT1 = setup->io_port-0x10;
796 }
797
798 spin_lock_init(&QLOCK);
799 RECONNECT = setup->reconnect;
800 SYNCHRONOUS = setup->synchronous;
801 PARITY = setup->parity;
802 DELAY = setup->delay;
803 EXT_TRANS = setup->ext_trans;
804
805#if defined(AHA152X_DEBUG)
806 HOSTDATA(shpnt)->debug = setup->debug;
807#endif
808
809 SETPORT(SCSIID, setup->scsiid << 4);
810 shpnt->this_id = setup->scsiid;
811
812 if (setup->reconnect)
813 shpnt->can_queue = AHA152X_MAXQUEUE;
814
815 /* RESET OUT */
816 printk("aha152x: resetting bus...\n");
817 SETPORT(SCSISEQ, SCSIRSTO);
818 mdelay(256);
819 SETPORT(SCSISEQ, 0);
820 mdelay(DELAY);
821
822 reset_ports(shpnt);
823
824 printk(KERN_INFO
825 "aha152x%d%s: "
826 "vital data: rev=%x, "
827 "io=0x%03lx (0x%03lx/0x%03lx), "
828 "irq=%d, "
829 "scsiid=%d, "
830 "reconnect=%s, "
831 "parity=%s, "
832 "synchronous=%s, "
833 "delay=%d, "
834 "extended translation=%s\n",
835 shpnt->host_no, setup->tc1550 ? " (tc1550 mode)" : "",
836 GETPORT(REV) & 0x7,
837 shpnt->io_port, HOSTIOPORT0, HOSTIOPORT1,
838 shpnt->irq,
839 shpnt->this_id,
840 RECONNECT ? "enabled" : "disabled",
841 PARITY ? "enabled" : "disabled",
842 SYNCHRONOUS ? "enabled" : "disabled",
843 DELAY,
844 EXT_TRANS ? "enabled" : "disabled");
845
846 /* not expecting any interrupts */
847 SETPORT(SIMODE0, 0);
848 SETPORT(SIMODE1, 0);
849
Thomas Gleixner1d6f3592006-07-01 19:29:42 -0700850 if( request_irq(shpnt->irq, swintr, IRQF_DISABLED|IRQF_SHARED, "aha152x", shpnt) ) {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700851 printk(KERN_ERR "aha152x%d: irq %d busy.\n", shpnt->host_no, shpnt->irq);
852 goto out_host_put;
853 }
854
855 HOSTDATA(shpnt)->swint = 0;
856
857 printk(KERN_INFO "aha152x%d: trying software interrupt, ", shpnt->host_no);
858
859 mb();
860 SETPORT(DMACNTRL0, SWINT|INTEN);
861 mdelay(1000);
862 free_irq(shpnt->irq, shpnt);
863
864 if (!HOSTDATA(shpnt)->swint) {
865 if (TESTHI(DMASTAT, INTSTAT)) {
866 printk("lost.\n");
867 } else {
868 printk("failed.\n");
869 }
870
871 SETPORT(DMACNTRL0, INTEN);
872
873 printk(KERN_ERR "aha152x%d: irq %d possibly wrong. "
874 "Please verify.\n", shpnt->host_no, shpnt->irq);
875 goto out_host_put;
876 }
877 printk("ok.\n");
878
879
880 /* clear interrupts */
881 SETPORT(SSTAT0, 0x7f);
882 SETPORT(SSTAT1, 0xef);
883
Thomas Gleixner1d6f3592006-07-01 19:29:42 -0700884 if ( request_irq(shpnt->irq, intr, IRQF_DISABLED|IRQF_SHARED, "aha152x", shpnt) ) {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700885 printk(KERN_ERR "aha152x%d: failed to reassign irq %d.\n", shpnt->host_no, shpnt->irq);
886 goto out_host_put;
887 }
888
889 if( scsi_add_host(shpnt, NULL) ) {
890 free_irq(shpnt->irq, shpnt);
891 printk(KERN_ERR "aha152x%d: failed to add host.\n", shpnt->host_no);
892 goto out_host_put;
893 }
894
895 scsi_scan_host(shpnt);
896
Linus Torvalds1da177e2005-04-16 15:20:36 -0700897 return shpnt;
898
899out_host_put:
James Bottomley5fcda422006-09-14 17:04:58 -0500900 list_del(&HOSTDATA(shpnt)->host_list);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700901 scsi_host_put(shpnt);
902
903 return NULL;
904}
905
906void aha152x_release(struct Scsi_Host *shpnt)
907{
908 if(!shpnt)
909 return;
910
911 if (shpnt->irq)
912 free_irq(shpnt->irq, shpnt);
913
914#if !defined(PCMCIA)
915 if (shpnt->io_port)
916 release_region(shpnt->io_port, IO_RANGE);
917#endif
918
919#ifdef __ISAPNP__
920 if (HOSTDATA(shpnt)->pnpdev)
921 pnp_device_detach(HOSTDATA(shpnt)->pnpdev);
922#endif
923
924 scsi_remove_host(shpnt);
James Bottomley5fcda422006-09-14 17:04:58 -0500925 list_del(&HOSTDATA(shpnt)->host_list);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700926 scsi_host_put(shpnt);
927}
928
929
930/*
931 * setup controller to generate interrupts depending
932 * on current state (lock has to be acquired)
933 *
934 */
935static int setup_expected_interrupts(struct Scsi_Host *shpnt)
936{
937 if(CURRENT_SC) {
938 CURRENT_SC->SCp.phase |= 1 << 16;
939
940 if(CURRENT_SC->SCp.phase & selecting) {
941 DPRINTK(debug_intr, DEBUG_LEAD "expecting: (seldo) (seltimo) (seldi)\n", CMDINFO(CURRENT_SC));
942 SETPORT(SSTAT1, SELTO);
943 SETPORT(SIMODE0, ENSELDO | (DISCONNECTED_SC ? ENSELDI : 0));
944 SETPORT(SIMODE1, ENSELTIMO);
945 } else {
946 DPRINTK(debug_intr, DEBUG_LEAD "expecting: (phase change) (busfree) %s\n", CMDINFO(CURRENT_SC), CURRENT_SC->SCp.phase & spiordy ? "(spiordy)" : "");
947 SETPORT(SIMODE0, (CURRENT_SC->SCp.phase & spiordy) ? ENSPIORDY : 0);
948 SETPORT(SIMODE1, ENPHASEMIS | ENSCSIRST | ENSCSIPERR | ENBUSFREE);
949 }
950 } else if(STATE==seldi) {
951 DPRINTK(debug_intr, DEBUG_LEAD "expecting: (phase change) (identify)\n", CMDINFO(CURRENT_SC));
952 SETPORT(SIMODE0, 0);
953 SETPORT(SIMODE1, ENPHASEMIS | ENSCSIRST | ENSCSIPERR | ENBUSFREE);
954 } else {
955 DPRINTK(debug_intr, DEBUG_LEAD "expecting: %s %s\n",
956 CMDINFO(CURRENT_SC),
957 DISCONNECTED_SC ? "(reselection)" : "",
958 ISSUE_SC ? "(busfree)" : "");
959 SETPORT(SIMODE0, DISCONNECTED_SC ? ENSELDI : 0);
960 SETPORT(SIMODE1, ENSCSIRST | ( (ISSUE_SC||DONE_SC) ? ENBUSFREE : 0));
961 }
962
963 if(!HOSTDATA(shpnt)->in_intr)
964 SETBITS(DMACNTRL0, INTEN);
965
966 return TESTHI(DMASTAT, INTSTAT);
967}
968
969
970/*
971 * Queue a command and setup interrupts for a free bus.
972 */
973static int aha152x_internal_queue(Scsi_Cmnd *SCpnt, struct semaphore *sem, int phase, void (*done)(Scsi_Cmnd *))
974{
975 struct Scsi_Host *shpnt = SCpnt->device->host;
976 unsigned long flags;
977
978#if defined(AHA152X_DEBUG)
979 if (HOSTDATA(shpnt)->debug & debug_queue) {
980 printk(INFO_LEAD "queue: %p; cmd_len=%d pieces=%d size=%u cmnd=",
981 CMDINFO(SCpnt), SCpnt, SCpnt->cmd_len, SCpnt->use_sg, SCpnt->request_bufflen);
db9dff32005-04-03 14:53:59 -0500982 __scsi_print_command(SCpnt->cmnd);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700983 }
984#endif
985
986 SCpnt->scsi_done = done;
987 SCpnt->resid = SCpnt->request_bufflen;
988 SCpnt->SCp.phase = not_issued | phase;
989 SCpnt->SCp.Status = CHECK_CONDITION;
990 SCpnt->SCp.Message = 0;
991 SCpnt->SCp.have_data_in = 0;
992 SCpnt->SCp.sent_command = 0;
993
994 if(SCpnt->SCp.phase & (resetting|check_condition)) {
995 if(SCpnt->host_scribble==0 || SCSEM(SCpnt) || SCNEXT(SCpnt)) {
996 printk(ERR_LEAD "cannot reuse command\n", CMDINFO(SCpnt));
997 return FAILED;
998 }
999 } else {
Christoph Hellwig5e13cdf2006-07-08 20:39:30 +02001000 struct aha152x_scdata *sc;
1001
Linus Torvalds1da177e2005-04-16 15:20:36 -07001002 SCpnt->host_scribble = kmalloc(sizeof(struct aha152x_scdata), GFP_ATOMIC);
1003 if(SCpnt->host_scribble==0) {
1004 printk(ERR_LEAD "allocation failed\n", CMDINFO(SCpnt));
1005 return FAILED;
1006 }
Christoph Hellwig5e13cdf2006-07-08 20:39:30 +02001007
1008 sc = SCDATA(SCpnt);
1009 memcpy(sc->cmnd, SCpnt->cmnd, sizeof(sc->cmnd));
1010 sc->request_buffer = SCpnt->request_buffer;
1011 sc->request_bufflen = SCpnt->request_bufflen;
1012 sc->use_sg = SCpnt->use_sg;
1013 sc->cmd_len = SCpnt->cmd_len;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001014 }
1015
1016 SCNEXT(SCpnt) = NULL;
1017 SCSEM(SCpnt) = sem;
1018
1019 /* setup scratch area
1020 SCp.ptr : buffer pointer
1021 SCp.this_residual : buffer length
1022 SCp.buffer : next buffer
1023 SCp.buffers_residual : left buffers in list
1024 SCp.phase : current state of the command */
1025 if (SCpnt->use_sg) {
1026 SCpnt->SCp.buffer = (struct scatterlist *) SCpnt->request_buffer;
1027 SCpnt->SCp.ptr = SG_ADDRESS(SCpnt->SCp.buffer);
1028 SCpnt->SCp.this_residual = SCpnt->SCp.buffer->length;
1029 SCpnt->SCp.buffers_residual = SCpnt->use_sg - 1;
1030 } else {
1031 SCpnt->SCp.ptr = (char *) SCpnt->request_buffer;
1032 SCpnt->SCp.this_residual = SCpnt->request_bufflen;
1033 SCpnt->SCp.buffer = NULL;
1034 SCpnt->SCp.buffers_residual = 0;
1035 }
1036
1037 DO_LOCK(flags);
1038
1039#if defined(AHA152X_STAT)
1040 HOSTDATA(shpnt)->total_commands++;
1041#endif
1042
1043 /* Turn led on, when this is the first command. */
1044 HOSTDATA(shpnt)->commands++;
1045 if (HOSTDATA(shpnt)->commands==1)
1046 SETPORT(PORTA, 1);
1047
1048 append_SC(&ISSUE_SC, SCpnt);
1049
1050 if(!HOSTDATA(shpnt)->in_intr)
1051 setup_expected_interrupts(shpnt);
1052
1053 DO_UNLOCK(flags);
1054
1055 return 0;
1056}
1057
1058/*
1059 * queue a command
1060 *
1061 */
1062static int aha152x_queue(Scsi_Cmnd *SCpnt, void (*done)(Scsi_Cmnd *))
1063{
1064#if 0
1065 if(*SCpnt->cmnd == REQUEST_SENSE) {
1066 SCpnt->result = 0;
1067 done(SCpnt);
1068
1069 return 0;
1070 }
1071#endif
1072
1073 return aha152x_internal_queue(SCpnt, NULL, 0, done);
1074}
1075
1076
1077/*
1078 *
1079 *
1080 */
1081static void reset_done(Scsi_Cmnd *SCpnt)
1082{
1083#if 0
1084 struct Scsi_Host *shpnt = SCpnt->host;
1085 DPRINTK(debug_eh, INFO_LEAD "reset_done called\n", CMDINFO(SCpnt));
1086#endif
1087 if(SCSEM(SCpnt)) {
1088 up(SCSEM(SCpnt));
1089 } else {
1090 printk(KERN_ERR "aha152x: reset_done w/o semaphore\n");
1091 }
1092}
1093
1094/*
1095 * Abort a command
1096 *
1097 */
1098static int aha152x_abort(Scsi_Cmnd *SCpnt)
1099{
1100 struct Scsi_Host *shpnt = SCpnt->device->host;
1101 Scsi_Cmnd *ptr;
1102 unsigned long flags;
1103
1104#if defined(AHA152X_DEBUG)
1105 if(HOSTDATA(shpnt)->debug & debug_eh) {
1106 printk(DEBUG_LEAD "abort(%p)", CMDINFO(SCpnt), SCpnt);
1107 show_queues(shpnt);
1108 }
1109#endif
1110
1111 DO_LOCK(flags);
1112
1113 ptr=remove_SC(&ISSUE_SC, SCpnt);
1114
1115 if(ptr) {
1116 DPRINTK(debug_eh, DEBUG_LEAD "not yet issued - SUCCESS\n", CMDINFO(SCpnt));
1117
1118 HOSTDATA(shpnt)->commands--;
1119 if (!HOSTDATA(shpnt)->commands)
1120 SETPORT(PORTA, 0);
1121 DO_UNLOCK(flags);
1122
1123 kfree(SCpnt->host_scribble);
1124 SCpnt->host_scribble=NULL;
1125
1126 return SUCCESS;
1127 }
1128
1129 DO_UNLOCK(flags);
1130
1131 /*
1132 * FIXME:
1133 * for current command: queue ABORT for message out and raise ATN
1134 * for disconnected command: pseudo SC with ABORT message or ABORT on reselection?
1135 *
1136 */
1137
1138 printk(ERR_LEAD "cannot abort running or disconnected command\n", CMDINFO(SCpnt));
1139
1140 return FAILED;
1141}
1142
1143static void timer_expired(unsigned long p)
1144{
1145 Scsi_Cmnd *SCp = (Scsi_Cmnd *)p;
1146 struct semaphore *sem = SCSEM(SCp);
1147 struct Scsi_Host *shpnt = SCp->device->host;
1148 unsigned long flags;
1149
1150 /* remove command from issue queue */
1151 DO_LOCK(flags);
1152 remove_SC(&ISSUE_SC, SCp);
1153 DO_UNLOCK(flags);
1154
1155 up(sem);
1156}
1157
1158/*
1159 * Reset a device
1160 *
1161 */
1162static int aha152x_device_reset(Scsi_Cmnd * SCpnt)
1163{
1164 struct Scsi_Host *shpnt = SCpnt->device->host;
1165 DECLARE_MUTEX_LOCKED(sem);
1166 struct timer_list timer;
1167 int ret, issued, disconnected;
Christoph Hellwig631c2282006-07-08 20:42:15 +02001168 unsigned char old_cmd_len = SCpnt->cmd_len;
1169 unsigned short old_use_sg = SCpnt->use_sg;
1170 void *old_buffer = SCpnt->request_buffer;
1171 unsigned old_bufflen = SCpnt->request_bufflen;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001172 unsigned long flags;
1173
1174#if defined(AHA152X_DEBUG)
1175 if(HOSTDATA(shpnt)->debug & debug_eh) {
1176 printk(INFO_LEAD "aha152x_device_reset(%p)", CMDINFO(SCpnt), SCpnt);
1177 show_queues(shpnt);
1178 }
1179#endif
1180
1181 if(CURRENT_SC==SCpnt) {
1182 printk(ERR_LEAD "cannot reset current device\n", CMDINFO(SCpnt));
1183 return FAILED;
1184 }
1185
1186 DO_LOCK(flags);
1187 issued = remove_SC(&ISSUE_SC, SCpnt)==0;
1188 disconnected = issued && remove_SC(&DISCONNECTED_SC, SCpnt);
1189 DO_UNLOCK(flags);
1190
1191 SCpnt->cmd_len = 0;
1192 SCpnt->use_sg = 0;
1193 SCpnt->request_buffer = NULL;
1194 SCpnt->request_bufflen = 0;
1195
1196 init_timer(&timer);
1197 timer.data = (unsigned long) SCpnt;
1198 timer.expires = jiffies + 100*HZ; /* 10s */
1199 timer.function = (void (*)(unsigned long)) timer_expired;
1200
1201 aha152x_internal_queue(SCpnt, &sem, resetting, reset_done);
1202 add_timer(&timer);
1203 down(&sem);
1204 del_timer(&timer);
Christoph Hellwig631c2282006-07-08 20:42:15 +02001205
1206 SCpnt->cmd_len = old_cmd_len;
1207 SCpnt->use_sg = old_use_sg;
1208 SCpnt->request_buffer = old_buffer;
1209 SCpnt->request_bufflen = old_bufflen;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001210
1211 DO_LOCK(flags);
1212
1213 if(SCpnt->SCp.phase & resetted) {
1214 HOSTDATA(shpnt)->commands--;
1215 if (!HOSTDATA(shpnt)->commands)
1216 SETPORT(PORTA, 0);
1217 kfree(SCpnt->host_scribble);
1218 SCpnt->host_scribble=NULL;
1219
1220 ret = SUCCESS;
1221 } else {
1222 /* requeue */
1223 if(!issued) {
1224 append_SC(&ISSUE_SC, SCpnt);
1225 } else if(disconnected) {
1226 append_SC(&DISCONNECTED_SC, SCpnt);
1227 }
1228
1229 ret = FAILED;
1230 }
1231
1232 DO_UNLOCK(flags);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001233 return ret;
1234}
1235
1236static void free_hard_reset_SCs(struct Scsi_Host *shpnt, Scsi_Cmnd **SCs)
1237{
1238 Scsi_Cmnd *ptr;
1239
1240 ptr=*SCs;
1241 while(ptr) {
1242 Scsi_Cmnd *next;
1243
1244 if(SCDATA(ptr)) {
1245 next = SCNEXT(ptr);
1246 } else {
1247 printk(DEBUG_LEAD "queue corrupted at %p\n", CMDINFO(ptr), ptr);
1248 next = NULL;
1249 }
1250
1251 if (!ptr->device->soft_reset) {
1252 DPRINTK(debug_eh, DEBUG_LEAD "disconnected command %p removed\n", CMDINFO(ptr), ptr);
1253 remove_SC(SCs, ptr);
1254 HOSTDATA(shpnt)->commands--;
1255 kfree(ptr->host_scribble);
1256 ptr->host_scribble=NULL;
1257 }
1258
1259 ptr = next;
1260 }
1261}
1262
1263/*
1264 * Reset the bus
1265 *
1266 */
Jürgen E. Fischere2482fa2006-02-19 00:31:51 +01001267static int aha152x_bus_reset_host(struct Scsi_Host *shpnt)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001268{
Linus Torvalds1da177e2005-04-16 15:20:36 -07001269 unsigned long flags;
1270
1271 DO_LOCK(flags);
1272
1273#if defined(AHA152X_DEBUG)
1274 if(HOSTDATA(shpnt)->debug & debug_eh) {
Jürgen E. Fischere2482fa2006-02-19 00:31:51 +01001275 printk(KERN_DEBUG "scsi%d: bus reset", shpnt->host_no);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001276 show_queues(shpnt);
1277 }
1278#endif
1279
1280 free_hard_reset_SCs(shpnt, &ISSUE_SC);
1281 free_hard_reset_SCs(shpnt, &DISCONNECTED_SC);
1282
Jürgen E. Fischere2482fa2006-02-19 00:31:51 +01001283 DPRINTK(debug_eh, KERN_DEBUG "scsi%d: resetting bus\n", shpnt->host_no);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001284
1285 SETPORT(SCSISEQ, SCSIRSTO);
1286 mdelay(256);
1287 SETPORT(SCSISEQ, 0);
1288 mdelay(DELAY);
1289
Jürgen E. Fischere2482fa2006-02-19 00:31:51 +01001290 DPRINTK(debug_eh, KERN_DEBUG "scsi%d: bus resetted\n", shpnt->host_no);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001291
1292 setup_expected_interrupts(shpnt);
1293 if(HOSTDATA(shpnt)->commands==0)
1294 SETPORT(PORTA, 0);
1295
1296 DO_UNLOCK(flags);
1297
1298 return SUCCESS;
1299}
1300
Jürgen E. Fischere2482fa2006-02-19 00:31:51 +01001301/*
1302 * Reset the bus
1303 *
1304 */
1305static int aha152x_bus_reset(Scsi_Cmnd *SCpnt)
1306{
1307 return aha152x_bus_reset_host(SCpnt->device->host);
1308}
Linus Torvalds1da177e2005-04-16 15:20:36 -07001309
1310/*
1311 * Restore default values to the AIC-6260 registers and reset the fifos
1312 *
1313 */
1314static void reset_ports(struct Scsi_Host *shpnt)
1315{
1316 unsigned long flags;
1317
1318 /* disable interrupts */
1319 SETPORT(DMACNTRL0, RSTFIFO);
1320
1321 SETPORT(SCSISEQ, 0);
1322
1323 SETPORT(SXFRCTL1, 0);
1324 SETPORT(SCSISIG, 0);
1325 SETRATE(0);
1326
1327 /* clear all interrupt conditions */
1328 SETPORT(SSTAT0, 0x7f);
1329 SETPORT(SSTAT1, 0xef);
1330
1331 SETPORT(SSTAT4, SYNCERR | FWERR | FRERR);
1332
1333 SETPORT(DMACNTRL0, 0);
1334 SETPORT(DMACNTRL1, 0);
1335
1336 SETPORT(BRSTCNTRL, 0xf1);
1337
1338 /* clear SCSI fifos and transfer count */
1339 SETPORT(SXFRCTL0, CH1|CLRCH1|CLRSTCNT);
1340 SETPORT(SXFRCTL0, CH1);
1341
1342 DO_LOCK(flags);
1343 setup_expected_interrupts(shpnt);
1344 DO_UNLOCK(flags);
1345}
1346
1347/*
1348 * Reset the host (bus and controller)
1349 *
1350 */
Jürgen E. Fischere2482fa2006-02-19 00:31:51 +01001351int aha152x_host_reset_host(struct Scsi_Host *shpnt)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001352{
Jürgen E. Fischere2482fa2006-02-19 00:31:51 +01001353 DPRINTK(debug_eh, KERN_DEBUG "scsi%d: host reset\n", shpnt->host_no);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001354
Jürgen E. Fischere2482fa2006-02-19 00:31:51 +01001355 aha152x_bus_reset_host(shpnt);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001356
Jürgen E. Fischere2482fa2006-02-19 00:31:51 +01001357 DPRINTK(debug_eh, KERN_DEBUG "scsi%d: resetting ports\n", shpnt->host_no);
1358 reset_ports(shpnt);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001359
1360 return SUCCESS;
1361}
1362
1363/*
Jürgen E. Fischere2482fa2006-02-19 00:31:51 +01001364 * Reset the host (bus and controller)
1365 *
1366 */
1367static int aha152x_host_reset(Scsi_Cmnd *SCpnt)
1368{
1369 return aha152x_host_reset_host(SCpnt->device->host);
1370}
1371
1372/*
Linus Torvalds1da177e2005-04-16 15:20:36 -07001373 * Return the "logical geometry"
1374 *
1375 */
1376static int aha152x_biosparam(struct scsi_device *sdev, struct block_device *bdev,
1377 sector_t capacity, int *info_array)
1378{
1379 struct Scsi_Host *shpnt = sdev->host;
1380
1381 /* try default translation */
1382 info_array[0] = 64;
1383 info_array[1] = 32;
1384 info_array[2] = (unsigned long)capacity / (64 * 32);
1385
1386 /* for disks >1GB do some guessing */
1387 if (info_array[2] >= 1024) {
1388 int info[3];
1389
1390 /* try to figure out the geometry from the partition table */
1391 if (scsicam_bios_param(bdev, capacity, info) < 0 ||
1392 !((info[0] == 64 && info[1] == 32) || (info[0] == 255 && info[1] == 63))) {
1393 if (EXT_TRANS) {
1394 printk(KERN_NOTICE
1395 "aha152x: unable to verify geometry for disk with >1GB.\n"
1396 " using extended translation.\n");
1397 info_array[0] = 255;
1398 info_array[1] = 63;
1399 info_array[2] = (unsigned long)capacity / (255 * 63);
1400 } else {
1401 printk(KERN_NOTICE
1402 "aha152x: unable to verify geometry for disk with >1GB.\n"
1403 " Using default translation. Please verify yourself.\n"
1404 " Perhaps you need to enable extended translation in the driver.\n"
1405 " See Documentation/scsi/aha152x.txt for details.\n");
1406 }
1407 } else {
1408 info_array[0] = info[0];
1409 info_array[1] = info[1];
1410 info_array[2] = info[2];
1411
1412 if (info[0] == 255 && !EXT_TRANS) {
1413 printk(KERN_NOTICE
1414 "aha152x: current partition table is using extended translation.\n"
1415 " using it also, although it's not explicitly enabled.\n");
1416 }
1417 }
1418 }
1419
1420 return 0;
1421}
1422
1423/*
1424 * Internal done function
1425 *
1426 */
1427static void done(struct Scsi_Host *shpnt, int error)
1428{
1429 if (CURRENT_SC) {
1430 if(DONE_SC)
1431 printk(ERR_LEAD "there's already a completed command %p - will cause abort\n", CMDINFO(CURRENT_SC), DONE_SC);
1432
1433 DONE_SC = CURRENT_SC;
1434 CURRENT_SC = NULL;
1435 DONE_SC->result = error;
1436 } else
1437 printk(KERN_ERR "aha152x: done() called outside of command\n");
1438}
1439
1440static struct work_struct aha152x_tq;
1441
1442/*
1443 * Run service completions on the card with interrupts enabled.
1444 *
1445 */
1446static void run(void)
1447{
James Bottomley5fcda422006-09-14 17:04:58 -05001448 struct aha152x_hostdata *hd;
1449
1450 list_for_each_entry(hd, &aha152x_host_list, host_list) {
1451 struct Scsi_Host *shost = container_of((void *)hd, struct Scsi_Host, hostdata);
1452
1453 is_complete(shost);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001454 }
1455}
1456
1457/*
Jürgen E. Fischere2482fa2006-02-19 00:31:51 +01001458 * Interrupt handler
Linus Torvalds1da177e2005-04-16 15:20:36 -07001459 *
1460 */
David Howells7d12e782006-10-05 14:55:46 +01001461static irqreturn_t intr(int irqno, void *dev_id)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001462{
James Bottomley5fcda422006-09-14 17:04:58 -05001463 struct Scsi_Host *shpnt = (struct Scsi_Host *)dev_id;
Jürgen E. Fischere2482fa2006-02-19 00:31:51 +01001464 unsigned long flags;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001465 unsigned char rev, dmacntrl0;
1466
1467 if (!shpnt) {
1468 printk(KERN_ERR "aha152x: catched interrupt %d for unknown controller.\n", irqno);
1469 return IRQ_NONE;
1470 }
1471
1472 /*
1473 * Read a couple of registers that are known to not be all 1's. If
1474 * we read all 1's (-1), that means that either:
1475 *
1476 * a. The host adapter chip has gone bad, and we cannot control it,
1477 * OR
1478 * b. The host adapter is a PCMCIA card that has been ejected
1479 *
1480 * In either case, we cannot do anything with the host adapter at
1481 * this point in time. So just ignore the interrupt and return.
1482 * In the latter case, the interrupt might actually be meant for
1483 * someone else sharing this IRQ, and that driver will handle it.
1484 */
1485 rev = GETPORT(REV);
1486 dmacntrl0 = GETPORT(DMACNTRL0);
1487 if ((rev == 0xFF) && (dmacntrl0 == 0xFF))
1488 return IRQ_NONE;
1489
Jürgen E. Fischere2482fa2006-02-19 00:31:51 +01001490 if( TESTLO(DMASTAT, INTSTAT) )
1491 return IRQ_NONE;
1492
Linus Torvalds1da177e2005-04-16 15:20:36 -07001493 /* no more interrupts from the controller, while we're busy.
1494 INTEN is restored by the BH handler */
1495 CLRBITS(DMACNTRL0, INTEN);
1496
Jürgen E. Fischere2482fa2006-02-19 00:31:51 +01001497 DO_LOCK(flags);
1498 if( HOSTDATA(shpnt)->service==0 ) {
1499 HOSTDATA(shpnt)->service=1;
1500
1501 /* Poke the BH handler */
1502 INIT_WORK(&aha152x_tq, (void *) run, NULL);
1503 schedule_work(&aha152x_tq);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001504 }
Jürgen E. Fischere2482fa2006-02-19 00:31:51 +01001505 DO_UNLOCK(flags);
1506
Linus Torvalds1da177e2005-04-16 15:20:36 -07001507 return IRQ_HANDLED;
1508}
1509
1510/*
1511 * busfree phase
1512 * - handle completition/disconnection/error of current command
1513 * - start selection for next command (if any)
1514 */
1515static void busfree_run(struct Scsi_Host *shpnt)
1516{
1517 unsigned long flags;
1518#if defined(AHA152X_STAT)
1519 int action=0;
1520#endif
1521
1522 SETPORT(SXFRCTL0, CH1|CLRCH1|CLRSTCNT);
1523 SETPORT(SXFRCTL0, CH1);
1524
1525 SETPORT(SSTAT1, CLRBUSFREE);
1526
1527 if(CURRENT_SC) {
1528#if defined(AHA152X_STAT)
1529 action++;
1530#endif
1531 CURRENT_SC->SCp.phase &= ~syncneg;
1532
1533 if(CURRENT_SC->SCp.phase & completed) {
1534 /* target sent COMMAND COMPLETE */
1535 done(shpnt, (CURRENT_SC->SCp.Status & 0xff) | ((CURRENT_SC->SCp.Message & 0xff) << 8) | (DID_OK << 16));
1536
1537 } else if(CURRENT_SC->SCp.phase & aborted) {
1538 DPRINTK(debug_eh, DEBUG_LEAD "ABORT sent\n", CMDINFO(CURRENT_SC));
1539 done(shpnt, (CURRENT_SC->SCp.Status & 0xff) | ((CURRENT_SC->SCp.Message & 0xff) << 8) | (DID_ABORT << 16));
1540
1541 } else if(CURRENT_SC->SCp.phase & resetted) {
1542 DPRINTK(debug_eh, DEBUG_LEAD "BUS DEVICE RESET sent\n", CMDINFO(CURRENT_SC));
1543 done(shpnt, (CURRENT_SC->SCp.Status & 0xff) | ((CURRENT_SC->SCp.Message & 0xff) << 8) | (DID_RESET << 16));
1544
1545 } else if(CURRENT_SC->SCp.phase & disconnected) {
1546 /* target sent DISCONNECT */
1547 DPRINTK(debug_selection, DEBUG_LEAD "target disconnected at %d/%d\n",
1548 CMDINFO(CURRENT_SC),
1549 CURRENT_SC->resid,
1550 CURRENT_SC->request_bufflen);
1551#if defined(AHA152X_STAT)
1552 HOSTDATA(shpnt)->disconnections++;
1553#endif
1554 append_SC(&DISCONNECTED_SC, CURRENT_SC);
1555 CURRENT_SC->SCp.phase |= 1 << 16;
1556 CURRENT_SC = NULL;
1557
1558 } else {
1559 done(shpnt, DID_ERROR << 16);
1560 }
1561#if defined(AHA152X_STAT)
1562 } else {
1563 HOSTDATA(shpnt)->busfree_without_old_command++;
1564#endif
1565 }
1566
1567 DO_LOCK(flags);
1568
1569 if(DONE_SC) {
1570#if defined(AHA152X_STAT)
1571 action++;
1572#endif
1573
1574 if(DONE_SC->SCp.phase & check_condition) {
Christoph Hellwig5e13cdf2006-07-08 20:39:30 +02001575 struct scsi_cmnd *cmd = HOSTDATA(shpnt)->done_SC;
1576 struct aha152x_scdata *sc = SCDATA(cmd);
1577
Linus Torvalds1da177e2005-04-16 15:20:36 -07001578#if 0
1579 if(HOSTDATA(shpnt)->debug & debug_eh) {
1580 printk(ERR_LEAD "received sense: ", CMDINFO(DONE_SC));
db9dff32005-04-03 14:53:59 -05001581 scsi_print_sense("bh", DONE_SC);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001582 }
1583#endif
1584
1585 /* restore old command */
Christoph Hellwig5e13cdf2006-07-08 20:39:30 +02001586 memcpy(cmd->cmnd, sc->cmnd, sizeof(sc->cmnd));
1587 cmd->request_buffer = sc->request_buffer;
1588 cmd->request_bufflen = sc->request_bufflen;
1589 cmd->use_sg = sc->use_sg;
1590 cmd->cmd_len = sc->cmd_len;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001591
Christoph Hellwig5e13cdf2006-07-08 20:39:30 +02001592 cmd->SCp.Status = 0x02;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001593
1594 HOSTDATA(shpnt)->commands--;
1595 if (!HOSTDATA(shpnt)->commands)
1596 SETPORT(PORTA, 0); /* turn led off */
1597 } else if(DONE_SC->SCp.Status==0x02) {
1598#if defined(AHA152X_STAT)
1599 HOSTDATA(shpnt)->busfree_with_check_condition++;
1600#endif
1601#if 0
1602 DPRINTK(debug_eh, ERR_LEAD "CHECK CONDITION found\n", CMDINFO(DONE_SC));
1603#endif
1604
1605 if(!(DONE_SC->SCp.Status & not_issued)) {
1606 Scsi_Cmnd *ptr = DONE_SC;
1607 DONE_SC=NULL;
1608#if 0
1609 DPRINTK(debug_eh, ERR_LEAD "requesting sense\n", CMDINFO(ptr));
1610#endif
1611
1612 ptr->cmnd[0] = REQUEST_SENSE;
1613 ptr->cmnd[1] = 0;
1614 ptr->cmnd[2] = 0;
1615 ptr->cmnd[3] = 0;
1616 ptr->cmnd[4] = sizeof(ptr->sense_buffer);
1617 ptr->cmnd[5] = 0;
1618 ptr->cmd_len = 6;
1619 ptr->use_sg = 0;
1620 ptr->request_buffer = ptr->sense_buffer;
1621 ptr->request_bufflen = sizeof(ptr->sense_buffer);
1622
1623 DO_UNLOCK(flags);
1624 aha152x_internal_queue(ptr, NULL, check_condition, ptr->scsi_done);
1625 DO_LOCK(flags);
1626#if 0
1627 } else {
1628 DPRINTK(debug_eh, ERR_LEAD "command not issued - CHECK CONDITION ignored\n", CMDINFO(DONE_SC));
1629#endif
1630 }
1631 }
1632
1633 if(DONE_SC && DONE_SC->scsi_done) {
1634#if defined(AHA152X_DEBUG)
1635 int hostno=DONE_SC->device->host->host_no;
1636 int id=DONE_SC->device->id & 0xf;
1637 int lun=DONE_SC->device->lun & 0x7;
1638#endif
1639 Scsi_Cmnd *ptr = DONE_SC;
1640 DONE_SC=NULL;
1641
1642 /* turn led off, when no commands are in the driver */
1643 HOSTDATA(shpnt)->commands--;
1644 if (!HOSTDATA(shpnt)->commands)
1645 SETPORT(PORTA, 0); /* turn led off */
1646
1647 if(ptr->scsi_done != reset_done) {
1648 kfree(ptr->host_scribble);
1649 ptr->host_scribble=NULL;
1650 }
1651
1652 DO_UNLOCK(flags);
1653 DPRINTK(debug_done, DEBUG_LEAD "calling scsi_done(%p)\n", hostno, id, lun, ptr);
1654 ptr->scsi_done(ptr);
1655 DPRINTK(debug_done, DEBUG_LEAD "scsi_done(%p) returned\n", hostno, id, lun, ptr);
1656 DO_LOCK(flags);
1657 }
1658
1659 DONE_SC=NULL;
1660#if defined(AHA152X_STAT)
1661 } else {
1662 HOSTDATA(shpnt)->busfree_without_done_command++;
1663#endif
1664 }
1665
1666 if(ISSUE_SC)
1667 CURRENT_SC = remove_first_SC(&ISSUE_SC);
1668
1669 DO_UNLOCK(flags);
1670
1671 if(CURRENT_SC) {
1672#if defined(AHA152X_STAT)
1673 action++;
1674#endif
1675 CURRENT_SC->SCp.phase |= selecting;
1676
1677 DPRINTK(debug_selection, DEBUG_LEAD "selecting target\n", CMDINFO(CURRENT_SC));
1678
1679 /* clear selection timeout */
1680 SETPORT(SSTAT1, SELTO);
1681
1682 SETPORT(SCSIID, (shpnt->this_id << OID_) | CURRENT_SC->device->id);
1683 SETPORT(SXFRCTL1, (PARITY ? ENSPCHK : 0 ) | ENSTIMER);
1684 SETPORT(SCSISEQ, ENSELO | ENAUTOATNO | (DISCONNECTED_SC ? ENRESELI : 0));
1685 } else {
1686#if defined(AHA152X_STAT)
1687 HOSTDATA(shpnt)->busfree_without_new_command++;
1688#endif
1689 SETPORT(SCSISEQ, DISCONNECTED_SC ? ENRESELI : 0);
1690 }
1691
1692#if defined(AHA152X_STAT)
1693 if(!action)
1694 HOSTDATA(shpnt)->busfree_without_any_action++;
1695#endif
1696}
1697
1698/*
1699 * Selection done (OUT)
1700 * - queue IDENTIFY message and SDTR to selected target for message out
1701 * (ATN asserted automagically via ENAUTOATNO in busfree())
1702 */
1703static void seldo_run(struct Scsi_Host *shpnt)
1704{
1705 SETPORT(SCSISIG, 0);
1706 SETPORT(SSTAT1, CLRBUSFREE);
1707 SETPORT(SSTAT1, CLRPHASECHG);
1708
1709 CURRENT_SC->SCp.phase &= ~(selecting|not_issued);
1710
1711 SETPORT(SCSISEQ, 0);
1712
1713 if (TESTLO(SSTAT0, SELDO)) {
1714 printk(ERR_LEAD "aha152x: passing bus free condition\n", CMDINFO(CURRENT_SC));
1715 done(shpnt, DID_NO_CONNECT << 16);
1716 return;
1717 }
1718
1719 SETPORT(SSTAT0, CLRSELDO);
1720
1721 ADDMSGO(IDENTIFY(RECONNECT, CURRENT_SC->device->lun));
1722
1723 if (CURRENT_SC->SCp.phase & aborting) {
1724 ADDMSGO(ABORT);
1725 } else if (CURRENT_SC->SCp.phase & resetting) {
1726 ADDMSGO(BUS_DEVICE_RESET);
1727 } else if (SYNCNEG==0 && SYNCHRONOUS) {
1728 CURRENT_SC->SCp.phase |= syncneg;
Matthew Wilcox6ea3c0b2006-02-07 07:54:46 -07001729 MSGOLEN += spi_populate_sync_msg(&MSGO(MSGOLEN), 50, 8);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001730 SYNCNEG=1; /* negotiation in progress */
1731 }
1732
1733 SETRATE(SYNCRATE);
1734}
1735
1736/*
1737 * Selection timeout
1738 * - return command to mid-level with failure cause
1739 *
1740 */
1741static void selto_run(struct Scsi_Host *shpnt)
1742{
1743 SETPORT(SCSISEQ, 0);
1744 SETPORT(SSTAT1, CLRSELTIMO);
1745
1746 DPRINTK(debug_selection, DEBUG_LEAD "selection timeout\n", CMDINFO(CURRENT_SC));
1747
1748 if(!CURRENT_SC) {
1749 DPRINTK(debug_selection, DEBUG_LEAD "!CURRENT_SC\n", CMDINFO(CURRENT_SC));
1750 return;
1751 }
1752
1753 CURRENT_SC->SCp.phase &= ~selecting;
1754
1755 if (CURRENT_SC->SCp.phase & aborted) {
1756 DPRINTK(debug_selection, DEBUG_LEAD "aborted\n", CMDINFO(CURRENT_SC));
1757 done(shpnt, DID_ABORT << 16);
1758 } else if (TESTLO(SSTAT0, SELINGO)) {
1759 DPRINTK(debug_selection, DEBUG_LEAD "arbitration not won\n", CMDINFO(CURRENT_SC));
1760 done(shpnt, DID_BUS_BUSY << 16);
1761 } else {
1762 /* ARBITRATION won, but SELECTION failed */
1763 DPRINTK(debug_selection, DEBUG_LEAD "selection failed\n", CMDINFO(CURRENT_SC));
1764 done(shpnt, DID_NO_CONNECT << 16);
1765 }
1766}
1767
1768/*
1769 * Selection in done
1770 * - put current command back to issue queue
1771 * (reconnection of a disconnected nexus instead
1772 * of successful selection out)
1773 *
1774 */
1775static void seldi_run(struct Scsi_Host *shpnt)
1776{
1777 int selid;
1778 int target;
1779 unsigned long flags;
1780
1781 SETPORT(SCSISIG, 0);
1782 SETPORT(SSTAT0, CLRSELDI);
1783 SETPORT(SSTAT1, CLRBUSFREE);
1784 SETPORT(SSTAT1, CLRPHASECHG);
1785
1786 if(CURRENT_SC) {
1787 if(!(CURRENT_SC->SCp.phase & not_issued))
1788 printk(ERR_LEAD "command should not have been issued yet\n", CMDINFO(CURRENT_SC));
1789
1790 DPRINTK(debug_selection, ERR_LEAD "command requeued - reselection\n", CMDINFO(CURRENT_SC));
1791
1792 DO_LOCK(flags);
1793 append_SC(&ISSUE_SC, CURRENT_SC);
1794 DO_UNLOCK(flags);
1795
1796 CURRENT_SC = NULL;
1797 }
1798
1799 if(!DISCONNECTED_SC) {
1800 DPRINTK(debug_selection, DEBUG_LEAD "unexpected SELDI ", CMDINFO(CURRENT_SC));
1801 return;
1802 }
1803
1804 RECONN_TARGET=-1;
1805
1806 selid = GETPORT(SELID) & ~(1 << shpnt->this_id);
1807
1808 if (selid==0) {
1809 printk("aha152x%d: target id unknown (%02x)\n", HOSTNO, selid);
1810 return;
1811 }
1812
1813 for(target=7; !(selid & (1 << target)); target--)
1814 ;
1815
1816 if(selid & ~(1 << target)) {
1817 printk("aha152x%d: multiple targets reconnected (%02x)\n",
1818 HOSTNO, selid);
1819 }
1820
1821
1822 SETPORT(SCSIID, (shpnt->this_id << OID_) | target);
1823 SETPORT(SCSISEQ, 0);
1824
1825 SETRATE(HOSTDATA(shpnt)->syncrate[target]);
1826
1827 RECONN_TARGET=target;
1828 DPRINTK(debug_selection, DEBUG_LEAD "target %d reselected (%02x).\n", CMDINFO(CURRENT_SC), target, selid);
1829}
1830
1831/*
1832 * message in phase
1833 * - handle initial message after reconnection to identify
1834 * reconnecting nexus
1835 * - queue command on DISCONNECTED_SC on DISCONNECT message
1836 * - set completed flag on COMMAND COMPLETE
1837 * (other completition code moved to busfree_run)
1838 * - handle response to SDTR
1839 * - clear synchronous transfer agreements on BUS RESET
1840 *
1841 * FIXME: what about SAVE POINTERS, RESTORE POINTERS?
1842 *
1843 */
1844static void msgi_run(struct Scsi_Host *shpnt)
1845{
1846 for(;;) {
1847 int sstat1 = GETPORT(SSTAT1);
1848
1849 if(sstat1 & (PHASECHG|PHASEMIS|BUSFREE) || !(sstat1 & REQINIT))
1850 return;
1851
1852 if(TESTLO(SSTAT0,SPIORDY)) {
1853 DPRINTK(debug_msgi, DEBUG_LEAD "!SPIORDY\n", CMDINFO(CURRENT_SC));
1854 return;
1855 }
1856
1857 ADDMSGI(GETPORT(SCSIDAT));
1858
1859#if defined(AHA152X_DEBUG)
1860 if (HOSTDATA(shpnt)->debug & debug_msgi) {
1861 printk(INFO_LEAD "inbound message %02x ", CMDINFO(CURRENT_SC), MSGI(0));
Matthew Wilcox1abfd372005-12-15 16:22:01 -05001862 spi_print_msg(&MSGI(0));
Linus Torvalds1da177e2005-04-16 15:20:36 -07001863 printk("\n");
1864 }
1865#endif
1866
1867 if(!CURRENT_SC) {
1868 if(LASTSTATE!=seldi) {
1869 printk(KERN_ERR "aha152x%d: message in w/o current command not after reselection\n", HOSTNO);
1870 }
1871
1872 /*
1873 * Handle reselection
1874 */
1875 if(!(MSGI(0) & IDENTIFY_BASE)) {
1876 printk(KERN_ERR "aha152x%d: target didn't identify after reselection\n", HOSTNO);
1877 continue;
1878 }
1879
1880 CURRENT_SC = remove_lun_SC(&DISCONNECTED_SC, RECONN_TARGET, MSGI(0) & 0x3f);
1881
1882 if (!CURRENT_SC) {
1883 show_queues(shpnt);
1884 printk(KERN_ERR "aha152x%d: no disconnected command for target %d/%d\n", HOSTNO, RECONN_TARGET, MSGI(0) & 0x3f);
1885 continue;
1886 }
1887
1888 DPRINTK(debug_msgi, DEBUG_LEAD "target reconnected\n", CMDINFO(CURRENT_SC));
1889
1890 CURRENT_SC->SCp.Message = MSGI(0);
1891 CURRENT_SC->SCp.phase &= ~disconnected;
1892
1893 MSGILEN=0;
1894
1895 /* next message if any */
1896 continue;
1897 }
1898
1899 CURRENT_SC->SCp.Message = MSGI(0);
1900
1901 switch (MSGI(0)) {
1902 case DISCONNECT:
1903 if (!RECONNECT)
1904 printk(WARN_LEAD "target was not allowed to disconnect\n", CMDINFO(CURRENT_SC));
1905
1906 CURRENT_SC->SCp.phase |= disconnected;
1907 break;
1908
1909 case COMMAND_COMPLETE:
1910 if(CURRENT_SC->SCp.phase & completed)
1911 DPRINTK(debug_msgi, DEBUG_LEAD "again COMMAND COMPLETE\n", CMDINFO(CURRENT_SC));
1912
1913 CURRENT_SC->SCp.phase |= completed;
1914 break;
1915
1916 case MESSAGE_REJECT:
1917 if (SYNCNEG==1) {
1918 printk(INFO_LEAD "Synchronous Data Transfer Request was rejected\n", CMDINFO(CURRENT_SC));
1919 SYNCNEG=2; /* negotiation completed */
1920 } else
1921 printk(INFO_LEAD "inbound message (MESSAGE REJECT)\n", CMDINFO(CURRENT_SC));
1922 break;
1923
1924 case SAVE_POINTERS:
1925 break;
1926
1927 case RESTORE_POINTERS:
1928 break;
1929
1930 case EXTENDED_MESSAGE:
1931 if(MSGILEN<2 || MSGILEN<MSGI(1)+2) {
1932 /* not yet completed */
1933 continue;
1934 }
1935
1936 switch (MSGI(2)) {
1937 case EXTENDED_SDTR:
1938 {
1939 long ticks;
1940
1941 if (MSGI(1) != 3) {
1942 printk(ERR_LEAD "SDTR message length!=3\n", CMDINFO(CURRENT_SC));
1943 break;
1944 }
1945
1946 if (!HOSTDATA(shpnt)->synchronous)
1947 break;
1948
1949 printk(INFO_LEAD, CMDINFO(CURRENT_SC));
Matthew Wilcox1abfd372005-12-15 16:22:01 -05001950 spi_print_msg(&MSGI(0));
Linus Torvalds1da177e2005-04-16 15:20:36 -07001951 printk("\n");
1952
1953 ticks = (MSGI(3) * 4 + 49) / 50;
1954
1955 if (syncneg) {
1956 /* negotiation in progress */
1957 if (ticks > 9 || MSGI(4) < 1 || MSGI(4) > 8) {
1958 ADDMSGO(MESSAGE_REJECT);
1959 printk(INFO_LEAD "received Synchronous Data Transfer Request invalid - rejected\n", CMDINFO(CURRENT_SC));
1960 break;
1961 }
1962
1963 SYNCRATE |= ((ticks - 2) << 4) + MSGI(4);
1964 } else if (ticks <= 9 && MSGI(4) >= 1) {
1965 ADDMSGO(EXTENDED_MESSAGE);
1966 ADDMSGO(3);
1967 ADDMSGO(EXTENDED_SDTR);
1968 if (ticks < 4) {
1969 ticks = 4;
1970 ADDMSGO(50);
1971 } else
1972 ADDMSGO(MSGI(3));
1973
1974 if (MSGI(4) > 8)
1975 MSGI(4) = 8;
1976
1977 ADDMSGO(MSGI(4));
1978
1979 SYNCRATE |= ((ticks - 2) << 4) + MSGI(4);
1980 } else {
1981 /* requested SDTR is too slow, do it asynchronously */
1982 printk(INFO_LEAD "Synchronous Data Transfer Request too slow - Rejecting\n", CMDINFO(CURRENT_SC));
1983 ADDMSGO(MESSAGE_REJECT);
1984 }
1985
1986 SYNCNEG=2; /* negotiation completed */
1987 SETRATE(SYNCRATE);
1988 }
1989 break;
1990
1991 case BUS_DEVICE_RESET:
1992 {
1993 int i;
1994
1995 for(i=0; i<8; i++) {
1996 HOSTDATA(shpnt)->syncrate[i]=0;
1997 HOSTDATA(shpnt)->syncneg[i]=0;
1998 }
1999
2000 }
2001 break;
2002
2003 case EXTENDED_MODIFY_DATA_POINTER:
2004 case EXTENDED_EXTENDED_IDENTIFY:
2005 case EXTENDED_WDTR:
2006 default:
2007 ADDMSGO(MESSAGE_REJECT);
2008 break;
2009 }
2010 break;
2011 }
2012
2013 MSGILEN=0;
2014 }
2015}
2016
2017static void msgi_end(struct Scsi_Host *shpnt)
2018{
2019 if(MSGILEN>0)
2020 printk(WARN_LEAD "target left before message completed (%d)\n", CMDINFO(CURRENT_SC), MSGILEN);
2021
2022 if (MSGOLEN > 0 && !(GETPORT(SSTAT1) & BUSFREE)) {
2023 DPRINTK(debug_msgi, DEBUG_LEAD "msgo pending\n", CMDINFO(CURRENT_SC));
2024 SETPORT(SCSISIG, P_MSGI | SIG_ATNO);
2025 }
2026}
2027
2028/*
2029 * message out phase
2030 *
2031 */
2032static void msgo_init(struct Scsi_Host *shpnt)
2033{
2034 if(MSGOLEN==0) {
2035 if((CURRENT_SC->SCp.phase & syncneg) && SYNCNEG==2 && SYNCRATE==0) {
2036 ADDMSGO(IDENTIFY(RECONNECT, CURRENT_SC->device->lun));
2037 } else {
2038 printk(INFO_LEAD "unexpected MESSAGE OUT phase; rejecting\n", CMDINFO(CURRENT_SC));
2039 ADDMSGO(MESSAGE_REJECT);
2040 }
2041 }
2042
2043#if defined(AHA152X_DEBUG)
2044 if(HOSTDATA(shpnt)->debug & debug_msgo) {
2045 int i;
2046
2047 printk(DEBUG_LEAD "messages( ", CMDINFO(CURRENT_SC));
Matthew Wilcox1abfd372005-12-15 16:22:01 -05002048 for (i=0; i<MSGOLEN; i+=spi_print_msg(&MSGO(i)), printk(" "))
Linus Torvalds1da177e2005-04-16 15:20:36 -07002049 ;
2050 printk(")\n");
2051 }
2052#endif
2053}
2054
2055/*
2056 * message out phase
2057 *
2058 */
2059static void msgo_run(struct Scsi_Host *shpnt)
2060{
2061 if(MSGO_I==MSGOLEN)
2062 DPRINTK(debug_msgo, DEBUG_LEAD "messages all sent (%d/%d)\n", CMDINFO(CURRENT_SC), MSGO_I, MSGOLEN);
2063
2064 while(MSGO_I<MSGOLEN) {
2065 DPRINTK(debug_msgo, DEBUG_LEAD "message byte %02x (%d/%d)\n", CMDINFO(CURRENT_SC), MSGO(MSGO_I), MSGO_I, MSGOLEN);
2066
2067 if(TESTLO(SSTAT0, SPIORDY)) {
2068 DPRINTK(debug_msgo, DEBUG_LEAD "!SPIORDY\n", CMDINFO(CURRENT_SC));
2069 return;
2070 }
2071
2072 if (MSGO_I==MSGOLEN-1) {
2073 /* Leave MESSAGE OUT after transfer */
2074 SETPORT(SSTAT1, CLRATNO);
2075 }
2076
2077
2078 if (MSGO(MSGO_I) & IDENTIFY_BASE)
2079 CURRENT_SC->SCp.phase |= identified;
2080
2081 if (MSGO(MSGO_I)==ABORT)
2082 CURRENT_SC->SCp.phase |= aborted;
2083
2084 if (MSGO(MSGO_I)==BUS_DEVICE_RESET)
2085 CURRENT_SC->SCp.phase |= resetted;
2086
2087 SETPORT(SCSIDAT, MSGO(MSGO_I++));
2088 }
2089}
2090
2091static void msgo_end(struct Scsi_Host *shpnt)
2092{
2093 if(MSGO_I<MSGOLEN) {
2094 printk(ERR_LEAD "message sent incompletely (%d/%d)\n", CMDINFO(CURRENT_SC), MSGO_I, MSGOLEN);
2095 if(SYNCNEG==1) {
2096 printk(INFO_LEAD "Synchronous Data Transfer Request was rejected\n", CMDINFO(CURRENT_SC));
2097 SYNCNEG=2;
2098 }
2099 }
2100
2101 MSGO_I = 0;
2102 MSGOLEN = 0;
2103}
2104
2105/*
2106 * command phase
2107 *
2108 */
2109static void cmd_init(struct Scsi_Host *shpnt)
2110{
2111 if (CURRENT_SC->SCp.sent_command) {
2112 printk(ERR_LEAD "command already sent\n", CMDINFO(CURRENT_SC));
2113 done(shpnt, DID_ERROR << 16);
2114 return;
2115 }
2116
2117#if defined(AHA152X_DEBUG)
2118 if (HOSTDATA(shpnt)->debug & debug_cmd) {
2119 printk(DEBUG_LEAD "cmd_init: ", CMDINFO(CURRENT_SC));
db9dff32005-04-03 14:53:59 -05002120 __scsi_print_command(CURRENT_SC->cmnd);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002121 }
2122#endif
2123
2124 CMD_I=0;
2125}
2126
2127/*
2128 * command phase
2129 *
2130 */
2131static void cmd_run(struct Scsi_Host *shpnt)
2132{
2133 if(CMD_I==CURRENT_SC->cmd_len) {
2134 DPRINTK(debug_cmd, DEBUG_LEAD "command already completely sent (%d/%d)", CMDINFO(CURRENT_SC), CMD_I, CURRENT_SC->cmd_len);
2135 disp_ports(shpnt);
2136 }
2137
2138 while(CMD_I<CURRENT_SC->cmd_len) {
2139 DPRINTK(debug_cmd, DEBUG_LEAD "command byte %02x (%d/%d)\n", CMDINFO(CURRENT_SC), CURRENT_SC->cmnd[CMD_I], CMD_I, CURRENT_SC->cmd_len);
2140
2141 if(TESTLO(SSTAT0, SPIORDY)) {
2142 DPRINTK(debug_cmd, DEBUG_LEAD "!SPIORDY\n", CMDINFO(CURRENT_SC));
2143 return;
2144 }
2145
2146 SETPORT(SCSIDAT, CURRENT_SC->cmnd[CMD_I++]);
2147 }
2148}
2149
2150static void cmd_end(struct Scsi_Host *shpnt)
2151{
2152 if(CMD_I<CURRENT_SC->cmd_len)
2153 printk(ERR_LEAD "command sent incompletely (%d/%d)\n", CMDINFO(CURRENT_SC), CMD_I, CURRENT_SC->cmd_len);
2154 else
2155 CURRENT_SC->SCp.sent_command++;
2156}
2157
2158/*
2159 * status phase
2160 *
2161 */
2162static void status_run(struct Scsi_Host *shpnt)
2163{
2164 if(TESTLO(SSTAT0,SPIORDY)) {
2165 DPRINTK(debug_status, DEBUG_LEAD "!SPIORDY\n", CMDINFO(CURRENT_SC));
2166 return;
2167 }
2168
2169 CURRENT_SC->SCp.Status = GETPORT(SCSIDAT);
2170
2171#if defined(AHA152X_DEBUG)
2172 if (HOSTDATA(shpnt)->debug & debug_status) {
2173 printk(DEBUG_LEAD "inbound status %02x ", CMDINFO(CURRENT_SC), CURRENT_SC->SCp.Status);
db9dff32005-04-03 14:53:59 -05002174 scsi_print_status(CURRENT_SC->SCp.Status);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002175 printk("\n");
2176 }
2177#endif
2178}
2179
2180/*
2181 * data in phase
2182 *
2183 */
2184static void datai_init(struct Scsi_Host *shpnt)
2185{
2186 SETPORT(DMACNTRL0, RSTFIFO);
2187 SETPORT(DMACNTRL0, RSTFIFO|ENDMA);
2188
2189 SETPORT(SXFRCTL0, CH1|CLRSTCNT);
2190 SETPORT(SXFRCTL0, CH1|SCSIEN|DMAEN);
2191
2192 SETPORT(SIMODE0, 0);
2193 SETPORT(SIMODE1, ENSCSIPERR | ENSCSIRST | ENPHASEMIS | ENBUSFREE);
2194
2195 DATA_LEN=0;
2196 DPRINTK(debug_datai,
2197 DEBUG_LEAD "datai_init: request_bufflen=%d resid=%d\n",
2198 CMDINFO(CURRENT_SC), CURRENT_SC->request_bufflen, CURRENT_SC->resid);
2199}
2200
2201static void datai_run(struct Scsi_Host *shpnt)
2202{
2203 unsigned long the_time;
2204 int fifodata, data_count;
2205
2206 /*
2207 * loop while the phase persists or the fifos are not empty
2208 *
2209 */
2210 while(TESTLO(DMASTAT, INTSTAT) || TESTLO(DMASTAT, DFIFOEMP) || TESTLO(SSTAT2, SEMPTY)) {
2211 /* FIXME: maybe this should be done by setting up
2212 * STCNT to trigger ENSWRAP interrupt, instead of
2213 * polling for DFIFOFULL
2214 */
2215 the_time=jiffies + 100*HZ;
2216 while(TESTLO(DMASTAT, DFIFOFULL|INTSTAT) && time_before(jiffies,the_time))
2217 barrier();
2218
2219 if(TESTLO(DMASTAT, DFIFOFULL|INTSTAT)) {
2220 printk(ERR_LEAD "datai timeout", CMDINFO(CURRENT_SC));
2221 disp_ports(shpnt);
2222 break;
2223 }
2224
2225 if(TESTHI(DMASTAT, DFIFOFULL)) {
2226 fifodata = 128;
2227 } else {
2228 the_time=jiffies + 100*HZ;
2229 while(TESTLO(SSTAT2, SEMPTY) && time_before(jiffies,the_time))
2230 barrier();
2231
2232 if(TESTLO(SSTAT2, SEMPTY)) {
2233 printk(ERR_LEAD "datai sempty timeout", CMDINFO(CURRENT_SC));
2234 disp_ports(shpnt);
2235 break;
2236 }
2237
2238 fifodata = GETPORT(FIFOSTAT);
2239 }
2240
2241 if(CURRENT_SC->SCp.this_residual>0) {
2242 while(fifodata>0 && CURRENT_SC->SCp.this_residual>0) {
2243 data_count = fifodata>CURRENT_SC->SCp.this_residual ?
2244 CURRENT_SC->SCp.this_residual :
2245 fifodata;
2246 fifodata -= data_count;
2247
2248 if(data_count & 1) {
2249 DPRINTK(debug_datai, DEBUG_LEAD "8bit\n", CMDINFO(CURRENT_SC));
2250 SETPORT(DMACNTRL0, ENDMA|_8BIT);
2251 *CURRENT_SC->SCp.ptr++ = GETPORT(DATAPORT);
2252 CURRENT_SC->SCp.this_residual--;
2253 DATA_LEN++;
2254 SETPORT(DMACNTRL0, ENDMA);
2255 }
2256
2257 if(data_count > 1) {
2258 DPRINTK(debug_datai, DEBUG_LEAD "16bit(%d)\n", CMDINFO(CURRENT_SC), data_count);
2259 data_count >>= 1;
2260 insw(DATAPORT, CURRENT_SC->SCp.ptr, data_count);
2261 CURRENT_SC->SCp.ptr += 2 * data_count;
2262 CURRENT_SC->SCp.this_residual -= 2 * data_count;
2263 DATA_LEN += 2 * data_count;
2264 }
2265
2266 if(CURRENT_SC->SCp.this_residual==0 && CURRENT_SC->SCp.buffers_residual>0) {
2267 /* advance to next buffer */
2268 CURRENT_SC->SCp.buffers_residual--;
2269 CURRENT_SC->SCp.buffer++;
2270 CURRENT_SC->SCp.ptr = SG_ADDRESS(CURRENT_SC->SCp.buffer);
2271 CURRENT_SC->SCp.this_residual = CURRENT_SC->SCp.buffer->length;
2272 }
2273 }
2274 } else if(fifodata>0) {
2275 printk(ERR_LEAD "no buffers left for %d(%d) bytes (data overrun!?)\n", CMDINFO(CURRENT_SC), fifodata, GETPORT(FIFOSTAT));
2276 SETPORT(DMACNTRL0, ENDMA|_8BIT);
2277 while(fifodata>0) {
2278 int data;
2279 data=GETPORT(DATAPORT);
2280 DPRINTK(debug_datai, DEBUG_LEAD "data=%02x\n", CMDINFO(CURRENT_SC), data);
2281 fifodata--;
2282 DATA_LEN++;
2283 }
2284 SETPORT(DMACNTRL0, ENDMA|_8BIT);
2285 }
2286 }
2287
2288 if(TESTLO(DMASTAT, INTSTAT) ||
2289 TESTLO(DMASTAT, DFIFOEMP) ||
2290 TESTLO(SSTAT2, SEMPTY) ||
2291 GETPORT(FIFOSTAT)>0) {
2292 /*
2293 * something went wrong, if there's something left in the fifos
2294 * or the phase didn't change
2295 */
2296 printk(ERR_LEAD "fifos should be empty and phase should have changed\n", CMDINFO(CURRENT_SC));
2297 disp_ports(shpnt);
2298 }
2299
2300 if(DATA_LEN!=GETSTCNT()) {
2301 printk(ERR_LEAD
2302 "manual transfer count differs from automatic (count=%d;stcnt=%d;diff=%d;fifostat=%d)",
2303 CMDINFO(CURRENT_SC), DATA_LEN, GETSTCNT(), GETSTCNT()-DATA_LEN, GETPORT(FIFOSTAT));
2304 disp_ports(shpnt);
2305 mdelay(10000);
2306 }
2307}
2308
2309static void datai_end(struct Scsi_Host *shpnt)
2310{
2311 CURRENT_SC->resid -= GETSTCNT();
2312
2313 DPRINTK(debug_datai,
2314 DEBUG_LEAD "datai_end: request_bufflen=%d resid=%d stcnt=%d\n",
2315 CMDINFO(CURRENT_SC), CURRENT_SC->request_bufflen, CURRENT_SC->resid, GETSTCNT());
2316
2317 SETPORT(SXFRCTL0, CH1|CLRSTCNT);
2318 SETPORT(DMACNTRL0, 0);
2319}
2320
2321/*
2322 * data out phase
2323 *
2324 */
2325static void datao_init(struct Scsi_Host *shpnt)
2326{
2327 SETPORT(DMACNTRL0, WRITE_READ | RSTFIFO);
2328 SETPORT(DMACNTRL0, WRITE_READ | ENDMA);
2329
2330 SETPORT(SXFRCTL0, CH1|CLRSTCNT);
2331 SETPORT(SXFRCTL0, CH1|SCSIEN|DMAEN);
2332
2333 SETPORT(SIMODE0, 0);
2334 SETPORT(SIMODE1, ENSCSIPERR | ENSCSIRST | ENPHASEMIS | ENBUSFREE );
2335
2336 DATA_LEN = CURRENT_SC->resid;
2337
2338 DPRINTK(debug_datao,
2339 DEBUG_LEAD "datao_init: request_bufflen=%d; resid=%d\n",
2340 CMDINFO(CURRENT_SC), CURRENT_SC->request_bufflen, CURRENT_SC->resid);
2341}
2342
2343static void datao_run(struct Scsi_Host *shpnt)
2344{
2345 unsigned long the_time;
2346 int data_count;
2347
2348 /* until phase changes or all data sent */
2349 while(TESTLO(DMASTAT, INTSTAT) && CURRENT_SC->SCp.this_residual>0) {
2350 data_count = 128;
2351 if(data_count > CURRENT_SC->SCp.this_residual)
2352 data_count=CURRENT_SC->SCp.this_residual;
2353
2354 if(TESTLO(DMASTAT, DFIFOEMP)) {
2355 printk(ERR_LEAD "datao fifo not empty (%d)", CMDINFO(CURRENT_SC), GETPORT(FIFOSTAT));
2356 disp_ports(shpnt);
2357 break;
2358 }
2359
2360 if(data_count & 1) {
2361 SETPORT(DMACNTRL0,WRITE_READ|ENDMA|_8BIT);
2362 SETPORT(DATAPORT, *CURRENT_SC->SCp.ptr++);
2363 CURRENT_SC->SCp.this_residual--;
2364 CURRENT_SC->resid--;
2365 SETPORT(DMACNTRL0,WRITE_READ|ENDMA);
2366 }
2367
2368 if(data_count > 1) {
2369 data_count >>= 1;
2370 outsw(DATAPORT, CURRENT_SC->SCp.ptr, data_count);
2371 CURRENT_SC->SCp.ptr += 2 * data_count;
2372 CURRENT_SC->SCp.this_residual -= 2 * data_count;
2373 CURRENT_SC->resid -= 2 * data_count;
2374 }
2375
2376 if(CURRENT_SC->SCp.this_residual==0 && CURRENT_SC->SCp.buffers_residual>0) {
2377 /* advance to next buffer */
2378 CURRENT_SC->SCp.buffers_residual--;
2379 CURRENT_SC->SCp.buffer++;
2380 CURRENT_SC->SCp.ptr = SG_ADDRESS(CURRENT_SC->SCp.buffer);
2381 CURRENT_SC->SCp.this_residual = CURRENT_SC->SCp.buffer->length;
2382 }
2383
2384 the_time=jiffies + 100*HZ;
2385 while(TESTLO(DMASTAT, DFIFOEMP|INTSTAT) && time_before(jiffies,the_time))
2386 barrier();
2387
2388 if(TESTLO(DMASTAT, DFIFOEMP|INTSTAT)) {
2389 printk(ERR_LEAD "dataout timeout", CMDINFO(CURRENT_SC));
2390 disp_ports(shpnt);
2391 break;
2392 }
2393 }
2394}
2395
2396static void datao_end(struct Scsi_Host *shpnt)
2397{
2398 if(TESTLO(DMASTAT, DFIFOEMP)) {
2399 int data_count = (DATA_LEN - CURRENT_SC->resid) - GETSTCNT();
2400
2401 DPRINTK(debug_datao, DEBUG_LEAD "datao: %d bytes to resend (%d written, %d transferred)\n",
2402 CMDINFO(CURRENT_SC),
2403 data_count,
2404 DATA_LEN-CURRENT_SC->resid,
2405 GETSTCNT());
2406
2407 CURRENT_SC->resid += data_count;
2408
2409 if(CURRENT_SC->use_sg) {
2410 data_count -= CURRENT_SC->SCp.ptr - SG_ADDRESS(CURRENT_SC->SCp.buffer);
2411 while(data_count>0) {
2412 CURRENT_SC->SCp.buffer--;
2413 CURRENT_SC->SCp.buffers_residual++;
2414 data_count -= CURRENT_SC->SCp.buffer->length;
2415 }
2416 CURRENT_SC->SCp.ptr = SG_ADDRESS(CURRENT_SC->SCp.buffer) - data_count;
2417 CURRENT_SC->SCp.this_residual = CURRENT_SC->SCp.buffer->length + data_count;
2418 } else {
2419 CURRENT_SC->SCp.ptr -= data_count;
2420 CURRENT_SC->SCp.this_residual += data_count;
2421 }
2422 }
2423
2424 DPRINTK(debug_datao, DEBUG_LEAD "datao_end: request_bufflen=%d; resid=%d; stcnt=%d\n",
2425 CMDINFO(CURRENT_SC),
2426 CURRENT_SC->request_bufflen,
2427 CURRENT_SC->resid,
2428 GETSTCNT());
2429
2430 SETPORT(SXFRCTL0, CH1|CLRCH1|CLRSTCNT);
2431 SETPORT(SXFRCTL0, CH1);
2432
2433 SETPORT(DMACNTRL0, 0);
2434}
2435
2436/*
2437 * figure out what state we're in
2438 *
2439 */
2440static int update_state(struct Scsi_Host *shpnt)
2441{
2442 int dataphase=0;
2443 unsigned int stat0 = GETPORT(SSTAT0);
2444 unsigned int stat1 = GETPORT(SSTAT1);
2445
2446 PREVSTATE = STATE;
2447 STATE=unknown;
2448
2449 if(stat1 & SCSIRSTI) {
2450 STATE=rsti;
2451 SETPORT(SCSISEQ,0);
2452 SETPORT(SSTAT1,SCSIRSTI);
2453 } else if(stat0 & SELDI && PREVSTATE==busfree) {
2454 STATE=seldi;
2455 } else if(stat0 & SELDO && CURRENT_SC && (CURRENT_SC->SCp.phase & selecting)) {
2456 STATE=seldo;
2457 } else if(stat1 & SELTO) {
2458 STATE=selto;
2459 } else if(stat1 & BUSFREE) {
2460 STATE=busfree;
2461 SETPORT(SSTAT1,BUSFREE);
2462 } else if(stat1 & SCSIPERR) {
2463 STATE=parerr;
2464 SETPORT(SSTAT1,SCSIPERR);
2465 } else if(stat1 & REQINIT) {
2466 switch(GETPORT(SCSISIG) & P_MASK) {
2467 case P_MSGI: STATE=msgi; break;
2468 case P_MSGO: STATE=msgo; break;
2469 case P_DATAO: STATE=datao; break;
2470 case P_DATAI: STATE=datai; break;
2471 case P_STATUS: STATE=status; break;
2472 case P_CMD: STATE=cmd; break;
2473 }
2474 dataphase=1;
2475 }
2476
2477 if((stat0 & SELDI) && STATE!=seldi && !dataphase) {
2478 printk(INFO_LEAD "reselection missed?", CMDINFO(CURRENT_SC));
2479 disp_ports(shpnt);
2480 }
2481
2482 if(STATE!=PREVSTATE) {
2483 LASTSTATE=PREVSTATE;
2484 }
2485
2486 return dataphase;
2487}
2488
2489/*
2490 * handle parity error
2491 *
2492 * FIXME: in which phase?
2493 *
2494 */
2495static void parerr_run(struct Scsi_Host *shpnt)
2496{
2497 printk(ERR_LEAD "parity error\n", CMDINFO(CURRENT_SC));
2498 done(shpnt, DID_PARITY << 16);
2499}
2500
2501/*
2502 * handle reset in
2503 *
2504 */
2505static void rsti_run(struct Scsi_Host *shpnt)
2506{
2507 Scsi_Cmnd *ptr;
2508
2509 printk(KERN_NOTICE "aha152x%d: scsi reset in\n", HOSTNO);
2510
2511 ptr=DISCONNECTED_SC;
2512 while(ptr) {
2513 Scsi_Cmnd *next = SCNEXT(ptr);
2514
2515 if (!ptr->device->soft_reset) {
2516 remove_SC(&DISCONNECTED_SC, ptr);
2517
2518 kfree(ptr->host_scribble);
2519 ptr->host_scribble=NULL;
2520
2521 ptr->result = DID_RESET << 16;
2522 ptr->scsi_done(ptr);
2523 }
2524
2525 ptr = next;
2526 }
2527
2528 if(CURRENT_SC && !CURRENT_SC->device->soft_reset)
2529 done(shpnt, DID_RESET << 16 );
2530}
2531
2532
2533/*
2534 * bottom-half handler
2535 *
2536 */
2537static void is_complete(struct Scsi_Host *shpnt)
2538{
2539 int dataphase;
2540 unsigned long flags;
2541 int pending;
2542
Jürgen E. Fischere2482fa2006-02-19 00:31:51 +01002543 if(!shpnt)
2544 return;
2545
Linus Torvalds1da177e2005-04-16 15:20:36 -07002546 DO_LOCK(flags);
Jürgen E. Fischere2482fa2006-02-19 00:31:51 +01002547
2548 if( HOSTDATA(shpnt)->service==0 ) {
2549 DO_UNLOCK(flags);
2550 return;
2551 }
2552
2553 HOSTDATA(shpnt)->service = 0;
2554
Linus Torvalds1da177e2005-04-16 15:20:36 -07002555 if(HOSTDATA(shpnt)->in_intr) {
2556 DO_UNLOCK(flags);
2557 /* aha152x_error never returns.. */
2558 aha152x_error(shpnt, "bottom-half already running!?");
2559 }
2560 HOSTDATA(shpnt)->in_intr++;
2561
2562 /*
2563 * loop while there are interrupt conditions pending
2564 *
2565 */
2566 do {
2567 unsigned long start = jiffies;
2568 DO_UNLOCK(flags);
2569
2570 dataphase=update_state(shpnt);
2571
2572 DPRINTK(debug_phases, LEAD "start %s %s(%s)\n", CMDINFO(CURRENT_SC), states[STATE].name, states[PREVSTATE].name, states[LASTSTATE].name);
2573
2574 /*
2575 * end previous state
2576 *
2577 */
2578 if(PREVSTATE!=STATE && states[PREVSTATE].end)
2579 states[PREVSTATE].end(shpnt);
2580
2581 /*
2582 * disable SPIO mode if previous phase used it
2583 * and this one doesn't
2584 *
2585 */
2586 if(states[PREVSTATE].spio && !states[STATE].spio) {
2587 SETPORT(SXFRCTL0, CH1);
2588 SETPORT(DMACNTRL0, 0);
2589 if(CURRENT_SC)
2590 CURRENT_SC->SCp.phase &= ~spiordy;
2591 }
2592
2593 /*
2594 * accept current dataphase phase
2595 *
2596 */
2597 if(dataphase) {
2598 SETPORT(SSTAT0, REQINIT);
2599 SETPORT(SCSISIG, GETPORT(SCSISIG) & P_MASK);
2600 SETPORT(SSTAT1, PHASECHG);
2601 }
2602
2603 /*
2604 * enable SPIO mode if previous didn't use it
2605 * and this one does
2606 *
2607 */
2608 if(!states[PREVSTATE].spio && states[STATE].spio) {
2609 SETPORT(DMACNTRL0, 0);
2610 SETPORT(SXFRCTL0, CH1|SPIOEN);
2611 if(CURRENT_SC)
2612 CURRENT_SC->SCp.phase |= spiordy;
2613 }
2614
2615 /*
2616 * initialize for new state
2617 *
2618 */
2619 if(PREVSTATE!=STATE && states[STATE].init)
2620 states[STATE].init(shpnt);
2621
2622 /*
2623 * handle current state
2624 *
2625 */
2626 if(states[STATE].run)
2627 states[STATE].run(shpnt);
2628 else
2629 printk(ERR_LEAD "unexpected state (%x)\n", CMDINFO(CURRENT_SC), STATE);
2630
2631 /*
2632 * setup controller to interrupt on
2633 * the next expected condition and
2634 * loop if it's already there
2635 *
2636 */
2637 DO_LOCK(flags);
2638 pending=setup_expected_interrupts(shpnt);
2639#if defined(AHA152X_STAT)
2640 HOSTDATA(shpnt)->count[STATE]++;
2641 if(PREVSTATE!=STATE)
2642 HOSTDATA(shpnt)->count_trans[STATE]++;
2643 HOSTDATA(shpnt)->time[STATE] += jiffies-start;
2644#endif
2645
2646 DPRINTK(debug_phases, LEAD "end %s %s(%s)\n", CMDINFO(CURRENT_SC), states[STATE].name, states[PREVSTATE].name, states[LASTSTATE].name);
2647 } while(pending);
2648
2649 /*
2650 * enable interrupts and leave bottom-half
2651 *
2652 */
2653 HOSTDATA(shpnt)->in_intr--;
2654 SETBITS(DMACNTRL0, INTEN);
2655 DO_UNLOCK(flags);
2656}
2657
2658
2659/*
2660 * Dump the current driver status and panic
2661 */
2662static void aha152x_error(struct Scsi_Host *shpnt, char *msg)
2663{
2664 printk(KERN_EMERG "\naha152x%d: %s\n", HOSTNO, msg);
2665 show_queues(shpnt);
2666 panic("aha152x panic\n");
2667}
2668
2669/*
2670 * Display registers of AIC-6260
2671 */
2672static void disp_ports(struct Scsi_Host *shpnt)
2673{
2674#if defined(AHA152X_DEBUG)
2675 int s;
2676
2677 printk("\n%s: %s(%s) ",
2678 CURRENT_SC ? "busy" : "waiting",
2679 states[STATE].name,
2680 states[PREVSTATE].name);
2681
2682 s = GETPORT(SCSISEQ);
2683 printk("SCSISEQ( ");
2684 if (s & TEMODEO)
2685 printk("TARGET MODE ");
2686 if (s & ENSELO)
2687 printk("SELO ");
2688 if (s & ENSELI)
2689 printk("SELI ");
2690 if (s & ENRESELI)
2691 printk("RESELI ");
2692 if (s & ENAUTOATNO)
2693 printk("AUTOATNO ");
2694 if (s & ENAUTOATNI)
2695 printk("AUTOATNI ");
2696 if (s & ENAUTOATNP)
2697 printk("AUTOATNP ");
2698 if (s & SCSIRSTO)
2699 printk("SCSIRSTO ");
2700 printk(");");
2701
2702 printk(" SCSISIG(");
2703 s = GETPORT(SCSISIG);
2704 switch (s & P_MASK) {
2705 case P_DATAO:
2706 printk("DATA OUT");
2707 break;
2708 case P_DATAI:
2709 printk("DATA IN");
2710 break;
2711 case P_CMD:
2712 printk("COMMAND");
2713 break;
2714 case P_STATUS:
2715 printk("STATUS");
2716 break;
2717 case P_MSGO:
2718 printk("MESSAGE OUT");
2719 break;
2720 case P_MSGI:
2721 printk("MESSAGE IN");
2722 break;
2723 default:
2724 printk("*invalid*");
2725 break;
2726 }
2727
2728 printk("); ");
2729
2730 printk("INTSTAT (%s); ", TESTHI(DMASTAT, INTSTAT) ? "hi" : "lo");
2731
2732 printk("SSTAT( ");
2733 s = GETPORT(SSTAT0);
2734 if (s & TARGET)
2735 printk("TARGET ");
2736 if (s & SELDO)
2737 printk("SELDO ");
2738 if (s & SELDI)
2739 printk("SELDI ");
2740 if (s & SELINGO)
2741 printk("SELINGO ");
2742 if (s & SWRAP)
2743 printk("SWRAP ");
2744 if (s & SDONE)
2745 printk("SDONE ");
2746 if (s & SPIORDY)
2747 printk("SPIORDY ");
2748 if (s & DMADONE)
2749 printk("DMADONE ");
2750
2751 s = GETPORT(SSTAT1);
2752 if (s & SELTO)
2753 printk("SELTO ");
2754 if (s & ATNTARG)
2755 printk("ATNTARG ");
2756 if (s & SCSIRSTI)
2757 printk("SCSIRSTI ");
2758 if (s & PHASEMIS)
2759 printk("PHASEMIS ");
2760 if (s & BUSFREE)
2761 printk("BUSFREE ");
2762 if (s & SCSIPERR)
2763 printk("SCSIPERR ");
2764 if (s & PHASECHG)
2765 printk("PHASECHG ");
2766 if (s & REQINIT)
2767 printk("REQINIT ");
2768 printk("); ");
2769
2770
2771 printk("SSTAT( ");
2772
2773 s = GETPORT(SSTAT0) & GETPORT(SIMODE0);
2774
2775 if (s & TARGET)
2776 printk("TARGET ");
2777 if (s & SELDO)
2778 printk("SELDO ");
2779 if (s & SELDI)
2780 printk("SELDI ");
2781 if (s & SELINGO)
2782 printk("SELINGO ");
2783 if (s & SWRAP)
2784 printk("SWRAP ");
2785 if (s & SDONE)
2786 printk("SDONE ");
2787 if (s & SPIORDY)
2788 printk("SPIORDY ");
2789 if (s & DMADONE)
2790 printk("DMADONE ");
2791
2792 s = GETPORT(SSTAT1) & GETPORT(SIMODE1);
2793
2794 if (s & SELTO)
2795 printk("SELTO ");
2796 if (s & ATNTARG)
2797 printk("ATNTARG ");
2798 if (s & SCSIRSTI)
2799 printk("SCSIRSTI ");
2800 if (s & PHASEMIS)
2801 printk("PHASEMIS ");
2802 if (s & BUSFREE)
2803 printk("BUSFREE ");
2804 if (s & SCSIPERR)
2805 printk("SCSIPERR ");
2806 if (s & PHASECHG)
2807 printk("PHASECHG ");
2808 if (s & REQINIT)
2809 printk("REQINIT ");
2810 printk("); ");
2811
2812 printk("SXFRCTL0( ");
2813
2814 s = GETPORT(SXFRCTL0);
2815 if (s & SCSIEN)
2816 printk("SCSIEN ");
2817 if (s & DMAEN)
2818 printk("DMAEN ");
2819 if (s & CH1)
2820 printk("CH1 ");
2821 if (s & CLRSTCNT)
2822 printk("CLRSTCNT ");
2823 if (s & SPIOEN)
2824 printk("SPIOEN ");
2825 if (s & CLRCH1)
2826 printk("CLRCH1 ");
2827 printk("); ");
2828
2829 printk("SIGNAL( ");
2830
2831 s = GETPORT(SCSISIG);
2832 if (s & SIG_ATNI)
2833 printk("ATNI ");
2834 if (s & SIG_SELI)
2835 printk("SELI ");
2836 if (s & SIG_BSYI)
2837 printk("BSYI ");
2838 if (s & SIG_REQI)
2839 printk("REQI ");
2840 if (s & SIG_ACKI)
2841 printk("ACKI ");
2842 printk("); ");
2843
2844 printk("SELID (%02x), ", GETPORT(SELID));
2845
2846 printk("STCNT (%d), ", GETSTCNT());
2847
2848 printk("SSTAT2( ");
2849
2850 s = GETPORT(SSTAT2);
2851 if (s & SOFFSET)
2852 printk("SOFFSET ");
2853 if (s & SEMPTY)
2854 printk("SEMPTY ");
2855 if (s & SFULL)
2856 printk("SFULL ");
2857 printk("); SFCNT (%d); ", s & (SFULL | SFCNT));
2858
2859 s = GETPORT(SSTAT3);
2860 printk("SCSICNT (%d), OFFCNT(%d), ", (s & 0xf0) >> 4, s & 0x0f);
2861
2862 printk("SSTAT4( ");
2863 s = GETPORT(SSTAT4);
2864 if (s & SYNCERR)
2865 printk("SYNCERR ");
2866 if (s & FWERR)
2867 printk("FWERR ");
2868 if (s & FRERR)
2869 printk("FRERR ");
2870 printk("); ");
2871
2872 printk("DMACNTRL0( ");
2873 s = GETPORT(DMACNTRL0);
2874 printk("%s ", s & _8BIT ? "8BIT" : "16BIT");
2875 printk("%s ", s & DMA ? "DMA" : "PIO");
2876 printk("%s ", s & WRITE_READ ? "WRITE" : "READ");
2877 if (s & ENDMA)
2878 printk("ENDMA ");
2879 if (s & INTEN)
2880 printk("INTEN ");
2881 if (s & RSTFIFO)
2882 printk("RSTFIFO ");
2883 if (s & SWINT)
2884 printk("SWINT ");
2885 printk("); ");
2886
2887 printk("DMASTAT( ");
2888 s = GETPORT(DMASTAT);
2889 if (s & ATDONE)
2890 printk("ATDONE ");
2891 if (s & WORDRDY)
2892 printk("WORDRDY ");
2893 if (s & DFIFOFULL)
2894 printk("DFIFOFULL ");
2895 if (s & DFIFOEMP)
2896 printk("DFIFOEMP ");
2897 printk(")\n");
2898#endif
2899}
2900
2901/*
2902 * display enabled interrupts
2903 */
2904static void disp_enintr(struct Scsi_Host *shpnt)
2905{
2906 int s;
2907
2908 printk(KERN_DEBUG "enabled interrupts ( ");
2909
2910 s = GETPORT(SIMODE0);
2911 if (s & ENSELDO)
2912 printk("ENSELDO ");
2913 if (s & ENSELDI)
2914 printk("ENSELDI ");
2915 if (s & ENSELINGO)
2916 printk("ENSELINGO ");
2917 if (s & ENSWRAP)
2918 printk("ENSWRAP ");
2919 if (s & ENSDONE)
2920 printk("ENSDONE ");
2921 if (s & ENSPIORDY)
2922 printk("ENSPIORDY ");
2923 if (s & ENDMADONE)
2924 printk("ENDMADONE ");
2925
2926 s = GETPORT(SIMODE1);
2927 if (s & ENSELTIMO)
2928 printk("ENSELTIMO ");
2929 if (s & ENATNTARG)
2930 printk("ENATNTARG ");
2931 if (s & ENPHASEMIS)
2932 printk("ENPHASEMIS ");
2933 if (s & ENBUSFREE)
2934 printk("ENBUSFREE ");
2935 if (s & ENSCSIPERR)
2936 printk("ENSCSIPERR ");
2937 if (s & ENPHASECHG)
2938 printk("ENPHASECHG ");
2939 if (s & ENREQINIT)
2940 printk("ENREQINIT ");
2941 printk(")\n");
2942}
2943
2944/*
2945 * Show the command data of a command
2946 */
2947static void show_command(Scsi_Cmnd *ptr)
2948{
Jeff Garzik017560f2005-10-24 18:04:36 -04002949 scmd_printk(KERN_DEBUG, ptr, "%p: cmnd=(", ptr);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002950
db9dff32005-04-03 14:53:59 -05002951 __scsi_print_command(ptr->cmnd);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002952
2953 printk(KERN_DEBUG "); request_bufflen=%d; resid=%d; phase |",
2954 ptr->request_bufflen, ptr->resid);
2955
2956 if (ptr->SCp.phase & not_issued)
2957 printk("not issued|");
2958 if (ptr->SCp.phase & selecting)
2959 printk("selecting|");
2960 if (ptr->SCp.phase & identified)
2961 printk("identified|");
2962 if (ptr->SCp.phase & disconnected)
2963 printk("disconnected|");
2964 if (ptr->SCp.phase & completed)
2965 printk("completed|");
2966 if (ptr->SCp.phase & spiordy)
2967 printk("spiordy|");
2968 if (ptr->SCp.phase & syncneg)
2969 printk("syncneg|");
2970 if (ptr->SCp.phase & aborted)
2971 printk("aborted|");
2972 if (ptr->SCp.phase & resetted)
2973 printk("resetted|");
2974 if( SCDATA(ptr) ) {
2975 printk("; next=0x%p\n", SCNEXT(ptr));
2976 } else {
2977 printk("; next=(host scribble NULL)\n");
2978 }
2979}
2980
2981/*
2982 * Dump the queued data
2983 */
2984static void show_queues(struct Scsi_Host *shpnt)
2985{
2986 Scsi_Cmnd *ptr;
2987 unsigned long flags;
2988
2989 DO_LOCK(flags);
2990 printk(KERN_DEBUG "\nqueue status:\nissue_SC:\n");
2991 for (ptr = ISSUE_SC; ptr; ptr = SCNEXT(ptr))
2992 show_command(ptr);
2993 DO_UNLOCK(flags);
2994
2995 printk(KERN_DEBUG "current_SC:\n");
2996 if (CURRENT_SC)
2997 show_command(CURRENT_SC);
2998 else
2999 printk(KERN_DEBUG "none\n");
3000
3001 printk(KERN_DEBUG "disconnected_SC:\n");
3002 for (ptr = DISCONNECTED_SC; ptr; ptr = SCDATA(ptr) ? SCNEXT(ptr) : NULL)
3003 show_command(ptr);
3004
3005 disp_ports(shpnt);
3006 disp_enintr(shpnt);
3007}
3008
3009#undef SPRINTF
3010#define SPRINTF(args...) pos += sprintf(pos, ## args)
3011
3012static int get_command(char *pos, Scsi_Cmnd * ptr)
3013{
3014 char *start = pos;
3015 int i;
3016
3017 SPRINTF("0x%08x: target=%d; lun=%d; cmnd=( ",
3018 (unsigned int) ptr, ptr->device->id, ptr->device->lun);
3019
3020 for (i = 0; i < COMMAND_SIZE(ptr->cmnd[0]); i++)
3021 SPRINTF("0x%02x ", ptr->cmnd[i]);
3022
3023 SPRINTF("); resid=%d; residual=%d; buffers=%d; phase |",
3024 ptr->resid, ptr->SCp.this_residual, ptr->SCp.buffers_residual);
3025
3026 if (ptr->SCp.phase & not_issued)
3027 SPRINTF("not issued|");
3028 if (ptr->SCp.phase & selecting)
3029 SPRINTF("selecting|");
3030 if (ptr->SCp.phase & disconnected)
3031 SPRINTF("disconnected|");
3032 if (ptr->SCp.phase & aborted)
3033 SPRINTF("aborted|");
3034 if (ptr->SCp.phase & identified)
3035 SPRINTF("identified|");
3036 if (ptr->SCp.phase & completed)
3037 SPRINTF("completed|");
3038 if (ptr->SCp.phase & spiordy)
3039 SPRINTF("spiordy|");
3040 if (ptr->SCp.phase & syncneg)
3041 SPRINTF("syncneg|");
3042 SPRINTF("; next=0x%p\n", SCNEXT(ptr));
3043
3044 return (pos - start);
3045}
3046
3047static int get_ports(struct Scsi_Host *shpnt, char *pos)
3048{
3049 char *start = pos;
3050 int s;
3051
3052 SPRINTF("\n%s: %s(%s) ", CURRENT_SC ? "on bus" : "waiting", states[STATE].name, states[PREVSTATE].name);
3053
3054 s = GETPORT(SCSISEQ);
3055 SPRINTF("SCSISEQ( ");
3056 if (s & TEMODEO)
3057 SPRINTF("TARGET MODE ");
3058 if (s & ENSELO)
3059 SPRINTF("SELO ");
3060 if (s & ENSELI)
3061 SPRINTF("SELI ");
3062 if (s & ENRESELI)
3063 SPRINTF("RESELI ");
3064 if (s & ENAUTOATNO)
3065 SPRINTF("AUTOATNO ");
3066 if (s & ENAUTOATNI)
3067 SPRINTF("AUTOATNI ");
3068 if (s & ENAUTOATNP)
3069 SPRINTF("AUTOATNP ");
3070 if (s & SCSIRSTO)
3071 SPRINTF("SCSIRSTO ");
3072 SPRINTF(");");
3073
3074 SPRINTF(" SCSISIG(");
3075 s = GETPORT(SCSISIG);
3076 switch (s & P_MASK) {
3077 case P_DATAO:
3078 SPRINTF("DATA OUT");
3079 break;
3080 case P_DATAI:
3081 SPRINTF("DATA IN");
3082 break;
3083 case P_CMD:
3084 SPRINTF("COMMAND");
3085 break;
3086 case P_STATUS:
3087 SPRINTF("STATUS");
3088 break;
3089 case P_MSGO:
3090 SPRINTF("MESSAGE OUT");
3091 break;
3092 case P_MSGI:
3093 SPRINTF("MESSAGE IN");
3094 break;
3095 default:
3096 SPRINTF("*invalid*");
3097 break;
3098 }
3099
3100 SPRINTF("); ");
3101
3102 SPRINTF("INTSTAT (%s); ", TESTHI(DMASTAT, INTSTAT) ? "hi" : "lo");
3103
3104 SPRINTF("SSTAT( ");
3105 s = GETPORT(SSTAT0);
3106 if (s & TARGET)
3107 SPRINTF("TARGET ");
3108 if (s & SELDO)
3109 SPRINTF("SELDO ");
3110 if (s & SELDI)
3111 SPRINTF("SELDI ");
3112 if (s & SELINGO)
3113 SPRINTF("SELINGO ");
3114 if (s & SWRAP)
3115 SPRINTF("SWRAP ");
3116 if (s & SDONE)
3117 SPRINTF("SDONE ");
3118 if (s & SPIORDY)
3119 SPRINTF("SPIORDY ");
3120 if (s & DMADONE)
3121 SPRINTF("DMADONE ");
3122
3123 s = GETPORT(SSTAT1);
3124 if (s & SELTO)
3125 SPRINTF("SELTO ");
3126 if (s & ATNTARG)
3127 SPRINTF("ATNTARG ");
3128 if (s & SCSIRSTI)
3129 SPRINTF("SCSIRSTI ");
3130 if (s & PHASEMIS)
3131 SPRINTF("PHASEMIS ");
3132 if (s & BUSFREE)
3133 SPRINTF("BUSFREE ");
3134 if (s & SCSIPERR)
3135 SPRINTF("SCSIPERR ");
3136 if (s & PHASECHG)
3137 SPRINTF("PHASECHG ");
3138 if (s & REQINIT)
3139 SPRINTF("REQINIT ");
3140 SPRINTF("); ");
3141
3142
3143 SPRINTF("SSTAT( ");
3144
3145 s = GETPORT(SSTAT0) & GETPORT(SIMODE0);
3146
3147 if (s & TARGET)
3148 SPRINTF("TARGET ");
3149 if (s & SELDO)
3150 SPRINTF("SELDO ");
3151 if (s & SELDI)
3152 SPRINTF("SELDI ");
3153 if (s & SELINGO)
3154 SPRINTF("SELINGO ");
3155 if (s & SWRAP)
3156 SPRINTF("SWRAP ");
3157 if (s & SDONE)
3158 SPRINTF("SDONE ");
3159 if (s & SPIORDY)
3160 SPRINTF("SPIORDY ");
3161 if (s & DMADONE)
3162 SPRINTF("DMADONE ");
3163
3164 s = GETPORT(SSTAT1) & GETPORT(SIMODE1);
3165
3166 if (s & SELTO)
3167 SPRINTF("SELTO ");
3168 if (s & ATNTARG)
3169 SPRINTF("ATNTARG ");
3170 if (s & SCSIRSTI)
3171 SPRINTF("SCSIRSTI ");
3172 if (s & PHASEMIS)
3173 SPRINTF("PHASEMIS ");
3174 if (s & BUSFREE)
3175 SPRINTF("BUSFREE ");
3176 if (s & SCSIPERR)
3177 SPRINTF("SCSIPERR ");
3178 if (s & PHASECHG)
3179 SPRINTF("PHASECHG ");
3180 if (s & REQINIT)
3181 SPRINTF("REQINIT ");
3182 SPRINTF("); ");
3183
3184 SPRINTF("SXFRCTL0( ");
3185
3186 s = GETPORT(SXFRCTL0);
3187 if (s & SCSIEN)
3188 SPRINTF("SCSIEN ");
3189 if (s & DMAEN)
3190 SPRINTF("DMAEN ");
3191 if (s & CH1)
3192 SPRINTF("CH1 ");
3193 if (s & CLRSTCNT)
3194 SPRINTF("CLRSTCNT ");
3195 if (s & SPIOEN)
3196 SPRINTF("SPIOEN ");
3197 if (s & CLRCH1)
3198 SPRINTF("CLRCH1 ");
3199 SPRINTF("); ");
3200
3201 SPRINTF("SIGNAL( ");
3202
3203 s = GETPORT(SCSISIG);
3204 if (s & SIG_ATNI)
3205 SPRINTF("ATNI ");
3206 if (s & SIG_SELI)
3207 SPRINTF("SELI ");
3208 if (s & SIG_BSYI)
3209 SPRINTF("BSYI ");
3210 if (s & SIG_REQI)
3211 SPRINTF("REQI ");
3212 if (s & SIG_ACKI)
3213 SPRINTF("ACKI ");
3214 SPRINTF("); ");
3215
3216 SPRINTF("SELID(%02x), ", GETPORT(SELID));
3217
3218 SPRINTF("STCNT(%d), ", GETSTCNT());
3219
3220 SPRINTF("SSTAT2( ");
3221
3222 s = GETPORT(SSTAT2);
3223 if (s & SOFFSET)
3224 SPRINTF("SOFFSET ");
3225 if (s & SEMPTY)
3226 SPRINTF("SEMPTY ");
3227 if (s & SFULL)
3228 SPRINTF("SFULL ");
3229 SPRINTF("); SFCNT (%d); ", s & (SFULL | SFCNT));
3230
3231 s = GETPORT(SSTAT3);
3232 SPRINTF("SCSICNT (%d), OFFCNT(%d), ", (s & 0xf0) >> 4, s & 0x0f);
3233
3234 SPRINTF("SSTAT4( ");
3235 s = GETPORT(SSTAT4);
3236 if (s & SYNCERR)
3237 SPRINTF("SYNCERR ");
3238 if (s & FWERR)
3239 SPRINTF("FWERR ");
3240 if (s & FRERR)
3241 SPRINTF("FRERR ");
3242 SPRINTF("); ");
3243
3244 SPRINTF("DMACNTRL0( ");
3245 s = GETPORT(DMACNTRL0);
3246 SPRINTF("%s ", s & _8BIT ? "8BIT" : "16BIT");
3247 SPRINTF("%s ", s & DMA ? "DMA" : "PIO");
3248 SPRINTF("%s ", s & WRITE_READ ? "WRITE" : "READ");
3249 if (s & ENDMA)
3250 SPRINTF("ENDMA ");
3251 if (s & INTEN)
3252 SPRINTF("INTEN ");
3253 if (s & RSTFIFO)
3254 SPRINTF("RSTFIFO ");
3255 if (s & SWINT)
3256 SPRINTF("SWINT ");
3257 SPRINTF("); ");
3258
3259 SPRINTF("DMASTAT( ");
3260 s = GETPORT(DMASTAT);
3261 if (s & ATDONE)
3262 SPRINTF("ATDONE ");
3263 if (s & WORDRDY)
3264 SPRINTF("WORDRDY ");
3265 if (s & DFIFOFULL)
3266 SPRINTF("DFIFOFULL ");
3267 if (s & DFIFOEMP)
3268 SPRINTF("DFIFOEMP ");
3269 SPRINTF(")\n");
3270
3271 SPRINTF("enabled interrupts( ");
3272
3273 s = GETPORT(SIMODE0);
3274 if (s & ENSELDO)
3275 SPRINTF("ENSELDO ");
3276 if (s & ENSELDI)
3277 SPRINTF("ENSELDI ");
3278 if (s & ENSELINGO)
3279 SPRINTF("ENSELINGO ");
3280 if (s & ENSWRAP)
3281 SPRINTF("ENSWRAP ");
3282 if (s & ENSDONE)
3283 SPRINTF("ENSDONE ");
3284 if (s & ENSPIORDY)
3285 SPRINTF("ENSPIORDY ");
3286 if (s & ENDMADONE)
3287 SPRINTF("ENDMADONE ");
3288
3289 s = GETPORT(SIMODE1);
3290 if (s & ENSELTIMO)
3291 SPRINTF("ENSELTIMO ");
3292 if (s & ENATNTARG)
3293 SPRINTF("ENATNTARG ");
3294 if (s & ENPHASEMIS)
3295 SPRINTF("ENPHASEMIS ");
3296 if (s & ENBUSFREE)
3297 SPRINTF("ENBUSFREE ");
3298 if (s & ENSCSIPERR)
3299 SPRINTF("ENSCSIPERR ");
3300 if (s & ENPHASECHG)
3301 SPRINTF("ENPHASECHG ");
3302 if (s & ENREQINIT)
3303 SPRINTF("ENREQINIT ");
3304 SPRINTF(")\n");
3305
3306 return (pos - start);
3307}
3308
3309static int aha152x_set_info(char *buffer, int length, struct Scsi_Host *shpnt)
3310{
3311 if(!shpnt || !buffer || length<8 || strncmp("aha152x ", buffer, 8)!=0)
3312 return -EINVAL;
3313
3314#if defined(AHA152X_DEBUG)
3315 if(length>14 && strncmp("debug ", buffer+8, 6)==0) {
3316 int debug = HOSTDATA(shpnt)->debug;
3317
3318 HOSTDATA(shpnt)->debug = simple_strtoul(buffer+14, NULL, 0);
3319
3320 printk(KERN_INFO "aha152x%d: debugging options set to 0x%04x (were 0x%04x)\n", HOSTNO, HOSTDATA(shpnt)->debug, debug);
3321 } else
3322#endif
3323#if defined(AHA152X_STAT)
3324 if(length>13 && strncmp("reset", buffer+8, 5)==0) {
3325 int i;
3326
3327 HOSTDATA(shpnt)->total_commands=0;
3328 HOSTDATA(shpnt)->disconnections=0;
3329 HOSTDATA(shpnt)->busfree_without_any_action=0;
3330 HOSTDATA(shpnt)->busfree_without_old_command=0;
3331 HOSTDATA(shpnt)->busfree_without_new_command=0;
3332 HOSTDATA(shpnt)->busfree_without_done_command=0;
3333 HOSTDATA(shpnt)->busfree_with_check_condition=0;
3334 for (i = idle; i<maxstate; i++) {
3335 HOSTDATA(shpnt)->count[i]=0;
3336 HOSTDATA(shpnt)->count_trans[i]=0;
3337 HOSTDATA(shpnt)->time[i]=0;
3338 }
3339
3340 printk(KERN_INFO "aha152x%d: stats reseted.\n", HOSTNO);
3341
3342 } else
3343#endif
3344 {
3345 return -EINVAL;
3346 }
3347
3348
3349 return length;
3350}
3351
3352#undef SPRINTF
3353#define SPRINTF(args...) \
3354 do { if(pos < buffer + length) pos += sprintf(pos, ## args); } while(0)
3355
3356static int aha152x_proc_info(struct Scsi_Host *shpnt, char *buffer, char **start,
3357 off_t offset, int length, int inout)
3358{
3359 int i;
3360 char *pos = buffer;
3361 Scsi_Cmnd *ptr;
3362 unsigned long flags;
3363 int thislength;
3364
3365 DPRINTK(debug_procinfo,
3366 KERN_DEBUG "aha152x_proc_info: buffer=%p offset=%ld length=%d hostno=%d inout=%d\n",
3367 buffer, offset, length, shpnt->host_no, inout);
3368
3369
3370 if (inout)
3371 return aha152x_set_info(buffer, length, shpnt);
3372
3373 SPRINTF(AHA152X_REVID "\n");
3374
3375 SPRINTF("ioports 0x%04lx to 0x%04lx\n",
3376 shpnt->io_port, shpnt->io_port + shpnt->n_io_port - 1);
3377 SPRINTF("interrupt 0x%02x\n", shpnt->irq);
3378 SPRINTF("disconnection/reconnection %s\n",
3379 RECONNECT ? "enabled" : "disabled");
3380 SPRINTF("parity checking %s\n",
3381 PARITY ? "enabled" : "disabled");
3382 SPRINTF("synchronous transfers %s\n",
3383 SYNCHRONOUS ? "enabled" : "disabled");
3384 SPRINTF("%d commands currently queued\n", HOSTDATA(shpnt)->commands);
3385
3386 if(SYNCHRONOUS) {
3387 SPRINTF("synchronously operating targets (tick=50 ns):\n");
3388 for (i = 0; i < 8; i++)
3389 if (HOSTDATA(shpnt)->syncrate[i] & 0x7f)
3390 SPRINTF("target %d: period %dT/%dns; req/ack offset %d\n",
3391 i,
3392 (((HOSTDATA(shpnt)->syncrate[i] & 0x70) >> 4) + 2),
3393 (((HOSTDATA(shpnt)->syncrate[i] & 0x70) >> 4) + 2) * 50,
3394 HOSTDATA(shpnt)->syncrate[i] & 0x0f);
3395 }
3396#if defined(AHA152X_DEBUG)
3397#define PDEBUG(flags,txt) \
3398 if(HOSTDATA(shpnt)->debug & flags) SPRINTF("(%s) ", txt);
3399
3400 SPRINTF("enabled debugging options: ");
3401
3402 PDEBUG(debug_procinfo, "procinfo");
3403 PDEBUG(debug_queue, "queue");
3404 PDEBUG(debug_intr, "interrupt");
3405 PDEBUG(debug_selection, "selection");
3406 PDEBUG(debug_msgo, "message out");
3407 PDEBUG(debug_msgi, "message in");
3408 PDEBUG(debug_status, "status");
3409 PDEBUG(debug_cmd, "command");
3410 PDEBUG(debug_datai, "data in");
3411 PDEBUG(debug_datao, "data out");
3412 PDEBUG(debug_eh, "eh");
3413 PDEBUG(debug_locks, "locks");
3414 PDEBUG(debug_phases, "phases");
3415
3416 SPRINTF("\n");
3417#endif
3418
3419 SPRINTF("\nqueue status:\n");
3420 DO_LOCK(flags);
3421 if (ISSUE_SC) {
3422 SPRINTF("not yet issued commands:\n");
3423 for (ptr = ISSUE_SC; ptr; ptr = SCNEXT(ptr))
3424 pos += get_command(pos, ptr);
3425 } else
3426 SPRINTF("no not yet issued commands\n");
3427 DO_UNLOCK(flags);
3428
3429 if (CURRENT_SC) {
3430 SPRINTF("current command:\n");
3431 pos += get_command(pos, CURRENT_SC);
3432 } else
3433 SPRINTF("no current command\n");
3434
3435 if (DISCONNECTED_SC) {
3436 SPRINTF("disconnected commands:\n");
3437 for (ptr = DISCONNECTED_SC; ptr; ptr = SCNEXT(ptr))
3438 pos += get_command(pos, ptr);
3439 } else
3440 SPRINTF("no disconnected commands\n");
3441
3442 pos += get_ports(shpnt, pos);
3443
3444#if defined(AHA152X_STAT)
3445 SPRINTF("statistics:\n"
3446 "total commands: %d\n"
3447 "disconnections: %d\n"
3448 "busfree with check condition: %d\n"
3449 "busfree without old command: %d\n"
3450 "busfree without new command: %d\n"
3451 "busfree without done command: %d\n"
3452 "busfree without any action: %d\n"
3453 "state "
3454 "transitions "
3455 "count "
3456 "time\n",
3457 HOSTDATA(shpnt)->total_commands,
3458 HOSTDATA(shpnt)->disconnections,
3459 HOSTDATA(shpnt)->busfree_with_check_condition,
3460 HOSTDATA(shpnt)->busfree_without_old_command,
3461 HOSTDATA(shpnt)->busfree_without_new_command,
3462 HOSTDATA(shpnt)->busfree_without_done_command,
3463 HOSTDATA(shpnt)->busfree_without_any_action);
3464 for(i=0; i<maxstate; i++) {
3465 SPRINTF("%-10s %-12d %-12d %-12ld\n",
3466 states[i].name,
3467 HOSTDATA(shpnt)->count_trans[i],
3468 HOSTDATA(shpnt)->count[i],
3469 HOSTDATA(shpnt)->time[i]);
3470 }
3471#endif
3472
3473 DPRINTK(debug_procinfo, KERN_DEBUG "aha152x_proc_info: pos=%p\n", pos);
3474
3475 thislength = pos - (buffer + offset);
3476 DPRINTK(debug_procinfo, KERN_DEBUG "aha152x_proc_info: length=%d thislength=%d\n", length, thislength);
3477
3478 if(thislength<0) {
3479 DPRINTK(debug_procinfo, KERN_DEBUG "aha152x_proc_info: output too short\n");
3480 *start = NULL;
3481 return 0;
3482 }
3483
3484 thislength = thislength<length ? thislength : length;
3485
3486 DPRINTK(debug_procinfo, KERN_DEBUG "aha152x_proc_info: return %d\n", thislength);
3487
3488 *start = buffer + offset;
3489 return thislength < length ? thislength : length;
3490}
3491
Christoph Hellwigd0be4a7d2005-10-31 18:31:40 +01003492static struct scsi_host_template aha152x_driver_template = {
Linus Torvalds1da177e2005-04-16 15:20:36 -07003493 .module = THIS_MODULE,
3494 .name = AHA152X_REVID,
3495 .proc_name = "aha152x",
3496 .proc_info = aha152x_proc_info,
3497 .queuecommand = aha152x_queue,
3498 .eh_abort_handler = aha152x_abort,
3499 .eh_device_reset_handler = aha152x_device_reset,
3500 .eh_bus_reset_handler = aha152x_bus_reset,
3501 .eh_host_reset_handler = aha152x_host_reset,
3502 .bios_param = aha152x_biosparam,
3503 .can_queue = 1,
3504 .this_id = 7,
3505 .sg_tablesize = SG_ALL,
3506 .cmd_per_lun = 1,
3507 .use_clustering = DISABLE_CLUSTERING,
3508};
3509
3510#if !defined(PCMCIA)
3511static int setup_count;
3512static struct aha152x_setup setup[2];
3513
3514/* possible i/o addresses for the AIC-6260; default first */
3515static unsigned short ports[] = { 0x340, 0x140 };
3516
3517#if !defined(SKIP_BIOSTEST)
3518/* possible locations for the Adaptec BIOS; defaults first */
3519static unsigned int addresses[] =
3520{
3521 0xdc000, /* default first */
3522 0xc8000,
3523 0xcc000,
3524 0xd0000,
3525 0xd4000,
3526 0xd8000,
3527 0xe0000,
3528 0xeb800, /* VTech Platinum SMP */
3529 0xf0000,
3530};
3531
3532/* signatures for various AIC-6[23]60 based controllers.
3533 The point in detecting signatures is to avoid useless and maybe
3534 harmful probes on ports. I'm not sure that all listed boards pass
3535 auto-configuration. For those which fail the BIOS signature is
3536 obsolete, because user intervention to supply the configuration is
3537 needed anyway. May be an information whether or not the BIOS supports
3538 extended translation could be also useful here. */
3539static struct signature {
3540 unsigned char *signature;
3541 int sig_offset;
3542 int sig_length;
3543} signatures[] =
3544{
3545 { "Adaptec AHA-1520 BIOS", 0x102e, 21 },
3546 /* Adaptec 152x */
3547 { "Adaptec AHA-1520B", 0x000b, 17 },
3548 /* Adaptec 152x rev B */
3549 { "Adaptec AHA-1520B", 0x0026, 17 },
3550 /* Iomega Jaz Jet ISA (AIC6370Q) */
3551 { "Adaptec ASW-B626 BIOS", 0x1029, 21 },
3552 /* on-board controller */
3553 { "Adaptec BIOS: ASW-B626", 0x000f, 22 },
3554 /* on-board controller */
3555 { "Adaptec ASW-B626 S2", 0x2e6c, 19 },
3556 /* on-board controller */
3557 { "Adaptec BIOS:AIC-6360", 0x000c, 21 },
3558 /* on-board controller */
3559 { "ScsiPro SP-360 BIOS", 0x2873, 19 },
3560 /* ScsiPro-Controller */
3561 { "GA-400 LOCAL BUS SCSI BIOS", 0x102e, 26 },
3562 /* Gigabyte Local-Bus-SCSI */
3563 { "Adaptec BIOS:AVA-282X", 0x000c, 21 },
3564 /* Adaptec 282x */
3565 { "Adaptec IBM Dock II SCSI", 0x2edd, 24 },
3566 /* IBM Thinkpad Dock II */
3567 { "Adaptec BIOS:AHA-1532P", 0x001c, 22 },
3568 /* IBM Thinkpad Dock II SCSI */
3569 { "DTC3520A Host Adapter BIOS", 0x318a, 26 },
3570 /* DTC 3520A ISA SCSI */
3571};
3572#endif /* !SKIP_BIOSTEST */
3573
3574/*
3575 * Test, if port_base is valid.
3576 *
3577 */
3578static int aha152x_porttest(int io_port)
3579{
3580 int i;
3581
3582 SETPORT(io_port + O_DMACNTRL1, 0); /* reset stack pointer */
3583 for (i = 0; i < 16; i++)
3584 SETPORT(io_port + O_STACK, i);
3585
3586 SETPORT(io_port + O_DMACNTRL1, 0); /* reset stack pointer */
3587 for (i = 0; i < 16 && GETPORT(io_port + O_STACK) == i; i++)
3588 ;
3589
3590 return (i == 16);
3591}
3592
3593static int tc1550_porttest(int io_port)
3594{
3595 int i;
3596
3597 SETPORT(io_port + O_TC_DMACNTRL1, 0); /* reset stack pointer */
3598 for (i = 0; i < 16; i++)
3599 SETPORT(io_port + O_STACK, i);
3600
3601 SETPORT(io_port + O_TC_DMACNTRL1, 0); /* reset stack pointer */
3602 for (i = 0; i < 16 && GETPORT(io_port + O_TC_STACK) == i; i++)
3603 ;
3604
3605 return (i == 16);
3606}
3607
3608
3609static int checksetup(struct aha152x_setup *setup)
3610{
3611 int i;
3612 for (i = 0; i < ARRAY_SIZE(ports) && (setup->io_port != ports[i]); i++)
3613 ;
3614
3615 if (i == ARRAY_SIZE(ports))
3616 return 0;
3617
3618 if ( request_region(setup->io_port, IO_RANGE, "aha152x")==0 ) {
3619 printk(KERN_ERR "aha152x: io port 0x%x busy.\n", setup->io_port);
3620 return 0;
3621 }
3622
3623 if( aha152x_porttest(setup->io_port) ) {
3624 setup->tc1550=0;
3625 } else if( tc1550_porttest(setup->io_port) ) {
3626 setup->tc1550=1;
3627 } else {
3628 release_region(setup->io_port, IO_RANGE);
3629 return 0;
3630 }
3631
3632 release_region(setup->io_port, IO_RANGE);
3633
3634 if ((setup->irq < IRQ_MIN) || (setup->irq > IRQ_MAX))
3635 return 0;
3636
3637 if ((setup->scsiid < 0) || (setup->scsiid > 7))
3638 return 0;
3639
3640 if ((setup->reconnect < 0) || (setup->reconnect > 1))
3641 return 0;
3642
3643 if ((setup->parity < 0) || (setup->parity > 1))
3644 return 0;
3645
3646 if ((setup->synchronous < 0) || (setup->synchronous > 1))
3647 return 0;
3648
3649 if ((setup->ext_trans < 0) || (setup->ext_trans > 1))
3650 return 0;
3651
3652
3653 return 1;
3654}
3655
3656
3657static int __init aha152x_init(void)
3658{
3659 int i, j, ok;
3660#if defined(AUTOCONF)
3661 aha152x_config conf;
3662#endif
3663#ifdef __ISAPNP__
3664 struct pnp_dev *dev=NULL, *pnpdev[2] = {NULL, NULL};
3665#endif
3666
3667 if ( setup_count ) {
3668 printk(KERN_INFO "aha152x: processing commandline: ");
3669
3670 for (i = 0; i<setup_count; i++) {
3671 if (!checksetup(&setup[i])) {
3672 printk(KERN_ERR "\naha152x: %s\n", setup[i].conf);
3673 printk(KERN_ERR "aha152x: invalid line\n");
3674 }
3675 }
3676 printk("ok\n");
3677 }
3678
3679#if defined(SETUP0)
3680 if (setup_count < ARRAY_SIZE(setup)) {
3681 struct aha152x_setup override = SETUP0;
3682
3683 if (setup_count == 0 || (override.io_port != setup[0].io_port)) {
3684 if (!checksetup(&override)) {
3685 printk(KERN_ERR "\naha152x: invalid override SETUP0={0x%x,%d,%d,%d,%d,%d,%d,%d}\n",
3686 override.io_port,
3687 override.irq,
3688 override.scsiid,
3689 override.reconnect,
3690 override.parity,
3691 override.synchronous,
3692 override.delay,
3693 override.ext_trans);
3694 } else
3695 setup[setup_count++] = override;
3696 }
3697 }
3698#endif
3699
3700#if defined(SETUP1)
3701 if (setup_count < ARRAY_SIZE(setup)) {
3702 struct aha152x_setup override = SETUP1;
3703
3704 if (setup_count == 0 || (override.io_port != setup[0].io_port)) {
3705 if (!checksetup(&override)) {
3706 printk(KERN_ERR "\naha152x: invalid override SETUP1={0x%x,%d,%d,%d,%d,%d,%d,%d}\n",
3707 override.io_port,
3708 override.irq,
3709 override.scsiid,
3710 override.reconnect,
3711 override.parity,
3712 override.synchronous,
3713 override.delay,
3714 override.ext_trans);
3715 } else
3716 setup[setup_count++] = override;
3717 }
3718 }
3719#endif
3720
3721#if defined(MODULE)
3722 if (setup_count<ARRAY_SIZE(setup) && (aha152x[0]!=0 || io[0]!=0 || irq[0]!=0)) {
3723 if(aha152x[0]!=0) {
3724 setup[setup_count].conf = "";
3725 setup[setup_count].io_port = aha152x[0];
3726 setup[setup_count].irq = aha152x[1];
3727 setup[setup_count].scsiid = aha152x[2];
3728 setup[setup_count].reconnect = aha152x[3];
3729 setup[setup_count].parity = aha152x[4];
3730 setup[setup_count].synchronous = aha152x[5];
3731 setup[setup_count].delay = aha152x[6];
3732 setup[setup_count].ext_trans = aha152x[7];
3733#if defined(AHA152X_DEBUG)
3734 setup[setup_count].debug = aha152x[8];
3735#endif
3736 } else if(io[0]!=0 || irq[0]!=0) {
3737 if(io[0]!=0) setup[setup_count].io_port = io[0];
3738 if(irq[0]!=0) setup[setup_count].irq = irq[0];
3739
3740 setup[setup_count].scsiid = scsiid[0];
3741 setup[setup_count].reconnect = reconnect[0];
3742 setup[setup_count].parity = parity[0];
3743 setup[setup_count].synchronous = sync[0];
3744 setup[setup_count].delay = delay[0];
3745 setup[setup_count].ext_trans = exttrans[0];
3746#if defined(AHA152X_DEBUG)
3747 setup[setup_count].debug = debug[0];
3748#endif
3749 }
3750
3751 if (checksetup(&setup[setup_count]))
3752 setup_count++;
3753 else
3754 printk(KERN_ERR "aha152x: invalid module params io=0x%x, irq=%d,scsiid=%d,reconnect=%d,parity=%d,sync=%d,delay=%d,exttrans=%d\n",
3755 setup[setup_count].io_port,
3756 setup[setup_count].irq,
3757 setup[setup_count].scsiid,
3758 setup[setup_count].reconnect,
3759 setup[setup_count].parity,
3760 setup[setup_count].synchronous,
3761 setup[setup_count].delay,
3762 setup[setup_count].ext_trans);
3763 }
3764
3765 if (setup_count<ARRAY_SIZE(setup) && (aha152x1[0]!=0 || io[1]!=0 || irq[1]!=0)) {
3766 if(aha152x1[0]!=0) {
3767 setup[setup_count].conf = "";
3768 setup[setup_count].io_port = aha152x1[0];
3769 setup[setup_count].irq = aha152x1[1];
3770 setup[setup_count].scsiid = aha152x1[2];
3771 setup[setup_count].reconnect = aha152x1[3];
3772 setup[setup_count].parity = aha152x1[4];
3773 setup[setup_count].synchronous = aha152x1[5];
3774 setup[setup_count].delay = aha152x1[6];
3775 setup[setup_count].ext_trans = aha152x1[7];
3776#if defined(AHA152X_DEBUG)
3777 setup[setup_count].debug = aha152x1[8];
3778#endif
3779 } else if(io[1]!=0 || irq[1]!=0) {
3780 if(io[1]!=0) setup[setup_count].io_port = io[1];
3781 if(irq[1]!=0) setup[setup_count].irq = irq[1];
3782
3783 setup[setup_count].scsiid = scsiid[1];
3784 setup[setup_count].reconnect = reconnect[1];
3785 setup[setup_count].parity = parity[1];
3786 setup[setup_count].synchronous = sync[1];
3787 setup[setup_count].delay = delay[1];
3788 setup[setup_count].ext_trans = exttrans[1];
3789#if defined(AHA152X_DEBUG)
3790 setup[setup_count].debug = debug[1];
3791#endif
3792 }
3793 if (checksetup(&setup[setup_count]))
3794 setup_count++;
3795 else
3796 printk(KERN_ERR "aha152x: invalid module params io=0x%x, irq=%d,scsiid=%d,reconnect=%d,parity=%d,sync=%d,delay=%d,exttrans=%d\n",
3797 setup[setup_count].io_port,
3798 setup[setup_count].irq,
3799 setup[setup_count].scsiid,
3800 setup[setup_count].reconnect,
3801 setup[setup_count].parity,
3802 setup[setup_count].synchronous,
3803 setup[setup_count].delay,
3804 setup[setup_count].ext_trans);
3805 }
3806#endif
3807
3808#ifdef __ISAPNP__
3809 for(i=0; setup_count<ARRAY_SIZE(setup) && id_table[i].vendor; i++) {
3810 while ( setup_count<ARRAY_SIZE(setup) &&
3811 (dev=pnp_find_dev(NULL, id_table[i].vendor, id_table[i].function, dev)) ) {
3812 if (pnp_device_attach(dev) < 0)
3813 continue;
3814
3815 if (pnp_activate_dev(dev) < 0) {
3816 pnp_device_detach(dev);
3817 continue;
3818 }
3819
3820 if (!pnp_port_valid(dev, 0)) {
3821 pnp_device_detach(dev);
3822 continue;
3823 }
3824
3825 if (setup_count==1 && pnp_port_start(dev, 0)==setup[0].io_port) {
3826 pnp_device_detach(dev);
3827 continue;
3828 }
3829
3830 setup[setup_count].io_port = pnp_port_start(dev, 0);
3831 setup[setup_count].irq = pnp_irq(dev, 0);
3832 setup[setup_count].scsiid = 7;
3833 setup[setup_count].reconnect = 1;
3834 setup[setup_count].parity = 1;
3835 setup[setup_count].synchronous = 1;
3836 setup[setup_count].delay = DELAY_DEFAULT;
3837 setup[setup_count].ext_trans = 0;
3838#if defined(AHA152X_DEBUG)
3839 setup[setup_count].debug = DEBUG_DEFAULT;
3840#endif
3841#if defined(__ISAPNP__)
3842 pnpdev[setup_count] = dev;
3843#endif
3844 printk (KERN_INFO
3845 "aha152x: found ISAPnP adapter at io=0x%03x, irq=%d\n",
3846 setup[setup_count].io_port, setup[setup_count].irq);
3847 setup_count++;
3848 }
3849 }
3850#endif
3851
3852#if defined(AUTOCONF)
3853 if (setup_count<ARRAY_SIZE(setup)) {
3854#if !defined(SKIP_BIOSTEST)
3855 ok = 0;
3856 for (i = 0; i < ARRAY_SIZE(addresses) && !ok; i++) {
3857 void __iomem *p = ioremap(addresses[i], 0x4000);
3858 if (!p)
3859 continue;
3860 for (j = 0; j<ARRAY_SIZE(signatures) && !ok; j++)
3861 ok = check_signature(p + signatures[j].sig_offset,
3862 signatures[j].signature, signatures[j].sig_length);
3863 iounmap(p);
3864 }
3865 if (!ok && setup_count == 0)
3866 return 0;
3867
3868 printk(KERN_INFO "aha152x: BIOS test: passed, ");
3869#else
3870 printk(KERN_INFO "aha152x: ");
3871#endif /* !SKIP_BIOSTEST */
3872
3873 ok = 0;
3874 for (i = 0; i < ARRAY_SIZE(ports) && setup_count < 2; i++) {
3875 if ((setup_count == 1) && (setup[0].io_port == ports[i]))
3876 continue;
3877
3878 if ( request_region(ports[i], IO_RANGE, "aha152x")==0 ) {
3879 printk(KERN_ERR "aha152x: io port 0x%x busy.\n", ports[i]);
3880 continue;
3881 }
3882
3883 if (aha152x_porttest(ports[i])) {
3884 setup[setup_count].tc1550 = 0;
3885
3886 conf.cf_port =
3887 (GETPORT(ports[i] + O_PORTA) << 8) + GETPORT(ports[i] + O_PORTB);
3888 } else if (tc1550_porttest(ports[i])) {
3889 setup[setup_count].tc1550 = 1;
3890
3891 conf.cf_port =
3892 (GETPORT(ports[i] + O_TC_PORTA) << 8) + GETPORT(ports[i] + O_TC_PORTB);
3893 } else {
3894 release_region(ports[i], IO_RANGE);
3895 continue;
3896 }
3897
3898 release_region(ports[i], IO_RANGE);
3899
3900 ok++;
3901 setup[setup_count].io_port = ports[i];
3902 setup[setup_count].irq = IRQ_MIN + conf.cf_irq;
3903 setup[setup_count].scsiid = conf.cf_id;
3904 setup[setup_count].reconnect = conf.cf_tardisc;
3905 setup[setup_count].parity = !conf.cf_parity;
3906 setup[setup_count].synchronous = conf.cf_syncneg;
3907 setup[setup_count].delay = DELAY_DEFAULT;
3908 setup[setup_count].ext_trans = 0;
3909#if defined(AHA152X_DEBUG)
3910 setup[setup_count].debug = DEBUG_DEFAULT;
3911#endif
3912 setup_count++;
3913
3914 }
3915
3916 if (ok)
3917 printk("auto configuration: ok, ");
3918 }
3919#endif
3920
3921 printk("%d controller(s) configured\n", setup_count);
3922
3923 for (i=0; i<setup_count; i++) {
3924 if ( request_region(setup[i].io_port, IO_RANGE, "aha152x") ) {
3925 struct Scsi_Host *shpnt = aha152x_probe_one(&setup[i]);
3926
3927 if( !shpnt ) {
3928 release_region(setup[i].io_port, IO_RANGE);
3929#if defined(__ISAPNP__)
3930 } else if( pnpdev[i] ) {
3931 HOSTDATA(shpnt)->pnpdev=pnpdev[i];
3932 pnpdev[i]=NULL;
3933#endif
3934 }
3935 } else {
3936 printk(KERN_ERR "aha152x: io port 0x%x busy.\n", setup[i].io_port);
3937 }
3938
3939#if defined(__ISAPNP__)
3940 if( pnpdev[i] )
3941 pnp_device_detach(pnpdev[i]);
3942#endif
3943 }
3944
James Bottomley5fcda422006-09-14 17:04:58 -05003945 return 1;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003946}
3947
3948static void __exit aha152x_exit(void)
3949{
James Bottomley5fcda422006-09-14 17:04:58 -05003950 struct aha152x_hostdata *hd;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003951
James Bottomley5fcda422006-09-14 17:04:58 -05003952 list_for_each_entry(hd, &aha152x_host_list, host_list) {
3953 struct Scsi_Host *shost = container_of((void *)hd, struct Scsi_Host, hostdata);
3954
3955 aha152x_release(shost);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003956 }
3957}
3958
3959module_init(aha152x_init);
3960module_exit(aha152x_exit);
3961
3962#if !defined(MODULE)
3963static int __init aha152x_setup(char *str)
3964{
3965#if defined(AHA152X_DEBUG)
3966 int ints[11];
3967#else
3968 int ints[10];
3969#endif
3970 get_options(str, ARRAY_SIZE(ints), ints);
3971
3972 if(setup_count>=ARRAY_SIZE(setup)) {
3973 printk(KERN_ERR "aha152x: you can only configure up to two controllers\n");
3974 return 1;
3975 }
3976
3977 setup[setup_count].conf = str;
3978 setup[setup_count].io_port = ints[0] >= 1 ? ints[1] : 0x340;
3979 setup[setup_count].irq = ints[0] >= 2 ? ints[2] : 11;
3980 setup[setup_count].scsiid = ints[0] >= 3 ? ints[3] : 7;
3981 setup[setup_count].reconnect = ints[0] >= 4 ? ints[4] : 1;
3982 setup[setup_count].parity = ints[0] >= 5 ? ints[5] : 1;
3983 setup[setup_count].synchronous = ints[0] >= 6 ? ints[6] : 1;
3984 setup[setup_count].delay = ints[0] >= 7 ? ints[7] : DELAY_DEFAULT;
3985 setup[setup_count].ext_trans = ints[0] >= 8 ? ints[8] : 0;
3986#if defined(AHA152X_DEBUG)
3987 setup[setup_count].debug = ints[0] >= 9 ? ints[9] : DEBUG_DEFAULT;
3988 if (ints[0] > 9) {
3989 printk(KERN_NOTICE "aha152x: usage: aha152x=<IOBASE>[,<IRQ>[,<SCSI ID>"
3990 "[,<RECONNECT>[,<PARITY>[,<SYNCHRONOUS>[,<DELAY>[,<EXT_TRANS>[,<DEBUG>]]]]]]]]\n");
3991#else
3992 if (ints[0] > 8) { /*}*/
3993 printk(KERN_NOTICE "aha152x: usage: aha152x=<IOBASE>[,<IRQ>[,<SCSI ID>"
3994 "[,<RECONNECT>[,<PARITY>[,<SYNCHRONOUS>[,<DELAY>[,<EXT_TRANS>]]]]]]]\n");
3995#endif
3996 } else {
3997 setup_count++;
3998 return 0;
3999 }
4000
4001 return 1;
4002}
4003__setup("aha152x=", aha152x_setup);
4004#endif
4005
4006#endif /* !PCMCIA */