1 /**********************************************************************
3 * Copyright(c) 2008 Imagination Technologies Ltd. All rights reserved.
5 * This program is free software; you can redistribute it and/or modify it
6 * under the terms and conditions of the GNU General Public License,
7 * version 2, as published by the Free Software Foundation.
9 * This program is distributed in the hope it will be useful but, except
10 * as otherwise stated in writing, without any warranty; without even the
11 * implied warranty of merchantability or fitness for a particular purpose.
12 * See the GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License along with
15 * this program; if not, write to the Free Software Foundation, Inc.,
16 * 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA.
18 * The full GNU General Public License is included in this distribution in
19 * the file called "COPYING".
21 * Contact Information:
22 * Imagination Technologies Ltd. <gpl-support@imgtec.com>
23 * Home Park Estate, Kings Langley, Herts, WD4 8LZ, UK
25 ******************************************************************************/
27 #ifndef __PVR_BRIDGE_KM_H_
28 #define __PVR_BRIDGE_KM_H_
30 #include <linux/fs.h> /* for struct file */
31 #include <linux/wait.h>
32 #include <linux/sched.h>
34 #include "pvr_bridge.h"
37 extern int pvr_dvfs_active;
38 extern struct mutex gPVRSRVLock;
39 extern wait_queue_head_t pvr_dvfs_wq;
41 void pvr_dvfs_wait_active(void);
43 static inline void pvr_dvfs_lock(void)
45 mutex_lock(&gPVRSRVLock);
47 mutex_unlock(&gPVRSRVLock);
50 static inline void pvr_dvfs_unlock(void)
52 mutex_lock(&gPVRSRVLock);
54 wake_up(&pvr_dvfs_wq);
55 mutex_unlock(&gPVRSRVLock);
58 static inline void pvr_lock(void)
60 mutex_lock(&gPVRSRVLock);
62 pvr_dvfs_wait_active();
65 static inline void pvr_unlock(void)
67 mutex_unlock(&gPVRSRVLock);
70 static inline int pvr_is_locked(void)
72 return mutex_is_locked(&gPVRSRVLock);
75 enum PVRSRV_ERROR LinuxBridgeInit(void);
76 void LinuxBridgeDeInit(void);
78 enum PVRSRV_ERROR PVRSRVEnumerateDevicesKM(u32 *pui32NumDevices,
79 struct PVRSRV_DEVICE_IDENTIFIER *psDevIdList);
81 enum PVRSRV_ERROR PVRSRVAcquireDeviceDataKM(u32 uiDevIndex,
82 enum PVRSRV_DEVICE_TYPE eDeviceType,
85 enum PVRSRV_ERROR PVRSRVCreateCommandQueueKM(u32 ui32QueueSize,
86 struct PVRSRV_QUEUE_INFO **ppsQueueInfo);
88 enum PVRSRV_ERROR PVRSRVDestroyCommandQueueKM(
89 struct PVRSRV_QUEUE_INFO *psQueueInfo);
91 enum PVRSRV_ERROR PVRSRVGetDeviceMemHeapsKM(void *hDevCookie,
92 struct PVRSRV_HEAP_INFO *psHeapInfo);
94 enum PVRSRV_ERROR PVRSRVCreateDeviceMemContextKM(void *hDevCookie,
95 struct PVRSRV_PER_PROCESS_DATA *psPerProc,
96 void **phDevMemContext, u32 *pui32ClientHeapCount,
97 struct PVRSRV_HEAP_INFO *psHeapInfo, IMG_BOOL *pbCreated,
100 enum PVRSRV_ERROR PVRSRVDestroyDeviceMemContextKM(void *hDevCookie,
101 void *hDevMemContext, IMG_BOOL *pbCreated);
103 enum PVRSRV_ERROR PVRSRVGetDeviceMemHeapInfoKM(void *hDevCookie,
104 void *hDevMemContext, u32 *pui32ClientHeapCount,
105 struct PVRSRV_HEAP_INFO *psHeapInfo, IMG_BOOL *pbShared);
107 enum PVRSRV_ERROR PVRSRVAllocDeviceMemKM(void *hDevCookie,
108 struct PVRSRV_PER_PROCESS_DATA *psPerProc, void *hDevMemHeap,
109 u32 ui32Flags, u32 ui32Size, u32 ui32Alignment,
110 struct PVRSRV_KERNEL_MEM_INFO **ppsMemInfo);
112 enum PVRSRV_ERROR PVRSRVFreeDeviceMemKM(void *hDevCookie,
113 struct PVRSRV_KERNEL_MEM_INFO *psMemInfo);
115 enum PVRSRV_ERROR PVRSRVDissociateDeviceMemKM(void *hDevCookie,
116 struct PVRSRV_KERNEL_MEM_INFO *psMemInfo);
118 enum PVRSRV_ERROR PVRSRVReserveDeviceVirtualMemKM(void *hDevMemHeap,
119 struct IMG_DEV_VIRTADDR *psDevVAddr, u32 ui32Size,
120 u32 ui32Alignment, struct PVRSRV_KERNEL_MEM_INFO **ppsMemInfo);
122 enum PVRSRV_ERROR PVRSRVFreeDeviceVirtualMemKM(
123 struct PVRSRV_KERNEL_MEM_INFO *psMemInfo);
125 enum PVRSRV_ERROR PVRSRVMapDeviceMemoryKM(
126 struct PVRSRV_PER_PROCESS_DATA *psPerProc,
127 struct PVRSRV_KERNEL_MEM_INFO *psSrcMemInfo,
128 void *hDstDevMemHeap,
129 struct PVRSRV_KERNEL_MEM_INFO **ppsDstMemInfo);
131 enum PVRSRV_ERROR PVRSRVUnmapDeviceMemoryKM(
132 struct PVRSRV_KERNEL_MEM_INFO *psMemInfo);
134 enum PVRSRV_ERROR PVRSRVWrapExtMemoryKM(void *hDevCookie,
135 struct PVRSRV_PER_PROCESS_DATA *psPerProc, void *hDevMemContext,
136 u32 ui32ByteSize, u32 ui32PageOffset, IMG_BOOL bPhysContig,
137 struct IMG_SYS_PHYADDR *psSysAddr, void *pvLinAddr,
138 struct PVRSRV_KERNEL_MEM_INFO **ppsMemInfo);
140 enum PVRSRV_ERROR PVRSRVUnwrapExtMemoryKM(struct PVRSRV_KERNEL_MEM_INFO
143 enum PVRSRV_ERROR PVRSRVEnumerateDCKM(enum PVRSRV_DEVICE_CLASS DeviceClass,
144 u32 *pui32DevCount, u32 *pui32DevID);
146 enum PVRSRV_ERROR PVRSRVOpenDCDeviceKM(
147 struct PVRSRV_PER_PROCESS_DATA *psPerProc,
148 u32 ui32DeviceID, void *hDevCookie, void **phDeviceKM);
150 enum PVRSRV_ERROR PVRSRVCloseDCDeviceKM(void *hDeviceKM,
151 IMG_BOOL bResManCallback);
153 enum PVRSRV_ERROR PVRSRVEnumDCFormatsKM(void *hDeviceKM, u32 *pui32Count,
154 struct DISPLAY_FORMAT *psFormat);
156 enum PVRSRV_ERROR PVRSRVEnumDCDimsKM(void *hDeviceKM,
157 struct DISPLAY_FORMAT *psFormat, u32 *pui32Count,
158 struct DISPLAY_DIMS *psDim);
160 enum PVRSRV_ERROR PVRSRVGetDCSystemBufferKM(void *hDeviceKM, void **phBuffer);
162 enum PVRSRV_ERROR PVRSRVGetDCInfoKM(void *hDeviceKM,
163 struct DISPLAY_INFO *psDisplayInfo);
165 enum PVRSRV_ERROR PVRSRVCreateDCSwapChainKM(
166 struct PVRSRV_PER_PROCESS_DATA *psPerProc, void *hDeviceKM,
167 u32 ui32Flags, struct DISPLAY_SURF_ATTRIBUTES *psDstSurfAttrib,
168 struct DISPLAY_SURF_ATTRIBUTES *psSrcSurfAttrib,
169 u32 ui32BufferCount, u32 ui32OEMFlags, void **phSwapChain,
170 u32 *pui32SwapChainID);
172 enum PVRSRV_ERROR PVRSRVDestroyDCSwapChainKM(void *hSwapChain);
173 enum PVRSRV_ERROR PVRSRVSetDCDstRectKM(void *hDeviceKM, void *hSwapChain,
174 struct IMG_RECT *psRect);
175 enum PVRSRV_ERROR PVRSRVSetDCSrcRectKM(void *hDeviceKM, void *hSwapChain,
176 struct IMG_RECT *psRect);
177 enum PVRSRV_ERROR PVRSRVSetDCDstColourKeyKM(void *hDeviceKM, void *hSwapChain,
179 enum PVRSRV_ERROR PVRSRVSetDCSrcColourKeyKM(void *hDeviceKM, void *hSwapChain,
181 enum PVRSRV_ERROR PVRSRVGetDCBuffersKM(void *hDeviceKM, void *hSwapChain,
182 u32 *pui32BufferCount, void **phBuffer);
183 enum PVRSRV_ERROR PVRSRVSwapToDCBufferKM(void *hDeviceKM, void *hBuffer,
184 u32 ui32SwapInterval, void *hPrivateTag,
185 u32 ui32ClipRectCount, struct IMG_RECT *psClipRect);
186 enum PVRSRV_ERROR PVRSRVSwapToDCSystemKM(void *hDeviceKM, void *hSwapChain);
188 enum PVRSRV_ERROR PVRSRVOpenBCDeviceKM(
189 struct PVRSRV_PER_PROCESS_DATA *psPerProc,
190 u32 ui32DeviceID, void *hDevCookie, void **phDeviceKM);
191 enum PVRSRV_ERROR PVRSRVCloseBCDeviceKM(void *hDeviceKM,
192 IMG_BOOL bResManCallback);
194 enum PVRSRV_ERROR PVRSRVGetBCInfoKM(void *hDeviceKM,
195 struct BUFFER_INFO *psBufferInfo);
196 enum PVRSRV_ERROR PVRSRVGetBCBufferKM(void *hDeviceKM,
197 u32 ui32BufferIndex, void **phBuffer);
199 enum PVRSRV_ERROR PVRSRVMapDeviceClassMemoryKM(
200 struct PVRSRV_PER_PROCESS_DATA *psPerProc, void *hDevMemContext,
201 void *hDeviceClassBuffer,
202 struct PVRSRV_KERNEL_MEM_INFO **ppsMemInfo, void **phOSMapInfo);
204 enum PVRSRV_ERROR PVRSRVUnmapDeviceClassMemoryKM(
205 struct PVRSRV_KERNEL_MEM_INFO *psMemInfo);
207 enum PVRSRV_ERROR PVRSRVGetFreeDeviceMemKM(u32 ui32Flags, u32 *pui32Total,
208 u32 *pui32Free, u32 *pui32LargestBlock);
209 enum PVRSRV_ERROR PVRSRVAllocSyncInfoKM(void *hDevCookie, void *hDevMemContext,
210 struct PVRSRV_KERNEL_SYNC_INFO **ppsKernelSyncInfo);
211 enum PVRSRV_ERROR PVRSRVFreeSyncInfoKM(
212 struct PVRSRV_KERNEL_SYNC_INFO *psKernelSyncInfo);
214 enum PVRSRV_ERROR PVRSRVGetMiscInfoKM(struct PVRSRV_MISC_INFO *psMiscInfo);
216 enum PVRSRV_ERROR PVRSRVGetFBStatsKM(u32 *pui32Total, u32 *pui32Available);
218 enum PVRSRV_ERROR PVRSRVAllocSharedSysMemoryKM(
219 struct PVRSRV_PER_PROCESS_DATA *psPerProc, u32 ui32Flags,
220 u32 ui32Size, struct PVRSRV_KERNEL_MEM_INFO **ppsKernelMemInfo);
222 enum PVRSRV_ERROR PVRSRVFreeSharedSysMemoryKM(
223 struct PVRSRV_KERNEL_MEM_INFO *psKernelMemInfo);
225 enum PVRSRV_ERROR PVRSRVDissociateMemFromResmanKM(
226 struct PVRSRV_KERNEL_MEM_INFO *psKernelMemInfo);
228 long PVRSRV_BridgeDispatchKM(struct file *, unsigned, unsigned long);