mirror of
https://github.com/elliotnunn/mac-rom.git
synced 2025-01-15 12:30:53 +00:00
232 lines
7.0 KiB
C
232 lines
7.0 KiB
C
|
/*
|
|||
|
File: DBDMA.h
|
|||
|
|
|||
|
Contains: public headers defining the Descriptor Based DMA standard
|
|||
|
|
|||
|
Written by: Craig Prouse
|
|||
|
|
|||
|
Copyright: <EFBFBD> 1993 by Apple Computer, Inc., all rights reserved.
|
|||
|
|
|||
|
Change History (most recent first):
|
|||
|
|
|||
|
<SM2> 12/13/93 chp Add TStat encodings.
|
|||
|
<1> 11/10/93 fau first checked in
|
|||
|
<SMG3> 10/26/93 chp Checking in the first <EFBFBD>complete<EFBFBD> version.
|
|||
|
<SMG2> 9/29/93 chp Add channel control bits and channel commands. Prepare for
|
|||
|
littleEndian support by default.
|
|||
|
|
|||
|
*/
|
|||
|
|
|||
|
#ifndef __DBDMA__
|
|||
|
#define __DBDMA__
|
|||
|
|
|||
|
#ifndef __M68K__
|
|||
|
#include <M68K.h>
|
|||
|
#endif
|
|||
|
|
|||
|
#ifndef __ENDIANAWARE__
|
|||
|
#include <EndianAware.h>
|
|||
|
#endif
|
|||
|
|
|||
|
|
|||
|
// This structure defines the standard set of DB-DMA channel registers.
|
|||
|
|
|||
|
struct DBDMAChannelRegisters {
|
|||
|
unsigned long channelControl;
|
|||
|
unsigned long channelStatus;
|
|||
|
unsigned long commandPtrHi; // implementation optional
|
|||
|
unsigned long commandPtrLo;
|
|||
|
unsigned long dataPtrHi; // implementation optional
|
|||
|
unsigned long dataPtrLo;
|
|||
|
unsigned long byteCount;
|
|||
|
|
|||
|
unsigned long reserved1;
|
|||
|
unsigned long data2PtrHi; // implementation optional
|
|||
|
unsigned long data2PtrLo; // implementation optional
|
|||
|
unsigned long transferModes; // implementation optional
|
|||
|
unsigned long addressHi; // implementation optional
|
|||
|
unsigned long reserved2 [4];
|
|||
|
unsigned long unimplemented [16];
|
|||
|
|
|||
|
// This structure must remain fully padded to 256 bytes.
|
|||
|
unsigned long undefined [32];
|
|||
|
};
|
|||
|
typedef struct DBDMAChannelRegisters DBDMAChannelRegisters;
|
|||
|
|
|||
|
|
|||
|
// These constants define the DB-DMA channel control words and status flags.
|
|||
|
|
|||
|
enum {
|
|||
|
kdbdmaSetRun = 0x80008000,
|
|||
|
kdbdmaClrRun = 0x80000000,
|
|||
|
kdbdmaSetPause = 0x40004000,
|
|||
|
kdbdmaClrPause = 0x40000000,
|
|||
|
|
|||
|
kdbdmaClrHalted = 0x20000000,
|
|||
|
kdbdmaClrDead = 0x10000000,
|
|||
|
kdbdmaSetActive = 0x08000800,
|
|||
|
|
|||
|
kdbdmaSetS3 = 0x00080008,
|
|||
|
kdbdmaClrS3 = 0x00080000,
|
|||
|
kdbdmaSetS2 = 0x00040004,
|
|||
|
kdbdmaClrS2 = 0x00040000,
|
|||
|
kdbdmaSetS1 = 0x00020002,
|
|||
|
kdbdmaClrS1 = 0x00020000,
|
|||
|
kdbdmaSetS0 = 0x00010001,
|
|||
|
kdbdmaClrS0 = 0x00010000,
|
|||
|
|
|||
|
kdbdmaClrAll = 0xF00F0000,
|
|||
|
|
|||
|
kdbdmaHalted = 0x2000,
|
|||
|
kdbdmaDead = 0x1000,
|
|||
|
kdbdmaActive = 0x0800,
|
|||
|
kdbdmaPaused = 0x0400,
|
|||
|
|
|||
|
kTStatMore = 0x0000,
|
|||
|
kTStatDone = 0x0100,
|
|||
|
kTStatDiff = 0x0200,
|
|||
|
kTStatError = 0x0300,
|
|||
|
kdbdmaTStatMask = 0x0300,
|
|||
|
|
|||
|
kdbdmaS3 = 0x0008,
|
|||
|
kdbdmaS2 = 0x0004,
|
|||
|
kdbdmaS1 = 0x0002,
|
|||
|
kdbdmaS0 = 0x0001
|
|||
|
};
|
|||
|
|
|||
|
|
|||
|
// This structure defines the DB-DMA channel command descriptor.
|
|||
|
|
|||
|
// *** WARNING: Endian-ness issues must be considered when performing load/store! ***
|
|||
|
// *** DB-DMA specifies memory organization as quadlets so it is not correct
|
|||
|
// *** to think of either the operation or result field as two 16-bit fields.
|
|||
|
// *** This would have undesirable effects on the byte ordering within their
|
|||
|
// *** respective quadlets.
|
|||
|
|
|||
|
struct DBDMADescriptor {
|
|||
|
unsigned long operation; // MSW = command, LSW = reqCount
|
|||
|
unsigned long address;
|
|||
|
unsigned long data32;
|
|||
|
unsigned long result; // MSW = xferStatus, LSW = resCount
|
|||
|
};
|
|||
|
typedef struct DBDMADescriptor DBDMADescriptor, *DBDMADescriptorPtr;
|
|||
|
|
|||
|
|
|||
|
// These constants define the DB-DMA channel command operations and modifiers.
|
|||
|
|
|||
|
enum {
|
|||
|
// Command.cmd operations
|
|||
|
OUTPUT_MORE = 0x0000,
|
|||
|
OUTPUT_LAST = 0x0100,
|
|||
|
INPUT_MORE = 0x0200,
|
|||
|
INPUT_LAST = 0x0300,
|
|||
|
STORE_QUAD = 0x0400,
|
|||
|
LOAD_QUAD = 0x0500,
|
|||
|
JUMP = 0x0600,
|
|||
|
WAIT = 0x0700,
|
|||
|
STOP = 0x0800,
|
|||
|
kdbdmaCmdMask = 0x0F00,
|
|||
|
|
|||
|
// Command.test modifiers (choose all that apply)
|
|||
|
kTestMore = 0x1000,
|
|||
|
kTestDone = 0x2000,
|
|||
|
kTestDiff = 0x4000,
|
|||
|
kTestError = 0x8000,
|
|||
|
kdbdmaTestMask = 0xF000,
|
|||
|
|
|||
|
// Command.i modifiers (choose one)
|
|||
|
kIntError = 0x0000, // default modifier
|
|||
|
kIntErrorDiff = 0x0040,
|
|||
|
kIntErrorDiffDone = 0x0080,
|
|||
|
kIntAll = 0x00C0,
|
|||
|
kdbdmaIMask = 0x00C0,
|
|||
|
|
|||
|
// Command.h modifiers (choose one)
|
|||
|
kHaltError = 0x0000, // default modifier
|
|||
|
kHaltErrorDiff = 0x0010,
|
|||
|
kHaltErrorDiffDone = 0x0020,
|
|||
|
kHaltNone = 0x0030,
|
|||
|
kdbdmaHMask = 0x0030,
|
|||
|
|
|||
|
// Command.cdep.key modifiers (choose one for INPUT, OUTPUT, LOAD, and STORE operations)
|
|||
|
KEY_STREAM0 = 0x0000, // default modifier
|
|||
|
KEY_STREAM1 = 0x0001,
|
|||
|
KEY_STREAM2 = 0x0002,
|
|||
|
KEY_STREAM3 = 0x0003,
|
|||
|
KEY_REGS = 0x0005,
|
|||
|
KEY_SYSTEM = 0x0006,
|
|||
|
KEY_DEVICE = 0x0007,
|
|||
|
kdbdmaKeyMask = 0x0007,
|
|||
|
|
|||
|
// Command.cdep.cond modifiers (choose all that apply for JUMP and WAIT operations)
|
|||
|
kFailZerosFailOnes = 0x0001,
|
|||
|
kFailZerosPassOnes = 0x0002,
|
|||
|
kPassZerosFailOnes = 0x0004,
|
|||
|
kPassZerosPassOnes = 0x0008,
|
|||
|
kdbdmaCondMask = 0x000F
|
|||
|
};
|
|||
|
|
|||
|
|
|||
|
// void MakeCCDescriptor (DBDMADescriptor *descPtr, unsigned short cmd,
|
|||
|
// unsigned short count, unsigned long addr);
|
|||
|
#define MakeCCDescriptor(descPtr,cmd,count,addr) \
|
|||
|
((descPtr)->result = 0, \
|
|||
|
(descPtr)->data32 = 0, \
|
|||
|
(descPtr)->address = EndianSwap32(addr), \
|
|||
|
NOP(), \
|
|||
|
(descPtr)->operation = EndianSwap32((cmd) << 16 | ((count) & 0x0000FFFF)), \
|
|||
|
NOP())
|
|||
|
|
|||
|
// void MakeData32CCDescriptor (DBDMADescriptor *descPtr, unsigned short cmd,
|
|||
|
// unsigned short count, unsigned long addr, unsigned long data);
|
|||
|
#define MakeData32CCDescriptor(descPtr,cmd,count,addr,data) \
|
|||
|
((descPtr)->result = 0, \
|
|||
|
(descPtr)->data32 = EndianSwap32(data), \
|
|||
|
(descPtr)->address = EndianSwap32(addr), \
|
|||
|
NOP(), \
|
|||
|
(descPtr)->operation = EndianSwap32((cmd) << 16 | ((count) & 0x0000FFFF)), \
|
|||
|
NOP())
|
|||
|
|
|||
|
// unsigned short GetCCCmd (DBDMADescriptor *descPtr)
|
|||
|
#define GetCCCmd(descPtr) \
|
|||
|
((unsigned short) (EndianSwap32((descPtr)->operation) >> 16))
|
|||
|
|
|||
|
// unsigned short GetCCReqCount (DBDMADescriptor *descPtr)
|
|||
|
#define GetCCReqCount(descPtr) \
|
|||
|
((unsigned short) (EndianSwap32((descPtr)->operation) & 0x0000FFFF))
|
|||
|
|
|||
|
// unsigned long GetCCAddress (DBDMADescriptor *descPtr);
|
|||
|
#define GetCCAddress(descPtr) \
|
|||
|
(EndianSwap32((descPtr)->address))
|
|||
|
|
|||
|
// unsigned long GetCCData32 (DBDMADescriptor *descPtr);
|
|||
|
#define GetCCData32(descPtr) \
|
|||
|
(EndianSwap32((descPtr)->data32))
|
|||
|
|
|||
|
// unsigned short GetCCXferStatus (DBDMADescriptor *descPtr);
|
|||
|
#define GetCCXferStatus(descPtr) \
|
|||
|
((unsigned short) (EndianSwap32((descPtr)->result) >> 16))
|
|||
|
|
|||
|
// unsigned short GetCCResCount (DBDMADescriptor *descPtr);
|
|||
|
#define GetCCResCount(descPtr) \
|
|||
|
((unsigned short) (EndianSwap32((descPtr)->result) & 0x0000FFFF))
|
|||
|
|
|||
|
// void SetChannelControl (DBDMAChannelRegisters *registerSetPtr, unsigned long ctlValue);
|
|||
|
#define SetChannelControl(registerSetPtr, ctlValue) \
|
|||
|
((registerSetPtr)->channelControl = EndianSwap32(ctlValue), NOP())
|
|||
|
|
|||
|
// unsigned long GetChannelStatus (DBDMAChannelRegisters *registerSetPtr);
|
|||
|
#define GetChannelStatus(registerSetPtr) \
|
|||
|
(EndianSwap32((registerSetPtr)->channelStatus))
|
|||
|
|
|||
|
// unsigned long GetCommandPtr (DBDMAChannelRegisters *registerSetPtr);
|
|||
|
#define GetCommandPtr(registerSetPtr) \
|
|||
|
(EndianSwap32((registerSetPtr)->commandPtrLo))
|
|||
|
|
|||
|
// void SetCommandPtr (DBDMAChannelRegisters *registerSetPtr, unsigned long cclPtr);
|
|||
|
#define SetCommandPtr(registerSetPtr,cclPtr) \
|
|||
|
((registerSetPtr)->commandPtrLo = EndianSwap32(cclPtr), NOP())
|
|||
|
|
|||
|
|
|||
|
#endif __DBDMA__
|