mirror of
https://github.com/elliotnunn/mac-rom.git
synced 2025-01-04 01:29:22 +00:00
572 lines
25 KiB
Plaintext
572 lines
25 KiB
Plaintext
|
;
|
|||
|
; File: SCSIPriv.a
|
|||
|
;
|
|||
|
; Contains: SCSI Mgr-specific variable and constant definitions
|
|||
|
;
|
|||
|
; Written by: Jerry Katzung
|
|||
|
;
|
|||
|
; Copyright: <09> 1989-1992 by Apple Computer, Inc. All rights reserved.
|
|||
|
;
|
|||
|
; Change History (most recent first):
|
|||
|
;
|
|||
|
; <SM7> 11/20/92 SWC Rolled in changes from Horror.
|
|||
|
; <H4> 6/10/92 BG Added global sdmStack for DB Lite SCSI Disk Mode. Added global
|
|||
|
; for DREQ bit position within DREQ access location. Added tail
|
|||
|
; bytes to SCSIGlobals for expansion and updated file from Reality
|
|||
|
; SCSIPriv.a .
|
|||
|
; <H3> 2/28/92 SWC Removed temporary DBLite equates.
|
|||
|
; <H2> 2/10/92 SWC jab/Added base address storage for external c80 in DB Lite.
|
|||
|
; <SM6> 7/28/92 PW Added Cousin Itt stuff: xptGlobals (ptr) and RecorderPtr (for
|
|||
|
; debugging).
|
|||
|
; <SM5> 7/7/92 CSS Updated from Reality:
|
|||
|
; <17> 5/22/92 DTY #1029009 <jab>: Added global for DREQ bit position within DREQ
|
|||
|
; access location.
|
|||
|
; <SM4> 5/17/92 kc Remove conditionals.
|
|||
|
; <SM3> 5/1/92 JSM Roll-in changes from Reality:
|
|||
|
; <16> 5/1/92 JSM We need to define Max020030BusErrs because it's sometimes wrong
|
|||
|
; to use MaxBusErr since CPU is set to 00 for System builds.
|
|||
|
; <15> 4/7/92 pvh Fill in vectors jvUnused10-jvUnused 16 for the SCSI Manager
|
|||
|
; (these are what were added to HORROR's SCSIPriv.a) Per James
|
|||
|
; Blair.
|
|||
|
; <SM2> 3/3/92 kc Add TransactionFlag, and FreeHookPending to SCSIGlobals.
|
|||
|
; <14> 12/26/91 RB Include PowerPrivEqu.a for Power Manager definitions.
|
|||
|
; <13> 12/21/91 RB Need to add definition for scsiNewSCSIMax for the ROM to build.
|
|||
|
; <12> 11/25/91 DTY Added bit flags for transaction table.
|
|||
|
; <11> 10/28/91 SAM/KSM Rolled in Regatta file.
|
|||
|
; (pdw) Added all of the lo-mem SCSI Globals that were defined in
|
|||
|
; the TERROR version of this file. Also added several others that
|
|||
|
; are unique to the Regatta version of the c96 SCSIMgr.
|
|||
|
; <10> 8/22/91 JSM Clean up header.
|
|||
|
; <9> 6/12/91 LN added #include 'InternalOnlyEqu.a'
|
|||
|
; <8> 1/30/91 gbm sab, #38: Change the <20>already including this file<6C> variable to
|
|||
|
; all uppercase (for security reasons)
|
|||
|
; <7> 12/14/90 dnf Add dispatch selector and macro for _SCSIBusy
|
|||
|
; <6> 9/14/90 MSH Added to conditional list that extends the local storage to
|
|||
|
; accomodate spinning down the hard disk.
|
|||
|
; <4> 2/21/90 CCH Removed Max040BusErrs from conditional.
|
|||
|
; <3> 2/20/90 BG Added 040 BusErr retry constant.
|
|||
|
; <2> 1/18/90 JWK Needed for Zone5 - Added equates for SCSIStat fix and new
|
|||
|
; watchdog timeout value.
|
|||
|
; <1.4> 12/10/89 jwk NEEDED FOR F19 - Additional locals to DMA in old SCSI Mgr
|
|||
|
; <1.3> 9/11/89 jwk NEEDED FOR F19 - Added Bus Dev Rst, support for SE and Plus
|
|||
|
; <1.2> 7/15/89 jwk NEEDED FOR AURORA - Minor changes for intr handling
|
|||
|
; <1.1> 6/29/89 jwk NEEDED FOR AURORA - Added equates to help with System patch
|
|||
|
; builds
|
|||
|
; <1.0> 6/13/89 jwk Reorganizing SCSI sources to be Universal-ROM friendly
|
|||
|
;
|
|||
|
|
|||
|
IF &TYPE('__INCLUDINGSCSIPRIV__') = 'UNDEFINED' THEN
|
|||
|
__INCLUDINGSCSIPRIV__ SET 1
|
|||
|
|
|||
|
; This is the SCSIPriv.a file
|
|||
|
; <start>
|
|||
|
|
|||
|
BLANKS ON
|
|||
|
STRING ASIS
|
|||
|
|
|||
|
INCLUDE 'InternalOnlyEqu.a'
|
|||
|
INCLUDE 'PowerPrivEqu.a' ; <14> rb
|
|||
|
|
|||
|
IF Cpu <20> 020 THEN
|
|||
|
MACHINE MC68020 ; for '020 instructions <C846>
|
|||
|
ENDIF
|
|||
|
|
|||
|
scsiNewSCSIMax EQU 2 ; <13> rb, maximum selector supported in motherboard
|
|||
|
|
|||
|
;
|
|||
|
; Stack frame definitions (frame allocated in StdEntry)
|
|||
|
;
|
|||
|
|
|||
|
OldBusErrVct EQU -4 ; long <C789>
|
|||
|
BusErrCount EQU -6 ; word <C846>
|
|||
|
LocalSize EQU -6 ; total <C789>
|
|||
|
|
|||
|
IF Cpu <20> 020 THEN
|
|||
|
MaxBusErr EQU 5
|
|||
|
ELSE
|
|||
|
MaxBusErr EQU 2
|
|||
|
ENDIF
|
|||
|
|
|||
|
Max020030BusErrs EQU 5 ; same as MaxBusErr when Cpu <20> 020 <16>
|
|||
|
Max040BusErrs EQU 1 ; only once because of Instruction Restart <3><4>
|
|||
|
|
|||
|
;
|
|||
|
; Additional stack frame definitions for SCSI DMA chip support in the old SCSI Mgr <v1.4>
|
|||
|
; <start>
|
|||
|
AddLocalSize EQU 20 ; 5 longs
|
|||
|
vAddr EQU 0 ; virtual address
|
|||
|
vCount EQU 4 ; virtual buffer length
|
|||
|
pAddr EQU 8 ; physical address <end>
|
|||
|
pCount EQU 12 ; physical buffer length <v1.4>
|
|||
|
|
|||
|
;=======================================================================================
|
|||
|
; Private Old SCSI Manager Related Stuff
|
|||
|
|
|||
|
scsiBusy Equ 14 ; SCSIBusy routine selector <7> djw
|
|||
|
|
|||
|
macro ; check if SCSI mgr is busy or free <7> djw
|
|||
|
_SCSIBusy
|
|||
|
move.w #scsiBusy,-(sp)
|
|||
|
_SCSIDispatch
|
|||
|
endm
|
|||
|
|
|||
|
; Bit flags for transaction table
|
|||
|
|
|||
|
fDoFreeHook equ 0 ; set = execute "jSCSIFreeHook"
|
|||
|
fSetTransFlag equ 1 ; set = set "TransactionFlag"
|
|||
|
fClearTransFlag equ 2 ; set = clear "TransactionFlag" unconditionally
|
|||
|
fClearTransErr equ 3 ; set = clear "TransactionFlag" if function error
|
|||
|
|
|||
|
;
|
|||
|
; Trap number for the new SCSI Manager trap
|
|||
|
;
|
|||
|
TrapNum EQU $A089 ; _NewSCSI
|
|||
|
_NewSCSI OPWORD $A089 ; the exciting, powerful, new SCSI Mgr traps
|
|||
|
;
|
|||
|
; These are the private fields in the parameter block
|
|||
|
;
|
|||
|
scsiPrivPB RECORD 0, INCREMENT
|
|||
|
scsiPrivLink DS.L 1 ; link to next SCSI Mgr private record
|
|||
|
scsiFlags DS.B 1 ; SCSI Mgr operation flag bits
|
|||
|
scsiState DS.B 1 ; SCSI Message Out state machine
|
|||
|
scsiFlag1 DS.B 1 ; flag expansion
|
|||
|
scsiFlag2 DS.B 1 ; flag expansion
|
|||
|
scsiTime DS.L 1 ; timeout time
|
|||
|
scsiCmdOffs DS.L 1 ; value of command buffer ptr between interrupts
|
|||
|
scsiTempErr DS.W 1 ; current error message <v1.2>
|
|||
|
scsiFiller DS.W 1 ; future expansion <v1.2>
|
|||
|
scsiDCSaved DS.L 1 ; part of Saved Data Pointer
|
|||
|
scsiDCOffs DS.L 1 ; value of data pointer between interrupts
|
|||
|
scsiMoveOffs DS.L 1 ; partial "dcMove" count between interrupts
|
|||
|
scsiVAddr DS.L 1 ; virtual address for Logical/Physical translation
|
|||
|
scsiVCount DS.L 1 ; virtual count for Logical/Physical translation
|
|||
|
scsiPAddr DS.L 1 ; physical address from Logical/Physical translation
|
|||
|
scsiPCount DS.L 1 ; physical count from Logical/Physical translation
|
|||
|
scsiPrivPBSize EQU *-scsiPrivPB ; size of SCSI Mgr private storage (per active request)
|
|||
|
ENDR
|
|||
|
;
|
|||
|
; Version number of the SCSI Mgr
|
|||
|
;
|
|||
|
mgrVersion EQU 1 ; brand new SCSI Mgr 2
|
|||
|
;
|
|||
|
; Valid ID and LUN values are from 0-7 inclusive.
|
|||
|
;
|
|||
|
LUNMask EQU 7 ; mask for valid logical unit numbers (0-7)
|
|||
|
;
|
|||
|
; SCSI protocol equates
|
|||
|
;
|
|||
|
minSnsLen EQU 4 ; minimum sense buffer length
|
|||
|
allocLen EQU 4 ; offset to alloc length byte in auto Req Sense cmd
|
|||
|
;
|
|||
|
; These bits are used to indicate information in the "state1" global variable
|
|||
|
;
|
|||
|
dtEnqueued EQU 7 ; Deferred Task already enqueued
|
|||
|
dataSem EQU 3 ; SCSI Mgr data structures inconsistent
|
|||
|
doingDMA EQU 1 ; SCSIDMA chip is DMAing (don't let SCSIStat touch it) <2>
|
|||
|
waitingForIRQ EQU 0 ; waiting for an intr - DMA in progress, <v1.3>
|
|||
|
; or waiting for Loss of BSY <v1.3>
|
|||
|
;
|
|||
|
; This constant is used to set up the watchdog timer to timeout after 250ms.
|
|||
|
; This value was chosen as the timeout value since 250ms is much more lenient than
|
|||
|
; the current 16us on the MacII-class machines. It is equal to the Mac SE timeout,
|
|||
|
; and is much greater than the effective 20us timeout of the Mac Plus.
|
|||
|
;
|
|||
|
sc250msTicks EQU 2500000 ; 250ms * 10000 watchdog timer ticks/ms <2>
|
|||
|
;
|
|||
|
; interrupt level of the SCSI chip -- will be moved to HardwareEqu.a (???)
|
|||
|
;
|
|||
|
scsiIntMask EQU $0200 ; on Rom32 machines
|
|||
|
;
|
|||
|
; Currently the watchdog timer goes off every five seconds.
|
|||
|
;
|
|||
|
WDTO EQU 5000 ; watchdog timeout value in milliseconds (word)
|
|||
|
|
|||
|
bDBP EQU 0 ; bit test for *DBP - add to xHardwareEqu.a
|
|||
|
|
|||
|
; Location of Mac Plus SCSIGlobals ptr <v1.1>
|
|||
|
SCSIDispVct EQU $000c54 ; address of _SCSIDispatch vector in trap dispatch table
|
|||
|
SCSIPtr EQU -4 ; offset from _SCSIDispatch code to SCSI Mgr globals ptr
|
|||
|
|
|||
|
;
|
|||
|
; Base addresses for the Mac Plus. The Mac Plus doesn't actually have
|
|||
|
; hardware-handshaking circuitry, but using the pseudo-DMA base address
|
|||
|
; in place of the hhsk base address makes the data transfer code simpler.
|
|||
|
;
|
|||
|
plusSCSIBase EQU $580000 ; read base address of Mac Plus SCSI chip <v1.2>
|
|||
|
plusSCSIDMA EQU $580200 ; pseudo-DMA read base address of Mac Plus SCSI chip <v1.2>
|
|||
|
plusSCSIHsk EQU $580200 ; fake "hardware-handshake" read base address <v1.2>
|
|||
|
|
|||
|
macPlusSCSIDB EQU $00db ; trial-and-error value for Mac Plus <v1.2><v1.3>
|
|||
|
macSeSCSIDB EQU $00fc ; trial-and-error value for Mac SE <v1.2><v1.3>
|
|||
|
|
|||
|
OldTimeSCSIDB EQU $da6 ; SCSI DBRA's per millisecond on all machines
|
|||
|
|
|||
|
scsiOldSCSIErr EQU -1 ; old SCSI Mgr called ClearState <v1.2>
|
|||
|
|
|||
|
;
|
|||
|
; SCSI Mgr flags:
|
|||
|
;
|
|||
|
scsiFInUse EQU $01 ; SCSI Mgr private storage record is in use
|
|||
|
scsiFAutoSns EQU $02 ; parameter block for automatic Request Sense
|
|||
|
scsiFComp EQU $10 ; Perform a read-compare (old requests only)
|
|||
|
scsiFStatus EQU $20 ; Device has gone through Status phase
|
|||
|
scsiFPtyErr EQU $40 ; a parity error has occurred
|
|||
|
scsiFTagged EQU $80 ; request is in danger of timing out
|
|||
|
; SCSI Mgr bits:
|
|||
|
scsiBInUse EQU 0 ; SCSI Mgr private storage record is in use
|
|||
|
scsiBAutoSns EQU 1 ; parameter block for automatic Request Sense
|
|||
|
scsiBComp EQU 4 ; Perform a read-compare (old requests only)
|
|||
|
scsiBStatus EQU 5 ; Device has gone through Status phase
|
|||
|
scsiBPtyErr EQU 6 ; a parity error has occurred
|
|||
|
scsiBTagged EQU 7 ; request is in danger of timing out
|
|||
|
;
|
|||
|
; Message Out state machine state variable values
|
|||
|
;
|
|||
|
scsiMOID EQU $00 ; "ID" state - normal Identify sequence
|
|||
|
scsiMOMR EQU $01 ; "MR" state - Message Reject sequence
|
|||
|
scsiMOInvalid EQU $02 ; "Invalid" state - bad state machine sequence
|
|||
|
scsiMOKIO EQU $03 ; "KIO" state - Kill I/O sequence
|
|||
|
scsiMONOP EQU $04 ; "NOP" state - unexpected Message Out, send No Op's
|
|||
|
scsiMOBDR EQU $05 ; "Bus Device Reset" state - send a BDR message <v1.3>
|
|||
|
|
|||
|
;
|
|||
|
; Messages - used as an index into a jump table of message-handler routines
|
|||
|
;
|
|||
|
scsiCmdComplete EQU $00 ; Command Complete
|
|||
|
scsiExtendedMsg EQU $01 ; Extended Message
|
|||
|
scsiSaveDataPtr EQU $02 ; Save Data Pointer
|
|||
|
scsiRestorePtrs EQU $03 ; Restore Pointers
|
|||
|
scsiDisconnect EQU $04 ; Disconnect
|
|||
|
scsiIDetectErr EQU $05 ; Initiator Detected Error
|
|||
|
scsiAbort EQU $06 ; Abort
|
|||
|
scsiMsgReject EQU $07 ; Message Reject
|
|||
|
scsiNoOperation EQU $08 ; No Operation
|
|||
|
scsiMsgParityErr EQU $09 ; Message Parity Error
|
|||
|
scsiLnkCmdCpl EQU $0A ; Linked Command Complete
|
|||
|
scsiLnkCmdCplFlg EQU $0B ; Linked Command Complete (with flag)
|
|||
|
scsiBusDevReset EQU $0C ; Bus Device Reset
|
|||
|
scsiIdentFlg EQU $80 ; Identify flag
|
|||
|
scsiIdentBit EQU 7 ; Identify bit
|
|||
|
scsiReselFlg EQU $40 ; "Initiator supports Reselection" flag
|
|||
|
scsiReselBit EQU 6 ; "Initiator supports Reselection" bit
|
|||
|
scsiIdentifyIn EQU $0D ; vector number for Identify message (pseudo-message)
|
|||
|
scsiMsgRejectOut EQU $0E ; vector number for an invalid message (pseudo-message)
|
|||
|
|
|||
|
;
|
|||
|
; declaration of SCSI Manager globals
|
|||
|
;
|
|||
|
scsiGlobalRecord RECORD 0, INCREMENT
|
|||
|
;
|
|||
|
; SCSI Manager "G_State" flags
|
|||
|
;
|
|||
|
;sBusy EQU 1 ; used for G_State field -- SCSI Mgr is busy (non-zero)
|
|||
|
;sFree EQU 0 ; used for G_State field -- SCSI Mgr is free
|
|||
|
scPending EQU 7 ; bit in G_State -- an old request is spinning in SCSIGet
|
|||
|
scBusy EQU 0 ; bit in G_State -- an old request is pending/in progress
|
|||
|
;
|
|||
|
; old SCSI Manager globals
|
|||
|
;
|
|||
|
numVectors EQU 24 ; 24 4-byte jump table vectors
|
|||
|
numSCSIVect EQU numVectors ; number of SCSI Mgr vectors
|
|||
|
jmpTblSize EQU numVectors*4 ; 24 4-byte jump table vectors
|
|||
|
G_JmpTbl ; 24 4-byte jump table vectors
|
|||
|
jvReset DS.L 1 ; SCSIReset vector
|
|||
|
jvGet DS.L 1 ; SCSIGet vector
|
|||
|
jvSelect DS.L 1 ; SCSISelect vector
|
|||
|
jvCmd DS.L 1 ; SCSICmd vector
|
|||
|
jvComplete DS.L 1 ; SCSIComplete vector
|
|||
|
jvRead DS.L 1 ; SCSIRead vector
|
|||
|
jvWrite DS.L 1 ; SCSIWrite vector
|
|||
|
jvInstall DS.L 1 ; SCSI installation vector (for debugging purposes)
|
|||
|
jvRBlind DS.L 1 ; SCSIRBlind vector
|
|||
|
jvWBlind DS.L 1 ; SCSIWBlind vector
|
|||
|
jvStat DS.L 1 ; SCSIStat vector
|
|||
|
jvSelAtn DS.L 1 ; SCSISelAtn vector
|
|||
|
jvSMsgIn DS.L 1 ; SCSIMsgIn vector
|
|||
|
jvSMsgOut DS.L 1 ; SCSIMsgOut vector
|
|||
|
;
|
|||
|
firstPrivate DS.L 1 ; ptr to SCSI Mgr private storage record circularly linked list
|
|||
|
nextPrivate DS.L 1 ; ptr to next available SCSI Mgr private storage record
|
|||
|
base5380 DS.L 1 ; SCSI read base address
|
|||
|
pdma5380 DS.L 1 ; SCSI pseudo-DMA read base addr
|
|||
|
hhsk5380 DS.L 1 ; SCSI hardware-handshaked read base addr
|
|||
|
wrOffset DS.W 1 ; write offset relative to "base5380"
|
|||
|
scsiQHdr ; 10-byte OS queue header - SCSI request queue
|
|||
|
scsiQFlags DS.W 1 ; flags for SCSI request queue
|
|||
|
scsiQHead DS.L 1 ; ptr to head of SCSI request queue
|
|||
|
scsiQTail DS.L 1 ; ptr to tail of SCSI request queue
|
|||
|
activeReq DS.L 1 ; ptr to currently active SCSI request
|
|||
|
timeout DS.L 1 ; next timeout should occur at this time
|
|||
|
;
|
|||
|
G_ID DS.B 1 ; initiator's SCSI ID mask
|
|||
|
G_State DS.B 1 ; SCSI Mgr state (free/busy)
|
|||
|
G_Async DS.W 1 ; unused - $62
|
|||
|
;G_CompTicks ; when request finished (unpatched SE only) <v1.1>
|
|||
|
G_Reserved0 DS.L 1 ; box number in high byte. HW flags in low bytes <v1.1>
|
|||
|
pageFault ; ptr to page fault SCSI PB <v1.1>
|
|||
|
G_Reserved1 DS.L 1 ; used for storing timer value <?> pdw
|
|||
|
G_Reserved2 DS.L 1 ; machine-specific storage <v1.1>
|
|||
|
RecorderPtr DS.L 1 ; debugging event recorder pointer $70 <SM6> pdw
|
|||
|
;G_ExtPtr DS.L 1 ; unused (saved for future expansion)
|
|||
|
;
|
|||
|
; extended SCSI manager globals
|
|||
|
;
|
|||
|
numExtVec EQU 96 ; 96 new vectors
|
|||
|
discLUN DS.B 8 ; bitmaps of disconnected LUN's by SCSI ID
|
|||
|
discID DS.B 1 ; bitmap of disconnected SCSI ID's
|
|||
|
state1 DS.B 1 ; dTask enqueued, data structures inconsistent, DMA in progress
|
|||
|
state2 DS.B 1 ; SCSI Mgr interface level
|
|||
|
state3 DS.B 1 ; SCSI DMA ?
|
|||
|
busTO DS.L 1 ; byte-to-byte timing in microseconds
|
|||
|
phaseTable ; 8-entry jump table for phase handler routines
|
|||
|
jvDataOut DS.L 1 ; Data Out phase handler
|
|||
|
jvDataIn DS.L 1 ; Data In phase handler
|
|||
|
jvCommand DS.L 1 ; Command phase handler
|
|||
|
jvStatus DS.L 1 ; Status phase handler
|
|||
|
jvIllegal1 DS.L 1 ; Illegal phase - reset the bus
|
|||
|
jvIllegal2 DS.L 1 ; Illegal phase - reset the bus
|
|||
|
jvMsgOut DS.L 1 ; Message Out phase handler
|
|||
|
jvMsgIn DS.L 1 ; Message In phase handler
|
|||
|
dataTable ; 16-entry jump table for data-transfer routines
|
|||
|
jvVSR DS.L 1 ; virtual slow reads
|
|||
|
jvVSW DS.L 1 ; virtual slow writes
|
|||
|
jvVFR DS.L 1 ; virtual fast reads
|
|||
|
jvVFW DS.L 1 ; virtual fast writes
|
|||
|
jvUnused1 DS.L 1 ; unused (illegal)
|
|||
|
jvUnused2 DS.L 1 ; unused (illegal)
|
|||
|
jvPFR DS.L 1 ; physical fast reads (DMA)
|
|||
|
jvPFW DS.L 1 ; physical fast writes (DMA)
|
|||
|
jvVSRO DS.L 1 ; virtual slow reads
|
|||
|
jvVSWO DS.L 1 ; virtual slow writes
|
|||
|
jvVFRO DS.L 1 ; virtual fast reads (hhsk)
|
|||
|
jvVFWO DS.L 1 ; virtual fast writes (hhsk)
|
|||
|
jvCSO DS.L 1 ; virtual slow compare ("p" bit redefined to mean "compare")
|
|||
|
jvUnused3 DS.L 1 ; unused
|
|||
|
jvCFO DS.L 1 ; virtual fast compare ("p" bit redefined to mean "compare")
|
|||
|
jvUnused4 DS.L 1 ; unused
|
|||
|
scsiReadSlow EQU jvVSRO - jvVSR ; offset to old slow read routine <v1.2>
|
|||
|
scsiWriteSlow EQU jvVSWO - jvVSR ; offset to old slow write routine <v1.2>
|
|||
|
scsiReadFast EQU jvVFRO - jvVSR ; offset to old slow read routine <v1.2>
|
|||
|
scsiWriteFast EQU jvVFWO - jvVSR ; offset to old slow write routine <v1.2>
|
|||
|
scsiCompBit EQU scsiBPhysical ; bit to select old SCSI Mgr "scComp" operation
|
|||
|
;
|
|||
|
msgTable ; 32-entry jump table for different messages
|
|||
|
jvInvalidIn DS.L 1 ; Invalid Message In
|
|||
|
jvIdentifyIn DS.L 1 ; Identify Message In
|
|||
|
jvCmdComplete DS.L 1 ; Command Complete
|
|||
|
jvExtendedMsg DS.L 1 ; Extended Message
|
|||
|
jvSaveDataPtr DS.L 1 ; Save Data Pointer
|
|||
|
jvRestorePtrs DS.L 1 ; Restore Pointers
|
|||
|
jvDisconnect DS.L 1 ; Disconnect
|
|||
|
jvMsgRejIn DS.L 1 ; Message Reject In
|
|||
|
jvLCCF DS.L 1 ; Linked Command Complete with (or without) flag
|
|||
|
|
|||
|
; Base addresses for dual c80 SCSI Bus
|
|||
|
sdmStack DS.L 1 ; SCSIDiskMode stack global for DB Lite <H5> jab
|
|||
|
base5380_1 DS.L 1 ; SCSI read base address (internal) <H2>
|
|||
|
pdma5380_1 DS.L 1 ; SCSI pseudo-DMA read base addr (internal) <H2>
|
|||
|
hhsk5380_1 DS.L 1 ; SCSI hardware-handshaked read base addr (internal)<H2>
|
|||
|
base5380_2 DS.L 1 ; SCSI read base address (external) <H2>
|
|||
|
pdma5380_2 DS.L 1 ; SCSI pseudo-DMA read base addr (external) <H2>
|
|||
|
hhsk5380_2 DS.L 1 ; SCSI hardware-handshaked read base addr (external)<H2>
|
|||
|
|
|||
|
jvIdentifyOut DS.L 1 ; Identify Message Out
|
|||
|
jvMsgRejOut DS.L 1 ; Message Reject Out
|
|||
|
jvInvalidOut DS.L 1 ; Invalid Message Out
|
|||
|
jvKillIO DS.L 1 ; Kill I/O
|
|||
|
jvNoOp DS.L 1 ; No Operation
|
|||
|
jvBusDevRstOut DS.L 1 ; Bus Device Reset Out <v1.3>
|
|||
|
|
|||
|
; SUPPORT FOR 5396 (13C bytes from the base) <T3>
|
|||
|
; (These used to be jvUnused23-30) <T3>
|
|||
|
G_SCSIDREQ DS.L 1 ; SCSI DREQ base address <T3><T4>
|
|||
|
G_TargetID DS.L 1 ; Target ID <T3>
|
|||
|
G_FakeStat DS.L 1 ; Fake state <T3>
|
|||
|
G_OldTrapAdrs DS.L 1 ; contains the old SCSIMgr address <T3>
|
|||
|
G_OldIntHnd DS.L 1 ; contains old intrp level 2 handler <T3>
|
|||
|
G_IntrpCount DS.L 1 ; counts total # of intrps <T3>
|
|||
|
G_IntrpStat DS.L 1 ; Status read by Intrp routine <T3>
|
|||
|
G_State96 DS.L 1 ; Bits to make c96 backwards compatible <T10> pdw
|
|||
|
|
|||
|
BootCfgFlags DS.L 1 ; copy of d2 passed to InitHW_SCSI96 at boot (used by jvInitHW) <T10> pdw
|
|||
|
G_bitDREQ DS.B 1 ; Bit position at DREQ location <17> jab
|
|||
|
jvUnused32 DS.B 1 ; Future expansion <17> jab
|
|||
|
jvUnused33 DS.W 1 ; Future expansion <17> jab
|
|||
|
; <?> from prev <?>
|
|||
|
jvIntHnd DS.L 1 ; 24-entry jump table -- interrupt handler
|
|||
|
jvMessage DS.L 1 ; Send a message to the deferred task
|
|||
|
jvClearIRQ DS.L 1 ; Clear the SCSI interrupt (and VIA, if necessary)
|
|||
|
jvDisEnable DS.L 1 ; Enable/disable interrupts routine
|
|||
|
jvLogError DS.L 1 ; Record error for the PB <v1.2>
|
|||
|
jvSCSIDT DS.L 1 ; Deferred Task for all other interrupts
|
|||
|
jvFind DS.L 1 ; Find a request to process
|
|||
|
jvSetup DS.L 1 ; Setup active request
|
|||
|
jvPreflight DS.L 1 ; Preflight the parameter block
|
|||
|
jvEnDequeue DS.L 1 ; Enqueue/dequeue a parameter block
|
|||
|
jvArb DS.L 1 ; Arbitrate for the SCSI bus
|
|||
|
jvSel DS.L 1 ; Select a SCSI device
|
|||
|
jvDelay22 DS.L 1 ; Delay 2.2 microseconds
|
|||
|
jvClearState DS.L 1 ; Remove the current request
|
|||
|
jvTransfer DS.L 1 ; Transfer data using the primitive routines
|
|||
|
jvSetTimer DS.L 1 ; Set the timer
|
|||
|
jvResetBus DS.L 1 ; Reset SCSI bus and kill all requests
|
|||
|
jvClearBus DS.L 1 ; Clear the SCSI bus
|
|||
|
jvBusErr DS.L 1 ; Bus error handler
|
|||
|
jvDataDMA DS.L 1 ; DMA-related data-chaining interpreter <v1.2>
|
|||
|
xptGlobals DS.L 1 ; pointer to Cousin Itt's XPT globals $1b4 <SM6> pdw
|
|||
|
; <?> thru next <?>
|
|||
|
; More Space for the new SCSI96 Manager(1B8 bytes from the base) <T3>
|
|||
|
; (these used to be jvUnused 47-53) <T3>
|
|||
|
blindBusTO DS.L 1 ; number of ticks to wait for blind transfer bytes (after 1st byte)
|
|||
|
transferType DS.W 1 ; Type of data transfer to perform (used in Transfer_96, BusError)
|
|||
|
lastINTread DS.B 1 ; Value of rINT at last valid interrupt read
|
|||
|
lastSTAread DS.B 1 ; Value of rSTA at last valid interrupt read
|
|||
|
yeOldeBusErrVct DS.L 1 ; temp storage while we insert our buserr handler <T10> pdw
|
|||
|
base539x0 DS.L 1 ; SCSI 539x base address, bus0 <T3><T4>
|
|||
|
base539x1 DS.L 1 ; SCSI 539x base address, bus1 <T3><T4>
|
|||
|
G_SCSIDevMap0 DS.L 1 ; SCSI Device Map for the Internal SCSI Bus <T3>
|
|||
|
G_SCSIDevMap1 DS.L 1 ; SCSI Device Map for the External SCSI Bus <T3>
|
|||
|
|
|||
|
jvErr DS.L 1 ; SCSI96 Error, used to be jUnused 54 <T6> <T6>
|
|||
|
jvEscLoop DS.L 1 ; SCSI Escape Loop Vector <T7>
|
|||
|
jvCyclePhase DS.L 1 ; Bitbuckets or fills bytes to get target to Status phase (was jvUnused49)
|
|||
|
jvInitSCSIHW DS.L 1 ; init SCSI chip (was jvUnused57) <T10> pdw
|
|||
|
; <?> from prev <?>
|
|||
|
;
|
|||
|
newSCSIDisp
|
|||
|
jvSCSIRequestIO DS.L 1 ; SCSIRequestIO
|
|||
|
jvSCSIKillIO DS.L 1 ; SCSIKillIO
|
|||
|
jvSCSIBusInfo DS.L 1 ; SCSIBusInfo
|
|||
|
|
|||
|
newSCSI96Disp ; used to be jvUnused63-jvUnused66 <?> thru next <?>
|
|||
|
jvSCSIBusy DS.L 1 ; SCSIBusy vector, selector 14
|
|||
|
jvSel15 DS.L 1 ; SCSI vector for selector 15
|
|||
|
jvSel16 DS.L 1 ; SCSI vector for selector 16
|
|||
|
jvSel17 DS.L 1 ; SCSI vector for selector 17
|
|||
|
jvAltBusCall DS.L 1 ; Call to alternate SCSI bus <?> from prev <?>
|
|||
|
;
|
|||
|
numMsgVct EQU 36 ; number of message routing vectors
|
|||
|
msgInTbl DS.B numMsgVct ; dispatch table for Messages 00H-23H (Msg In)
|
|||
|
msgOutTbl DS.B numMsgVct ; dispatch table for Messages 00H-23H (Msg Out)
|
|||
|
;
|
|||
|
dtQElSize EQU 20 ; temporary
|
|||
|
dTask DS.B dtQElSize ; Deferred Task Mgr task record
|
|||
|
;
|
|||
|
tmQSize EQU 14 ; Time Mgr task record size
|
|||
|
timer DS.B tmQSize ; Time Mgr task record for request timing
|
|||
|
;
|
|||
|
RSCmd DS.B 6 ; Request Sense command buffer
|
|||
|
RSDC DS.L 12 ; data-chaining block for Request Sense command
|
|||
|
;
|
|||
|
dummy DS scsiPB ; dummy parameter block
|
|||
|
;
|
|||
|
dummyPriv DS scsiPrivPB ; dummy private storage
|
|||
|
faultPriv DS scsiPrivPB ; private storage for page-fault handling
|
|||
|
firstPriv DS scsiPrivPB ; private storage for request processing
|
|||
|
DS scsiPrivPB ; private storage for request processing
|
|||
|
DS scsiPrivPB ; private storage for request processing
|
|||
|
DS scsiPrivPB ; private storage (machine-specific storage follows)
|
|||
|
TransactionFlag DS.L 1 ; location to store SCSI transaction flag <2> kc
|
|||
|
FreeHookPending DS.L 1 ; location of pending free-hook flag <2> kc
|
|||
|
|
|||
|
GlobalSize EQU *-scsiGlobalRecord ; size of SCSI Mgr globals
|
|||
|
ENDR
|
|||
|
|
|||
|
;
|
|||
|
; Machine-specific structure
|
|||
|
;
|
|||
|
machSpecRecord RECORD 0, INCREMENT
|
|||
|
|
|||
|
IF tmQSize > SleepqRec.SleepqSize THEN ; use the larger of the two data structures <14> rb
|
|||
|
sleep ; 12-byte sleep queue element (onHcMac) OR
|
|||
|
timer2 DS.B tmQSize ; 14-byte intr polling timer (onMac) <v1.1>
|
|||
|
ELSE
|
|||
|
sleep ; 12-byte sleep queue element (onHcMac) OR
|
|||
|
timer2 DS.B SleepqSize ; 14-byte intr polling timer (onMac) <v1.1>
|
|||
|
ENDIF
|
|||
|
machSpecSize EQU *-machSpecRecord ; size of machine-specific record
|
|||
|
ENDR
|
|||
|
|
|||
|
;
|
|||
|
; Find selector (passed in d0.l)
|
|||
|
;
|
|||
|
findAny EQU -1 ; find first non-disconnected request
|
|||
|
findAnyFlag EQU 31 ; find first non-disconnected request flag (bit 31)
|
|||
|
|
|||
|
;
|
|||
|
; EnDequeue selector (passed in d0.l)
|
|||
|
;
|
|||
|
enqNormal EQU -1 ; enqueue at end of queue
|
|||
|
enqFront EQU -2 ; enqueue at front of queue ("immediate" function, page fault)
|
|||
|
deqNormal EQU 1 ; dequeue one request (linked commands are elevated)
|
|||
|
deqLinked EQU 2 ; remove a series of linked commands (to cleanly kill linked cmds)
|
|||
|
enqueueFlag EQU 31 ; enqueue/dequeue selection flag (bit 31)
|
|||
|
|
|||
|
;
|
|||
|
; Masks for the interrupt handler. They are used to determine the interrupt type.
|
|||
|
; These masks are the concatenation of the Bus and Status Register with the
|
|||
|
; Current SCSI Bus Status Register. The BSR is the most-significant byte.
|
|||
|
;
|
|||
|
mReselect EQU $F5E2 ; mask to clear don't cares for Reselect interrupt
|
|||
|
iReselect EQU $1002 ; bit image for a Reselect intr. with don't care bits reset
|
|||
|
scResel EQU 7 ; bit in "dtParm" for Reselect interrupts
|
|||
|
mEOP EQU $F6C2 ; mask to clear don't cares for EOP intr (PM is don't care) <v1.2>
|
|||
|
iEOP EQU $9040 ; bit image for EOP intr. with don't care bits cleared
|
|||
|
scEOP EQU 6 ; bit in "dtParm" for Reselect interrupts
|
|||
|
mPhaseMm EQU $BDE2 ; mask to clear don't cares for Phase Mismatch Error intr.
|
|||
|
iPhaseMm EQU $1060 ; bit image for Phase Mismatch Error without don't care's
|
|||
|
scPhaseMm EQU 5 ; bit in "dtParm" for Reselect interrupts
|
|||
|
mLossBsy EQU $F7FF ; mask to clear don't cares for Loss of BSY interrupts
|
|||
|
iLossBsy EQU $1400 ; bit image for Loss of BSY intr. without don't care's
|
|||
|
scLossBsy EQU 4 ; bit in "dtParm" for Reselect interrupts
|
|||
|
mBusReset EQU $F77F ; mask to clear don't cares for SCSI Bus Reset interrupt
|
|||
|
iBusReset EQU $1000 ; bit image for SCSI Bus Reset intr. with don't care's reset
|
|||
|
scBusReset EQU 3 ; bit in "dtParm" for Reselect interrupts
|
|||
|
mParity EQU $BCC2 ; mask to clear don't cares for Parity Error interrupt
|
|||
|
iParity EQU $3840 ; bit image for Parity Error intr. with don't care's reset
|
|||
|
scParity EQU 2 ; bit in "dtParm" for Reselect interrupts
|
|||
|
scNewRequest EQU 1 ; bit in "dtParm" indicating a new request to process
|
|||
|
|
|||
|
;
|
|||
|
; Register saving convention
|
|||
|
;
|
|||
|
scsiRegs REG a0-a5/d1-d7 ; standard register saving convention (result in d0)
|
|||
|
intrRegs REG a0-a5/d0-d7 ; interrupt handler register saving convention
|
|||
|
zeroReg EQU d7 ; quick source of zeroes (CLR won't work on SCSI chip)
|
|||
|
|
|||
|
;
|
|||
|
; Old SCSI Mgr equates -- temporary, since SCSIEqu.a has the public portion of the PB
|
|||
|
;
|
|||
|
|
|||
|
maxOpcode EQU 8 ; highest numbered TIB opcode (from PatchIIROM.a)
|
|||
|
|
|||
|
; <v1.6>
|
|||
|
; <end>
|
|||
|
;
|
|||
|
; Here we redefined the Universal ROM's hardware feature bits to serve our own twisted
|
|||
|
; purposes. If we're building for a System Disk, then these bits in the "G_Reserved0"
|
|||
|
; variable in the globals reflect the low memory data structures defined for the ROM's. <v1.1>
|
|||
|
; <start>
|
|||
|
; NOTE that these are also defined in SCSIMgrFlags.a, so if you change 'em here....
|
|||
|
;
|
|||
|
sHWCbPwrMgr equ 0 ; see if we have a Power Mgr
|
|||
|
sOSSExists equ 1 ; do we have an OSS ?
|
|||
|
sRBVExists equ 2 ; do we have an RBV ?
|
|||
|
sVIA2Exists equ 3 ; do we have a second VIA ?
|
|||
|
sSCSIDMAExists equ 4 ; do we have a SCSI DMA chip ?
|
|||
|
isMacPlus equ 5 ; are we on a Mac Plus ?
|
|||
|
is68000 equ 6 ; are we on a 68000 ? <v1.1>
|
|||
|
sDeferUserFn equ 7 ; is _DeferUserFn defined ? <end>
|
|||
|
;sSCSI96_1 equ 8 ; do we have 1st SCSI96 chip <T3>
|
|||
|
;sSCSI96_2 equ 9 ; do we have 2nd SCSI96 chip? <T3>
|
|||
|
;sSCSI96_1 equ 8 ; do we have 1st SCSI96 chip <T3>
|
|||
|
;sSCSI96_2 equ 9 ; do we have 2nd SCSI96 chip? <T3>
|
|||
|
|
|||
|
|
|||
|
numSelectorsDB equ 2 ; we only patch three SCSI Mgr routines <H2>
|
|||
|
|
|||
|
cTargSetup equ $40 ; setup target mode for DBLite's dual bus DiskMode <H2>
|
|||
|
|
|||
|
|
|||
|
ENDIF ; ...already included
|