mirror of
https://github.com/elliotnunn/mac-rom.git
synced 2025-01-18 15:30:19 +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.
195 lines
5.9 KiB
C
195 lines
5.9 KiB
C
/*
|
|
File: GrandCentralPriv.h
|
|
|
|
Contains: private headers for use with the Grand Central I/O Controller
|
|
|
|
Written by: Craig Prouse
|
|
|
|
Copyright: © 1993 by Apple Computer, Inc., all rights reserved.
|
|
|
|
Change History (most recent first):
|
|
|
|
<SM2> 12/1/93 chp Add serialization primitives to ensure correct operation of
|
|
interrupt enable/disable/clear macros.
|
|
<SM1> 11/10/93 fau first checked in
|
|
<SMG5> 10/26/93 chp Slight macro name changes.
|
|
<SMG4> 9/29/93 chp Break out GCHandlerVector as its own data type.
|
|
<SMG3> 8/30/93 chp Add more macros and use nested macro substitution to make the
|
|
macros more readable. Add a reserved field to the dispatch table
|
|
structure to achieve more natural data alignment.
|
|
<SMG2> 8/26/93 chp Add macros for maintaining the Grand Central interrupt dispatch
|
|
table, and for enabling and disabling Grand Central interrupt
|
|
sources.
|
|
|
|
*/
|
|
|
|
#ifndef __GRANDCENTRALPRIV__
|
|
#define __GRANDCENTRALPRIV__
|
|
|
|
#ifndef __SYSEQU__
|
|
#include <SysEqu.h>
|
|
#endif
|
|
|
|
#ifndef __M68K__
|
|
#include <M68K.h>
|
|
#endif
|
|
|
|
#ifndef __EXPANDMEMPRIV__
|
|
#include <ExpandMemPriv.h>
|
|
#endif
|
|
|
|
|
|
/* Grand Central controller register mappings */
|
|
|
|
#define gcInterruptEvents 0x00020 /* offset from Grand Central base address */
|
|
#define gcInterruptMask 0x00024
|
|
#define gcInterruptClear 0x00028
|
|
#define gcInterruptLevels 0x0002C
|
|
|
|
// Grand Central interrupt flags
|
|
//
|
|
// Grand Central is a little-endian device. These constants correspond to 680x0 bit positions
|
|
// within a 32-bit Grand Central register, adjusted to avoid any need for byte swapping. For
|
|
// example, gcifIntMode is the most significant bit of the InterruptMask register, but it
|
|
// appears to the 680x0 emulator in bit 7.
|
|
enum {
|
|
gcifDmaSCSI0 = 24, // level 4
|
|
gcifDmaFloppy, // level 4
|
|
gcifDmaEthTx, // level 4
|
|
gcifDmaEthRx, // level 4
|
|
gcifDmaSccATx, // level 4
|
|
gcifDmaSccARx, // level 4
|
|
gcifDmaSccBTx, // level 4
|
|
gcifDmaSccBRx, // level 4
|
|
gcifDmaAudOut = 16, // level 4
|
|
gcifDmaAudIn, // level 4
|
|
gcifDmaSCSI1, // level 4
|
|
|
|
gcifDevSCSI0, // level 2
|
|
gcifDevSCSI1, // level 2
|
|
gcifDevMACE, // level 3
|
|
gcifDevSccA = 23, // level 4
|
|
gcifDevSccB = 8, // level 4
|
|
gcifDevAudio, // level 2
|
|
gcifDevVia, // level 1
|
|
gcifDevSwim3, // level 2
|
|
|
|
gcifExtNMI, // level 7
|
|
|
|
gcifExtPci0, // level 2
|
|
gcifExtPci1, // level 2
|
|
gcifExtSlot0, // level 2
|
|
gcifExtSlot1 = 0, // level 2
|
|
gcifExtSlot2, // level 2
|
|
gcifExtSwatch0, // level 2
|
|
gcifExtSwatch1, // level 2
|
|
gcifExtJivi, // level 2
|
|
gcifExtGotham, // level 2
|
|
gcifExtSpare, // level 2
|
|
|
|
gcifIntMode, // valid only in InterruptMask register
|
|
gcifMode1Clear = 7 // valid only in InterruptClear register
|
|
};
|
|
|
|
|
|
/* Grand Central DMA channel register mappings (refer to DB-DMA documentation) */
|
|
|
|
#define kGCDMAChannelRegisterSpace 0x08000 /* offset from Grand Central base address */
|
|
|
|
// indexes into DB-DMA channel register array
|
|
enum {
|
|
gcChannelSCSI0,
|
|
gcChannelFloppy,
|
|
gcChannelEnetTx,
|
|
gcChannelEnetRx,
|
|
gcChannelSCCATx,
|
|
gcChannelSCCARx,
|
|
gcChannelSCCBTx,
|
|
gcChannelSCCBRx,
|
|
gcChannelAudioOut,
|
|
gcChannelAudioIn,
|
|
gcChannelSCSI1
|
|
};
|
|
|
|
|
|
/* Grand Central device register mappings (refer to device-specific documentation) */
|
|
|
|
#define kGCDeviceRegisterSpace 0x10000 /* offset from Grand Central base address */
|
|
|
|
// indexes into DB-DMA device register array
|
|
enum {
|
|
gcDeviceSCSI0,
|
|
gcDeviceMACE,
|
|
gcDeviceV0SCC, // traditional SCC register mapping
|
|
gcDeviceV1SCC, // MacRISC SCC register mapping
|
|
gcDeviceAudio,
|
|
gcDeviceSWIM3,
|
|
gcDeviceVIA, // VIA uses the address space of two devices
|
|
gcDeviceSCSI1 = 0x08,
|
|
gcDeviceEnetPROM,
|
|
gcDeviceGBus1,
|
|
gcDeviceGBus2,
|
|
gcDeviceGBus3,
|
|
gcDeviceGBus4,
|
|
gcDeviceGBus5,
|
|
gcDeviceGBus6
|
|
};
|
|
|
|
|
|
/* Grand Central interrupt dispatch table (for 680x0 interrupt emulation only) */
|
|
|
|
struct GCHandlerVector {
|
|
void (*gcVector) (void);
|
|
void * gcRefCon;
|
|
};
|
|
typedef struct GCHandlerVector GCHandlerVector;
|
|
|
|
|
|
struct GCInterruptDispatchTable {
|
|
unsigned long gcBaseAddr;
|
|
unsigned long reserved;
|
|
|
|
GCHandlerVector handlerVector [32]; // Grand Central has 32 interrupt sources.
|
|
};
|
|
typedef struct GCInterruptDispatchTable GCInterruptDispatchTable;
|
|
|
|
|
|
// Use this macro to express the Grand Central base address.
|
|
|
|
#define GCBaseAddr \
|
|
(((GCInterruptDispatchTable *) GetExpandMemDMADispatchGlobals())->gcBaseAddr)
|
|
|
|
// This macro can be used to access an interrupt vector directly; it is intended
|
|
// to be used only as a building block for other macros defined below.
|
|
|
|
#define GCHandler(intSource) \
|
|
(((GCInterruptDispatchTable *) GetExpandMemDMADispatchGlobals())->handlerVector[intSource])
|
|
|
|
// Use this macro to register an interrupt handler and a refCon (passed to the
|
|
// handler in register A1) for a Grand Central interrupt source specified by
|
|
// its interrupt flag (e.g. gcifDevMACE).
|
|
|
|
#define GCRegisterHandler(intSource, intHandler, refCon) \
|
|
(GCHandler(intSource).gcVector = (intHandler), \
|
|
GCHandler(intSource).gcRefCon = (refCon))
|
|
|
|
// Use this macro to unregister a Grand Central interrupt handler.
|
|
|
|
#define GCUnregisterHandler(intSource) \
|
|
(GCHandler(intSource).gcVector = *(void (**)(void)) BadIntVector, \
|
|
GCHandler(intSource).gcRefCon = 0)
|
|
|
|
// Use these macros to enable, disable, and clear Grand Central interrupt sources.
|
|
|
|
#define GCEnableInterruptSource(intSource) \
|
|
((*(unsigned long *) (GCBaseAddr + gcInterruptMask)) |= 1 << (intSource), NOP())
|
|
|
|
#define GCDisableInterruptSource(intSource) \
|
|
((*(unsigned long *) (GCBaseAddr + gcInterruptMask)) &= ~(1 << (intSource)), NOP())
|
|
|
|
#define GCClearInterruptSource(intSource) \
|
|
((*(unsigned long *) (GCBaseAddr + gcInterruptClear)) |= 1 << (intSource), NOP())
|
|
|
|
|
|
#endif __GRANDCENTRALPRIV__
|