freebsd-dev/sys/dev/aic7xxx
Justin T. Gibbs 85ac786b13 Kill the "unpause_always" argument to unpause_sequencer(). The reasons
for optimizing the unpause operation no-longer exist, and this is much
safer.

When restarting the sequencer, reconstitute the free SCB list on the card.
This deals with a single instruction gap between marking the SCB as free
and actually getting it onto the free list.

Reduce the number of transfer negotiations that occur.  In the past, we
renegotiated after every reported check condition status.  This ensures
that we catch devices that have unexpectidly reset.  In this situation,
the target will always report the check condition before performing a
data-phase.  The new behavior is to renegotiate for any check-condition where
the residual matches the orginal data-length of the command (including
0 length transffers).  This avoids renegotiations during things like
variable tape block reads, where the check condition is reported only
to indicate the residual of the read.

Revamp the parity error detection logic.  We now properly report and
handle injected parity errors in all phases.  The old code used to hang
on message-in parity errors.

Correct the reporting of selection timeout errors to the XPT.  When
a selection timeout occurs, only the currently selecting command
is flagged with SELTO status instead of aborting all currently active
commands to that target.

Fix flipped arguments in ahc_match_scb and in some of the callers of this
routine.  I wish that gcc allowed you to request warnings for enums passed
as ints.

Make ahc_find_msg generically handle all message types.

Work around the target mode data-in wideodd bug in all non-U2 chips.
We can now do sync-wide target mode transfers in target mode across the
hole product line.

Use lastphase exclusively for handling timeouts.  The current phase
doesn't take the bus free state into account.

Fix a bug in the timeout handler that could cause corruption of the
disconnected list.

When sending an embedded cdb to a target, ensure that we start on a
quad word boundary in the data-fifo.  It seems that unaligned stores
do not work correctly.
2000-02-09 21:25:00 +00:00
..
aicasm Simplify my copyright license terms. 1999-12-06 18:23:31 +00:00
93cx6.c Update copyrights to Y2K. 2000-01-07 23:08:20 +00:00
93cx6.h Update copyright license terms to match the reset of the aic7xxx dirver. 2000-02-03 16:54:11 +00:00
ahc_eisa.c remove #include "eisa.h" and #if NEISA > 0 - this is guaranteed by 2000-01-29 14:22:19 +00:00
ahc_pci.c Fix parity error detection logic for aic7880 and aic7895 chips during 2000-02-09 21:00:22 +00:00
aic7xxx_93cx6.c Update copyrights to Y2K. 2000-01-07 23:08:20 +00:00
aic7xxx_93cx6.h Update copyright license terms to match the reset of the aic7xxx dirver. 2000-02-03 16:54:11 +00:00
aic7xxx.c Kill the "unpause_always" argument to unpause_sequencer(). The reasons 2000-02-09 21:25:00 +00:00
aic7xxx.h Kill the "unpause_always" argument to unpause_sequencer(). The reasons 2000-02-09 21:25:00 +00:00
aic7xxx.reg Kill the "unpause_always" argument to unpause_sequencer(). The reasons 2000-02-09 21:25:00 +00:00
aic7xxx.seq Kill the "unpause_always" argument to unpause_sequencer(). The reasons 2000-02-09 21:25:00 +00:00
aicasm_gram.y Simplify my copyright license terms. 1999-12-06 18:23:31 +00:00
aicasm_scan.l Simplify my copyright license terms. 1999-12-06 18:23:31 +00:00
aicasm_symbol.c Simplify my copyright license terms. 1999-12-06 18:23:31 +00:00
aicasm_symbol.h Simplify my copyright license terms. 1999-12-06 18:23:31 +00:00
aicasm.c $Id$ -> $FreeBSD$ 1999-08-28 01:08:13 +00:00
aicasm.h Simplify my copyright license terms. 1999-12-06 18:23:31 +00:00
Makefile $Id$ -> $FreeBSD$ 1999-08-28 01:08:13 +00:00
sequencer.h Simplify my copyright license terms. 1999-12-06 18:23:31 +00:00