1 /* 2 * dspbridge/mpu_api/inc/cmmdefs.h 3 * 4 * DSP-BIOS Bridge driver support functions for TI OMAP processors. 5 * 6 * Copyright (C) 2007 Texas Instruments, Inc. 7 * 8 * This program is free software; you can redistribute it and/or modify it 9 * under the terms of the GNU Lesser General Public License as published 10 * by the Free Software Foundation version 2.1 of the License. 11 * 12 * This program is distributed .as is. WITHOUT ANY WARRANTY of any kind, 13 * whether express or implied; without even the implied warranty of 14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 15 * Lesser General Public License for more details. 16 */ 17 18 19 /* 20 * ======== cmmdefs.h ======== 21 * Purpose: 22 * Global MEM constants and types. 23 * 24 *! Revision History: 25 *! ================ 26 *! 12-Nov-2001 ag CMM_KERNMAPTYPE added for dsp<->device process addr map'n. 27 *! This allows addr conversion from drvr process <-> DSP addr. 28 *! 29-Aug-2001 ag Added CMM_ALLSEGMENTS. 29 *! 08-Dec-2000 ag Added bus address conversion type CMM_POMAPEMIF2DSPBUS. 30 *! 05-Dec-2000 ag Added default CMM_DEFLTCONVFACTOR & CMM_DEFLTDSPADDROFFSET. 31 *! 29-Oct-2000 ag Added converstion factor for GPP DSP Pa translation. 32 *! 15-Oct-2000 ag Added address translator attributes and defaults. 33 *! 12-Jul-2000 ag Created. 34 */ 35 36 #ifndef CMMDEFS_ 37 #define CMMDEFS_ 38 39 #ifdef __cplusplus 40 extern "C" { 41 #endif 42 43 #include <list.h> 44 45 /* Cmm attributes used in CMM_Create() */ 46 struct CMM_MGRATTRS { 47 ULONG ulMinBlockSize; /* Minimum SM allocation; default 32 bytes. */ 48 }; 49 50 /* Attributes for CMM_AllocBuf() & CMM_AllocDesc() */ 51 struct CMM_ATTRS { 52 ULONG ulSegId; /* 1,2... are SM segments. 0 is not. */ 53 ULONG ulAlignment; /* 0,1,2,4....ulMinBlockSize */ 54 } ; 55 56 /* 57 * DSPPa to GPPPa Conversion Factor. 58 * 59 * For typical platforms: 60 * converted Address = PaDSP + ( cFactor * addressToConvert). 61 */ 62 typedef enum { 63 CMM_SUBFROMDSPPA = -1, 64 CMM_POMAPEMIF2DSPBUS = 0, /* PreOMAP is special case: not simple offset */ 65 CMM_ADDTODSPPA = 1 66 } CMM_CNVTTYPE; 67 68 #define CMM_DEFLTDSPADDROFFSET 0 69 #define CMM_DEFLTCONVFACTOR CMM_POMAPEMIF2DSPBUS /* PreOMAP DSPBUS<->EMIF */ 70 #define CMM_ALLSEGMENTS 0xFFFFFF /* All SegIds */ 71 #define CMM_MAXGPPSEGS 1 /* Maximum # of SM segs */ 72 73 /* 74 * SMSEGs are SM segments the DSP allocates from. 75 * 76 * This info is used by the GPP to xlate DSP allocated PAs. 77 */ 78 struct CMM_SMSEG { 79 DWORD dwSMBasePA; /* Physical SM Base address(GPP). */ 80 ULONG ulTotalSizePA; /* Size of SM segment in GPP bytes. */ 81 DWORD dwPAPAConvert; /* DSP PA to GPP PA Conversion. */ 82 CMM_CNVTTYPE cFactor; /* CMM_ADDTOPA=1, CMM_SUBFROMPA=-1 */ 83 } ; 84 85 /* Fixed size memory descriptor */ 86 struct CMM_FDESC { 87 struct LST_ELEM link; /* must be 1st element */ 88 DWORD dwPA; 89 DWORD dwVA; 90 DWORD dwSize; 91 DWORD dwAttrs; /* [31-1 reserved ][0 - SM] */ 92 } ; 93 94 struct CMM_SEGINFO { 95 DWORD dwSegBasePa; /* Start Phys address of SM segment */ 96 ULONG ulTotalSegSize; /* Total size in bytes of segment: DSP+GPP */ 97 DWORD dwGPPBasePA; /* Start Phys addr of Gpp SM seg */ 98 ULONG ulGPPSize; /* Size of Gpp SM seg in bytes */ 99 DWORD dwDSPBaseVA; /* DSP virt base byte address */ 100 ULONG ulDSPSize; /* DSP seg size in bytes */ 101 ULONG ulInUseCnt; /* # of current GPP allocations from this segment */ 102 DWORD dwSegBaseVa; /* Start Virt address of SM seg */ 103 104 } ; 105 106 /* CMM useful information */ 107 struct CMM_INFO { 108 ULONG ulNumGPPSMSegs; /* # of SM segments registered with this Cmm. */ 109 ULONG ulTotalInUseCnt; /* Total # of allocations outstanding for CMM */ 110 /* Min SM block size allocation from CMM_Create() */ 111 ULONG ulMinBlockSize; 112 /* Info per registered SM segment. */ 113 struct CMM_SEGINFO segInfo[CMM_MAXGPPSEGS]; 114 } ; 115 116 /* XlatorCreate attributes */ 117 struct CMM_XLATORATTRS { 118 ULONG ulSegId; /* segment Id used for SM allocations */ 119 DWORD dwDSPBufs; /* # of DSP-side bufs */ 120 DWORD dwDSPBufSize; /* size of DSP-side bufs in GPP bytes */ 121 PVOID pVmBase; /* Vm base address alloc'd in client process context */ 122 DWORD dwVmSize; /* dwVmSize must be >= (dwMaxNumBufs * dwMaxSize) */ 123 } ; 124 125 /* Descriptor attributes */ 126 typedef enum { 127 CMM_LOCAL = 0, /* Bit 0 =0 is local memory from default heap */ 128 CMM_SHARED = 1, /* Bit 0 =1 descriptor is SM */ 129 /* Bits 1- 31 RESERVED for future use */ 130 } CMM_DESCTYPE; 131 132 /* 133 * Cmm translation types. Use to map SM addresses to process context. 134 */ 135 typedef enum { 136 CMM_VA2PA = 0, /* Virtual to GPP physical address xlation */ 137 CMM_PA2VA = 1, /* GPP Physical to virtual */ 138 CMM_VA2DSPPA = 2, /* Va to DSP Pa */ 139 CMM_PA2DSPPA = 3, /* GPP Pa to DSP Pa */ 140 CMM_DSPPA2PA = 4, /* DSP Pa to GPP Pa */ 141 } CMM_XLATETYPE; 142 143 /* 144 * Used to "map" between device process virt addr and dsp addr. 145 */ 146 typedef enum { 147 CMM_KERNVA2DSP = 0, /* Device process context to dsp address. */ 148 CMM_DSP2KERNVA = 1, /* Dsp address to device process context. */ 149 } CMM_KERNMAPTYPE; 150 151 struct CMM_OBJECT; 152 /*typedef struct CMM_OBJECT *CMM_HMGR;*/ 153 struct CMM_XLATOROBJECT; 154 /*typedef struct CMM_XLATOROBJECT *CMM_HXLATOR;*/ 155 156 #ifdef __cplusplus 157 } 158 #endif 159 #endif /* CMMDEFS_ */ 160