mirror of
https://github.com/elliotnunn/mac-rom.git
synced 2024-12-31 19:33:04 +00:00
4325cdcc78
Resource forks are included only for .rsrc files. These are DeRezzed into their data fork. 'ckid' resources, from the Projector VCS, are not included. The Tools directory, containing mostly junk, is also excluded.
3377 lines
145 KiB
Plaintext
3377 lines
145 KiB
Plaintext
;__________________________________________________________________________________________________
|
|
;
|
|
; File: HardwarePrivateEqu.a
|
|
;
|
|
; Contains: Macintosh assembly equates THAT ARE NOT TO BE RELEASED TO THE WORLD.
|
|
;
|
|
; Copyright: © 1990-1993 by Apple Computer, Inc. All rights reserved.
|
|
;
|
|
; Change History (most recent first):
|
|
;
|
|
; <SM30> 12/13/93 PN Roll in KAOs and Horror changes to support Malcom and AJ
|
|
; machines
|
|
; <SM29> 11/16/93 SAM Added an eieio macro for use on systems that have non serialized
|
|
; i/o space. Basically, the macro will expand to a 68k NOP if
|
|
; "forNonSerializedIO" is set to true.
|
|
; <SM28> 11/9/93 KW added eieioSTP macro. When forSTP601 is defined as True, a 68k
|
|
; nop instruction will be added. Emulator turns 68k nop into
|
|
; eieio. Only effects the CygnusX1 ROM
|
|
; <SM27> 8/4/93 JDR private sound defines are in SoundPrivate.a
|
|
; <SM26> 7/20/93 SAM Fixed the ROMHeader record. Added the fields the SuperMario
|
|
; guys forgot to add to the end of the structure.
|
|
; <SM25> 7/14/93 RC Added BART nubus controller register defs for PDM and Cold
|
|
; Fusion
|
|
; <SM24> 5/6/93 SAM More generic AMIC stuff.
|
|
; <SM23> 4/22/93 SAM Added some general AMIC equates (for PDM).
|
|
; <SM22> 3/31/93 chp Synchronize SuperMario with changes from <LW2>.
|
|
; <LW2> 2/24/93 chp Added equates for the PSC wait/request multiplexer control bits
|
|
; in VIA1.
|
|
; <SM21> 01-12-93 jmp Added in the CSC equates.
|
|
; <SM20> 12/4/92 SWC Added ascPlayRecA to the ASC equates.
|
|
; <SM19> 12/1/92 EH Added Pratt Memory controller equates and Via1 equates for
|
|
; Blackbird.
|
|
; <SM18> 11/6/92 rab Roll in Horror changes. Comments follow:
|
|
; <H28> 10/12/92 BG Added symbolic constants for refering to the CPU ID bits that
|
|
; describe CPU_SPEED and CPU_ID values for Wombat/WLCD/Vail040.
|
|
; <H27> 9/6/92 jab Added SCSI configuration info for BIOS.
|
|
; <H26> 8/25/92 BG Added definitions for BIOS configuration registers.
|
|
; <SM17> 10/27/92 fau Added a YMCABase to the YMCA equ's.
|
|
; <SM16> 9/30/92 fau Added a couple of constants for YMCA register sizes to aid in
|
|
; the SizeMem programming; renamed a couple of YMCA registers to
|
|
; something better.
|
|
; <SM15> 9/16/92 WS Fix bug change / to _
|
|
; <SM14> 9/16/92 WS
|
|
; <SM14> 9/15/92 gjs Added the YMCA equates for EVT-4.
|
|
; <SM13> 8/17/92 CCH Bumped HeapStart to $2800.
|
|
; <SM12> 8/7/92 JDB Changed Singer control register to have 0 for the output
|
|
; attenuation and 5 for the input gain.
|
|
; <SM11> 07-14-92 jmp (ag,H24) Change the name of a bit from PontiSndExtMic to
|
|
; PontiSndIntMic
|
|
; (jmp,H23) Added some additional DAFB equates for the WombatDAFB
|
|
; code.
|
|
; (BG,H22) Added one more djMEMC-related symbolic definition
|
|
; (dj_MaxBanks).
|
|
; <SM10> 6/21/92 ejb Adding bit field definitions for dspOverrun register in PSC.
|
|
; <SM9> 6/21/92 RB Adding runtime support for EVT1 and EVT2 Cyclones. Defined
|
|
; temporary equates for the EVT1 Cyclone units.
|
|
; <SM8> 6/18/92 KW (BG,H21) Added djMEMC memory controller equates for Wombat and
|
|
; WLCD.
|
|
; (jmp,H20) Wombat has a different dot-clock chip than
|
|
; Spike/Eclipse/Zydeco, so I added an equate to reflect this.
|
|
; <SM7> 6/18/92 RB Added equates for the new EVT2 (final offsets) of the VIA2 on
|
|
; Cyclone. The old values are still supported under the
|
|
; conditional forEVT1. These should be deleted once everyone moves
|
|
; to EVT2 boards. Did the same with MUNIBase as well.
|
|
; <SM6> 6/4/92 KW (fau,P18) Added and equate for Civic_VidInDble to support Civic
|
|
; II.
|
|
; <SM5> 5/25/92 RB Removed a forCyclone conditional. This should be the last one
|
|
; left. Renamed MSCBank1Enable to MSCBank8M.
|
|
; <SM4> 5/21/92 RB Making changes for Cyclone. Some comments may be duplicated due
|
|
; to the Pandora/Terror history. <P17> 5/13/92 KW (ag,H18) Added
|
|
; Ponti Definitions. (BG,H17) Added symbol v2MicCtl to the VIA2
|
|
; bit definitions. This is a microphone control bit that is
|
|
; defined for Wombat. Also updated some comments from Eclipse and
|
|
; Zydeco to the appropriate Quadra names. <P16> 4/16/92 KW (SWC,
|
|
; H16) Set bufWorldSize to 8K so Macsbug won't load into the
|
|
; middle of DBLite's sound buffer and get trashed when a sound is
|
|
; played. <P15> 03/24/92 jmp Renamed one of the MMC registers to
|
|
; something more appropriate (i.e., MMC_Interlace to
|
|
; MMC_ClockSelect). <P14> 03/22/92 jmp Put back <P12>. <P13>
|
|
; 3/19/92 FU Rolled back changes in <P12>. <P12> 3/18/92 FU
|
|
; (SWC,H15) Added SCSI DiskMode bit definitions for Niagra to the
|
|
; VIA 1 list. <P11> 03/04/92 jmp Updated the comments and changed
|
|
; the names of some of the Civic-related equates. <P10> 02/28/92
|
|
; jmp (ejb) Turned off the DSP frame-interrupt enable bit so that
|
|
; DSP driver doesnÕt suffer frame overrun when it trys to boot the
|
|
; DSP. <P9> 02/20/92 jmp (JC,H14) Define PatchFlags in unused by
|
|
; of ROM header ($0014). Define PatchBits based on available
|
|
; features in BBSStartup. Include support for Horror based and
|
|
; Pandora (Cyclone) based ROMs. <P8> 2/19/92 chp (jmp,H13) Put a
|
|
; ÒhasSonora1Ó conditional around the Sonora video control
|
|
; register base address to reflect impending hardware changes to
|
|
; Sonora. <P7> 02/07/92 jmp (HJR,H12) Added new Niagra Equates.
|
|
; (SWC,H11) One more go-round on MSC configuration: RAM bank 1
|
|
; needs to be disabled since there's only 2MB on DBLite LC.
|
|
; (SWC,H10) Fixed the MSC configuration value: it needs to be
|
|
; setup for a minimum amount of RAM so that the sound FIFO will
|
|
; always exist in real RAM for BootBeep. (SWC,H9) Added an equate
|
|
; for the default MSC configuration register value. Also, added
|
|
; Civic and Civic-related equates for Cyclone. <P6> 2/5/92 RMP
|
|
; Added MUNI equates. <P5> 1/21/92 mal Added PSC VIA2 equates <P4>
|
|
; 1/18/92 RMP Added PSC sound equates. <P3> 1/15/92 RP Fixed
|
|
; header (sorry). <P2> 1/15/92 RP Added new VIA definition bits
|
|
; and MMC equates.
|
|
; <SM3> 5/17/92 kc Roll in Horror Changes. Comments follow:
|
|
; <H16> 4/8/92 SWC Set bufWorldSize to 8K so Macsbug won't load into the middle of
|
|
; DBLite's sound buffer and get trashed when a sound is played.
|
|
; <H15> 3/3/92 SWC Added SCSI DiskMode bit definitions for Niagra to the VIA 1
|
|
; list.
|
|
; <H14> 2/19/92 JC Define PatchFlags in unused by of ROM header ($0014). Define
|
|
; PatchBits based on available features in BBSStartup. Include
|
|
; support for Horror based and Pandora (Cyclone) based ROMs.
|
|
; <H11> 1/23/92 SWC One more go-round on MSC configuration: RAM bank 1 needs to be
|
|
; disabled since there's only 2MB on DBLite LC.
|
|
; <H10> 1/22/92 SWC Fixed the MSC configuration value: it needs to be setup for a
|
|
; minimum amount of RAM so that the sound FIFO will always exist
|
|
; in real RAM for BootBeep.
|
|
; <H9> 1/22/92 SWC Added an equate for the default MSC configuration register
|
|
; value.
|
|
; <H8> 12/20/91 JC Create common Via2/RBV offset equates and temporary redefinition
|
|
; on Sonora Specific builds to only use RBV offsets
|
|
; <H6> 12/03/91 jmp Added various (but not yet complete) SonoraAddr and
|
|
; Sonora-VDACAddr equates. Sorry to have cancelled your check-out
|
|
; swc, but we had pressing needs.
|
|
; <H5> 11/26/91 jmp Added equates for the GSC.
|
|
; <H4> 11/25/91 SAM Added Sonora specific equate for RAMSize reg.
|
|
; <H2> 8/5/91 SWC Added MSCPowerCycle, the offset to the power cycle register from
|
|
; the base of the MSC.
|
|
|
|
; <T21> 7/8/91 HJR Rename JAWSAuxWaitS to JAWSEconoMode register to reflect its new
|
|
; pupose in life.
|
|
; <T20> 5/24/91 jmp Added another VIA2, port A, bit-7 equate for Spike & Eclipse:
|
|
; v2SyncOnGreen. This bit allows us to enable & disable the
|
|
; sync-on-green signal in ACDC.
|
|
; <T19> 5/10/91 djw Add sound input select bits for Eclipse in VIA2
|
|
; <T18> 5/1/91 HJR Added in register definitions for the MSC memory controller
|
|
; (DB-Lite).
|
|
; <T17> 4/1/91 BG Modified the v2Keyswitch bit definition to agree with what it
|
|
; will be on DVT Eclipse.
|
|
; <T14> 3/3/91 BG Added bit definition for Eclipse Keyswitch bit in VIA2.
|
|
; <T12> 2/16/91 BG Added Orwell constants to deal with 33MHz.
|
|
; <T8> 1/18/91 CCH Added equates for Spike's VIA2.
|
|
; <T6> 11/7/90 BG Made changes for new rev. of Orwell (2) permanent.
|
|
; <SM2> 4/22/92 RB Moved the start of the System heap in order to get some space
|
|
; for vector tables. This movement of the heap from $2000 to $2100
|
|
; is for experimentation and will need to be changed at a later
|
|
; date.
|
|
; <35> 12/31/91 RB Renamed JAWSAuxWaitS to JAWSEconoMode to reflect its real
|
|
; purpose.
|
|
; <34> 12/29/91 RB Updated some of the Terror constants.
|
|
; <33> 10/28/91 SAM/KSM Rolled in Regatta file.
|
|
;
|
|
; Regatta Change History:
|
|
;
|
|
; <2> 8/8/91 SAM (pdw, ag) Added some equates from HardwarePrivateEqu in
|
|
; TERROR.
|
|
; <1> 8/8/91 SAM Split off from 7.0 GM sources.
|
|
;
|
|
; 7.0 Change History:
|
|
;
|
|
; <32> 10/1/91 JSM DonÕt use eclipseDebug.
|
|
; <31> 8/30/91 DTY Complicate matters so onMac32 stuff doesnÕt get defined for
|
|
; onMac, onMacPP, or onMacHc. (Since these arenÕt defined in
|
|
; BBSStartup anymore, this is necessary.)
|
|
; <30> 8/22/91 JSM Clean up header.
|
|
; <29> 7/24/91 MH Added conditional wrapper(s) to prevent duplication of public
|
|
; interface declarations: TimeSCSIDB
|
|
; <28> 1/30/91 gbm sab, #38: Change the Ôalready including this fileÕ variable to
|
|
; all uppercase (for security reasons)
|
|
; <27> 11/26/90 gbm (and bbm) On 7.0 (and other places eventually) HiIntMask will be
|
|
; $0700 instead of $0300 all the time, not just when on a
|
|
; non-Plus.
|
|
; <26> 10/22/90 JJ Rex V8: Added equates for V8 registers
|
|
; <25> 9/24/90 BG Added symbolic names for the Data and Instruction Cache enable
|
|
; bits for the CACRs of various machines.
|
|
; <24> 9/13/90 MSH A couple of VIA2 assignments have changed for TIM.
|
|
; <23> 9/1/90 BG Updated and added various constants to agree with the EVT1
|
|
; version of the Eclipse board.
|
|
; <22> 7/11/90 gbm Take out some things that are in SysEqu.a
|
|
; <21> 7/6/90 CCH Changed default ROM wait states and RAM refresh rate for
|
|
; Eclipse.
|
|
; <20> 6/27/90 CCH Took out the conditionals around TestInRam!
|
|
; <19> 6/27/90 CCH TestInRAM macro gets compiled when eclipseDebug is set.
|
|
; <18> 5/24/90 HJR Update Machine equate to 7 instead of 6 for newer machines.
|
|
; <16> 4/4/90 HJR Clean up some build problems.
|
|
; <15> 4/4/90 MSH forrom removal.
|
|
; <14> 4/4/90 MSH Merged HardwareEqu.a back into HardwarePrivateEqu.a and
|
|
; restructured/rewrote the resultant file. This action obsoletes
|
|
; HardwareEqu.a. All future equate additions should be done to
|
|
; HardwarePrivateEqu.a only.
|
|
; <13> 3/29/90 MSH Add VIA2 labels for Waimea.
|
|
; <12> 3/22/90 JJ Force definition of onElsie=0 if onElsie is undefined.
|
|
; <11> 2/14/90 DAF Added VISA register names. Since Elsie isn't fully integrated,
|
|
; it doesn't have real feature conditional yet.
|
|
; <10> 2/9/90 BG Modified ORWELL_INIT value to reflect the parts being used on
|
|
; the Eclipse prototype.
|
|
; <9> 2/9/90 JJ Added RvExp, offset of RBV Expansion Register in Elsie.
|
|
; <8> 2/9/90 BG Moved EQUs for the Eclipse VIA2 out of the -ELSEIF onEclipse-,
|
|
; as those definitions will be used even if the -onEclipse-
|
|
; conditional stuff is not used.
|
|
; <7> 2/2/90 BG Missed one re-definition in previous change.
|
|
; <6> 2/2/90 BG Modified some bits in the Eclipse VIA2 buffer A description to
|
|
; have relevant mnemonic names.
|
|
; <5> 1/31/90 BG Added Orwell-specific register bit definitions, address offsets
|
|
; and configuration register initial values.
|
|
; <4> 1/30/90 BG Added Eclipse-specific hardware constant definitions.
|
|
; <3> 1/18/90 SWC Updating FMCInit and FMCRPUInit with the final values.
|
|
; <2> 1/12/90 CCH Added missing ENDIF.
|
|
; <1> 1/11/90 CCH Moved in private equates from ÒHardwareEqu.aÓ.
|
|
;
|
|
; NOTE:
|
|
;
|
|
; For change history versions not mentioned in the above -Change History-, refer
|
|
; to <Sources>:Interfaces:AIncludes:HardwareEqu.a.
|
|
;
|
|
|
|
IF &TYPE('__INCLUDINGHARDWAREPRIVATEEQU__') = 'UNDEFINED' THEN
|
|
__INCLUDINGHARDWAREPRIVATEEQU__ SET 1
|
|
|
|
|
|
|
|
;__________________________________________________________________________________________
|
|
;
|
|
; Welcome to the New Hardware Equates File. By following some simple procedures this file
|
|
; can keep its youthful appearance for years to come. This file is a recombination of
|
|
; HardwareEqu.a and HardwarePrivateEqu.a. Everyone should be using this file only. Please
|
|
; change any of your files that use either of the hardware equate files to use only this one.
|
|
; HardwareEqu.a will be left as an historical artifact for future generations.
|
|
;
|
|
; To help you navigate through this file use the "Mark" menu item, and please help to keep
|
|
; it current. When you add a new section, add a handy mark to find it again. Equates are
|
|
; grouped in a semi-logical way in the follwing order:
|
|
;
|
|
; Chip Offsets - Register offsets for the 'standard' Mac peripheral chips.
|
|
; Chip Offsets 2 - Register offsets for the 'non-standard' Mac peripheral chips.
|
|
; VIA1 - Register offsets and pin descriptions.
|
|
; VIA2 - Register offsets and pin descriptions.
|
|
; RBV - Register offsets and pin descriptions.
|
|
; VISA - Register offsets and pin descriptions.
|
|
; Memory Controllers - Register definitions and miscellaneous equates.
|
|
; Interrupts - Auto vector names and mask definitions.
|
|
; Miscellaneous - The "Smorgasboard" of equates.
|
|
; Old 16 Bit Equates - Machine dependent equates for Mac, MacPP, HcMac, and Mac16.
|
|
;
|
|
;
|
|
;__________________________________________________________________________________________
|
|
|
|
|
|
|
|
|
|
|
|
;__________________________________________________________________________________________
|
|
;
|
|
;
|
|
; Chip Offsets - Register offsets for "standard" Mac chips. This includes the following:
|
|
; IWM, SWIM, SCC, SCSI (with and without DMA), ASC.
|
|
;
|
|
;
|
|
;__________________________________________________________________________________________
|
|
|
|
|
|
;---------------------------------------------------
|
|
; IWM Offsets
|
|
;---------------------------------------------------
|
|
|
|
ph0L EQU 0 ; disk address offsets from base
|
|
ph0H EQU $200
|
|
ph1L EQU $400
|
|
ph1H EQU $600
|
|
ph2L EQU $800
|
|
ph2H EQU $A00
|
|
ph3L EQU $C00
|
|
ph3H EQU $E00
|
|
mtrOff EQU $1000
|
|
mtrOn EQU $1200
|
|
intDrive EQU $1400 ; enable internal drive address
|
|
extDrive EQU $1600 ; enable external drive address
|
|
q6L EQU $1800
|
|
q6H EQU $1A00
|
|
q7L EQU $1C00
|
|
q7H EQU $1E00
|
|
|
|
IWMInitMode equ $17 ; initial IWM mode setting <3.5>
|
|
|
|
;---------------------------------------------------
|
|
; SWIM offsets
|
|
;---------------------------------------------------
|
|
|
|
wData EQU $0000 ;Write a data byte
|
|
wMark EQU $0200 ;Write a mark byte
|
|
wCRC EQU $0400 ;Write a 2-byte CRC (1 access does both)
|
|
wIWMConfig EQU wCRC ;Set IWM configuration
|
|
wParams EQU $0600 ;Set the 16 parameter registers
|
|
wPhase EQU $0800 ;Set phase lines states and directions
|
|
wSetup EQU $0A00 ;Set the current configuration
|
|
wZeroes EQU $0C00 ;Mode reg: 1's clr bits, 0's=don't care
|
|
wOnes EQU $0E00 ;Mode reg: 1's set bits, 0's=don't care
|
|
rData EQU $1000 ;Read a data byte
|
|
rCorrection EQU rData ;Read the correction factor
|
|
rMark EQU $1200 ;Read a mark byte
|
|
rError EQU $1400 ;Error register
|
|
rParams EQU $1600 ;Parameters (16 bytes deep at this addr)
|
|
rPhase EQU $1800 ;Phase lines states and directions
|
|
rSetup EQU $1A00 ;Read the current configuration
|
|
rStatus EQU $1C00 ;Status (returns current mode reg value)
|
|
rHandshake EQU $1E00 ;Handshake register
|
|
|
|
|
|
;---------------------------------------------------
|
|
; 8530 SCC Offsets
|
|
;---------------------------------------------------
|
|
|
|
aData EQU 6 ; offset for A channel data
|
|
aCtl EQU 2 ; offset for A channel control
|
|
bData EQU 4 ; offset for B channel data
|
|
bCtl EQU 0 ; offset for B channel control
|
|
sccData EQU 4 ; general offset for data from control
|
|
rxBF EQU 0 ; SCC receive buffer full
|
|
txBE EQU 2 ; SCC transmit buffer empty
|
|
RxCA EQU 0 ; Receive Character Available
|
|
|
|
|
|
;---------------------------------------------------
|
|
; 53C80 SCSI Register Defs, Offsets
|
|
;---------------------------------------------------
|
|
|
|
sCDR EQU $00 ; Current SCSI Read Data
|
|
sODR EQU $00 ; Output data register
|
|
sICR EQU $10 ; Initiator Command Register - READ/WRITE
|
|
iRST EQU $80 ; *RST asserted
|
|
iAIP EQU $40 ; arbitration in progress (read)
|
|
bAIP EQU 6 ; bit test for arbitration in progress
|
|
aTMD EQU $40 ; assert Test Mode (write)
|
|
iLA EQU $20 ; Lost arbitration (read)
|
|
bLA EQU 5 ; bit test for Lost Arbitration
|
|
aDIFF EQU $20 ; assert Differential enable (write)
|
|
iACK EQU $10 ; *ACK is asserted
|
|
iBSY EQU $08 ; *BSY is asserted
|
|
iSEL EQU $04 ; *SEL is asserted
|
|
iATN EQU $02 ; *ATN is asserted
|
|
iDB EQU $01 ; Data bus is asserted
|
|
sMR EQU $20 ; Mode Register - READ/WRITE
|
|
iBDMA EQU $80 ; Block Mode DMA
|
|
iTGT EQU $40 ; Target Mode
|
|
iPTY EQU $20 ; Enable Parity Checking
|
|
iIPTY EQU $10 ; Enable Parity interrupt
|
|
iIEOP EQU $08 ; Enable EOP interrupt
|
|
iMBSY EQU $04 ; Monitor BSY
|
|
iDMA EQU $02 ; DMA Mode
|
|
iARB EQU $01 ; Arbitration
|
|
sTCR EQU $30 ; Target Command Register - READ/WRITE
|
|
iREQ EQU $08 ; Assert *REQ
|
|
iMSG EQU $04 ; Assert *MSG
|
|
iCD EQU $02 ; Assert C/*D
|
|
iIO EQU $01 ; Assert I/*O
|
|
sCSR EQU $40 ; Current SCSI Bus Status (READ)
|
|
aRST EQU $80 ; *RST
|
|
aBSY EQU $40 ; *BSY
|
|
bBSY EQU 6 ; bit test for *BSY
|
|
aREQ EQU $20 ; *REQ
|
|
bREQ EQU 5 ; bit test for *REQ
|
|
aMSG EQU $10 ; *MSG
|
|
bMSG EQU 4 ; bit test for *MSG
|
|
aCD EQU $08 ; C/*D
|
|
bCD EQU 3 ; bit test for C/*D
|
|
aIO EQU $04 ; I/*O
|
|
bIO EQU 2 ; bit test for I/*O
|
|
aSEL EQU $02 ; *SEL
|
|
bSEL EQU 1 ; bit test for *SEL
|
|
aDBP EQU $01 ; *DBP
|
|
sSER EQU $40 ; Select Enable Register (WRITE)
|
|
sBSR EQU $50 ; Bus & Status Register (READ)
|
|
iEDMA EQU $80 ; End of DMA
|
|
bEDMA EQU 7 ; bit test for end of DMA
|
|
iDMAR EQU $40 ; DMA Request
|
|
bDMAR EQU 6 ; bit test for DMA Req
|
|
iPERR EQU $20 ; Parity Error
|
|
iIREQ EQU $10 ; Interrupt Request
|
|
bIREQ EQU 4 ; bit test for interrupt
|
|
iPM EQU $08 ; Phase Match
|
|
bPM EQU 3 ; bit test for Phase Match
|
|
iBERR EQU $04 ; Bus Error
|
|
ATN EQU $02 ; *ATN
|
|
ACK EQU $01 ; *ACK
|
|
bACK EQU 0 ; bit test for ACK
|
|
sDMAtx EQU $50 ; DMA Transmit Start (WRITE)
|
|
sIDR EQU $60 ; Data input register (READ)
|
|
sTDMArx EQU $60 ; Start Target DMA receive (WRITE)
|
|
sRESET EQU $70 ; Reset Parity/Interrupt (READ)
|
|
sIDMArx EQU $70 ; Start Initiator DMA receive (WRITE)
|
|
|
|
|
|
;---------------------------------------------------
|
|
; SCSI DMA chip register offsets
|
|
;---------------------------------------------------
|
|
|
|
; Note that the 53C80 registers are provided on the SCSI DMA chip. The registers
|
|
; described here are in addition to the 53C80 registers.
|
|
|
|
sDCTRL EQU $80
|
|
bDMAEN EQU 0 ; bit to enable SCSI DMA
|
|
iDMAEN EQU $0001 ; mask to enable SCSI DMA
|
|
bINTREN EQU 1 ; bit to enable SCSI DMA interrupts
|
|
iINTREN EQU $0002 ; mask to enable SCSI DMA interrupts
|
|
bTIMEEN EQU 2 ; bit to enable watchdog timer intr's
|
|
iTIMEEN EQU $0004 ; mask to enable watchdog timer intr's
|
|
bHSKEN EQU 3 ; bit to enable hardware-handshaking (write)
|
|
iHSKEN EQU $0008 ; mask to enable hardware-handshaking (write)
|
|
bRESET EQU 4 ; bit to reset SCSI DMA chip (write)
|
|
iRESET EQU $0010 ; mask to reset SCSI DMA chip (write)
|
|
bFIFO EQU 4 ; bit indicating bytes left in FIFO (read)
|
|
iFIFO EQU $0010 ; mask indicating bytes left in FIFO (read)
|
|
bTEST EQU 5 ; bit to enable SCSI Test Mode (write)
|
|
iTEST EQU $0020 ; mask to enable SCSI Test Mode (write)
|
|
bSCSIP EQU 6 ; bit indicating SCSI intr pending (read)
|
|
iSCSIP EQU $0040 ; mask indicating SCSI intr pending (read)
|
|
bTIMEP EQU 7 ; bit indicating timer intr pending (read)
|
|
iTIMEP EQU $0080 ; mask indicating timer intr pending (read)
|
|
bDMABERR EQU 8 ; bit indicating DMA bus error (read)
|
|
iDMABERR EQU $0100 ; mask indicating DMA bus error (read)
|
|
iARBID EQU $0E00 ; mask to get target ID for arbitration
|
|
bARBIDEN EQU 12 ; bit to enable hardware arbitration
|
|
iARBIDEN EQU $1000 ; mask to enable hardware arbitration
|
|
bWONARB EQU 13 ; bit indicating successful arbitration
|
|
iWONARB EQU $2000 ; mask indicating successful arbitration
|
|
iINFIFO EQU $C000 ; mask to get bytes left in FIFO (read)
|
|
|
|
sDCNT EQU $C0
|
|
|
|
sDADDR EQU $100
|
|
|
|
sDTIME EQU $140
|
|
|
|
sTEST equ $180
|
|
|
|
;__________________________________________________________________________________________
|
|
;
|
|
;
|
|
; Chip Offsets - Register offsets for "non standard" Mac chips. This includes the following:
|
|
; OSS and IOP.
|
|
;
|
|
;
|
|
;__________________________________________________________________________________________
|
|
|
|
|
|
;---------------------------------------------------
|
|
; OSS (Operating System Support) Chip Address & Offsets
|
|
;---------------------------------------------------
|
|
|
|
OSSMskFirst equ $000 ;offset to first interrupt mask register
|
|
OSSMskSlot9 equ OSSMskFirst ;offset to slot 9 interrupt mask register
|
|
OSSMskSlotA equ $001 ;offset to slot A interrupt mask register
|
|
OSSMskSlotB equ $002 ;offset to slot B interrupt mask register
|
|
OSSMskSlotC equ $003 ;offset to slot C interrupt mask register
|
|
OSSMskSlotD equ $004 ;offset to slot D interrupt mask register
|
|
OSSMskSlotE equ $005 ;offset to slot E interrupt mask register
|
|
OSSMskPSwm equ $006 ;offset to SWIM PIC interrupt mask register
|
|
OSSMskPScc equ $007 ;offset to SCC PIC interrupt mask register
|
|
OSSMskSnd equ $008 ;offset to Sound interrupt mask register
|
|
OSSMskScsi equ $009 ;offset to SCSI interrupt mask register
|
|
OSSMsk60Hz equ $00A ;offset to 60 Hz interrupt mask register
|
|
OSSMskVia1 equ $00B ;offset to VIA1 interrupt mask register
|
|
OSSMskRTC equ $00C ;offset to RTC interrupt mask register
|
|
OSSMskADB equ $00D ;offset to ADB interrupt mask register (not used) <5.1>
|
|
OSSMskRPU equ $00E ;offset to RPU interrupt mask register <4.8>
|
|
OSSMskLast equ OSSMskRPU ;offset to last interrupt mask register
|
|
|
|
rpuReset EQU $010 ; RPU write offset to reset serial ptr <4.9>
|
|
|
|
OSSIntStat equ $202 ;offset to interrupt status register. Bits are: <3.7>
|
|
; 15: interrupt 15 (spare) pending
|
|
; 14: interrupt 14 (RPU) pending <4.8>
|
|
; 13: interrupt 13 (spare) pending <5.1>
|
|
; 12: interrupt 12 (RTC) pending
|
|
; 11: interrupt 11 (VIA1) pending
|
|
; 10: interrupt 10 (60 Hz) pending
|
|
; 9: interrupt 9 (SCSI) pending
|
|
; 8: interrupt 8 (sound) pending
|
|
; 7: interrupt 7 (SCC PIC) pending
|
|
; 6: interrupt 6 (SWIM PIC) pending
|
|
; 5: interrupt 5 (slot E) pending
|
|
; 4: interrupt 4 (slot D) pending
|
|
; 3: interrupt 3 (slot C) pending
|
|
; 2: interrupt 2 (slot B) pending
|
|
; 1: interrupt 1 (slot A) pending
|
|
; 0: interrupt 0 (slot 9) pending
|
|
|
|
;¥¥¥¥¥ NOTE: In the new OSS, the interrupt status register is a long word starting at $200. <3.7>
|
|
;¥¥¥¥¥ Since only the low-order word is currently used, making a single change here <3.7>
|
|
;¥¥¥¥¥ has less impact on the ROM sources. When we permanently switch over to the <3.7>
|
|
;¥¥¥¥¥ new OSS hardware, then it may make sense to fix this equate and change all its <3.7>
|
|
;¥¥¥¥¥ uses from MOVE.Ws to MOVE.Ls. <3.7>
|
|
|
|
OSSRomCntl equ $204 ;offset to ROM control register. Bits are:
|
|
; <to be specified - see Steve Ray's spec> <2.0>
|
|
|
|
OSSPwrOff equ OSSRomCntl ;power off is now a bit in the ROM control register <5.1>
|
|
OSSPwrOffBit equ 7 ; 7: write a 1 here to power off the machine <2.1><3.7>
|
|
|
|
OSSCntrCntl equ $205 ;offset to counter control register. Bits are
|
|
; 7-2: unused
|
|
; 1: test control. A 1 causes each 4 bit
|
|
; counter segment to count in parallel
|
|
; 0: counter hold. A 1 holds current value
|
|
; so all 64 bits can be read. Hold doesn't
|
|
; affect counting, though!
|
|
|
|
OSSInpStat equ $206 ;offset to input status register. Bits are
|
|
; 7-2: not used, read as zero
|
|
; 1: SCC write request. Not used if PIC present
|
|
; 0: mini-phono device plugged in flag. A 1
|
|
; means a device IS plugged in.
|
|
|
|
OSS60HzAck equ $207 ;offset to 'Clear 60 Hz interrupt flag' register. Both <3.7>
|
|
; writes and reads clear it, so might as well write it.
|
|
|
|
OSSCounter equ $208 ;offset to 64 bit counter register. Low order 8
|
|
;.bits are always read as zero (maybe not in future...)
|
|
|
|
; Bit numbers in OSS interrupt status register
|
|
|
|
OSSIntIOPSWIM equ 6 ;bit # of SWIM IOP in interrupt status register
|
|
OSSIntIOPSCC equ 7 ;bit # of SCC IOP in interrupt status register
|
|
OSSIntSound equ 8 ;bit # of ASC in interrupt status register
|
|
OSSIntSCSI equ 9 ;bit # of SCSI in interrupt status register
|
|
OSSIntVBL60Hz equ 10 ;bit # of 60Hz VBL in interrupt status register
|
|
OSSIntVia1 equ 11 ;bit # of VIA 1 in interrupt status register
|
|
OSSIntRTC equ 12 ;bit # of RTC in interrupt status register
|
|
OSSIntADB equ 13 ;bit # of ADB in interrupt status register
|
|
OSSIntRPU equ 14 ;bit # of RPU in interrupt status register <4.8>
|
|
OSSIntLast equ 14 ;bit # of last interrupt source
|
|
|
|
OSSRomInit EQU $D ; initial value for ROM control register<3.5>
|
|
|
|
|
|
;---------------------------------------------------
|
|
; IOP (Input Output Processor) Chip Offsets and bit definitions
|
|
;---------------------------------------------------
|
|
|
|
iopRamAddrH equ $0000-$20 ; high byte of shared RAM address register
|
|
iopRamAddrL equ $0002-$20 ; low byte of shared RAM address register
|
|
iopRamAddr equ iopRamAddrL-1 ; WORD access to shared RAM address register
|
|
|
|
iopRamData equ $0008-$20 ; shared RAM data register (byte, word, or long)
|
|
iopStatCtl equ $0004-$20 ; IOP Status and Control register
|
|
|
|
; bit numbers within the iopStatCtl register
|
|
iopInBypassMode equ 0 ; IOP is in BYPASS mode
|
|
iopIncEnable equ 1 ; enable addr pointer increment
|
|
iopRun equ 2 ; 0 -> reset IOP, 1 -> run IOP
|
|
iopGenInterrupt equ 3 ; interrupt the IOP
|
|
iopInt0Active equ 4 ; interrupt 0 active
|
|
iopInt1Active equ 5 ; interrupt 1 active
|
|
iopBypassIntReq equ 6 ; peripheral chip interrupt request in bypass mode
|
|
iopSCCWrReq equ 7 ; 0 -> SCC REQ active, 1 -> inactive
|
|
|
|
; commands bytes to write to the iopStatCtl register
|
|
setIopIncEnable equ (1<<iopIncEnable)|\ ; set increment enable
|
|
(1<<iopRun) ; leave iop running
|
|
|
|
clrIopIncEnable equ (0<<iopIncEnable)|\ ; reset increment enable
|
|
(1<<iopRun) ; leave iop running
|
|
|
|
clrIopInt0 equ (1<<iopInt0Active)|\ ; clear interrupt 0 active
|
|
(1<<iopRun)|\ ; leave iop running
|
|
(1<<iopIncEnable) ; leave increment enabled
|
|
|
|
clrIopInt1 equ (1<<iopInt1Active)|\ ; clear interrupt 1 active
|
|
(1<<iopRun)|\ ; leave iop running
|
|
(1<<iopIncEnable) ; leave increment enabled
|
|
|
|
setIopGenInt equ (1<<iopGenInterrupt)|\ ; interrupt the IOP
|
|
(1<<iopRun)|\ ; leave iop running
|
|
(1<<iopIncEnable) ; leave increment enabled
|
|
|
|
resetIopRun equ (0<<iopRun)|\ ; stop iop from running
|
|
(1<<iopInt0Active)|\ ; clear interrupt 0 active
|
|
(1<<iopInt1Active)|\ ; clear interrupt 1 active
|
|
(1<<iopIncEnable) ; set increment enable
|
|
|
|
setIopRun equ (1<<iopRun)|\ ; start iop running
|
|
(1<<iopInt0Active)|\ ; clear interrupt 0 active
|
|
(1<<iopInt1Active)|\ ; clear interrupt 1 active
|
|
(1<<iopIncEnable) ; set increment enable
|
|
|
|
|
|
|
|
;__________________________________________________________________________________________
|
|
;
|
|
;
|
|
; The STP card has problems when accessing VIA's if the 601 instruction 'eieio' is not
|
|
; not used to force in order execution. Macro expands to nop only when conditional build
|
|
; flag forSTP601 is defined as TRUE. The 68k nop instruction is turned into an eieio
|
|
; instruction by the emulator.
|
|
;__________________________________________________________________________________________
|
|
|
|
MACRO
|
|
eieioSTP ; do nop if forSTP601 is set, emulator does eieio for 68k nop
|
|
if forSTPnop then
|
|
nop ; force write to complete
|
|
endif
|
|
ENDM
|
|
|
|
|
|
;__________________________________________________________________________________________ <SAM>
|
|
; Enforce In-order Execution of I/O.
|
|
;
|
|
; This macro is for use on systems that have non-serialized memory-mapped I/O.
|
|
; It will order loads and stores ensuring that all previous storage accesses
|
|
; previously initiated by the processor are complete with respect to main storage.
|
|
;
|
|
; The macro will expand only if the build conditional "hasSerializedIO" is true. It will
|
|
; expand to a 68K "NOP" which the V0 emulator translates to a PowerPC "eieio" instrucion.
|
|
;__________________________________________________________________________________________
|
|
MACRO
|
|
eieio ; do nop if nonSerializedIO is set
|
|
if nonSerializedIO then
|
|
nop ; force writes to complete
|
|
endif
|
|
ENDM
|
|
|
|
|
|
|
|
|
|
;__________________________________________________________________________________________
|
|
;
|
|
;
|
|
; VIA1 or Equivalent Pin Definitions and Register Offsets - Multiple names for the same pin
|
|
; are grouped together. New definitions for VIA1 pins are added such that the grouping is
|
|
; maintained.
|
|
;
|
|
;
|
|
;__________________________________________________________________________________________
|
|
|
|
;---------------------------------------------------
|
|
; 6522 VIA1 (and VIA2) register offsets
|
|
;---------------------------------------------------
|
|
|
|
vBufB EQU 0 ; BUFFER B
|
|
vBufAH EQU $200 ; buffer a (with handshake) [ Dont use! ]
|
|
vDIRB EQU $400 ; DIRECTION B
|
|
vDIRA EQU $600 ; DIRECTION A
|
|
vT1C EQU $800 ; TIMER 1 COUNTER (L.O.)
|
|
vT1CH EQU $A00 ; timer 1 counter (high order)
|
|
vT1L EQU $C00 ; TIMER 1 LATCH (L.O.)
|
|
vT1LH EQU $E00 ; timer 1 latch (high order)
|
|
vT2C EQU $1000 ; TIMER 2 LATCH (L.O.)
|
|
vT2CH EQU $1200 ; timer 2 counter (high order)
|
|
vSR EQU $1400 ; SHIFT REGISTER
|
|
vACR EQU $1600 ; AUX. CONTROL REG.
|
|
vPCR EQU $1800 ; PERIPH. CONTROL REG.
|
|
vIFR EQU $1A00 ; INT. FLAG REG.
|
|
vIER EQU $1C00 ; INT. ENABLE REG.
|
|
vBufA EQU $1E00 ; BUFFER A
|
|
vBufD EQU vBufA ; disk head select is buffer A <3.5>
|
|
|
|
;---------------------------------------------------
|
|
; VIA IFR/IER bits
|
|
;---------------------------------------------------
|
|
|
|
ifCA2 EQU 0 ; CA2 interrupt
|
|
ifCA1 EQU 1 ; CA1 interrupt
|
|
ifSR EQU 2 ; SR shift register done
|
|
ifCB2 EQU 3 ; CB2 interrupt
|
|
ifCB1 EQU 4 ; CB1 interrupt
|
|
ifT2 EQU 5 ; T2 timer2 interrupt
|
|
ifT1 EQU 6 ; T1 timer1 interrupt
|
|
ifIRQ EQU 7 ; any interrupt
|
|
|
|
|
|
;---------------------------------------------------
|
|
; VIA1 Port A definitions
|
|
;---------------------------------------------------
|
|
|
|
vSound EQU $7 ; sound volume bits (0..2) (output)
|
|
|
|
vTestJ EQU 0 ; Burn In Test jumper (input)
|
|
|
|
vCpuId0 EQU 1 ; CPU Identification bit 0 (input)
|
|
vCpuId1 EQU 2 ; CPU Identification bit 1 (input)
|
|
vSync EQU 3 ; Synchronous modem
|
|
vOverlay EQU 4 ; overlay bit (overlay when 1)
|
|
vCpuId2 EQU 4 ; CPU Identification bit 2
|
|
vReqAEnable EQU 4 ; enable ReqA into vSCCWrReq (PSC only) <LW2>
|
|
vHeadSel EQU 5 ; head select line for Sony
|
|
vCpuId3 EQU 6 ; CPU Identification bit 3
|
|
vRev8Bd EQU 6 ; =0 for rev 8 board>
|
|
vReqBEnable EQU 6 ; enable ReqB into vSCCWrReq (PSC only) <LW2>
|
|
vSCCWrReq EQU 7 ; SCC write/request line
|
|
|
|
;---------------------------------------------------
|
|
; VIA1 Port B definitions
|
|
;---------------------------------------------------
|
|
|
|
vEclipseLED EQU 0 ; flashable Eclipse LED (how quaint!) <23>
|
|
vRTCData EQU 0 ; real time clock data
|
|
vRMP0 EQU 0 ; Reserved for RMP (PSC only)
|
|
vENetIDClk EQU 0 ; Ethernet ID ROM clock for Whitney <SM19>
|
|
vRTCClk EQU 1 ; real time clock clock pulses
|
|
vRMP1 EQU 1 ; Reserved for RMP (PSC only)
|
|
vENetIDData EQU 1 ; Ethernet ID ROM clock for Whitney <SM19>
|
|
vRTCEnb EQU 2 ; clock enable (0 for enable)
|
|
vRMP2 EQU 2 ; Reserved for RMP (PSC only)
|
|
vFDBInt EQU 3 ; Front Desk bus interrupt
|
|
vXcvrsesbit EQU 3 ; Egret transceiver session bit <6>
|
|
vSDMCable EQU 3 ; SCSI DiskMode cable sense for Dartanian <H15>
|
|
vCudaTREQ EQU 3 ; Cuda transaction request input <P2><SM4> rb
|
|
vSDMDiskID EQU 4 ; DiskMode HD ID (bits 4-6) for Dartanian <H15>
|
|
vFDesk1 EQU 4 ; Front Desk bus state bit 0
|
|
vViafullbit EQU 4 ; Egret via full bit <6>
|
|
vCudaBYTEACK EQU 4 ; Cuda byte acknowledge output <P2><SM4> rb
|
|
vFDesk2 EQU 5 ; Front Desk bus state bit 1
|
|
vSyssesbit EQU 5 ; Egret system session bit <6><SM4> rb
|
|
vCudaTIP EQU 5 ; Cuda interface transaction in progress output <P2>
|
|
vAUXIntEnb EQU 6 ; switch to A/UX interrupt scheme (output) <23>
|
|
vPGCEnb EQU 6 ; Parity Generator/Checker enable (0 for enable)
|
|
vJMPDude6 EQU 6 ; Reserved for JMP (PSC only)
|
|
vPGCErr EQU 7 ; Parity Generator/Checker error (input)
|
|
vSndEnb EQU 7 ; /sound enable (reset when 1) (output)
|
|
vSWInt EQU 7 ; cause a software interrupt (output) <23>
|
|
vJMPDude7 EQU 7 ; Reserved for JMP (PSC only)
|
|
|
|
|
|
|
|
;__________________________________________________________________________________________
|
|
;
|
|
;
|
|
; VIA2 or Equivalent Pin Definitions and Register Offsets - Multiple names for the same pin
|
|
; are grouped together. New definitions for VIA2 pins are added such that the grouping is
|
|
; maintained.
|
|
;
|
|
;
|
|
;__________________________________________________________________________________________
|
|
|
|
;---------------------------------------------------
|
|
; VIA2 Port A definitions
|
|
;---------------------------------------------------
|
|
|
|
v2IRQ1 EQU 0 ; slot 1 interrupt
|
|
v2EnetIRQ EQU 0 ; on-board ethernet <8><23>
|
|
v2IRQ2 EQU 1 ; slot 2 interrupt
|
|
v2IRQ3 EQU 2 ; slot 3 interrupt
|
|
v2IRQ4 EQU 3 ; slot 4 interrupt
|
|
v2IRQ5 EQU 4 ; slot 5 interrupt
|
|
v2IRQ6 EQU 5 ; slot 6 interrupt
|
|
v2RAM0 EQU 6 ; RAM size bit 0
|
|
v2LCDIRQ EQU 6 ; on-board LCD video
|
|
v2VideoIRQ EQU 6 ; on-board video <8><23>
|
|
v2RAM1 EQU 7 ; RAM size bit 1
|
|
v2CardIn EQU 7 ; on-board video
|
|
v2SyncOnGreen EQU 7 ; for enabling/disabling Sync-on-Green (DAFB) <T20>
|
|
|
|
;---------------------------------------------------
|
|
; VIA2 Port B definitions
|
|
;---------------------------------------------------
|
|
|
|
v2ConfigLE EQU 0 ; DFAC config latch enable <T8>
|
|
v2CDis EQU 0 ; cache disable (when 1) <3.3>
|
|
v2Keyswitch EQU 0 ; 900/950 ONLY - keyswitch shadow bit (1=SECURE)<T14><T17><SM4> rb
|
|
v2BusLk EQU 1 ; Bus lockout
|
|
v2PMack EQU 1 ; Power manager handshake acknowledge
|
|
v2PowerOff EQU 2 ; soft power off signal (when 0)
|
|
; (also 900/950 keyswitch OFF bit) <T17><SM4> rb
|
|
v2PMreq EQU 2 ; Power manager handshake request
|
|
v2ConfigData EQU 3 ; DFAC config data <T8>
|
|
v2FC3 EQU 3 ; PMMU FC3 indicator
|
|
vFC3 EQU 3 ; PMMU FC3 indicator
|
|
v2SndInSel0 EQU 3 ; Eclipse only - sound input select bit 0 <t19><H17>
|
|
v2ConfigClk EQU 4 ; DFAC config clock <T8>
|
|
v2TM1A EQU 4 ; bit for NUBus
|
|
v2TM0A EQU 5 ; and another
|
|
v2Speed EQU 5 ; 25/33 Mhz 68040 input (0=25MHz, 1=33 MHz)
|
|
v2MicCtl EQU 5 ; microphone control on Wombats <H17><SM4> rb
|
|
v2HMMU EQU 5 ; HMMU 24/32 <15> HJR
|
|
v2CDis2 EQU 6 ; On Tim the CDIS is on pb6 <15> HJR
|
|
v2SndExt EQU 6 ; 1 = internal speaker, 0 = ext. audio
|
|
v2SndInSel1 EQU 6 ; Q900/950 only - sound input select bit 1 <t19><SM4> rb
|
|
v2VBL EQU 7 ; pseudo VBL signal
|
|
v2ModemRST EQU 7 ; Modem.Reset <15> HJR
|
|
|
|
|
|
|
|
; temporary Cyclone equates <SM4> rb, start, <SM5> rb
|
|
|
|
|
|
; <SM7> rb, ¥ TEMP EQUATES
|
|
|
|
CycloneEVT1Reg EQU $A55A2800 ; id which identifies an EVT1 cyclone in CPURegID <SM9> rb
|
|
PSCVIA2SIntEVT1 EQU $000 ; Slot interrupt reg. offset <SM9> rb
|
|
PSCVIA2IFREVT1 EQU $004 ; VIA2 interrupt flag reg. offset <SM9> rb
|
|
PSCVIA2IEREVT1 EQU $008 ; VIA2 interrupt enable reg. offset <SM9> rb
|
|
|
|
PSCVIA2SInt EQU $1E00 ; Slot interrupt reg. offset <SM7> rb
|
|
PSCVIA2IFR EQU $1A00 ; VIA2 interrupt flag reg. offset <SM7> rb
|
|
PSCVIA2IER EQU $1C00 ; VIA2 interrupt enable reg. offset <SM7> rb
|
|
|
|
|
|
; PSC VIA2 Slot Interrupt Register equates
|
|
PSCSlotC EQU 3 ; slot C int.
|
|
PSCSlotD EQU 4 ; slot D int.
|
|
PSCSlotE EQU 5 ; slot E int.
|
|
PSCOVBVBL EQU 6 ; on-board video vbl int.
|
|
|
|
; PSC VIA2 Interrupt Flag and Interrupt Enable Registers equates
|
|
PSCSCSI0 EQU 0 ; SCSI int., same as bit 3
|
|
PSCSlot EQU 1 ; any slot int.
|
|
PSCMUNI EQU 2 ; MUNI int.
|
|
PSCSCSI3 EQU 3 ; SCSI int.
|
|
PSCFDC EQU 5 ; floppy int.
|
|
PSCSNDFRM EQU 6 ; sound frame int.
|
|
PSCANY EQU 7 ; any of the above
|
|
|
|
; <SM4> rb, end, <SM5> rb
|
|
|
|
|
|
;----------
|
|
;RBV (Ram Based Video) register definitions
|
|
;----------
|
|
|
|
RvDataB EQU $000 ; VIA2 data reg. B equivalent <v1.4><2.5>
|
|
RvExp EQU $001 ; RBV Expansion Register <3>
|
|
RvSInt EQU $002 ; Slot interrupts reg. <v1.4><2.5>
|
|
RvIFR EQU $003 ; interrupt flag reg. <v1.4><2.5>
|
|
RvMonP EQU $010 ; monitor parameters reg. <v1.4><2.5>
|
|
RvChpT EQU $011 ; chip test reg. <v1.4><2.5>
|
|
RvSEnb EQU $012 ; Slot interrupt enable reg. <v1.4><2.5>
|
|
RvIER EQU $013 ; interrupt flag enable reg. <v1.4><2.5>
|
|
|
|
;----------
|
|
;Common Via 2 and RBV (Ram Based Video) register offsets
|
|
;----------
|
|
|
|
|
|
Rv2DataB EQU vBufB++RvDataB ; RBV/VIA2 data reg. B equivalent <H8>
|
|
Rv2Exp EQU RvExp ; RBV Expansion Register <H8>
|
|
Rv2SInt EQU RvSInt ; Slot interrupts reg. <H8>
|
|
Rv2IFR EQU vIFR++RvIFR ; RBV/VIA2 interrupt flag reg. <H8>
|
|
Rv2MonP EQU RvMonP ; monitor parameters reg. <H8>
|
|
Rv2ChpT EQU RvChpT ; chip test reg. <H8>
|
|
Rv2SEnb EQU RvSEnb ; Slot interrupt enable reg. <H8>
|
|
Rv2IER EQU vIER++RvIER ; iRBV/VIA2 interrupt enable reg. <H8>
|
|
|
|
|
|
; ====== VIA2 BufferB Equivalent Address: $50026000 ===== <v1.4>
|
|
RvCDis EQU 0 ; cache disable (when 1) <v1.4><3.3>
|
|
RvBusLk EQU 1 ; Bus lockout <v1.4>
|
|
RvPowerOff EQU 2 ; soft power off signal (when 0) <v1.4>
|
|
RvCFlush EQU 3 ; Flush external cache (when 0) <v1.4>
|
|
RvTM1A EQU 4 ; bit for NUBus <v1.4>
|
|
RvTM0A EQU 5 ; and another <v1.4>
|
|
RvSndExt EQU 6 ; 1 = internal speaker, 0 = ext. audio <v1.4>
|
|
; jack in use <v1.4>
|
|
RvPGCTest EQU 7 ; 1 = generate good parity, 0 = generate errors
|
|
|
|
; ====== Future Expansion Address: $50026001 ===== <v1.4>
|
|
|
|
; ====== Slot Interrupts Address: $50026002 ===== <v1.4>
|
|
RvIRQ1 EQU 0 ; slot 1 interrupt <v1.4>
|
|
RvIRQ2 EQU 1 ; slot 2 interrupt <v1.4>
|
|
RvIRQ3 EQU 2 ; slot 3 interrupt <v1.4>
|
|
RvIRQ4 EQU 3 ; slot 4 interrupt <v1.4>
|
|
RvIRQ5 EQU 4 ; slot 5 interrupt <v1.4>
|
|
RvIRQ6 EQU 5 ; slot 6 interrupt <v1.4>
|
|
RvIRQ0 EQU 6 ; slot 0 interrupt or internal video <v1.4>
|
|
; blanking interrupt <v1.4>
|
|
;RvResr EQU 7 ; reserved <v1.4>
|
|
|
|
; ====== Interrupt Flags Address: $50026003 ===== <v1.4>
|
|
RvSCSIDRQ EQU 0 ; 1 = SCSI DRQ interrupt <v1.4>
|
|
RvAnySlot EQU 1 ; 1 = any slot(0-6).IRQ int <v1.4>
|
|
RvExpIRQ EQU 2 ; 1 = expansion int. (reserved) <v1.4>
|
|
RvSCSIRQ EQU 3 ; 1 = SCSI IRQ interrupt <v1.4>
|
|
RvSndIRQ EQU 4 ; 1 = Apple Sound Chip interrup <v1.4>
|
|
;RvResr EQU 5 ; reserved <v1.4>
|
|
;RvResr EQU 6 ; reserved <v1.4>
|
|
;RvSetClr EQU 7 ; on READ, 1 = any enable interrupt <v1.4>
|
|
; on WRITE, 1 = 1-bits in bits 0-6 write 1's<v1.4>
|
|
; 0 = 1-bits in bits 0-6 write 0's<v1.4>
|
|
|
|
; ====== Monitor Parameters Address: $50026010 ===== <v1.4>
|
|
RvColor1 EQU 0 ; (lsb) R/W 000 = 1bit, 001 = 2 bit <v1.4>
|
|
RvColor2 EQU 1 ; R/W 010 = 4bit, 011 = 8 bit <v1.4>
|
|
RvColor3 EQU 2 ; (msb) Read 1xx = Reserved <v1.4>
|
|
RvMonID1 EQU 3 ; READ 000,011,100=reserved; x01=15" monitor<v1.4>
|
|
RvMonID2 EQU 4 ; 010=Mod'IIGSmonitor;110=MacII monitors <v1.4>
|
|
RvMonID3 EQU 5 ; 111= 9" build in monitor <v1.4>
|
|
RvVIDOff EQU 6 ; 1 = Video off <v1.4>
|
|
RvVID3St EQU 7 ; 1 = all video outputs tri-stated <v1.4>
|
|
|
|
; ====== Chip Test Address: $50026011 ===== <v1.4>
|
|
RvC60 EQU 0 ; 1 = C60 clock run 128 x normal <v1.4>
|
|
RvSpd1 EQU 1 ; (lsb) 00 = normal, 01=medium <v1.4>
|
|
RvSpd2 EQU 2 ; (msb) 10 = fast, 11 = very fast <v1.4>
|
|
RvHndShk3 EQU 3 ; 1=VID.REQ & VID.RES tri-stated <v1.4>
|
|
RvIOClk3 EQU 4 ; 1=C16M, C8M, C3.7M tri-stated <v1.4>
|
|
RvC30M EQU 5 ; 1=30.24 mHz clock for all monitors <v1.4>
|
|
RvSDTClk EQU 6 ; 1 = Dot clock halted <v1.4>
|
|
RvTstRes EQU 7 ; 1 = reset video counters <v1.4>
|
|
|
|
; ====== Slot Interrupts Enable Address: $50026012 ===== <v1.4>
|
|
RvIRQ1En EQU 0 ; slot 1 interrupt enabled <v1.4>
|
|
RvIRQ2En EQU 1 ; slot 2 interrupt enabled <v1.4>
|
|
RvIRQ3En EQU 2 ; slot 3 interrupt enabled <v1.4>
|
|
RvIRQ4En EQU 3 ; slot 4 interrupt enabled <v1.4>
|
|
RvIRQ5En EQU 4 ; slot 5 interrupt enabled <v1.4>
|
|
RvIRQ6En EQU 5 ; slot 6 interrupt enabled <v1.4>
|
|
RvIRQ0En EQU 6 ; slot 0 interrupt or internal video enabled<v1.4>
|
|
;RvSetClr EQU 7 ; on READs, always reads 0 <v1.4>
|
|
; on WRITEs, 1 = 1-bits in bits 0-6 write 1's<v1.4>
|
|
; 0 = 1-bits in bits 0-6 write 0's<v1.4>
|
|
|
|
; ====== Interrupt Flags Enable Address: $50026013 =====
|
|
RvSCSIDRQEn EQU 0 ; 1 = SCSI DRQ interrupt enabled <v1.4>
|
|
RvAnySlotEn EQU 1 ; 1 = any slot(0-6).IRQ int. enabled <v1.4>
|
|
RvExpIRQEn EQU 2 ; 1 = expansion int. (reserved) enabled <v1.4>
|
|
RvSCSIRQEn EQU 3 ; 1 = SCSI IRQ interrupt enabled <v1.4>
|
|
RvSndIRQEn EQU 4 ; 1 = Apple Sound Chip interrupt enabled <v1.4>
|
|
;RvResr EQU 5 ; reserved <v1.4>
|
|
;RvResr EQU 6 ; reserved <v1.4>
|
|
;RvSetClr EQU 7 ; on READs, always reads 1 <v1.4>
|
|
; on WRITEs, 1 = 1-bits in bits 0-6 write 1's<v1.4>
|
|
; 0 = 1-bits in bits 0-6 write 0's<v1.4>
|
|
|
|
;----------
|
|
; VDAC register definitions
|
|
;----------
|
|
|
|
vDACwAddReg EQU $0000 ; offset from vDACBase for write address reg
|
|
vDACrAddReg EQU $000C ; offset from vDACBase for read address register <v4.2>
|
|
vDACwDataReg EQU $0004 ; offset from vDACBase for write data reg
|
|
|
|
vDACPixRdMask EQU $0008 ; offset from vDACBase for pixel mask
|
|
|
|
|
|
;__________________________________________________________________________________________
|
|
;
|
|
;
|
|
; VISA Pin Definitions and Register Offsets - Multiple names for the same pin are grouped
|
|
; together. New definitions for VISA pins are added such that the grouping is maintained.
|
|
;
|
|
;
|
|
;__________________________________________________________________________________________
|
|
|
|
|
|
;----------
|
|
; VISA register definitions - generally, these equates are a precise subset
|
|
; of the RBV equates.
|
|
;----------
|
|
|
|
; these registers are accessed off of VIA1 lomem
|
|
VsData1A EQU $1E00 ; VIA1 data reg A
|
|
VsData1B EQU $0000 ; VIA1 data reg B
|
|
|
|
; these registers are accessed off of VISA lomem
|
|
VsData2B EQU $000 ; VIA2 data reg B equivalent
|
|
VsExp EQU $001 ; VISA Expansion Register
|
|
VsSInt EQU $002 ; Slot Interrupt Register
|
|
VsIFR EQU $003 ; Interrupt Flag Register
|
|
VsMonP EQU $010 ; Monitor Parameters Register
|
|
VsSEnb EQU $012 ; Slot Interrupt Enable Register
|
|
VsIER EQU $013 ; Interrupt Flag Enable Register
|
|
|
|
; ====== VIA2 BufferB Equivalent Address: $50026000 =====
|
|
;*VsResr EQU 0 ; reserved
|
|
;*VsResr EQU 1 ; reserved
|
|
;*VsResr EQU 2 ; reserved
|
|
VsFC3 EQU 3 ; select 32-bit map. 0=24 bit, 1=32 bit
|
|
;*VsResr EQU 4 ; reserved
|
|
;*VsResr EQU 5 ; reserved
|
|
VsSndExt EQU 6 ; Always reads as 1 - play sounds in Mono
|
|
;*VsResr EQU 7 ; reserved
|
|
|
|
; ====== Future Expansion Address: $50026001 =====
|
|
VsA2Mode EQU 0 ; 0=512*384 mode, 1=560*384 mode
|
|
VsVResEn EQU 1 ; 1=enable vertical counter reset for video genlock
|
|
VsFlWrEn EQU 2 ; 1=enable writes to flash EEPROM
|
|
Vs1BV EQU 3 ; 1=low base for 1-bit mode, 0=high base
|
|
VsPg2 EQU 4 ; 1=main video page, 0=sec video page
|
|
;*VsResr EQU 5 ; reserved
|
|
VsSiz0 EQU 6 ; RAM size control bit 00=1MB, 01=1.5MB
|
|
VsSiz1 EQU 7 ; 10=3MB,11=9MB
|
|
|
|
; ====== Slot Interrupts Address: $50026002 =====
|
|
;*VsResr EQU 0 ; reserved
|
|
;*VsResr EQU 1 ; reserved
|
|
;*VsResr EQU 2 ; reserved
|
|
;*VsResr EQU 3 ; reserved
|
|
;*VsResr EQU 4 ; reserved
|
|
VsSIRQ EQU 5 ; expansion slot interrupt
|
|
VsVBLInt EQU 6 ; slot zero (built-in) VBL interrupt
|
|
;*VsResr EQU 7 ; reserved
|
|
|
|
|
|
; ====== Interrupt Flags Address: $50026003 =====
|
|
VsSCSIDRQ EQU 0 ; 1 = SCSI DRQ interrup
|
|
VsAnySlot EQU 1 ; 1 = any slot(0-6).IRQ int
|
|
;*VsResr EQU 2 ; reserved
|
|
VsSCSIRQ EQU 3 ; 1 = SCSI IRQ interrupt
|
|
VsSndIRQ EQU 4 ; 1 = Apple Sound Chip interrupt
|
|
;RvResr EQU 5 ; reserved
|
|
;RvResr EQU 6 ; reserved
|
|
RvSetClr EQU 7 ; on READ, 1 = any enabled interrupt
|
|
; on WRITE, 1 = 1-bits in bits 0-6 write 1's
|
|
; 0 = 1-bits in bits 0-6 write 0's
|
|
|
|
; ====== Monitor Parameters Address: $50026010 =====
|
|
;*VsResr EQU 0 ; (lsb)
|
|
VsColor EQU 1 ; (compat w/RBV) R/W 000 = 1bit, R/W 010 = 4bit
|
|
;*VsResr EQU 2 ; (msb)
|
|
VsMonConn EQU 3 ; (lsb)1=no monitor connected
|
|
;*VsResr EQU 4 ; (compat w/RBV)
|
|
VsMonSel EQU 5 ; (msb) Monitor select 1=Jersey, 0=Rubik
|
|
;*VsResr EQU 6 ; reserved
|
|
;*VsResr EQU 7 ; reserved
|
|
|
|
|
|
; ====== Slot Interrupts Enable Address: $50026012 =====
|
|
;*VsResr EQU 0 ; reserved
|
|
;*VsResr EQU 1 ; reserved
|
|
;*VsResr EQU 2 ; reserved
|
|
;*VsResr EQU 3 ; reserved
|
|
;*VsResr EQU 4 ; reserved
|
|
VsExtIRQEn EQU 5 ; expansion slot interrupt enabled
|
|
VsIntIRQEn EQU 6 ; internal video interrupt enabled
|
|
VsSetClr EQU 7 ; on READs, always reads 0
|
|
; on WRITEs, 1 = 1-bits in bits 0-6 write 1's
|
|
; 0 = 1-bits in bits 0-6 write 0's
|
|
|
|
; ====== Interrupt Flags Enable Address: $50026013 =====
|
|
VsSCSIDRQEn EQU 0 ; 1 = SCSI DRQ interrupt enabled
|
|
VsAnySlotEn EQU 1 ; 1 = any slot(0-6).IRQ int. enabled
|
|
;*VsResr EQU 2 ; reserved
|
|
VsSCSIRQEn EQU 3 ; 1 = SCSI IRQ interrupt enabled
|
|
VsSndIRQEn EQU 4 ; 1 = Apple Sound Chip interrupt enabled
|
|
;VsResr EQU 5 ; reserved
|
|
;VsResr EQU 6 ; reserved
|
|
;RvSetClr EQU 7 ; on READs, always reads 1
|
|
; on WRITEs, 1 = 1-bits in bits 0-6 write 1's
|
|
; 0 = 1-bits in bits 0-6 write 0's
|
|
|
|
|
|
;----------
|
|
; V8 register definitions - generally compatible with the VISA equates above, but a few equates
|
|
; have changed names.
|
|
;----------
|
|
|
|
; these registers are accessed off of the V8 lomem
|
|
V8Exp EQU $001 ; V8 Expansion Register
|
|
V8SInt EQU $002 ; V8 Slot Interrupt Register
|
|
V8MonP EQU $010 ; Monitor Parameters Register
|
|
V8SEnb EQU $012 ; Slot Interrupt Enable Register
|
|
|
|
; ====== Future Expansion Address: $50F26001 =====
|
|
V8A2Mode EQU 0 ; 0=512*384 mode, 1=560*384 mode
|
|
V8512Row EQU 1 ; 1=V8 rowbytes is 256, 0=rowbytes is 512
|
|
V8vRAMIn EQU 2 ; 1=refresh video from vRAM, 0=refresh from dRAM
|
|
;*V8Resr EQU 3 ; no 1BV on V8
|
|
;*V8Resr EQU 4 ; no VP2 on V8
|
|
V8Siz0 EQU 5 ; RAM size control bit 0
|
|
V8Siz1 EQU 6 ; RAM size control bit 1
|
|
V8Siz2 EQU 7 ; RAM size control bit 2
|
|
|
|
; ====== Monitor Parameters Address: $50F26010 =====
|
|
V8Col0 EQU 0 ; Video depth control bit 0
|
|
V8Col1 EQU 1 ; Video depth control bit 1
|
|
V8Col2 EQU 2 ; Video depth control bit 2
|
|
V8MonID1 EQU 3 ; Monitor sense ID bit 1
|
|
V8MonID2 EQU 4 ; Monitor sense ID bit 2
|
|
V8MonID3 EQU 5 ; Monitor sense ID bit 3
|
|
;*VsResr EQU 6 ; reserved
|
|
;*VsResr EQU 7 ; reserved
|
|
|
|
; ====== Slot Interrupts Enable Address: $50F26012 =====
|
|
;*V8Resr EQU 0 ; reserved
|
|
;*V8Resr EQU 1 ; reserved
|
|
;*V8Resr EQU 2 ; reserved
|
|
;*V8Resr EQU 3 ; reserved
|
|
;*V8Resr EQU 4 ; reserved
|
|
V8ExtIRQEn EQU 5 ; expansion slot interrupt enabled
|
|
V8IntIRQEn EQU 6 ; internal video interrupt enabled
|
|
;*V8Resr EQU 7 ; reserved
|
|
|
|
|
|
;----------
|
|
; Elsie VDAC register definitions
|
|
;----------
|
|
|
|
; VISA/Bt450 registers
|
|
|
|
VsDACwAddReg EQU $0000 ; offset from vDACBase for write address reg
|
|
VsDACwDataReg EQU $0001 ; offset from vDACBase for write data reg
|
|
|
|
; V8/Ariel registers
|
|
|
|
V8DACrAddReg EQU $0000 ; offset for read address reg
|
|
V8DACwAddReg EQU $0000 ; offset for write address reg
|
|
V8DACrDataReg EQU $0001 ; offset for read data reg
|
|
V8DACwDataReg EQU $0001 ; offset for write data reg
|
|
V8DACrCntlReg EQU $0002 ; offset for read control reg
|
|
V8DACwCntlReg EQU $0002 ; offset for write control reg
|
|
V8DACrKeyReg EQU $0003 ; offset for read key color reg
|
|
V8DACwKeyReg EQU $0003 ; offset for write key color reg
|
|
|
|
V8vRAMBase EQU $50F40000 ; base address of V8 VRAM, if present
|
|
|
|
; End of VISA changes <4> <cv>
|
|
|
|
|
|
;----------
|
|
; DAFB register definitions (offsets from DAFBBase in ProductInfo) ($F980 0000)
|
|
;----------
|
|
|
|
DAFB_BaseOffset EQU $0 ; DAFB offset from DAFBBase
|
|
DAFB_ParmSize EQU $5 ; size of DAFB programmed subset
|
|
DAFB_NumRegs Equ (16-4) ; Number of DAFB registers (Color Regs are really vRAM).
|
|
|
|
DAFB_VidBaseHi EQU $0 ; DAFB video base address, bits 20:9
|
|
DAFB_VidBaseLo EQU $4 ; DAFB video base address, bits 8:5 (4:0 always zero)
|
|
DAFB_RowWords EQU $8 ; DAFB rowlongs size
|
|
DAFB_ClkCfg EQU $C ; DAFB clock configuration
|
|
DAFB_Config EQU $10 ; DAFB general configuration
|
|
DAFB_BlkWrtEn EQU $14 ; DAFB block write enable
|
|
DAFB_PgMdEn EQU $18 ; DAFB page mode enable
|
|
DAFB_Sense EQU $1C ; DAFB sense line
|
|
DAFB_Reset EQU $20 ; DAFB reset control
|
|
DAFB_SCSIch0 EQU $24 ; Turbo SCSI channel 0 control (not used)
|
|
DAFB_SCSIch1 EQU $28 ; Turbo SCSI channel 1 control (not used)
|
|
DAFB_Test EQU $2C ; DAFB test control
|
|
|
|
DAFB_CRB0 EQU $30 ; vRAM Color Register, bank 0
|
|
DAFB_CRB1 EQU $34 ; vRAM Color Register, bank 1
|
|
DAFB_CRB2 EQU $38 ; vRAM Color Register, bank 2
|
|
DAFB_CRB3 EQU $3C ; vRAM Color Register, bank 3
|
|
|
|
;----------
|
|
; Swatch (in DAFB) register definitions (offsets from DAFBBase in ProductInfo)
|
|
;----------
|
|
|
|
Swatch_BaseOffset EQU $100 ; Swatch offset from DAFBBase
|
|
Swatch_BaseOffset1 EQU $124 ; parameter offset
|
|
Swatch_ParmSize1 EQU $12 ; size of Swatch parameter list
|
|
; ¥¥¥ This number is off by 2, we think. BG/NJV
|
|
; Swatch_NumRegs Equ 30 ; Number of Swatch registers.
|
|
Swatch_NumRegs Equ 28 ; Number of Swatch registers.
|
|
|
|
Swatch_Mode EQU $100 ; Swatch general control
|
|
Swatch_IntMsk EQU $104 ; Swatch interrupt control
|
|
Swatch_IntStat EQU $108 ; Swatch interrupt status
|
|
Swatch_ClrCrsrInt EQU $10C ; Swatch clear cursor interrupt (not used in this form)
|
|
Swatch_ClrAnimInt EQU $110 ; Swatch clear animation interrupt (not used in this form)
|
|
Swatch_ClrVBLInt EQU $114 ; Swatch clear VBL interrupt (not used in this form)
|
|
Swatch_CrsrLine EQU $118 ; Swatch cursor interrupt trigger line
|
|
Swatch_AnimLine EQU $11C ; Swatch animation interrupt trigger line
|
|
Swatch_Test EQU $120 ; Swatch counter test
|
|
Swatch_HSyncRegs EQU $124 ; Swatch horizontal sync registers (set as a group)
|
|
Swatch_HSerr Equ $124 ; HSerr
|
|
Swatch_Hlfln Equ $128 ; Hlfln
|
|
Swatch_HEq Equ $12C ; HEq
|
|
Swatch_HSP Equ $130 ; HSP
|
|
Swatch_HBWay Equ $134 ; HBWay
|
|
Swatch_HBrst Equ $138 ; HBrst
|
|
Swatch_HBP Equ $13C ; HBP
|
|
Swatch_HAL Equ $140 ; HAL
|
|
Swatch_HFP Equ $144 ; HFP
|
|
Swatch_HPix Equ $148 ; HPix
|
|
Swatch_VSyncRegs EQU $14C ; Swatch vertical sync registers (set as a group)
|
|
Swatch_VHLine Equ $14C ; VHLine
|
|
Swatch_VSync Equ $150 ; VSync
|
|
Swatch_VBPEq Equ $154 ; VBPEq
|
|
Swatch_VBP Equ $158 ; VBP
|
|
Swatch_VAL Equ $15C ; VAL
|
|
Swatch_VFP Equ $160 ; VFP
|
|
Swatch_VFPEq Equ $164 ; VFPEq
|
|
Swatch_TimeAdj EQU $168 ; Swatch miscellaneous timing adjust
|
|
Swatch_ActLine EQU $16C ; Swatch active video line (read-only)
|
|
|
|
;----------
|
|
; ACDC register definitions (offsets from DAFBBase in ProductInfo, also in vDACBase)
|
|
;----------
|
|
|
|
ACDC_AddrReg EQU $200 ; set position in ACDC internal RAM
|
|
ACDC_DataReg EQU $210 ; read/write data in ACDC internal RAM
|
|
ACDC_ConfigReg EQU $220 ; ACDC offset from DAFBBase
|
|
ACDC_ParmSize EQU $1 ; size of ACDC parameter list
|
|
|
|
|
|
;----------
|
|
; National Clock Chip register definitions (offsets from DAFBBase in ProductInfo)
|
|
;----------
|
|
|
|
Clk_BaseOffset EQU $300 ; National offset from DAFBBase
|
|
Clk_ChipIntOffset EQU $C0 ; Clock Chip Interface offset from National offset from DAFBBase <H33>
|
|
Clk_ParmSize EQU $10 ; size of National parameter list
|
|
Clk_ParmSize1 Equ $0A ; (Once programmed, the last six bytes are always the same.)
|
|
|
|
;----------
|
|
; Misc. DAFB Parms
|
|
;----------
|
|
Misc_ParmSize Equ $4 ; Just for consistency with other DAFB parms.
|
|
|
|
|
|
;----------
|
|
; GSC register definitions (offsets from VDACAddr in ProductInfo) ($50F2 0000) <H5> jmp
|
|
;----------
|
|
GSCDeviceID Equ $00 ; Device revision register; read only.
|
|
GSCPanelID Equ $01 ; ÒSenselineÓ read/write register.
|
|
GSCPanelControl Equ $02 ; Switches r/w sense of PanelID reg.
|
|
GSCPanelSetup Equ $03 ; Panel intialization register.
|
|
GSCGrayScale Equ $04 ; The depth-switching register.
|
|
GSCPolyAdj Equ $05 ; Allows for grayscale adjustment.
|
|
GSCPanelAdj Equ $06 ; Allows for panel adjustment.
|
|
GSCACDClk Equ $07 ; Who knows?
|
|
GSCRefreshRate Equ $08 ; Refresh cycles per scanline.
|
|
GSCBlankShade Equ $09 ; Shade of gray for depth switches.
|
|
GSCPanelSkew Equ $0A ; Who knows?
|
|
|
|
GSCDiag0 Equ $1D ; Undocumented ÒdiagnosticÓ registers.
|
|
GSCDiag1 Equ $1E
|
|
GSCDiag2 Equ $1F
|
|
|
|
;----------
|
|
; CSC register definitions (offsets from VDACAddr in ProductInfo) ($50F2 0000) <H30> jmp
|
|
;----------
|
|
CSCDeviceID Equ $00 ; Device revision register; read only.
|
|
CSCPanelID Equ $02 ; ÒSenselineÓ register; read only.
|
|
CSCPanelIDControl Equ $04 ; Extended senseline control.
|
|
CSCPanelType Equ $06 ; Controls mono/color, size, etcÉ.
|
|
CSCPanelSetup Equ $08 ; Controls polarity, power, etcÉ.
|
|
CSCDataOutputForm Equ $0A ; Controls datapath output type.
|
|
CSCFRCControl Equ $0C ; ÒDACÓ control from CLUT for panel.
|
|
CSCPolyMAdj Equ $0E ; M adjustment for FRC.
|
|
CSCPolyNAdj Equ $10 ; N adjustment for FRC.
|
|
CSCDisplayDataForm Equ $12 ; 1,2,4,8,16 bpp.
|
|
CSCDisplayStatus Equ $14 ; IFR,IER,blanking.
|
|
CSCRefreshRate Equ $16 ; Controls refresh cycles per scanline.
|
|
CSCVRAMControl Equ $18 ; Controls VRAM clocking.
|
|
CSCHSkewHi Equ $1A ; Effectively, controls the horizontal
|
|
CSCHSkewLo Equ $1C ; timing.
|
|
CSCACDClkHi Equ $1E ; Effectively, controls the dot-clock
|
|
CSCACDClkLo Equ $20 ; timing.
|
|
CSCVSkewHi Equ $22 ; Effectively, control the vertical
|
|
CSCVSkewLo Equ $24 ; timing.
|
|
CSCMemConfig Equ $26 ; Controls addressing for type of VRAM.
|
|
CSCLPStart Equ $28 ; Controls start of timing diagram.
|
|
CSCLPWidth Equ $2A ; Controls width of timing diagram.
|
|
CSCFLMControl Equ $2C ; What does this do?
|
|
|
|
CSCFrstReg Equ CSCPanelType ; First CSC register we need to save/restore.
|
|
CSCLastReg Equ CSCFLMControl+2 ; Last CSC register we need to save/restore.
|
|
CSCNumRegs Equ ((CSCLastReg-CSCFrstReg)/2) ; Total number of registers to save/restore.
|
|
|
|
CSCGTweak Equ $3C ; For ÒtweakingÓ the gray-only panels.
|
|
|
|
CSCAddrRegW Equ $40 ; Sets the index of the NEXT Palette Write.
|
|
CSCAddrRegR Equ $46 ; Sets the index of the NEXT Palette Read.
|
|
CSCDataReg Equ $42 ; Accessed as an R-G-B tripple into the Palette.
|
|
|
|
CSCMaskReg Equ $44 ; Logically masks out video data; set to all $F's.
|
|
|
|
;----------
|
|
; Sonora register definitions (offsets from SonoraAddr in ProductInfo) ($50F0 0000) <H4><H6>
|
|
;----------
|
|
|
|
SonoraVIA2Base Equ $26000 ; Base address of VIA2
|
|
|
|
SonoraVIA2Data Equ $00 ; VIA2 Data Register
|
|
SonoraRAMSize EQU $01 ; DRAM config
|
|
SonoraSlotIFR Equ $02 ; Slot Interrupt Flags Register
|
|
SonoraVIA2IFR Equ $03 ; VIA2 Interrupt Flags Register
|
|
SonoraVRAMSize Equ $04 ; VRAM config
|
|
SonoraSpeedReg Equ $05 ; System CPU Speed (waitstate) Register
|
|
SonoraSlotIER Equ $12 ; Slot Interrupt Enable Register
|
|
SonoraVIA2IER Equ $13 ; Interrupt Flag Register
|
|
SonoraVdCtlBase Equ $28000 ; Base address of video control registers
|
|
|
|
SonoraVdModeReg Equ $00 ; Monitor code and video blanking register
|
|
SonoraVdColrReg Equ $01 ; Framebuffer pixel depth control register
|
|
SonoraVdSenseRg Equ $02 ; Senseline register
|
|
|
|
; Bits for Misc Sonora Regs
|
|
;
|
|
SonoraSetClr Equ 7 ; on WRITEs, 1 = 1-bits in bits 0-6 write 1's
|
|
; 0 = 1-bits in bits 0-6 write 0's
|
|
|
|
; Bits for SonoraSlotIER
|
|
;
|
|
SonoraVBLIRQEn Equ 6 ; Enable/Disable built-in video VBL
|
|
|
|
;----------
|
|
; Additional register definitions implemented in the Ardbeg variation of the Sonora chip <HK4><H31> thru next <H31>
|
|
;----------
|
|
|
|
ArdbegPwr EQU $00A ; Ardbeg chip Power Management register
|
|
|
|
;----------
|
|
; Power Management register bit definitions
|
|
;----------
|
|
ArdbegPwrSaver EQU 0 ; 1=Monitor power saver mode enabled (monitor power is off) <H31>
|
|
|
|
;----------
|
|
; Ariel register definitions (offsets from VDACAddr in ProductInfo) ($50F2 4000) <H6>
|
|
;----------
|
|
ArielAddrReg Equ 0 ; Offset to r/w address register
|
|
ArielDataReg Equ 1 ; Offset to r/w data register
|
|
ArielConfigReg Equ 2 ; Offset to r/w control register
|
|
ArielKeyReg Equ 3 ; Offset to r/w key color register
|
|
|
|
;----------
|
|
; FIFO Memory Definitions for Whitney/Hardrock machines
|
|
;----------
|
|
FIFOMEM_BASE Equ $50F24000 ; Logical address assignment for base of FIFO's
|
|
FIFO_0_OFFSET Equ (16*1024)
|
|
FIFO_1_OFFSET Equ (32*1024)
|
|
FIFO_2_OFFSET Equ (48*1024)
|
|
|
|
;----------
|
|
; Whitney register definitions <ged>
|
|
;----------
|
|
|
|
WhitneyPwrCtl Equ $50F96000 ; Whitney power control register
|
|
WhitneyRev Equ $50F96004 ; Whitney revision register
|
|
|
|
;----------
|
|
; Whitney power register bit definitions <K4>
|
|
;----------
|
|
|
|
WhitneySCCclk equ 7 ; 1 = SCC pClk forced low
|
|
WhitneyInt3En equ 6 ; 1 = MDM_IRQ_L causes level 3 interrupt
|
|
WhitneySWIMclk equ 5 ; 1 = Swim clock forced low
|
|
WhitneySWIMReset equ 4 ; 0 = reset SWIM chip
|
|
WhitneyKEYclk equ 3 ; 1 = KEY_C16 forced low
|
|
WhitneySCCpwr equ 2 ; 1 = power off serial driver chip
|
|
WhitneyEnetReset equ 1 ; 0 = reset SONIC chip
|
|
WhitneyEnetPwr equ 0 ; 1 = power off Sonic chip
|
|
;----------
|
|
; MMC register definitions (offsets from MMCAddr in ProductInfo) ($50F3 0400) <P2><SM4> rb, start
|
|
;----------
|
|
|
|
MMC_DRAMspeed0 EQU $00 ; DRAM timing register 0 [M0].
|
|
MMC_DRAMspeed1 EQU $04 ; DRAM timing register 1 [M1].
|
|
|
|
MMC_CPUspeed0 EQU $08 ; Clock speed 0 [M2].
|
|
MMC_CPUspeed1 EQU $0C ; Clock speed 1 [M3].
|
|
|
|
MMC_ROMspeed0 EQU $10 ; ROM cycle time 0 [M4].
|
|
MMC_ROMspeed1 EQU $14 ; ROM cycle time 1 [M5].
|
|
MMC_ROMspeed2 EQU $18 ; ROM cycle time 2 [M6].
|
|
|
|
MMC_DSPspeed EQU $1C ; DSP clock speed [M7].
|
|
|
|
MMC_DRAMwidth0 EQU $20 ; DRAM width 0 [M8].
|
|
MMC_DRAMwidth1 EQU $24 ; DRAM width 1 [M9].
|
|
MMC_DRAMwidth2 EQU $28 ; DRAM width 2 [M10].
|
|
MMC_DRAMwidth3 EQU $2C ; DRAM width 3 [M11].
|
|
|
|
MMC_EPROMmode EQU $30 ; EPROM mode [M12].
|
|
|
|
MMC_DRAMrange2 EQU $34 ; DRAM bank range 0 [M13].
|
|
MMC_DRAMrange1 EQU $38 ; DRAM bank range 1 [M14].
|
|
MMC_DRAMrange0 EQU $3C ; DRAM bank range 2 [M15].
|
|
|
|
MMC_CPUID0 EQU $40 ; CPU ID 0 [M16].
|
|
MMC_CPUID1 EQU $44 ; CPU ID 1 [M17].
|
|
|
|
MMC_ClockSelect EQU $48 ; Endeavor Input Clock Select (NTSC/PAL) [M18].
|
|
|
|
MMC_Bypass EQU $4C ; RGB or Composite bypass [M19].
|
|
|
|
;----------
|
|
; YMCA register definitions (offsets from YMCAAddr in ProductInfo) ($50F3 0400) <SM16> fau, start
|
|
;----------
|
|
YMCABase EQU $50F30400 ; Used in YMCASizeBank 'cause we ran out of registers. <SM17>
|
|
YMCAMaxSize EQU 5 ; Maximum value that can be programed into the size registers
|
|
BankBdryRegSize EQU 7 ; Size in bits of the boundary registers
|
|
BankSizeRegSize EQU 3 ; Size in bits of the size register
|
|
|
|
YMCA_DRAMspeed0 EQU $00 ; DRAM timing register 0 [M0].
|
|
YMCA_DRAMspeed1 EQU $04 ; DRAM timing register 1 [M1].
|
|
|
|
YMCA_CPUspeed0 EQU $08 ; Clock speed 0 [M2].
|
|
YMCA_CPUspeed1 EQU $0C ; Clock speed 1 [M3].
|
|
|
|
YMCA_ROMspeed0 EQU $10 ; ROM cycle time 0 [M4].
|
|
YMCA_ROMspeed1 EQU $14 ; ROM cycle time 1 [M5].
|
|
YMCA_ROMspeed2 EQU $18 ; ROM cycle time 2 [M6].
|
|
|
|
YMCA_DSPspeed EQU $1C ; DSP clock speed [M7].
|
|
|
|
YMCA_DRAMwidth0 EQU $20 ; DRAM width 0 [M8].
|
|
YMCA_DRAMwidth1 EQU $24 ; DRAM width 1 [M9].
|
|
YMCA_DRAMwidth2 EQU $28 ; DRAM width 2 [M10].
|
|
YMCA_DRAMwidth3 EQU $2C ; DRAM width 3 [M11].
|
|
|
|
YMCA_EPROMmode EQU $30 ; EPROM mode [M12].
|
|
|
|
YMCA_040Mode EQU $34 ; 040 Special Mode [M13].
|
|
|
|
YMCA_CPUID0 EQU $38 ; CPU ID 0 [M14].
|
|
YMCA_CPUID1 EQU $3C ; CPU ID 1 [M15].
|
|
YMCA_CPUID2 EQU $40 ; CPU ID 2 [M16].
|
|
YMCA_CPUID3 EQU $44 ; CPU ID 3 [M17].
|
|
|
|
YMCA__ClockSelect EQU $48 ; Endeavor Input Clock Select [M18].
|
|
YMCA_Bypass EQU $4C ; Composite out or RGB [M19].
|
|
|
|
YMCA_DRAMBank0_A20 EQU $50 ; DRAM Bank0 Addr A20 [M20].
|
|
YMCA_DRAMBank0_A21 EQU $54 ; DRAM Bank0 Addr A21 [M21].
|
|
YMCA_DRAMBank0_A22 EQU $58 ; DRAM Bank0 Addr A22 [M22].
|
|
YMCA_DRAMBank0_A23 EQU $5C ; DRAM Bank0 Addr A23 [M23].
|
|
YMCA_DRAMBank0_A24 EQU $60 ; DRAM Bank0 Addr A24 [M24].
|
|
YMCA_DRAMBank0_A25 EQU $64 ; DRAM Bank0 Addr A25 [M25].
|
|
YMCA_DRAMBank0_A26 EQU $68 ; DRAM Bank0 Addr A26 [M26].
|
|
YMCA_DRAMBank0_Sz0 EQU $6C ; DRAM Bank0 Size 0 [M27].
|
|
YMCA_DRAMBank0_Sz1 EQU $70 ; DRAM Bank0 Size 1 [M28].
|
|
YMCA_DRAMBank0_Sz2 EQU $74 ; DRAM Bank0 Size 2 [M29].
|
|
|
|
YMCA_DRAMBank1_A20 EQU $78 ; DRAM Bank1 Addr A20 [M30].
|
|
YMCA_DRAMBank1_A21 EQU $7C ; DRAM Bank1 Addr A21 [M31].
|
|
YMCA_DRAMBank1_A22 EQU $80 ; DRAM Bank1 Addr A22 [M32].
|
|
YMCA_DRAMBank1_A23 EQU $84 ; DRAM Bank1 Addr A23 [M33].
|
|
YMCA_DRAMBank1_A24 EQU $88 ; DRAM Bank1 Addr A24 [M34].
|
|
YMCA_DRAMBank1_A25 EQU $8C ; DRAM Bank1 Addr A25 [M35].
|
|
YMCA_DRAMBank1_A26 EQU $90 ; DRAM Bank1 Addr A26 [M36].
|
|
YMCA_DRAMBank1_Sz0 EQU $94 ; DRAM Bank1 Size 0 [M37].
|
|
YMCA_DRAMBank1_Sz1 EQU $98 ; DRAM Bank1 Size 1 [M38].
|
|
YMCA_DRAMBank1_Sz2 EQU $9C ; DRAM Bank1 Size 2 [M39].
|
|
|
|
YMCA_DRAMBank2_A20 EQU $A0 ; DRAM Bank2 Addr A20 [M40].
|
|
YMCA_DRAMBank2_A21 EQU $A4 ; DRAM Bank2 Addr A21 [M41].
|
|
YMCA_DRAMBank2_A22 EQU $A8 ; DRAM Bank2 Addr A22 [M42].
|
|
YMCA_DRAMBank2_A23 EQU $AC ; DRAM Bank2 Addr A23 [M43].
|
|
YMCA_DRAMBank2_A24 EQU $B0 ; DRAM Bank2 Addr A24 [M44].
|
|
YMCA_DRAMBank2_A25 EQU $B4 ; DRAM Bank2 Addr A25 [M45].
|
|
YMCA_DRAMBank2_A26 EQU $B8 ; DRAM Bank2 Addr A26 [M46].
|
|
YMCA_DRAMBank2_Sz0 EQU $BC ; DRAM Bank2 Size 0 [M47].
|
|
YMCA_DRAMBank2_Sz1 EQU $C0 ; DRAM Bank2 Size 1 [M48].
|
|
YMCA_DRAMBank2_Sz2 EQU $C4 ; DRAM Bank2 Size 2 [M49].
|
|
|
|
YMCA_DRAMBank3_A20 EQU $C8 ; DRAM Bank3 Addr A20 [M50].
|
|
YMCA_DRAMBank3_A21 EQU $CC ; DRAM Bank3 Addr A21 [M51].
|
|
YMCA_DRAMBank3_A22 EQU $D0 ; DRAM Bank3 Addr A22 [M52].
|
|
YMCA_DRAMBank3_A23 EQU $D4 ; DRAM Bank3 Addr A23 [M53].
|
|
YMCA_DRAMBank3_A24 EQU $D8 ; DRAM Bank3 Addr A24 [M54].
|
|
YMCA_DRAMBank3_A25 EQU $DC ; DRAM Bank3 Addr A25 [M55].
|
|
YMCA_DRAMBank3_A26 EQU $E0 ; DRAM Bank3 Addr A26 [M56].
|
|
YMCA_DRAMBank3_Sz0 EQU $E4 ; DRAM Bank3 Size 0 [M57].
|
|
YMCA_DRAMBank3_Sz1 EQU $E8 ; DRAM Bank3 Size 1 [M58].
|
|
YMCA_DRAMBank3_Sz2 EQU $EC ; DRAM Bank3 Size 2 [M59].
|
|
|
|
YMCA_DRAMBank4_A20 EQU $F0 ; DRAM Bank4 Addr A20 [M60].
|
|
YMCA_DRAMBank4_A21 EQU $F4 ; DRAM Bank4 Addr A21 [M61].
|
|
YMCA_DRAMBank4_A22 EQU $F8 ; DRAM Bank4 Addr A22 [M62].
|
|
YMCA_DRAMBank4_A23 EQU $FC ; DRAM Bank4 Addr A23 [M63].
|
|
YMCA_DRAMBank4_A24 EQU $100 ; DRAM Bank4 Addr A24 [M64].
|
|
YMCA_DRAMBank4_A25 EQU $104 ; DRAM Bank4 Addr A25 [M65].
|
|
YMCA_DRAMBank4_A26 EQU $108 ; DRAM Bank4 Addr A26 [M66].
|
|
YMCA_DRAMBank4_Sz0 EQU $10C ; DRAM Bank4 Size 0 [M67].
|
|
YMCA_DRAMBank4_Sz1 EQU $110 ; DRAM Bank4 Size 1 [M68].
|
|
YMCA_DRAMBank4_Sz2 EQU $114 ; DRAM Bank4 Size 2 [M69].
|
|
|
|
YMCA_DRAMBank5_A20 EQU $118 ; DRAM Bank5 Addr A20 [M70].
|
|
YMCA_DRAMBank5_A21 EQU $11C ; DRAM Bank5 Addr A21 [M71].
|
|
YMCA_DRAMBank5_A22 EQU $120 ; DRAM Bank5 Addr A22 [M72].
|
|
YMCA_DRAMBank5_A23 EQU $124 ; DRAM Bank5 Addr A23 [M73].
|
|
YMCA_DRAMBank5_A24 EQU $128 ; DRAM Bank5 Addr A24 [M74].
|
|
YMCA_DRAMBank5_A25 EQU $12C ; DRAM Bank5 Addr A25 [M75].
|
|
YMCA_DRAMBank5_A26 EQU $130 ; DRAM Bank5 Addr A26 [M76].
|
|
YMCA_DRAMBank5_Sz0 EQU $134 ; DRAM Bank5 Size 0 [M77].
|
|
YMCA_DRAMBank5_Sz1 EQU $138 ; DRAM Bank5 Size 1 [M78].
|
|
YMCA_DRAMBank5_Sz2 EQU $13C ; DRAM Bank5 Size 2 [M79].
|
|
|
|
YMCA_DRAMBank6_A20 EQU $140 ; DRAM Bank6 Addr A20 [M80].
|
|
YMCA_DRAMBank6_A21 EQU $144 ; DRAM Bank6 Addr A21 [M81].
|
|
YMCA_DRAMBank6_A22 EQU $148 ; DRAM Bank6 Addr A22 [M82].
|
|
YMCA_DRAMBank6_A23 EQU $14C ; DRAM Bank6 Addr A23 [M83].
|
|
YMCA_DRAMBank6_A24 EQU $150 ; DRAM Bank6 Addr A24 [M84].
|
|
YMCA_DRAMBank6_A25 EQU $154 ; DRAM Bank6 Addr A25 [M85].
|
|
YMCA_DRAMBank6_A26 EQU $158 ; DRAM Bank6 Addr A26 [M86].
|
|
YMCA_DRAMBank6_Sz0 EQU $15C ; DRAM Bank6 Size 0 [M87].
|
|
YMCA_DRAMBank6_Sz1 EQU $160 ; DRAM Bank6 Size 1 [M88].
|
|
YMCA_DRAMBank6_Sz2 EQU $164 ; DRAM Bank1 Size 2 [M89].
|
|
|
|
YMCA_DRAMBank7_A20 EQU $168 ; DRAM Bank7 Addr A20 [M90].
|
|
YMCA_DRAMBank7_A21 EQU $16C ; DRAM Bank7 Addr A21 [M91].
|
|
YMCA_DRAMBank7_A22 EQU $170 ; DRAM Bank7 Addr A22 [M92].
|
|
YMCA_DRAMBank7_A23 EQU $174 ; DRAM Bank7 Addr A23 [M93].
|
|
YMCA_DRAMBank7_A24 EQU $178 ; DRAM Bank7 Addr A24 [M94].
|
|
YMCA_DRAMBank7_A25 EQU $17C ; DRAM Bank7 Addr A25 [M95].
|
|
YMCA_DRAMBank7_A26 EQU $180 ; DRAM Bank7 Addr A26 [M96].
|
|
YMCA_DRAMBank7_Sz0 EQU $184 ; DRAM Bank7 Size 0 [M97].
|
|
YMCA_DRAMBank7_Sz1 EQU $188 ; DRAM Bank7 Size 1 [M98].
|
|
YMCA_DRAMBank7_Sz2 EQU $18C ; DRAM Bank7 Size 2 [M99].
|
|
|
|
YMCA_Test_Mode EQU $190 ; Enable Test Mode [M100].
|
|
YMCA_Refresh_Test EQU $194 ; Refresh Test Mode [M101].
|
|
|
|
; ; <SM16> fau, end
|
|
;----------
|
|
; MUNI (NuBus) register definitions <P6>
|
|
;----------
|
|
|
|
; <SM7> rb, ¥ TEMP for EVT1 ; <SM7> rb
|
|
|
|
MUNIBaseEVT1 EQU $50F30800 ; Base address of Muni for EVT1 <SM9> rb
|
|
|
|
|
|
MUNIBase EQU $50F30000 ; Base address of Muni. <SM7> rb
|
|
|
|
|
|
|
|
MUNI_IntCntrl EQU $00 ; Interrupt control register.
|
|
MUNI_IntStatus EQU $04 ; Interrupt status register.
|
|
MUNI_Control EQU $08 ; System control register.
|
|
MUNI_BlkAttmpt EQU $0C ; Block attempt register.
|
|
MUNI_Status EQU $10 ; Status register.
|
|
MUNI_Test EQU $14 ; Test control register.
|
|
|
|
;----------
|
|
; Civic register definitions (offsets from CivicAddr in ProductInfo) ($50F3 6000)
|
|
;----------
|
|
|
|
Civic_VBLInt Equ $000 ; Read-only VBL flag register
|
|
Civic_VBLEnb Equ $110 ; Enables VBL interrupt.
|
|
Civic_VBLClr Equ $120 ; Clear VBL interrupt.
|
|
|
|
Civic_Enable Equ $004 ; Enables CivicÕs timing generator (Casio).
|
|
Civic_Reset Equ $10C ; Resets Casio.
|
|
|
|
Civic_VDCInt Equ $008 ; Read-only VDC flag register.
|
|
Civic_VDCClr Equ $00C ; Clears VDC interrupt.
|
|
Civic_VDCEnb Equ $010 ; Enables VDC interrupt.
|
|
Civic_VDCClk Equ $018 ; Enables VDC clock.
|
|
|
|
Civic_VidInSize Equ $014 ; Controls video-in Rows (1024 vs. 1536 bytes).
|
|
|
|
Civic_VidInDble Equ $208 ; Controls whether Civic Doubles each Video-in Field
|
|
|
|
Civic_ScanCtl Equ $01C ; Controls progressive vs. interlaced scans.
|
|
|
|
Civic_GSCDivide Equ $020 ; Controls graphics clock divide count.
|
|
Civic_VSCDivide Equ $02C ; Controls video-in clock divide count.
|
|
|
|
Civic_VRAMSize Equ $040 ; Controls VRAM sizing (1 vs. 2 Mbytes).
|
|
|
|
Civic_RfrshCtl Equ $044 ; Controls the refresh mode.
|
|
|
|
Civic_BusSize Equ $04C ; Controls the bus size (32 vs. 64 bits).
|
|
|
|
Civic_SpeedCtl Equ $050 ; Controls the timing (25 vs. 33 MHz).
|
|
|
|
Civic_ConvEnb Equ $054 ; Enables convolution.
|
|
|
|
Civic_ReadSense Equ $088 ; Sense-line registers.
|
|
Civic_SenseCtl Equ $058 ;
|
|
Civic_Sense0 Equ $05C ;
|
|
Civic_Sense1 Equ $060 ;
|
|
Civic_Sense2 Equ $064 ;
|
|
Civic_SenseTst Equ $068 ;
|
|
|
|
Civic_SyncClr Equ $06C ; Disables RGB (Sync) output.
|
|
|
|
Civic_BaseAddr Equ $0C0 ; Base address of active video.
|
|
Civic_RowWords Equ $094 ; Row long words of active video.
|
|
|
|
Civic_AdjF1 Equ $128 ; Timing adjust registers.
|
|
Civic_AdjF2 Equ $124 ;
|
|
Civic_Piped Equ $440 ;
|
|
|
|
Civic_HSerr Equ $180 ; Horizontal timing registers.
|
|
Civic_HlfLn Equ $280 ;
|
|
Civic_HEq Equ $2C0 ;
|
|
Civic_HSP Equ $300 ;
|
|
Civic_HBWay Equ $340 ;
|
|
Civic_HAL Equ $380 ;
|
|
Civic_HFP Equ $3C0 ;
|
|
Civic_HPix Equ $400 ;
|
|
|
|
Civic_VHLine Equ $480 ; Vertical timing registers.
|
|
Civic_VSync Equ $4C0 ;
|
|
Civic_VBPEqu Equ $500 ;
|
|
Civic_VBP Equ $540 ;
|
|
Civic_VAL Equ $580 ;
|
|
Civic_VFP Equ $640 ;
|
|
Civic_VFPEqu Equ $680 ;
|
|
Civic_CurLine Equ $6C0 ;
|
|
|
|
Civic_VInHAL Equ $1C0 ; Video-in timing registers.
|
|
Civic_VInHFPD Equ $200 ;
|
|
Civic_VInHFP Equ $240 ;
|
|
Civic_VInVAL Equ $5C0 ;
|
|
Civic_VInVFP Equ $600 ;
|
|
|
|
Civic_HLDB Equ $114 ; Horizontal test/control registers.
|
|
Civic_HHLTB Equ $118 ;
|
|
Civic_HActHi Equ $11C
|
|
|
|
Civic_VLDB Equ $100 ; VSync test/control registers.
|
|
Civic_VHLTB Equ $104 ;
|
|
Civic_VActHi Equ $108 ;
|
|
|
|
Civic_TestEnb Equ $12C ; Enables Casio test mode.
|
|
Civic_CntTest Equ $140 ; Count test register.
|
|
|
|
;----------
|
|
; Sebastian register definitions (offsets from SebastianAddr in ProductInfo) ($50F3 0000)
|
|
;----------
|
|
|
|
SebastAddrReg Equ $000 ; CLUT/DAC Address register.
|
|
SebastDataReg Equ $010 ; CLUT/DAC Data register.
|
|
SebastPCBR Equ $020 ; CLUT/DAC Pixel Bus Control register.
|
|
|
|
;----------
|
|
; Endeavor register definitions
|
|
;----------
|
|
|
|
Endeavor Equ $50F2E000 ; Base address of Endeavor in Cyclone.
|
|
|
|
EndeavorM Equ $000 ; 8-bit numerator.
|
|
EndeavorN Equ $010 ; 8-bit denominator.
|
|
EndeavorClk Equ $020 ; Clock select (A or B).
|
|
|
|
;----------
|
|
; MSC register definitions (offsets from MSCAddr in ProductInfo) ($50F2 6000)
|
|
;----------
|
|
|
|
MSCSlotIFR EQU $02 ; slots interrupt flags
|
|
MSCVIA2IFR EQU $03 ; VIA 2 interrupt flags
|
|
MSCConfig EQU $10 ; RAM, clock configuration
|
|
MSCSlotIER EQU $12 ; slots interrupt enables
|
|
MSCVIA2IER EQU $13 ; VIA 2 interrupt enables
|
|
MSCClkCntl EQU $21 ; peripherals clock control
|
|
MSCSndCntl EQU $22 ; sound control
|
|
MSCFlashWrEnb EQU $23 ; flash ROM write enable
|
|
MSCPowerCycle EQU $50FA0000-$50F26000 ; CPU power off control register <H2>
|
|
|
|
; ====== VIA2 BufferB Equivalent Address: $50F26000 =====
|
|
MSCEnableFPU EQU 0 ; 0 = enable on-board floating point processor <H29>
|
|
;v2PMack EQU 1 ; Power manager handshake acknowledge
|
|
;v2PMreq EQU 2 ; Power manager handshake request
|
|
;reserved3 EQU 3 ; reserved
|
|
;reserved4 EQU 4 ; reserved
|
|
;reserved5 EQU 5 ; reserved
|
|
;reserved6 EQU 6 ; reserved
|
|
;reserved7 EQU 7 ; reserved
|
|
|
|
; ====== Slot Interrupt Flags Address: $50F26002 =====
|
|
;reserved0 EQU 0 ; reserved
|
|
;reserved1 EQU 1 ; reserved
|
|
;reserved2 EQU 2 ; reserved
|
|
;reserved3 EQU 3 ; reserved
|
|
;reserved4 EQU 4 ; reserved
|
|
;RvIRQE EQU 5 ; slot E interrupt
|
|
;RvIRQLCD EQU 6 ; LCD display VBL interrupt
|
|
;reserved7 EQU 7 ; reserved
|
|
|
|
; ====== VIA 2 Interrupt Flags Address: $50F26003 =====
|
|
;RvSCSIDRQ EQU 0 ; 1 = SCSI DRQ interrupt
|
|
;RvAnySlot EQU 1 ; 1 = any slot(0-6).IRQ int
|
|
;reserved2 EQU 2 ; reserved
|
|
;RvSCSIRQ EQU 3 ; 1 = SCSI IRQ interrupt
|
|
;RvSndIRQ EQU 4 ; 1 = Apple Sound Chip interrup
|
|
;reserved5 EQU 5 ; reserved
|
|
;reserved6 EQU 6 ; reserved
|
|
;RvSetClr EQU 7 ; on READ, 1 = any enable interrupt
|
|
|
|
; ====== MSC Configuration Address: $50F26010 =====
|
|
MSC25MHz EQU 0 ; 1 = 25MHz system, 0 = 33MHz system
|
|
MSCEconoBit EQU 1 ; 1 = econo-mode enabled (switches to 16MHz)
|
|
MSCFastROM EQU 2 ; 1 = 100ns ROMs installed, 0 = 120ns ROMs installed
|
|
;reserved3 EQU 3 ; reserved
|
|
MSCBank8M EQU 4 ; 1 = banks 4-7 are 8MB, 0=banks 4-7 are 2MB
|
|
MSCSize0 EQU 5 ; RAM size bit
|
|
MSCSize1 EQU 6 ; RAM size bit
|
|
MSCSize2 EQU 7 ; RAM size bit
|
|
|
|
; ====== Slot Interrupt Enables Address: $50F26012 =====
|
|
;reserved0 EQU 0 ; reserved
|
|
;reserved1 EQU 1 ; reserved
|
|
;reserved2 EQU 2 ; reserved
|
|
;reserved3 EQU 3 ; reserved
|
|
;reserved4 EQU 4 ; reserved
|
|
;RvIRQEEn EQU 5 ; slot E interrupt enabled
|
|
;RvIRQLCDEn EQU 6 ; LCD display VBL interrupt enabled
|
|
;RvSetClr EQU 7 ; on READs, always reads 0
|
|
|
|
; ====== VIA 2 Interrupt Enables Address: $50F26013 =====
|
|
;RvSCSIDRQEn EQU 0 ; 1 = SCSI DRQ interrupt enabled
|
|
;RvAnySlotEn EQU 1 ; 1 = any slot(0-6).IRQ int. enabled
|
|
;reserved2 EQU 2 ; reserved
|
|
;RvSCSIRQEn EQU 3 ; 1 = SCSI IRQ interrupt enabled
|
|
;RvSndIRQEn EQU 4 ; 1 = Apple Sound Chip interrupt enabled
|
|
;reserved5 EQU 5 ; reserved
|
|
;reserved6 EQU 6 ; reserved
|
|
;RvSetClr EQU 7 ; on READs, always reads 0
|
|
; on WRITEs, 1 = 1-bits in bits 0-6 write 1's
|
|
; 0 = 1-bits in bits 0-6 write 0's
|
|
|
|
; ====== Peripherals Clock Control Address: $50F26021 =====
|
|
MSCIOClk EQU 0 ; 1=15.6672MHz I/O clock running, 0=stopped
|
|
MSCSCCClk EQU 1 ; 1=3.672MHz SCC clock running, 0=stopped
|
|
MSCSCSIReset EQU 2 ; 1=SCSI reset not asserted, 0=reset asserted (clocks stop)
|
|
MSCLCDReset EQU 3 ; 1=LCD reset not asserted, 0=reset asserted (clocks stop)
|
|
;reserved4 EQU 4 ; reserved
|
|
;reserved5 EQU 5 ; reserved
|
|
;reserved6 EQU 6 ; reserved
|
|
;reserved7 EQU 7 ; reserved
|
|
|
|
; ====== Sound Control Address: $50F26022 =====
|
|
MSCSndPower EQU 0 ; 1=DFAC power on, 0=DFAC power off
|
|
;reserved1 EQU 1 ; reserved
|
|
;reserved2 EQU 2 ; reserved
|
|
;reserved3 EQU 3 ; reserved
|
|
;reserved4 EQU 4 ; reserved
|
|
;reserved5 EQU 5 ; reserved
|
|
MSCSndBusy EQU 6 ; 1=access to FIFO since last access to this register
|
|
MSCSndLatch EQU 7 ; 1=DFAC is powered up and initialized
|
|
|
|
|
|
MSCDefConfig EQU (1<<MSC25MHz)|\ ; 25MHz system <H9>
|
|
(0<<MSCEconoBit)|\ ; econo-mode disabled <H9>
|
|
(0<<MSCFastROM)|\ ; 120ns ROMs installed <H9>
|
|
(0<<MSCBank8M)|\ ; assume 2MB each in banks 4-7 <H19>
|
|
(%000<<MSCSize0) ; set 2MB so there's real RAM for BootBeep <H10>
|
|
|
|
|
|
BIOSAddr EQU $50F18000 ; verified by hasBIOSAddr in ExtValid <H26><SM18>
|
|
|
|
BIOS_Config EQU 0 ; contains bit 0: 0 = BCLK ³ 33MHz <H26>
|
|
; 1 = BCLK ² 25MHz <H26>
|
|
BIOS_SONIC_SCSI EQU $200 ; contains SONIC and SCSI parameters <H26>
|
|
BIOSSCSIFilter EQU $40 ; bit 6 = SONIC stuff, all the rest are SCSI<H31>
|
|
; (bit 7 in BIOS is undefined) <H31>
|
|
BIOScfg20MHz EQU $1B ; 3-clk PDMA Write and Read <H27><SM18>
|
|
BIOScfg25MHz EQU $3F ; 3-clk PDMA Write and Read/DRQCHK on <H27><SM18>
|
|
BIOScfg33MHz EQU $12 ; 4-clk PDMA Write and Read <H27><SM18>
|
|
BIOScfg40MHz EQU $00 ; 5-clk PDMA Write and Read <H27><SM18>
|
|
|
|
BIOS_REVISION EQU $300 ; bits 5:7 is BIOS revision number <H26>
|
|
bBIOSW1Cmplt EQU $2 ; bit positions... <H27>
|
|
bBIOSR1Cmplt EQU $1 ; <H27>
|
|
bBIOSSCSIBERR EQU $0 ; <H27>
|
|
|
|
BIOS_PDMA EQU $300 ; bits 0:2 are Pseudo-DMA control bits <H26>
|
|
BIOS_SCSI_RESID EQU $400 ; bits 0:16 are latched SCSI data <H26>
|
|
BIOS_BRIGHTNESS EQU $500 ; 8 bits of 0-$FF brightness <H31>
|
|
BIOS_CONTRAST EQU $501 ; 8 bits of 0-$FF contrast <H31>
|
|
BIOS_Timeout EQU $600 ; bits 0:11 are watchdog timer timeout cntr <H26>
|
|
|
|
BIOS_Config2 EQU $100 ; for Primus/Optimus bios <H35>
|
|
bBIOSBR30116BIT EQU $0 ; bit positions... <H35>
|
|
bBIOSIOCSTime EQU $1 ; <H35>
|
|
bBIOSENETIRQLVL EQU $2 ; <H35>
|
|
|
|
;__________________________________________________________________________________________ <SM23> SAM
|
|
; AMIC (Apple Memory mapped I/O Controller) Creative name huh? Equates
|
|
; First used on PDM/Cold Fusion
|
|
;__________________________________________________________________________________________
|
|
|
|
AMICBase EQU $50F30000 ; AMIC base
|
|
AMICDMABase EQU $50F31000 ; DMA Buffer Base Address (256k alignment)
|
|
AMICSCSIDMABase EQU $0000 ; SCSI DMA Buffer Base Address [scsi has its own buffer] (8 byte alignment)
|
|
|
|
AMICSCSICntrl EQU $1008 ; SCSI DMA control register
|
|
|
|
AMICEnetTxCntrl EQU $0C20 ; Ethernet transmit DMA control register
|
|
AMICEnetRxCntrl EQU $1028 ; Ethernet receive DMA control register
|
|
|
|
AMICFloppyCntrl EQU $1068 ; Floppy DMA control register
|
|
|
|
AMICSCCTxACntrl EQU $1088 ; SCC port A transmit DMA control register
|
|
AMICSCCRxACntrl EQU $1098 ; SCC port A receive DMA control register
|
|
|
|
AMICSCCTxBCntrl EQU $10A8 ; SCC port B transmit DMA control register
|
|
AMICSCCRxBCntrl EQU $10B8 ; SCC port B receive DMA control register
|
|
|
|
AMICIrqBase EQU $50F2A000 ; AMIC's interrupt register base
|
|
AMICIrqFlags EQU $0000 ; Interrupt source register
|
|
AMICDMAFlags0 EQU $0008 ; DMA interrupt source register
|
|
AMICDMAFlags1 EQU $000A ; DMA interrupt source register
|
|
|
|
PDMrbvSize EQU 768*1024 ; 768k for RBV <SM24>
|
|
PDMDMAbufSize EQU 160*1024 ; 160k for the DMA buffer
|
|
PDMDMAlogAddr EQU $61000000 ; Logical address of the DMA buffer
|
|
|
|
;__________________________________________________________________________________________
|
|
; BART (PDM/Cold Fusion NuBus Controller) Equates
|
|
; First used on PDM/Cold Fusion
|
|
;__________________________________________________________________________________________
|
|
BARTBase EQU $F0000000 ; BART Register Base
|
|
|
|
BARTResetReg EQU $F0000000 ; bit zero of this register will reset NuBus
|
|
BARTResetBit EQU $0
|
|
|
|
BARTSlowReg EQU $F0000001 ; Setting bit 8 will add wait states
|
|
BARTSlowBit EQU $8
|
|
|
|
BARTOffSltE EQU $F0000011 ; Setting bit 8 will cause slot E to be disabled (for Cold Fusion)
|
|
BARTOFFBit EQU $8
|
|
|
|
BARTBurstReg EQU $80 ; Offset from base to slot zero burst reg (not actually used directly)
|
|
BARTBurstRegOff EQU $08 ; Offset from Busrt Reg to next slot Reg ($80, $78, $70, $68 ... $10)
|
|
BARTBurstBit EQU $8
|
|
|
|
|
|
;__________________________________________________________________________________________
|
|
;
|
|
;
|
|
; Memory Controllers - Register Definitions and Misc Equates for Memory Controllers. Included
|
|
; are: FMC, ORWELL, JAWS, Niagra, Ponti, djMEMC, Pratt
|
|
;
|
|
;
|
|
;__________________________________________________________________________________________
|
|
|
|
|
|
;---------------------------------------------------
|
|
; FMC (Fitch Memory Controller) Equates
|
|
;---------------------------------------------------
|
|
|
|
FMCConfig equ $0 ; offset to configuration register. It is a 16
|
|
; bit wide register with a 1 bit wide data port
|
|
; on d24, so do byte writes (and rotates) and
|
|
; let dynamic bus sizing replicate it on d24-31.
|
|
|
|
FMCLatch equ $10 ; offset to 'latch config data' register (latches
|
|
; on a write to here)
|
|
FMCInit EQU $F3EF ; config reg initial value <4.5><4.6><4.9><1>
|
|
FMCRPUInit EQU $F3FF ; config reg initial value (parity) <1>
|
|
|
|
|
|
;---------------------------------------------------
|
|
; Orwell Memory Controller Equates <5>
|
|
;---------------------------------------------------
|
|
|
|
; Orwell only has one input/output data bit. So to store or retrieve any configuration register
|
|
; information, you must read/write a succession of long-word addresses, starting at the addresses
|
|
; below, with the ONLY valid data bit being {reg}:0. Valued being read must be assembled one bit
|
|
; at a time; values being written must be loaded into the config registers 1 bit at a time. The
|
|
; new config. register values do not become active until a "latch" register address associated
|
|
; with the config. register is written.
|
|
;
|
|
; The below addresses correspond to longword addresses where bit 0 of whatever data register used to
|
|
; read/write the location will be stored. The Orwell configuration register is a 34-bit register,
|
|
; with each bit written to/read by addressing the appropriate longword offset.
|
|
;
|
|
; The configuration register can be thought of like this:
|
|
;
|
|
; +---------------------------------------------------------------------------------------------+
|
|
; | PAR_ODD | PAR_ENB | REFRESH | ROM_SPEED | DRAM_SPEED | CLK_SPEED | BANK_D | BANK_C | BANK_B |
|
|
; +---------------------------------------------------------------------------------------------+
|
|
; 28 27 26 24 23 21 20 19 18 17 12 11 6 5 0
|
|
;
|
|
; <T6>
|
|
; +---------------------------------------------------------------------+ <T6>
|
|
; | RAS | Optional WRITE | Optional Read | Optional Read | Page | <T6>
|
|
; | Precharge | wait state | 2nd wait state | 1st wait state | Mode | <T6>
|
|
; +---------------------------------------------------------------------+ <T6>
|
|
; 33 32 31 30 29 <T6>
|
|
|
|
; *** Register Offsets ***
|
|
|
|
OrCfgRegAddr EQU 0 ; starting offset of config reg. bits
|
|
OrCfgRegSize EQU 34 ; number of bits in the configuration register <T6>
|
|
|
|
OrBankFieldSize EQU 6 ; each bank config. reg. field is 6 bits wide
|
|
OrBankBCfgAddr EQU OrCfgRegAddr ; starting offset of BankB(5:0)
|
|
OrBankCCfgAddr EQU OrBankBCfgAddr+(4*OrBankFieldSize); starting offset of BankC(5:0)
|
|
OrBankDCfgAddr EQU OrBankCCfgAddr+(4*OrBankFieldSize); starting offset of BankD(5:0)
|
|
OrClkSpeedAddr EQU OrBankDCfgAddr+(4*OrBankFieldSize); starting address of Clock_Speed
|
|
; ... Clock_Speed is 1 bit (0=25MHz)
|
|
OrDRAMSpeedAddr EQU OrClkSpeedAddr+4 ; starting address of DRAM Speed(1:0)
|
|
OrDRAMFieldSize EQU 2 ; DRAM speed config reg. field is 2 bits wide
|
|
OrROMSpeedAddr EQU OrDRAMSpeedAddr+(4*OrDRAMFieldSize); starting address of ROM Speed(2:0)
|
|
OrROMFieldSize EQU 3 ; ROM speed config reg. field is 3 bits wide
|
|
OrRefreshAddr EQU OrROMSpeedAddr+(4*OrROMFieldSize); starting address of Refresh Rate(2:0)
|
|
OrRefreshSize EQU 3 ; Refresh speed config reg. field is 3 bits wide
|
|
OrParityEnbAddr EQU OrRefreshAddr+(4*OrRefreshSize); starting address of parity enable/disable
|
|
; ... Parity_Enable is 1 bit (0=parity OFF)
|
|
OrParityTypAddr EQU OrParityEnbAddr+4 ; starting address of parity type (even/odd)
|
|
; ... Parity_Type is 1 bit (0=parity EVEN)
|
|
OrPageMode EQU OrParityTypAddr+4 ; <T6>
|
|
OrWaitRead1 EQU OrPageMode+4 ; <T6>
|
|
OrWaitRead2 EQU OrWaitRead1+4 ; <T6>
|
|
OrWaitWrite1 EQU OrWaitRead2+4 ; <T6>
|
|
OrRASPrecharge EQU OrWaitWrite1+4 ; <T6>
|
|
|
|
OrLatchOffset EQU $A0 ; offset from start of config reg. where latches live <T6>
|
|
OrwellLatches EQU OrCfgRegAddr+OrLatchOffset; starting address of Latch Addresses <T6>
|
|
|
|
OrLoadBanks EQU OrwellLatches ; Load Bank Config Reg. Latch address <T6>
|
|
OrLoadSpeeds EQU OrLoadBanks+4 ; Load Clock, DRAM and ROM Speeds Latch address
|
|
OrLoadRefresh EQU OrLoadSpeeds+4 ; Load Refresh interval Latch address
|
|
OrLoadParity EQU OrLoadRefresh+4 ; Load Parity enable/disable and type Latch address
|
|
|
|
OrLoadMode EQU OrLoadParity+4 ; Load Page Mode On/Off address <T6>
|
|
OrLoadWaitStates EQU OrLoadMode+4 ; Load Read/Write extra waitstates address <T6>
|
|
OrLoadPrecharge EQU OrLoadWaitStates+4 ; Load RAS precharge address <T6>
|
|
|
|
OrParityStatus EQU $100 ; A0-BC = LS 8 bits, C0-DC = LM 8 bits <T6>
|
|
; E0-FC = HM 8 bits, 100-11C = MS 8 bits
|
|
OrParErrInByte0 EQU $180 ; =1 if parity error occurred in byte 0
|
|
OrParErrInByte1 EQU $184 ; =1 if parity error occurred in byte 1
|
|
OrParityError EQU $188 ; =1 if parity error occurred (period)
|
|
|
|
; *** Initializing Values at Bootup Time ***
|
|
|
|
ORINITBankB EQU $10 ; 10=Bank B at 64MB
|
|
ORINITBankC EQU $20 ; 20=Bank C at 128MB
|
|
ORINITBankD EQU $30 ; 30=Bank D at 192MB
|
|
|
|
ORINITClock25 EQU 1 ; 1=25MHz, 0=33MHz <T12>
|
|
ORINITClock33 EQU 0 ; <T12>
|
|
ORINITDRAMSpeed EQU 1 ; 0=100ns, 1=80ns, 2=60ns <10>
|
|
ORINITROMSpeed25 EQU 2 ; *n* = Clock_Access-3 (0 = 3 Clock_Access) <T6><T12>
|
|
ORINITROMSpeed33 EQU 4 ; *n* = Clock_Access-3 (0 = 3 Clock_Access) <T6><T12>
|
|
ORINITREFRESH25 EQU 2 ; 0=25MHz 7.8µsec, 1=33MHz, 7.8µsec <21> <T12>
|
|
; 2=25MHz 15.6µsec, 3=33MHz 15.6µsec <21> <T12>
|
|
ORINITREFRESH33 EQU 3 ; <21> <T12>
|
|
ORINITParity EQU 0 ; 0=parity OFF, 1=parity ON
|
|
ORINITParType EQU 1 ; 0=even, 1=odd
|
|
|
|
; Additional (programmable) wait states for reads and writes
|
|
|
|
ORINITPageMode EQU 0 ; 0=off, 1=on <T6>
|
|
ORINITWaitRd1 EQU 0 ; 0=off, 1=on (unless Rd2 = 1, in which case it is interpreted as off)<T6>
|
|
ORINITWaitRd2 EQU 0 ; 0=off, 1=on (unless Rd1 = 1, in which case it is interpreted as off)<T6>
|
|
ORINITWaitWr1 EQU 0 ; 0=off, 1=on <T6>
|
|
ORINITRAS25 EQU 0 ; 0=2 cycles, 1=3 cycles <T6>
|
|
ORINITRAS33 EQU 1 ; <T12>
|
|
|
|
; These are 32-bit constants that hold all but 2 bits of the initial defaults we .
|
|
; would want to jam into the Orwell configuration register. These are arranged .
|
|
; in order the register is memory-mapped to facilitate the code that sticks them .
|
|
; in the register. There are two bits that don't fit in a 32-bit constant, the .
|
|
; optional -OrWaitWrite1- and the not-so-optional -OrRASPrecharge-. Those values .
|
|
; are used and initialized separately. .
|
|
|
|
ORWELL_INIT25 EQU \ ; <T6><T12>
|
|
(ORINITWaitRd2<<31)|\ ; initial value - are TWO read-related wait states needed? (0=no)<T6>
|
|
(ORINITWaitRd1<<30)|\ ; initial value - is ONE read-related wait state needed? (0=no)<T6>
|
|
(ORINITPageMode<<29)|\ ; initial page mode value (OFF) <T6>
|
|
(ORINITParType<<28)|\ ; initial parity even/odd value
|
|
(ORINITParity<<27)|\ ; initial parity on/off value
|
|
(ORINITREFRESH25<<24)|\ ; initial refresh rate value <T12>
|
|
(ORINITROMSpeed25<<21)|\; initial ROM speed value <T12>
|
|
(ORINITDRAMSpeed<<19)|\ ; initial DRAM speed value
|
|
(ORINITClock25<<18)|\ ; initial clock speed value <T12>
|
|
(ORINITBankD<<12)|\ ; initial Bank D starting address value
|
|
(ORINITBankC<<6)|\ ; initial Bank C starting address value
|
|
(ORINITBankB) ; initial Bank B starting address value
|
|
ORWELL_INIT33 EQU \ ; <T6><T12> thru next <T12>
|
|
(ORINITWaitRd2<<31)|\ ; initial value - are TWO read-related wait states needed? (0=no)<T6>
|
|
(ORINITWaitRd1<<30)|\ ; initial value - is ONE read-related wait state needed? (0=no)<T6>
|
|
(ORINITPageMode<<29)|\ ; initial page mode value (OFF) <T6>
|
|
(ORINITParType<<28)|\ ; initial parity even/odd value
|
|
(ORINITParity<<27)|\ ; initial parity on/off value
|
|
(ORINITREFRESH33<<24)|\ ; initial refresh rate value
|
|
(ORINITROMSpeed33<<21)|\; initial ROM speed value
|
|
(ORINITDRAMSpeed<<19)|\ ; initial DRAM speed value
|
|
(ORINITClock33<<18)|\ ; initial clock speed value
|
|
(ORINITBankD<<12)|\ ; initial Bank D starting address value
|
|
(ORINITBankC<<6)|\ ; initial Bank C starting address value
|
|
(ORINITBankB) ; initial Bank B starting address value <T12>
|
|
|
|
|
|
;---------------------------------------------------
|
|
; JAWS Memory Controller Equates
|
|
;---------------------------------------------------
|
|
|
|
JAWSRAMWaitS EQU $00000 ; RAM wait state control register offset
|
|
JAWSEconoMode EQU $04000 ; Econo-Mode register offset <21> HJR
|
|
JAWSROMWaitS EQU $06000 ; ROM wait state control register offset
|
|
|
|
JAWSMemConfigA EQU $10000 ; Contiguous memory (knitting) registers
|
|
JAWSMemConfigB EQU $12000 ; Contiguous memory (knitting) registers
|
|
JAWSMemConfigC EQU $14000 ; Contiguous memory (knitting) registers
|
|
|
|
JAWSPowerCycle EQU $20000 ; CPU power off control register
|
|
JAWSSetCPUClock EQU $22000 ; Controls the CPU clock frequency
|
|
JAWSPCBLevel EQU $30000 ; Selects between SCC and SCC/SCSI combo
|
|
JAWSLockRAM EQU $32000 ; Puts RAM in self refresh state
|
|
JAWSGetCPUClock EQU $34000 ; Returns the CPU clock frequency
|
|
|
|
;---------------------------------------------------
|
|
; Niagra Memory Controller Equates
|
|
;---------------------------------------------------
|
|
|
|
NiagraVidCntCtr EQU $02000 ; Video count options <21> HJR
|
|
NiagraGUR EQU $16000 ; General Utility Registers (ponti register access)<SM4> rb
|
|
NiagraVidAcc1 EQU $22000 ; Video Accesses thru 64
|
|
NiagraVidAcc2 EQU $24000 ; Video Accesses thru 512
|
|
NiagraVidAcc3 EQU $26000 ; Video Accesses thru 2K
|
|
NiagraFlashEnbl EQU $30000 ; Enable flash from Niagra
|
|
NiagraFPUAcc EQU $34000 ; FPU access detected
|
|
NiagraSpeedReg EQU $36000 ; Returns the CPU clock frequency
|
|
|
|
;---------------------------------------------------
|
|
; Pratt Memory Controller Equates
|
|
;---------------------------------------------------
|
|
|
|
PrattChipID EQU $5ffffff8 ; Pratt ID register address (chip version) CSR0
|
|
PrattSysStat EQU $0007 ; CPU speed register offset CSR1
|
|
PrattROMSpeed EQU $000B ; ROM speed register offset CSR2
|
|
PrattRAMDensity EQU $000F ; RAM density register offset CSR3
|
|
PrattRAMConfig EQU $0013 ; RAM configuration register offset CSR4
|
|
PrattRefresh EQU $0017 ; RAM refresh register offset CSR5
|
|
PrattNapReg EQU $001B ; PowerCycling enable register offset CSR6
|
|
PrattVersion EQU $001F ; Unused register offset (always reads zero) CSR7
|
|
|
|
;CSR1 System Status Register
|
|
Pratt16MHzCPU EQU %00000000 ; CPU speed reg config values (bits 0:1)
|
|
Pratt20MHzCPU EQU %00000001 ;
|
|
Pratt25MHzCPU EQU %00000010 ;
|
|
Pratt33MHzCPU EQU %00000011 ;
|
|
PrattFlashLBit EQU 2 ; bit position for Flash detection (0 = Flash is present)
|
|
PrattROMBit EQU 3 ; bit position for ROM boot (1 = ROM in system)
|
|
|
|
Pratt250nsROM EQU %00000000 ;CSR2 ROM speed reg config values
|
|
Pratt200nsROM EQU %00000001 ;
|
|
Pratt150nsROM EQU %00000010 ;
|
|
Pratt120nsROM EQU %00000011 ;
|
|
|
|
;CSR3/4 RAM sizing bit definitions
|
|
PrattDensBits EQU %00001111 ; bit mask showing active density config bits
|
|
PrattBankBits EQU %00111111 ; bit mask showing active bank occupancy bits
|
|
PrattDefDensity EQU %00000111 ; Default RAM Density value for Pratt (all 8MB banks)
|
|
PrattDefConfig EQU %00111111 ; Default RAM Bank Configuration for Pratt (all banks occupied)
|
|
PrattNumbanks EQU 6 ; Total number of RAM banks, onboard plus expansion
|
|
|
|
Pratt0MBbank EQU %11111100 ; Onboard RAM bank bit masks
|
|
Pratt2MBbank EQU %11111110
|
|
Pratt4MBbank EQU %11111101
|
|
Pratt8MBbank EQU %11111111
|
|
|
|
Pratt0MBExBank EQU %11110011 ; Expansion RAM bank bit masks
|
|
Pratt2MBExBank EQU %11110011
|
|
Pratt4MBExBank EQU %11111011
|
|
Pratt8MBExBank EQU %11110111
|
|
|
|
;CSR5 Test Control Bits
|
|
PrattFreqRfsh EQU 0 ; Pratt frequent refresh control bit
|
|
PrattDBRfshOnly EQU 1 ; Do daughterboard refresh only bit
|
|
PrattShortRamp EQU 2 ; Do short power rampup bit
|
|
|
|
PrattPwrCyclBit EQU 0 ;CSR6 Power Cycling bit (= 1 to power cycle)
|
|
|
|
;--------------------------------------------------- <SM4> rb, start
|
|
; Ponti Register Equates (NiagraGUR register space + offset
|
|
;---------------------------------------------------
|
|
|
|
PontiSPIMdmCtl EQU $000
|
|
PontiSndCtl EQU $400
|
|
PontiSPISftReg EQU $800
|
|
PontiLmpSftCtl EQU $C00
|
|
|
|
; Ponti PontiSPIMdmCtl bit definitions
|
|
PontiSPIMdmId EQU 0 ; (1 = SPI modem connected)
|
|
PontiSPIAck EQU 2 ; (1 = ack idle)
|
|
PontiSPIReq EQU 3 ; (1 = req idle)
|
|
PontiSPIIrq EQU 4 ; (1 = interrupting)
|
|
|
|
; Ponti PontiSoundCtl bit definitions
|
|
PontiSndSPIIrqMsk EQU 0 ; (1 = mask int) - irq mask for PontiSPIIrq
|
|
PontiSndIntMic EQU 1 ; (1 = using internal mic) - flag to check which mike is used <H22>
|
|
PontiSndLatchClr EQU 2 ; (pulse high to clear) - line directly to latch
|
|
PontiSndLatchData EQU 3 ; (1 = snd ckt used) - output value of the sound latch
|
|
PontiSndPWMOff EQU 4 ; (1 = PWM off) - ultimate off to remove "pop"
|
|
PontiSndPwrOn EQU 5 ; (1 = power snd ckt) - sw equal of latch output
|
|
PontiSndMux0 EQU 6 ; (1 = ???)
|
|
PontiSndMux1 EQU 7 ; (1 = modem sound {regardless of Mux0})
|
|
|
|
; Ponti PontiLmpSftCtl bit definitions
|
|
PontiLmpOff EQU 0 ; (1 = backlight on) - turn on the backlight tube
|
|
PontiLmpHWCtl EQU 1 ; (1 = Hardware control) - if set, hardware control loop
|
|
PontiLmpMux0 EQU 2 ; (1 = 1/2 pot) - 1/2 scale pot reduction
|
|
PontiLmpMux1 EQU 3 ; (1 = 1/4 pot) - 1/4 scale pot reduction
|
|
PontiLmpSPIDir EQU 4 ; (1 = shift out) - direction of shift register
|
|
|
|
;--------------------------------------------------- <K9> HJR
|
|
; HardRock Register Equates
|
|
;---------------------------------------------------
|
|
HardRockSlotBase EQU $FB000000
|
|
|
|
HardRockCodecICR EQU HardRockSlotBase + $1020
|
|
HardRockCodecSRCR EQU HardRockSlotBase + $1024
|
|
HardRockCodecEnReg EQU HardRockSlotBase + $1028
|
|
HardRockCodecOutAtt EQU HardRockSlotBase + $1030
|
|
HardRockCodecInGain EQU HardRockSlotBase + $1034
|
|
|
|
HardRockFifoBase EQU HardRockSlotBase + $2000
|
|
HardRockFifoControl EQU HardRockSlotBase + $2000 +4
|
|
|
|
HRChan_run12 EQU 12 ; 1 = enable channel 12
|
|
HRChan_run9 EQU 9 ; 1 = enable channel 9
|
|
HRChan_run7 EQU 7 ; 1 = enable channel 7
|
|
HRChan_run6 EQU 6 ; 1 = enable channel 6
|
|
HRChan_run5 EQU 5 ; 1 = enable channel 5
|
|
HRChan_run4 EQU 4 ; 1 = enable channel 4
|
|
HRChan_run3 EQU 3 ; 1 = enable channel 3
|
|
HRChan_run2 EQU 2 ; 1 = enable channel 2
|
|
HRChan_run1 EQU 1 ; 1 = enable channel 1
|
|
HRSPI_Voice_Sel EQU 0 ; 1 = Voice DMA data goes through SPI Interface
|
|
; 0 = Voice DMA data goes through CODEC Interface
|
|
|
|
HardRockFifoCTL0 EQU HardRockFifoBase + $10
|
|
HardRockFifoCTL1 EQU HardRockFifoBase + $20
|
|
HardRockFifoCTL2 EQU HardRockFifoBase + $30
|
|
|
|
HardRockFifoBase0 EQU HardRockFifoBase + $1C
|
|
HardRockFifoBase1 EQU HardRockFifoBase + $2C
|
|
HardRockFifoBase2 EQU HardRockFifoBase + $3C
|
|
|
|
HardRockFifoRec RECORD 0,Increment ;
|
|
HRFifoConfig DS.W 1 ; 0
|
|
HRFifoInt DS.W 1 ; 2
|
|
HRFifoReserved DS.W 2 ; 4
|
|
HRFifoReadptr DS.W 1 ; 8
|
|
HRFifoWriteptr DS.W 1 ; A
|
|
HRFifoBase DS.L 1 ; C
|
|
HRFiforecSize EQU *-HardRockFifoRec
|
|
ENDR
|
|
|
|
HRFifoConfig64b EQU 6 ; Fifo config size of 64 bytes
|
|
HRFifoConfig128b EQU 7 ; Fifo config size of 128 bytes
|
|
HRFifoConfig256b EQU 8 ; Fifo config size of 256 bytes
|
|
HRFifoConfig512b EQU 9 ; Fifo config size of 512 bytes
|
|
HRFifoConfig1k EQU 10 ; Fifo config size of 1 kbytes
|
|
HRFifoConfig2k EQU 11 ; Fifo config size of 2 kbytes
|
|
HRFifoConfig4k EQU 12 ; Fifo config size of 4 kbytes
|
|
HRFifoConfig8k EQU 13 ; Fifo config size of 8 kbytes
|
|
|
|
HRFifoConfigVal EQU HRFifoConfig1k ; Currently set Fifo size to 1k
|
|
HRFifoSz EQU $400 ; $400 = #1024 = 1k
|
|
HRFifoWrapVal EQU HRFifoSz-1
|
|
|
|
HardRockFifoIntMsk0 EQU HardRockFifoBase + $12
|
|
HardRockFifoIntMsk1 EQU HardRockFifoBase + $22
|
|
HardRockFifoIntMsk2 EQU HardRockFifoBase + $32
|
|
|
|
HRIntMask EQU 0 ; 1 = interrupt masked, 0 = interrupt enabled
|
|
|
|
HardRockReadIntRec RECORD 0,Increment ;
|
|
HRIntFlags DS.B 1
|
|
HRRcvFlags DS.B 1
|
|
HRDataCount DS.W 1
|
|
ENDR
|
|
|
|
HardRockModemPwrReg EQU HardRockSlotBase + $20
|
|
HardRockModemRstClr EQU 2 ; 0 = deassertion of CHIQUITA_RESET_L is high level
|
|
; 1 = deassertion of CHIQUITA_RESET_L is tristate level
|
|
HardRockModem_RST EQU 1 ; 0 = assert CHIQUITA_RESET_L
|
|
HardRockModem_PWR EQU 0 ; 1 = Enable power to modem
|
|
|
|
HardRockModem_base EQU HardRockSlotBase + $4000
|
|
|
|
HardRockSPIMdmCtl EQU $000
|
|
HardRockSPIAck EQU 2 ; (1 = ack idle)
|
|
HardRockSPIReq EQU 3 ; (1 = req idle)
|
|
|
|
HardRockSndCtl EQU $400
|
|
HardRockSndSPIIrqMsk EQU 0 ; (1 = mask int)
|
|
|
|
HardRockSPISftReg EQU $800
|
|
|
|
HardRockLmpSftCtl EQU $C00
|
|
HardRockLmpSPIDir EQU 4 ; (1 = shift out) - direction of shift register
|
|
|
|
ModemExtCmdRec RECORD 0,Increment ;
|
|
modemcmdsel ds.b 1
|
|
modemdata ds.b 1
|
|
endr
|
|
|
|
WriteFifoRect RECORD 0,Increment ;
|
|
writeflags ds.b 1
|
|
writecnthi ds.b 1
|
|
writecntlo ds.b 1
|
|
writepad ds.b 1 ; <K9>
|
|
endr
|
|
|
|
|
|
;------------------------------------- <H21> thru next <H21>
|
|
; djMEMC memory controller equates
|
|
;-------------------------------------
|
|
|
|
; This hard-coded I/O address is in here because there is no more room in the
|
|
; Universal tables to hold this information.
|
|
|
|
MEMCAddr EQU $50F0E000 ; same for both Wombat + WLCD memory maps
|
|
|
|
; djMEMC-specific CPU_ID bit values
|
|
|
|
djVIA_CPU_TYPE_MASK EQU %01000010 ; PA6, PA1 = CPU type bits <SM18>
|
|
djCPU_TYPE_VAIL040 EQU %00000000 ; Vail 040 = 00 <SM18>
|
|
djCPU_TYPE_FRIDGE EQU %00000010 ; Frigidaire = 01 <SM18>
|
|
djCPU_TYPE_WLCD EQU %01000000 ; WLCD = 10 <SM18>
|
|
djCPU_TYPE_LEGO EQU %01000010 ; Lego = 11 <SM18>
|
|
|
|
djVIA_CPU_SPEED_MASK EQU %00010100 ; PA4, PA2 = CPU speed bits <SM18>
|
|
djCPU_SPEED_20MHZ EQU %00000000 ; 20MHz = 00 <SM18>
|
|
djCPU_SPEED_25MHZ EQU %00000100 ; 25MHz = 01 <SM18>
|
|
djCPU_SPEED_33MHZ EQU %00010000 ; 33MHz = 10 <SM18>
|
|
djCPU_SPEED_40MHZ EQU %00010100 ; 40MHz = 11 <SM18>
|
|
|
|
MEMCRegisterStart EQU 0
|
|
MEMCIntleaveEnable EQU MEMCRegisterStart ; DRAM interleave enable reg.
|
|
dj_OneBufferedBusBit EQU 5
|
|
; djMEMC supports up to a maximum of 10 (TEN) DRAM banks
|
|
dj_MaxBanks EQU 10 ; <H22>
|
|
|
|
MEMCDRAMCfg0 EQU MEMCIntleaveEnable+4 ; Bank 0 cfg reg
|
|
MEMCDRAMCfg1 EQU MEMCDRAMCfg0+4 ; Bank 1 cfg reg
|
|
MEMCDRAMCfg2 EQU MEMCDRAMCfg1+4 ; Bank 2 cfg reg
|
|
MEMCDRAMCfg3 EQU MEMCDRAMCfg2+4 ; Bank 3 cfg reg
|
|
MEMCDRAMCfg4 EQU MEMCDRAMCfg3+4 ; Bank 4 cfg reg
|
|
MEMCDRAMCfg5 EQU MEMCDRAMCfg4+4 ; Bank 5 cfg reg
|
|
MEMCDRAMCfg6 EQU MEMCDRAMCfg5+4 ; Bank 6 cfg reg
|
|
MEMCDRAMCfg7 EQU MEMCDRAMCfg6+4 ; Bank 7 cfg reg
|
|
MEMCDRAMCfg8 EQU MEMCDRAMCfg7+4 ; Bank 8 cfg reg
|
|
MEMCDRAMCfg9 EQU MEMCDRAMCfg8+4 ; Bank 9 cfg reg
|
|
|
|
MEMCmemTop EQU MEMCDRAMCfg9+4 ; Top of stitched RAM
|
|
MEMCconfig EQU MEMCmemTop+4 ; "Multiple bit DRAM/ROM configuration register"
|
|
MEMCRefresh EQU MEMCconfig+4 ; DRAM refresh rate register
|
|
|
|
|
|
;__________________________________________________________________________________________
|
|
;
|
|
;
|
|
; Interrupt Vector Definitions and Masks
|
|
;
|
|
;
|
|
;__________________________________________________________________________________________
|
|
|
|
|
|
|
|
;---------------------------------------------------
|
|
; Interrupt Masks
|
|
;---------------------------------------------------
|
|
|
|
hiIntMask EQU $0700 ; programmer switch only
|
|
pwrOffEnbl EQU $2500 ; mask to allow poweroff interrupts
|
|
sccIntMask EQU $0400 ; SCC interrupt level
|
|
sccEnblMask EQU $FBFF ; mask to enable SCC interrupts
|
|
slotIntMask EQU $0200 ; slot's interrupt level <v1.4><1.9>
|
|
viaIntMask EQU $0100 ; VIA1 interrupt level
|
|
loIntMask EQU $0100
|
|
|
|
|
|
;---------------------------------------------------
|
|
; Hardware Base Addresses
|
|
;---------------------------------------------------
|
|
|
|
WrOffs EQU 0 ; SCSI write addrs are same as read base
|
|
MskIOP1 EQU 1 ; IOP 1 (SWIM) is level 1 interrupt
|
|
MskVIA1 EQU 1 ; VIA 1 is level 1
|
|
MskADB EQU 1 ; ADB is level 1
|
|
Msk60Hz EQU 1 ; 60 Hz is level 1
|
|
MskSCSI EQU 2 ; SCSI is level 2
|
|
MskSound EQU 2 ; sound is level 2 <4.5>
|
|
MskSlots EQU 2 ; slots are level 2 interrupts
|
|
MskRTC EQU 3 ; RTC is level 3
|
|
MskIOP0 EQU 4 ; IOP 0 (& SCC chip) is level 4
|
|
MskPwrOff EQU 6 ; Poweroff button is level 6
|
|
MskNMI EQU 7 ; NMI switch is level 7
|
|
|
|
|
|
; --------------------------------------------------------------------------------------------------- <T8>
|
|
; Bit definitions for the Cache Control Register (CACR) on various CPUs <T8>
|
|
; --------------------------------------------------------------------------------------------------- <T8>
|
|
;
|
|
; 020 CACR: (from MC68020 User's Manual, 3rd Ed. pg. 6-3) <T8>
|
|
; +------------------------------------------------+ <T8>
|
|
; | 0 .............. 0 | C | CE | F | E | <T8>
|
|
; +------------------------------------------------+ <T8>
|
|
; 31 4 3 2 1 0 <T8>
|
|
;
|
|
; C = Clear Cache <T8>
|
|
; CE = Clear Entry <T8>
|
|
; F = Freeze Cache <T8>
|
|
; E = Enable (Inst.) Cache <T8>
|
|
;
|
|
;
|
|
; 030 CACR: (from MC68030 User's Manual, 2nd Ed. pg 6-15) <T8>
|
|
; +------------------------------------------------------------------------------------+ <T8>
|
|
; | 0 ... 0 | WA | DBE | CD | CED | FD | ED | 0 | 0 | 0 | IBE | CI | CEI | FI | EI | <T8>
|
|
; +------------------------------------------------------------------------------------+ <T8>
|
|
; 31 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 <T8>
|
|
;
|
|
; WA = Write Allocate <T8>
|
|
; DBE = Data Burst Allocate <T8>
|
|
; CD = Clear Data Cache <T8>
|
|
; CED = Clear Entry in Data Cache <T8>
|
|
; FD = Freeze Data Cache <T8>
|
|
; ED = Enable Data Cache <T8>
|
|
; IBE = Instruction Burst Enable <T8>
|
|
; CI = Clear Instruction Cache <T8>
|
|
; CEI = Clear Entry in Instruction Cache <T8>
|
|
; FI = Freeze Instruction Cache <T8>
|
|
; EI = Enable Instruction Cache <T8>
|
|
;
|
|
;
|
|
; 040 CACR: (from MC68040 User's Manual, 1st Ed., pg. 7-19) <T8>
|
|
; +-------------------------------------+ <T8>
|
|
; | DE | 0 ... 0 | IE | 0 ... 0 | <T8>
|
|
; +-------------------------------------+ <T8>
|
|
; 31 30 16 15 14 0 <T8>
|
|
;
|
|
; DE = Enable Data Cache <T8>
|
|
; IE = Enable Instruction Cache <T8>
|
|
;
|
|
|
|
; MC68040 CACR bits of note:
|
|
|
|
CACR_IE_040 EQU 15 ; bit # of instruction cache enable/disable on 040s <T8>
|
|
CACR_DE_040 EQU 31 ; bit # of data cache enable/disable on 040s <T8>
|
|
|
|
; MC68020 and MC68030 CACR bits of note:
|
|
|
|
CACR_EI_020_030 EQU 0 ; bit # of inst. cache enable/disable on 020/030s <T8>
|
|
CACR_FI_020_030 EQU 1 ; bit # of inst. cache freeze on 020/030s <T8>
|
|
CACR_CEI_020_030 EQU 2 ; bit # of inst. cache flush entry on 020/030s <T8>
|
|
CACR_CI_020_030 EQU 3 ; bit # of inst. cache flush on 020/030s <T8>
|
|
CACR_IBE_030 EQU 4 ; bit # of data cache burst enable on 030s <T8>
|
|
CACR_ED_030 EQU 8 ; bit # of data cache enable/disable on 030s <T8>
|
|
CACR_FD_030 EQU 9 ; bit # of data cache freeze on 030s <T8>
|
|
CACR_CED_030 EQU 10 ; bit # of data cache flush entry on 030s <T8>
|
|
CACR_CD_030 EQU 11 ; bit # of data cache flush on 030s <T8>
|
|
CACR_DBE_030 EQU 12 ; bit # of data cache burst enable on 030s <T8>
|
|
CACR_WA_030 EQU 13 ; bit # of write allocate enable on 030s <T8>
|
|
|
|
;__________________________________________________________________________________________
|
|
;
|
|
;
|
|
; Miscellaneous Equates - Look Here If You Can't Find It Anywhere Else.
|
|
;
|
|
;
|
|
;__________________________________________________________________________________________
|
|
|
|
|
|
|
|
Machine EQU 7 ; new Machine number for patches <18>
|
|
|
|
;---------------------------------------------------
|
|
; System Software Information
|
|
;---------------------------------------------------
|
|
|
|
numOsTrap EQU 256 ; number of os traps
|
|
ToolTable EQU $0E00 ; start of toolbox trap table
|
|
numTbTrap EQU 1024 ; number of toolbox traps
|
|
numTrapMask EQU numTbTrap-1 ; mask for number of tb traps
|
|
JMemMgr24 EQU $1E00 ; jump vector start for 24 bit Memory Manager <v1.9>
|
|
JMemMgr32 EQU $1F00 ; jump vector start for 32 bit Memory Manager <v1.9>
|
|
HeapStart EQU $2800 ; Low mem is now 10k bytes <SM13>
|
|
defSysHeap EQU $18000 ; Default size of the system heap
|
|
nDfltStackSize EQU $6000 ; Default stack size
|
|
|
|
**** maybe not so temporary to allow things to build **** <3.5>
|
|
oneSecConst EQU 8 ; gets converted to $80000 for onesec constant<3.5>
|
|
IF BlackBirdDebug THEN
|
|
ROMStart EQU $40000000 ; ¥¥PN BlackBirdstarting address of final ROM code <3.5>
|
|
ELSE
|
|
ROMStart EQU $40800000 ; starting address of final ROM code <3.5>
|
|
ENDIF
|
|
snd2MemTop EQU $300 ; SoundLow to Memtop
|
|
pwm2MemTop EQU $2FF ; PWMBuffer to MemTop
|
|
bufWorldSize EQU 8192 ; total size of the BufPtr world <H16>
|
|
|
|
;--------------------------------------------------- <SM4> rb, start
|
|
; Sound parameters <P4>
|
|
;---------------------------------------------------
|
|
sampleSize equ 4 ; number of bytes per sample
|
|
bufferSize equ 960 ; number of samples per buffer
|
|
sampleRate equ 24 * 1024 ; 24KHz sample rate
|
|
|
|
;---------------------------------------------------------------------
|
|
; Whitney Sound Register Offsets (from ASC base in UniversalTables.a)
|
|
;---------------------------------------------------------------------
|
|
wSndInABWritePtr equ $f54 ; [word] A/B input FIFO write pointer (alias at $f04)
|
|
wSndInAReadPtr equ $f52 ; [word] A input FIFO read pointer
|
|
wSndInBReadPtr equ $f56 ; [word] B input FIFO read pointer
|
|
|
|
wSndOutAWritePtr equ $f58 ; [word] A output FIFO write pointer
|
|
wSndOutBWritePtr equ $f5c ; [word] B output FIFO write pointer
|
|
wSndOutABReadPtr equ $f5a ; [word] A/B output FIFO read pointer (alias at $f26)
|
|
|
|
wSndControl equ $f40 ; [byte] configures Singer power/FIFO size/sample rate, etc.
|
|
wSndFIFOBase equ $f44 ; [long] physical base address of FIFO
|
|
wSndFIFOBaseHi equ $f44 ; [word] high order (physical) word of FIFO base address in RAM
|
|
wSndFIFOBaseLo equ $f46 ; [word] low order word of FIFO base address in RAM
|
|
|
|
wSndAData equ $1000 ; [word] 16-bit sound in/out data for left channel
|
|
wSndBData equ $1800 ; [word] 16-bit sound in/out data for right channel
|
|
|
|
wSndSingerCtl1 equ $f48 ; [word] Singer mute/input select/gain control
|
|
wSndSingerCtl2 equ $f4a ; [word] Singer attenuation/digital out control
|
|
wSndSingerStat1 equ $f4c ; [word] Singer valid/clipping/error/rev status
|
|
wSndSingerStat2 equ $f4e ; [word] Singer digital input status
|
|
|
|
;---------------------------------------------------
|
|
; Whitney Sound Register Bit Definitions
|
|
;---------------------------------------------------
|
|
|
|
; === sndControl register ===
|
|
wSampleRateMsk equ $03 ; Mask for sample rate bits
|
|
wFIFOSizeMsk equ $0C ; Mask for FIFO size bits
|
|
|
|
wSampleRate equ 0 ; Sample rate field for Singer Serial Clock (2 bits)
|
|
wSampleRate1 equ 0 ; lsbit
|
|
wSampleRate2 equ 1 ; msbit
|
|
|
|
wFIFOSize equ 2 ; FIFO size (2 bits)
|
|
wFIFOSize1 equ 2 ; lsbit
|
|
wFIFOSize2 equ 3 ; msbit
|
|
|
|
wSingerClk equ 4 ; Singer master clock enable
|
|
wSingerPower equ 5 ; Singer power enable
|
|
wSingerSNDFlag equ 6 ; Singer sound flag
|
|
; equ 7 ; unused
|
|
|
|
; === sndSingerCtl1 register ===
|
|
wRGainMsk equ $000F ; Mask for right channel input gain
|
|
wLGainMsk equ $00F0 ; Mask for left channel input gain
|
|
wRGain equ 0 ; Singer right input A/D gain (4 bits)
|
|
wRGain1 equ 0 ; lsb
|
|
wRGain2 equ 1
|
|
wRGain3 equ 2
|
|
wRGain4 equ 3 ; msb
|
|
|
|
wLGain equ 4 ; Singer left input A/D gain (4 bits)
|
|
wLGain1 equ 4 ; lsb
|
|
wLGain2 equ 5
|
|
wLGain3 equ 6
|
|
wLGain4 equ 7 ; msb
|
|
|
|
wInSelRight equ 8 ; Input select for right channel
|
|
wInSelLeft equ 9 ; Input select for left channel
|
|
|
|
wMute equ 10 ; Mute enable
|
|
|
|
wWordAOut equ 11 ; Word A Out 17:21 (5 bits) - 0's, see Singer spec
|
|
; equ 12
|
|
; equ 13
|
|
; equ 14
|
|
; equ 15
|
|
|
|
; === sndSingerCtl2 register ===
|
|
wDigOut equ 0 ; Singer digital output (4 bits)
|
|
wDigOut4 equ 0 ; output 4
|
|
wDigOut3 equ 1 ; output 3
|
|
wDigOut2 equ 2 ; output 2
|
|
wDigOut1 equ 3 ; output 1
|
|
|
|
wRAtten equ 4 ; Singer right D/A attenuation (4 bits)
|
|
wRAtten1 equ 4 ; lsb
|
|
wRAtten2 equ 5
|
|
wRAtten3 equ 6
|
|
wRAtten4 equ 7 ; msb
|
|
|
|
wLAtten equ 8 ; Singer left D/A attenuation (4 bits)
|
|
wLAtten1 equ 8 ; lsb
|
|
wLAtten2 equ 9
|
|
wLAtten3 equ 10
|
|
wLAtten4 equ 11 ; msb
|
|
|
|
|
|
wWordBOut equ 12 ; Word B Out 49:52 (5 bits) - 0's in SM1, see Singer spec
|
|
; equ 13
|
|
; equ 14
|
|
; equ 15
|
|
|
|
; === sndSingerStat1 register ===
|
|
wRev equ 0 ; Singer revision number (4 bits)
|
|
wRev1 equ 0 ; lsb
|
|
wRev2 equ 1
|
|
wRev3 equ 2
|
|
wRev4 equ 3 ; msb
|
|
|
|
wErr equ 4 ; Singer error code (4 bits)
|
|
wErr1 equ 4 ; lsb
|
|
wErr2 equ 5
|
|
wErr3 equ 6
|
|
wErr4 equ 7 ; msb
|
|
|
|
wRClip equ 8 ; Right clipping indicator
|
|
wLClip equ 9 ; Left clipping indicator
|
|
|
|
wADValid equ 10 ; A/D valid data indicator
|
|
|
|
wWordAIn equ 11 ; Word A In 17:21 (5 bits), see Singer spec
|
|
; equ 12
|
|
; equ 13
|
|
; equ 14
|
|
; equ 15
|
|
|
|
; === sndSingerStat2 register ===
|
|
wDigIn equ 0 ; Singer digital input (4 bits)
|
|
wDigIn4 equ 0 ; input 4
|
|
wDigIn3 equ 1 ; input 3
|
|
wDigIn2 equ 2 ; input 2
|
|
wDigIn1 equ 3 ; input 1
|
|
|
|
wWordBIn equ 4 ; Word B In 49:60 (12 bits), see Singer spec
|
|
; equ 5
|
|
; equ 6
|
|
; equ 7
|
|
; equ 8
|
|
; equ 9
|
|
; equ 10
|
|
; equ 11
|
|
; equ 12
|
|
; equ 13
|
|
; equ 14
|
|
; equ 15
|
|
|
|
;---------------------------------------------------
|
|
; PSC Hardware Defs
|
|
;---------------------------------------------------
|
|
|
|
; === Hardware Base Addresses ===
|
|
PSCBase equ $50f31000 ; Base address of the PSC
|
|
|
|
;---------------------------------------------------
|
|
; PSC Sound Register Offsets
|
|
;---------------------------------------------------
|
|
sndComCtl equ $200 ; [word] sound and communications control
|
|
singerCtl equ $204 ; [long] singer sound CODEC control
|
|
singerStat equ $208 ; [long] singer sound CODEC status (read only)
|
|
sndPhase equ $20c ; [long] sound subsystem phase (read only)
|
|
sndInBase equ $210 ; [long] sound input double-buffer base address
|
|
sndOutBase equ $214 ; [long] sound output double buffer base address
|
|
sndSize equ $218 ; [word] sound input and output buffer size
|
|
dspOverRun equ $21C ; [byte] DSP overrun status register.
|
|
|
|
;---------------------------------------------------
|
|
; PSC Sound Register Bit Definitions
|
|
;---------------------------------------------------
|
|
; === sndComCtl register ===
|
|
pSubFrmInSel equ 0 ; singer sound CODEC input subframe select
|
|
pSubFrmInSel1 equ 0 ; singer sound CODEC input subframe select, lsbit
|
|
pSubFrmInSel2 equ 1 ; singer sound CODEC input subframe select, msbit
|
|
|
|
pSubFrmOutSel equ 2 ; singer sound CODEC output subframe select
|
|
pSubFrmOutSel1 equ 2 ; singer sound CODEC output subframe select, lsbit
|
|
pSubFrmOutSel2 equ 3 ; singer sound CODEC output subframe select
|
|
pSubFrmOutSel3 equ 4 ; singer sound CODEC output subframe select
|
|
pSubFrmOutSel4 equ 5 ; singer sound CODEC output subframe select, msbit
|
|
|
|
pFrmIntEn equ 6 ; frame interrupt enable
|
|
pSndInEn equ 7 ; sound input DMA enable
|
|
pSndOutEn equ 8 ; sound output DMA enable
|
|
|
|
pSndRate equ 9 ; singer sound CODEC sampling rate control
|
|
pSndRate1 equ 9 ; singer sound CODEC sampling rate control, lsbit
|
|
pSndRate2 equ 10 ; singer sound CODEC sampling rate control, msbit
|
|
|
|
pComRate equ 11 ; communications CODEC sampling rate contrl
|
|
pComRate1 equ 11 ; communications CODEC sampling rate contrl, lsbit
|
|
pComRate2 equ 12 ; communications CODEC sampling rate contrl, msbit
|
|
; equ 13 ; unused
|
|
; equ 14 ; unused
|
|
; equ 15 ; unused
|
|
|
|
|
|
sndComCtlInit equ (0<<pSubFrmInSel)|\ ; Input subframe zero selected
|
|
(0<<pSubFrmOutSel)|\ ; Ouput subframe zero selected
|
|
(0<<pFrmIntEn)|\ ; frame interrupts disabled
|
|
(0<<pSndInEn)|\ ; sound input disabled
|
|
(0<<pSndOutEn)|\ ; sound output disabled
|
|
(0<<pSndRate)|\ ; 24KHz sampling rate selected
|
|
(0<<pComRate) ; communications CODEC, we just don't care
|
|
|
|
soundOutEnable equ (0<<pSubFrmInSel)|\ ; Input subframe zero selected
|
|
(1<<pSubFrmOutSel)|\ ; Ouput subframe zero selected
|
|
(0<<pFrmIntEn)|\ ; frame interrupts enabled
|
|
(0<<pSndInEn)|\ ; sound input disabled
|
|
(1<<pSndOutEn)|\ ; sound output disabled
|
|
(0<<pSndRate)|\ ; 24KHz sampling rate selected
|
|
(0<<pComRate) ; communications CODEC, we just don't care
|
|
|
|
|
|
|
|
; === singerCtl register ===
|
|
pOutputPort equ 0 ; set digital output port
|
|
pOutputPort1 equ 0 ; set digital output port, lsb
|
|
pOutputPort2 equ 1 ; set digital output port
|
|
pOutputPort3 equ 2 ; set digital output port
|
|
pOutputPort4 equ 3 ; set digital output port, msb
|
|
|
|
pRightAtten equ 4 ; right ouput attenutaion
|
|
pRightAtten1 equ 4 ; right ouput attenutaion, lsb
|
|
pRightAtten2 equ 5 ; right ouput attenutaion
|
|
pRightAtten3 equ 6 ; right ouput attenutaion
|
|
pRightAtten4 equ 7 ; right ouput attenutaion, msb
|
|
|
|
pLeftAtten equ 8 ; Left ouput attenutaion
|
|
pLeftAtten1 equ 8 ; Left ouput attenutaion, lsb
|
|
pLeftAtten2 equ 9 ; Left ouput attenutaion
|
|
pLeftAtten3 equ 10 ; Left ouput attenutaion
|
|
pLeftAtten4 equ 11 ; Left ouput attenutaion, msb
|
|
|
|
pRightGain equ 12 ; right input gain
|
|
pRightGain1 equ 12 ; right input gain, lsb
|
|
pRightGain2 equ 13 ; right input gain
|
|
pRightGain3 equ 14 ; right input gain
|
|
pRightGain4 equ 15 ; right input gain, msb
|
|
|
|
pLeftGain equ 16 ; left input gain
|
|
pLeftGain1 equ 16 ; left input gain, lsb
|
|
pLeftGain2 equ 17 ; left input gain
|
|
pLeftGain3 equ 18 ; left input gain
|
|
pLeftGain4 equ 19 ; left input gain, msb
|
|
|
|
pRightInMux equ 20 ; right input mux
|
|
pLeftInMux equ 21 ; left input mux
|
|
pMute equ 22 ; mute bit
|
|
pExpCtl equ 23 ; expand bit for control
|
|
; equ 24 ; unused
|
|
; equ 25 ; unused
|
|
; equ 26 ; unused
|
|
; equ 27 ; unused
|
|
; equ 28 ; unused
|
|
; equ 29 ; unused
|
|
; equ 30 ; unused
|
|
; equ 31 ; unused
|
|
|
|
singerCtlInit equ (%1111<<pOutputPort)|\ ; digitial ouput ports selected
|
|
(0<<pRightAtten)|\ ; right output attenuation set to zero
|
|
(0<<pLeftAtten)|\ ; left output attenuation set to zero
|
|
(%0101<<pRightGain)|\ ; right input gain set to middle
|
|
(%0101<<pLeftGain)|\ ; left input gain set to middle
|
|
(0<<pRightInMux)|\ ; input muxes irrelevant
|
|
(0<<pLeftInMux)|\ ;
|
|
(1<<pMute)|\ ; mute ON
|
|
(0<<pExpCtl) ; no expand
|
|
|
|
unMute equ (%1111<<pOutputPort)|\ ; digitial ouput ports selected
|
|
(0<<pRightAtten)|\ ; right output attenuation set to zero
|
|
(0<<pLeftAtten)|\ ; left output attenuation set to zero
|
|
(%0101<<pRightGain)|\ ; right input gain set to middle
|
|
(%0101<<pLeftGain)|\ ; left input gain set to middle
|
|
(0<<pRightInMux)|\ ; input muxes irrelevant
|
|
(0<<pLeftInMux)|\ ;
|
|
(0<<pMute)|\ ; mute OFF
|
|
(0<<pExpCtl) ; no expand
|
|
|
|
|
|
|
|
; === singerStat register ===
|
|
pInputPort1 equ 0 ; set digital Input port, lsb
|
|
pInputPort2 equ 1 ; set digital Input port
|
|
pInputPort3 equ 2 ; set digital Input port
|
|
pInputPort4 equ 3 ; set digital Input port, msb
|
|
; equ 4 ; unused
|
|
; equ 5 ; unused
|
|
; equ 6 ; unused
|
|
; equ 7 ; unused
|
|
; equ 8 ; unused
|
|
; equ 9 ; unused
|
|
; equ 10 ; unused
|
|
; equ 11 ; unused
|
|
pRevNum1 equ 12 ; revision number, lsb
|
|
pRevNum2 equ 13 ; revision number
|
|
pRevNum3 equ 14 ; revision number
|
|
pRevNum4 equ 15 ; revision number, msb
|
|
pSingerStatus1 equ 16 ; status bits, lsb
|
|
pSingerStatus2 equ 17 ; status bits
|
|
pSingerStatus3 equ 18 ; status bits
|
|
pSingerStatus4 equ 19 ; status bits, msb
|
|
pOFRight equ 20 ; right channel overflow
|
|
pOFLeft equ 21 ; left channel overflow
|
|
pValidData equ 22 ; valid sound data
|
|
pExpStat equ 23 ; expand bit for status
|
|
; equ 24 ; unused
|
|
; equ 25 ; unused
|
|
; equ 26 ; unused
|
|
; equ 27 ; unused
|
|
; equ 28 ; unused
|
|
; equ 29 ; unused
|
|
; equ 30 ; unused
|
|
; equ 31 ; unused
|
|
|
|
|
|
; === sound phase register ===
|
|
pPreScaleLSB equ 0 ; pre-scaler lsbit
|
|
pReScaleMSB equ 5 ; pre-Scaler msbit
|
|
pOffsetLSB equ 6 ; sample offset lsbit
|
|
pOffsetMSB equ 17 ; sample offset msbit
|
|
; equ 18 ; unused
|
|
; equ 19 ; unused
|
|
; equ 20 ; unused
|
|
; equ 21 ; unused
|
|
; equ 22 ; unused
|
|
; equ 23 ; unused
|
|
; equ 24 ; unused
|
|
; equ 25 ; unused
|
|
; equ 26 ; unused
|
|
; equ 27 ; unused
|
|
; equ 28 ; unused
|
|
; equ 29 ; unused
|
|
; equ 30 ; unused
|
|
; equ 31 ; unused
|
|
|
|
phaseOffsetMsk equ $003FFFC0 ; <SM4> rb, end
|
|
|
|
;---------------------------------------------------
|
|
; PSC DSP Register Bit Definitions <SM10> ejb
|
|
;---------------------------------------------------
|
|
|
|
; === dspOverrun register ===
|
|
pdspReset equ 0 ; when set places the dsp in reset state
|
|
pdspResetEn equ 1 ; when cleared disables the dspReset bit
|
|
pdspFrameOvr equ 2 ; when set indicates cat2 frame overrun on the dsp
|
|
; equ 3 ; unused
|
|
; equ 4 ; unused
|
|
; equ 5 ; unused
|
|
; equ 6 ; unused
|
|
pdspSet equ 7 ; "0" clears, "1" sets for any bit field [0:6] containing a "1"
|
|
|
|
;---------------------------------------------------
|
|
; ???
|
|
;---------------------------------------------------
|
|
|
|
seRegs EQU $0C30 ; offset to Sys Error Regs w/o Overlay
|
|
|
|
;---------------------------------------------------
|
|
; Hardware configuration bits.
|
|
;---------------------------------------------------
|
|
|
|
hwCbSCSI EQU 15 ; SCSI port present
|
|
hwCbClock EQU 14 ; New clock chip present
|
|
hwCbExPRAM EQU 13 ; Extra Parameter Ram valid.
|
|
hwCbFPU EQU 12 ; FPU chip present.
|
|
hwCbMMU EQU 11 ; Some kind of MMU present (see MMUType for what kind).
|
|
hwCbADB EQU 10 ; Apple Desktop Bus present.
|
|
hwCbAUX EQU 9 ; Running A/UX <2.8>
|
|
hwCbPwrMgr EQU 8 ; Power Manager present <2.8>
|
|
hwCmSCSI EQU (1 << hwCbSCSI)
|
|
hwCmClock EQU (1 << hwCbClock)
|
|
hwCmExPRAM EQU (1 << hwCbExPRAM)
|
|
hwCmFPU EQU (1 << hwCbFPU)
|
|
hwCmMMU EQU (1 << hwCbMMU)
|
|
hwCmADB EQU (1 << hwCbADB)
|
|
hwCmAUX EQU (1 << hwCbAUX)
|
|
hwCmPwrMgr EQU (1 << hwCbPwrMgr)
|
|
|
|
|
|
;---------------------------------------------------
|
|
; HcMac Clock Change Addresses
|
|
;---------------------------------------------------
|
|
|
|
Clock16M EQU $FE0000 ; Go to sixteen megahertz clock throughput
|
|
Clock1M EQU $FE0002 ; Go to one megahertz clock throughput (adds 64 wait states)
|
|
|
|
|
|
;---------------------------------------------------
|
|
; SCC Clock Rates, Baud Rate Constants
|
|
;---------------------------------------------------
|
|
|
|
nuMacClock EQU 36864
|
|
nuMacConst EQU 115200
|
|
|
|
macClock EQU 36707 ; in Hz * 100
|
|
macConst EQU 114709 ; in Hz/32
|
|
|
|
hcMacClock EQU 36720 ; SCC clock rates
|
|
hcMacConst EQU 114750
|
|
|
|
|
|
;---------------------------------------------------
|
|
; Deep Shit Rectangle info
|
|
;---------------------------------------------------
|
|
|
|
dsRectTL EQU (64<<16)+32 ; top left = 64,32
|
|
dsRectBR EQU (190<<16)+480 ; bottom right = 190,480
|
|
dsRectHei EQU (DSrectBR**$FFFF0000)-(DSrectTL**$FFFF0000)>>16
|
|
dsRectLen EQU (DSrectBR**$FFFF)-(DSrectTL**$FFFF)
|
|
|
|
|
|
;---------------------------------------------------
|
|
; System Error Equates
|
|
;---------------------------------------------------
|
|
|
|
seVars EQU seRegs ; start of system error data space (wrap city)
|
|
seVSize EQU 128 ; # of bytes in space
|
|
seD0 EQU seVars ; loc of saved reg D0
|
|
seA0 EQU seD0+32 ; loc of saved reg A0
|
|
seA7 EQU seA0+28 ; loc of saved reg A7
|
|
sePC EQU seA7+4 ; loc of saved PC
|
|
seSR EQU sePC+4 ; loc of saved SR
|
|
seAccess EQU seSR+2 ; PC address during bus/address error
|
|
seCmdSize EQU seAccess+4 ; # of bytes of parameters passed in _debugger call
|
|
se000BE EQU seCmdSize+2 ; 8 bytes of bus error info for 68000
|
|
seLastVar EQU se000BE+8 ; last var in System Error data space
|
|
|
|
|
|
;---------------------------------------------------
|
|
; ROM based debugger nub
|
|
;---------------------------------------------------
|
|
|
|
rdPort EQU seLastVar ; Number of port currently in use (0 => no link, 1 => A, 2 => B)
|
|
rdCode EQU rdPort+2 ; Ptr to code download buffer.
|
|
rdAtrap EQU rdCode+4 ; Saved Rom Atrap handler
|
|
rdLowTrap EQU rdAtrap+4 ; low value for trap handling
|
|
rdHiTrap EQU rdLowTrap+2 ; high value for trap handling
|
|
rdResult EQU rdHiTrap+2 ; result of executing down-loaded code, etc. (16 bytes)
|
|
rdEnd EQU rdResult+16 ; end of vars
|
|
|
|
|
|
;---------------------------------------------------
|
|
; Microbug
|
|
;---------------------------------------------------
|
|
|
|
; NOTE: Keep mbDotAddr immediately before mBlocAddr
|
|
|
|
mbBufSize EQU 34
|
|
mbBuffer EQU seLastVar ; buffer for input
|
|
mbSign EQU mbBuffer+mbBufSize ; ST => negative sign during conversion
|
|
mbDotAddr EQU mbSign+2 ; saved address
|
|
mBlocAddr EQU mbDotAddr+4 ; saved location
|
|
|
|
|
|
;---------------------------------------------------
|
|
; Alternate ROM vectors
|
|
;---------------------------------------------------
|
|
|
|
DiagROM EQU $F80000 ; Alternate ROM - initial vector
|
|
DiagROM1 EQU $F80080 ; Alternate ROM - memory sizing vector
|
|
DiagROM2 EQU $F80088 ; Alternate ROM - init I/O vector
|
|
|
|
|
|
;---------------------------------------------------
|
|
; Timing constants
|
|
;---------------------------------------------------
|
|
|
|
VIAClockHz EQU 783360 ; VIA clock rate is 783360 Hz. <2.8>
|
|
nTicks EQU VIAClockHz/1000 ; VIA timer ticks per msec
|
|
oneSecTicks EQU 60 ; ticks, of course
|
|
IF &TYPE('__SysEqu__') = 'UNDEFINED' THEN
|
|
TimeSCSIDB EQU $0B24 ; DBRAs & SCSI access per millisecond <1.9>
|
|
ENDIF
|
|
|
|
ramChk EQU 1024 ; Amount of memory tested for stack.
|
|
|
|
|
|
|
|
;__________________________________________________________________________________________
|
|
;
|
|
;
|
|
; ROM Header RECORD Definition
|
|
;
|
|
;
|
|
;__________________________________________________________________________________________
|
|
|
|
ROMHeader RECORD 0,INCREMENT ; offsets to fields in base of ROM
|
|
ResetSP DS.L 1 ; $0000 SP to be loaded at reset time
|
|
CheckSum EQU ResetSP ; $0000 hiram stuffs checksum here
|
|
ResetPC DS.L 1 ; $0004 PC to be loaded at reset time
|
|
MachineNumber DS.B 1 ; $0008 Machine Number
|
|
ROMVersion DS.B 1 ; $0009 ROM Version Number
|
|
ReStart DS.W 2 ; $000A JMP to StartBoot routine
|
|
BadDisk DS.W 2 ; $000E JMP to eject disk, and ReBoot routine
|
|
ROMRelease DS.W 1 ; $0012 ROM Release in HEX, eg. $10B5 is 1.0§5
|
|
PatchFlags DS.B 1 ; $0014 ROM overpatch basis <H14>
|
|
DS.B 1 ; $0015 unused <H14>
|
|
ForeighOSTbl DS.L 1 ; $0016 offset to foreign OS vector table
|
|
RomRsrc DS.L 1 ; $001A HiRam stuffs offset to ROM rsrc header here
|
|
Eject DS.W 2 ; $001E JMP to DoEject routine
|
|
DispTableOff DS.L 1 ; $0022 offset to the compressed dispatch table
|
|
Critical DS.W 2 ; $0026 JMP to Critical error handler
|
|
ResetEntry DS.W 2 ; $002A JMP to Reset Entry Point routine.
|
|
RomLoc DS.B 1 ; $002E (Bit 0: In Ram, Bit 1: In Emulator)
|
|
DS.B 1 ; $002F unused
|
|
CheckSum0 DS.L 1 ; $0030 checksum 0
|
|
CheckSum1 DS.L 1 ; $0034 checksum 1
|
|
CheckSum2 DS.L 1 ; $0038 checksum 2
|
|
CheckSum3 DS.L 1 ; $003C checksum 3
|
|
RomSize DS.L 1 ; $0040 HiRam stuffs size of ROM in bytes here
|
|
EraseIconOff DS.L 1 ; $0044 Offset to code to ease the Happy Mac icon
|
|
InitSys7ToolboxOff DS.L 1 ; $0048 Offset to System 7.0 toolbox init code
|
|
SubVers DS.L 1 ; $004C Yet another subversion (sigh)
|
|
ENDR
|
|
|
|
|
|
;---------------------------------------------------
|
|
; Romulator ROM location bits and TestFor Macro
|
|
;---------------------------------------------------
|
|
|
|
locValid1 EQU 7 ; this must be 1
|
|
locValid2 EQU 6 ; this must be 0
|
|
inEmulatorBit EQU 1 ; running in emulator
|
|
inRamBit EQU 0 ; running in ram
|
|
|
|
;----------
|
|
; TestInRam Macro <4.4>
|
|
;
|
|
; This macro tests the RomLoc byte in the ROM header to determine the ROM is located
|
|
; in RAM.
|
|
;----------
|
|
MACRO
|
|
TestInRam ®
|
|
lea @testInRamData,®
|
|
move.w #$1,(®) ; write to "ROM"
|
|
tst.w @testInRamData ; did it stick?
|
|
bra.s @testDone
|
|
@testInRamData dc.w 0
|
|
@testDone
|
|
ENDM
|
|
|
|
;----------
|
|
; WhitneyRevAtLeast Macro
|
|
; Sets the Z bit in the CCR if Whitney revision is greater or equal to &rev parameter passed in
|
|
; else clears the Z bit
|
|
; NOTE: This macro no longer supports the original rev Whitney b/c the hack used will interfere with
|
|
; modem operation.
|
|
;----------
|
|
MACRO
|
|
WhitneyRevAtLeast &rev
|
|
cmpi.b #&rev,WhitneyRev
|
|
bmi.s @older
|
|
ori #$04,CCR ;set the Z bit
|
|
bra.s @exit
|
|
@older andi #$FB,CCR ;clear the Z bit
|
|
@exit
|
|
ENDM
|
|
|
|
;----------
|
|
; PrattFlashSystem Macro
|
|
; Sets the Z bit in the CCR if Pratt detects Flash on the expansion board,
|
|
; else clears the Z bit
|
|
;----------
|
|
PrattSysStatReg EQU $50080007
|
|
MACRO
|
|
PrattFlashSystem
|
|
btst.b #PrattFlashLBit,PrattSysStatReg ; Is this a flash rom system
|
|
ENDM
|
|
|
|
ForAmusementOnly equ 0
|
|
If ForAmusementOnly then
|
|
;__________________________________________________________________________________________
|
|
;
|
|
;
|
|
; Old 16 bit Equates for onMac, onMacPP, and onHcMac
|
|
;
|
|
;
|
|
;__________________________________________________________________________________________
|
|
|
|
;=======================================;
|
|
; Macintosh Plus Hardware Information ;
|
|
;=======================================;
|
|
|
|
hwCfgBits EQU hwCmSCSI++hwCmClock
|
|
machine EQU 0
|
|
rom85Bits EQU $7F ; New ROMs, No Power Off.
|
|
|
|
; === Interrupt Masks ===
|
|
hiIntMask EQU $0700 ; programmer switch only
|
|
sccIntMask EQU $0200 ; SCC interrupt Level <1.5>
|
|
sccEnblMask EQU $F9FF ; mask to enable SCC interrupts
|
|
viaIntMask EQU $0100 ; mask for VIA (and VBL) interrupts
|
|
loIntMask EQU $0100
|
|
|
|
; === VIA1 BUFFER A ===
|
|
;vSound EQU $7 ; sound volume bits (0..2)
|
|
vSndPg2 EQU 3 ; select sound page 2 if 0
|
|
;vOverlay EQU 4 ; overlay bit (overlay when 1)
|
|
;vHeadSel EQU 5 ; head select line for Sony
|
|
vPage2 EQU 6 ; select video page 2 if 0
|
|
;vSCCWrReq EQU 7 ; SCC write/request line
|
|
|
|
vAOut EQU (vSound)|\ ; sound volume bits are outputs
|
|
(1<<vSndPg2)|\ ; sound page 2 select is an output
|
|
(1<<vOverlay)|\ ; overlay bit is an output
|
|
(1<<vHeadSel)|\ ; head select line is an output
|
|
(1<<vPage2)|\ ; video page 2 select is an output
|
|
(0<<vSCCWrReq) ; SCC write/request line is an input
|
|
|
|
vAInit EQU (1)|\ ; sound volume level initially 1
|
|
(1<<vSndPg2)|\ ; main sound buffer selected
|
|
(0<<vOverlay)|\ ; overlay is turned off
|
|
(1<<vHeadSel)|\ ; head select line is an output
|
|
(1<<vPage2)|\ ; main screen buffer selected
|
|
(0<<vSCCWrReq) ; SCC write/request line is an input
|
|
|
|
|
|
; === VIA1 BUFFER B ===
|
|
;vRTCData EQU 0 ; real time clock data
|
|
;vRTCClk EQU 1 ; real time clock clock pulses
|
|
;vRTCEnb EQU 2 ; clock enable (0 for enable)
|
|
vSW EQU 3 ; mouse switch (0 when down)
|
|
vX2 EQU 4 ; mouse X level
|
|
vY2 EQU 5 ; mouse Y level
|
|
vH4 EQU 6 ; horizontal sync
|
|
;vSndEnb EQU 7 ; /sound enable (reset when 1)
|
|
|
|
vBOut EQU (1<<vRTCData)|\ ; real time clock data initially an output
|
|
(1<<vRTCClk)|\ ; real time clock clock is an output
|
|
(1<<vRTCEnb)|\ ; clock enable is an output
|
|
(0<<vSW)|\ ; mouse switch is an input
|
|
(0<<vX2)|\ ; mouse X level is an input
|
|
(0<<vY2)|\ ; mouse Y level is an input
|
|
(0<<vH4)|\ ; horizontal sync is an input
|
|
(1<<vSndEnb) ; sound enable is an output
|
|
|
|
vBInit EQU (1<<vRTCData)|\ ; real time clock data is one
|
|
(1<<vRTCClk)|\ ; real time clock clock is high
|
|
(1<<vRTCEnb)|\ ; clock initially disabled
|
|
(0<<vSW)|\ ; mouse switch is an input
|
|
(0<<vX2)|\ ; mouse X level is an input
|
|
(0<<vY2)|\ ; mouse Y level is an input
|
|
(0<<vH4)|\ ; horizontal sync is an input
|
|
(1<<vSndEnb) ; sound is disabled
|
|
|
|
vBufM EQU vBufB ; mouse state is buffer B
|
|
|
|
|
|
; === Hardware Base Addresses ===
|
|
|
|
PhaseRead EQU $F00000 ; Phase read address
|
|
|
|
VBase EQU $EFE1FE ; VIA base address
|
|
AVBufA EQU VBase+vBufA ; VIA buffer A
|
|
AVBufB EQU VBase+vBufB ; VIA buffer B
|
|
AVBufM EQU VBase+vBufM ; VIA buffer with mouse button bit
|
|
|
|
SCCRBase EQU $9FFFF8 ; SCC base read address
|
|
SCCWBase EQU $BFFFF9 ; SCC base write address
|
|
sccWrite EQU SCCWBase-SCCRBase ; general offset for write from read
|
|
|
|
SCSIRd EQU $580000 ; base addr SCSI interface - READ
|
|
SCSIWr EQU $580001 ; base addr SCSI interface - WRITE
|
|
wrOffs EQU SCSIWr-SCSIRd ; write addrs are +1 to the read base
|
|
|
|
SoundLow EQU $3FFD00 ; sound buffer start address
|
|
snd2MemTop EQU $300 ; SoundLow to Memtop
|
|
|
|
PWMBuffer EQU $3FFD01 ; PWM bytes are low bytes
|
|
pwm2MemTop EQU $2FF ; PWMBuffer to MemTop
|
|
|
|
; === Video Parameters ===
|
|
|
|
ScreenLow EQU $3FA700 ; top of screen screen address
|
|
scrn2MemTop EQU $5900 ; ScreenBase to Memtop
|
|
|
|
; === Hardware Base Addresses ===
|
|
|
|
romBSize EQU $20000 ; 128K bytes in ROM $0075
|
|
ROMStart EQU $400000 ; starting address of ROM code
|
|
|
|
DBase EQU $DFE1FF ; disk address base
|
|
|
|
; === System Software Information ===
|
|
bufWorldSize EQU scrn2MemTop ; total size of the BufPtr world
|
|
|
|
oneSecConst EQU 2 ; gets converted to $20000 for onesec constant
|
|
numOsTrap EQU 256 ; number of os traps
|
|
ToolTable EQU $0C00 ; start of toolbox trap table
|
|
numTbTrap EQU 512 ; number of toolbox traps
|
|
numTrapMask EQU numTbTrap-1 ; mask for number of tb traps
|
|
HeapStart EQU $1400 ; Mac Plus starting point
|
|
defSysHeap EQU $B700 ; Default size of the system heap
|
|
nDfltStackSize EQU $2000 ; Default stack size
|
|
|
|
oneSec EQU 95528 ; looptimes *** patch only ***
|
|
halfSec EQU onesec/2 ; *** patch only ***
|
|
stlDelay EQU $30 ; default bus settle delay *** patch only ***
|
|
ROMDoEject EQU $40001E ; jump to DoEject utility *** patch only ***
|
|
dACKRd EQU $200 ; offset of psuedo-DMA - READ *** patch only ***
|
|
|
|
|
|
;=======================================;
|
|
; Macintosh SE Hardware Information ;
|
|
;=======================================;
|
|
|
|
hwCfgBits EQU hwCmSCSI++hwCmClock++hwCmADB
|
|
machine EQU 2
|
|
rom85Bits EQU $7F ; New ROMs, No Power Off.
|
|
|
|
; === Interrupt Masks ===
|
|
hiIntMask EQU $0700 ; programmer switch only
|
|
sccIntMask EQU $0200 ; SCC interrupt Level <1.5>
|
|
sccEnblMask EQU $F9FF ; mask to enable SCC interrupts
|
|
viaIntMask EQU $0100 ; mask for VIA (and VBL) interrupts
|
|
loIntMask EQU $0100
|
|
|
|
; === VIA1 BUFFER A ===
|
|
;vSound EQU $7 ; sound volume bits (0..2)
|
|
;vSync EQU 3 ; Synchronous modem
|
|
vDriveSel EQU 4 ; int drive select (lower drive when 1)
|
|
;vHeadSel EQU 5 ; head select line for Sony
|
|
vPage2 EQU 6 ; select video page 2 if 0
|
|
;vSCCWrReq EQU 7 ; SCC write/request line
|
|
|
|
vAOut EQU (vSound)|\ ; sound volume bits are outputs
|
|
(1<<vSync)|\ ; Synchronous modem is an output
|
|
(1<<vDriveSel)|\ ; int drive select is an output
|
|
(1<<vHeadSel)|\ ; head select line is an output
|
|
(1<<vPage2)|\ ; video page 2 select is an output
|
|
(0<<vSCCWrReq) ; SCC write/request line is an input
|
|
|
|
vAInit EQU (1)|\ ; sound volume level initially 1
|
|
(1<<vSync)|\ ; Synchronous modem disabled (active low)
|
|
(0<<vDriveSel)|\ ; upper floppy drive selected
|
|
(1<<vHeadSel)|\ ; head select line is an output
|
|
(1<<vPage2)|\ ; main screen buffer selected
|
|
(0<<vSCCWrReq) ; SCC write/request line is an input
|
|
|
|
|
|
|
|
; === VIA1 BUFFER B ===
|
|
;vRTCData EQU 0 ; real time clock data
|
|
;vRTCClk EQU 1 ; real time clock clock pulses
|
|
;vRTCEnb EQU 2 ; clock enable (0 for enable)
|
|
;vFDBInt EQU 3 ; Front Desk bus interrupt
|
|
;vFDesk1 EQU 4 ; Front Desk bus state bit 0
|
|
;vFDesk2 EQU 5 ; Front Desk bus state bit 1
|
|
vSCSIMask EQU 6 ; SCSI IRQ mask
|
|
vH4 EQU vSCSIMask ; SCSI IRQ mask (was horiz. sync)
|
|
;vSndEnb EQU 7 ; /sound enable (reset when 1)
|
|
|
|
vBOut EQU (1<<vRTCData)|\ ; real time clock data initially an output
|
|
(1<<vRTCClk)|\ ; real time clock clock is an output
|
|
(1<<vRTCEnb)|\ ; clock enable is an output
|
|
(0<<vFDBInt)|\ ; Front Desk bus interrupt is an input
|
|
(1<<vFDesk1)|\ ; FDB state bit 0 is an output
|
|
(1<<vFDesk2)|\ ; FDB state bit 1 is an output
|
|
(1<<vSCSIMask)|\ ; SCSI IRQ mask is an output
|
|
(1<<vSndEnb) ; sound enable is an output
|
|
|
|
vBInit EQU (1<<vRTCData)|\ ; real time clock data is one
|
|
(1<<vRTCClk)|\ ; real time clock clock is high
|
|
(1<<vRTCEnb)|\ ; clock initially disabled
|
|
(0<<vFDBInt)|\ ; Front Desk bus interrupt is an input
|
|
(1<<vFDesk1)|\ ; FDB state bit 0 is initially state 3
|
|
(1<<vFDesk2)|\ ; FDB state bit 1 is initially state 3
|
|
(1<<vSCSIMask)|\ ; SCSI IRQ mask is initially masked
|
|
(1<<vSndEnb) ; sound is disabled
|
|
|
|
|
|
; === Hardware Base Addresses ===
|
|
|
|
VBase EQU $EFE1FE ; VIA base address
|
|
AVBufA EQU VBase+vBufA ; VIA buffer A
|
|
AVBufB EQU VBase+vBufB ; VIA buffer B
|
|
|
|
SCCRBase EQU $9FFFF8 ; SCC base read address
|
|
SCCWBase EQU $BFFFF9 ; SCC base write address
|
|
sccWrite EQU SCCWBase-SCCRBase ; general offset for write from read
|
|
|
|
SCSIRd EQU $5FF000 ; base addr SCSI interface - READ
|
|
SCSIWr EQU $5FF001 ; base addr SCSI interface - WRITE
|
|
MacSCSIBase EQU $5FF000 ; base addr SCSI READ interface
|
|
MacSCSIDMA EQU $5FF200 ; base addr SCSI DMA
|
|
MacSCSIHsk EQU $5FF200 ; base addr SCSI handshake
|
|
wrOffs EQU SCSIWr-SCSIRd ; write addrs are +1 to the read base
|
|
|
|
SoundLow EQU $3FFD00 ; sound buffer start address
|
|
snd2MemTop EQU $300 ; SoundLow to Memtop
|
|
|
|
PWMBuffer EQU $3FFD01 ; PWM bytes are low bytes
|
|
pwm2MemTop EQU $2FF ; PWMBuffer to MemTop
|
|
|
|
; === Video Parameters ===
|
|
|
|
ScreenLow EQU $3FA700 ; top of screen screen address
|
|
scrn2MemTop EQU $5900 ; ScreenBase to Memtop
|
|
|
|
; === Hardware Base Addresses ===
|
|
|
|
romBSize EQU $40000 ; 256K bytes in present ROM
|
|
ROMStart EQU $400000 ; starting address of ROM code
|
|
|
|
DBase EQU $DFE1FE ; disk address base
|
|
|
|
; === System Software Information ===
|
|
bufWorldSize EQU scrn2MemTop ; total size of the BufPtr world
|
|
|
|
oneSecConst EQU 2 ; gets converted to $20000 for onesec constant
|
|
numOsTrap EQU 256 ; number of os traps
|
|
ToolTable EQU $0E00 ; start of toolbox trap table
|
|
|
|
numTbTrap EQU 512 ; number of toolbox traps
|
|
numTrapMask EQU numTbTrap-1 ; mask for number of tb traps
|
|
HeapStart EQU $1600 ; Aladdin starting point
|
|
|
|
defSysHeap EQU $18000 ; Default size of the system heap
|
|
nDfltStackSize EQU $2000 ; Default stack size
|
|
|
|
|
|
;===========================================;
|
|
; Macintosh Portable Hardware Information ;
|
|
;===========================================;
|
|
|
|
hwCfgBits EQU hwCmSCSI++hwCmClock++hwCmADB++hwCbPwrMgr ; <2.8>
|
|
machine EQU 3
|
|
rom85Bits EQU $7F ; New ROMs, No Power Off.
|
|
|
|
|
|
; === Interrupt Masks ===
|
|
hiIntMask EQU $0700 ; programmer switch only
|
|
sccIntMask EQU $0200 ; SCC interrupt Level <1.5>
|
|
sccEnblMask EQU $F9FF ; mask to enable SCC interrupts
|
|
viaIntMask EQU $0100 ; mask for VIA (and VBL) interrupts
|
|
loIntMask EQU $0100
|
|
|
|
|
|
; === VIA1 BUFFER A ===
|
|
; 68000 <-> PowerMgr data bus
|
|
vAIn EQU $00 ; VBufA output bits (all inputs)
|
|
vAOut EQU $FF ; VBufA output bits (all outputs)
|
|
vAInit EQU $00 ; VBufA initial values
|
|
|
|
|
|
; === VIA1 BUFFER B ===
|
|
vPMreq EQU 0 ; Power manager handshake request
|
|
vPMack EQU 1 ; Power manager handshake acknowledge
|
|
vTestJ EQU 2 ; Test jumper
|
|
;vSync EQU 3 ; Synchronous modem
|
|
vDriveSel EQU 4 ; int drive select (lower drive when 1)
|
|
;vHeadSel EQU 5 ; head select line for Sony
|
|
vStereo EQU 6 ; Stereo sound enable
|
|
;vSCCWrReq EQU 7 ; SCC write/request line (input)
|
|
;vSndEnb EQU 7 ; /sound enable (reset when 1) (output)
|
|
|
|
vBOut EQU (1<<vPMreq)|\ ; Power mgr handshake request is an output
|
|
(0<<vPMack)|\ ; Power mgr handshake acknowledge is an input
|
|
(0<<vTestJ)|\ ; Test jumper is an input
|
|
(1<<vSync)|\ ; Synchronous modem is an output
|
|
(1<<vDriveSel)|\ ; int drive select is an output
|
|
(1<<vHeadSel)|\ ; head select line is an output
|
|
(0<<vStereo)|\ ; Stereo sound detect is an input
|
|
(1<<vSndEnb) ; sound enable is an output
|
|
|
|
vBInit EQU (1<<vPMreq)|\ ; Power mgr handshake not requesting
|
|
(1<<vPMack)|\ ; Power mgr handshake acknowledge is an input
|
|
(1<<vTestJ)|\ ; Test jumper is an input
|
|
(1<<vSync)|\ ; Synchronous modem disabled (active low)
|
|
(1<<vDriveSel)|\ ; lower floppy drive selected
|
|
(0<<vHeadSel)|\ ; head select line is an output
|
|
(1<<vStereo)|\ ; Stereo sound detect is an input
|
|
(1<<vSndEnb) ; sound is disabled
|
|
|
|
vBufD EQU vBufB ; disk head select is buffer B
|
|
|
|
|
|
; === Hardware Base Addresses ===
|
|
|
|
VBase EQU $F70000 ; VIA base address
|
|
AVBufA EQU VBase+vBufA ; VIA buffer A
|
|
AVBufB EQU VBase+vBufB ; VIA buffer B
|
|
|
|
SCCRBase EQU $FD0000 ; SCC base read address
|
|
SCCWBase EQU $FD8000 ; SCC base write address
|
|
sccWrite EQU SCCWBase-SCCRBase ; general offset for write from read
|
|
|
|
SCSIRd EQU $F90000 ; base address of SCSI interface - READ
|
|
SCSIWr EQU $F90001 ; base address of SCSI interface - WRITE
|
|
MacSCSIBase EQU $F90000 ; base address of SCSI READ interface
|
|
MacSCSIDMA EQU $F90200 ; base address of SCSI DMA
|
|
MacSCSIHsk EQU $F90200 ; base address of SCSI handshake
|
|
wrOffs EQU SCSIWr-SCSIRd ; write addrs are +1 to the read base
|
|
|
|
SndBase EQU $FB0000 ; sound chip's base address
|
|
|
|
MapperBase EQU $FC0000 ; Mapper RAM base address
|
|
|
|
RAMconfigBase EQU $FE0200 ; Internal/external RAM control register
|
|
RAMconfigInit EQU $0006 ; Init test register <v2.6>
|
|
|
|
; === Video Parameters ===
|
|
|
|
ScreenLow EQU $FA8000 ; top of screen screen address
|
|
hcVideoSize EQU $8000 ; 32k of video memory
|
|
HcVideoStart EQU ScreenLow
|
|
HcVideoEnd EQU HcVideoStart+hcVideoSize
|
|
NTSCMaxX EQU 512 ; NTSC output is narrow
|
|
NTSCOffset EQU 8 ; and centered
|
|
LCDmode EQU 0 ; Normal built in screen
|
|
Mac2mode EQU 1 ; Custom screen for Mac2
|
|
NTSCmode EQU 2 ; NTSC output for Topanga
|
|
|
|
; === Hardware Base Addresses ===
|
|
|
|
romBSize EQU $40000 ; 256K bytes in present ROM
|
|
ROMStart EQU $900000 ; starting address of ROM code
|
|
|
|
DBase EQU $F6E1FF ; disk address base
|
|
|
|
AccessBase EQU $FC0200 ; SLIM card DTACK counter load address (what a mouthful)
|
|
SLIMinserted EQU 3 ; SLIMs inserted bit <v2.6>
|
|
|
|
; === System Software Information ===
|
|
snd2MemTop EQU $300 ; SoundLow to Memtop
|
|
pwm2MemTop EQU $2FF ; PWMBuffer to MemTop
|
|
bufWorldSize EQU snd2MemTop ; total size of the BufPtr world
|
|
|
|
oneSecConst EQU 2 ; gets converted to $20000 for onesec constant
|
|
numOsTrap EQU 256 ; number of os traps
|
|
ToolTable EQU $0E00 ; start of toolbox trap table
|
|
numTbTrap EQU 1024 ; number of toolbox traps
|
|
numTrapMask EQU numTbTrap-1 ; mask for number of tb traps
|
|
HeapStart EQU $1E00 ; Portable starting point <1.2>
|
|
DefSysHeap EQU $18000 ; Default size of the system heap
|
|
NDfltStackSize EQU $2000 ; Default stack size
|
|
|
|
|
|
;===================================================;
|
|
; Universal 16 bit Macintosh Hardware Information ;
|
|
;===================================================;
|
|
|
|
|
|
; === Interrupt Masks ===
|
|
hiIntMask EQU $0700 ; programmer switch only
|
|
sccIntMask EQU $0200 ; SCC interrupt Level <1.5>
|
|
sccEnblMask EQU $F9FF ; mask to enable SCC interrupts
|
|
viaIntMask EQU $0100 ; mask for VIA (and VBL) interrupts
|
|
loIntMask EQU $0100
|
|
|
|
; === VIA1 BUFFER A ===
|
|
;vSound EQU $7 ; sound volume bits (0..2)
|
|
vSndPg2 EQU 3 ; select sound page 2 if 0
|
|
;vSync EQU 3 ; Synchronous modem
|
|
;vOverlay EQU 4 ; overlay bit (overlay when 1)
|
|
;vDriveSel EQU 4 ; int drive select (lower drive when 1)
|
|
;vHeadSel EQU 5 ; head select line for Sony
|
|
vPage2 EQU 6 ; select video page 2 if 0
|
|
;vSCCWrReq EQU 7 ; SCC write/request line
|
|
|
|
; === VIA1 BUFFER B ===
|
|
;vRTCData EQU 0 ; real time clock data
|
|
;vRTCClk EQU 1 ; real time clock clock pulses
|
|
;vRTCEnb EQU 2 ; clock enable (0 for enable)
|
|
vSW EQU 3 ; mouse switch (0 when down)
|
|
;vFDBInt EQU 3 ; Front Desk bus interrupt
|
|
vX2 EQU 4 ; mouse X level
|
|
;vFDesk1 EQU 4 ; Front Desk bus state bit 0
|
|
vY2 EQU 5 ; mouse Y level
|
|
;vFDesk2 EQU 5 ; Front Desk bus state bit 1
|
|
vH4 EQU 6 ; horizontal sync
|
|
vSCSIMask EQU 6 ; SCSI IRQ mask
|
|
;vSndEnb EQU 7 ; /sound enable (reset when 1)
|
|
|
|
vPMreq EQU 0 ; Power manager handshake request
|
|
vPMack EQU 1 ; Power manager handshake acknowledge
|
|
vTestJ EQU 2 ; Test jumper
|
|
;vSync EQU 3 ; Synchronous modem
|
|
;vDriveSel EQU 4 ; int drive select (lower drive when 1)
|
|
;vHeadSel EQU 5 ; head select line for Sony
|
|
vStereo EQU 6 ; Stereo sound enable
|
|
;vSCCWrReq EQU 7 ; SCC write/request line (input)
|
|
|
|
; === VIA1 BUFFER A/B ===
|
|
;vSync EQU 3 ; Synchronous modem <3.1>
|
|
vDriveSel EQU 4 ; int drive select (lower drive when 1) <3.1>
|
|
;vHeadSel EQU 5 ; head select line for Sony <3.1>
|
|
;vSCCWrReq EQU 7 ; SCC write/request line <3.1>
|
|
|
|
; === Hardware Base Addresses ===
|
|
|
|
wrOffs EQU 1 ; write addrs are +1 to the read base
|
|
|
|
; === System Software Information ===
|
|
|
|
numOsTrap EQU 256 ; number of os traps
|
|
ToolTable EQU $0E00 ; start of toolbox trap table
|
|
numTbTrap EQU 1024 ; number of toolbox traps
|
|
numTrapMask EQU numTbTrap-1 ; mask for number of tb traps
|
|
HeapStart EQU $1E00 ; Laguna starting point <1.2>
|
|
DefSysHeap EQU $18000 ; Default size of the system heap
|
|
NDfltStackSize EQU $2000 ; Default stack size
|
|
|
|
|
|
|
|
ENDIF ; ForAmusementOnly
|
|
|
|
HardwarePrivate EQU 1
|
|
|
|
ENDIF ; __INCLUDINGHARDWAREPRIVATEEQU__
|
|
|