/********************************************************************** * * Copyright (C) Imagination Technologies Ltd. All rights reserved. * * This program is free software; you can redistribute it and/or modify it * under the terms and conditions of the GNU General Public License, * version 2, as published by the Free Software Foundation. * * This program is distributed in the hope it will be useful but, except * as otherwise stated in writing, without any warranty; without even the * implied warranty of merchantability or fitness for a particular purpose. * See the GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along with * this program; if not, write to the Free Software Foundation, Inc., * 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA. * * The full GNU General Public License is included in this distribution in * the file called "COPYING". * * Contact Information: * Imagination Technologies Ltd. * Home Park Estate, Kings Langley, Herts, WD4 8LZ, UK * ******************************************************************************/ #ifndef __SERVICES_H__ #define __SERVICES_H__ #if defined (__cplusplus) extern "C" { #endif #include "img_defs.h" #include "servicesext.h" #include "pdumpdefs.h" #define PVRSRV_4K_PAGE_SIZE 4096UL #define PVRSRV_MAX_CMD_SIZE 1024 #define PVRSRV_MAX_DEVICES 16 #define EVENTOBJNAME_MAXLENGTH (50) #define PVRSRV_MEM_READ (1U<<0) #define PVRSRV_MEM_WRITE (1U<<1) #define PVRSRV_MEM_CACHE_CONSISTENT (1U<<2) #define PVRSRV_MEM_NO_SYNCOBJ (1U<<3) #define PVRSRV_MEM_INTERLEAVED (1U<<4) #define PVRSRV_MEM_DUMMY (1U<<5) #define PVRSRV_MEM_EDM_PROTECT (1U<<6) #define PVRSRV_MEM_ZERO (1U<<7) #define PVRSRV_MEM_USER_SUPPLIED_DEVVADDR (1U<<8) #define PVRSRV_MEM_RAM_BACKED_ALLOCATION (1U<<9) #define PVRSRV_MEM_NO_RESMAN (1U<<10) #define PVRSRV_MEM_EXPORTED (1U<<11) #define PVRSRV_HAP_CACHED (1U<<12) #define PVRSRV_HAP_UNCACHED (1U<<13) #define PVRSRV_HAP_WRITECOMBINE (1U<<14) #define PVRSRV_HAP_CACHETYPE_MASK (PVRSRV_HAP_CACHED|PVRSRV_HAP_UNCACHED|PVRSRV_HAP_WRITECOMBINE) #define PVRSRV_HAP_KERNEL_ONLY (1U<<15) #define PVRSRV_HAP_SINGLE_PROCESS (1U<<16) #define PVRSRV_HAP_MULTI_PROCESS (1U<<17) #define PVRSRV_HAP_FROM_EXISTING_PROCESS (1U<<18) #define PVRSRV_HAP_NO_CPU_VIRTUAL (1U<<19) #define PVRSRV_HAP_MAPTYPE_MASK (PVRSRV_HAP_KERNEL_ONLY \ |PVRSRV_HAP_SINGLE_PROCESS \ |PVRSRV_HAP_MULTI_PROCESS \ |PVRSRV_HAP_FROM_EXISTING_PROCESS \ |PVRSRV_HAP_NO_CPU_VIRTUAL) #define PVRSRV_MEM_CACHED PVRSRV_HAP_CACHED #define PVRSRV_MEM_UNCACHED PVRSRV_HAP_UNCACHED #define PVRSRV_MEM_WRITECOMBINE PVRSRV_HAP_WRITECOMBINE #define PVRSRV_MEM_BACKINGSTORE_FIELD_SHIFT (24) #define PVRSRV_MAP_NOUSERVIRTUAL (1UL<<27) #define PVRSRV_MEM_XPROC (1U<<28) #define PVRSRV_MEM_ION (1U<<29) #define PVRSRV_MEM_ALLOCATENONCACHEDMEM (1UL<<30) #define PVRSRV_NO_CONTEXT_LOSS 0 #define PVRSRV_SEVERE_LOSS_OF_CONTEXT 1 #define PVRSRV_PRE_STATE_CHANGE_MASK 0x80 #define PVRSRV_DEFAULT_DEV_COOKIE (1) #define PVRSRV_MISC_INFO_TIMER_PRESENT (1U<<0) #define PVRSRV_MISC_INFO_CLOCKGATE_PRESENT (1U<<1) #define PVRSRV_MISC_INFO_MEMSTATS_PRESENT (1U<<2) #define PVRSRV_MISC_INFO_GLOBALEVENTOBJECT_PRESENT (1U<<3) #define PVRSRV_MISC_INFO_DDKVERSION_PRESENT (1U<<4) #define PVRSRV_MISC_INFO_CPUCACHEOP_PRESENT (1U<<5) #define PVRSRV_MISC_INFO_FREEMEM_PRESENT (1U<<6) #define PVRSRV_MISC_INFO_GET_REF_COUNT_PRESENT (1U<<7) #define PVRSRV_MISC_INFO_RESET_PRESENT (1U<<31) #define PVRSRV_PDUMP_MAX_FILENAME_SIZE 20 #define PVRSRV_PDUMP_MAX_COMMENT_SIZE 200 #define PVRSRV_CHANGEDEVMEM_ATTRIBS_CACHECOHERENT 0x00000001 #define PVRSRV_MAPEXTMEMORY_FLAGS_ALTERNATEVA 0x00000001 #define PVRSRV_MAPEXTMEMORY_FLAGS_PHYSCONTIG 0x00000002 #define PVRSRV_MODIFYSYNCOPS_FLAGS_WO_INC 0x00000001 #define PVRSRV_MODIFYSYNCOPS_FLAGS_RO_INC 0x00000002 #define SRV_FLAGS_PERSIST 0x1 #define SRV_FLAGS_PDUMP_ACTIVE 0x2 #define PVRSRV_PDUMP_FLAGS_CONTINUOUS 0x1 typedef enum _PVRSRV_DEVICE_TYPE_ { PVRSRV_DEVICE_TYPE_UNKNOWN = 0 , PVRSRV_DEVICE_TYPE_MBX1 = 1 , PVRSRV_DEVICE_TYPE_MBX1_LITE = 2 , PVRSRV_DEVICE_TYPE_M24VA = 3, PVRSRV_DEVICE_TYPE_MVDA2 = 4, PVRSRV_DEVICE_TYPE_MVED1 = 5, PVRSRV_DEVICE_TYPE_MSVDX = 6, PVRSRV_DEVICE_TYPE_SGX = 7, PVRSRV_DEVICE_TYPE_VGX = 8, PVRSRV_DEVICE_TYPE_EXT = 9, PVRSRV_DEVICE_TYPE_LAST = 9, PVRSRV_DEVICE_TYPE_FORCE_I32 = 0x7fffffff } PVRSRV_DEVICE_TYPE; #define HEAP_ID( _dev_ , _dev_heap_idx_ ) ( ((_dev_)<<24) | ((_dev_heap_idx_)&((1<<24)-1)) ) #define HEAP_IDX( _heap_id_ ) ( (_heap_id_)&((1<<24) - 1 ) ) #define HEAP_DEV( _heap_id_ ) ( (_heap_id_)>>24 ) #define PVRSRV_UNDEFINED_HEAP_ID (~0LU) typedef enum { IMG_EGL = 0x00000001, IMG_OPENGLES1 = 0x00000002, IMG_OPENGLES2 = 0x00000003, IMG_D3DM = 0x00000004, IMG_SRV_UM = 0x00000005, IMG_OPENVG = 0x00000006, IMG_SRVCLIENT = 0x00000007, IMG_VISTAKMD = 0x00000008, IMG_VISTA3DNODE = 0x00000009, IMG_VISTAMVIDEONODE = 0x0000000A, IMG_VISTAVPBNODE = 0x0000000B, IMG_OPENGL = 0x0000000C, IMG_D3D = 0x0000000D, #if defined(SUPPORT_GRAPHICS_HAL) || defined(SUPPORT_COMPOSER_HAL) IMG_ANDROID_HAL = 0x0000000E, #endif #if defined(SUPPORT_OPENCL) IMG_OPENCL = 0x0000000F, #endif } IMG_MODULE_ID; #define APPHINT_MAX_STRING_SIZE 256 typedef enum { IMG_STRING_TYPE = 1, IMG_FLOAT_TYPE , IMG_UINT_TYPE , IMG_INT_TYPE , IMG_FLAG_TYPE }IMG_DATA_TYPE; typedef struct _PVRSRV_DEV_DATA_ *PPVRSRV_DEV_DATA; typedef struct _PVRSRV_DEVICE_IDENTIFIER_ { PVRSRV_DEVICE_TYPE eDeviceType; PVRSRV_DEVICE_CLASS eDeviceClass; IMG_UINT32 ui32DeviceIndex; IMG_CHAR *pszPDumpDevName; IMG_CHAR *pszPDumpRegName; } PVRSRV_DEVICE_IDENTIFIER; typedef struct _PVRSRV_CLIENT_DEV_DATA_ { IMG_UINT32 ui32NumDevices; PVRSRV_DEVICE_IDENTIFIER asDevID[PVRSRV_MAX_DEVICES]; PVRSRV_ERROR (*apfnDevConnect[PVRSRV_MAX_DEVICES])(PPVRSRV_DEV_DATA); PVRSRV_ERROR (*apfnDumpTrace[PVRSRV_MAX_DEVICES])(PPVRSRV_DEV_DATA); } PVRSRV_CLIENT_DEV_DATA; typedef struct _PVRSRV_CONNECTION_ { IMG_HANDLE hServices; IMG_UINT32 ui32ProcessID; PVRSRV_CLIENT_DEV_DATA sClientDevData; IMG_UINT32 ui32SrvFlags; }PVRSRV_CONNECTION; typedef struct _PVRSRV_DEV_DATA_ { IMG_CONST PVRSRV_CONNECTION *psConnection; #if defined (SUPPORT_SID_INTERFACE) IMG_SID hDevCookie; #else IMG_HANDLE hDevCookie; #endif } PVRSRV_DEV_DATA; typedef struct _PVRSRV_MEMUPDATE_ { IMG_UINT32 ui32UpdateAddr; IMG_UINT32 ui32UpdateVal; } PVRSRV_MEMUPDATE; typedef struct _PVRSRV_HWREG_ { IMG_UINT32 ui32RegAddr; IMG_UINT32 ui32RegVal; } PVRSRV_HWREG; typedef struct _PVRSRV_MEMBLK_ { IMG_DEV_VIRTADDR sDevVirtAddr; IMG_HANDLE hOSMemHandle; IMG_HANDLE hOSWrapMem; IMG_HANDLE hBuffer; IMG_HANDLE hResItem; IMG_SYS_PHYADDR *psIntSysPAddr; } PVRSRV_MEMBLK; typedef struct _PVRSRV_KERNEL_MEM_INFO_ *PPVRSRV_KERNEL_MEM_INFO; typedef struct _PVRSRV_CLIENT_MEM_INFO_ { IMG_PVOID pvLinAddr; IMG_PVOID pvLinAddrKM; IMG_DEV_VIRTADDR sDevVAddr; IMG_CPU_PHYADDR sCpuPAddr; IMG_UINT32 ui32Flags; IMG_UINT32 ui32ClientFlags; IMG_SIZE_T uAllocSize; struct _PVRSRV_CLIENT_SYNC_INFO_ *psClientSyncInfo; #if defined (SUPPORT_SID_INTERFACE) IMG_SID hMappingInfo; IMG_SID hKernelMemInfo; IMG_SID hResItem; #else IMG_HANDLE hMappingInfo; IMG_HANDLE hKernelMemInfo; IMG_HANDLE hResItem; #endif #if defined(SUPPORT_MEMINFO_IDS) #if !defined(USE_CODE) IMG_UINT64 ui64Stamp; #else IMG_UINT32 dummy1; IMG_UINT32 dummy2; #endif #endif struct _PVRSRV_CLIENT_MEM_INFO_ *psNext; } PVRSRV_CLIENT_MEM_INFO, *PPVRSRV_CLIENT_MEM_INFO; #define PVRSRV_MAX_CLIENT_HEAPS (32) typedef struct _PVRSRV_HEAP_INFO_ { IMG_UINT32 ui32HeapID; #if defined (SUPPORT_SID_INTERFACE) IMG_SID hDevMemHeap; #else IMG_HANDLE hDevMemHeap; #endif IMG_DEV_VIRTADDR sDevVAddrBase; IMG_UINT32 ui32HeapByteSize; IMG_UINT32 ui32Attribs; IMG_UINT32 ui32XTileStride; }PVRSRV_HEAP_INFO; typedef struct _PVRSRV_EVENTOBJECT_ { IMG_CHAR szName[EVENTOBJNAME_MAXLENGTH]; #if defined (SUPPORT_SID_INTERFACE) IMG_SID hOSEventKM; #else IMG_HANDLE hOSEventKM; #endif } PVRSRV_EVENTOBJECT; typedef enum { PVRSRV_MISC_INFO_CPUCACHEOP_NONE = 0, PVRSRV_MISC_INFO_CPUCACHEOP_CLEAN, PVRSRV_MISC_INFO_CPUCACHEOP_FLUSH } PVRSRV_MISC_INFO_CPUCACHEOP_TYPE; typedef struct _PVRSRV_MISC_INFO_ { IMG_UINT32 ui32StateRequest; IMG_UINT32 ui32StatePresent; IMG_VOID *pvSOCTimerRegisterKM; IMG_VOID *pvSOCTimerRegisterUM; #if defined (SUPPORT_SID_INTERFACE) IMG_SID hSOCTimerRegisterOSMemHandle; IMG_SID hSOCTimerRegisterMappingInfo; #else IMG_HANDLE hSOCTimerRegisterOSMemHandle; IMG_HANDLE hSOCTimerRegisterMappingInfo; #endif IMG_VOID *pvSOCClockGateRegs; IMG_UINT32 ui32SOCClockGateRegsSize; IMG_CHAR *pszMemoryStr; IMG_UINT32 ui32MemoryStrLen; PVRSRV_EVENTOBJECT sGlobalEventObject; #if defined (SUPPORT_SID_INTERFACE) IMG_EVENTSID hOSGlobalEvent; #else IMG_HANDLE hOSGlobalEvent; #endif IMG_UINT32 aui32DDKVersion[4]; struct { IMG_BOOL bDeferOp; PVRSRV_MISC_INFO_CPUCACHEOP_TYPE eCacheOpType; #if !defined (SUPPORT_SID_INTERFACE) union { PVRSRV_CLIENT_MEM_INFO *psClientMemInfo; struct _PVRSRV_KERNEL_MEM_INFO_ *psKernelMemInfo; } u; #endif IMG_VOID *pvBaseVAddr; IMG_UINT32 ui32Length; } sCacheOpCtl; struct { #if !defined(SUPPORT_SID_INTERFACE) union { PVRSRV_CLIENT_MEM_INFO *psClientMemInfo; struct _PVRSRV_KERNEL_MEM_INFO_ *psKernelMemInfo; } u; #endif IMG_UINT32 ui32RefCount; } sGetRefCountCtl; } PVRSRV_MISC_INFO; typedef struct _PVRSRV_SYNC_TOKEN_ { struct { #if defined (SUPPORT_SID_INTERFACE) IMG_SID hKernelSyncInfo; #else IMG_HANDLE hKernelSyncInfo; #endif IMG_UINT32 ui32ReadOpsPendingSnapshot; IMG_UINT32 ui32WriteOpsPendingSnapshot; IMG_UINT32 ui32ReadOps2PendingSnapshot; } sPrivate; } PVRSRV_SYNC_TOKEN; typedef enum _PVRSRV_CLIENT_EVENT_ { PVRSRV_CLIENT_EVENT_HWTIMEOUT = 0, } PVRSRV_CLIENT_EVENT; typedef IMG_VOID (*PFN_QUEUE_COMMAND_COMPLETE)(IMG_HANDLE hCallbackData); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVClientEvent(IMG_CONST PVRSRV_CLIENT_EVENT eEvent, PVRSRV_DEV_DATA *psDevData, IMG_PVOID pvData); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVConnect(PVRSRV_CONNECTION **ppsConnection, IMG_UINT32 ui32SrvFlags); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVDisconnect(IMG_CONST PVRSRV_CONNECTION *psConnection); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVEnumerateDevices(IMG_CONST PVRSRV_CONNECTION *psConnection, IMG_UINT32 *puiNumDevices, PVRSRV_DEVICE_IDENTIFIER *puiDevIDs); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVAcquireDeviceData(IMG_CONST PVRSRV_CONNECTION *psConnection, IMG_UINT32 uiDevIndex, PVRSRV_DEV_DATA *psDevData, PVRSRV_DEVICE_TYPE eDeviceType); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVGetMiscInfo (IMG_CONST PVRSRV_CONNECTION *psConnection, PVRSRV_MISC_INFO *psMiscInfo); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVReleaseMiscInfo (IMG_CONST PVRSRV_CONNECTION *psConnection, PVRSRV_MISC_INFO *psMiscInfo); #if 1 IMG_IMPORT IMG_UINT32 ReadHWReg(IMG_PVOID pvLinRegBaseAddr, IMG_UINT32 ui32Offset); IMG_IMPORT IMG_VOID WriteHWReg(IMG_PVOID pvLinRegBaseAddr, IMG_UINT32 ui32Offset, IMG_UINT32 ui32Value); IMG_IMPORT IMG_VOID WriteHWRegs(IMG_PVOID pvLinRegBaseAddr, IMG_UINT32 ui32Count, PVRSRV_HWREG *psHWRegs); #endif IMG_IMPORT PVRSRV_ERROR PVRSRVPollForValue ( const PVRSRV_CONNECTION *psConnection, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hOSEvent, #else IMG_HANDLE hOSEvent, #endif volatile IMG_UINT32 *pui32LinMemAddr, IMG_UINT32 ui32Value, IMG_UINT32 ui32Mask, IMG_UINT32 ui32Waitus, IMG_UINT32 ui32Tries); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVCreateDeviceMemContext(IMG_CONST PVRSRV_DEV_DATA *psDevData, #if defined (SUPPORT_SID_INTERFACE) IMG_SID *phDevMemContext, #else IMG_HANDLE *phDevMemContext, #endif IMG_UINT32 *pui32SharedHeapCount, PVRSRV_HEAP_INFO *psHeapInfo); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVDestroyDeviceMemContext(IMG_CONST PVRSRV_DEV_DATA *psDevData, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hDevMemContext #else IMG_HANDLE hDevMemContext #endif ); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVGetDeviceMemHeapInfo(IMG_CONST PVRSRV_DEV_DATA *psDevData, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hDevMemContext, #else IMG_HANDLE hDevMemContext, #endif IMG_UINT32 *pui32SharedHeapCount, PVRSRV_HEAP_INFO *psHeapInfo); #if defined(PVRSRV_LOG_MEMORY_ALLOCS) #define PVRSRVAllocDeviceMem_log(psDevData, hDevMemHeap, ui32Attribs, ui32Size, ui32Alignment, ppsMemInfo, logStr) \ (PVR_TRACE(("PVRSRVAllocDeviceMem(" #psDevData "," #hDevMemHeap "," #ui32Attribs "," #ui32Size "," #ui32Alignment "," #ppsMemInfo ")" \ ": " logStr " (size = 0x%lx)", ui32Size)), \ PVRSRVAllocDeviceMem(psDevData, hDevMemHeap, ui32Attribs, ui32Size, ui32Alignment, ppsMemInfo)) #else #define PVRSRVAllocDeviceMem_log(psDevData, hDevMemHeap, ui32Attribs, ui32Size, ui32Alignment, ppsMemInfo, logStr) \ PVRSRVAllocDeviceMem(psDevData, hDevMemHeap, ui32Attribs, ui32Size, ui32Alignment, ppsMemInfo) #endif IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVAllocDeviceMem2(IMG_CONST PVRSRV_DEV_DATA *psDevData, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hDevMemHeap, #else IMG_HANDLE hDevMemHeap, #endif IMG_UINT32 ui32Attribs, IMG_SIZE_T ui32Size, IMG_SIZE_T ui32Alignment, IMG_PVOID pvPrivData, IMG_UINT32 ui32PrivDataLength, PVRSRV_CLIENT_MEM_INFO **ppsMemInfo); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVAllocDeviceMem(IMG_CONST PVRSRV_DEV_DATA *psDevData, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hDevMemHeap, #else IMG_HANDLE hDevMemHeap, #endif IMG_UINT32 ui32Attribs, IMG_SIZE_T ui32Size, IMG_SIZE_T ui32Alignment, PVRSRV_CLIENT_MEM_INFO **ppsMemInfo); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVFreeDeviceMem(IMG_CONST PVRSRV_DEV_DATA *psDevData, PVRSRV_CLIENT_MEM_INFO *psMemInfo); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVExportDeviceMem(IMG_CONST PVRSRV_DEV_DATA *psDevData, PVRSRV_CLIENT_MEM_INFO *psMemInfo, #if defined (SUPPORT_SID_INTERFACE) IMG_SID *phMemInfo #else IMG_HANDLE *phMemInfo #endif ); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVReserveDeviceVirtualMem(IMG_CONST PVRSRV_DEV_DATA *psDevData, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hDevMemHeap, #else IMG_HANDLE hDevMemHeap, #endif IMG_DEV_VIRTADDR *psDevVAddr, IMG_SIZE_T ui32Size, IMG_SIZE_T ui32Alignment, PVRSRV_CLIENT_MEM_INFO **ppsMemInfo); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVFreeDeviceVirtualMem(IMG_CONST PVRSRV_DEV_DATA *psDevData, PVRSRV_CLIENT_MEM_INFO *psMemInfo); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVMapDeviceMemory (IMG_CONST PVRSRV_DEV_DATA *psDevData, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hKernelMemInfo, IMG_SID hDstDevMemHeap, #else IMG_HANDLE hKernelMemInfo, IMG_HANDLE hDstDevMemHeap, #endif PVRSRV_CLIENT_MEM_INFO **ppsDstMemInfo); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVUnmapDeviceMemory (IMG_CONST PVRSRV_DEV_DATA *psDevData, PVRSRV_CLIENT_MEM_INFO *psMemInfo); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVMapExtMemory (IMG_CONST PVRSRV_DEV_DATA *psDevData, PVRSRV_CLIENT_MEM_INFO *psMemInfo, IMG_SYS_PHYADDR *psSysPAddr, IMG_UINT32 ui32Flags); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVUnmapExtMemory (IMG_CONST PVRSRV_DEV_DATA *psDevData, PVRSRV_CLIENT_MEM_INFO *psMemInfo, IMG_UINT32 ui32Flags); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVWrapExtMemory(IMG_CONST PVRSRV_DEV_DATA *psDevData, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hDevMemContext, #else IMG_HANDLE hDevMemContext, #endif IMG_SIZE_T ui32ByteSize, IMG_SIZE_T ui32PageOffset, IMG_BOOL bPhysContig, IMG_SYS_PHYADDR *psSysPAddr, IMG_VOID *pvLinAddr, IMG_UINT32 ui32Flags, PVRSRV_CLIENT_MEM_INFO **ppsMemInfo); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVUnwrapExtMemory (IMG_CONST PVRSRV_DEV_DATA *psDevData, PVRSRV_CLIENT_MEM_INFO *psMemInfo); PVRSRV_ERROR PVRSRVChangeDeviceMemoryAttributes(IMG_CONST PVRSRV_DEV_DATA *psDevData, PVRSRV_CLIENT_MEM_INFO *psClientMemInfo, IMG_UINT32 ui32Attribs); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVMapDeviceClassMemory (IMG_CONST PVRSRV_DEV_DATA *psDevData, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hDevMemContext, IMG_SID hDeviceClassBuffer, #else IMG_HANDLE hDevMemContext, IMG_HANDLE hDeviceClassBuffer, #endif PVRSRV_CLIENT_MEM_INFO **ppsMemInfo); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVUnmapDeviceClassMemory (IMG_CONST PVRSRV_DEV_DATA *psDevData, PVRSRV_CLIENT_MEM_INFO *psMemInfo); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVMapPhysToUserSpace(IMG_CONST PVRSRV_DEV_DATA *psDevData, IMG_SYS_PHYADDR sSysPhysAddr, IMG_UINT32 uiSizeInBytes, IMG_PVOID *ppvUserAddr, IMG_UINT32 *puiActualSize, IMG_PVOID *ppvProcess); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVUnmapPhysToUserSpace(IMG_CONST PVRSRV_DEV_DATA *psDevData, IMG_PVOID pvUserAddr, IMG_PVOID pvProcess); #if defined(LINUX) IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVExportDeviceMem2(IMG_CONST PVRSRV_DEV_DATA *psDevData, PVRSRV_CLIENT_MEM_INFO *psMemInfo, IMG_INT *iFd); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVMapDeviceMemory2(IMG_CONST PVRSRV_DEV_DATA *psDevData, IMG_INT iFd, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hDstDevMemHeap, #else IMG_HANDLE hDstDevMemHeap, #endif PVRSRV_CLIENT_MEM_INFO **ppsDstMemInfo); #endif #if defined(SUPPORT_ION) PVRSRV_ERROR PVRSRVMapIonHandle(const PVRSRV_DEV_DATA *psDevData, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hDevMemContext, #else IMG_HANDLE hDevMemContext, #endif IMG_INT32 uiFD, IMG_UINT32 uiSize, IMG_UINT32 ui32Attribs, PVRSRV_CLIENT_MEM_INFO **ppsMemInfo); PVRSRV_ERROR PVRSRVUnmapIonHandle(const PVRSRV_DEV_DATA *psDevData, PVRSRV_CLIENT_MEM_INFO *psMemInfo); #endif typedef enum _PVRSRV_SYNCVAL_MODE_ { PVRSRV_SYNCVAL_READ = IMG_TRUE, PVRSRV_SYNCVAL_WRITE = IMG_FALSE, } PVRSRV_SYNCVAL_MODE, *PPVRSRV_SYNCVAL_MODE; typedef IMG_UINT32 PVRSRV_SYNCVAL; IMG_IMPORT PVRSRV_ERROR PVRSRVWaitForOpsComplete(PPVRSRV_CLIENT_MEM_INFO psMemInfo, PVRSRV_SYNCVAL_MODE eMode, PVRSRV_SYNCVAL OpRequired); IMG_IMPORT PVRSRV_ERROR PVRSRVWaitForAllOpsComplete(PPVRSRV_CLIENT_MEM_INFO psMemInfo, PVRSRV_SYNCVAL_MODE eMode); IMG_IMPORT IMG_BOOL PVRSRVTestOpsComplete(PPVRSRV_CLIENT_MEM_INFO psMemInfo, PVRSRV_SYNCVAL_MODE eMode, PVRSRV_SYNCVAL OpRequired); IMG_IMPORT IMG_BOOL PVRSRVTestAllOpsComplete(PPVRSRV_CLIENT_MEM_INFO psMemInfo, PVRSRV_SYNCVAL_MODE eMode); IMG_IMPORT IMG_BOOL PVRSRVTestOpsNotComplete(PPVRSRV_CLIENT_MEM_INFO psMemInfo, PVRSRV_SYNCVAL_MODE eMode, PVRSRV_SYNCVAL OpRequired); IMG_IMPORT IMG_BOOL PVRSRVTestAllOpsNotComplete(PPVRSRV_CLIENT_MEM_INFO psMemInfo, PVRSRV_SYNCVAL_MODE eMode); IMG_IMPORT PVRSRV_SYNCVAL PVRSRVGetPendingOpSyncVal(PPVRSRV_CLIENT_MEM_INFO psMemInfo, PVRSRV_SYNCVAL_MODE eMode); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVEnumerateDeviceClass(IMG_CONST PVRSRV_CONNECTION *psConnection, PVRSRV_DEVICE_CLASS DeviceClass, IMG_UINT32 *pui32DevCount, IMG_UINT32 *pui32DevID); IMG_IMPORT IMG_HANDLE IMG_CALLCONV PVRSRVOpenDCDevice(IMG_CONST PVRSRV_DEV_DATA *psDevData, IMG_UINT32 ui32DeviceID); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVCloseDCDevice(IMG_CONST PVRSRV_CONNECTION *psConnection, IMG_HANDLE hDevice); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVEnumDCFormats (IMG_HANDLE hDevice, IMG_UINT32 *pui32Count, DISPLAY_FORMAT *psFormat); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVEnumDCDims (IMG_HANDLE hDevice, IMG_UINT32 *pui32Count, DISPLAY_FORMAT *psFormat, DISPLAY_DIMS *psDims); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVGetDCSystemBuffer(IMG_HANDLE hDevice, #if defined (SUPPORT_SID_INTERFACE) IMG_SID *phBuffer #else IMG_HANDLE *phBuffer #endif ); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVGetDCInfo(IMG_HANDLE hDevice, DISPLAY_INFO* psDisplayInfo); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVCreateDCSwapChain (IMG_HANDLE hDevice, IMG_UINT32 ui32Flags, DISPLAY_SURF_ATTRIBUTES *psDstSurfAttrib, DISPLAY_SURF_ATTRIBUTES *psSrcSurfAttrib, IMG_UINT32 ui32BufferCount, IMG_UINT32 ui32OEMFlags, IMG_UINT32 *pui32SwapChainID, #if defined (SUPPORT_SID_INTERFACE) IMG_SID *phSwapChain #else IMG_HANDLE *phSwapChain #endif ); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVDestroyDCSwapChain (IMG_HANDLE hDevice, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hSwapChain #else IMG_HANDLE hSwapChain #endif ); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVSetDCDstRect (IMG_HANDLE hDevice, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hSwapChain, #else IMG_HANDLE hSwapChain, #endif IMG_RECT *psDstRect); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVSetDCSrcRect (IMG_HANDLE hDevice, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hSwapChain, #else IMG_HANDLE hSwapChain, #endif IMG_RECT *psSrcRect); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVSetDCDstColourKey (IMG_HANDLE hDevice, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hSwapChain, #else IMG_HANDLE hSwapChain, #endif IMG_UINT32 ui32CKColour); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVSetDCSrcColourKey (IMG_HANDLE hDevice, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hSwapChain, #else IMG_HANDLE hSwapChain, #endif IMG_UINT32 ui32CKColour); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVGetDCBuffers(IMG_HANDLE hDevice, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hSwapChain, IMG_SID *phBuffer #else IMG_HANDLE hSwapChain, IMG_HANDLE *phBuffer #endif ); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVGetDCBuffers2(IMG_HANDLE hDevice, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hSwapChain, IMG_SID *phBuffer, #else IMG_HANDLE hSwapChain, IMG_HANDLE *phBuffer, #endif IMG_SYS_PHYADDR *psPhyAddr); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVSwapToDCBuffer (IMG_HANDLE hDevice, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hBuffer, #else IMG_HANDLE hBuffer, #endif IMG_UINT32 ui32ClipRectCount, IMG_RECT *psClipRect, IMG_UINT32 ui32SwapInterval, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hPrivateTag #else IMG_HANDLE hPrivateTag #endif ); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVSwapToDCBuffer2 (IMG_HANDLE hDevice, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hBuffer, #else IMG_HANDLE hBuffer, #endif IMG_UINT32 ui32SwapInterval, PVRSRV_CLIENT_MEM_INFO **ppsMemInfos, IMG_UINT32 ui32NumMemInfos, IMG_PVOID pvPrivData, IMG_UINT32 ui32PrivDataLength); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVSwapToDCSystem (IMG_HANDLE hDevice, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hSwapChain #else IMG_HANDLE hSwapChain #endif ); IMG_IMPORT IMG_HANDLE IMG_CALLCONV PVRSRVOpenBCDevice(IMG_CONST PVRSRV_DEV_DATA *psDevData, IMG_UINT32 ui32DeviceID); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVCloseBCDevice(IMG_CONST PVRSRV_CONNECTION *psConnection, IMG_HANDLE hDevice); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVGetBCBufferInfo(IMG_HANDLE hDevice, BUFFER_INFO *psBuffer); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVGetBCBuffer(IMG_HANDLE hDevice, IMG_UINT32 ui32BufferIndex, #if defined (SUPPORT_SID_INTERFACE) IMG_SID *phBuffer #else IMG_HANDLE *phBuffer #endif ); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVPDumpInit(IMG_CONST PVRSRV_CONNECTION *psConnection); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVPDumpStartInitPhase(IMG_CONST PVRSRV_CONNECTION *psConnection); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVPDumpStopInitPhase(IMG_CONST PVRSRV_CONNECTION *psConnection); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVPDumpMemPol(IMG_CONST PVRSRV_CONNECTION *psConnection, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hKernelMemInfo, #else PVRSRV_CLIENT_MEM_INFO *psMemInfo, #endif IMG_UINT32 ui32Offset, IMG_UINT32 ui32Value, IMG_UINT32 ui32Mask, PDUMP_POLL_OPERATOR eOperator, IMG_UINT32 ui32Flags); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVPDumpSyncPol(IMG_CONST PVRSRV_CONNECTION *psConnection, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hKernelSyncInfo, #else PVRSRV_CLIENT_SYNC_INFO *psClientSyncInfo, #endif IMG_BOOL bIsRead, IMG_UINT32 ui32Value, IMG_UINT32 ui32Mask); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVPDumpSyncPol2(IMG_CONST PVRSRV_CONNECTION *psConnection, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hKernelSyncInfo, #else PVRSRV_CLIENT_SYNC_INFO *psClientSyncInfo, #endif IMG_BOOL bIsRead); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVPDumpMem(IMG_CONST PVRSRV_CONNECTION *psConnection, IMG_PVOID pvAltLinAddr, PVRSRV_CLIENT_MEM_INFO *psMemInfo, IMG_UINT32 ui32Offset, IMG_UINT32 ui32Bytes, IMG_UINT32 ui32Flags); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVPDumpSync(IMG_CONST PVRSRV_CONNECTION *psConnection, IMG_PVOID pvAltLinAddr, PVRSRV_CLIENT_SYNC_INFO *psClientSyncInfo, IMG_UINT32 ui32Offset, IMG_UINT32 ui32Bytes); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVPDumpReg(IMG_CONST PVRSRV_DEV_DATA *psDevData, IMG_CHAR *pszRegRegion, IMG_UINT32 ui32RegAddr, IMG_UINT32 ui32RegValue, IMG_UINT32 ui32Flags); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVPDumpRegPolWithFlags(const PVRSRV_DEV_DATA *psDevData, IMG_CHAR *pszRegRegion, IMG_UINT32 ui32RegAddr, IMG_UINT32 ui32RegValue, IMG_UINT32 ui32Mask, IMG_UINT32 ui32Flags); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVPDumpRegPol(const PVRSRV_DEV_DATA *psDevData, IMG_CHAR *pszRegRegion, IMG_UINT32 ui32RegAddr, IMG_UINT32 ui32RegValue, IMG_UINT32 ui32Mask); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVPDumpPDReg(IMG_CONST PVRSRV_CONNECTION *psConnection, IMG_UINT32 ui32RegAddr, IMG_UINT32 ui32RegValue); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVPDumpPDDevPAddr(IMG_CONST PVRSRV_CONNECTION *psConnection, PVRSRV_CLIENT_MEM_INFO *psMemInfo, IMG_UINT32 ui32Offset, IMG_DEV_PHYADDR sPDDevPAddr); #if !defined(USE_CODE) IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVPDumpMemPages(IMG_CONST PVRSRV_DEV_DATA *psDevData, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hKernelMemInfo, #else IMG_HANDLE hKernelMemInfo, #endif IMG_DEV_PHYADDR *pPages, IMG_UINT32 ui32NumPages, IMG_DEV_VIRTADDR sDevVAddr, IMG_UINT32 ui32Start, IMG_UINT32 ui32Length, IMG_UINT32 ui32Flags); #endif IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVPDumpSetFrame(IMG_CONST PVRSRV_CONNECTION *psConnection, IMG_UINT32 ui32Frame); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVPDumpComment(IMG_CONST PVRSRV_CONNECTION *psConnection, IMG_CONST IMG_CHAR *pszComment, IMG_BOOL bContinuous); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVPDumpCommentf(IMG_CONST PVRSRV_CONNECTION *psConnection, IMG_BOOL bContinuous, IMG_CONST IMG_CHAR *pszFormat, ...) #if !defined(USE_CODE) IMG_FORMAT_PRINTF(3, 4) #endif ; IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVPDumpCommentWithFlagsf(IMG_CONST PVRSRV_CONNECTION *psConnection, IMG_UINT32 ui32Flags, IMG_CONST IMG_CHAR *pszFormat, ...) #if !defined(USE_CODE) IMG_FORMAT_PRINTF(3, 4) #endif ; IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVPDumpDriverInfo(IMG_CONST PVRSRV_CONNECTION *psConnection, IMG_CHAR *pszString, IMG_BOOL bContinuous); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVPDumpIsCapturing(IMG_CONST PVRSRV_CONNECTION *psConnection, IMG_BOOL *pbIsCapturing); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVPDumpBitmap(IMG_CONST PVRSRV_DEV_DATA *psDevData, IMG_CHAR *pszFileName, IMG_UINT32 ui32FileOffset, IMG_UINT32 ui32Width, IMG_UINT32 ui32Height, IMG_UINT32 ui32StrideInBytes, IMG_DEV_VIRTADDR sDevBaseAddr, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hDevMemContext, #else IMG_HANDLE hDevMemContext, #endif IMG_UINT32 ui32Size, PDUMP_PIXEL_FORMAT ePixelFormat, PDUMP_MEM_FORMAT eMemFormat, IMG_UINT32 ui32PDumpFlags); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVPDumpRegRead(IMG_CONST PVRSRV_DEV_DATA *psDevData, IMG_CONST IMG_CHAR *pszRegRegion, IMG_CONST IMG_CHAR *pszFileName, IMG_UINT32 ui32FileOffset, IMG_UINT32 ui32Address, IMG_UINT32 ui32Size, IMG_UINT32 ui32PDumpFlags); IMG_IMPORT IMG_BOOL IMG_CALLCONV PVRSRVPDumpIsCapturingTest(IMG_CONST PVRSRV_CONNECTION *psConnection); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVPDumpCycleCountRegRead(IMG_CONST PVRSRV_DEV_DATA *psDevData, IMG_UINT32 ui32RegOffset, IMG_BOOL bLastFrame); IMG_IMPORT IMG_HANDLE PVRSRVLoadLibrary(const IMG_CHAR *pszLibraryName); IMG_IMPORT PVRSRV_ERROR PVRSRVUnloadLibrary(IMG_HANDLE hExtDrv); IMG_IMPORT PVRSRV_ERROR PVRSRVGetLibFuncAddr(IMG_HANDLE hExtDrv, const IMG_CHAR *pszFunctionName, IMG_VOID **ppvFuncAddr); IMG_IMPORT IMG_UINT32 PVRSRVClockus (void); IMG_IMPORT IMG_VOID PVRSRVWaitus (IMG_UINT32 ui32Timeus); IMG_IMPORT IMG_VOID PVRSRVReleaseThreadQuanta (void); IMG_IMPORT IMG_UINT32 IMG_CALLCONV PVRSRVGetCurrentProcessID(void); IMG_IMPORT IMG_CHAR * IMG_CALLCONV PVRSRVSetLocale(const IMG_CHAR *pszLocale); IMG_IMPORT IMG_VOID IMG_CALLCONV PVRSRVCreateAppHintState(IMG_MODULE_ID eModuleID, const IMG_CHAR *pszAppName, IMG_VOID **ppvState); IMG_IMPORT IMG_VOID IMG_CALLCONV PVRSRVFreeAppHintState(IMG_MODULE_ID eModuleID, IMG_VOID *pvHintState); IMG_IMPORT IMG_BOOL IMG_CALLCONV PVRSRVGetAppHint(IMG_VOID *pvHintState, const IMG_CHAR *pszHintName, IMG_DATA_TYPE eDataType, const IMG_VOID *pvDefault, IMG_VOID *pvReturn); IMG_IMPORT IMG_PVOID IMG_CALLCONV PVRSRVAllocUserModeMem (IMG_SIZE_T ui32Size); IMG_IMPORT IMG_PVOID IMG_CALLCONV PVRSRVCallocUserModeMem (IMG_SIZE_T ui32Size); IMG_IMPORT IMG_PVOID IMG_CALLCONV PVRSRVReallocUserModeMem (IMG_PVOID pvBase, IMG_SIZE_T uNewSize); IMG_IMPORT IMG_VOID IMG_CALLCONV PVRSRVFreeUserModeMem (IMG_PVOID pvMem); IMG_IMPORT IMG_VOID PVRSRVMemCopy(IMG_VOID *pvDst, const IMG_VOID *pvSrc, IMG_SIZE_T ui32Size); IMG_IMPORT IMG_VOID PVRSRVMemSet(IMG_VOID *pvDest, IMG_UINT8 ui8Value, IMG_SIZE_T ui32Size); struct _PVRSRV_MUTEX_OPAQUE_STRUCT_; typedef struct _PVRSRV_MUTEX_OPAQUE_STRUCT_ *PVRSRV_MUTEX_HANDLE; IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVCreateMutex(PVRSRV_MUTEX_HANDLE *phMutex); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVDestroyMutex(PVRSRV_MUTEX_HANDLE hMutex); IMG_IMPORT IMG_VOID IMG_CALLCONV PVRSRVLockMutex(PVRSRV_MUTEX_HANDLE hMutex); IMG_IMPORT IMG_VOID IMG_CALLCONV PVRSRVUnlockMutex(PVRSRV_MUTEX_HANDLE hMutex); IMG_IMPORT IMG_VOID IMG_CALLCONV PVRSRVLockProcessGlobalMutex(void); IMG_IMPORT IMG_VOID IMG_CALLCONV PVRSRVUnlockProcessGlobalMutex(void); struct _PVRSRV_SEMAPHORE_OPAQUE_STRUCT_; typedef struct _PVRSRV_SEMAPHORE_OPAQUE_STRUCT_ *PVRSRV_SEMAPHORE_HANDLE; #define IMG_SEMAPHORE_WAIT_INFINITE ((IMG_UINT64)0xFFFFFFFFFFFFFFFFull) #if !defined(USE_CODE) #ifdef INLINE_IS_PRAGMA #pragma inline(PVRSRVCreateSemaphore) #endif static INLINE PVRSRV_ERROR PVRSRVCreateSemaphore(PVRSRV_SEMAPHORE_HANDLE *phSemaphore, IMG_INT iInitialCount) { PVR_UNREFERENCED_PARAMETER(iInitialCount); *phSemaphore = 0; return PVRSRV_OK; } #ifdef INLINE_IS_PRAGMA #pragma inline(PVRSRVDestroySemaphore) #endif static INLINE PVRSRV_ERROR PVRSRVDestroySemaphore(PVRSRV_SEMAPHORE_HANDLE hSemaphore) { PVR_UNREFERENCED_PARAMETER(hSemaphore); return PVRSRV_OK; } #ifdef INLINE_IS_PRAGMA #pragma inline(PVRSRVWaitSemaphore) #endif static INLINE PVRSRV_ERROR PVRSRVWaitSemaphore(PVRSRV_SEMAPHORE_HANDLE hSemaphore, IMG_UINT64 ui64TimeoutMicroSeconds) { PVR_UNREFERENCED_PARAMETER(hSemaphore); PVR_UNREFERENCED_PARAMETER(ui64TimeoutMicroSeconds); return PVRSRV_ERROR_INVALID_PARAMS; } #ifdef INLINE_IS_PRAGMA #pragma inline(PVRSRVPostSemaphore) #endif static INLINE IMG_VOID PVRSRVPostSemaphore(PVRSRV_SEMAPHORE_HANDLE hSemaphore, IMG_INT iPostCount) { PVR_UNREFERENCED_PARAMETER(hSemaphore); PVR_UNREFERENCED_PARAMETER(iPostCount); } #endif #if (defined(DEBUG) && defined(__linux__)) IMG_IMPORT IMG_PVOID IMG_CALLCONV PVRSRVAllocUserModeMemTracking(IMG_SIZE_T ui32Size, IMG_CHAR *pszFileName, IMG_UINT32 ui32LineNumber); IMG_IMPORT IMG_PVOID IMG_CALLCONV PVRSRVCallocUserModeMemTracking(IMG_SIZE_T ui32Size, IMG_CHAR *pszFileName, IMG_UINT32 ui32LineNumber); IMG_IMPORT IMG_VOID IMG_CALLCONV PVRSRVFreeUserModeMemTracking(IMG_VOID *pvMem); IMG_IMPORT IMG_PVOID IMG_CALLCONV PVRSRVReallocUserModeMemTracking(IMG_VOID *pvMem, IMG_SIZE_T ui32NewSize, IMG_CHAR *pszFileName, IMG_UINT32 ui32LineNumber); #endif IMG_IMPORT PVRSRV_ERROR PVRSRVEventObjectWait(const PVRSRV_CONNECTION *psConnection, #if defined (SUPPORT_SID_INTERFACE) IMG_EVENTSID hOSEvent #else IMG_HANDLE hOSEvent #endif ); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVCreateSyncInfoModObj(const PVRSRV_CONNECTION *psConnection, #if defined (SUPPORT_SID_INTERFACE) IMG_SID *phKernelSyncInfoModObj #else IMG_HANDLE *phKernelSyncInfoModObj #endif ); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVDestroySyncInfoModObj(const PVRSRV_CONNECTION *psConnection, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hKernelSyncInfoModObj #else IMG_HANDLE hKernelSyncInfoModObj #endif ); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVModifyPendingSyncOps(const PVRSRV_CONNECTION *psConnection, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hKernelSyncInfoModObj, #else IMG_HANDLE hKernelSyncInfoModObj, #endif PVRSRV_CLIENT_SYNC_INFO *psSyncInfo, IMG_UINT32 ui32ModifyFlags, IMG_UINT32 *pui32ReadOpsPending, IMG_UINT32 *pui32WriteOpsPending); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVModifyCompleteSyncOps(const PVRSRV_CONNECTION *psConnection, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hKernelSyncInfoModObj #else IMG_HANDLE hKernelSyncInfoModObj #endif ); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVSyncOpsTakeToken(const PVRSRV_CONNECTION *psConnection, #if defined (SUPPORT_SID_INTERFACE) const IMG_SID hKernelSyncInfo, #else const PVRSRV_CLIENT_SYNC_INFO *psSyncInfo, #endif PVRSRV_SYNC_TOKEN *psSyncToken); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVSyncOpsFlushToToken(const PVRSRV_CONNECTION *psConnection, #if defined (SUPPORT_SID_INTERFACE) const IMG_SID hKernelSyncInfo, #else const PVRSRV_CLIENT_SYNC_INFO *psSyncInfo, #endif const PVRSRV_SYNC_TOKEN *psSyncToken, IMG_BOOL bWait); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVSyncOpsFlushToModObj(const PVRSRV_CONNECTION *psConnection, #if defined (SUPPORT_SID_INTERFACE) IMG_SID hKernelSyncInfoModObj, #else IMG_HANDLE hKernelSyncInfoModObj, #endif IMG_BOOL bWait); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVSyncOpsFlushToDelta(const PVRSRV_CONNECTION *psConnection, PVRSRV_CLIENT_SYNC_INFO *psClientSyncInfo, IMG_UINT32 ui32Delta, IMG_BOOL bWait); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVAllocSyncInfo(IMG_CONST PVRSRV_DEV_DATA *psDevData, PVRSRV_CLIENT_SYNC_INFO **ppsSyncInfo); IMG_IMPORT PVRSRV_ERROR IMG_CALLCONV PVRSRVFreeSyncInfo(IMG_CONST PVRSRV_DEV_DATA *psDevData, PVRSRV_CLIENT_SYNC_INFO *psSyncInfo); IMG_IMPORT const IMG_CHAR *PVRSRVGetErrorString(PVRSRV_ERROR eError); #define TIME_NOT_PASSED_UINT32(a,b,c) (((a) - (b)) < (c)) #if defined (__cplusplus) } #endif #endif