Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
linux
Commits
14686d42
Commit
14686d42
authored
Mar 10, 2003
by
Justin T. Gibbs
Browse files
Options
Browse Files
Download
Plain Diff
Merge from Linux bk tree.
parents
8da730e9
403671e8
Changes
27
Hide whitespace changes
Inline
Side-by-side
Showing
27 changed files
with
1241 additions
and
864 deletions
+1241
-864
drivers/scsi/aic7xxx/Kconfig.aic7xxx
drivers/scsi/aic7xxx/Kconfig.aic7xxx
+1
-1
drivers/scsi/aic7xxx/aic7770.c
drivers/scsi/aic7xxx/aic7770.c
+36
-1
drivers/scsi/aic7xxx/aic7770_osm.c
drivers/scsi/aic7xxx/aic7770_osm.c
+2
-2
drivers/scsi/aic7xxx/aic79xx.h
drivers/scsi/aic7xxx/aic79xx.h
+33
-17
drivers/scsi/aic7xxx/aic79xx.reg
drivers/scsi/aic7xxx/aic79xx.reg
+9
-8
drivers/scsi/aic7xxx/aic79xx.seq
drivers/scsi/aic7xxx/aic79xx.seq
+154
-56
drivers/scsi/aic7xxx/aic79xx_core.c
drivers/scsi/aic7xxx/aic79xx_core.c
+67
-39
drivers/scsi/aic7xxx/aic79xx_inline.h
drivers/scsi/aic7xxx/aic79xx_inline.h
+3
-2
drivers/scsi/aic7xxx/aic79xx_osm.c
drivers/scsi/aic7xxx/aic79xx_osm.c
+59
-31
drivers/scsi/aic7xxx/aic79xx_osm.h
drivers/scsi/aic7xxx/aic79xx_osm.h
+4
-4
drivers/scsi/aic7xxx/aic79xx_pci.c
drivers/scsi/aic7xxx/aic79xx_pci.c
+15
-11
drivers/scsi/aic7xxx/aic79xx_proc.c
drivers/scsi/aic7xxx/aic79xx_proc.c
+7
-2
drivers/scsi/aic7xxx/aic79xx_reg.h_shipped
drivers/scsi/aic7xxx/aic79xx_reg.h_shipped
+6
-5
drivers/scsi/aic7xxx/aic79xx_reg_print.c_shipped
drivers/scsi/aic7xxx/aic79xx_reg_print.c_shipped
+2
-2
drivers/scsi/aic7xxx/aic79xx_seq.h_shipped
drivers/scsi/aic7xxx/aic79xx_seq.h_shipped
+285
-239
drivers/scsi/aic7xxx/aic7xxx.h
drivers/scsi/aic7xxx/aic7xxx.h
+56
-28
drivers/scsi/aic7xxx/aic7xxx.reg
drivers/scsi/aic7xxx/aic7xxx.reg
+2
-2
drivers/scsi/aic7xxx/aic7xxx_core.c
drivers/scsi/aic7xxx/aic7xxx_core.c
+319
-385
drivers/scsi/aic7xxx/aic7xxx_inline.h
drivers/scsi/aic7xxx/aic7xxx_inline.h
+1
-1
drivers/scsi/aic7xxx/aic7xxx_osm.c
drivers/scsi/aic7xxx/aic7xxx_osm.c
+50
-15
drivers/scsi/aic7xxx/aic7xxx_osm.h
drivers/scsi/aic7xxx/aic7xxx_osm.h
+3
-3
drivers/scsi/aic7xxx/aic7xxx_pci.c
drivers/scsi/aic7xxx/aic7xxx_pci.c
+120
-4
drivers/scsi/aic7xxx/aic7xxx_proc.c
drivers/scsi/aic7xxx/aic7xxx_proc.c
+2
-1
drivers/scsi/aic7xxx/aic7xxx_reg.h_shipped
drivers/scsi/aic7xxx/aic7xxx_reg.h_shipped
+2
-2
drivers/scsi/aic7xxx/aic7xxx_reg_print.c_shipped
drivers/scsi/aic7xxx/aic7xxx_reg_print.c_shipped
+1
-1
drivers/scsi/aic7xxx/aic7xxx_seq.h_shipped
drivers/scsi/aic7xxx/aic7xxx_seq.h_shipped
+1
-1
drivers/scsi/aic7xxx/aicasm/Makefile
drivers/scsi/aic7xxx/aicasm/Makefile
+1
-1
No files found.
drivers/scsi/aic7xxx/Kconfig.aic7xxx
View file @
14686d42
#
# AIC7XXX and AIC79XX 2.5.X Kernel configuration File.
# $Id: //depot/linux-aic79xx-2.5.0/drivers/scsi/aic7xxx/Kconfig.aic7xxx#
5
$
# $Id: //depot/linux-aic79xx-2.5.0/drivers/scsi/aic7xxx/Kconfig.aic7xxx#
6
$
#
config SCSI_AIC7XXX
tristate "Adaptec AIC7xxx Fast -> U160 support (New Driver)"
...
...
drivers/scsi/aic7xxx/aic7770.c
View file @
14686d42
...
...
@@ -37,7 +37,7 @@
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGES.
*
* $Id: //depot/aic7xxx/aic7xxx/aic7770.c#2
7
$
* $Id: //depot/aic7xxx/aic7xxx/aic7770.c#2
9
$
*
* $FreeBSD$
*/
...
...
@@ -59,6 +59,9 @@
#define ID_OLV_274x 0x04907782
/* Olivetti OEM */
#define ID_OLV_274xD 0x04907783
/* Olivetti OEM (Differential) */
static
int
aic7770_chip_init
(
struct
ahc_softc
*
ahc
);
static
int
aic7770_suspend
(
struct
ahc_softc
*
ahc
);
static
int
aic7770_resume
(
struct
ahc_softc
*
ahc
);
static
int
aha2840_load_seeprom
(
struct
ahc_softc
*
ahc
);
static
ahc_device_setup_t
ahc_aic7770_VL_setup
;
static
ahc_device_setup_t
ahc_aic7770_EISA_setup
;;
...
...
@@ -144,6 +147,12 @@ aic7770_config(struct ahc_softc *ahc, struct aic7770_identity *entry, u_int io)
ahc
->
description
=
entry
->
name
;
error
=
ahc_softc_init
(
ahc
);
if
(
error
!=
0
)
return
(
error
);
ahc
->
bus_chip_init
=
aic7770_chip_init
;
ahc
->
bus_suspend
=
aic7770_suspend
;
ahc
->
bus_resume
=
aic7770_resume
;
error
=
ahc_reset
(
ahc
);
if
(
error
!=
0
)
...
...
@@ -226,6 +235,9 @@ aic7770_config(struct ahc_softc *ahc, struct aic7770_identity *entry, u_int io)
ahc_outb
(
ahc
,
BUSSPD
,
hostconf
&
DFTHRSH
);
ahc_outb
(
ahc
,
BUSTIME
,
(
hostconf
<<
2
)
&
BOFF
);
ahc
->
bus_softc
.
aic7770_softc
.
busspd
=
hostconf
&
DFTHRSH
;
ahc
->
bus_softc
.
aic7770_softc
.
bustime
=
(
hostconf
<<
2
)
&
BOFF
;
/*
* Generic aic7xxx initialization.
*/
...
...
@@ -253,6 +265,28 @@ aic7770_config(struct ahc_softc *ahc, struct aic7770_identity *entry, u_int io)
return
(
0
);
}
static
int
aic7770_chip_init
(
struct
ahc_softc
*
ahc
)
{
ahc_outb
(
ahc
,
BUSSPD
,
ahc
->
bus_softc
.
aic7770_softc
.
busspd
);
ahc_outb
(
ahc
,
BUSTIME
,
ahc
->
bus_softc
.
aic7770_softc
.
bustime
);
ahc_outb
(
ahc
,
SBLKCTL
,
ahc_inb
(
ahc
,
SBLKCTL
)
&
~
AUTOFLUSHDIS
);
ahc_outb
(
ahc
,
BCTL
,
ENABLE
);
return
(
ahc_chip_init
(
ahc
));
}
static
int
aic7770_suspend
(
struct
ahc_softc
*
ahc
)
{
return
(
ahc_suspend
(
ahc
));
}
static
int
aic7770_resume
(
struct
ahc_softc
*
ahc
)
{
return
(
ahc_resume
(
ahc
));
}
/*
* Read the 284x SEEPROM.
*/
...
...
@@ -371,5 +405,6 @@ ahc_aic7770_setup(struct ahc_softc *ahc)
ahc
->
features
=
AHC_AIC7770_FE
;
ahc
->
bugs
|=
AHC_TMODE_WIDEODD_BUG
;
ahc
->
flags
|=
AHC_PAGESCBS
;
ahc
->
instruction_ram_size
=
448
;
return
(
0
);
}
drivers/scsi/aic7xxx/aic7770_osm.c
View file @
14686d42
...
...
@@ -36,7 +36,7 @@
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGES.
*
* $Id: //depot/aic7xxx/linux/drivers/scsi/aic7xxx/aic7770_osm.c#1
2
$
* $Id: //depot/aic7xxx/linux/drivers/scsi/aic7xxx/aic7770_osm.c#1
3
$
*/
#include "aic7xxx_osm.h"
...
...
@@ -66,7 +66,7 @@ aic7770_linux_probe(Scsi_Host_Template *template)
continue
;
request_region
(
eisaBase
,
AHC_EISA_IOSIZE
,
"aic7xxx"
);
#else
if
(
request_region
(
eisaBase
,
AHC_EISA_IOSIZE
,
"aic7xxx"
)
!
=
0
)
if
(
request_region
(
eisaBase
,
AHC_EISA_IOSIZE
,
"aic7xxx"
)
=
=
0
)
continue
;
#endif
...
...
drivers/scsi/aic7xxx/aic79xx.h
View file @
14686d42
...
...
@@ -37,7 +37,7 @@
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGES.
*
* $Id: //depot/aic7xxx/aic7xxx/aic79xx.h#
78
$
* $Id: //depot/aic7xxx/aic7xxx/aic79xx.h#
85
$
*
* $FreeBSD$
*/
...
...
@@ -258,27 +258,30 @@ typedef enum {
AHD_PCIX_CHIPRST_BUG
=
0x0040
,
/* MMAPIO is not functional in PCI-X mode. */
AHD_PCIX_MMAPIO_BUG
=
0x0080
,
/* Reads to SCBRAM fail to reset the discard timer. */
AHD_PCIX_SCBRAM_RD_BUG
=
0x0100
,
/* Bug workarounds that can be disabled on non-PCIX busses. */
AHD_PCIX_BUG_MASK
=
AHD_PCIX_CHIPRST_BUG
|
AHD_PCIX_MMAPIO_BUG
,
|
AHD_PCIX_MMAPIO_BUG
|
AHD_PCIX_SCBRAM_RD_BUG
,
/*
* LQOSTOP0 status set even for forced selections with ATN
* to perform non-packetized message delivery.
*/
AHD_LQO_ATNO_BUG
=
0x0
1
00
,
AHD_LQO_ATNO_BUG
=
0x0
2
00
,
/* FIFO auto-flush does not always trigger. */
AHD_AUTOFLUSH_BUG
=
0x0
2
00
,
AHD_AUTOFLUSH_BUG
=
0x0
4
00
,
/* The CLRLQO registers are not self-clearing. */
AHD_CLRLQO_AUTOCLR_BUG
=
0x0
4
00
,
AHD_CLRLQO_AUTOCLR_BUG
=
0x0
8
00
,
/* The PACKETIZED status bit refers to the previous connection. */
AHD_PKTIZED_STATUS_BUG
=
0x
08
00
,
AHD_PKTIZED_STATUS_BUG
=
0x
10
00
,
/* "Short Luns" are not placed into outgoing LQ packets correctly. */
AHD_PKT_LUN_BUG
=
0x
1
000
,
AHD_PKT_LUN_BUG
=
0x
2
000
,
/*
* Only the FIFO allocated to the non-packetized connection may
* be in use during a non-packetzied connection.
*/
AHD_NONPACKFIFO_BUG
=
0x
2
000
,
AHD_NONPACKFIFO_BUG
=
0x
4
000
,
/*
* Writing to a DFF SCBPTR register may fail if concurent with
* a hardware write to the other DFF SCBPTR register. This is
...
...
@@ -286,30 +289,40 @@ typedef enum {
* this bug have the AHD_NONPACKFIFO_BUG and all writes of concern
* occur in non-packetized connections.
*/
AHD_MDFF_WSCBPTR_BUG
=
0x
4
000
,
AHD_MDFF_WSCBPTR_BUG
=
0x
8
000
,
/* SGHADDR updates are slow. */
AHD_REG_SLOW_SETTLE_BUG
=
0x
8
000
,
AHD_REG_SLOW_SETTLE_BUG
=
0x
10
000
,
/*
* Changing the MODE_PTR coincident with an interrupt that
* switches to a different mode will cause the interrupt to
* be in the mode written outside of interrupt context.
*/
AHD_SET_MODE_BUG
=
0x
1
0000
,
AHD_SET_MODE_BUG
=
0x
2
0000
,
/* Non-packetized busfree revision does not work. */
AHD_BUSFREEREV_BUG
=
0x
2
0000
,
AHD_BUSFREEREV_BUG
=
0x
4
0000
,
/*
* Paced transfers are indicated with a non-standard PPR
* option bit in the neg table, 160MHz is indicated by
* sync factor 0x7, and the offset if off by a factor of 2.
*/
AHD_PACED_NEGTABLE_BUG
=
0x
4
0000
,
AHD_PACED_NEGTABLE_BUG
=
0x
8
0000
,
/* LQOOVERRUN false positives. */
AHD_LQOOVERRUN_BUG
=
0x
8
0000
,
AHD_LQOOVERRUN_BUG
=
0x
10
0000
,
/*
* Controller write to INTSTAT will lose to a host
* write to CLRINT.
*/
AHD_INTCOLLISION_BUG
=
0x100000
AHD_INTCOLLISION_BUG
=
0x200000
,
/*
* The GEM318 violates the SCSI spec by not waiting
* the mandated bus settle delay between phase changes
* in some situations. Some aic79xx chip revs. are more
* strict in this regard and will treat REQ assertions
* that fall within the bus settle delay window as
* glitches. This flag tells the firmware to tolerate
* early REQ assertions.
*/
AHD_EARLY_REQ_BUG
=
0x400000
}
ahd_bug
;
/*
...
...
@@ -411,7 +424,10 @@ typedef uint32_t sense_addr_t;
#define MAX_CDB_LEN 16
#define MAX_CDB_LEN_WITH_SENSE_ADDR (MAX_CDB_LEN - sizeof(sense_addr_t))
union
initiator_data
{
uint64_t
cdbptr
;
struct
{
uint64_t
cdbptr
;
uint8_t
cdblen
;
}
cdb_from_host
;
uint8_t
cdb
[
MAX_CDB_LEN
];
struct
{
uint8_t
cdb
[
MAX_CDB_LEN_WITH_SENSE_ADDR
];
...
...
@@ -727,7 +743,7 @@ struct ahd_tmode_lstate;
#define AHD_WIDTH_UNKNOWN 0xFF
#define AHD_PERIOD_UNKNOWN 0xFF
#define AHD_OFFSET_UNKNOWN 0x
0
#define AHD_OFFSET_UNKNOWN 0x
FF
#define AHD_PPR_OPTS_UNKNOWN 0xFF
/*
...
...
drivers/scsi/aic7xxx/aic79xx.reg
View file @
14686d42
...
...
@@ -39,7 +39,7 @@
*
* $FreeBSD$
*/
VERSION = "$Id: //depot/aic7xxx/aic7xxx/aic79xx.reg#6
0
$"
VERSION = "$Id: //depot/aic7xxx/aic7xxx/aic79xx.reg#6
4
$"
/*
* This file is processed by the aic7xxx_asm utility for use in assembling
...
...
@@ -2071,14 +2071,14 @@ register LQIMODE1 {
address 0x051
access_mode RW
modes M_CFG
field ENLQIPHASE_LQ 0x80
field ENLQIPHASE_NLQ 0x40
field ENLQIPHASE_LQ 0x80
/* LQIPHASE1 */
field ENLQIPHASE_NLQ 0x40
/* LQIPHASE2 */
field ENLIQABORT 0x20
field ENLQICRCI_LQ 0x10
field ENLQICRCI_NLQ 0x08
field ENLQICRCI_LQ 0x10
/* LQICRCI1 */
field ENLQICRCI_NLQ 0x08
/* LQICRCI2 */
field ENLQIBADLQI 0x04
field ENLQIOVERI_LQ 0x02
field ENLQIOVERI_NLQ 0x01
field ENLQIOVERI_LQ 0x02
/* LQIOVERI1 */
field ENLQIOVERI_NLQ 0x01
/* LQIOVERI2 */
}
/*
...
...
@@ -3769,16 +3769,17 @@ scb {
SCB_RESIDUAL_DATACNT {
size 4
alias SCB_CDB_STORE
alias SCB_HOST_CDB_PTR
}
SCB_RESIDUAL_SGPTR {
size 4
alias SCB_CDB_PTR
field SG_ADDR_MASK 0xf8 /* In the last byte */
field SG_OVERRUN_RESID 0x02 /* In the first byte */
field SG_LIST_NULL 0x01 /* In the first byte */
}
SCB_SCSI_STATUS {
size 1
alias SCB_HOST_CDB_LEN
}
SCB_TARGET_PHASES {
size 1
...
...
drivers/scsi/aic7xxx/aic79xx.seq
View file @
14686d42
...
...
@@ -40,7 +40,7 @@
* $FreeBSD$
*/
VERSION = "$Id: //depot/aic7xxx/aic7xxx/aic79xx.seq#
7
8 $"
VERSION = "$Id: //depot/aic7xxx/aic7xxx/aic79xx.seq#
8
8 $"
PATCH_ARG_LIST = "struct ahd_softc *ahd"
PREFIX = "ahd_"
...
...
@@ -122,22 +122,24 @@ gsfifo_complete_normally:
/*
* Since this status did not consume a FIFO, we have to
* be a bit more dilligent in how we check for FIFOs pertaining
* to this transaction. There are t
hree
states that a FIFO still
* to this transaction. There are t
wo
states that a FIFO still
* transferring data may be in.
*
* 1) Configured and draining to the host, with a pending CLRCHN.
* 2) Configured and draining to the host, no pending CLRCHN.
* 3) Pending cfg4data, fifo not empty.
* 1) Configured and draining to the host, with a FIFO handler.
* 2) Pending cfg4data, fifo not empty.
*
* Case
s 1 and 2 can be detected by noticing that a longjmp is
*
active for the FIFO and LONGJMP_SCB matches our SCB. In this
*
case, we allow
the routine servicing the FIFO to complete the SCB.
* Case
1 can be detected by noticing that a longjmp is active for
*
the FIFO and LONGJMP_SCB matches our SCB. In this case, we allow
* the routine servicing the FIFO to complete the SCB.
*
* Case
3
implies either a pending or yet to occur save data
* Case
2
implies either a pending or yet to occur save data
* pointers for this same context in the other FIFO. So, if
* we detect case
2
, we will properly defer the post of the SCB
* we detect case
1
, we will properly defer the post of the SCB
* and achieve the desired result. The pending cfg4data will
* notice that status has been received and complete the SCB.
*
* If the data-transfer has been completed, or no data transfer
* was needed for this SCB, it is safe to complete the command.
*/
test SCB_SGPTR, SG_LIST_NULL jz good_status_check_fifos;
/*
...
...
@@ -519,7 +521,7 @@ BEGIN_CRITICAL;
/*
* For packetized, the LQO manager clears ENSELO on
* the assertion of SELDO. If we are non-packetized,
* LASTSCB and CURRSCB are ac
u
ate.
* LASTSCB and CURRSCB are ac
cur
ate.
*/
test SCSISEQ0, ENSELO jnz use_lastscb;
...
...
@@ -706,7 +708,7 @@ SET_DST_MODE M_DFF1;
add NONE, -17, SCB_CDB_LEN;
jnc p_command_embedded;
p_command_from_host:
bmov HADDR[0], SCB_
CDB_PTR, 11
;
bmov HADDR[0], SCB_
HOST_CDB_PTR, 9
;
mvi SG_CACHE_PRE, LAST_SEG;
mvi DFCNTRL, (PRELOADEN|SCSIEN|HDMAEN);
jmp p_command_xfer;
...
...
@@ -1030,14 +1032,6 @@ queue_arg1_scb_completion:
SET_MODE(M_SCSI, M_SCSI)
bmov SCBPTR, ARG_1, 2;
queue_scb_completion:
if ((ahd->bugs & AHD_ABORT_LQI_BUG) == 0) {
/*
* Set MK_MESSAGE to trigger an abort should this SCB
* be referenced by a target even though it is not currently
* active.
*/
or SCB_CONTROL, MK_MESSAGE;
}
test SCB_SCSI_STATUS,0xff jnz bad_status;
/*
* Check for residuals
...
...
@@ -1163,7 +1157,28 @@ clear_target_state:
mvi SEQ_FLAGS, NOT_IDENTIFIED|NO_CDB_SENT ret;
phase_lock:
test SCSIPHASE, 0xFF jz .;
if ((ahd->bugs & AHD_EARLY_REQ_BUG) != 0) {
/*
* Don't ignore persistent REQ assertions just because
* they were asserted within the bus settle delay window.
* This allows us to tolerate devices like the GEM318
* that violate the SCSI spec. We are careful not to
* count REQ while we are waiting for it to fall during
* an async phase due to our asserted ACK. Each
* sequencer instruction takes ~25ns, so the REQ must
* last at least 100ns in order to be counted as a true
* REQ.
*/
test SCSIPHASE, 0xFF jnz phase_locked;
test SCSISIGI, ACKI jnz phase_lock;
test SCSISIGI, REQI jz phase_lock;
test SCSIPHASE, 0xFF jnz phase_locked;
test SCSISIGI, ACKI jnz phase_lock;
test SCSISIGI, REQI jz phase_lock;
phase_locked:
} else {
test SCSIPHASE, 0xFF jz .;
}
test SSTAT1, SCSIPERR jnz phase_lock;
phase_lock_latch_phase:
and LASTPHASE, PHASE_MASK, SCSISIGI ret;
...
...
@@ -1247,7 +1262,7 @@ service_fifo:
nop;
}
and SGHADDR[0], SG_PREFETCH_ALIGN_MASK, SCB_RESIDUAL_SGPTR;
mvi CCSGCTL, CCSGEN|
SG_CACHE_AVAIL|
CCSGRESET;
mvi CCSGCTL, CCSGEN|CCSGRESET;
or SG_STATE, FETCH_INPROG ret;
idle_sgfetch_complete:
/*
...
...
@@ -1261,6 +1276,15 @@ idle_sgfetch_complete:
idle_sg_avail:
/* Does the hardware have space for another SG entry? */
test DFSTATUS, PRELOAD_AVAIL jz return;
/*
* On the A, preloading a segment before HDMAENACK
* comes true can clobber the shaddow address of the
* first segment in the S/G FIFO. Wait until it is
* safe to proceed.
*/
if ((ahd->features & AHD_NEW_DFCNTRL_OPTS) == 0) {
test DFCNTRL, HDMAENACK jz return;
}
if ((ahd->flags & AHD_64BIT_ADDRESSING) != 0) {
bmov HADDR, CCSGRAM, 8;
} else {
...
...
@@ -1290,22 +1314,12 @@ sg_advance:
or SINDEX, LAST_SEG;
clr SG_STATE;
mov SG_CACHE_PRE, SINDEX;
/*
* Load the segment. Or in HDMAEN here too
* just in case HDMAENACK has not come true
* by the time this segment is loaded. If
* HDMAENACK is not true, this or will disable
* HDMAEN mid-transfer. We do not want to simply
* mvi our original settings as SCSIEN automatically
* de-asserts and we don't want to accidentally
* re-enable it.
*/
if ((ahd->features & AHD_NEW_DFCNTRL_OPTS) != 0) {
/*
* Use SCSIENWRDIS so that SCSIEN is never
* modified by this operation.
*/
or DFCNTRL, PRELOADEN|
SCSIENWRDIS|HDMAEN
;
or DFCNTRL, PRELOADEN|
HDMAEN|SCSIENWRDIS
;
} else {
or DFCNTRL, PRELOADEN|HDMAEN;
}
...
...
@@ -1510,12 +1524,6 @@ data_phase_done:
* the idle loop and there is no need to perform
* any fixups.
*/
calc_residual:
test SG_CACHE_SHADOW, LAST_SEG jz residual_before_last_seg;
/* Record if we've consumed all S/G entries */
test MDFFSTAT, SHVALID jz . + 2;
bmov SCB_RESIDUAL_DATACNT, SHCNT, 3 ret;
or SCB_RESIDUAL_SGPTR[0], SG_LIST_NULL ret;
residual_before_last_seg:
test MDFFSTAT, SHVALID jnz sgptr_fixup;
/*
...
...
@@ -1525,7 +1533,13 @@ residual_before_last_seg:
*/
call idle_loop_service_fifos;
RESTORE_MODE(SAVED_MODE)
jmp calc_residual;
/* FALLTHROUGH */
calc_residual:
test SG_CACHE_SHADOW, LAST_SEG jz residual_before_last_seg;
/* Record if we've consumed all S/G entries */
test MDFFSTAT, SHVALID jz . + 2;
bmov SCB_RESIDUAL_DATACNT, SHCNT, 3 ret;
or SCB_RESIDUAL_SGPTR[0], SG_LIST_NULL ret;
sgptr_fixup:
/*
...
...
@@ -1570,7 +1584,51 @@ export timer_isr:
}
export seq_isr:
nop; /* Jumps in the first ISR instruction fail on Rev A. */
if ((ahd->features & AHD_RTI) == 0) {
/*
* On RevA Silicon, if the target returns us to data-out
* after we have already trained for data-out, it is
* possible for us to transition the free running clock to
* data-valid before the required 100ns P1 setup time (8 P1
* assertions in fast-160 mode). This will only happen if
* this L-Q is a continuation of a data transfer for which
* we have already prefetched data into our FIFO (LQ/Data
* followed by LQ/Data for the same write transaction).
* This can cause some target implementations to miss the
* first few data transfers on the bus. We detect this
* situation by noticing that this is the first data transfer
* after an LQ (LQIWORKONLQ true), that the data transfer is
* a continuation of a transfer already setup in our FIFO
* (SAVEPTRS interrupt), and that the transaction is a write
* (DIRECTION set in DFCNTRL). The delay is performed by
* disabling SCSIEN until we see the first REQ from the
* target.
*
* First instruction in an ISR cannot be a branch on
* Rev A. Snapshot LQISTAT2 so the status is not missed
* and deffer the test by one instruction.
*/
mov REG_ISR, LQISTAT2;
test REG_ISR, LQIWORKONLQ jz data_valid;
test SEQINTSRC, SAVEPTRS jz data_valid;
test LONGJMP_ADDR[1], INVALID_ADDR jz saveptr_active_fifo;
/*
* Switch to the active FIFO.
*/
xor MODE_PTR, MK_MODE(M_DFF1, M_DFF1);
test DFCNTRL, DIRECTION jz snapshot_other_fifo;
and DFCNTRL, ~SCSIEN;
test SSTAT1, REQINIT jz .;
or DFCNTRL, SCSIEN;
/* FALLTHROUGH */
snapshot_other_fifo:
xor MODE_PTR, MK_MODE(M_DFF1, M_DFF1);
/* FALLTHROUGH */
snapshot_saveptr:
mvi DFFSXFRCTL, CLRCHN;
or SEQINTCTL, IRET ret;
data_valid:
}
test SEQINTSRC, CFG4DATA jnz cfg4data_intr;
test SEQINTSRC, CFG4ISTAT jnz cfg4istat_intr;
test SEQINTSRC, SAVEPTRS jnz saveptr_intr;
...
...
@@ -1583,21 +1641,23 @@ export seq_isr:
* active and contains a snapshot of the current poniter information.
* This happens between packets in a stream for a single L_Q. Since we
* are not performing a pointer save, we can safely clear the channel
* so it can be used for other transactions.
* so it can be used for other transactions. On RTI capable controllers,
* where snapshots can, and are, disabled, the code to handle this type
* of snapshot is not active.
*
* The second case is a save pointers on an active FIFO which occurs
* if the target changes to a new L_Q or busfrees/QAS
'
and the transfer
* if the target changes to a new L_Q or busfrees/QAS
es
and the transfer
* has a residual. This should occur coincident with a ctxtdone. We
* disable the interrupt and allow our active routine to handle the
* save.
*/
saveptr_intr:
test DFCNTRL, HDMAENACK jz snapshot_saveptr;
if ((ahd->features & AHD_RTI) == 0) {
test LONGJMP_ADDR[1], INVALID_ADDR jnz snapshot_saveptr;
}
saveptr_active_fifo:
and SEQIMODE, ~ENSAVEPTRS;
or SEQINTCTL, IRET ret;
snapshot_saveptr:
mvi DFFSXFRCTL, CLRCHN;
or SEQINTCTL, IRET ret;
cfg4data_intr:
test SCB_SGPTR[0], SG_LIST_NULL jnz pkt_handle_overrun;
...
...
@@ -1633,6 +1693,18 @@ cfg4istat_no_taskmgmt_func:
call pkt_handle_status;
or SEQINTCTL, IRET ret;
cfg4icmd_intr:
/*
* In the case of DMAing a CDB from the host, the normal
* CDB buffer is formatted with an 8 byte address followed
* by a 1 byte count.
*/
bmov HADDR[0], SCB_HOST_CDB_PTR, 9;
mvi SG_CACHE_PRE, LAST_SEG;
mvi DFCNTRL, (PRELOADEN|SCSIEN|HDMAEN);
call pkt_handle_cdb;
or SEQINTCTL, IRET ret;
/*
* See if the target has gone on in this context creating an
* overrun condition. For the write case, the hardware cannot
...
...
@@ -1672,7 +1744,7 @@ pkt_service_fifo:
pkt_last_seg:
call setjmp;
test SEQINTSRC, SAVEPTRS jnz pkt_saveptrs;
test SG_CACHE_SHADOW, LAST_SEG_DONE jnz last_pkt_done;
test SG_CACHE_SHADOW, LAST_SEG_DONE jnz last_pkt_
xfer_
done;
test SCSIPHASE, ~DATA_PHASE_MASK jz . + 2;
test SCSISIGO, ATNO jnz . + 2;
test SSTAT2, NONPACKREQ jz return;
...
...
@@ -1716,7 +1788,7 @@ pkt_saveptrs_clrchn:
mvi DFFSXFRCTL, CLRCHN ret;
END_CRITICAL;
last_pkt_done:
last_pkt_
xfer_
done:
BEGIN_CRITICAL;
if ((ahd->bugs & AHD_AUTOFLUSH_BUG) != 0) {
or DFCNTRL, FIFOFLUSH;
...
...
@@ -1765,13 +1837,15 @@ BEGIN_CRITICAL;
mvi DFFSXFRCTL, CLRCHN ret;
END_CRITICAL;
check_status_overrun:
test SHCNT[2], 0xFF jz status_IU_done;
SET_SEQINTCODE(STATUS_OVERRUN)
jmp status_IU_done;
/*
* Watch over the status transfer. Our host sense buffer is
* large enough to take the maximum allowed status packet.
* None-the-less, we must still catch and report overruns to
* the host.
*/
pkt_handle_status:
call setjmp_setscb;
test
MDFFSTAT, LASTSDONE jn
z check_status_overrun;
test
SG_CACHE_SHADOW, LAST_SEG_DONE j
z check_status_overrun;
test SEQINTSRC, CTXTDONE jz return;
status_IU_done:
BEGIN_CRITICAL;
...
...
@@ -1783,6 +1857,21 @@ BEGIN_CRITICAL;
or SCB_CONTROL, STATUS_RCVD;
jmp last_pkt_complete;
END_CRITICAL;
check_status_overrun:
/*
* We've filled the entire sense buffer.
* Wait for either context done or a negative
* shaddow count. If the context completes without
* causing the shaddow count to go negative, then
* this was a successful transfer up to the status
* limit. Otherwise we report the error.
*/
test SHCNT[2], 0xFF jnz report_status_overrun;
test SEQINTSRC, CTXTDONE jz return;
test SHCNT[2], 0xFF jz status_IU_done;
report_status_overrun:
SET_SEQINTCODE(STATUS_OVERRUN)
jmp status_IU_done;
SET_SRC_MODE M_DFF0;
SET_DST_MODE M_DFF0;
...
...
@@ -1796,6 +1885,16 @@ check_fifo:
stc ret;
END_CRITICAL;
/*
* Must wait until CDB xfer is over before issuing the
* clear channel.
*/
pkt_handle_cdb:
call setjmp_setscb;
test SG_CACHE_SHADOW, LAST_SEG_DONE jz return;
or LONGJMP_ADDR[1], INVALID_ADDR;
mvi DFFSXFRCTL, CLRCHN ret;
/*
* Nonpackreq is a polled status. It can come true in three situations:
* we have received an L_Q, we have sent one or more L_Qs, or there is no
...
...
@@ -1865,6 +1964,7 @@ pkt_overrun_end:
or SCB_RESIDUAL_SGPTR, SG_OVERRUN_RESID;
test SEQINTSRC, CTXTDONE jz unexpected_nonpkt_phase;
test SCB_CONTROL, STATUS_RCVD jnz last_pkt_queue_scb;
or LONGJMP_ADDR[1], INVALID_ADDR;
mvi DFFSXFRCTL, CLRCHN ret;
if ((ahd->bugs & AHD_PKT_BITBUCKET_BUG) != 0) {
...
...
@@ -1885,5 +1985,3 @@ load_overrun_buf:
mvi HCNT[1], ((PKT_OVERRUN_BUFSIZE >> 8) & 0xFF);
clr HCNT[2] ret;
}
cfg4icmd_intr:
drivers/scsi/aic7xxx/aic79xx_core.c
View file @
14686d42
...
...
@@ -37,7 +37,7 @@
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGES.
*
* $Id: //depot/aic7xxx/aic7xxx/aic79xx.c#1
56
$
* $Id: //depot/aic7xxx/aic7xxx/aic79xx.c#1
72
$
*
* $FreeBSD$
*/
...
...
@@ -406,7 +406,7 @@ ahd_flush_qoutfifo(struct ahd_softc *ahd)
u_int
i
;
ahd_set_scbptr
(
ahd
,
scbid
);
next_scbid
=
ahd_inw
(
ahd
,
SCB_NEXT_COMPLETE
);
next_scbid
=
ahd_inw
_scbram
(
ahd
,
SCB_NEXT_COMPLETE
);
scb
=
ahd_lookup_scb
(
ahd
,
scbid
);
if
(
scb
==
NULL
)
{
printf
(
"%s: Warning - DMA-up and complete "
...
...
@@ -415,7 +415,7 @@ ahd_flush_qoutfifo(struct ahd_softc *ahd)
}
hscb_ptr
=
(
uint8_t
*
)
scb
->
hscb
;
for
(
i
=
0
;
i
<
sizeof
(
struct
hardware_scb
);
i
++
)
*
hscb_ptr
++
=
ahd_inb
(
ahd
,
SCB_BASE
+
i
);
*
hscb_ptr
++
=
ahd_inb
_scbram
(
ahd
,
SCB_BASE
+
i
);
ahd_complete_scb
(
ahd
,
scb
);
scbid
=
next_scbid
;
...
...
@@ -426,7 +426,7 @@ ahd_flush_qoutfifo(struct ahd_softc *ahd)
while
(
!
SCBID_IS_NULL
(
scbid
))
{
ahd_set_scbptr
(
ahd
,
scbid
);
next_scbid
=
ahd_inw
(
ahd
,
SCB_NEXT_COMPLETE
);
next_scbid
=
ahd_inw
_scbram
(
ahd
,
SCB_NEXT_COMPLETE
);
scb
=
ahd_lookup_scb
(
ahd
,
scbid
);
if
(
scb
==
NULL
)
{
printf
(
"%s: Warning - Complete SCB %d invalid
\n
"
,
...
...
@@ -1249,6 +1249,14 @@ ahd_handle_scsiint(struct ahd_softc *ahd, u_int intstat)
ahd_outb
(
ahd
,
CLRSINT3
,
status3
);
}
else
if
((
lqistat1
&
(
LQIPHASE_LQ
|
LQIPHASE_NLQ
))
!=
0
)
{
ahd_handle_lqiphase_error
(
ahd
,
lqistat1
);
}
else
if
((
lqistat1
&
LQICRCI_NLQ
)
!=
0
)
{
/*
* This status can be delayed during some
* streaming operations. The SCSIPHASE
* handler has already dealt with this case
* so just clear the error.
*/
ahd_outb
(
ahd
,
CLRLQIINT1
,
CLRLQICRCI_NLQ
);
}
else
if
((
status
&
BUSFREE
)
!=
0
)
{
u_int
lqostat1
;
int
restart
;
...
...
@@ -1284,9 +1292,9 @@ ahd_handle_scsiint(struct ahd_softc *ahd, u_int intstat)
scbid
=
ahd_get_scbptr
(
ahd
);
scb
=
ahd_lookup_scb
(
ahd
,
scbid
);
if
(
scb
==
NULL
)
{
printf
(
"%s: Invalid SCB in DFF%d "
printf
(
"%s: Invalid SCB
%d
in DFF%d "
"during unexpected busfree
\n
"
,
ahd_name
(
ahd
),
mode
);
ahd_name
(
ahd
),
scbid
,
mode
);
packetized
=
0
;
}
else
packetized
=
(
scb
->
flags
&
SCB_PACKETIZED
)
!=
0
;
...
...
@@ -1626,14 +1634,6 @@ ahd_handle_pkt_busfree(struct ahd_softc *ahd, u_int busfreetime)
scb
=
ahd_lookup_scb
(
ahd
,
scbid
);
if
(
scb
==
NULL
)
panic
(
"SCB not valid during LQOBUSFREE"
);
/*
* Return the LQO manager to its idle loop. It will
* not do this automatically if the busfree occurs
* after the first REQ of either the LQ or command
* packet or between the LQ and command packet.
*/
ahd_outb
(
ahd
,
LQCTL2
,
ahd_inb
(
ahd
,
LQCTL2
)
|
LQOTOIDLE
);
/*
* Clear the status.
*/
...
...
@@ -1641,8 +1641,17 @@ ahd_handle_pkt_busfree(struct ahd_softc *ahd, u_int busfreetime)
if
((
ahd
->
bugs
&
AHD_CLRLQO_AUTOCLR_BUG
)
!=
0
)
ahd_outb
(
ahd
,
CLRLQOINT1
,
0
);
ahd_outb
(
ahd
,
SCSISEQ0
,
ahd_inb
(
ahd
,
SCSISEQ0
)
&
~
ENSELO
);
ahd_flush_device_writes
(
ahd
);
ahd_outb
(
ahd
,
CLRSINT0
,
CLRSELDO
);
/*
* Return the LQO manager to its idle loop. It will
* not do this automatically if the busfree occurs
* after the first REQ of either the LQ or command
* packet or between the LQ and command packet.
*/
ahd_outb
(
ahd
,
LQCTL2
,
ahd_inb
(
ahd
,
LQCTL2
)
|
LQOTOIDLE
);
/*
* Update the waiting for selection queue so
* we restart on the correct SCB.
...
...
@@ -1653,12 +1662,12 @@ ahd_handle_pkt_busfree(struct ahd_softc *ahd, u_int busfreetime)
ahd_outw
(
ahd
,
WAITING_TID_HEAD
,
scbid
);
waiting_t
=
ahd_inw
(
ahd
,
WAITING_TID_TAIL
);
next
=
SCB_LIST_NULL
;
if
(
waiting_t
==
waiting_h
)
{
ahd_outw
(
ahd
,
WAITING_TID_TAIL
,
scbid
);
next
=
SCB_LIST_NULL
;
}
else
{
ahd_set_scbptr
(
ahd
,
waiting_h
);
next
=
ahd_inw
(
ahd
,
SCB_NEXT2
);
next
=
ahd_inw
_scbram
(
ahd
,
SCB_NEXT2
);
}
ahd_set_scbptr
(
ahd
,
scbid
);
ahd_outw
(
ahd
,
SCB_NEXT2
,
next
);
...
...
@@ -1704,6 +1713,7 @@ ahd_handle_pkt_busfree(struct ahd_softc *ahd, u_int busfreetime)
scb
=
ahd_lookup_scb
(
ahd
,
scbid
);
ahd_print_path
(
ahd
,
scb
);
printf
(
"Unexpected PKT busfree condition
\n
"
);
ahd_dump_card_state
(
ahd
);
ahd_abort_scbs
(
ahd
,
SCB_GET_TARGET
(
ahd
,
scb
),
'A'
,
SCB_GET_LUN
(
scb
),
SCB_GET_TAG
(
scb
),
ROLE_INITIATOR
,
CAM_UNEXP_BUSFREE
);
...
...
@@ -1988,7 +1998,8 @@ ahd_handle_proto_violation(struct ahd_softc *ahd)
if
((
seq_flags
&
NO_CDB_SENT
)
!=
0
)
{
ahd_print_path
(
ahd
,
scb
);
printf
(
"No or incomplete CDB sent to device.
\n
"
);
}
else
if
((
ahd_inb
(
ahd
,
SCB_CONTROL
)
&
STATUS_RCVD
)
==
0
)
{
}
else
if
((
ahd_inb_scbram
(
ahd
,
SCB_CONTROL
)
&
STATUS_RCVD
)
==
0
)
{
/*
* The target never bothered to provide status to
* us prior to completing the command. Since we don't
...
...
@@ -2605,8 +2616,12 @@ ahd_set_syncrate(struct ahd_softc *ahd, struct ahd_devinfo *devinfo,
ahd_name
(
ahd
),
devinfo
->
target
,
period
,
offset
);
options
=
0
;
if
((
ppr_options
&
MSG_EXT_PPR_RD_STRM
)
!=
0
)
{
printf
(
"(RDSTRM"
);
options
++
;
}
if
((
ppr_options
&
MSG_EXT_PPR_DT_REQ
)
!=
0
)
{
printf
(
"(DT"
);
printf
(
"
%s"
,
options
?
"|DT"
:
"
(DT"
);
options
++
;
}
if
((
ppr_options
&
MSG_EXT_PPR_IU_REQ
)
!=
0
)
{
...
...
@@ -4980,6 +4995,8 @@ ahd_reset(struct ahd_softc *ahd)
* to disturb the integrity of the bus.
*/
ahd_pause
(
ahd
);
ahd_update_modes
(
ahd
);
ahd_set_modes
(
ahd
,
AHD_MODE_SCSI
,
AHD_MODE_SCSI
);
sxfrctl1
=
ahd_inb
(
ahd
,
SXFRCTL1
);
cmd
=
ahd_pci_read_config
(
ahd
->
dev_softc
,
PCIR_COMMAND
,
/*bytes*/
2
);
...
...
@@ -5028,13 +5045,16 @@ ahd_reset(struct ahd_softc *ahd)
ahd_pci_write_config
(
ahd
->
dev_softc
,
PCIR_COMMAND
,
cmd
,
/*bytes*/
2
);
}
/* After a reset, we know the state of the mode register. */
ahd_known_modes
(
ahd
,
AHD_MODE_SCSI
,
AHD_MODE_SCSI
);
/* Determine chip configuration */
ahd
->
features
&=
~
AHD_WIDE
;
if
((
ahd_inb
(
ahd
,
SBLKCTL
)
&
SELWIDE
)
!=
0
)
ahd
->
features
|=
AHD_WIDE
;
/*
* Mode should be SCSI after a chip reset, but lets
* set it just to be safe. We touch the MODE_PTR
* register directly so as to bypass the lazy update
* code in ahd_set_modes().
*/
ahd_known_modes
(
ahd
,
AHD_MODE_SCSI
,
AHD_MODE_SCSI
);
ahd_outb
(
ahd
,
MODE_PTR
,
ahd_build_mode_state
(
ahd
,
AHD_MODE_SCSI
,
AHD_MODE_SCSI
));
/*
* Restore SXFRCTL1.
...
...
@@ -5047,9 +5067,14 @@ ahd_reset(struct ahd_softc *ahd)
ahd_outb
(
ahd
,
SXFRCTL1
,
sxfrctl1
|
STPWEN
);
ahd_outb
(
ahd
,
SXFRCTL1
,
sxfrctl1
);
/* Determine chip configuration */
ahd
->
features
&=
~
AHD_WIDE
;
if
((
ahd_inb
(
ahd
,
SBLKCTL
)
&
SELWIDE
)
!=
0
)
ahd
->
features
|=
AHD_WIDE
;
/*
* If a recovery action has forced a chip reset,
* re-initialize the chip to our lik
e
ing.
* re-initialize the chip to our liking.
*/
if
(
ahd
->
init_level
>
0
)
ahd_chip_init
(
ahd
);
...
...
@@ -5158,7 +5183,7 @@ ahd_init_scbdata(struct ahd_softc *ahd)
scb_data
->
init_level
++
;
/* DMA tag for our S/G structures. */
if
(
ahd_dma_tag_create
(
ahd
,
ahd
->
parent_dmat
,
/*alignment*/
1
,
if
(
ahd_dma_tag_create
(
ahd
,
ahd
->
parent_dmat
,
/*alignment*/
8
,
/*boundary*/
BUS_SPACE_MAXADDR_32BIT
+
1
,
/*lowaddr*/
BUS_SPACE_MAXADDR_32BIT
,
/*highaddr*/
BUS_SPACE_MAXADDR
,
...
...
@@ -5793,7 +5818,9 @@ ahd_init(struct ahd_softc *ahd)
/* DMA tag for mapping buffers into device visible space. */
if
(
ahd_dma_tag_create
(
ahd
,
ahd
->
parent_dmat
,
/*alignment*/
1
,
/*boundary*/
BUS_SPACE_MAXADDR_32BIT
+
1
,
/*lowaddr*/
BUS_SPACE_MAXADDR
,
/*lowaddr*/
ahd
->
flags
&
AHD_39BIT_ADDRESSING
?
(
bus_addr_t
)
0x7FFFFFFFFFULL
:
BUS_SPACE_MAXADDR_32BIT
,
/*highaddr*/
BUS_SPACE_MAXADDR
,
/*filter*/
NULL
,
/*filterarg*/
NULL
,
/*maxsize*/
(
AHD_NSEG
-
1
)
*
PAGE_SIZE
,
...
...
@@ -6050,7 +6077,7 @@ ahd_chip_init(struct ahd_softc *ahd)
}
else
{
ahd_outb
(
ahd
,
OPTIONMODE
,
AUTOACKEN
|
BUSFREEREV
|
AUTO_MSGOUT_DE
);
}
ahd_outb
(
ahd
,
SCSCHKN
,
CURRFIFODEF
|
WIDERESEN
);
ahd_outb
(
ahd
,
SCSCHKN
,
CURRFIFODEF
|
WIDERESEN
|
SHVALIDSTDIS
);
if
((
ahd
->
chip
&
AHD_BUS_MASK
)
==
AHD_PCIX
)
/*
* Do not issue a target abort when a split completion
...
...
@@ -6341,7 +6368,7 @@ ahd_default_config(struct ahd_softc *ahd)
#else
tinfo
->
user
.
period
=
AHD_SYNCRATE_160
;
#endif
tinfo
->
user
.
offset
=
~
0
;
tinfo
->
user
.
offset
=
MAX_OFFSET
;
tinfo
->
user
.
ppr_options
=
MSG_EXT_PPR_RD_STRM
|
MSG_EXT_PPR_WR_FLOW
|
MSG_EXT_PPR_HOLD_MCS
...
...
@@ -6565,13 +6592,13 @@ ahd_enable_coalessing(struct ahd_softc *ahd, int enable)
void
ahd_pause_and_flushwork
(
struct
ahd_softc
*
ahd
)
{
u_int
intstat
;
u_int
maxloops
;
int
paused
;
ahd_mode_state
saved_modes
;
u_int
intstat
;
u_int
maxloops
;
int
paused
;
maxloops
=
1000
;
ahd
->
flags
|=
AHD_ALL_INTERRUPTS
;
intstat
=
0
;
paused
=
FALSE
;
do
{
struct
scb
*
waiting_scb
;
...
...
@@ -6582,6 +6609,8 @@ ahd_pause_and_flushwork(struct ahd_softc *ahd)
ahd_pause
(
ahd
);
paused
=
TRUE
;
ahd_clear_critical_section
(
ahd
);
saved_modes
=
ahd_save_modes
(
ahd
);
ahd_set_modes
(
ahd
,
AHD_MODE_SCSI
,
AHD_MODE_SCSI
);
if
((
ahd_inb
(
ahd
,
SSTAT0
)
&
(
SELDO
|
SELINGO
))
==
0
)
ahd_outb
(
ahd
,
SCSISEQ0
,
ahd_inb
(
ahd
,
SCSISEQ0
)
&
~
ENSELO
);
...
...
@@ -6598,10 +6627,10 @@ ahd_pause_and_flushwork(struct ahd_softc *ahd)
ahd_outb
(
ahd
,
SCSISEQ0
,
ahd_inb
(
ahd
,
SCSISEQ0
)
|
ENSELO
);
if
(
intstat
==
0xFF
&&
(
ahd
->
features
&
AHD_REMOVABLE
)
!=
0
)
break
;
intstat
=
ahd_inb
(
ahd
,
INTSTAT
);
}
while
(
--
maxloops
&&
(((
intstat
=
ahd_inb
(
ahd
,
INTSTAT
))
&
INT_PEND
)
!=
0
&&
(
intstat
!=
0xFF
||
(
ahd
->
features
&
AHD_REMOVABLE
)
==
0
)
&&
((
intstat
&
INT_PEND
)
!=
0
||
(
ahd_inb
(
ahd
,
SSTAT0
)
&
(
SELDO
|
SELINGO
))));
if
(
maxloops
==
0
)
{
printf
(
"Infinite interrupt loop, INTSTAT = %x"
,
...
...
@@ -6612,6 +6641,7 @@ ahd_pause_and_flushwork(struct ahd_softc *ahd)
ahd_platform_flushwork
(
ahd
);
ahd
->
flags
&=
~
AHD_ALL_INTERRUPTS
;
ahd_restore_modes
(
ahd
,
saved_modes
);
}
int
...
...
@@ -7670,7 +7700,6 @@ ahd_handle_scsi_status(struct ahd_softc *ahd, struct scb *scb)
{
struct
hardware_scb
*
hscb
;
u_int
qfreeze_cnt
;
ahd_mode_state
saved_modes
;
/*
* The sequencer freezes its select-out queue
...
...
@@ -7682,7 +7711,6 @@ ahd_handle_scsi_status(struct ahd_softc *ahd, struct scb *scb)
/* Freeze the queue until the client sees the error. */
ahd_pause
(
ahd
);
saved_modes
=
ahd_save_modes
(
ahd
);
ahd_clear_critical_section
(
ahd
);
ahd_set_modes
(
ahd
,
AHD_MODE_SCSI
,
AHD_MODE_SCSI
);
ahd_freeze_devq
(
ahd
,
scb
);
...
...
@@ -8148,7 +8176,7 @@ ahd_loadseq(struct ahd_softc *ahd)
/* Start by aligning to the nearest cacheline. */
sg_prefetch_align
=
ahd
->
pci_cachesize
;
if
(
sg_prefetch_align
==
0
)
sg_prefetch_
cnt
=
8
;
sg_prefetch_
align
=
8
;
/* Round down to the nearest power of 2. */
while
(
powerof2
(
sg_prefetch_align
)
==
0
)
sg_prefetch_align
--
;
...
...
drivers/scsi/aic7xxx/aic79xx_inline.h
View file @
14686d42
...
...
@@ -37,7 +37,7 @@
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGES.
*
* $Id: //depot/aic7xxx/aic7xxx/aic79xx_inline.h#4
1
$
* $Id: //depot/aic7xxx/aic7xxx/aic79xx_inline.h#4
4
$
*
* $FreeBSD$
*/
...
...
@@ -678,7 +678,8 @@ ahd_inb_scbram(struct ahd_softc *ahd, u_int offset)
* Razor #528
*/
value
=
ahd_inb
(
ahd
,
offset
);
ahd_inb
(
ahd
,
MODE_PTR
);
if
((
ahd
->
flags
&
AHD_PCIX_SCBRAM_RD_BUG
)
!=
0
)
ahd_inb
(
ahd
,
MODE_PTR
);
return
(
value
);
}
...
...
drivers/scsi/aic7xxx/aic79xx_osm.c
View file @
14686d42
/*
* Adaptec AIC79xx device driver for Linux.
*
* $Id: //depot/aic7xxx/linux/drivers/scsi/aic7xxx/aic79xx_osm.c#1
15
$
* $Id: //depot/aic7xxx/linux/drivers/scsi/aic7xxx/aic79xx_osm.c#1
28
$
*
* --------------------------------------------------------------------------
* Copyright (c) 1994-2000 Justin T. Gibbs.
...
...
@@ -994,9 +994,13 @@ ahd_linux_queue(Scsi_Cmnd * cmd, void (*scsi_done) (Scsi_Cmnd *))
cmd
->
device
->
id
,
cmd
->
device
->
lun
,
/*alloc*/
TRUE
);
if
(
dev
==
NULL
)
{
ahd_cmd_set_transaction_status
(
cmd
,
CAM_RESRC_UNAVAIL
);
ahd_linux_queue_cmd_complete
(
ahd
,
cmd
);
ahd_schedule_completeq
(
ahd
,
NULL
);
ahd_midlayer_entrypoint_unlock
(
ahd
,
&
flags
);
printf
(
"aic79xx_linux_queue: Unable to allocate device!
\n
"
);
return
(
-
ENOMEM
);
printf
(
"%s: aic79xx_linux_queue - Unable to allocate device!
\n
"
,
ahd_name
(
ahd
));
return
(
0
);
}
if
(
cmd
->
cmd_len
>
MAX_CDB_LEN
)
return
(
-
EINVAL
);
...
...
@@ -1215,6 +1219,7 @@ ahd_linux_abort(Scsi_Cmnd *cmd)
u_int
saved_scbptr
;
u_int
active_scbptr
;
u_int
last_phase
;
u_int
cdb_byte
;
int
retval
;
int
paused
;
int
wait
;
...
...
@@ -1227,9 +1232,12 @@ ahd_linux_abort(Scsi_Cmnd *cmd)
ahd
=
*
(
struct
ahd_softc
**
)
cmd
->
device
->
host
->
hostdata
;
acmd
=
(
struct
ahd_cmd
*
)
cmd
;
printf
(
"%s:%d:%d:%d: Attempting to abort cmd %p
\n
"
,
printf
(
"%s:%d:%d:%d: Attempting to abort cmd %p
:
"
,
ahd_name
(
ahd
),
cmd
->
device
->
channel
,
cmd
->
device
->
id
,
cmd
->
device
->
lun
,
cmd
);
for
(
cdb_byte
=
0
;
cdb_byte
<
cmd
->
cmd_len
;
cdb_byte
++
)
printf
(
" 0x%x"
,
cmd
->
cmnd
[
cdb_byte
]);
printf
(
"
\n
"
);
/*
* In all versions of Linux, we have to work around
...
...
@@ -1456,14 +1464,14 @@ ahd_linux_abort(Scsi_Cmnd *cmd)
struct
timer_list
timer
;
int
ret
;
ahd
->
platform_data
->
flags
|=
AHD_UP_EH_SEMAPHORE
;
pending_scb
->
platform_data
->
flags
|=
AHD_SCB_UP_EH_SEM
;
#if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)
ahd_unlock
(
ahd
,
&
s
);
#else
spin_unlock_irq
(
ahd
->
platform_data
->
host
->
host_lock
);
#endif
init_timer
(
&
timer
);
timer
.
data
=
(
u_long
)
ahd
;
timer
.
data
=
(
u_long
)
pending_scb
;
timer
.
expires
=
jiffies
+
(
5
*
HZ
);
timer
.
function
=
ahd_linux_sem_timeout
;
add_timer
(
&
timer
);
...
...
@@ -1577,14 +1585,14 @@ ahd_linux_dev_reset(Scsi_Cmnd *cmd)
LIST_INSERT_HEAD
(
&
ahd
->
pending_scbs
,
scb
,
pending_links
);
ahd_queue_scb
(
ahd
,
scb
);
ahd
->
platform_data
->
flags
|=
AHD_UP_EH_SEMAPHORE
;
scb
->
platform_data
->
flags
|=
AHD_SCB_UP_EH_SEM
;
#if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)
ahd_unlock
(
ahd
,
&
s
);
#else
spin_unlock_irq
(
ahd
->
platform_data
->
host
->
host_lock
);
#endif
init_timer
(
&
timer
);
timer
.
data
=
(
u_long
)
ahd
;
timer
.
data
=
(
u_long
)
scb
;
timer
.
expires
=
jiffies
+
(
5
*
HZ
);
timer
.
function
=
ahd_linux_sem_timeout
;
add_timer
(
&
timer
);
...
...
@@ -1691,7 +1699,7 @@ Scsi_Host_Template aic79xx_driver_template = {
.
max_sectors
=
8192
,
#endif
#if defined CONFIG_HIGHIO || LINUX_VERSION_CODE >= KERNEL_VERSION(2,5,0)
#if LINUX_VERSION_CODE < KERNEL_VERSION(2,4,1
8
)
#if LINUX_VERSION_CODE < KERNEL_VERSION(2,4,1
0
)
/* Assume RedHat Distribution with its different HIGHIO conventions. */
.
can_dma_32
=
1
,
.
single_sg_okay
=
1
,
...
...
@@ -2405,8 +2413,23 @@ ahd_linux_register_host(struct ahd_softc *ahd, Scsi_Host_Template *template)
* negotiation will occur for the first command, and DV
* will comence should that first command be successful.
*/
for
(
target
=
0
;
target
<
host
->
max_id
;
target
++
)
for
(
target
=
0
;
target
<
host
->
max_id
;
target
++
)
{
/*
* Skip our own ID. Some Compaq/HP storage devices
* have enclosure management devices that respond to
* single bit selection (i.e. selecting ourselves).
* It is expected that either an external application
* or a modified kernel will be used to probe this
* ID if it is appropriate. To accomodate these installations,
* ahc_linux_alloc_target() will allocate for our ID if
* asked to do so.
*/
if
(
target
==
ahd
->
our_id
)
continue
;
ahd_linux_alloc_target
(
ahd
,
0
,
target
);
}
ahd_intr_enable
(
ahd
,
TRUE
);
ahd_linux_start_dv
(
ahd
);
ahd_unlock
(
ahd
,
&
s
);
...
...
@@ -2851,16 +2874,21 @@ ahd_linux_dv_thread(void *data)
printf
(
"In DV Thread
\n
"
);
#endif
/*
* Complete thread creation.
*/
lock_kernel
();
#if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,60)
/*
* Don't care about any signals.
*/
siginitsetinv
(
&
current
->
blocked
,
0
);
/*
* Complete thread creation.
*/
lock_kernel
();
daemonize
();
sprintf
(
current
->
comm
,
"ahd_dv_%d"
,
ahd
->
unit
);
#else
daemonize
(
"ahd_dv_%d"
,
ahd
->
unit
);
#endif
unlock_kernel
();
while
(
1
)
{
...
...
@@ -3026,6 +3054,7 @@ ahd_linux_dv_target(struct ahd_softc *ahd, u_int target_offset)
}
case
AHD_DV_STATE_TUR
:
case
AHD_DV_STATE_BUSY
:
timeout
=
5
*
HZ
;
ahd_linux_dv_tur
(
ahd
,
cmd
,
&
devinfo
);
break
;
case
AHD_DV_STATE_REBD
:
...
...
@@ -4437,17 +4466,6 @@ static struct ahd_linux_target*
ahd_linux_alloc_target
(
struct
ahd_softc
*
ahd
,
u_int
channel
,
u_int
target
)
{
struct
ahd_linux_target
*
targ
;
u_int
target_offset
;
target_offset
=
target
;
/*
* Never allow allocation of a target object for
* our own SCSIID.
*/
if
(
target
==
ahd
->
our_id
)
{
ahd
->
platform_data
->
targets
[
target_offset
]
=
NULL
;
return
(
NULL
);
}
targ
=
malloc
(
sizeof
(
*
targ
),
M_DEVBUF
,
M_NOWAIT
);
if
(
targ
==
NULL
)
...
...
@@ -4457,7 +4475,7 @@ ahd_linux_alloc_target(struct ahd_softc *ahd, u_int channel, u_int target)
targ
->
target
=
target
;
targ
->
ahd
=
ahd
;
targ
->
flags
=
AHD_DV_REQUIRED
;
ahd
->
platform_data
->
targets
[
target
_offset
]
=
targ
;
ahd
->
platform_data
->
targets
[
target
]
=
targ
;
return
(
targ
);
}
...
...
@@ -4699,6 +4717,14 @@ ahd_done(struct ahd_softc *ahd, struct scb *scb)
#endif
ahd_set_transaction_status
(
scb
,
CAM_UNCOR_PARITY
);
}
else
if
(
amount_xferred
<
scb
->
io_ctx
->
underflow
)
{
u_int
i
;
ahd_print_path
(
ahd
,
scb
);
printf
(
"CDB:"
);
for
(
i
=
0
;
i
<
scb
->
io_ctx
->
cmd_len
;
i
++
)
printf
(
" 0x%x"
,
scb
->
io_ctx
->
cmnd
[
i
]);
printf
(
"
\n
"
);
ahd_print_path
(
ahd
,
scb
);
printf
(
"Saw underflow (%ld of %ld bytes). "
"Treated as error
\n
"
,
ahd_get_residual
(
scb
),
...
...
@@ -4755,8 +4781,8 @@ ahd_done(struct ahd_softc *ahd, struct scb *scb)
if
(
ahd_get_transaction_status
(
scb
)
==
CAM_BDR_SENT
||
ahd_get_transaction_status
(
scb
)
==
CAM_REQ_ABORTED
)
ahd_set_transaction_status
(
scb
,
CAM_CMD_TIMEOUT
);
if
((
ahd
->
platform_data
->
flags
&
AHD_UP_EH_SEMAPHORE
)
!=
0
)
{
ahd
->
platform_data
->
flags
&=
~
AHD_UP_EH_SEMAPHORE
;
if
((
scb
->
platform_data
->
flags
&
AHD_SCB_UP_EH_SEM
)
!=
0
)
{
scb
->
platform_data
->
flags
&=
~
AHD_SCB_UP_EH_SEM
;
up
(
&
ahd
->
platform_data
->
eh_sem
);
}
}
...
...
@@ -5258,13 +5284,15 @@ ahd_release_simq(struct ahd_softc *ahd)
static
void
ahd_linux_sem_timeout
(
u_long
arg
)
{
struct
scb
*
scb
;
struct
ahd_softc
*
ahd
;
u_long
s
;
ahd
=
(
struct
ahd_softc
*
)
arg
;
scb
=
(
struct
scb
*
)
arg
;
ahd
=
scb
->
ahd_softc
;
ahd_lock
(
ahd
,
&
s
);
if
((
ahd
->
platform_data
->
flags
&
AHD_UP_EH_SEMAPHORE
)
!=
0
)
{
ahd
->
platform_data
->
flags
&=
~
AHD_UP_EH_SEMAPHORE
;
if
((
scb
->
platform_data
->
flags
&
AHD_SCB_UP_EH_SEM
)
!=
0
)
{
scb
->
platform_data
->
flags
&=
~
AHD_SCB_UP_EH_SEM
;
up
(
&
ahd
->
platform_data
->
eh_sem
);
}
ahd_unlock
(
ahd
,
&
s
);
...
...
drivers/scsi/aic7xxx/aic79xx_osm.h
View file @
14686d42
...
...
@@ -36,7 +36,7 @@
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGES.
*
* $Id: //depot/aic7xxx/linux/drivers/scsi/aic7xxx/aic79xx_osm.h#1
08
$
* $Id: //depot/aic7xxx/linux/drivers/scsi/aic7xxx/aic79xx_osm.h#1
17
$
*
*/
#ifndef _AIC79XX_LINUX_H_
...
...
@@ -286,7 +286,7 @@ ahd_scb_timer_reset(struct scb *scb, u_int usec)
#include <linux/smp.h>
#endif
#define AIC79XX_DRIVER_VERSION "1.3.
0
"
#define AIC79XX_DRIVER_VERSION "1.3.
4
"
/**************************** Front End Queues ********************************/
/*
...
...
@@ -487,7 +487,7 @@ struct ahd_linux_target {
* Per-SCB OSM storage.
*/
typedef
enum
{
AHD_
UP_EH_SEMAPHORE
=
0x1
AHD_
SCB_UP_EH_SEM
=
0x1
}
ahd_linux_scb_flags
;
struct
scb_platform_data
{
...
...
@@ -947,7 +947,7 @@ void ahd_power_state_change(struct ahd_softc *ahd,
*/
#if LINUX_VERSION_CODE <= KERNEL_VERSION(2,1,92)
#if defined(__sparc_v9__) || defined(__powerpc__)
#error "PPC and Sparc platforms are only support under 2.1.92 and above"
#error "PPC and Sparc platforms are only support
ed
under 2.1.92 and above"
#endif
#include <linux/bios32.h>
#endif
...
...
drivers/scsi/aic7xxx/aic79xx_pci.c
View file @
14686d42
...
...
@@ -38,7 +38,7 @@
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGES.
*
* $Id: //depot/aic7xxx/aic7xxx/aic79xx_pci.c#6
1
$
* $Id: //depot/aic7xxx/aic7xxx/aic79xx_pci.c#6
7
$
*
* $FreeBSD$
*/
...
...
@@ -80,6 +80,7 @@ ahd_compose_id(u_int device, u_int vendor, u_int subdevice, u_int subvendor)
#define ID_AIC7902_B 0x801D9005FFFF9005ull
#define ID_AIC7902_B_IROC 0x809D9005FFFF9005ull
#define ID_AHA_39320 0x8010900500409005ull
#define ID_AHA_39320A 0x8016900500409005ull
#define ID_AHA_39320D 0x8011900500419005ull
#define ID_AHA_39320D_B 0x801C900500419005ull
#define ID_AHA_39320D_HP 0x8011900500AC0E11ull
...
...
@@ -137,6 +138,12 @@ struct ahd_pci_identity ahd_pci_ident_table [] =
"Adaptec 39320 Ultra320 SCSI adapter"
,
ahd_aic7902_setup
},
{
ID_AHA_39320A
,
ID_ALL_MASK
,
"Adaptec 39320A Ultra320 SCSI adapter"
,
ahd_aic7902_setup
},
{
ID_AHA_39320D
,
ID_ALL_MASK
,
...
...
@@ -378,12 +385,10 @@ ahd_pci_config(struct ahd_softc *ahd, struct ahd_pci_identity *entry)
int
ahd_pci_test_register_access
(
struct
ahd_softc
*
ahd
)
{
ahd_mode_state
saved_modes
;
uint32_t
cmd
;
int
error
;
uint8_t
hcntrl
;
saved_modes
=
ahd_save_modes
(
ahd
);
error
=
EIO
;
/*
...
...
@@ -449,7 +454,6 @@ ahd_pci_test_register_access(struct ahd_softc *ahd)
ahd_outb
(
ahd
,
CLRINT
,
CLRPCIINT
);
}
ahd_restore_modes
(
ahd
,
saved_modes
);
ahd_outb
(
ahd
,
SEQCTL0
,
PERRORDIS
|
FAILDIS
);
ahd_pci_write_config
(
ahd
->
dev_softc
,
PCIR_COMMAND
,
cmd
,
/*bytes*/
2
);
return
(
error
);
...
...
@@ -698,7 +702,7 @@ static const char *split_status_strings[] =
"%s: Split completion data bucket in %s
\n
"
,
"%s: Split completion address error in %s
\n
"
,
"%s: Split completion byte count error in %s
\n
"
,
"%s: Signaled Target-abort to early terminate a split in %s
\n
"
,
"%s: Signaled Target-abort to early terminate a split in %s
\n
"
};
static
const
char
*
pci_status_strings
[]
=
...
...
@@ -879,11 +883,11 @@ ahd_aic7902_setup(struct ahd_softc *ahd)
|
AHD_NLQICRC_DELAYED_BUG
|
AHD_SCSIRST_BUG
|
AHD_LQO_ATNO_BUG
|
AHD_AUTOFLUSH_BUG
|
AHD_CLRLQO_AUTOCLR_BUG
|
AHD_PCIX_MMAPIO_BUG
|
AHD_PCIX_CHIPRST_BUG
|
AHD_P
KTIZED_STATUS
_BUG
|
AHD_PKT
_LUN_BUG
|
AHD_MDFF_WSCBPTR
_BUG
|
AHD_
REG_SLOW_SETTLE_BUG
|
AHD_SET_MOD
E_BUG
|
AHD_
BUSFREEREV_BUG
|
AHD_NONPACKFIFO
_BUG
|
AHD_PACED_NEGTABLE_BUG
;
|
AHD_PCIX_CHIPRST_BUG
|
AHD_P
CIX_SCBRAM_RD
_BUG
|
AHD_PKT
IZED_STATUS_BUG
|
AHD_PKT_LUN
_BUG
|
AHD_
MDFF_WSCBPTR_BUG
|
AHD_REG_SLOW_SETTL
E_BUG
|
AHD_
SET_MODE_BUG
|
AHD_BUSFREEREV
_BUG
|
AHD_
NONPACKFIFO_BUG
|
AHD_
PACED_NEGTABLE_BUG
;
/*
* IO Cell paramter setup.
...
...
@@ -898,7 +902,7 @@ ahd_aic7902_setup(struct ahd_softc *ahd)
ahd
->
features
|=
AHD_RTI
|
AHD_NEW_IOCELL_OPTS
|
AHD_NEW_DFCNTRL_OPTS
;
ahd
->
bugs
|=
AHD_LQOOVERRUN_BUG
|
AHD_ABORT_LQI_BUG
|
AHD_INTCOLLISION_BUG
;
|
AHD_INTCOLLISION_BUG
|
AHD_EARLY_REQ_BUG
;
/*
* IO Cell paramter setup.
...
...
drivers/scsi/aic7xxx/aic79xx_proc.c
View file @
14686d42
...
...
@@ -37,7 +37,7 @@
* String handling code courtesy of Gerard Roudier's <groudier@club-internet.fr>
* sym driver.
*
* $Id: //depot/aic7xxx/linux/drivers/scsi/aic7xxx/aic79xx_proc.c#1
1
$
* $Id: //depot/aic7xxx/linux/drivers/scsi/aic7xxx/aic79xx_proc.c#1
3
$
*/
#include "aic79xx_osm.h"
#include "aic79xx_inline.h"
...
...
@@ -124,8 +124,12 @@ ahd_format_transinfo(struct info_str *info, struct ahd_transinfo *tinfo)
printed_options
=
0
;
copy_info
(
info
,
" (%d.%03dMHz"
,
freq
/
1000
,
freq
%
1000
);
if
((
tinfo
->
ppr_options
&
MSG_EXT_PPR_RD_STRM
)
!=
0
)
{
copy_info
(
info
,
" RDSTRM"
);
printed_options
++
;
}
if
((
tinfo
->
ppr_options
&
MSG_EXT_PPR_DT_REQ
)
!=
0
)
{
copy_info
(
info
,
" DT"
);
copy_info
(
info
,
"
%s"
,
printed_options
?
"|DT"
:
"
DT"
);
printed_options
++
;
}
if
((
tinfo
->
ppr_options
&
MSG_EXT_PPR_IU_REQ
)
!=
0
)
{
...
...
@@ -311,6 +315,7 @@ ahd_linux_proc_info(char *buffer, char **start, off_t offset,
copy_info
(
&
info
,
"Adaptec AIC79xx driver version: %s
\n
"
,
AIC79XX_DRIVER_VERSION
);
copy_info
(
&
info
,
"%s
\n
"
,
ahd
->
description
);
ahd_controller_info
(
ahd
,
ahd_info
);
copy_info
(
&
info
,
"%s
\n\n
"
,
ahd_info
);
...
...
drivers/scsi/aic7xxx/aic79xx_reg.h_shipped
View file @
14686d42
...
...
@@ -2,8 +2,8 @@
* DO NOT EDIT - This file is automatically generated
* from the following source files:
*
* $Id: //depot/aic7xxx/aic7xxx/aic79xx.seq#
78
$
* $Id: //depot/aic7xxx/aic7xxx/aic79xx.reg#6
0
$
* $Id: //depot/aic7xxx/aic7xxx/aic79xx.seq#
87
$
* $Id: //depot/aic7xxx/aic7xxx/aic79xx.reg#6
2
$
*/
typedef int (ahd_reg_print_t)(u_int, u_int *, u_int);
typedef struct ahd_reg_parse_entry {
...
...
@@ -3638,13 +3638,14 @@ ahd_reg_print_t ahd_scb_disconnected_lists_print;
#define SCB_RESIDUAL_DATACNT 0x180
#define SCB_CDB_STORE 0x180
#define SCB_HOST_CDB_PTR 0x180
#define SCB_RESIDUAL_SGPTR 0x184
#define SCB_CDB_PTR 0x184
#define SG_ADDR_MASK 0xf8
#define SG_OVERRUN_RESID 0x02
#define SCB_SCSI_STATUS 0x188
#define SCB_HOST_CDB_LEN 0x188
#define SCB_TARGET_PHASES 0x189
...
...
@@ -3774,5 +3775,5 @@ ahd_reg_print_t ahd_scb_disconnected_lists_print;
/* Exported Labels */
#define LABEL_seq_isr 0x26
3
#define LABEL_timer_isr 0x2
5f
#define LABEL_seq_isr 0x26
8
#define LABEL_timer_isr 0x2
64
drivers/scsi/aic7xxx/aic79xx_reg_print.c_shipped
View file @
14686d42
...
...
@@ -2,8 +2,8 @@
* DO NOT EDIT - This file is automatically generated
* from the following source files:
*
* $Id: //depot/aic7xxx/aic7xxx/aic79xx.seq#
78
$
* $Id: //depot/aic7xxx/aic7xxx/aic79xx.reg#6
0
$
* $Id: //depot/aic7xxx/aic7xxx/aic79xx.seq#
87
$
* $Id: //depot/aic7xxx/aic7xxx/aic79xx.reg#6
2
$
*/
#include "aic79xx_osm.h"
...
...
drivers/scsi/aic7xxx/aic79xx_seq.h_shipped
View file @
14686d42
...
...
@@ -2,8 +2,8 @@
* DO NOT EDIT - This file is automatically generated
* from the following source files:
*
* $Id: //depot/aic7xxx/aic7xxx/aic79xx.seq#
78
$
* $Id: //depot/aic7xxx/aic7xxx/aic79xx.reg#6
0
$
* $Id: //depot/aic7xxx/aic7xxx/aic79xx.seq#
87
$
* $Id: //depot/aic7xxx/aic7xxx/aic79xx.reg#6
2
$
*/
static uint8_t seqprog[] = {
0xff, 0x02, 0x06, 0x78,
...
...
@@ -23,16 +23,16 @@ static uint8_t seqprog[] = {
0x20, 0x4b, 0x78, 0x69,
0xfc, 0x42, 0x24, 0x78,
0x10, 0x40, 0x24, 0x78,
0x00, 0xe2, 0x
a4
, 0x5d,
0x00, 0xe2, 0x
d6
, 0x5d,
0x20, 0x4d, 0x28, 0x78,
0x00, 0xe2, 0x
a4
, 0x5d,
0x00, 0xe2, 0x
d6
, 0x5d,
0x00, 0xe2, 0x34, 0x58,
0x00, 0xe2, 0x66, 0x58,
0x00, 0xe2, 0x76, 0x58,
0x00, 0xe2, 0x06, 0x40,
0x33, 0xea, 0x3a, 0x59,
0x33, 0xea, 0x00, 0x00,
0x01, 0x52, 0x
66
, 0x7d,
0x01, 0x52, 0x
8c
, 0x7d,
0x02, 0x58, 0x50, 0x31,
0xff, 0xea, 0x10, 0x0b,
0xff, 0x93, 0x45, 0x78,
...
...
@@ -42,18 +42,18 @@ static uint8_t seqprog[] = {
0x14, 0xea, 0x04, 0x00,
0x08, 0xa8, 0x51, 0x03,
0x01, 0xa4, 0x4d, 0x78,
0x00, 0xe2, 0x4
4
, 0x5b,
0x00, 0xe2, 0x4
2
, 0x5b,
0x00, 0xe2, 0x34, 0x40,
0xff, 0xea, 0xd4, 0x19,
0x02, 0xa8, 0x84, 0x32,
0x00, 0xea, 0x3a, 0x59,
0x01, 0xea, 0x00, 0x30,
0x00, 0xe2, 0x
98
, 0x5d,
0x00, 0xe2, 0x
66
, 0x4d,
0x00, 0xe2, 0x
c2
, 0x5d,
0x00, 0xe2, 0x
8c
, 0x4d,
0x11, 0xea, 0x3a, 0x59,
0x11, 0xea, 0x00, 0x00,
0x00, 0xe2, 0x
98
, 0x5d,
0x00, 0xe2, 0x
66
, 0x4d,
0x00, 0xe2, 0x
c2
, 0x5d,
0x00, 0xe2, 0x
8c
, 0x4d,
0x33, 0xea, 0x3a, 0x59,
0x33, 0xea, 0x00, 0x00,
0x00, 0xe2, 0x3a, 0x43,
...
...
@@ -72,14 +72,14 @@ static uint8_t seqprog[] = {
0x10, 0x16, 0x2c, 0x00,
0x18, 0xad, 0xee, 0x78,
0x04, 0xad, 0xbc, 0x68,
0x80, 0xad, 0x
66
, 0x7d,
0x80, 0xad, 0x
8c
, 0x7d,
0x10, 0xad, 0x8a, 0x78,
0xe7, 0xad, 0x5a, 0x0d,
0xe7, 0xad, 0x5a, 0x09,
0x00, 0xe2, 0x98, 0x58,
0xff, 0xea, 0x56, 0x02,
0x04, 0x7c, 0x78, 0x32,
0x20, 0x16, 0x
66
, 0x7d,
0x20, 0x16, 0x
8c
, 0x7d,
0x04, 0x38, 0x79, 0x32,
0x80, 0x37, 0x6f, 0x16,
0xff, 0x2d, 0xa7, 0x60,
...
...
@@ -92,7 +92,7 @@ static uint8_t seqprog[] = {
0x01, 0x4c, 0xc1, 0x31,
0x00, 0x50, 0xd5, 0x19,
0x00, 0xe2, 0xb6, 0x48,
0x80, 0x18, 0x
66
, 0x7d,
0x80, 0x18, 0x
8c
, 0x7d,
0x02, 0x4a, 0x1d, 0x30,
0x10, 0xea, 0x18, 0x00,
0x60, 0x18, 0x30, 0x00,
...
...
@@ -100,7 +100,7 @@ static uint8_t seqprog[] = {
0x02, 0xea, 0x02, 0x00,
0xff, 0xea, 0xa0, 0x0a,
0x80, 0x18, 0x30, 0x04,
0x40, 0xad, 0x
66
, 0x7d,
0x40, 0xad, 0x
8c
, 0x7d,
0xe7, 0xad, 0x5a, 0x09,
0x02, 0xa8, 0x40, 0x31,
0xff, 0xea, 0xc0, 0x09,
...
...
@@ -128,7 +128,7 @@ static uint8_t seqprog[] = {
0x04, 0x47, 0xf3, 0x68,
0x40, 0x16, 0x1e, 0x69,
0xff, 0x2d, 0x23, 0x61,
0xff, 0x29, 0x
67
, 0x75,
0xff, 0x29, 0x
8d
, 0x75,
0x01, 0x37, 0xc1, 0x31,
0x02, 0x28, 0x55, 0x32,
0x01, 0xea, 0x5a, 0x01,
...
...
@@ -236,8 +236,8 @@ static uint8_t seqprog[] = {
0xff, 0xea, 0x46, 0x02,
0x02, 0x5c, 0x50, 0x31,
0x40, 0xea, 0x96, 0x00,
0x02, 0x56, 0x
ac
, 0x6d,
0x01, 0x55, 0x
ac
, 0x6d,
0x02, 0x56, 0x
de
, 0x6d,
0x01, 0x55, 0x
de
, 0x6d,
0x10, 0xa8, 0xd5, 0x79,
0x10, 0x40, 0xde, 0x69,
0x01, 0x56, 0xde, 0x79,
...
...
@@ -253,9 +253,9 @@ static uint8_t seqprog[] = {
0x40, 0xea, 0x66, 0x02,
0x08, 0x3c, 0x78, 0x00,
0x80, 0xea, 0x62, 0x02,
0x00, 0xe2, 0xa
4
, 0x5b,
0x00, 0xe2, 0xa
2
, 0x5b,
0x01, 0x36, 0xc1, 0x31,
0x9f, 0xe0, 0x
38
, 0x7c,
0x9f, 0xe0, 0x
44
, 0x7c,
0x80, 0xe0, 0x02, 0x72,
0xa0, 0xe0, 0x3a, 0x72,
0xc0, 0xe0, 0x30, 0x72,
...
...
@@ -274,7 +274,7 @@ static uint8_t seqprog[] = {
0x00, 0xe2, 0x60, 0x59,
0xef, 0x92, 0xd5, 0x19,
0x00, 0xe2, 0x20, 0x52,
0x0
b, 0x84
, 0xe1, 0x30,
0x0
9, 0x80
, 0xe1, 0x30,
0x02, 0xea, 0x36, 0x00,
0xa8, 0xea, 0x32, 0x00,
0x00, 0xe2, 0x26, 0x42,
...
...
@@ -299,31 +299,31 @@ static uint8_t seqprog[] = {
0xbf, 0xe2, 0xc4, 0x09,
0x20, 0xa8, 0x5b, 0x7a,
0x01, 0xe2, 0x88, 0x30,
0x00, 0xe2, 0xa
4
, 0x5b,
0x00, 0xe2, 0xa
2
, 0x5b,
0xa0, 0x36, 0x63, 0x62,
0x23, 0xa8, 0x89, 0x08,
0x00, 0xe2, 0xa
4
, 0x5b,
0x00, 0xe2, 0xa
2
, 0x5b,
0xa0, 0x36, 0x63, 0x62,
0x00, 0xa8, 0x5a, 0x42,
0xff, 0xe2, 0x5a, 0x62,
0x00, 0xe2, 0x7a, 0x42,
0x40, 0xea, 0x98, 0x00,
0x01, 0xe2, 0x88, 0x30,
0x00, 0xe2, 0xa
4
, 0x5b,
0x00, 0xe2, 0xa
2
, 0x5b,
0xa0, 0x36, 0x39, 0x72,
0x40, 0xea, 0x98, 0x00,
0x01, 0x31, 0x89, 0x32,
0x08, 0xea, 0x62, 0x02,
0x00, 0xe2, 0xee, 0x41,
0xe0, 0xea, 0xb
4
, 0x5b,
0xe0, 0xea, 0xb
e
, 0x5b,
0x80, 0xe0, 0xb2, 0x6a,
0x04, 0xe0, 0x5
2
, 0x73,
0x02, 0xe0, 0x8
2
, 0x73,
0x04, 0xe0, 0x5
0
, 0x73,
0x02, 0xe0, 0x8
0
, 0x73,
0x00, 0xea, 0x10, 0x73,
0x03, 0xe0, 0x9
2
, 0x73,
0x03, 0xe0, 0x9
0
, 0x73,
0x23, 0xe0, 0x8c, 0x72,
0x08, 0xe0, 0xae, 0x72,
0x00, 0xe2, 0xa
4
, 0x5b,
0x00, 0xe2, 0xa
2
, 0x5b,
0x07, 0xea, 0x46, 0x59,
0x07, 0xea, 0x04, 0x00,
0x08, 0x42, 0xef, 0x71,
...
...
@@ -340,7 +340,7 @@ static uint8_t seqprog[] = {
0x00, 0x30, 0x3b, 0x59,
0x01, 0x30, 0x01, 0x30,
0x01, 0xe0, 0xac, 0x7a,
0xa0, 0xea, 0x
aa
, 0x5b,
0xa0, 0xea, 0x
b4
, 0x5b,
0x01, 0xa0, 0xac, 0x62,
0x01, 0x84, 0xa5, 0x7a,
0x01, 0xa7, 0xae, 0x7a,
...
...
@@ -348,7 +348,7 @@ static uint8_t seqprog[] = {
0x03, 0xea, 0x46, 0x59,
0x03, 0xea, 0x04, 0x00,
0x00, 0xe2, 0xae, 0x42,
0x07, 0xea, 0x
bc
, 0x5b,
0x07, 0xea, 0x
c6
, 0x5b,
0x01, 0x44, 0xd4, 0x31,
0x00, 0xe2, 0xee, 0x41,
0x3f, 0xe0, 0x6a, 0x0a,
...
...
@@ -367,13 +367,13 @@ static uint8_t seqprog[] = {
0x00, 0xe2, 0xf0, 0x42,
0x80, 0x33, 0x67, 0x02,
0x01, 0x44, 0xd4, 0x31,
0x00, 0xe2, 0xa
4
, 0x5b,
0x00, 0xe2, 0xa
2
, 0x5b,
0x01, 0x33, 0x67, 0x02,
0xe0, 0x36, 0x0b, 0x63,
0x02, 0x33, 0x67, 0x02,
0x20, 0x46, 0x04, 0x63,
0xff, 0xea, 0x52, 0x09,
0xa8, 0xea, 0x
aa
, 0x5b,
0xa8, 0xea, 0x
b4
, 0x5b,
0x04, 0xa8, 0xeb, 0x7a,
0x01, 0x34, 0xc1, 0x31,
0x00, 0xa9, 0xeb, 0x62,
...
...
@@ -390,7 +390,7 @@ static uint8_t seqprog[] = {
0x02, 0xa8, 0x90, 0x32,
0x00, 0xe2, 0x60, 0x59,
0x10, 0xa8, 0xaf, 0x7a,
0xff, 0xea, 0x
bc
, 0x5b,
0xff, 0xea, 0x
c6
, 0x5b,
0x00, 0xe2, 0xae, 0x42,
0x04, 0xea, 0x46, 0x59,
0x04, 0xea, 0x04, 0x00,
...
...
@@ -407,7 +407,7 @@ static uint8_t seqprog[] = {
0x0a, 0xea, 0x46, 0x59,
0x0a, 0xea, 0x04, 0x00,
0x00, 0xe2, 0x3a, 0x5b,
0x00, 0xe2, 0x6
e
, 0x43,
0x00, 0xe2, 0x6
c
, 0x43,
0x50, 0x4b, 0x28, 0x6b,
0xbf, 0x3a, 0x74, 0x08,
0x01, 0xe0, 0xf8, 0x31,
...
...
@@ -419,21 +419,20 @@ static uint8_t seqprog[] = {
0x33, 0xea, 0x3a, 0x59,
0x33, 0xea, 0x00, 0x00,
0x02, 0x42, 0x51, 0x31,
0x10, 0xa8, 0x51, 0x03,
0xff, 0x88, 0x49, 0x6b,
0x01, 0xa4, 0x45, 0x6b,
0x02, 0xa4, 0x4d, 0x6b,
0x01, 0x84, 0x4d, 0x7b,
0xff, 0x88, 0x47, 0x6b,
0x01, 0xa4, 0x43, 0x6b,
0x02, 0xa4, 0x4b, 0x6b,
0x01, 0x84, 0x4b, 0x7b,
0x02, 0x28, 0x19, 0x33,
0x02, 0xa8, 0x50, 0x36,
0xff, 0x88, 0x4
d
, 0x73,
0xff, 0x88, 0x4
b
, 0x73,
0x00, 0xe2, 0x24, 0x5b,
0x02, 0x2c, 0x19, 0x33,
0x02, 0xa8, 0x58, 0x32,
0x04, 0xa4, 0x49, 0x07,
0xc0, 0x33, 0xa7, 0x6a,
0x04, 0xa8, 0x51, 0x03,
0x20, 0xa8, 0x6
f
, 0x6b,
0x20, 0xa8, 0x6
d
, 0x6b,
0x02, 0xa8, 0x40, 0x31,
0xc0, 0x34, 0xc1, 0x09,
0x00, 0x35, 0x51, 0x01,
...
...
@@ -448,23 +447,23 @@ static uint8_t seqprog[] = {
0xf7, 0x57, 0xae, 0x08,
0x08, 0xea, 0x98, 0x00,
0x01, 0x44, 0xd4, 0x31,
0xee, 0x00, 0x7
8
, 0x6b,
0xee, 0x00, 0x7
6
, 0x6b,
0x02, 0xea, 0xb4, 0x00,
0x00, 0xe2, 0x
a0
, 0x5b,
0x09, 0x4c, 0x7
a
, 0x7b,
0x00, 0xe2, 0x
9e
, 0x5b,
0x09, 0x4c, 0x7
8
, 0x7b,
0x08, 0x4c, 0x06, 0x68,
0x0b, 0xea, 0x46, 0x59,
0x0b, 0xea, 0x04, 0x00,
0x01, 0x44, 0xd4, 0x31,
0x20, 0x33, 0xef, 0x79,
0x00, 0xe2, 0x8
a
, 0x5b,
0x00, 0xe2, 0x8
8
, 0x5b,
0x00, 0xe2, 0xee, 0x41,
0x01, 0x84, 0x8
f
, 0x7b,
0x01, 0x84, 0x8
d
, 0x7b,
0x01, 0xa4, 0x49, 0x07,
0x08, 0x60, 0x30, 0x33,
0x08, 0x80, 0x41, 0x37,
0xdf, 0x33, 0x67, 0x0a,
0xee, 0x00, 0x9
c
, 0x6b,
0xee, 0x00, 0x9
a
, 0x6b,
0x05, 0xea, 0xb4, 0x00,
0x33, 0xea, 0x3a, 0x59,
0x33, 0xea, 0x00, 0x00,
...
...
@@ -472,12 +471,18 @@ static uint8_t seqprog[] = {
0x00, 0xe2, 0xae, 0x42,
0x01, 0xea, 0x6c, 0x02,
0xc0, 0xea, 0x66, 0x06,
0xff, 0x42, 0xa4, 0x7b,
0x04, 0x4c, 0xa4, 0x6b,
0xff, 0x42, 0xae, 0x6b,
0x01, 0x41, 0xa2, 0x6b,
0x02, 0x41, 0xa2, 0x7b,
0xff, 0x42, 0xae, 0x6b,
0x01, 0x41, 0xa2, 0x6b,
0x02, 0x41, 0xa2, 0x7b,
0xff, 0x42, 0xae, 0x7b,
0x04, 0x4c, 0xa2, 0x6b,
0xe0, 0x41, 0x6c, 0x0e,
0x01, 0x44, 0xd4, 0x31,
0xff, 0x42, 0x
ac
, 0x7b,
0x04, 0x4c, 0x
ac
, 0x6b,
0xff, 0x42, 0x
b6
, 0x7b,
0x04, 0x4c, 0x
b6
, 0x6b,
0xe0, 0x41, 0x6c, 0x0a,
0xe0, 0x36, 0xef, 0x61,
0xff, 0xea, 0xca, 0x09,
...
...
@@ -486,28 +491,29 @@ static uint8_t seqprog[] = {
0x01, 0x44, 0xd4, 0x35,
0x10, 0xea, 0x80, 0x00,
0x01, 0xe2, 0x62, 0x36,
0x04, 0xa6, 0xc
4
, 0x7b,
0x04, 0xa6, 0xc
e
, 0x7b,
0xff, 0xea, 0x5a, 0x09,
0xff, 0xea, 0x4c, 0x0d,
0x01, 0xa6, 0xe
2
, 0x6b,
0x10, 0xad, 0x
66
, 0x7d,
0x80, 0xad, 0x
da
, 0x6b,
0x08, 0xad, 0x
66
, 0x6d,
0x01, 0xa6, 0xe
c
, 0x6b,
0x10, 0xad, 0x
8c
, 0x7d,
0x80, 0xad, 0x
e4
, 0x6b,
0x08, 0xad, 0x
8c
, 0x6d,
0x04, 0x84, 0xf9, 0x30,
0x00, 0xea, 0x08, 0x81,
0xff, 0xea, 0xd4, 0x09,
0x02, 0x84, 0xf9, 0x88,
0x
1
d, 0xea, 0x5a, 0x01,
0x
0
d, 0xea, 0x5a, 0x01,
0x04, 0xa6, 0x4c, 0x05,
0x04, 0xa6, 0x
66
, 0x7d,
0x04, 0xa6, 0x
8c
, 0x7d,
0xff, 0xea, 0x5a, 0x09,
0x03, 0x84, 0x59, 0x89,
0x03, 0xea, 0x4c, 0x01,
0x80, 0x1a, 0x66, 0x7d,
0x80, 0x1a, 0x8c, 0x7d,
0x08, 0x19, 0x8c, 0x7d,
0x08, 0xb0, 0xe0, 0x30,
0x04, 0xb0, 0xe0, 0x30,
0x03, 0xb0, 0xf0, 0x30,
0x01, 0x78, 0x
ee
, 0x7b,
0x01, 0x78, 0x
fa
, 0x7b,
0x01, 0xa7, 0x4e, 0x11,
0x01, 0xb0, 0x06, 0x33,
0x7f, 0x83, 0xe9, 0x08,
...
...
@@ -518,98 +524,97 @@ static uint8_t seqprog[] = {
0x00, 0x86, 0x0d, 0x23,
0x00, 0x87, 0x0f, 0x23,
0x01, 0x84, 0xc5, 0x31,
0x01, 0xa7, 0x
04
, 0x7c,
0x01, 0xa7, 0x
10
, 0x7c,
0x04, 0xe2, 0xc4, 0x01,
0x80, 0x83, 0x
0b
, 0x7c,
0x80, 0x83, 0x
17
, 0x7c,
0x02, 0xe2, 0xc4, 0x01,
0xff, 0xea, 0x4c, 0x09,
0x01, 0xe2, 0x36, 0x30,
0xc8, 0x19, 0x32, 0x00,
0x88, 0x19, 0x32, 0x00,
0x01, 0xac, 0xd4, 0x99,
0x00, 0xe2, 0x
66
, 0x55,
0x00, 0xe2, 0x
8c
, 0x55,
0xfe, 0xa6, 0x4c, 0x0d,
0x0b, 0x98, 0xe1, 0x30,
0x01, 0xa0, 0x4f, 0x09,
0xfd, 0xa4, 0x49, 0x09,
0x80, 0xa3, 0x2
1
, 0x7c,
0x80, 0xa3, 0x2
d
, 0x7c,
0x02, 0xa4, 0x48, 0x01,
0x01, 0xa7, 0x
24
, 0x7c,
0x01, 0xa7, 0x
30
, 0x7c,
0x04, 0xa4, 0x48, 0x01,
0x01, 0xa4, 0x36, 0x30,
0xa8, 0xea, 0x32, 0x00,
0xfd, 0xa4, 0x49, 0x0b,
0x05, 0xa3, 0x07, 0x33,
0x80, 0x83, 0x3
1
, 0x6c,
0x80, 0x83, 0x3
d
, 0x6c,
0x02, 0xea, 0x4c, 0x05,
0xff, 0xea, 0x4c, 0x0d,
0x00, 0xe2, 0x32, 0x59,
0x02, 0xa6, 0x
c6
, 0x6b,
0x02, 0xa6, 0x
d0
, 0x6b,
0x80, 0xf9, 0xf2, 0x05,
0xc0, 0x33, 0x
3f
, 0x7c,
0xc0, 0x33, 0x
4b
, 0x7c,
0x03, 0xea, 0x46, 0x59,
0x03, 0xea, 0x04, 0x00,
0x20, 0x33, 0x6
3
, 0x7c,
0x01, 0x84, 0x
49
, 0x6c,
0x20, 0x33, 0x6
f
, 0x7c,
0x01, 0x84, 0x
55
, 0x6c,
0x06, 0xea, 0x46, 0x59,
0x06, 0xea, 0x04, 0x00,
0x00, 0xe2, 0x
66
, 0x44,
0x00, 0xe2, 0x
72
, 0x44,
0x01, 0x00, 0x60, 0x32,
0xee, 0x00, 0x5
2
, 0x6c,
0xee, 0x00, 0x5
e
, 0x6c,
0x05, 0xea, 0xb4, 0x00,
0x33, 0xea, 0x3a, 0x59,
0x33, 0xea, 0x00, 0x00,
0x80, 0x3d, 0x7a, 0x00,
0xfc, 0x42, 0x
54
, 0x7c,
0xfc, 0x42, 0x
60
, 0x7c,
0x7f, 0x3d, 0x7a, 0x08,
0x00, 0x30, 0x3b, 0x59,
0x01, 0x30, 0x01, 0x30,
0x09, 0xea, 0x46, 0x59,
0x09, 0xea, 0x04, 0x00,
0x00, 0xe2, 0xee, 0x41,
0x01, 0xa4, 0x
49
, 0x6c,
0x00, 0xe2, 0x
16
, 0x5c,
0x01, 0xa4, 0x
55
, 0x6c,
0x00, 0xe2, 0x
22
, 0x5c,
0x20, 0x33, 0x67, 0x02,
0x01, 0x00, 0x60, 0x32,
0x02, 0xa6, 0x
6e
, 0x7c,
0x00, 0xe2, 0x3
2
, 0x5c,
0x02, 0xa6, 0x
7a
, 0x7c,
0x00, 0xe2, 0x3
e
, 0x5c,
0x00, 0xe2, 0x66, 0x58,
0x00, 0xe2, 0x76, 0x58,
0x00, 0xe2, 0x30, 0x58,
0x00, 0x30, 0x3b, 0x59,
0x01, 0x30, 0x01, 0x30,
0x20, 0x19, 0x
6e
, 0x6c,
0x00, 0xe2, 0x
96
, 0x5c,
0x04, 0x19, 0x
88
, 0x6c,
0x20, 0x19, 0x
7a
, 0x6c,
0x00, 0xe2, 0x
aa
, 0x5c,
0x04, 0x19, 0x
94
, 0x6c,
0x02, 0x19, 0x32, 0x00,
0x01, 0x84, 0x
89
, 0x7c,
0x01, 0x1b, 0x8
2
, 0x7c,
0x01, 0x1a, 0x
88
, 0x6c,
0x00, 0xe2, 0x
38
, 0x44,
0x80, 0x4b, 0x
8e
, 0x6c,
0x01, 0x4c, 0x
8a
, 0x7c,
0x03, 0x42, 0x
38
, 0x6c,
0x00, 0xe2, 0xc
0
, 0x5b,
0x01, 0x84, 0x
95
, 0x7c,
0x01, 0x1b, 0x8
e
, 0x7c,
0x01, 0x1a, 0x
94
, 0x6c,
0x00, 0xe2, 0x
44
, 0x44,
0x80, 0x4b, 0x
9a
, 0x6c,
0x01, 0x4c, 0x
96
, 0x7c,
0x03, 0x42, 0x
44
, 0x6c,
0x00, 0xe2, 0xc
a
, 0x5b,
0x80, 0xf9, 0xf2, 0x01,
0x04, 0x33, 0xef, 0x79,
0x00, 0xe2, 0xee, 0x41,
0x02, 0x1b, 0x9e, 0x7c,
0x08, 0x5d, 0x9c, 0x7c,
0x03, 0x68, 0x00, 0x37,
0x01, 0x84, 0x09, 0x07,
0x08, 0x5d, 0xa8, 0x6c,
0x08, 0x5d, 0xb2, 0x6c,
0x00, 0xe2, 0x66, 0x58,
0x00, 0x30, 0x3b, 0x59,
0x01, 0x30, 0x01, 0x30,
0x00, 0xe2, 0x96, 0x44,
0x80, 0x1b, 0xb2, 0x7c,
0x80, 0x84, 0xb3, 0x6c,
0x02, 0x1b, 0xa2, 0x7c,
0x08, 0x5d, 0xb0, 0x7c,
0x03, 0x68, 0x00, 0x37,
0x01, 0x84, 0x09, 0x07,
0x80, 0x1b, 0xbc, 0x7c,
0x80, 0x84, 0xbd, 0x6c,
0xff, 0x85, 0x0b, 0x1b,
0xff, 0x86, 0x0d, 0x23,
0xff, 0x87, 0x0f, 0x23,
0xf8, 0x1b, 0x08, 0x0b,
0xff, 0xea, 0x4e, 0x09,
0x04, 0x1b, 0x
ba
, 0x7c,
0x04, 0x1b, 0x
c4
, 0x7c,
0x01, 0xa7, 0x4e, 0x01,
0xff, 0xea, 0x06, 0x0b,
0x03, 0x68, 0x00, 0x37,
...
...
@@ -617,74 +622,88 @@ static uint8_t seqprog[] = {
0x10, 0xea, 0x18, 0x00,
0xf9, 0xd9, 0xb2, 0x0d,
0x01, 0xd9, 0xb2, 0x05,
0xff, 0xea, 0xd4, 0x09,
0x10, 0x5b, 0xde, 0x6c,
0x08, 0x5b, 0xe6, 0x6c,
0x20, 0x5b, 0xd4, 0x6c,
0x02, 0x5b, 0xfa, 0x6d,
0x01, 0x52, 0x48, 0x31,
0x20, 0xa4, 0xe8, 0x7c,
0x20, 0x5b, 0xe8, 0x7c,
0x80, 0xf9, 0xf6, 0x7c,
0x11, 0x00, 0x00, 0x10,
0x04, 0x19, 0xe2, 0x7c,
0xdf, 0x19, 0x32, 0x08,
0x01, 0x4c, 0xde, 0x7c,
0x20, 0x19, 0x32, 0x00,
0x11, 0x00, 0x00, 0x10,
0x02, 0xea, 0xb4, 0x00,
0x01, 0xd9, 0xb2, 0x05,
0x10, 0x5b, 0xfa, 0x6c,
0x08, 0x5b, 0x02, 0x6d,
0x20, 0x5b, 0xf4, 0x6c,
0x02, 0x5b, 0x22, 0x6d,
0x0e, 0xea, 0x46, 0x59,
0x0e, 0xea, 0x04, 0x00,
0x
08, 0x19, 0xda, 0x7
c,
0x
80, 0xf9, 0xe4, 0x6
c,
0xdf, 0x5c, 0xb8, 0x08,
0x01, 0xd9, 0xb2, 0x05,
0x02, 0xea, 0xb4, 0x00,
0x01, 0xd9, 0xb2, 0x05,
0x01, 0xa4, 0xc3, 0x6d,
0x00, 0xe2, 0x16, 0x5c,
0x00, 0xe2, 0x06, 0x5d,
0x01, 0xa4, 0xf5, 0x6d,
0x00, 0xe2, 0x22, 0x5c,
0x00, 0xe2, 0x2c, 0x5d,
0x01, 0xd9, 0xb2, 0x05,
0x00, 0xe2, 0x24, 0x5b,
0xf3, 0x92, 0xd5, 0x19,
0x00, 0xe2, 0x
f4, 0x54
,
0x80, 0x92, 0x
f5, 0x6c
,
0x00, 0xe2, 0x
10, 0x55
,
0x80, 0x92, 0x
11, 0x6d
,
0x0f, 0xea, 0x46, 0x59,
0x0f, 0xea, 0x04, 0x00,
0x00, 0xe2, 0x
fc, 0x44
,
0x00, 0xe2, 0x
18, 0x45
,
0x04, 0x8c, 0xe1, 0x30,
0x01, 0xea, 0xf2, 0x00,
0x02, 0xea, 0x36, 0x00,
0xa8, 0xea, 0x32, 0x00,
0xff, 0x93, 0x
03
, 0x7d,
0xff, 0x93, 0x
1f
, 0x7d,
0x14, 0xea, 0x46, 0x59,
0x14, 0xea, 0x04, 0x00,
0x00, 0xe2, 0x88, 0x5d,
0x00, 0xe2, 0xa6, 0x5d,
0x01, 0xd9, 0xb2, 0x05,
0x09, 0x80, 0xe1, 0x30,
0x02, 0xea, 0x36, 0x00,
0xa8, 0xea, 0x32, 0x00,
0x00, 0xe2, 0xce, 0x5d,
0x01, 0xd9, 0xb2, 0x05,
0x02, 0xa8, 0xf4, 0x31,
0x02, 0xa6, 0x
18
, 0x7d,
0x02, 0xa6, 0x
3e
, 0x7d,
0x00, 0xe2, 0x34, 0x59,
0x20, 0x5b, 0x
26
, 0x6d,
0xfc, 0x42, 0x
12
, 0x7d,
0x10, 0x40, 0x
14
, 0x6d,
0x20, 0x4d, 0x
16
, 0x7d,
0x08, 0x5d, 0x
26
, 0x6d,
0x02, 0xa6, 0x
c6
, 0x6b,
0x20, 0x5b, 0x
4c
, 0x6d,
0xfc, 0x42, 0x
38
, 0x7d,
0x10, 0x40, 0x
3a
, 0x6d,
0x20, 0x4d, 0x
3c
, 0x7d,
0x08, 0x5d, 0x
4c
, 0x6d,
0x02, 0xa6, 0x
d0
, 0x6b,
0x00, 0xe2, 0x34, 0x59,
0x20, 0x5b, 0x
26
, 0x6d,
0x01, 0x1b, 0x
46
, 0x6d,
0xfc, 0x42, 0x
22
, 0x7d,
0x10, 0x40, 0x
24
, 0x6d,
0x20, 0x4d, 0x
66
, 0x7d,
0x08, 0x5d, 0x
66
, 0x7d,
0x20, 0x5b, 0x
4c
, 0x6d,
0x01, 0x1b, 0x
6c
, 0x6d,
0xfc, 0x42, 0x
48
, 0x7d,
0x10, 0x40, 0x
4a
, 0x6d,
0x20, 0x4d, 0x
8c
, 0x7d,
0x08, 0x5d, 0x
8c
, 0x7d,
0x02, 0x19, 0x32, 0x00,
0x01, 0x5b, 0x40, 0x31,
0x00, 0xe2, 0x
96
, 0x5c,
0x00, 0xe2, 0x8
a
, 0x5b,
0x00, 0xe2, 0x
aa
, 0x5c,
0x00, 0xe2, 0x8
8
, 0x5b,
0x20, 0xea, 0xb6, 0x00,
0x00, 0xe2, 0xc
0
, 0x5b,
0x00, 0xe2, 0xc
a
, 0x5b,
0x20, 0x5c, 0xb8, 0x00,
0x04, 0x19, 0x
3c
, 0x6d,
0x01, 0x1a, 0x
3c
, 0x6d,
0x04, 0x19, 0x
62
, 0x6d,
0x01, 0x1a, 0x
62
, 0x6d,
0x00, 0xe2, 0x34, 0x59,
0x01, 0x1a, 0x
66
, 0x7d,
0x01, 0x1a, 0x
8c
, 0x7d,
0x80, 0xf9, 0xf2, 0x01,
0x20, 0xa0, 0x
ac
, 0x7d,
0x08, 0xa8, 0x
45
, 0x7d,
0x00, 0xe2, 0x
58
, 0x45,
0x20, 0xa0, 0x
de
, 0x7d,
0x08, 0xa8, 0x
6b
, 0x7d,
0x00, 0xe2, 0x
7e
, 0x45,
0x02, 0xea, 0xb4, 0x04,
0x02, 0x19, 0x32, 0x00,
0x08, 0xa8, 0x
69
, 0x7d,
0x04, 0x5d, 0x
c2
, 0x7d,
0x01, 0x1a, 0x
c2
, 0x7d,
0x08, 0xa8, 0x
8f
, 0x7d,
0x04, 0x5d, 0x
f4
, 0x7d,
0x01, 0x1a, 0x
f4
, 0x7d,
0x01, 0xa4, 0x49, 0x03,
0x80, 0xf9, 0xf2, 0x01,
0x02, 0xa8, 0x84, 0x32,
...
...
@@ -695,48 +714,54 @@ static uint8_t seqprog[] = {
0xff, 0xea, 0xd4, 0x19,
0x00, 0xe2, 0x40, 0x59,
0x11, 0x00, 0x00, 0x10,
0x00, 0xe2, 0x
98
, 0x5d,
0x00, 0xe2, 0x
c2
, 0x5d,
0x00, 0xe2, 0x34, 0x53,
0xff, 0xea, 0xd4, 0x0d,
0x00, 0xe2, 0x34, 0x59,
0x40, 0x5b, 0x
74
, 0x6d,
0x04, 0x5d, 0x
c2
, 0x7d,
0x01, 0x1a, 0x
c2
, 0x7d,
0x20, 0x4d, 0x
66
, 0x7d,
0x40, 0x5b, 0x
ac
, 0x7d,
0x04, 0x5d, 0x
c2
, 0x7d,
0x01, 0x1a, 0x
c2
, 0x7d,
0x40, 0x5b, 0x
9a
, 0x6d,
0x04, 0x5d, 0x
f4
, 0x7d,
0x01, 0x1a, 0x
f4
, 0x7d,
0x20, 0x4d, 0x
8c
, 0x7d,
0x40, 0x5b, 0x
de
, 0x7d,
0x04, 0x5d, 0x
f4
, 0x7d,
0x01, 0x1a, 0x
f4
, 0x7d,
0x80, 0xf9, 0xf2, 0x01,
0x01, 0xa4, 0x49, 0x03,
0x08, 0xa8, 0x
59
, 0x6d,
0x08, 0xa8, 0x
7f
, 0x6d,
0x02, 0xea, 0xb4, 0x04,
0xff, 0x6a, 0x8e, 0x7d,
0x10, 0xea, 0x46, 0x59,
0x10, 0xea, 0x04, 0x00,
0x00, 0xe2, 0x8e, 0x45,
0x00, 0xe2, 0x32, 0x59,
0x
10, 0x5d, 0x80, 0x6
d,
0x40, 0x5b, 0x
66
, 0x7d,
0x
01, 0x1b, 0xb6, 0x7
d,
0x40, 0x5b, 0x
8c
, 0x7d,
0x02, 0x19, 0x32, 0x00,
0x80, 0xf9, 0xf2, 0x01,
0xff, 0xea, 0x10, 0x03,
0x08, 0xa8, 0x51, 0x03,
0x00, 0xe2, 0x58, 0x45,
0x80, 0xf9, 0x66, 0x6d,
0x00, 0xe2, 0x7e, 0x45,
0xff, 0x6a, 0xbc, 0x6d,
0x40, 0x5b, 0x8c, 0x7d,
0xff, 0x6a, 0xac, 0x7d,
0x10, 0xea, 0x46, 0x59,
0x10, 0xea, 0x04, 0x00,
0x00, 0xe2, 0xac, 0x45,
0x80, 0xf9, 0x8c, 0x6d,
0x01, 0x43, 0xc1, 0x31,
0x00, 0xfb, 0x
66
, 0x65,
0x00, 0xfb, 0x
8c
, 0x65,
0x01, 0x42, 0xc1, 0x31,
0x00, 0xfa, 0x
66
, 0x65,
0x00, 0xfa, 0x
8c
, 0x65,
0x01, 0xe8, 0xd4, 0x1d,
0x00, 0xe2, 0x32, 0x59,
0x01, 0x1b, 0x8c, 0x7d,
0x80, 0xf9, 0xf2, 0x01,
0x02, 0xea, 0xb4, 0x04,
0x30, 0x3f, 0xc0, 0x09,
0x30, 0xe0, 0x
66
, 0x65,
0x40, 0x4b, 0x
66
, 0x6d,
0x30, 0xe0, 0x
8c
, 0x65,
0x40, 0x4b, 0x
8c
, 0x6d,
0xff, 0xea, 0x52, 0x01,
0xee, 0x00, 0x
b2
, 0x6d,
0xee, 0x00, 0x
e4
, 0x6d,
0x80, 0xf9, 0xf2, 0x01,
0x02, 0xea, 0xb4, 0x00,
0x20, 0xea, 0x9a, 0x00,
0xf3, 0x42, 0x
bc
, 0x6d,
0xf3, 0x42, 0x
ee
, 0x6d,
0x12, 0xea, 0x46, 0x59,
0x12, 0xea, 0x04, 0x00,
0x00, 0xe2, 0xee, 0x41,
...
...
@@ -747,18 +772,19 @@ static uint8_t seqprog[] = {
0x11, 0xea, 0x04, 0x00,
0x00, 0xe2, 0x24, 0x5b,
0x08, 0x5a, 0xb4, 0x00,
0x00, 0xe2, 0x
e4, 0x5d
,
0x00, 0xe2, 0x
18, 0x5e
,
0xa8, 0xea, 0x32, 0x00,
0x00, 0xe2, 0x34, 0x59,
0x80, 0x1a, 0x
d6, 0x7d
,
0x00, 0xe2, 0x
e4, 0x5d
,
0x80, 0x1a, 0x
08, 0x7e
,
0x00, 0xe2, 0x
18, 0x5e
,
0x80, 0x19, 0x32, 0x00,
0x40, 0x5b, 0x
dc, 0x6d
,
0x08, 0x5a, 0x
dc, 0x7d
,
0x20, 0x4d, 0x
66
, 0x7d,
0x40, 0x5b, 0x
0e, 0x6e
,
0x08, 0x5a, 0x
0e, 0x7e
,
0x20, 0x4d, 0x
8c
, 0x7d,
0x02, 0x84, 0x09, 0x03,
0x40, 0x5b, 0xac, 0x7d,
0x08, 0xa8, 0x51, 0x6d,
0x40, 0x5b, 0xde, 0x7d,
0x08, 0xa8, 0x77, 0x6d,
0x80, 0xf9, 0xf2, 0x01,
0x02, 0xea, 0xb4, 0x04,
0x01, 0x38, 0xe1, 0x30,
0x05, 0x39, 0xe3, 0x98,
...
...
@@ -774,12 +800,28 @@ static uint8_t seqprog[] = {
};
typedef int ahd_patch_func_t (struct ahd_softc *ahd);
static ahd_patch_func_t ahd_patch20_func;
static int
ahd_patch20_func(struct ahd_softc *ahd)
{
return ((ahd->bugs & AHD_PKT_BITBUCKET_BUG) != 0);
}
static ahd_patch_func_t ahd_patch19_func;
static int
ahd_patch19_func(struct ahd_softc *ahd)
{
return ((ahd->bugs & AHD_PKT_BITBUCKET_BUG) == 0);
}
static ahd_patch_func_t ahd_patch18_func;
static int
ahd_patch18_func(struct ahd_softc *ahd)
{
return ((ahd->
bugs & AHD_PKT_BITBUCKET_BUG) !
= 0);
return ((ahd->
features & AHD_RTI) =
= 0);
}
static ahd_patch_func_t ahd_patch17_func;
...
...
@@ -787,7 +829,7 @@ static ahd_patch_func_t ahd_patch17_func;
static int
ahd_patch17_func(struct ahd_softc *ahd)
{
return ((ahd->
bugs & AHD_PKT_BITBUCKET_BUG) =
= 0);
return ((ahd->
flags & AHD_INITIATORROLE) !
= 0);
}
static ahd_patch_func_t ahd_patch16_func;
...
...
@@ -795,7 +837,7 @@ static ahd_patch_func_t ahd_patch16_func;
static int
ahd_patch16_func(struct ahd_softc *ahd)
{
return ((ahd->flags & AHD_
INITIATOR
ROLE) != 0);
return ((ahd->flags & AHD_
TARGET
ROLE) != 0);
}
static ahd_patch_func_t ahd_patch15_func;
...
...
@@ -803,7 +845,7 @@ static ahd_patch_func_t ahd_patch15_func;
static int
ahd_patch15_func(struct ahd_softc *ahd)
{
return ((ahd->
flags & AHD_TARGETROLE
) != 0);
return ((ahd->
bugs & AHD_AUTOFLUSH_BUG
) != 0);
}
static ahd_patch_func_t ahd_patch14_func;
...
...
@@ -811,7 +853,7 @@ static ahd_patch_func_t ahd_patch14_func;
static int
ahd_patch14_func(struct ahd_softc *ahd)
{
return ((ahd->
bugs & AHD_AUTOFLUSH_BUG
) != 0);
return ((ahd->
features & AHD_NEW_DFCNTRL_OPTS
) != 0);
}
static ahd_patch_func_t ahd_patch13_func;
...
...
@@ -819,7 +861,7 @@ static ahd_patch_func_t ahd_patch13_func;
static int
ahd_patch13_func(struct ahd_softc *ahd)
{
return ((ahd->f
eatures & AHD_NEW_DFCNTRL_OPTS
) != 0);
return ((ahd->f
lags & AHD_39BIT_ADDRESSING
) != 0);
}
static ahd_patch_func_t ahd_patch12_func;
...
...
@@ -827,7 +869,7 @@ static ahd_patch_func_t ahd_patch12_func;
static int
ahd_patch12_func(struct ahd_softc *ahd)
{
return ((ahd->flags & AHD_
39
BIT_ADDRESSING) != 0);
return ((ahd->flags & AHD_
64
BIT_ADDRESSING) != 0);
}
static ahd_patch_func_t ahd_patch11_func;
...
...
@@ -835,7 +877,7 @@ static ahd_patch_func_t ahd_patch11_func;
static int
ahd_patch11_func(struct ahd_softc *ahd)
{
return ((ahd->f
lags & AHD_64BIT_ADDRESSING) !
= 0);
return ((ahd->f
eatures & AHD_NEW_DFCNTRL_OPTS) =
= 0);
}
static ahd_patch_func_t ahd_patch10_func;
...
...
@@ -851,7 +893,7 @@ static ahd_patch_func_t ahd_patch9_func;
static int
ahd_patch9_func(struct ahd_softc *ahd)
{
return ((ahd->bugs & AHD_
BUSFREEREV_BUG) =
= 0);
return ((ahd->bugs & AHD_
EARLY_REQ_BUG) !
= 0);
}
static ahd_patch_func_t ahd_patch8_func;
...
...
@@ -859,7 +901,7 @@ static ahd_patch_func_t ahd_patch8_func;
static int
ahd_patch8_func(struct ahd_softc *ahd)
{
return ((ahd->bugs & AHD_
ABORT_LQI
_BUG) == 0);
return ((ahd->bugs & AHD_
BUSFREEREV
_BUG) == 0);
}
static ahd_patch_func_t ahd_patch7_func;
...
...
@@ -1000,64 +1042,68 @@ static struct patch {
{ ahd_patch0_func, 399, 1, 1 },
{ ahd_patch2_func, 410, 1, 2 },
{ ahd_patch0_func, 411, 1, 1 },
{ ahd_patch8_func, 4
13
, 1, 1 },
{ ahd_patch
9_func, 440, 1, 1
},
{ ahd_patch
1_func, 447, 1, 2
},
{ ahd_patch
0_func, 448, 1, 1
},
{ ahd_patch
2_func, 460, 1, 2
},
{ ahd_patch
0_func, 461, 1, 1
},
{ ahd_patch
10_func, 489
, 1, 1 },
{ ahd_patch1
1_func, 498, 1, 2
},
{ ahd_patch
0_func, 499
, 1, 1 },
{ ahd_patch12_func, 504, 1,
1
},
{ ahd_patch
11
_func, 505, 1, 1 },
{ ahd_patch13_func, 51
8, 1, 2
},
{ ahd_patch
0_func, 519
, 1, 1 },
{ ahd_patch1
_func, 541
, 1, 2 },
{ ahd_patch0_func, 5
42
, 1, 1 },
{ ahd_patch1_func, 54
5
, 1, 2 },
{ ahd_patch0_func, 54
6
, 1, 1 },
{ ahd_patch
2
_func, 551, 1, 2 },
{ ahd_patch8_func, 4
39
, 1, 1 },
{ ahd_patch
1_func, 446, 1, 2
},
{ ahd_patch
0_func, 447, 1, 1
},
{ ahd_patch
2_func, 459, 1, 2
},
{ ahd_patch
0_func, 460, 1, 1
},
{ ahd_patch
9_func, 465, 6, 2
},
{ ahd_patch
0_func, 471
, 1, 1 },
{ ahd_patch1
0_func, 494, 1, 1
},
{ ahd_patch
11_func, 503
, 1, 1 },
{ ahd_patch12_func, 504, 1,
2
},
{ ahd_patch
0
_func, 505, 1, 1 },
{ ahd_patch13_func, 51
0, 1, 1
},
{ ahd_patch
12_func, 511
, 1, 1 },
{ ahd_patch1
4_func, 524
, 1, 2 },
{ ahd_patch0_func, 5
25
, 1, 1 },
{ ahd_patch1_func, 54
7
, 1, 2 },
{ ahd_patch0_func, 54
8
, 1, 1 },
{ ahd_patch
1
_func, 551, 1, 2 },
{ ahd_patch0_func, 552, 1, 1 },
{ ahd_patch2_func, 55
6
, 1, 2 },
{ ahd_patch0_func, 55
7
, 1, 1 },
{ ahd_patch
1_func, 558
, 1, 2 },
{ ahd_patch0_func, 5
59
, 1, 1 },
{ ahd_patch
2_func, 570
, 1, 2 },
{ ahd_patch0_func, 5
71
, 1, 1 },
{ ahd_patch
14_func, 575, 1, 1
},
{ ahd_patch
15_func, 580
, 1, 1 },
{ ahd_patch1
6_func, 581, 2
, 1 },
{ ahd_patch1
5_func, 585, 1, 2
},
{ ahd_patch
0_func, 586, 1
, 1 },
{ ahd_patch
2_func, 593
, 1, 2 },
{ ahd_patch0_func, 59
4
, 1, 1 },
{ ahd_patch2_func,
609
, 1, 2 },
{ ahd_patch0_func,
610
, 1, 1 },
{ ahd_patch
1_func, 616
, 1, 2 },
{ ahd_patch0_func, 61
7
, 1, 1 },
{ ahd_patch1
_func, 631, 1, 2
},
{ ahd_patch
0_func, 632, 1, 1
},
{ ahd_patch
1_func, 639, 1, 2
},
{ ahd_patch
0_func, 640
, 1, 1 },
{ ahd_patch1
4_func, 659, 1, 1
},
{ ahd_patch
14_func, 675
, 1, 1 },
{ ahd_patch
2_func, 687
, 1, 2 },
{ ahd_patch0_func, 6
88
, 1, 1 },
{ ahd_patch1
_func, 705, 1, 2
},
{ ahd_patch
0_func, 706
, 1, 1 },
{ ahd_patch
14_func, 711, 1, 1
},
{ ahd_patch
1_func, 731, 1, 2
},
{ ahd_patch
0_func, 732
, 1, 1 },
{ ahd_patch2_func, 55
7
, 1, 2 },
{ ahd_patch0_func, 55
8
, 1, 1 },
{ ahd_patch
2_func, 562
, 1, 2 },
{ ahd_patch0_func, 5
63
, 1, 1 },
{ ahd_patch
1_func, 564
, 1, 2 },
{ ahd_patch0_func, 5
65
, 1, 1 },
{ ahd_patch
2_func, 576, 1, 2
},
{ ahd_patch
0_func, 577
, 1, 1 },
{ ahd_patch1
5_func, 581, 1
, 1 },
{ ahd_patch1
6_func, 586, 1, 1
},
{ ahd_patch
17_func, 587, 2
, 1 },
{ ahd_patch
16_func, 591
, 1, 2 },
{ ahd_patch0_func, 59
2
, 1, 1 },
{ ahd_patch2_func,
595
, 1, 2 },
{ ahd_patch0_func,
596
, 1, 1 },
{ ahd_patch
2_func, 614
, 1, 2 },
{ ahd_patch0_func, 61
5
, 1, 1 },
{ ahd_patch1
8_func, 616, 12, 1
},
{ ahd_patch
1_func, 632, 1, 2
},
{ ahd_patch
0_func, 633, 1, 1
},
{ ahd_patch
18_func, 634
, 1, 1 },
{ ahd_patch1
_func, 645, 1, 2
},
{ ahd_patch
0_func, 646
, 1, 1 },
{ ahd_patch
1_func, 653
, 1, 2 },
{ ahd_patch0_func, 6
54
, 1, 1 },
{ ahd_patch1
5_func, 678, 1, 1
},
{ ahd_patch
15_func, 694
, 1, 1 },
{ ahd_patch
2_func, 706, 1, 2
},
{ ahd_patch
0_func, 707, 1, 1
},
{ ahd_patch
15_func, 726
, 1, 1 },
{ ahd_patch1_func, 734, 1, 2 },
{ ahd_patch0_func, 735, 1, 1 },
{ ahd_patch1_func, 737, 1, 2 },
{ ahd_patch0_func, 738, 1, 1 },
{ ahd_patch17_func, 740, 1, 2 },
{ ahd_patch0_func, 741, 2, 1 },
{ ahd_patch18_func, 744, 4, 2 },
{ ahd_patch0_func, 748, 1, 1 },
{ ahd_patch18_func, 754, 11, 1 }
{ ahd_patch1_func, 756, 1, 2 },
{ ahd_patch0_func, 757, 1, 1 },
{ ahd_patch1_func, 759, 1, 2 },
{ ahd_patch0_func, 760, 1, 1 },
{ ahd_patch1_func, 762, 1, 2 },
{ ahd_patch0_func, 763, 1, 1 },
{ ahd_patch19_func, 765, 1, 2 },
{ ahd_patch0_func, 766, 2, 1 },
{ ahd_patch20_func, 769, 4, 2 },
{ ahd_patch0_func, 773, 1, 1 },
{ ahd_patch20_func, 780, 11, 1 }
};
static struct cs {
...
...
@@ -1074,11 +1120,11 @@ static struct cs {
{ 153, 157 },
{ 165, 173 },
{ 196, 245 },
{ 6
59, 675
},
{ 6
75, 693
},
{
698, 704
},
{ 7
11, 716
},
{ 7
16, 722
}
{ 6
78, 694
},
{ 6
94, 712
},
{
717, 723
},
{ 7
26, 731
},
{ 7
37, 743
}
};
static const int num_critical_sections = sizeof(critical_sections)
...
...
drivers/scsi/aic7xxx/aic7xxx.h
View file @
14686d42
...
...
@@ -37,7 +37,7 @@
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGES.
*
* $Id: //depot/aic7xxx/aic7xxx/aic7xxx.h#7
0
$
* $Id: //depot/aic7xxx/aic7xxx/aic7xxx.h#7
3
$
*
* $FreeBSD$
*/
...
...
@@ -365,7 +365,8 @@ typedef enum {
AHC_LSCBS_ENABLED
=
0x2000000
,
/* 64Byte SCBs enabled */
AHC_SCB_CONFIG_USED
=
0x4000000
,
/* No SEEPROM but SCB2 had info. */
AHC_NO_BIOS_INIT
=
0x8000000
,
/* No BIOS left over settings. */
AHC_DISABLE_PCI_PERR
=
0x10000000
AHC_DISABLE_PCI_PERR
=
0x10000000
,
AHC_HAS_TERM_LOGIC
=
0x20000000
}
ahc_flag
;
/************************* Hardware SCB Definition ***************************/
...
...
@@ -691,7 +692,7 @@ struct ahc_tmode_lstate;
#define AHC_WIDTH_UNKNOWN 0xFF
#define AHC_PERIOD_UNKNOWN 0xFF
#define AHC_OFFSET_UNKNOWN 0x
0
#define AHC_OFFSET_UNKNOWN 0x
FF
#define AHC_PPR_OPTS_UNKNOWN 0xFF
/*
...
...
@@ -877,31 +878,39 @@ typedef enum {
/*********************** Software Configuration Structure *********************/
TAILQ_HEAD
(
scb_tailq
,
scb
);
struct
ahc_suspend_channel_state
{
uint8_t
scsiseq
;
uint8_t
sxfrctl0
;
uint8_t
sxfrctl1
;
uint8_t
simode0
;
uint8_t
simode1
;
uint8_t
seltimer
;
uint8_t
seqctl
;
struct
ahc_aic7770_softc
{
/*
* Saved register state used for chip_init().
*/
uint8_t
busspd
;
uint8_t
bustime
;
};
struct
ahc_pci_softc
{
/*
* Saved register state used for chip_init().
*/
uint32_t
devconfig
;
uint16_t
targcrccnt
;
uint8_t
command
;
uint8_t
csize_lattime
;
uint8_t
optionmode
;
uint8_t
crccontrol1
;
uint8_t
dscommand0
;
uint8_t
dspcistatus
;
uint8_t
scbbaddr
;
uint8_t
dff_thrsh
;
};
struct
ahc_suspend_state
{
struct
ahc_suspend_channel_state
channel
[
2
];
uint8_t
optionmode
;
uint8_t
dscommand0
;
uint8_t
dspcistatus
;
/* hsmailbox */
uint8_t
crccontrol1
;
uint8_t
scbbaddr
;
/* Host and sequencer SCB counts */
uint8_t
dff_thrsh
;
uint8_t
*
scratch_ram
;
uint8_t
*
btt
;
union
ahc_bus_softc
{
struct
ahc_aic7770_softc
aic7770_softc
;
struct
ahc_pci_softc
pci_softc
;
};
typedef
void
(
*
ahc_bus_intr_t
)(
struct
ahc_softc
*
);
typedef
int
(
*
ahc_bus_chip_init_t
)(
struct
ahc_softc
*
);
typedef
int
(
*
ahc_bus_suspend_t
)(
struct
ahc_softc
*
);
typedef
int
(
*
ahc_bus_resume_t
)(
struct
ahc_softc
*
);
typedef
void
ahc_callback_t
(
void
*
);
struct
ahc_softc
{
...
...
@@ -936,6 +945,11 @@ struct ahc_softc {
*/
struct
scb_tailq
untagged_queues
[
AHC_NUM_TARGETS
];
/*
* Bus attachment specific data.
*/
union
ahc_bus_softc
bus_softc
;
/*
* Platform specific data.
*/
...
...
@@ -951,6 +965,22 @@ struct ahc_softc {
*/
ahc_bus_intr_t
bus_intr
;
/*
* Bus specific initialization required
* after a chip reset.
*/
ahc_bus_chip_init_t
bus_chip_init
;
/*
* Bus specific suspend routine.
*/
ahc_bus_suspend_t
bus_suspend
;
/*
* Bus specific resume routine.
*/
ahc_bus_resume_t
bus_resume
;
/*
* Target mode related state kept on a per enabled lun basis.
* Targets that are not enabled will have null entries.
...
...
@@ -1043,9 +1073,6 @@ struct ahc_softc {
*/
bus_addr_t
dma_bug_buf
;
/* Information saved through suspend/resume cycles */
struct
ahc_suspend_state
suspend_state
;
/* Number of enabled target mode device on this card */
u_int
enabled_luns
;
...
...
@@ -1055,7 +1082,8 @@ struct ahc_softc {
/* PCI cacheline size. */
u_int
pci_cachesize
;
u_int
stack_size
;
/* Maximum number of sequencer instructions supported. */
u_int
instruction_ram_size
;
/* Per-Unit descriptive information */
const
char
*
description
;
...
...
@@ -1152,6 +1180,7 @@ int ahc_match_scb(struct ahc_softc *ahc, struct scb *scb,
struct
ahc_softc
*
ahc_alloc
(
void
*
platform_arg
,
char
*
name
);
int
ahc_softc_init
(
struct
ahc_softc
*
);
void
ahc_controller_info
(
struct
ahc_softc
*
ahc
,
char
*
buf
);
int
ahc_chip_init
(
struct
ahc_softc
*
ahc
);
int
ahc_init
(
struct
ahc_softc
*
ahc
);
void
ahc_intr_enable
(
struct
ahc_softc
*
ahc
,
int
enable
);
void
ahc_pause_and_flushwork
(
struct
ahc_softc
*
ahc
);
...
...
@@ -1167,7 +1196,6 @@ int ahc_reset(struct ahc_softc *ahc);
void
ahc_shutdown
(
void
*
arg
);
/*************************** Interrupt Services *******************************/
void
ahc_pci_intr
(
struct
ahc_softc
*
ahc
);
void
ahc_clear_intstat
(
struct
ahc_softc
*
ahc
);
void
ahc_run_qoutfifo
(
struct
ahc_softc
*
ahc
);
#ifdef AHC_TARGET_MODE
...
...
drivers/scsi/aic7xxx/aic7xxx.reg
View file @
14686d42
...
...
@@ -39,7 +39,7 @@
*
* $FreeBSD$
*/
VERSION = "$Id: //depot/aic7xxx/aic7xxx/aic7xxx.reg#3
7
$"
VERSION = "$Id: //depot/aic7xxx/aic7xxx/aic7xxx.reg#3
8
$"
/*
* This file is processed by the aic7xxx_asm utility for use in assembling
...
...
@@ -1580,7 +1580,7 @@ const BUS_32_BIT 0x02
const MAX_OFFSET_8BIT 0x0f
const MAX_OFFSET_16BIT 0x08
const MAX_OFFSET_ULTRA2 0x7f
const MAX_OFFSET 0x
f
f
const MAX_OFFSET 0x
7
f
const HOST_MSG 0xff
/* Target mode command processing constants */
...
...
drivers/scsi/aic7xxx/aic7xxx_core.c
View file @
14686d42
...
...
@@ -37,7 +37,7 @@
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGES.
*
* $Id: //depot/aic7xxx/aic7xxx/aic7xxx.c#1
12
$
* $Id: //depot/aic7xxx/aic7xxx/aic7xxx.c#1
21
$
*
* $FreeBSD$
*/
...
...
@@ -144,7 +144,8 @@ static struct ahc_syncrate ahc_syncrates[] =
#include "aic7xxx_seq.h"
/**************************** Function Declarations ***************************/
static
void
ahc_force_renegotiation
(
struct
ahc_softc
*
ahc
);
static
void
ahc_force_renegotiation
(
struct
ahc_softc
*
ahc
,
struct
ahc_devinfo
*
devinfo
);
static
struct
ahc_tmode_tstate
*
ahc_alloc_tstate
(
struct
ahc_softc
*
ahc
,
u_int
scsi_id
,
char
channel
);
...
...
@@ -224,7 +225,7 @@ static void ahc_reset_current_bus(struct ahc_softc *ahc);
#ifdef AHC_DUMP_SEQ
static
void
ahc_dumpseq
(
struct
ahc_softc
*
ahc
);
#endif
static
void
ahc_loadseq
(
struct
ahc_softc
*
ahc
);
static
int
ahc_loadseq
(
struct
ahc_softc
*
ahc
);
static
int
ahc_check_patch
(
struct
ahc_softc
*
ahc
,
struct
patch
**
start_patch
,
u_int
start_instr
,
u_int
*
skip_addr
);
...
...
@@ -1032,14 +1033,15 @@ ahc_handle_scsiint(struct ahc_softc *ahc, u_int intstat)
* we should look at the last phase the sequencer recorded,
* or the current phase presented on the bus.
*/
u_int
mesg_out
;
u_int
curphase
;
u_int
errorphase
;
u_int
lastphase
;
u_int
scsirate
;
u_int
i
;
u_int
sstat2
;
int
silent
;
struct
ahc_devinfo
devinfo
;
u_int
mesg_out
;
u_int
curphase
;
u_int
errorphase
;
u_int
lastphase
;
u_int
scsirate
;
u_int
i
;
u_int
sstat2
;
int
silent
;
lastphase
=
ahc_inb
(
ahc
,
LASTPHASE
);
curphase
=
ahc_inb
(
ahc
,
SCSISIGI
)
&
PHASE_MASK
;
...
...
@@ -1128,7 +1130,9 @@ ahc_handle_scsiint(struct ahc_softc *ahc, u_int intstat)
* case we are out of sync for some external reason
* unknown (or unreported) by the target.
*/
ahc_force_renegotiation
(
ahc
);
ahc_fetch_devinfo
(
ahc
,
&
devinfo
);
ahc_force_renegotiation
(
ahc
,
&
devinfo
);
ahc_outb
(
ahc
,
CLRINT
,
CLRSCSIINT
);
ahc_unpause
(
ahc
);
}
else
if
((
status
&
SELTO
)
!=
0
)
{
...
...
@@ -1165,6 +1169,7 @@ ahc_handle_scsiint(struct ahc_softc *ahc, u_int intstat)
ahc_name
(
ahc
),
scbptr
,
scb_index
);
ahc_dump_card_state
(
ahc
);
}
else
{
struct
ahc_devinfo
devinfo
;
#ifdef AHC_DEBUG
if
((
ahc_debug
&
AHC_SHOW_SELTO
)
!=
0
)
{
ahc_print_path
(
ahc
,
scb
);
...
...
@@ -1181,7 +1186,8 @@ ahc_handle_scsiint(struct ahc_softc *ahc, u_int intstat)
* a unit attention in this case, so we must always
* renegotiate.
*/
ahc_force_renegotiation
(
ahc
);
ahc_scb_devinfo
(
ahc
,
&
devinfo
,
scb
);
ahc_force_renegotiation
(
ahc
,
&
devinfo
);
ahc_set_transaction_status
(
scb
,
CAM_SEL_TIMEOUT
);
ahc_freeze_devq
(
ahc
,
scb
);
}
...
...
@@ -1189,13 +1195,14 @@ ahc_handle_scsiint(struct ahc_softc *ahc, u_int intstat)
ahc_restart
(
ahc
);
}
else
if
((
status
&
BUSFREE
)
!=
0
&&
(
ahc_inb
(
ahc
,
SIMODE1
)
&
ENBUSFREE
)
!=
0
)
{
u_int
lastphase
;
u_int
saved_scsiid
;
u_int
saved_lun
;
u_int
target
;
u_int
initiator_role_id
;
char
channel
;
int
printerror
;
struct
ahc_devinfo
devinfo
;
u_int
lastphase
;
u_int
saved_scsiid
;
u_int
saved_lun
;
u_int
target
;
u_int
initiator_role_id
;
char
channel
;
int
printerror
;
/*
* Clear our selection hardware as soon as possible.
...
...
@@ -1227,13 +1234,13 @@ ahc_handle_scsiint(struct ahc_softc *ahc, u_int intstat)
target
=
SCSIID_TARGET
(
ahc
,
saved_scsiid
);
initiator_role_id
=
SCSIID_OUR_ID
(
saved_scsiid
);
channel
=
SCSIID_CHANNEL
(
ahc
,
saved_scsiid
);
ahc_compile_devinfo
(
&
devinfo
,
initiator_role_id
,
target
,
saved_lun
,
channel
,
ROLE_INITIATOR
);
printerror
=
1
;
if
(
lastphase
==
P_MESGOUT
)
{
struct
ahc_devinfo
devinfo
;
u_int
tag
;
ahc_fetch_devinfo
(
ahc
,
&
devinfo
);
tag
=
SCB_LIST_NULL
;
if
(
ahc_sent_msg
(
ahc
,
AHCMSG_1B
,
MSG_ABORT_TAG
,
TRUE
)
||
ahc_sent_msg
(
ahc
,
AHCMSG_1B
,
MSG_ABORT
,
TRUE
))
{
...
...
@@ -1344,13 +1351,15 @@ ahc_handle_scsiint(struct ahc_softc *ahc, u_int intstat)
if
(
lastphase
==
ahc_phase_table
[
i
].
phase
)
break
;
}
/*
* Renegotiate with this device at the
* next oportunity just in case this busfree
* is due to a negotiation mismatch with the
* device.
*/
ahc_force_renegotiation
(
ahc
);
if
(
lastphase
!=
P_BUSFREE
)
{
/*
* Renegotiate with this device at the
* next oportunity just in case this busfree
* is due to a negotiation mismatch with the
* device.
*/
ahc_force_renegotiation
(
ahc
,
&
devinfo
);
}
printf
(
"Unexpected busfree %s
\n
"
"SEQADDR == 0x%x
\n
"
,
ahc_phase_table
[
i
].
phasemsg
,
...
...
@@ -1371,19 +1380,17 @@ ahc_handle_scsiint(struct ahc_softc *ahc, u_int intstat)
* a command to the current device.
*/
static
void
ahc_force_renegotiation
(
struct
ahc_softc
*
ahc
)
ahc_force_renegotiation
(
struct
ahc_softc
*
ahc
,
struct
ahc_devinfo
*
devinfo
)
{
struct
ahc_devinfo
devinfo
;
struct
ahc_initiator_tinfo
*
targ_info
;
struct
ahc_tmode_tstate
*
tstate
;
ahc_fetch_devinfo
(
ahc
,
&
devinfo
);
targ_info
=
ahc_fetch_transinfo
(
ahc
,
devinfo
.
channel
,
devinfo
.
our_scsiid
,
devinfo
.
target
,
devinfo
->
channel
,
devinfo
->
our_scsiid
,
devinfo
->
target
,
&
tstate
);
ahc_update_neg_request
(
ahc
,
&
devinfo
,
tstate
,
ahc_update_neg_request
(
ahc
,
devinfo
,
tstate
,
targ_info
,
AHC_NEG_IF_NON_ASYNC
);
}
...
...
@@ -4038,6 +4045,7 @@ ahc_reset(struct ahc_softc *ahc)
{
u_int
sblkctl
;
u_int
sxfrctl1_a
,
sxfrctl1_b
;
int
error
;
int
wait
;
/*
...
...
@@ -4128,12 +4136,19 @@ ahc_reset(struct ahc_softc *ahc)
}
ahc_outb
(
ahc
,
SXFRCTL1
,
sxfrctl1_a
);
error
=
0
;
if
(
ahc
->
init_level
>
0
)
/*
* If a recovery action has forced a chip reset,
* re-initialize the chip to our liking.
*/
error
=
ahc
->
bus_chip_init
(
ahc
);
#ifdef AHC_DUMP_SEQ
if
(
ahc
->
init_level
==
0
)
else
ahc_dumpseq
(
ahc
);
#endif
return
(
0
);
return
(
error
);
}
/*
...
...
@@ -4203,6 +4218,14 @@ ahc_build_free_scb_list(struct ahc_softc *ahc)
ahc_outb
(
ahc
,
SCB_LUN
,
0xFF
);
}
if
((
ahc
->
flags
&
AHC_PAGESCBS
)
!=
0
)
{
/* SCB 0 heads the free list. */
ahc_outb
(
ahc
,
FREE_SCBH
,
0
);
}
else
{
/* No free list. */
ahc_outb
(
ahc
,
FREE_SCBH
,
SCB_LIST_NULL
);
}
/* Make sure that the last SCB terminates the free list */
ahc_outb
(
ahc
,
SCBPTR
,
i
-
1
);
ahc_outb
(
ahc
,
SCB_NEXT
,
SCB_LIST_NULL
);
...
...
@@ -4228,20 +4251,11 @@ ahc_init_scbdata(struct ahc_softc *ahc)
/* Determine the number of hardware SCBs and initialize them */
scb_data
->
maxhscbs
=
ahc_probe_scbs
(
ahc
);
if
((
ahc
->
flags
&
AHC_PAGESCBS
)
!=
0
)
{
/* SCB 0 heads the free list */
ahc_outb
(
ahc
,
FREE_SCBH
,
0
);
}
else
{
ahc_outb
(
ahc
,
FREE_SCBH
,
SCB_LIST_NULL
);
}
if
(
ahc
->
scb_data
->
maxhscbs
==
0
)
{
printf
(
"%s: No SCB space found
\n
"
,
ahc_name
(
ahc
));
return
(
ENXIO
);
}
ahc_build_free_scb_list
(
ahc
);
/*
* Create our DMA tags. These tags define the kinds of device
* accessible memory allocations and memory mappings we will
...
...
@@ -4343,10 +4357,9 @@ ahc_init_scbdata(struct ahc_softc *ahc)
}
/*
*
Tell the sequencer which SCB will be the next one it receives
.
*
Reserve the next queued SCB
.
*/
ahc
->
next_queued_scb
=
ahc_get_scb
(
ahc
);
ahc_outb
(
ahc
,
NEXT_QUEUED_SCB
,
ahc
->
next_queued_scb
->
hscb
->
tag
);
/*
* Note that we were successfull
...
...
@@ -4531,6 +4544,192 @@ ahc_controller_info(struct ahc_softc *ahc, char *buf)
sprintf
(
buf
,
"%d SCBs"
,
ahc
->
scb_data
->
maxhscbs
);
}
int
ahc_chip_init
(
struct
ahc_softc
*
ahc
)
{
int
term
;
int
error
;
u_int
i
;
u_int
scsi_conf
;
u_int
scsiseq_template
;
uint32_t
physaddr
;
ahc_outb
(
ahc
,
SEQ_FLAGS
,
0
);
ahc_outb
(
ahc
,
SEQ_FLAGS2
,
0
);
/* Set the SCSI Id, SXFRCTL0, SXFRCTL1, and SIMODE1, for both channels*/
if
(
ahc
->
features
&
AHC_TWIN
)
{
/*
* Setup Channel B first.
*/
ahc_outb
(
ahc
,
SBLKCTL
,
ahc_inb
(
ahc
,
SBLKCTL
)
|
SELBUSB
);
term
=
(
ahc
->
flags
&
AHC_TERM_ENB_B
)
!=
0
?
STPWEN
:
0
;
ahc_outb
(
ahc
,
SCSIID
,
ahc
->
our_id_b
);
scsi_conf
=
ahc_inb
(
ahc
,
SCSICONF
+
1
);
ahc_outb
(
ahc
,
SXFRCTL1
,
(
scsi_conf
&
(
ENSPCHK
|
STIMESEL
))
|
term
|
ahc
->
seltime_b
|
ENSTIMER
|
ACTNEGEN
);
if
((
ahc
->
features
&
AHC_ULTRA2
)
!=
0
)
ahc_outb
(
ahc
,
SIMODE0
,
ahc_inb
(
ahc
,
SIMODE0
)
|
ENIOERR
);
ahc_outb
(
ahc
,
SIMODE1
,
ENSELTIMO
|
ENSCSIRST
|
ENSCSIPERR
);
ahc_outb
(
ahc
,
SXFRCTL0
,
DFON
|
SPIOEN
);
/* Select Channel A */
ahc_outb
(
ahc
,
SBLKCTL
,
ahc_inb
(
ahc
,
SBLKCTL
)
&
~
SELBUSB
);
}
term
=
(
ahc
->
flags
&
AHC_TERM_ENB_A
)
!=
0
?
STPWEN
:
0
;
if
((
ahc
->
features
&
AHC_ULTRA2
)
!=
0
)
ahc_outb
(
ahc
,
SCSIID_ULTRA2
,
ahc
->
our_id
);
else
ahc_outb
(
ahc
,
SCSIID
,
ahc
->
our_id
);
scsi_conf
=
ahc_inb
(
ahc
,
SCSICONF
);
ahc_outb
(
ahc
,
SXFRCTL1
,
(
scsi_conf
&
(
ENSPCHK
|
STIMESEL
))
|
term
|
ahc
->
seltime
|
ENSTIMER
|
ACTNEGEN
);
if
((
ahc
->
features
&
AHC_ULTRA2
)
!=
0
)
ahc_outb
(
ahc
,
SIMODE0
,
ahc_inb
(
ahc
,
SIMODE0
)
|
ENIOERR
);
ahc_outb
(
ahc
,
SIMODE1
,
ENSELTIMO
|
ENSCSIRST
|
ENSCSIPERR
);
ahc_outb
(
ahc
,
SXFRCTL0
,
DFON
|
SPIOEN
);
/* There are no untagged SCBs active yet. */
for
(
i
=
0
;
i
<
16
;
i
++
)
{
ahc_unbusy_tcl
(
ahc
,
BUILD_TCL
(
i
<<
4
,
0
));
if
((
ahc
->
flags
&
AHC_SCB_BTT
)
!=
0
)
{
int
lun
;
/*
* The SCB based BTT allows an entry per
* target and lun pair.
*/
for
(
lun
=
1
;
lun
<
AHC_NUM_LUNS
;
lun
++
)
ahc_unbusy_tcl
(
ahc
,
BUILD_TCL
(
i
<<
4
,
lun
));
}
}
/* All of our queues are empty */
for
(
i
=
0
;
i
<
256
;
i
++
)
ahc
->
qoutfifo
[
i
]
=
SCB_LIST_NULL
;
ahc_sync_qoutfifo
(
ahc
,
BUS_DMASYNC_PREREAD
);
for
(
i
=
0
;
i
<
256
;
i
++
)
ahc
->
qinfifo
[
i
]
=
SCB_LIST_NULL
;
if
((
ahc
->
features
&
AHC_MULTI_TID
)
!=
0
)
{
ahc_outb
(
ahc
,
TARGID
,
0
);
ahc_outb
(
ahc
,
TARGID
+
1
,
0
);
}
/*
* Tell the sequencer where it can find our arrays in memory.
*/
physaddr
=
ahc
->
scb_data
->
hscb_busaddr
;
ahc_outb
(
ahc
,
HSCB_ADDR
,
physaddr
&
0xFF
);
ahc_outb
(
ahc
,
HSCB_ADDR
+
1
,
(
physaddr
>>
8
)
&
0xFF
);
ahc_outb
(
ahc
,
HSCB_ADDR
+
2
,
(
physaddr
>>
16
)
&
0xFF
);
ahc_outb
(
ahc
,
HSCB_ADDR
+
3
,
(
physaddr
>>
24
)
&
0xFF
);
physaddr
=
ahc
->
shared_data_busaddr
;
ahc_outb
(
ahc
,
SHARED_DATA_ADDR
,
physaddr
&
0xFF
);
ahc_outb
(
ahc
,
SHARED_DATA_ADDR
+
1
,
(
physaddr
>>
8
)
&
0xFF
);
ahc_outb
(
ahc
,
SHARED_DATA_ADDR
+
2
,
(
physaddr
>>
16
)
&
0xFF
);
ahc_outb
(
ahc
,
SHARED_DATA_ADDR
+
3
,
(
physaddr
>>
24
)
&
0xFF
);
/*
* Initialize the group code to command length table.
* This overrides the values in TARG_SCSIRATE, so only
* setup the table after we have processed that information.
*/
ahc_outb
(
ahc
,
CMDSIZE_TABLE
,
5
);
ahc_outb
(
ahc
,
CMDSIZE_TABLE
+
1
,
9
);
ahc_outb
(
ahc
,
CMDSIZE_TABLE
+
2
,
9
);
ahc_outb
(
ahc
,
CMDSIZE_TABLE
+
3
,
0
);
ahc_outb
(
ahc
,
CMDSIZE_TABLE
+
4
,
15
);
ahc_outb
(
ahc
,
CMDSIZE_TABLE
+
5
,
11
);
ahc_outb
(
ahc
,
CMDSIZE_TABLE
+
6
,
0
);
ahc_outb
(
ahc
,
CMDSIZE_TABLE
+
7
,
0
);
if
((
ahc
->
features
&
AHC_HS_MAILBOX
)
!=
0
)
ahc_outb
(
ahc
,
HS_MAILBOX
,
0
);
/* Tell the sequencer of our initial queue positions */
if
((
ahc
->
features
&
AHC_TARGETMODE
)
!=
0
)
{
ahc
->
tqinfifonext
=
1
;
ahc_outb
(
ahc
,
KERNEL_TQINPOS
,
ahc
->
tqinfifonext
-
1
);
ahc_outb
(
ahc
,
TQINPOS
,
ahc
->
tqinfifonext
);
}
ahc
->
qinfifonext
=
0
;
ahc
->
qoutfifonext
=
0
;
if
((
ahc
->
features
&
AHC_QUEUE_REGS
)
!=
0
)
{
ahc_outb
(
ahc
,
QOFF_CTLSTA
,
SCB_QSIZE_256
);
ahc_outb
(
ahc
,
HNSCB_QOFF
,
ahc
->
qinfifonext
);
ahc_outb
(
ahc
,
SNSCB_QOFF
,
ahc
->
qinfifonext
);
ahc_outb
(
ahc
,
SDSCB_QOFF
,
0
);
}
else
{
ahc_outb
(
ahc
,
KERNEL_QINPOS
,
ahc
->
qinfifonext
);
ahc_outb
(
ahc
,
QINPOS
,
ahc
->
qinfifonext
);
ahc_outb
(
ahc
,
QOUTPOS
,
ahc
->
qoutfifonext
);
}
/* We don't have any waiting selections */
ahc_outb
(
ahc
,
WAITING_SCBH
,
SCB_LIST_NULL
);
/* Our disconnection list is empty too */
ahc_outb
(
ahc
,
DISCONNECTED_SCBH
,
SCB_LIST_NULL
);
/* Message out buffer starts empty */
ahc_outb
(
ahc
,
MSG_OUT
,
MSG_NOOP
);
/*
* Setup the allowed SCSI Sequences based on operational mode.
* If we are a target, we'll enalbe select in operations once
* we've had a lun enabled.
*/
scsiseq_template
=
ENSELO
|
ENAUTOATNO
|
ENAUTOATNP
;
if
((
ahc
->
flags
&
AHC_INITIATORROLE
)
!=
0
)
scsiseq_template
|=
ENRSELI
;
ahc_outb
(
ahc
,
SCSISEQ_TEMPLATE
,
scsiseq_template
);
/* Initialize our list of free SCBs. */
ahc_build_free_scb_list
(
ahc
);
/*
* Tell the sequencer which SCB will be the next one it receives.
*/
ahc_outb
(
ahc
,
NEXT_QUEUED_SCB
,
ahc
->
next_queued_scb
->
hscb
->
tag
);
/*
* Load the Sequencer program and Enable the adapter
* in "fast" mode.
*/
if
(
bootverbose
)
printf
(
"%s: Downloading Sequencer Program..."
,
ahc_name
(
ahc
));
error
=
ahc_loadseq
(
ahc
);
if
(
error
!=
0
)
return
(
error
);
if
((
ahc
->
features
&
AHC_ULTRA2
)
!=
0
)
{
int
wait
;
/*
* Wait for up to 500ms for our transceivers
* to settle. If the adapter does not have
* a cable attached, the transceivers may
* never settle, so don't complain if we
* fail here.
*/
ahc_pause
(
ahc
);
for
(
wait
=
5000
;
(
ahc_inb
(
ahc
,
SBLKCTL
)
&
(
ENAB40
|
ENAB20
))
==
0
&&
wait
;
wait
--
)
ahc_delay
(
100
);
ahc_unpause
(
ahc
);
}
return
(
0
);
}
/*
* Start the board, ready for normal operation
*/
...
...
@@ -4538,15 +4737,12 @@ int
ahc_init
(
struct
ahc_softc
*
ahc
)
{
int
max_targ
;
int
i
;
int
term
;
u_int
i
;
u_int
scsi_conf
;
u_int
scsiseq_template
;
u_int
ultraenb
;
u_int
discenable
;
u_int
tagenable
;
size_t
driver_data_size
;
uint32_t
physaddr
;
#ifdef AHC_DEBUG
if
((
ahc_debug
&
AHC_DEBUG_SEQUENCER
)
!=
0
)
...
...
@@ -4600,7 +4796,9 @@ ahc_init(struct ahc_softc *ahc)
/* DMA tag for mapping buffers into device visible space. */
if
(
ahc_dma_tag_create
(
ahc
,
ahc
->
parent_dmat
,
/*alignment*/
1
,
/*boundary*/
BUS_SPACE_MAXADDR_32BIT
+
1
,
/*lowaddr*/
BUS_SPACE_MAXADDR
,
/*lowaddr*/
ahc
->
flags
&
AHC_39BIT_ADDRESSING
?
(
bus_addr_t
)
0x7FFFFFFFFFULL
:
BUS_SPACE_MAXADDR_32BIT
,
/*highaddr*/
BUS_SPACE_MAXADDR
,
/*filter*/
NULL
,
/*filterarg*/
NULL
,
/*maxsize*/
(
AHC_NSEG
-
1
)
*
PAGE_SIZE
,
...
...
@@ -4664,9 +4862,6 @@ ahc_init(struct ahc_softc *ahc)
for
(
i
=
0
;
i
<
AHC_TMODE_CMDS
;
i
++
)
ahc
->
targetcmds
[
i
].
cmd_valid
=
0
;
ahc_sync_tqinfifo
(
ahc
,
BUS_DMASYNC_PREREAD
);
ahc
->
tqinfifonext
=
1
;
ahc_outb
(
ahc
,
KERNEL_TQINPOS
,
ahc
->
tqinfifonext
-
1
);
ahc_outb
(
ahc
,
TQINPOS
,
ahc
->
tqinfifonext
);
ahc
->
qoutfifo
=
(
uint8_t
*
)
&
ahc
->
targetcmds
[
256
];
}
ahc
->
qinfifo
=
&
ahc
->
qoutfifo
[
256
];
...
...
@@ -4697,9 +4892,6 @@ ahc_init(struct ahc_softc *ahc)
}
}
ahc_outb
(
ahc
,
SEQ_FLAGS
,
0
);
ahc_outb
(
ahc
,
SEQ_FLAGS2
,
0
);
if
(
ahc
->
scb_data
->
maxhscbs
<
AHC_SCB_MAX_ALLOC
)
{
ahc
->
flags
|=
AHC_PAGESCBS
;
}
else
{
...
...
@@ -4708,62 +4900,31 @@ ahc_init(struct ahc_softc *ahc)
#ifdef AHC_DEBUG
if
(
ahc_debug
&
AHC_SHOW_MISC
)
{
printf
(
"%s: hardware scb %
Zu bytes; kernel scb %Z
u bytes; "
"ahc_dma %
Z
u bytes
\n
"
,
printf
(
"%s: hardware scb %
u bytes; kernel scb %
u bytes; "
"ahc_dma %u bytes
\n
"
,
ahc_name
(
ahc
),
sizeof
(
struct
hardware_scb
),
sizeof
(
struct
scb
),
sizeof
(
struct
ahc_dma_seg
));
(
u_int
)
sizeof
(
struct
hardware_scb
),
(
u_int
)
sizeof
(
struct
scb
),
(
u_int
)
sizeof
(
struct
ahc_dma_seg
));
}
#endif
/* AHC_DEBUG */
/* Set the SCSI Id, SXFRCTL0, SXFRCTL1, and SIMODE1, for both channels*/
/*
* Look at the information that board initialization or
* the board bios has left us.
*/
if
(
ahc
->
features
&
AHC_TWIN
)
{
/*
* The device is gated to channel B after a chip reset,
* so set those values first
*/
ahc_outb
(
ahc
,
SBLKCTL
,
ahc_inb
(
ahc
,
SBLKCTL
)
|
SELBUSB
);
term
=
(
ahc
->
flags
&
AHC_TERM_ENB_B
)
!=
0
?
STPWEN
:
0
;
ahc_outb
(
ahc
,
SCSIID
,
ahc
->
our_id_b
);
scsi_conf
=
ahc_inb
(
ahc
,
SCSICONF
+
1
);
ahc_outb
(
ahc
,
SXFRCTL1
,
(
scsi_conf
&
(
ENSPCHK
|
STIMESEL
))
|
term
|
ahc
->
seltime_b
|
ENSTIMER
|
ACTNEGEN
);
if
((
ahc
->
features
&
AHC_ULTRA2
)
!=
0
)
ahc_outb
(
ahc
,
SIMODE0
,
ahc_inb
(
ahc
,
SIMODE0
)
|
ENIOERR
);
ahc_outb
(
ahc
,
SIMODE1
,
ENSELTIMO
|
ENSCSIRST
|
ENSCSIPERR
);
ahc_outb
(
ahc
,
SXFRCTL0
,
DFON
|
SPIOEN
);
if
((
scsi_conf
&
RESET_SCSI
)
!=
0
&&
(
ahc
->
flags
&
AHC_INITIATORROLE
)
!=
0
)
ahc
->
flags
|=
AHC_RESET_BUS_B
;
/* Select Channel A */
ahc_outb
(
ahc
,
SBLKCTL
,
ahc_inb
(
ahc
,
SBLKCTL
)
&
~
SELBUSB
);
}
term
=
(
ahc
->
flags
&
AHC_TERM_ENB_A
)
!=
0
?
STPWEN
:
0
;
if
((
ahc
->
features
&
AHC_ULTRA2
)
!=
0
)
ahc_outb
(
ahc
,
SCSIID_ULTRA2
,
ahc
->
our_id
);
else
ahc_outb
(
ahc
,
SCSIID
,
ahc
->
our_id
);
scsi_conf
=
ahc_inb
(
ahc
,
SCSICONF
);
ahc_outb
(
ahc
,
SXFRCTL1
,
(
scsi_conf
&
(
ENSPCHK
|
STIMESEL
))
|
term
|
ahc
->
seltime
|
ENSTIMER
|
ACTNEGEN
);
if
((
ahc
->
features
&
AHC_ULTRA2
)
!=
0
)
ahc_outb
(
ahc
,
SIMODE0
,
ahc_inb
(
ahc
,
SIMODE0
)
|
ENIOERR
);
ahc_outb
(
ahc
,
SIMODE1
,
ENSELTIMO
|
ENSCSIRST
|
ENSCSIPERR
);
ahc_outb
(
ahc
,
SXFRCTL0
,
DFON
|
SPIOEN
);
scsi_conf
=
ahc_inb
(
ahc
,
SCSICONF
);
if
((
scsi_conf
&
RESET_SCSI
)
!=
0
&&
(
ahc
->
flags
&
AHC_INITIATORROLE
)
!=
0
)
ahc
->
flags
|=
AHC_RESET_BUS_A
;
/*
* Look at the information that board initialization or
* the board bios has left us.
*/
ultraenb
=
0
;
tagenable
=
ALL_TARGETS_MASK
;
...
...
@@ -4815,7 +4976,7 @@ ahc_init(struct ahc_softc *ahc)
* connection type we have with the target.
*/
tinfo
->
user
.
period
=
ahc_syncrates
->
period
;
tinfo
->
user
.
offset
=
~
0
;
tinfo
->
user
.
offset
=
MAX_OFFSET
;
}
else
{
u_int
scsirate
;
uint16_t
mask
;
...
...
@@ -4850,7 +5011,7 @@ ahc_init(struct ahc_softc *ahc)
if
(
offset
==
0
)
tinfo
->
user
.
period
=
0
;
else
tinfo
->
user
.
offset
=
~
0
;
tinfo
->
user
.
offset
=
MAX_OFFSET
;
if
((
scsirate
&
SXFR_ULTRA2
)
<=
8
/*10MHz*/
&&
(
ahc
->
features
&
AHC_DT
)
!=
0
)
tinfo
->
user
.
ppr_options
=
...
...
@@ -4868,7 +5029,7 @@ ahc_init(struct ahc_softc *ahc)
?
AHC_SYNCRATE_ULTRA
:
AHC_SYNCRATE_FAST
);
if
(
tinfo
->
user
.
period
!=
0
)
tinfo
->
user
.
offset
=
~
0
;
tinfo
->
user
.
offset
=
MAX_OFFSET
;
}
if
(
tinfo
->
user
.
period
==
0
)
tinfo
->
user
.
offset
=
0
;
...
...
@@ -4890,127 +5051,7 @@ ahc_init(struct ahc_softc *ahc)
ahc
->
user_discenable
=
discenable
;
ahc
->
user_tagenable
=
tagenable
;
/* There are no untagged SCBs active yet. */
for
(
i
=
0
;
i
<
16
;
i
++
)
{
ahc_unbusy_tcl
(
ahc
,
BUILD_TCL
(
i
<<
4
,
0
));
if
((
ahc
->
flags
&
AHC_SCB_BTT
)
!=
0
)
{
int
lun
;
/*
* The SCB based BTT allows an entry per
* target and lun pair.
*/
for
(
lun
=
1
;
lun
<
AHC_NUM_LUNS
;
lun
++
)
ahc_unbusy_tcl
(
ahc
,
BUILD_TCL
(
i
<<
4
,
lun
));
}
}
/* All of our queues are empty */
for
(
i
=
0
;
i
<
256
;
i
++
)
ahc
->
qoutfifo
[
i
]
=
SCB_LIST_NULL
;
ahc_sync_qoutfifo
(
ahc
,
BUS_DMASYNC_PREREAD
);
for
(
i
=
0
;
i
<
256
;
i
++
)
ahc
->
qinfifo
[
i
]
=
SCB_LIST_NULL
;
if
((
ahc
->
features
&
AHC_MULTI_TID
)
!=
0
)
{
ahc_outb
(
ahc
,
TARGID
,
0
);
ahc_outb
(
ahc
,
TARGID
+
1
,
0
);
}
/*
* Tell the sequencer where it can find our arrays in memory.
*/
physaddr
=
ahc
->
scb_data
->
hscb_busaddr
;
ahc_outb
(
ahc
,
HSCB_ADDR
,
physaddr
&
0xFF
);
ahc_outb
(
ahc
,
HSCB_ADDR
+
1
,
(
physaddr
>>
8
)
&
0xFF
);
ahc_outb
(
ahc
,
HSCB_ADDR
+
2
,
(
physaddr
>>
16
)
&
0xFF
);
ahc_outb
(
ahc
,
HSCB_ADDR
+
3
,
(
physaddr
>>
24
)
&
0xFF
);
physaddr
=
ahc
->
shared_data_busaddr
;
ahc_outb
(
ahc
,
SHARED_DATA_ADDR
,
physaddr
&
0xFF
);
ahc_outb
(
ahc
,
SHARED_DATA_ADDR
+
1
,
(
physaddr
>>
8
)
&
0xFF
);
ahc_outb
(
ahc
,
SHARED_DATA_ADDR
+
2
,
(
physaddr
>>
16
)
&
0xFF
);
ahc_outb
(
ahc
,
SHARED_DATA_ADDR
+
3
,
(
physaddr
>>
24
)
&
0xFF
);
/*
* Initialize the group code to command length table.
* This overrides the values in TARG_SCSIRATE, so only
* setup the table after we have processed that information.
*/
ahc_outb
(
ahc
,
CMDSIZE_TABLE
,
5
);
ahc_outb
(
ahc
,
CMDSIZE_TABLE
+
1
,
9
);
ahc_outb
(
ahc
,
CMDSIZE_TABLE
+
2
,
9
);
ahc_outb
(
ahc
,
CMDSIZE_TABLE
+
3
,
0
);
ahc_outb
(
ahc
,
CMDSIZE_TABLE
+
4
,
15
);
ahc_outb
(
ahc
,
CMDSIZE_TABLE
+
5
,
11
);
ahc_outb
(
ahc
,
CMDSIZE_TABLE
+
6
,
0
);
ahc_outb
(
ahc
,
CMDSIZE_TABLE
+
7
,
0
);
/* Tell the sequencer of our initial queue positions */
ahc_outb
(
ahc
,
KERNEL_QINPOS
,
0
);
ahc_outb
(
ahc
,
QINPOS
,
0
);
ahc_outb
(
ahc
,
QOUTPOS
,
0
);
/*
* Use the built in queue management registers
* if they are available.
*/
if
((
ahc
->
features
&
AHC_QUEUE_REGS
)
!=
0
)
{
ahc_outb
(
ahc
,
QOFF_CTLSTA
,
SCB_QSIZE_256
);
ahc_outb
(
ahc
,
SDSCB_QOFF
,
0
);
ahc_outb
(
ahc
,
SNSCB_QOFF
,
0
);
ahc_outb
(
ahc
,
HNSCB_QOFF
,
0
);
}
/* We don't have any waiting selections */
ahc_outb
(
ahc
,
WAITING_SCBH
,
SCB_LIST_NULL
);
/* Our disconnection list is empty too */
ahc_outb
(
ahc
,
DISCONNECTED_SCBH
,
SCB_LIST_NULL
);
/* Message out buffer starts empty */
ahc_outb
(
ahc
,
MSG_OUT
,
MSG_NOOP
);
/*
* Setup the allowed SCSI Sequences based on operational mode.
* If we are a target, we'll enalbe select in operations once
* we've had a lun enabled.
*/
scsiseq_template
=
ENSELO
|
ENAUTOATNO
|
ENAUTOATNP
;
if
((
ahc
->
flags
&
AHC_INITIATORROLE
)
!=
0
)
scsiseq_template
|=
ENRSELI
;
ahc_outb
(
ahc
,
SCSISEQ_TEMPLATE
,
scsiseq_template
);
/*
* Load the Sequencer program and Enable the adapter
* in "fast" mode.
*/
if
(
bootverbose
)
printf
(
"%s: Downloading Sequencer Program..."
,
ahc_name
(
ahc
));
ahc_loadseq
(
ahc
);
if
((
ahc
->
features
&
AHC_ULTRA2
)
!=
0
)
{
int
wait
;
/*
* Wait for up to 500ms for our transceivers
* to settle. If the adapter does not have
* a cable attached, the transceivers may
* never settle, so don't complain if we
* fail here.
*/
ahc_pause
(
ahc
);
for
(
wait
=
5000
;
(
ahc_inb
(
ahc
,
SBLKCTL
)
&
(
ENAB40
|
ENAB20
))
==
0
&&
wait
;
wait
--
)
ahc_delay
(
100
);
ahc_unpause
(
ahc
);
}
return
(
0
);
return
(
ahc
->
bus_chip_init
(
ahc
));
}
void
...
...
@@ -5046,7 +5087,6 @@ ahc_pause_and_flushwork(struct ahc_softc *ahc)
maxloops
=
1000
;
ahc
->
flags
|=
AHC_ALL_INTERRUPTS
;
intstat
=
0
;
paused
=
FALSE
;
do
{
if
(
paused
)
...
...
@@ -5056,10 +5096,10 @@ ahc_pause_and_flushwork(struct ahc_softc *ahc)
paused
=
TRUE
;
ahc_outb
(
ahc
,
SCSISEQ
,
ahc_inb
(
ahc
,
SCSISEQ
)
&
~
ENSELO
);
ahc_clear_critical_section
(
ahc
);
if
(
intstat
==
0xFF
&&
(
ahc
->
features
&
AHC_REMOVABLE
)
!=
0
)
break
;
intstat
=
ahc_inb
(
ahc
,
INTSTAT
);
}
while
(
--
maxloops
&&
(((
intstat
=
ahc_inb
(
ahc
,
INTSTAT
))
&
INT_PEND
)
!=
0
&&
(
intstat
!=
0xFF
||
(
ahc
->
features
&
AHC_REMOVABLE
)
==
0
)
&&
((
intstat
&
INT_PEND
)
!=
0
||
(
ahc_inb
(
ahc
,
SSTAT0
)
&
(
SELDO
|
SELINGO
))));
if
(
maxloops
==
0
)
{
printf
(
"Infinite interrupt loop, INTSTAT = %x"
,
...
...
@@ -5072,13 +5112,13 @@ ahc_pause_and_flushwork(struct ahc_softc *ahc)
int
ahc_suspend
(
struct
ahc_softc
*
ahc
)
{
uint8_t
*
ptr
;
int
i
;
ahc_pause_and_flushwork
(
ahc
);
if
(
LIST_FIRST
(
&
ahc
->
pending_scbs
)
!=
NULL
)
if
(
LIST_FIRST
(
&
ahc
->
pending_scbs
)
!=
NULL
)
{
ahc_unpause
(
ahc
);
return
(
EBUSY
);
}
#if AHC_TARGET_MODE
/*
...
...
@@ -5086,73 +5126,11 @@ ahc_suspend(struct ahc_softc *ahc)
* Perhaps we should just refuse to be suspended if we
* are acting in a target role.
*/
if
(
ahc
->
pending_device
!=
NULL
)
if
(
ahc
->
pending_device
!=
NULL
)
{
ahc_unpause
(
ahc
);
return
(
EBUSY
);
#endif
/* Save volatile registers */
if
((
ahc
->
features
&
AHC_TWIN
)
!=
0
)
{
ahc_outb
(
ahc
,
SBLKCTL
,
ahc_inb
(
ahc
,
SBLKCTL
)
|
SELBUSB
);
ahc
->
suspend_state
.
channel
[
1
].
scsiseq
=
ahc_inb
(
ahc
,
SCSISEQ
);
ahc
->
suspend_state
.
channel
[
1
].
sxfrctl0
=
ahc_inb
(
ahc
,
SXFRCTL0
);
ahc
->
suspend_state
.
channel
[
1
].
sxfrctl1
=
ahc_inb
(
ahc
,
SXFRCTL1
);
ahc
->
suspend_state
.
channel
[
1
].
simode0
=
ahc_inb
(
ahc
,
SIMODE0
);
ahc
->
suspend_state
.
channel
[
1
].
simode1
=
ahc_inb
(
ahc
,
SIMODE1
);
ahc
->
suspend_state
.
channel
[
1
].
seltimer
=
ahc_inb
(
ahc
,
SELTIMER
);
ahc
->
suspend_state
.
channel
[
1
].
seqctl
=
ahc_inb
(
ahc
,
SEQCTL
);
ahc_outb
(
ahc
,
SBLKCTL
,
ahc_inb
(
ahc
,
SBLKCTL
)
&
~
SELBUSB
);
}
ahc
->
suspend_state
.
channel
[
0
].
scsiseq
=
ahc_inb
(
ahc
,
SCSISEQ
);
ahc
->
suspend_state
.
channel
[
0
].
sxfrctl0
=
ahc_inb
(
ahc
,
SXFRCTL0
);
ahc
->
suspend_state
.
channel
[
0
].
sxfrctl1
=
ahc_inb
(
ahc
,
SXFRCTL1
);
ahc
->
suspend_state
.
channel
[
0
].
simode0
=
ahc_inb
(
ahc
,
SIMODE0
);
ahc
->
suspend_state
.
channel
[
0
].
simode1
=
ahc_inb
(
ahc
,
SIMODE1
);
ahc
->
suspend_state
.
channel
[
0
].
seltimer
=
ahc_inb
(
ahc
,
SELTIMER
);
ahc
->
suspend_state
.
channel
[
0
].
seqctl
=
ahc_inb
(
ahc
,
SEQCTL
);
if
((
ahc
->
chip
&
AHC_PCI
)
!=
0
)
{
ahc
->
suspend_state
.
dscommand0
=
ahc_inb
(
ahc
,
DSCOMMAND0
);
ahc
->
suspend_state
.
dspcistatus
=
ahc_inb
(
ahc
,
DSPCISTATUS
);
}
if
((
ahc
->
features
&
AHC_DT
)
!=
0
)
{
u_int
sfunct
;
sfunct
=
ahc_inb
(
ahc
,
SFUNCT
)
&
~
ALT_MODE
;
ahc_outb
(
ahc
,
SFUNCT
,
sfunct
|
ALT_MODE
);
ahc
->
suspend_state
.
optionmode
=
ahc_inb
(
ahc
,
OPTIONMODE
);
ahc_outb
(
ahc
,
SFUNCT
,
sfunct
);
ahc
->
suspend_state
.
crccontrol1
=
ahc_inb
(
ahc
,
CRCCONTROL1
);
}
if
((
ahc
->
features
&
AHC_MULTI_FUNC
)
!=
0
)
ahc
->
suspend_state
.
scbbaddr
=
ahc_inb
(
ahc
,
SCBBADDR
);
if
((
ahc
->
features
&
AHC_ULTRA2
)
!=
0
)
ahc
->
suspend_state
.
dff_thrsh
=
ahc_inb
(
ahc
,
DFF_THRSH
);
ptr
=
ahc
->
suspend_state
.
scratch_ram
;
for
(
i
=
0
;
i
<
64
;
i
++
)
*
ptr
++
=
ahc_inb
(
ahc
,
SRAM_BASE
+
i
);
if
((
ahc
->
features
&
AHC_MORE_SRAM
)
!=
0
)
{
for
(
i
=
0
;
i
<
16
;
i
++
)
*
ptr
++
=
ahc_inb
(
ahc
,
TARG_OFFSET
+
i
);
}
ptr
=
ahc
->
suspend_state
.
btt
;
if
((
ahc
->
flags
&
AHC_SCB_BTT
)
!=
0
)
{
for
(
i
=
0
;
i
<
AHC_NUM_TARGETS
;
i
++
)
{
int
j
;
for
(
j
=
0
;
j
<
AHC_NUM_LUNS
;
j
++
)
{
u_int
tcl
;
tcl
=
BUILD_TCL
(
i
<<
4
,
j
);
*
ptr
=
ahc_index_busy_tcl
(
ahc
,
tcl
);
}
}
}
#endif
ahc_shutdown
(
ahc
);
return
(
0
);
}
...
...
@@ -5160,81 +5138,8 @@ ahc_suspend(struct ahc_softc *ahc)
int
ahc_resume
(
struct
ahc_softc
*
ahc
)
{
uint8_t
*
ptr
;
int
i
;
ahc_reset
(
ahc
);
ahc_build_free_scb_list
(
ahc
);
/* Restore volatile registers */
if
((
ahc
->
features
&
AHC_TWIN
)
!=
0
)
{
ahc_outb
(
ahc
,
SBLKCTL
,
ahc_inb
(
ahc
,
SBLKCTL
)
|
SELBUSB
);
ahc_outb
(
ahc
,
SCSIID
,
ahc
->
our_id
);
ahc_outb
(
ahc
,
SCSISEQ
,
ahc
->
suspend_state
.
channel
[
1
].
scsiseq
);
ahc_outb
(
ahc
,
SXFRCTL0
,
ahc
->
suspend_state
.
channel
[
1
].
sxfrctl0
);
ahc_outb
(
ahc
,
SXFRCTL1
,
ahc
->
suspend_state
.
channel
[
1
].
sxfrctl1
);
ahc_outb
(
ahc
,
SIMODE0
,
ahc
->
suspend_state
.
channel
[
1
].
simode0
);
ahc_outb
(
ahc
,
SIMODE1
,
ahc
->
suspend_state
.
channel
[
1
].
simode1
);
ahc_outb
(
ahc
,
SELTIMER
,
ahc
->
suspend_state
.
channel
[
1
].
seltimer
);
ahc_outb
(
ahc
,
SEQCTL
,
ahc
->
suspend_state
.
channel
[
1
].
seqctl
);
ahc_outb
(
ahc
,
SBLKCTL
,
ahc_inb
(
ahc
,
SBLKCTL
)
&
~
SELBUSB
);
}
ahc_outb
(
ahc
,
SCSISEQ
,
ahc
->
suspend_state
.
channel
[
0
].
scsiseq
);
ahc_outb
(
ahc
,
SXFRCTL0
,
ahc
->
suspend_state
.
channel
[
0
].
sxfrctl0
);
ahc_outb
(
ahc
,
SXFRCTL1
,
ahc
->
suspend_state
.
channel
[
0
].
sxfrctl1
);
ahc_outb
(
ahc
,
SIMODE0
,
ahc
->
suspend_state
.
channel
[
0
].
simode0
);
ahc_outb
(
ahc
,
SIMODE1
,
ahc
->
suspend_state
.
channel
[
0
].
simode1
);
ahc_outb
(
ahc
,
SELTIMER
,
ahc
->
suspend_state
.
channel
[
0
].
seltimer
);
ahc_outb
(
ahc
,
SEQCTL
,
ahc
->
suspend_state
.
channel
[
0
].
seqctl
);
if
((
ahc
->
features
&
AHC_ULTRA2
)
!=
0
)
ahc_outb
(
ahc
,
SCSIID_ULTRA2
,
ahc
->
our_id
);
else
ahc_outb
(
ahc
,
SCSIID
,
ahc
->
our_id
);
if
((
ahc
->
chip
&
AHC_PCI
)
!=
0
)
{
ahc_outb
(
ahc
,
DSCOMMAND0
,
ahc
->
suspend_state
.
dscommand0
);
ahc_outb
(
ahc
,
DSPCISTATUS
,
ahc
->
suspend_state
.
dspcistatus
);
}
if
((
ahc
->
features
&
AHC_DT
)
!=
0
)
{
u_int
sfunct
;
sfunct
=
ahc_inb
(
ahc
,
SFUNCT
)
&
~
ALT_MODE
;
ahc_outb
(
ahc
,
SFUNCT
,
sfunct
|
ALT_MODE
);
ahc_outb
(
ahc
,
OPTIONMODE
,
ahc
->
suspend_state
.
optionmode
);
ahc_outb
(
ahc
,
SFUNCT
,
sfunct
);
ahc_outb
(
ahc
,
CRCCONTROL1
,
ahc
->
suspend_state
.
crccontrol1
);
}
if
((
ahc
->
features
&
AHC_MULTI_FUNC
)
!=
0
)
ahc_outb
(
ahc
,
SCBBADDR
,
ahc
->
suspend_state
.
scbbaddr
);
if
((
ahc
->
features
&
AHC_ULTRA2
)
!=
0
)
ahc_outb
(
ahc
,
DFF_THRSH
,
ahc
->
suspend_state
.
dff_thrsh
);
ptr
=
ahc
->
suspend_state
.
scratch_ram
;
for
(
i
=
0
;
i
<
64
;
i
++
)
ahc_outb
(
ahc
,
SRAM_BASE
+
i
,
*
ptr
++
);
if
((
ahc
->
features
&
AHC_MORE_SRAM
)
!=
0
)
{
for
(
i
=
0
;
i
<
16
;
i
++
)
ahc_outb
(
ahc
,
TARG_OFFSET
+
i
,
*
ptr
++
);
}
ptr
=
ahc
->
suspend_state
.
btt
;
if
((
ahc
->
flags
&
AHC_SCB_BTT
)
!=
0
)
{
for
(
i
=
0
;
i
<
AHC_NUM_TARGETS
;
i
++
)
{
int
j
;
for
(
j
=
0
;
j
<
AHC_NUM_LUNS
;
j
++
)
{
u_int
tcl
;
tcl
=
BUILD_TCL
(
i
<<
4
,
j
);
ahc_busy_tcl
(
ahc
,
tcl
,
*
ptr
);
}
}
}
return
(
0
);
}
...
...
@@ -6379,19 +6284,11 @@ void
ahc_dumpseq
(
struct
ahc_softc
*
ahc
)
{
int
i
;
int
max_prog
;
if
((
ahc
->
chip
&
AHC_BUS_MASK
)
<
AHC_PCI
)
max_prog
=
448
;
else
if
((
ahc
->
features
&
AHC_ULTRA2
)
!=
0
)
max_prog
=
768
;
else
max_prog
=
512
;
ahc_outb
(
ahc
,
SEQCTL
,
PERRORDIS
|
FAILDIS
|
FASTMODE
|
LOADRAM
);
ahc_outb
(
ahc
,
SEQADDR0
,
0
);
ahc_outb
(
ahc
,
SEQADDR1
,
0
);
for
(
i
=
0
;
i
<
max_prog
;
i
++
)
{
for
(
i
=
0
;
i
<
ahc
->
instruction_ram_size
;
i
++
)
{
uint8_t
ins_bytes
[
4
];
ahc_insb
(
ahc
,
SEQRAM
,
ins_bytes
,
4
);
...
...
@@ -6403,7 +6300,7 @@ ahc_dumpseq(struct ahc_softc* ahc)
}
#endif
static
void
static
int
ahc_loadseq
(
struct
ahc_softc
*
ahc
)
{
struct
cs
cs_table
[
num_critical_sections
];
...
...
@@ -6413,9 +6310,9 @@ ahc_loadseq(struct ahc_softc *ahc)
u_int
cs_count
;
u_int
cur_cs
;
u_int
i
;
int
downloaded
;
u_int
skip_addr
;
u_int
sg_prefetch_cnt
;
int
downloaded
;
uint8_t
download_consts
[
7
];
/*
...
...
@@ -6456,6 +6353,19 @@ ahc_loadseq(struct ahc_softc *ahc)
*/
continue
;
}
if
(
downloaded
==
ahc
->
instruction_ram_size
)
{
/*
* We're about to exceed the instruction
* storage capacity for this chip. Fail
* the load.
*/
printf
(
"
\n
%s: Program too large for instruction memory "
"size of %d!
\n
"
,
ahc_name
(
ahc
),
ahc
->
instruction_ram_size
);
return
(
ENOMEM
);
}
/*
* Move through the CS table until we find a CS
* that might apply to this instruction.
...
...
@@ -6498,6 +6408,7 @@ ahc_loadseq(struct ahc_softc *ahc)
printf
(
"%s: Features 0x%x, Bugs 0x%x, Flags 0x%x
\n
"
,
ahc_name
(
ahc
),
ahc
->
features
,
ahc
->
bugs
,
ahc
->
flags
);
}
return
(
0
);
}
static
int
...
...
@@ -6942,11 +6853,12 @@ ahc_handle_en_lun(struct ahc_softc *ahc, struct cam_sim *sim, union ccb *ccb)
struct
ahc_tmode_lstate
*
lstate
;
struct
ccb_en_lun
*
cel
;
cam_status
status
;
u_long
s
;
u_int
target
;
u_int
lun
;
u_int
target_mask
;
u_int
our_id
;
u_long
s
;
int
error
;
char
channel
;
status
=
ahc_find_tmode_devs
(
ahc
,
sim
,
ccb
,
&
tstate
,
&
lstate
,
...
...
@@ -7023,7 +6935,8 @@ ahc_handle_en_lun(struct ahc_softc *ahc, struct cam_sim *sim, union ccb *ccb)
*/
if
((
ahc
->
flags
&
AHC_TARGETROLE
)
==
0
&&
ccb
->
ccb_h
.
target_id
!=
CAM_TARGET_WILDCARD
)
{
u_long
s
;
u_long
s
;
ahc_flag
saved_flags
;
printf
(
"Configuring Target Mode
\n
"
);
ahc_lock
(
ahc
,
&
s
);
...
...
@@ -7032,11 +6945,28 @@ ahc_handle_en_lun(struct ahc_softc *ahc, struct cam_sim *sim, union ccb *ccb)
ahc_unlock
(
ahc
,
&
s
);
return
;
}
saved_flags
=
ahc
->
flags
;
ahc
->
flags
|=
AHC_TARGETROLE
;
if
((
ahc
->
features
&
AHC_MULTIROLE
)
==
0
)
ahc
->
flags
&=
~
AHC_INITIATORROLE
;
ahc_pause
(
ahc
);
ahc_loadseq
(
ahc
);
error
=
ahc_loadseq
(
ahc
);
if
(
error
!=
0
)
{
/*
* Restore original configuration and notify
* the caller that we cannot support target mode.
* Since the adapter started out in this
* configuration, the firmware load will succeed,
* so there is no point in checking ahc_loadseq's
* return value.
*/
ahc
->
flags
=
saved_flags
;
(
void
)
ahc_loadseq
(
ahc
);
ahc_unpause
(
ahc
);
ahc_unlock
(
ahc
,
&
s
);
ccb
->
ccb_h
.
status
=
CAM_FUNC_NOTAVAIL
;
return
;
}
ahc_unlock
(
ahc
,
&
s
);
}
cel
=
&
ccb
->
cel
;
...
...
@@ -7272,7 +7202,11 @@ ahc_handle_en_lun(struct ahc_softc *ahc, struct cam_sim *sim, union ccb *ccb)
ahc
->
flags
&=
~
AHC_TARGETROLE
;
ahc
->
flags
|=
AHC_INITIATORROLE
;
ahc_pause
(
ahc
);
ahc_loadseq
(
ahc
);
/*
* Returning to a configuration that
* fit previously will always succeed.
*/
(
void
)
ahc_loadseq
(
ahc
);
}
}
ahc_unpause
(
ahc
);
...
...
drivers/scsi/aic7xxx/aic7xxx_inline.h
View file @
14686d42
...
...
@@ -37,7 +37,7 @@
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGES.
*
* $Id: //depot/aic7xxx/aic7xxx/aic7xxx_inline.h#
39
$
* $Id: //depot/aic7xxx/aic7xxx/aic7xxx_inline.h#
40
$
*
* $FreeBSD$
*/
...
...
drivers/scsi/aic7xxx/aic7xxx_osm.c
View file @
14686d42
/*
* Adaptec AIC7xxx device driver for Linux.
*
* $Id: //depot/aic7xxx/linux/drivers/scsi/aic7xxx/aic7xxx_osm.c#1
79
$
* $Id: //depot/aic7xxx/linux/drivers/scsi/aic7xxx/aic7xxx_osm.c#1
92
$
*
* Copyright (c) 1994 John Aycock
* The University of Calgary Department of Computer Science.
...
...
@@ -995,9 +995,13 @@ ahc_linux_queue(Scsi_Cmnd * cmd, void (*scsi_done) (Scsi_Cmnd *))
dev
=
ahc_linux_get_device
(
ahc
,
cmd
->
device
->
channel
,
cmd
->
device
->
id
,
cmd
->
device
->
lun
,
/*alloc*/
TRUE
);
if
(
dev
==
NULL
)
{
ahc_cmd_set_transaction_status
(
cmd
,
CAM_RESRC_UNAVAIL
);
ahc_linux_queue_cmd_complete
(
ahc
,
cmd
);
ahc_schedule_completeq
(
ahc
,
NULL
);
ahc_midlayer_entrypoint_unlock
(
ahc
,
&
flags
);
printf
(
"aic7xxx_linux_queue: Unable to allocate device!
\n
"
);
return
(
-
ENOMEM
);
printf
(
"%s: aic7xxx_linux_queue - Unable to allocate device!
\n
"
,
ahc_name
(
ahc
));
return
(
0
);
}
cmd
->
result
=
CAM_REQ_INPROG
<<
16
;
TAILQ_INSERT_TAIL
(
&
dev
->
busyq
,
(
struct
ahc_cmd
*
)
cmd
,
acmd_links
.
tqe
);
...
...
@@ -1291,7 +1295,7 @@ Scsi_Host_Template aic7xxx_driver_template = {
.
max_sectors
=
8192
,
#endif
#if defined CONFIG_HIGHIO || LINUX_VERSION_CODE >= KERNEL_VERSION(2,5,0)
#if LINUX_VERSION_CODE < KERNEL_VERSION(2,4,1
8
)
#if LINUX_VERSION_CODE < KERNEL_VERSION(2,4,1
0
)
/* Assume RedHat Distribution with its different HIGHIO conventions. */
.
can_dma_32
=
1
,
.
single_sg_okay
=
1
,
...
...
@@ -1882,13 +1886,28 @@ ahc_linux_register_host(struct ahc_softc *ahc, Scsi_Host_Template *template)
* negotiation will occur for the first command, and DV
* will comence should that first command be successful.
*/
for
(
target
=
0
;
target
<
host
->
max_id
*
host
->
max_channel
+
1
;
target
++
)
{
for
(
target
=
0
;
target
<
host
->
max_id
*
(
host
->
max_channel
+
1
);
target
++
)
{
u_int
channel
;
channel
=
0
;
if
(
target
>
7
&&
(
ahc
->
features
&
AHC_TWIN
)
!=
0
)
channel
=
1
;
/*
* Skip our own ID. Some Compaq/HP storage devices
* have enclosure management devices that respond to
* single bit selection (i.e. selecting ourselves).
* It is expected that either an external application
* or a modified kernel will be used to probe this
* ID if it is appropriate. To accomodate these installations,
* ahc_linux_alloc_target() will allocate for our ID if
* asked to do so.
*/
if
((
channel
==
0
&&
target
==
ahc
->
our_id
)
||
(
channel
==
1
&&
target
==
ahc
->
our_id_b
))
continue
;
ahc_linux_alloc_target
(
ahc
,
channel
,
target
);
}
ahc_intr_enable
(
ahc
,
TRUE
);
...
...
@@ -2328,7 +2347,7 @@ ahc_linux_start_dv(struct ahc_softc *ahc)
/*
* Freeze the simq and signal ahc_linux_queue to not let any
* more commands through
* more commands through
.
*/
if
((
ahc
->
platform_data
->
flags
&
AHC_DV_ACTIVE
)
==
0
)
{
#ifdef AHC_DEBUG
...
...
@@ -2362,7 +2381,17 @@ ahc_linux_dv_thread(void *data)
* Complete thread creation.
*/
lock_kernel
();
#if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,0)
/*
* Don't care about any signals.
*/
siginitsetinv
(
&
current
->
blocked
,
0
);
daemonize
();
sprintf
(
current
->
comm
,
"ahc_dv_%d"
,
ahc
->
unit
);
#else
daemonize
(
"ahc_dv_%d"
,
ahc
->
unit
);
#endif
unlock_kernel
();
while
(
1
)
{
...
...
@@ -2528,6 +2557,7 @@ ahc_linux_dv_target(struct ahc_softc *ahc, u_int target_offset)
}
case
AHC_DV_STATE_TUR
:
case
AHC_DV_STATE_BUSY
:
timeout
=
5
*
HZ
;
ahc_linux_dv_tur
(
ahc
,
cmd
,
&
devinfo
);
break
;
case
AHC_DV_STATE_REBD
:
...
...
@@ -3995,15 +4025,6 @@ ahc_linux_alloc_target(struct ahc_softc *ahc, u_int channel, u_int target)
target_offset
=
target
;
if
(
channel
!=
0
)
target_offset
+=
8
;
/*
* Never allow allocation of a target object for
* our own SCSIID.
*/
if
((
channel
==
0
&&
target
==
ahc
->
our_id
)
||
(
channel
==
1
&&
target
==
ahc
->
our_id_b
))
{
ahc
->
platform_data
->
targets
[
target_offset
]
=
NULL
;
return
(
NULL
);
}
targ
=
malloc
(
sizeof
(
*
targ
),
M_DEVBUG
,
M_NOWAIT
);
if
(
targ
==
NULL
)
...
...
@@ -4274,6 +4295,14 @@ ahc_done(struct ahc_softc *ahc, struct scb *scb)
#endif
ahc_set_transaction_status
(
scb
,
CAM_UNCOR_PARITY
);
}
else
if
(
amount_xferred
<
scb
->
io_ctx
->
underflow
)
{
u_int
i
;
ahc_print_path
(
ahc
,
scb
);
printf
(
"CDB:"
);
for
(
i
=
0
;
i
<
scb
->
io_ctx
->
cmd_len
;
i
++
)
printf
(
" 0x%x"
,
scb
->
io_ctx
->
cmnd
[
i
]);
printf
(
"
\n
"
);
ahc_print_path
(
ahc
,
scb
);
printf
(
"Saw underflow (%ld of %ld bytes). "
"Treated as error
\n
"
,
ahc_get_residual
(
scb
),
...
...
@@ -4815,6 +4844,7 @@ ahc_linux_queue_recovery_cmd(Scsi_Cmnd *cmd, scb_flag flag)
u_int
active_scb_index
;
u_int
last_phase
;
u_int
saved_scsiid
;
u_int
cdb_byte
;
int
retval
;
int
paused
;
int
wait
;
...
...
@@ -4831,6 +4861,11 @@ ahc_linux_queue_recovery_cmd(Scsi_Cmnd *cmd, scb_flag flag)
cmd
->
device
->
id
,
cmd
->
device
->
lun
,
flag
==
SCB_ABORT
?
"n ABORT"
:
" TARGET RESET"
);
printf
(
"CDB:"
);
for
(
cdb_byte
=
0
;
cdb_byte
<
cmd
->
cmd_len
;
cdb_byte
++
)
printf
(
" 0x%x"
,
cmd
->
cmnd
[
cdb_byte
]);
printf
(
"
\n
"
);
/*
* In all versions of Linux, we have to work around
* a major flaw in how the mid-layer is locked down
...
...
drivers/scsi/aic7xxx/aic7xxx_osm.h
View file @
14686d42
...
...
@@ -53,7 +53,7 @@
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGES.
*
* $Id: //depot/aic7xxx/linux/drivers/scsi/aic7xxx/aic7xxx_osm.h#12
3
$
* $Id: //depot/aic7xxx/linux/drivers/scsi/aic7xxx/aic7xxx_osm.h#12
8
$
*
*/
#ifndef _AIC7XXX_LINUX_H_
...
...
@@ -299,7 +299,7 @@ ahc_scb_timer_reset(struct scb *scb, u_int usec)
#include <linux/smp.h>
#endif
#define AIC7XXX_DRIVER_VERSION "6.2.
28
"
#define AIC7XXX_DRIVER_VERSION "6.2.
30
"
/**************************** Front End Queues ********************************/
/*
...
...
@@ -907,7 +907,7 @@ int aic7770_map_int(struct ahc_softc *ahc, u_int irq);
*/
#if LINUX_VERSION_CODE <= KERNEL_VERSION(2,1,92)
#if defined(__sparc_v9__) || defined(__powerpc__)
#error "PPC and Sparc platforms are only support under 2.1.92 and above"
#error "PPC and Sparc platforms are only support
ed
under 2.1.92 and above"
#endif
#include <linux/bios32.h>
#endif
...
...
drivers/scsi/aic7xxx/aic7xxx_pci.c
View file @
14686d42
...
...
@@ -39,7 +39,7 @@
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGES.
*
* $Id: //depot/aic7xxx/aic7xxx/aic7xxx_pci.c#
57
$
* $Id: //depot/aic7xxx/aic7xxx/aic7xxx_pci.c#
61
$
*
* $FreeBSD$
*/
...
...
@@ -696,8 +696,12 @@ static void aic787X_cable_detect(struct ahc_softc *ahc, int *internal50_present,
static
void
aic785X_cable_detect
(
struct
ahc_softc
*
ahc
,
int
*
internal50_present
,
int
*
externalcable_present
,
int
*
eeprom_present
);
static
void
write_brdctl
(
struct
ahc_softc
*
ahc
,
uint8_t
value
);
static
void
write_brdctl
(
struct
ahc_softc
*
ahc
,
uint8_t
value
);
static
uint8_t
read_brdctl
(
struct
ahc_softc
*
ahc
);
static
void
ahc_pci_intr
(
struct
ahc_softc
*
ahc
);
static
int
ahc_pci_chip_init
(
struct
ahc_softc
*
ahc
);
static
int
ahc_pci_suspend
(
struct
ahc_softc
*
ahc
);
static
int
ahc_pci_resume
(
struct
ahc_softc
*
ahc
);
static
int
ahc_9005_subdevinfo_valid
(
uint16_t
device
,
uint16_t
vendor
,
...
...
@@ -854,6 +858,9 @@ ahc_pci_config(struct ahc_softc *ahc, struct ahc_pci_identity *entry)
return
(
error
);
ahc
->
bus_intr
=
ahc_pci_intr
;
ahc
->
bus_chip_init
=
ahc_pci_chip_init
;
ahc
->
bus_suspend
=
ahc_pci_suspend
;
ahc
->
bus_resume
=
ahc_pci_resume
;
/* Remeber how the card was setup in case there is no SEEPROM */
if
((
ahc_inb
(
ahc
,
HCNTRL
)
&
POWRDN
)
==
0
)
{
...
...
@@ -993,6 +1000,35 @@ ahc_pci_config(struct ahc_softc *ahc, struct ahc_pci_identity *entry)
if
((
sxfrctl1
&
STPWEN
)
!=
0
)
ahc
->
flags
|=
AHC_TERM_ENB_A
;
/*
* Save chip register configuration data for chip resets
* that occur during runtime and resume events.
*/
ahc
->
bus_softc
.
pci_softc
.
devconfig
=
ahc_pci_read_config
(
ahc
->
dev_softc
,
DEVCONFIG
,
/*bytes*/
4
);
ahc
->
bus_softc
.
pci_softc
.
command
=
ahc_pci_read_config
(
ahc
->
dev_softc
,
PCIR_COMMAND
,
/*bytes*/
1
);
ahc
->
bus_softc
.
pci_softc
.
csize_lattime
=
ahc_pci_read_config
(
ahc
->
dev_softc
,
CSIZE_LATTIME
,
/*bytes*/
1
);
ahc
->
bus_softc
.
pci_softc
.
dscommand0
=
ahc_inb
(
ahc
,
DSCOMMAND0
);
ahc
->
bus_softc
.
pci_softc
.
dspcistatus
=
ahc_inb
(
ahc
,
DSPCISTATUS
);
if
((
ahc
->
features
&
AHC_DT
)
!=
0
)
{
u_int
sfunct
;
sfunct
=
ahc_inb
(
ahc
,
SFUNCT
)
&
~
ALT_MODE
;
ahc_outb
(
ahc
,
SFUNCT
,
sfunct
|
ALT_MODE
);
ahc
->
bus_softc
.
pci_softc
.
optionmode
=
ahc_inb
(
ahc
,
OPTIONMODE
);
ahc
->
bus_softc
.
pci_softc
.
targcrccnt
=
ahc_inw
(
ahc
,
TARGCRCCNT
);
ahc_outb
(
ahc
,
SFUNCT
,
sfunct
);
ahc
->
bus_softc
.
pci_softc
.
crccontrol1
=
ahc_inb
(
ahc
,
CRCCONTROL1
);
}
if
((
ahc
->
features
&
AHC_MULTI_FUNC
)
!=
0
)
ahc
->
bus_softc
.
pci_softc
.
scbbaddr
=
ahc_inb
(
ahc
,
SCBBADDR
);
if
((
ahc
->
features
&
AHC_ULTRA2
)
!=
0
)
ahc
->
bus_softc
.
pci_softc
.
dff_thrsh
=
ahc_inb
(
ahc
,
DFF_THRSH
);
/* Core initialization */
error
=
ahc_init
(
ahc
);
if
(
error
!=
0
)
...
...
@@ -1412,6 +1448,7 @@ check_extport(struct ahc_softc *ahc, u_int *sxfrctl1)
}
if
(
have_autoterm
)
{
ahc
->
flags
|=
AHC_HAS_TERM_LOGIC
;
ahc_acquire_seeprom
(
ahc
,
&
sd
);
configure_termination
(
ahc
,
&
sd
,
sc
->
adapter_control
,
sxfrctl1
);
ahc_release_seeprom
(
&
sd
);
...
...
@@ -1845,11 +1882,14 @@ aic785X_cable_detect(struct ahc_softc *ahc, int *internal50_present,
spiocap
|=
EXT_BRDCTL
;
ahc_outb
(
ahc
,
SPIOCAP
,
spiocap
);
ahc_outb
(
ahc
,
BRDCTL
,
BRDRW
|
BRDCS
);
ahc_flush_device_writes
(
ahc
);
ahc_delay
(
500
);
ahc_outb
(
ahc
,
BRDCTL
,
0
);
ahc_flush_device_writes
(
ahc
);
ahc_delay
(
500
);
brdctl
=
ahc_inb
(
ahc
,
BRDCTL
);
*
internal50_present
=
(
brdctl
&
BRDDAT5
)
?
0
:
1
;
*
externalcable_present
=
(
brdctl
&
BRDDAT6
)
?
0
:
1
;
*
eeprom_present
=
(
ahc_inb
(
ahc
,
SPIOCAP
)
&
EEPROM
)
?
1
:
0
;
}
...
...
@@ -1943,7 +1983,7 @@ read_brdctl(ahc)
return
(
value
);
}
void
static
void
ahc_pci_intr
(
struct
ahc_softc
*
ahc
)
{
u_int
error
;
...
...
@@ -1995,6 +2035,73 @@ ahc_pci_intr(struct ahc_softc *ahc)
ahc_unpause
(
ahc
);
}
static
int
ahc_pci_chip_init
(
struct
ahc_softc
*
ahc
)
{
ahc_outb
(
ahc
,
DSCOMMAND0
,
ahc
->
bus_softc
.
pci_softc
.
dscommand0
);
ahc_outb
(
ahc
,
DSPCISTATUS
,
ahc
->
bus_softc
.
pci_softc
.
dspcistatus
);
if
((
ahc
->
features
&
AHC_DT
)
!=
0
)
{
u_int
sfunct
;
sfunct
=
ahc_inb
(
ahc
,
SFUNCT
)
&
~
ALT_MODE
;
ahc_outb
(
ahc
,
SFUNCT
,
sfunct
|
ALT_MODE
);
ahc_outb
(
ahc
,
OPTIONMODE
,
ahc
->
bus_softc
.
pci_softc
.
optionmode
);
ahc_outw
(
ahc
,
TARGCRCCNT
,
ahc
->
bus_softc
.
pci_softc
.
targcrccnt
);
ahc_outb
(
ahc
,
SFUNCT
,
sfunct
);
ahc_outb
(
ahc
,
CRCCONTROL1
,
ahc
->
bus_softc
.
pci_softc
.
crccontrol1
);
}
if
((
ahc
->
features
&
AHC_MULTI_FUNC
)
!=
0
)
ahc_outb
(
ahc
,
SCBBADDR
,
ahc
->
bus_softc
.
pci_softc
.
scbbaddr
);
if
((
ahc
->
features
&
AHC_ULTRA2
)
!=
0
)
ahc_outb
(
ahc
,
DFF_THRSH
,
ahc
->
bus_softc
.
pci_softc
.
dff_thrsh
);
return
(
ahc_chip_init
(
ahc
));
}
static
int
ahc_pci_suspend
(
struct
ahc_softc
*
ahc
)
{
return
(
ahc_suspend
(
ahc
));
}
static
int
ahc_pci_resume
(
struct
ahc_softc
*
ahc
)
{
ahc_power_state_change
(
ahc
,
AHC_POWER_STATE_D0
);
/*
* We assume that the OS has restored our register
* mappings, etc. Just update the config space registers
* that the OS doesn't know about and rely on our chip
* reset handler to handle the rest.
*/
ahc_pci_write_config
(
ahc
->
dev_softc
,
DEVCONFIG
,
/*bytes*/
4
,
ahc
->
bus_softc
.
pci_softc
.
devconfig
);
ahc_pci_write_config
(
ahc
->
dev_softc
,
PCIR_COMMAND
,
/*bytes*/
1
,
ahc
->
bus_softc
.
pci_softc
.
command
);
ahc_pci_write_config
(
ahc
->
dev_softc
,
CSIZE_LATTIME
,
/*bytes*/
1
,
ahc
->
bus_softc
.
pci_softc
.
csize_lattime
);
if
((
ahc
->
flags
&
AHC_HAS_TERM_LOGIC
)
!=
0
)
{
struct
seeprom_descriptor
sd
;
u_int
sxfrctl1
;
sd
.
sd_ahc
=
ahc
;
sd
.
sd_control_offset
=
SEECTL
;
sd
.
sd_status_offset
=
SEECTL
;
sd
.
sd_dataout_offset
=
SEECTL
;
ahc_acquire_seeprom
(
ahc
,
&
sd
);
configure_termination
(
ahc
,
&
sd
,
ahc
->
seep_config
->
adapter_control
,
&
sxfrctl1
);
ahc_release_seeprom
(
&
sd
);
}
return
(
ahc_resume
(
ahc
));
}
static
int
ahc_aic785X_setup
(
struct
ahc_softc
*
ahc
)
{
...
...
@@ -2009,6 +2116,7 @@ ahc_aic785X_setup(struct ahc_softc *ahc)
rev
=
ahc_pci_read_config
(
pci
,
PCIR_REVID
,
/*bytes*/
1
);
if
(
rev
>=
1
)
ahc
->
bugs
|=
AHC_PCI_2_1_RETRY_BUG
;
ahc
->
instruction_ram_size
=
512
;
return
(
0
);
}
...
...
@@ -2026,6 +2134,7 @@ ahc_aic7860_setup(struct ahc_softc *ahc)
rev
=
ahc_pci_read_config
(
pci
,
PCIR_REVID
,
/*bytes*/
1
);
if
(
rev
>=
1
)
ahc
->
bugs
|=
AHC_PCI_2_1_RETRY_BUG
;
ahc
->
instruction_ram_size
=
512
;
return
(
0
);
}
...
...
@@ -2049,6 +2158,7 @@ ahc_aic7870_setup(struct ahc_softc *ahc)
ahc
->
chip
=
AHC_AIC7870
;
ahc
->
features
=
AHC_AIC7870_FE
;
ahc
->
bugs
|=
AHC_TMODE_WIDEODD_BUG
|
AHC_CACHETHEN_BUG
|
AHC_PCI_MWI_BUG
;
ahc
->
instruction_ram_size
=
512
;
return
(
0
);
}
...
...
@@ -2102,6 +2212,7 @@ ahc_aic7880_setup(struct ahc_softc *ahc)
}
else
{
ahc
->
bugs
|=
AHC_CACHETHEN_BUG
|
AHC_PCI_MWI_BUG
;
}
ahc
->
instruction_ram_size
=
512
;
return
(
0
);
}
...
...
@@ -2149,6 +2260,7 @@ ahc_aic7890_setup(struct ahc_softc *ahc)
rev
=
ahc_pci_read_config
(
pci
,
PCIR_REVID
,
/*bytes*/
1
);
if
(
rev
==
0
)
ahc
->
bugs
|=
AHC_AUTOFLUSH_BUG
|
AHC_CACHETHEN_BUG
;
ahc
->
instruction_ram_size
=
768
;
return
(
0
);
}
...
...
@@ -2161,6 +2273,7 @@ ahc_aic7892_setup(struct ahc_softc *ahc)
ahc
->
features
=
AHC_AIC7892_FE
;
ahc
->
flags
|=
AHC_NEWEEPROM_FMT
;
ahc
->
bugs
|=
AHC_SCBCHAN_UPLOAD_BUG
;
ahc
->
instruction_ram_size
=
1024
;
return
(
0
);
}
...
...
@@ -2216,6 +2329,7 @@ ahc_aic7895_setup(struct ahc_softc *ahc)
ahc_pci_write_config(pci, DEVCONFIG, devconfig, /*bytes*/1);
#endif
ahc
->
flags
|=
AHC_NEWEEPROM_FMT
;
ahc
->
instruction_ram_size
=
512
;
return
(
0
);
}
...
...
@@ -2230,6 +2344,7 @@ ahc_aic7896_setup(struct ahc_softc *ahc)
ahc
->
features
=
AHC_AIC7896_FE
;
ahc
->
flags
|=
AHC_NEWEEPROM_FMT
;
ahc
->
bugs
|=
AHC_CACHETHEN_DIS_BUG
;
ahc
->
instruction_ram_size
=
768
;
return
(
0
);
}
...
...
@@ -2244,6 +2359,7 @@ ahc_aic7899_setup(struct ahc_softc *ahc)
ahc
->
features
=
AHC_AIC7899_FE
;
ahc
->
flags
|=
AHC_NEWEEPROM_FMT
;
ahc
->
bugs
|=
AHC_SCBCHAN_UPLOAD_BUG
;
ahc
->
instruction_ram_size
=
1024
;
return
(
0
);
}
...
...
drivers/scsi/aic7xxx/aic7xxx_proc.c
View file @
14686d42
...
...
@@ -37,7 +37,7 @@
* String handling code courtesy of Gerard Roudier's <groudier@club-internet.fr>
* sym driver.
*
* $Id: //depot/aic7xxx/linux/drivers/scsi/aic7xxx/aic7xxx_proc.c#2
3
$
* $Id: //depot/aic7xxx/linux/drivers/scsi/aic7xxx/aic7xxx_proc.c#2
4
$
*/
#include "aic7xxx_osm.h"
#include "aic7xxx_inline.h"
...
...
@@ -325,6 +325,7 @@ ahc_linux_proc_info(char *buffer, char **start, off_t offset,
copy_info
(
&
info
,
"Adaptec AIC7xxx driver version: %s
\n
"
,
AIC7XXX_DRIVER_VERSION
);
copy_info
(
&
info
,
"%s
\n
"
,
ahc
->
description
);
ahc_controller_info
(
ahc
,
ahc_info
);
copy_info
(
&
info
,
"%s
\n\n
"
,
ahc_info
);
...
...
drivers/scsi/aic7xxx/aic7xxx_reg.h_shipped
View file @
14686d42
...
...
@@ -3,7 +3,7 @@
* from the following source files:
*
* $Id: //depot/aic7xxx/aic7xxx/aic7xxx.seq#54 $
* $Id: //depot/aic7xxx/aic7xxx/aic7xxx.reg#3
7
$
* $Id: //depot/aic7xxx/aic7xxx/aic7xxx.reg#3
8
$
*/
typedef int (ahc_reg_print_t)(u_int, u_int *, u_int);
typedef struct ahc_reg_parse_entry {
...
...
@@ -1776,7 +1776,7 @@ ahc_reg_print_t ahc_sg_cache_pre_print;
#define SEQ_MAILBOX_SHIFT 0x00
#define TARGET_DATA_IN 0x01
#define HOST_MSG 0xff
#define MAX_OFFSET 0x
f
f
#define MAX_OFFSET 0x
7
f
#define BUS_16_BIT 0x01
#define SCB_UPLOAD_SIZE 0x20
#define STACK_SIZE 0x04
...
...
drivers/scsi/aic7xxx/aic7xxx_reg_print.c_shipped
View file @
14686d42
...
...
@@ -3,7 +3,7 @@
* from the following source files:
*
* $Id: //depot/aic7xxx/aic7xxx/aic7xxx.seq#54 $
* $Id: //depot/aic7xxx/aic7xxx/aic7xxx.reg#3
7
$
* $Id: //depot/aic7xxx/aic7xxx/aic7xxx.reg#3
8
$
*/
#include "aic7xxx_osm.h"
...
...
drivers/scsi/aic7xxx/aic7xxx_seq.h_shipped
View file @
14686d42
...
...
@@ -3,7 +3,7 @@
* from the following source files:
*
* $Id: //depot/aic7xxx/aic7xxx/aic7xxx.seq#54 $
* $Id: //depot/aic7xxx/aic7xxx/aic7xxx.reg#3
7
$
* $Id: //depot/aic7xxx/aic7xxx/aic7xxx.reg#3
8
$
*/
static uint8_t seqprog[] = {
0xb2, 0x00, 0x00, 0x08,
...
...
drivers/scsi/aic7xxx/aicasm/Makefile
View file @
14686d42
...
...
@@ -11,7 +11,7 @@ GENSRCS= $(YSRCS:.y=.c) $(LSRCS:.l=.c)
SRCS
=
${CSRCS}
${GENSRCS}
LIBS
=
-ldb
CLEANFILES
=
${GENSRCS}
${GENHDRS}
$(YSRCS:.y=.output
)
clean-files
:=
${GENSRCS}
${GENHDRS}
$(YSRCS:.y=.output)
$(PROG
)
# Override default kernel CFLAGS. This is a userland app.
AICASM_CFLAGS
:=
-I
/usr/include
-I
.
YFLAGS
=
-d
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment