| /* |
| * Copyright 2001-2008 Texas Instruments - http://www.ti.com/ |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| |
| /* |
| * ======== cmmdefs.h ======== |
| * DSP-BIOS Bridge driver support functions for TI OMAP processors. |
| * Purpose: |
| * Global MEM constants and types. |
| * |
| *! Revision History: |
| *! ================ |
| *! 12-Nov-2001 ag CMM_KERNMAPTYPE added for dsp<->device process addr map'n. |
| *! This allows addr conversion from drvr process <-> DSP addr. |
| *! 29-Aug-2001 ag Added CMM_ALLSEGMENTS. |
| *! 08-Dec-2000 ag Added bus address conversion type CMM_POMAPEMIF2DSPBUS. |
| *! 05-Dec-2000 ag Added default CMM_DEFLTCONVFACTOR & CMM_DEFLTDSPADDROFFSET. |
| *! 29-Oct-2000 ag Added converstion factor for GPP DSP Pa translation. |
| *! 15-Oct-2000 ag Added address translator attributes and defaults. |
| *! 12-Jul-2000 ag Created. |
| */ |
| |
| #ifndef CMMDEFS_ |
| #define CMMDEFS_ |
| |
| #ifdef __cplusplus |
| extern "C" { |
| #endif |
| |
| #include <list.h> |
| |
| /* Cmm attributes used in CMM_Create() */ |
| struct CMM_MGRATTRS { |
| ULONG ulMinBlockSize; /* Minimum SM allocation; default 32 bytes. */ |
| }; |
| |
| /* Attributes for CMM_AllocBuf() & CMM_AllocDesc() */ |
| struct CMM_ATTRS { |
| ULONG ulSegId; /* 1,2... are SM segments. 0 is not. */ |
| ULONG ulAlignment; /* 0,1,2,4....ulMinBlockSize */ |
| } ; |
| |
| /* |
| * DSPPa to GPPPa Conversion Factor. |
| * |
| * For typical platforms: |
| * converted Address = PaDSP + ( cFactor * addressToConvert). |
| */ |
| typedef enum { |
| CMM_SUBFROMDSPPA = -1, |
| CMM_POMAPEMIF2DSPBUS = 0, /* PreOMAP is special case: not simple offset */ |
| CMM_ADDTODSPPA = 1 |
| } CMM_CNVTTYPE; |
| |
| #define CMM_DEFLTDSPADDROFFSET 0 |
| #define CMM_DEFLTCONVFACTOR CMM_POMAPEMIF2DSPBUS /* PreOMAP DSPBUS<->EMIF */ |
| #define CMM_ALLSEGMENTS 0xFFFFFF /* All SegIds */ |
| #define CMM_MAXGPPSEGS 1 /* Maximum # of SM segs */ |
| |
| /* |
| * SMSEGs are SM segments the DSP allocates from. |
| * |
| * This info is used by the GPP to xlate DSP allocated PAs. |
| */ |
| struct CMM_SMSEG { |
| DWORD dwSMBasePA; /* Physical SM Base address(GPP). */ |
| ULONG ulTotalSizePA; /* Size of SM segment in GPP bytes. */ |
| DWORD dwPAPAConvert; /* DSP PA to GPP PA Conversion. */ |
| CMM_CNVTTYPE cFactor; /* CMM_ADDTOPA=1, CMM_SUBFROMPA=-1 */ |
| } ; |
| |
| /* Fixed size memory descriptor */ |
| struct CMM_FDESC { |
| struct LST_ELEM link; /* must be 1st element */ |
| DWORD dwPA; |
| DWORD dwVA; |
| DWORD dwSize; |
| DWORD dwAttrs; /* [31-1 reserved ][0 - SM] */ |
| } ; |
| |
| struct CMM_SEGINFO { |
| DWORD dwSegBasePa; /* Start Phys address of SM segment */ |
| ULONG ulTotalSegSize; /* Total size in bytes of segment: DSP+GPP */ |
| DWORD dwGPPBasePA; /* Start Phys addr of Gpp SM seg */ |
| ULONG ulGPPSize; /* Size of Gpp SM seg in bytes */ |
| DWORD dwDSPBaseVA; /* DSP virt base byte address */ |
| ULONG ulDSPSize; /* DSP seg size in bytes */ |
| ULONG ulInUseCnt; /* # of current GPP allocations from this segment */ |
| DWORD dwSegBaseVa; /* Start Virt address of SM seg */ |
| |
| } ; |
| |
| /* CMM useful information */ |
| struct CMM_INFO { |
| ULONG ulNumGPPSMSegs; /* # of SM segments registered with this Cmm. */ |
| ULONG ulTotalInUseCnt; /* Total # of allocations outstanding for CMM */ |
| /* Min SM block size allocation from CMM_Create() */ |
| ULONG ulMinBlockSize; |
| /* Info per registered SM segment. */ |
| struct CMM_SEGINFO segInfo[CMM_MAXGPPSEGS]; |
| } ; |
| |
| /* XlatorCreate attributes */ |
| struct CMM_XLATORATTRS { |
| ULONG ulSegId; /* segment Id used for SM allocations */ |
| DWORD dwDSPBufs; /* # of DSP-side bufs */ |
| DWORD dwDSPBufSize; /* size of DSP-side bufs in GPP bytes */ |
| PVOID pVmBase; /* Vm base address alloc'd in client process context */ |
| DWORD dwVmSize; /* dwVmSize must be >= (dwMaxNumBufs * dwMaxSize) */ |
| } ; |
| |
| /* Descriptor attributes */ |
| typedef enum { |
| CMM_LOCAL = 0, /* Bit 0 =0 is local memory from default heap */ |
| CMM_SHARED = 1, /* Bit 0 =1 descriptor is SM */ |
| /* Bits 1- 31 RESERVED for future use */ |
| } CMM_DESCTYPE; |
| |
| /* |
| * Cmm translation types. Use to map SM addresses to process context. |
| */ |
| typedef enum { |
| CMM_VA2PA = 0, /* Virtual to GPP physical address xlation */ |
| CMM_PA2VA = 1, /* GPP Physical to virtual */ |
| CMM_VA2DSPPA = 2, /* Va to DSP Pa */ |
| CMM_PA2DSPPA = 3, /* GPP Pa to DSP Pa */ |
| CMM_DSPPA2PA = 4, /* DSP Pa to GPP Pa */ |
| } CMM_XLATETYPE; |
| |
| /* |
| * Used to "map" between device process virt addr and dsp addr. |
| */ |
| typedef enum { |
| CMM_KERNVA2DSP = 0, /* Device process context to dsp address. */ |
| CMM_DSP2KERNVA = 1, /* Dsp address to device process context. */ |
| } CMM_KERNMAPTYPE; |
| |
| struct CMM_OBJECT; |
| /*typedef struct CMM_OBJECT *CMM_HMGR;*/ |
| struct CMM_XLATOROBJECT; |
| /*typedef struct CMM_XLATOROBJECT *CMM_HXLATOR;*/ |
| |
| #ifdef __cplusplus |
| } |
| #endif |
| #endif /* CMMDEFS_ */ |