mirror of
https://github.com/elliotnunn/mac-rom.git
synced 2025-01-05 08:30:14 +00:00
275 lines
11 KiB
Plaintext
275 lines
11 KiB
Plaintext
|
;==========================================================================
|
|||
|
;
|
|||
|
; File: SCSIEqu53c96.a
|
|||
|
;
|
|||
|
; Contains: Equates for dealing with the SCSI 53c96 chip
|
|||
|
;
|
|||
|
; Written by: Jonathan Abilay/Paul Wolf
|
|||
|
;
|
|||
|
; Copyright: <09> 1990-1993 by Apple Computer, Inc., all rights reserved.
|
|||
|
;
|
|||
|
; Change History (most recent first):
|
|||
|
;
|
|||
|
; <SM16> 10/14/93 pdw <MC> roll-in.
|
|||
|
; <MC3> 10/12/93 pdw Added support for Synchronous data transfers, rewrote State
|
|||
|
; Machine, message handling etc.
|
|||
|
; <MC2> 9/16/93 pdw Tailoring the Select timeout values for 20 and 40MHz clock
|
|||
|
; speeds to about 200mS instead of 250mS to see if anybody
|
|||
|
; complains.
|
|||
|
; <SM15> 9/9/93 pdw Lots of little changes. Name changes, temporary cache_bug
|
|||
|
; stuff.
|
|||
|
; <SM14> 7/17/93 pdw Changed tc bit to bTermCnt (I think).
|
|||
|
; <SM13> 6/29/93 pdw Massive checkins: Change asynchronicity mechanism to CallMachine
|
|||
|
; stack switching mechanism. Adding support for Cold Fusion.
|
|||
|
; Rearranging HW/SW Init code. Some code optimizations.
|
|||
|
; <SM12> 5/25/93 DCB Rollin from Ludwig. (The next item below)
|
|||
|
; <LW5> 5/21/93 PW Adding target mode commands so that we can respond to a select
|
|||
|
; without toasting the bus.
|
|||
|
; <SM11> 5/5/93 PW Converted names to meanies-friendly names. Updated with latest
|
|||
|
; from Ludwig stuff.
|
|||
|
; <LW3> 3/26/93 PW Removed initCFx values.
|
|||
|
; <SM9> 1/31/93 PW Update from the latest of Ludwig. Also changes required for PDM
|
|||
|
; (will update Ludwig with these as needed myself).
|
|||
|
; <LW2> 1/27/93 PW Once again, added mSCSIRstRptIntDis to CF1.
|
|||
|
; <SM8> 12/5/92 PW Got rid of confusing and worthless iDcBsxx stuff.
|
|||
|
; <SM7> 11/17/92 DCB Changed initCF1: added mSCSIRstRptIntDis to disable interrupt on
|
|||
|
; reset until we figure out what's going on.
|
|||
|
; <SM6> 11/12/92 PW Rearranged a bit more logically and put 'm's in front of masks
|
|||
|
; and added some more stuff. Removed parityEnable.
|
|||
|
; <SM5> 10/30/92 DCB Changed some flags for to support changes to the interrupt
|
|||
|
; handling routines
|
|||
|
; <SM4> 10/8/92 PW Added bit definitions for status register.
|
|||
|
; <SM3> 8/31/92 PW Added vowels. Changed FFO to FIFO, Flsh to Flush, Rst to Reset,
|
|||
|
; S to SCSI, Chp to Chip, Acep to Accept, rFOS to rFIFOflags.
|
|||
|
; <SM2> 8/30/92 PW Added cDMASelWAtn3 and cSelWAtn3 commands to equates.
|
|||
|
; <SM1> - PW Initial check-in.
|
|||
|
;
|
|||
|
;==========================================================================
|
|||
|
|
|||
|
IF &TYPE('__INCLUDING_SCSIEqu53c96__') = 'UNDEFINED' THEN
|
|||
|
__INCLUDING_SCSIEqu53c96__ SET 1
|
|||
|
|
|||
|
|
|||
|
;---------------------------------------------------
|
|||
|
; SCSI 53C96 Command Set
|
|||
|
;---------------------------------------------------
|
|||
|
;Note:
|
|||
|
; for NON-DMA mode, bit7=0. DMA mode command bytes have bit7=1.
|
|||
|
|
|||
|
cNOP EQU $00 ; NOP command
|
|||
|
cFlushFIFO EQU $01 ; flush FIFO command <SM3> pdw
|
|||
|
cResetChip EQU $02 ; reset SCSI chip <SM3> pdw
|
|||
|
cResetSCSIBus EQU $03 ; reset SCSI bus <SM3> pdw
|
|||
|
|
|||
|
cIOXfer EQU $10 ; non-DMA Transfer command
|
|||
|
cCmdComplete EQU $11 ; Initiator Command Complete Sequence <SM3> pdw
|
|||
|
cMsgAccept EQU $12 ; Message Accepted <SM3> pdw
|
|||
|
|
|||
|
cSendMsg EQU $20 ; Send Message byte(s)
|
|||
|
cSendStatus EQU $21 ; Send status byte
|
|||
|
cSendData EQU $22 ; Send data byte(s)
|
|||
|
cDisconnectSeq EQU $23 ; Send 2 msg bytes and disconnect
|
|||
|
cTerminateSeq EQU $24 ; Send status byte, message byte then disconnect
|
|||
|
cTgtCmdComplete EQU $25 ; Send status byte, message byte DON'T disconnect
|
|||
|
cDisconnect EQU $27 ; Disconnect (drop busy)
|
|||
|
cRcvMsgSeq EQU $28 ; Receive Message byte(s)
|
|||
|
cRcvCmd EQU $29 ; Receive command byte(s) (specified count)
|
|||
|
cRcvData EQU $2a ; Receive data byte(s)
|
|||
|
cRcvCmdSeq EQU $29 ; Receive command byte(s) (decoded count)
|
|||
|
cStopDMA EQU $04 ; stop DMA
|
|||
|
|
|||
|
cSelWOAtn EQU $41 ; Select Without ATN Sequence
|
|||
|
cSelWAtn EQU $42 ; Select With ATN Sequence
|
|||
|
cSelWAtnStop EQU $43 ; Select With ATN and Stop Sequence <SM3> pdw
|
|||
|
cSelWAtn3 EQU $46 ; Select With ATN 3 (msg_out bytes) Sequence <SM2> pdw
|
|||
|
|
|||
|
cEnableR_sel EQU $44 ; Enable (re)selection
|
|||
|
|
|||
|
cSetAtn EQU $1A ; Set ATN command
|
|||
|
cRstAtn EQU $1B ; Reset ATN command
|
|||
|
|
|||
|
cDMAXfer EQU $90 ; DMA Transfer command
|
|||
|
cDMASelWOAtn EQU $C1 ; Select Without ATN Sequence, use DMA
|
|||
|
cDMASelWAtn EQU $C2 ; Select With ATN Sequence, use DMA
|
|||
|
cDMASelWAtnStop EQU $C3 ; Select With ATN and Stop Sequence <SM3> pdw
|
|||
|
cDMASelWAtn3 EQU $C6 ; Select With ATN 3 (msg_out bytes) Sequence <SM2> pdw
|
|||
|
|
|||
|
|
|||
|
;---------------------------------------------------
|
|||
|
; SCSI 53C96 Register Defs, Offsets
|
|||
|
;---------------------------------------------------
|
|||
|
|
|||
|
nonSerlzdDisp EQU $040000 ; disp. between serlzd and non-serlzd I/O images
|
|||
|
|
|||
|
rXCL EQU $00 ; Transfer count bits 0-7 (r/w)
|
|||
|
rXCM EQU $10 ; Transfer count bits 8-15 (r/w)
|
|||
|
rFIFO EQU $20 ; FIFO (r/w)
|
|||
|
rCMD EQU $30 ; Command (r/w)
|
|||
|
rCF1 EQU $80 ; Configuration 1 (w)
|
|||
|
rCF2 EQU $B0 ; Configuration 2 (w)
|
|||
|
rCF3 EQU $C0 ; Configuration 3 (w)
|
|||
|
|
|||
|
rSTA EQU $40 ; Status (r)
|
|||
|
rINT EQU $50 ; Interrupt (r)
|
|||
|
rSQS EQU $60 ; Sequence Step (r)
|
|||
|
rFIFOflags EQU $70 ; FIFO Flags/Sequence Step (r)
|
|||
|
|
|||
|
rDID EQU $40 ; Destination Bus ID (w)
|
|||
|
rSTO EQU $50 ; Select/Reselect Timeout (w)
|
|||
|
rSyncPeriod EQU $60 ; Synchronous Period (w)
|
|||
|
rSyncOffset EQU $70 ; Synchronous Offset (w)
|
|||
|
rCKF EQU $90 ; Clock Conversion Factor (w)
|
|||
|
rTST EQU $A0 ; Test (w)
|
|||
|
rXCH EQU $E0 ; Transfer count bits 16-24 (r/w)
|
|||
|
rChipID EQU rXCH ; Chip ID register (r)
|
|||
|
rFIFObtm EQU $F0 ; Reserve FIFO Byte (w)
|
|||
|
|
|||
|
rDMA EQU $100 ; Pseudo-DMA regr (r/w)
|
|||
|
|
|||
|
|
|||
|
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
; SCSI 53C96 Bit Defs
|
|||
|
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
|
|||
|
;<3B><><EFBFBD><EFBFBD> Interrupt Register (rINT) bits <20><><EFBFBD><EFBFBD>
|
|||
|
bSelected EQU 0 ; selected interrupt
|
|||
|
bSelectedWAtn EQU 1 ; selected w/atn interrupt
|
|||
|
bReselected EQU 2 ; reselected interrupt
|
|||
|
bFuncComplete EQU 3 ; function complete bit
|
|||
|
bBusService EQU 4 ; bus service bit
|
|||
|
bDisconnected EQU 5 ; disconnected bit
|
|||
|
bIllegalCmd EQU 6 ; illegal command interrupt
|
|||
|
bResetDetected EQU 7 ; SCSI reset detected interrupt
|
|||
|
|
|||
|
;<3B><><EFBFBD> masks <20><><EFBFBD>
|
|||
|
mSelected EQU 1<<bSelected
|
|||
|
mSelectedWAtn EQU 1<<bSelectedWAtn
|
|||
|
mReselected EQU 1<<bReselected
|
|||
|
mFuncComplete EQU 1<<bFuncComplete
|
|||
|
mBusService EQU 1<<bBusService
|
|||
|
mDisconnected EQU 1<<bDisconnected
|
|||
|
mIllegalCmd EQU 1<<bIllegalCmd
|
|||
|
mResetDetected EQU 1<<bResetDetected
|
|||
|
|
|||
|
mNonNormalInt EQU mIllegalCmd + mReselected + mSelected + mSelectedWAtn + mResetDetected
|
|||
|
|
|||
|
|
|||
|
;<3B><><EFBFBD><EFBFBD> Status Register (rSTA) bits <20><><EFBFBD><EFBFBD>
|
|||
|
bCmdXferComp EQU 3 ; Gross Error
|
|||
|
bTermCount EQU 4 ; terminal count
|
|||
|
bParityError EQU 5 ; Parity Error
|
|||
|
bGrossError EQU 6 ; Gross Error
|
|||
|
bINT EQU 7 ; interrupt
|
|||
|
|
|||
|
iPhaseMsk EQU $07 ; MASK value for phase bits
|
|||
|
|
|||
|
;<3B><><EFBFBD><EFBFBD> Command Register (rCMD) bits <20><><EFBFBD><EFBFBD>
|
|||
|
bINTMode EQU 4 ; initiator mode command
|
|||
|
bTRGMode EQU 5 ; target mode command
|
|||
|
bDSCMode EQU 6 ; disconnected mode command
|
|||
|
|
|||
|
;<3B><><EFBFBD><EFBFBD> Configuration 1 Register (rCF1) bits <20><><EFBFBD><EFBFBD>
|
|||
|
mCF1_SlowCableMode EQU $80 ; Slow Cable Mode enabled bit
|
|||
|
mCF1_ResetIntrpDisable EQU $40 ; SCSI Reset Reporting Intrp Disabled bit <SM7>
|
|||
|
mCF1_ParityTestMode EQU $20 ; Parity Test Mode bit
|
|||
|
mCF1_EnableParity EQU $10 ; Enable Parity Checking bit
|
|||
|
mCF1_ChipTestMode EQU $08 ; Enable Chip Test Mode bit
|
|||
|
|
|||
|
mCF1_MyBusID EQU $07 ; My SCSI Bus ID Mask
|
|||
|
|
|||
|
;<3B><><EFBFBD><EFBFBD> Configuration 2 Register (rCF2) bits <20><><EFBFBD><EFBFBD>
|
|||
|
mCF2_ReserveFIFOByte EQU $80 ; Reserve FIFO Byte
|
|||
|
mCF2_FeaturesEnable EQU $40 ; Enable Phase Latch
|
|||
|
; 53F96: turns on 24bit xfer count also
|
|||
|
mCF2_EnableByteControl EQU $20 ; Enable Byte Control
|
|||
|
mCF2_DREQHiZ EQU $10 ; DREQ High Impedance
|
|||
|
|
|||
|
mCF2_SCSI2 EQU $08 ; SCSI-2 Mode
|
|||
|
mCF2_TgtBadParityAbort EQU $04 ; Target Bad Parity Abort
|
|||
|
mCF2_RegisterParity EQU $02 ; Regr Parity Enable
|
|||
|
mCF2_DMAParity EQU $01 ; DMA Parity Enable
|
|||
|
|
|||
|
;<3B><><EFBFBD><EFBFBD> Configuration 3 Register (rCF3) bits <20><><EFBFBD><EFBFBD>
|
|||
|
mCF3_FastSCSI EQU $10 ; set if rate>5MB/s
|
|||
|
mCF3_FastClock EQU $08 ; set if clock = 40MHz
|
|||
|
mCF3_SaveResidual EQU $04 ; Save Residual Byte
|
|||
|
mCF3_AltDMAMode EQU $02 ; Alternate DMA Mode
|
|||
|
mCF3_Threshold8 EQU $01 ; Threshold 8
|
|||
|
|
|||
|
;<3B><><EFBFBD><EFBFBD> Other Register bits <20><><EFBFBD><EFBFBD>
|
|||
|
mSQSMsk EQU $07 ; sequence bits mask value (rSQS)
|
|||
|
mFIFOCount EQU $1F ; FIFO count mask value (rFOS)
|
|||
|
mSyncOffset EQU $0F ; synchronous offset bits (rSYO)
|
|||
|
mSyncPeriod EQU $1F ; synchronous period bits (rSYP)
|
|||
|
|
|||
|
;---------------------------------------------------
|
|||
|
; Miscellaneous Constants
|
|||
|
;---------------------------------------------------
|
|||
|
|
|||
|
iFifoSize EQU $10 ; FIFO size in bytes
|
|||
|
|
|||
|
|
|||
|
;---------------------------------------------------
|
|||
|
; 53c96 Register Values
|
|||
|
;---------------------------------------------------
|
|||
|
|
|||
|
;<3B><><EFBFBD><EFBFBD><EFBFBD> Phase values (for iPhaseMsk bits in rSTA) <20><><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
iDataOut EQU $00 ; Data-Out SCSI Phase value
|
|||
|
iDataIn EQU $01 ; Data-In SCSI Phase value
|
|||
|
iCommand EQU $02 ; Command Phase value
|
|||
|
iStatus EQU $03 ; Status Phase value
|
|||
|
iMsgOut EQU $06 ; Msg-Out SCSI Phase value
|
|||
|
iMsgIn EQU $07 ; Msg-In SCSI Phase value
|
|||
|
|
|||
|
|
|||
|
;<3B><><EFBFBD><EFBFBD><EFBFBD> Clock Conversion Values (based on SCSI chip clock - not CPU clock) <20><><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
ccf10MHz EQU $02 ; CLK conv factor 10.0Mhz
|
|||
|
ccf11to15MHz EQU $03 ; CLK conv factor 10.01 to 15.0Mhz
|
|||
|
ccf16to20MHz EQU $04 ; CLK conv factor 15.01 to 20.0Mhz
|
|||
|
ccf21to25MHz EQU $05 ; CLK conv factor 20.01 to 25.0Mhz
|
|||
|
ccf26to30MHz EQU $06 ; CLK conv factor 25.01 to 30.0Mhz
|
|||
|
ccf31to35MHz EQU $07 ; CLK conv factor 30.01 to 35.0Mhz
|
|||
|
ccf36to40MHz EQU $00 ; CLK conv factor 35.01 to 40.0Mhz (0 := 8)
|
|||
|
|
|||
|
SelTO16Mhz EQU 126 ; ($7e) using the formula: RV (regr value)
|
|||
|
; 126 = (16MHz * 250mS)/ (7682 * 4)
|
|||
|
; 250mS is ANSI standard.
|
|||
|
|
|||
|
SelTO20Mhz EQU 132;160 ; ($) using the formula: RV (regr value)
|
|||
|
; 162 = (20MHz * 250mS)/ (7682 * 4)
|
|||
|
; 250mS is ANSI standard.
|
|||
|
|
|||
|
SelTO25Mhz EQU 167 ; ($a7) using the formula: RV (regr value)
|
|||
|
; 163 = (25MHz * 250mS)/ (7682 * 5)
|
|||
|
; 250mS is ANSI standard.
|
|||
|
|
|||
|
SelTO33Mhz EQU 167 ; ($a7) using the formula: RV (regr value)
|
|||
|
; 153 = (33MHz * 250mS)/ (7682 * 7)
|
|||
|
; 250mS is ANSI standard.
|
|||
|
|
|||
|
SelTO40Mhz EQU 132;160 ; ($a7) using the formula: RV (regr value)
|
|||
|
; 163 = (40MHz * 250mS)/ (7682 * 8)
|
|||
|
; 250mS is ANSI standard.
|
|||
|
|
|||
|
; <SM5>
|
|||
|
|
|||
|
;<3B><><EFBFBD><EFBFBD><EFBFBD> Values to use <20><><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
asyncXfer EQU $0 ; Asynchronous Data Transfer = 0 Synch Offset value
|
|||
|
; a non-zero value indicates Synch data xfer
|
|||
|
|
|||
|
initOp EQU asyncXfer ; use this operation
|
|||
|
|
|||
|
;---------------------------------------------------
|
|||
|
; SCSI DAFB Register Information
|
|||
|
;---------------------------------------------------
|
|||
|
|
|||
|
SCSI0_DAFB EQU $F9800024 ; DAFB address to access SCSI1 DREQ bit
|
|||
|
SCSI1_DAFB EQU $F9800028 ; DAFB address to access SCSI2 DREQ bit
|
|||
|
bDREQ EQU 9 ; SCSI DREQ status bit
|
|||
|
|
|||
|
tsc_cf_stg_25 EQU $1EC ; DAFB state maching config value for 25 MHz CPU
|
|||
|
tsc_cf_stg_33 EQU $041 ; DAFB state maching config value for 33 MHz CPU
|
|||
|
|
|||
|
|
|||
|
ENDIF ; already included...
|