Annotation of XNU/iokit/IOKit/ppc/IODBDMA.h, revision 1.1.1.1

1.1       root        1: /*
                      2:  * Copyright (c) 1998-2000 Apple Computer, Inc. All rights reserved.
                      3:  *
                      4:  * @APPLE_LICENSE_HEADER_START@
                      5:  * 
                      6:  * The contents of this file constitute Original Code as defined in and
                      7:  * are subject to the Apple Public Source License Version 1.1 (the
                      8:  * "License").  You may not use this file except in compliance with the
                      9:  * License.  Please obtain a copy of the License at
                     10:  * http://www.apple.com/publicsource and read it before using this file.
                     11:  * 
                     12:  * This Original Code and all software distributed under the License are
                     13:  * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
                     14:  * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
                     15:  * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
                     16:  * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT.  Please see the
                     17:  * License for the specific language governing rights and limitations
                     18:  * under the License.
                     19:  * 
                     20:  * @APPLE_LICENSE_HEADER_END@
                     21:  */
                     22: /*
                     23:  * Copyright (c) 1997 Apple Computer, Inc.
                     24:  *
                     25:  *
                     26:  * HISTORY
                     27:  *
                     28:  * Simon Douglas  10 Nov 97
                     29:  * - first checked in, mostly from MacOS DBDMA.i, machdep/ppc/dbdma.h
                     30:  *     but use byte reverse ops.
                     31:  */
                     32: 
                     33: #ifndef _IODBDMA_H_
                     34: #define _IODBDMA_H_
                     35: 
                     36: #include <IOKit/IOTypes.h>
                     37: #include <libkern/OSByteOrder.h>
                     38: #include <stddef.h> 
                     39: 
                     40: 
                     41: /* DBDMA definitions */
                     42: 
                     43: struct IODBDMAChannelRegisters {
                     44:     unsigned long      channelControl;
                     45:     unsigned long      channelStatus;
                     46:     unsigned long      commandPtrHi;           /* implementation optional*/
                     47:     unsigned long      commandPtrLo;
                     48:     unsigned long      interruptSelect;        /* implementation optional*/
                     49:     unsigned long      branchSelect;           /* implementation optional*/
                     50:     unsigned long      waitSelect;             /* implementation optional*/
                     51:     unsigned long      transferModes;          /* implementation optional*/
                     52:     unsigned long      data2PtrHi;             /* implementation optional*/
                     53:     unsigned long      data2PtrLo;             /* implementation optional*/
                     54: 
                     55:     unsigned long      reserved1;
                     56:     unsigned long      addressHi;              /* implementation optional*/
                     57:     unsigned long      reserved2[4];
                     58:     unsigned long      unimplemented[16];
                     59: 
                     60: /* This structure must remain fully padded to 256 bytes.*/
                     61:     unsigned long      undefined[32];
                     62: };
                     63: typedef struct IODBDMAChannelRegisters IODBDMAChannelRegisters;
                     64: 
                     65: /* These constants define the DB-DMA channel control words and status flags.*/
                     66: 
                     67: enum {
                     68:        kdbdmaRun       = 0x00008000,
                     69:        kdbdmaPause     = 0x00004000,
                     70:        kdbdmaFlush     = 0x00002000,
                     71:        kdbdmaWake      = 0x00001000,
                     72:        kdbdmaDead      = 0x00000800,
                     73:        kdbdmaActive    = 0x00000400,
                     74:        kdbdmaBt        = 0x00000100,
                     75:        kdbdmaS7        = 0x00000080,
                     76:        kdbdmaS6        = 0x00000040,
                     77:        kdbdmaS5        = 0x00000020,
                     78:        kdbdmaS4        = 0x00000010,
                     79:        kdbdmaS3        = 0x00000008,
                     80:        kdbdmaS2        = 0x00000004,
                     81:        kdbdmaS1        = 0x00000002,
                     82:        kdbdmaS0        = 0x00000001
                     83: };
                     84: 
                     85: 
                     86: #define        IOSetDBDMAChannelControlBits(mask)      ( ((mask) | (mask) << 16) )
                     87: #define        IOClearDBDMAChannelControlBits(mask)    ( (mask) << 16)
                     88: 
                     89: 
                     90: /* This structure defines the DB-DMA channel command descriptor.*/
                     91: 
                     92: /*
                     93:    *** WARNING:        Endian-ness issues must be considered when performing load/store! ***
                     94: */
                     95: 
                     96: struct IODBDMADescriptor {
                     97:        unsigned long           operation;      /* cmd || key || i || b || w || reqCount*/
                     98:        unsigned long           address;
                     99:        unsigned long           cmdDep;
                    100:        unsigned long           result;         /* xferStatus || resCount*/
                    101: };
                    102: typedef struct IODBDMADescriptor IODBDMADescriptor;
                    103: 
                    104: /* These constants define the DB-DMA channel command operations and modifiers.*/
                    105: 
                    106: 
                    107: enum {
                    108: /* Command.cmd operations*/
                    109:        kdbdmaOutputMore        = 0,
                    110:        kdbdmaOutputLast        = 1,
                    111:        kdbdmaInputMore         = 2,
                    112:        kdbdmaInputLast         = 3,
                    113:        kdbdmaStoreQuad         = 4,
                    114:        kdbdmaLoadQuad          = 5,
                    115:        kdbdmaNop               = 6,
                    116:        kdbdmaStop              = 7,
                    117: };
                    118: 
                    119: 
                    120: enum {
                    121: /* Command.key modifiers (choose one for INPUT, OUTPUT, LOAD, and STORE)*/
                    122:        kdbdmaKeyStream0        = 0,    /* default modifier*/
                    123:        kdbdmaKeyStream1        = 1,
                    124:        kdbdmaKeyStream2        = 2,
                    125:        kdbdmaKeyStream3        = 3,
                    126:        kdbdmaKeyRegs           = 5,
                    127:        kdbdmaKeySystem         = 6,
                    128:        kdbdmaKeyDevice         = 7,
                    129: 
                    130:        kdbdmaIntNever          = 0,    /* default modifier*/
                    131:        kdbdmaIntIfTrue         = 1,
                    132:        kdbdmaIntIfFalse        = 2,
                    133:        kdbdmaIntAlways         = 3,
                    134: 
                    135:        kdbdmaBranchNever       = 0,    /* default modifier*/
                    136:        kdbdmaBranchIfTrue      = 1,
                    137:        kdbdmaBranchIfFalse     = 2,
                    138:        kdbdmaBranchAlways      = 3,
                    139: 
                    140:        kdbdmaWaitNever         = 0,    /* default modifier*/
                    141:        kdbdmaWaitIfTrue        = 1,
                    142:        kdbdmaWaitIfFalse       = 2,
                    143:        kdbdmaWaitAlways        = 3,
                    144: 
                    145:        kdbdmaCommandMask       = (long)0xFFFF0000,
                    146:        kdbdmaReqCountMask      = 0x0000FFFF
                    147: };
                    148: 
                    149: 
                    150: /* These constants define the DB-DMA channel command results.*/
                    151: 
                    152: enum {
                    153:        /* result masks*/
                    154:        kdbdmaStatusRun         = kdbdmaRun << 16,
                    155:        kdbdmaStatusPause       = kdbdmaPause << 16,
                    156:        kdbdmaStatusFlush       = kdbdmaFlush << 16,
                    157:        kdbdmaStatusWake        = kdbdmaWake << 16,
                    158:        kdbdmaStatusDead        = kdbdmaDead << 16,
                    159:        kdbdmaStatusActive      = kdbdmaActive << 16,
                    160:        kdbdmaStatusBt          = kdbdmaBt << 16,
                    161:        kdbdmaStatusS7          = kdbdmaS7 << 16,
                    162:        kdbdmaStatusS6          = kdbdmaS6 << 16,
                    163:        kdbdmaStatusS5          = kdbdmaS5 << 16,
                    164:        kdbdmaStatusS4          = kdbdmaS4 << 16,
                    165:        kdbdmaStatusS3          = kdbdmaS3 << 16,
                    166:        kdbdmaStatusS2          = kdbdmaS2 << 16,
                    167:        kdbdmaStatusS1          = kdbdmaS1 << 16,
                    168:        kdbdmaStatusS0          = kdbdmaS0 << 16,
                    169:        kdbdmaResCountMask      = 0x0000FFFF,
                    170:        kdbdmaXferStatusMask    = 0xFFFF0000
                    171: };
                    172: 
                    173: 
                    174: /*  These macros are are IODBDMAChannelRegisters accessor functions. */
                    175: 
                    176: #define IOSetDBDMAChannelRegister(registerSetPtr,field,value)  \
                    177: OSWriteSwapInt32(registerSetPtr,offsetof(IODBDMAChannelRegisters,field),value)
                    178: 
                    179: #define IOGetDBDMAChannelRegister(registerSetPtr, field)       \
                    180: OSReadSwapInt32(registerSetPtr,offsetof(IODBDMAChannelRegisters, field))
                    181: 
                    182: 
                    183: /*     void IOSetDBDMAChannelControl (IODBDMAChannelRegisters *registerSetPtr, unsigned long ctlValue); */
                    184: 
                    185: #define IOSetDBDMAChannelControl(registerSetPtr,ctlValue)              \
                    186: do {                                                                   \
                    187:     eieio();                                                           \
                    188:     IOSetDBDMAChannelRegister(registerSetPtr,channelControl,ctlValue); \
                    189:     eieio();                                                           \
                    190: } while(0)
                    191: 
                    192: /*     unsigned long IOGetDBDMAChannelStatus (IODBDMAChannelRegisters *registerSetPtr); */
                    193: 
                    194: #define IOGetDBDMAChannelStatus(registerSetPtr)                \
                    195:        IOGetDBDMAChannelRegister(registerSetPtr,channelStatus)
                    196: 
                    197: /*     unsigned long IOGetDBDMACommandPtr (IODBDMAChannelRegisters *registerSetPtr); */
                    198: 
                    199: #define IOGetDBDMACommandPtr(registerSetPtr)                   \
                    200:        IOGetDBDMAChannelRegister(registerSetPtr,commandPtrLo)
                    201: 
                    202: /*     void IOSetDBDMACommandPtr (IODBDMAChannelRegisters *registerSetPtr, unsigned long cclPtr); */
                    203: 
                    204: #define IOSetDBDMACommandPtr(registerSetPtr,cclPtr)                    \
                    205: do {                                                                   \
                    206:     IOSetDBDMAChannelRegister(registerSetPtr,commandPtrHi,0);          \
                    207:     eieio();                                                           \
                    208:     IOSetDBDMAChannelRegister(registerSetPtr,commandPtrLo,cclPtr);     \
                    209:     eieio();                                                           \
                    210: } while(0)
                    211: 
                    212: 
                    213: /*     unsigned long IOGetDBDMAInterruptSelect (IODBDMAChannelRegisters *registerSetPtr); */
                    214: 
                    215: #define IOGetDBDMAInterruptSelect(registerSetPtr)              \
                    216:         IOGetDBDMAChannelRegister(registerSetPtr,interruptSelect)
                    217: 
                    218: /*     void IOSetDBDMAInterruptSelect (IODBDMAChannelRegisters *registerSetPtr, unsigned long intSelValue); */
                    219: 
                    220: #define IOSetDBDMAInterruptSelect(registerSetPtr,intSelValue)             \
                    221: do {                                                                      \
                    222:     IOSetDBDMAChannelRegister(registerSetPtr,interruptSelect,intSelValue); \
                    223:     eieio();                                                              \
                    224: } while(0)
                    225: 
                    226: /*     unsigned long IOGetDBDMABranchSelect (IODBDMAChannelRegisters *registerSetPtr); */
                    227: 
                    228: #define IOGetDBDMABranchSelect(registerSetPtr)                         \
                    229:        IOGetDBDMAChannelRegister(registerSetPtr,branchSelect)
                    230: 
                    231: /*     void IOSetDBDMABranchSelect (IODBDMAChannelRegisters *registerSetPtr, unsigned long braSelValue); */
                    232: 
                    233: #define IOSetDBDMABranchSelect(registerSetPtr,braSelValue)             \
                    234: do {                                                                   \
                    235:     IOSetDBDMAChannelRegister(registerSetPtr,branchSelect,braSelValue);        \
                    236:     eieio();                                                           \
                    237: } while(0)
                    238: 
                    239: /*     unsigned long IOGetDBDMAWaitSelect (IODBDMAChannelRegisters *registerSetPtr); */
                    240: 
                    241: #define IOGetDBDMAWaitSelect(registerSetPtr)                           \
                    242:        IOGetDBDMAChannelRegister(registerSetPtr,waitSelect)
                    243: 
                    244: /*     void IOSetDBDMAWaitSelect (IODBDMAChannelRegisters *registerSetPtr, unsigned long waitSelValue); */
                    245: 
                    246: #define IOSetDBDMAWaitSelect(registerSetPtr,waitSelValue)              \
                    247: do {                                                                   \
                    248:     IOSetDBDMAChannelRegister(registerSetPtr,waitSelect,waitSelValue); \
                    249:     eieio();                                                           \
                    250: } while(0)
                    251: 
                    252: 
                    253: /*  These macros are IODBDMADescriptor accessor functions. */
                    254: 
                    255: #define IOSetDBDMADescriptor(descPtr,field,value)              \
                    256: OSWriteSwapInt32( descPtr, offsetof( IODBDMADescriptor, field), value)
                    257: 
                    258: #define IOGetDBDMADescriptor(descPtr,field)    \
                    259: OSReadSwapInt32( descPtr, offsetof( IODBDMADescriptor, field))
                    260: 
                    261: #define        IOMakeDBDMAOperation(cmd,key,interrupt,branch,wait,count)       \
                    262:     ( ((cmd) << 28) | ((key) << 24) | ((interrupt) << 20)              \
                    263:       | ((branch) << 18) | ( (wait) << 16) | (count) )
                    264: 
                    265: /* void  IOMakeDBDMADescriptor (IODBDMADescriptor *descPtr,
                    266:                                unsigned long cmd,
                    267:                                unsigned long key,
                    268:                                unsigned long interrupt,
                    269:                                unsigned long branch,
                    270:                                unsigned long wait,
                    271:                                unsigned long count,
                    272:                                unsigned long addr); */
                    273: 
                    274: #define IOMakeDBDMADescriptor(descPtr,cmd,key,interrupt,branch,wait,count,addr)\
                    275: do {                                                                          \
                    276:     IOSetDBDMADescriptor(descPtr, address, addr);                             \
                    277:     IOSetDBDMADescriptor(descPtr, cmdDep,  0);                                \
                    278:     IOSetDBDMADescriptor(descPtr, result,  0);                                \
                    279:     eieio();                                                                  \
                    280:     IOSetDBDMADescriptor(descPtr, operation,                                  \
                    281:         IOMakeDBDMAOperation(cmd,key,interrupt,branch,wait,count));           \
                    282:     eieio();                                                                  \
                    283: } while(0)
                    284: 
                    285: /* void IOMakeDBDMADescriptorDep (IODBDMADescriptor *descPtr,
                    286:                                unsigned long cmd,
                    287:                                unsigned long key,
                    288:                                unsigned long interrupt,
                    289:                                unsigned long branch,
                    290:                                unsigned long wait,
                    291:                                unsigned long count,
                    292:                                unsigned long addr,
                    293:                                unsigned long dep); */
                    294: 
                    295: #define IOMakeDBDMADescriptorDep(descPtr,cmd,key,interrupt,branch,wait,count,addr,dep) \
                    296: do {                                                                          \
                    297:     IOSetDBDMADescriptor(descPtr, address, addr);                             \
                    298:     IOSetDBDMADescriptor(descPtr, cmdDep, dep);                                       \
                    299:     IOSetDBDMADescriptor(descPtr, result, 0);                                 \
                    300:     eieio();                                                                  \
                    301:     IOSetDBDMADescriptor(descPtr, operation,                                  \
                    302:         IOMakeDBDMAOperation(cmd, key, interrupt, branch, wait, count));       \
                    303:     eieio();                                                                  \
                    304: } while(0)
                    305: 
                    306: /*     Field accessors - NOTE: unsynchronized */
                    307: 
                    308: /*     unsigned long IOGetDBDMAOperation (IODBDMADescriptor *descPtr) */
                    309: 
                    310: #define IOGetCCOperation(descPtr)                              \
                    311:        IOGetDBDMADescriptor(descPtr,operation)
                    312: 
                    313: /*     void IOSetCCOperation (IODBDMADescriptor *descPtr, unsigned long operationValue) */
                    314: 
                    315: #define IOSetCCOperation(descPtr,operationValue)               \
                    316:        IOSetDBDMADescriptor(descPtr,operation,operationValue)
                    317: 
                    318: /*     unsigned long IOGetCCAddress (IODBDMADescriptor *descPtr) */
                    319: 
                    320: #define IOGetCCAddress(descPtr)                                \
                    321:        IOGetDBDMADescriptor(descPtr,address)
                    322: 
                    323: /*     void IOSetCCAddress (IODBDMADescriptor *descPtr, unsigned long addressValue) */
                    324: 
                    325: #define IOSetCCAddress(descPtr,addressValue)           \
                    326:        IOSetDBDMADescriptor(descPtr,address, addressValue)
                    327: 
                    328: /*     unsigned long IOGetCCCmdDep (IODBDMADescriptor *descPtr) */
                    329: 
                    330: #define IOGetCCCmdDep(descPtr)                         \
                    331:        IOGetDBDMADescriptor(descPtr,cmdDep)
                    332: 
                    333: /*     void IOSetCCCmdDep (IODBDMADescriptor *descPtr, unsigned long cmdDepValue) */
                    334: 
                    335: #define IOSetCCCmdDep(descPtr,cmdDepValue)             \
                    336:        IOSetDBDMADescriptor(descPtr,cmdDep,cmdDepValue)
                    337: 
                    338: /*     unsigned long IOGetCCResult (IODBDMADescriptor *descPtr) */
                    339: 
                    340: #define IOGetCCResult(descPtr)                         \
                    341:        IOGetDBDMADescriptor(descPtr,result)
                    342: 
                    343: /*     void IOSetCCResult (IODBDMADescriptor *descPtr, unsigned long resultValue) */
                    344: 
                    345: #define IOSetCCResult(descPtr,resultValue)             \
                    346:        IOSetDBDMADescriptor(descPtr,result,resultValue)
                    347: 
                    348: 
                    349: /* DBDMA routines */
                    350: 
                    351: extern void    IODBDMAStart( volatile IODBDMAChannelRegisters *registerSetPtr, volatile IODBDMADescriptor *physicalDescPtr);
                    352: extern void    IODBDMAStop( volatile IODBDMAChannelRegisters *registerSetPtr);
                    353: extern void    IODBDMAFlush( volatile IODBDMAChannelRegisters *registerSetPtr);
                    354: extern void    IODBDMAReset( volatile IODBDMAChannelRegisters *registerSetPtr);
                    355: extern void    IODBDMAContinue( volatile IODBDMAChannelRegisters *registerSetPtr);
                    356: extern void    IODBDMAPause( volatile IODBDMAChannelRegisters *registerSetPtr);
                    357: 
                    358: extern IOReturn        IOAllocatePhysicallyContiguousMemory( unsigned int size, unsigned int options,
                    359:                                     IOVirtualAddress * logical, IOPhysicalAddress * physical );
                    360: extern IOReturn IOFreePhysicallyContiguousMemory( IOVirtualAddress * logical, unsigned int size);
                    361: 
                    362: #endif /* !defined(_IODBDMA_H_) */

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.