blob: a875183431c79b08a2cb08615569c5aad987f577 [file] [log] [blame]
/* -*- mode: c; indent-tabs-mode: t; c-basic-offset: 8; tab-width: 8 -*- */
/* vi: set ts=8 sw=8 sts=8: */
/*************************************************************************/ /*!
@File services_kernel_client.h
@Copyright Copyright (c) Imagination Technologies Ltd. All Rights Reserved
@License MIT
The contents of this file are subject to the MIT license as set out below.
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.
This License is also included in this distribution in the file called
"MIT-COPYING".
EXCEPT AS OTHERWISE STATED IN A NEGOTIATED AGREEMENT: (A) THE SOFTWARE IS
PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING
BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
PURPOSE AND NONINFRINGEMENT; AND (B) IN NO EVENT SHALL THE AUTHORS OR
COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*/ /**************************************************************************/
/* This file contains a partial redefinition of the PowerVR Services 5
* interface for use by components which are checkpatch clean. This
* header is included by the unrefined, non-checkpatch clean headers
* to ensure that prototype/typedef/macro changes break the build.
*/
#ifndef __SERVICES_KERNEL_CLIENT__
#define __SERVICES_KERNEL_CLIENT__
#include "pvrsrv_error.h"
#include <linux/types.h>
#include "pvrsrv_sync_km.h"
#include "sync_checkpoint_external.h"
#ifndef __pvrsrv_defined_struct_enum__
/* rgx_fwif_shared.h */
struct _RGXFWIF_DEV_VIRTADDR_ {
__u32 ui32Addr;
};
/* sync_external.h */
struct PVRSRV_CLIENT_SYNC_PRIM {
volatile __u32 *pui32LinAddr;
};
struct PVRSRV_CLIENT_SYNC_PRIM_OP {
__u32 ui32Flags;
struct pvrsrv_sync_prim *psSync;
__u32 ui32FenceValue;
__u32 ui32UpdateValue;
};
typedef enum tag_img_bool
{
IMG_FALSE = 0,
IMG_TRUE = 1,
IMG_FORCE_ALIGN = 0x7FFFFFFF
} IMG_BOOL, *IMG_PBOOL;
#else /* __pvrsrv_defined_struct_enum__ */
struct _RGXFWIF_DEV_VIRTADDR_;
struct PVRSRV_CLIENT_SYNC_PRIM;
struct PVRSRV_CLIENT_SYNC_PRIM_OP;
enum tag_img_bool;
#endif /* __pvrsrv_defined_struct_enum__ */
struct _PMR_;
struct _PVRSRV_DEVICE_NODE_;
struct dma_buf;
struct SYNC_PRIM_CONTEXT;
/* pvr_notifier.h */
#ifndef _CMDCOMPNOTIFY_PFN_
typedef void (*PFN_CMDCOMP_NOTIFY)(void *hCmdCompHandle);
#define _CMDCOMPNOTIFY_PFN_
#endif
enum PVRSRV_ERROR PVRSRVRegisterCmdCompleteNotify(void **phNotify,
PFN_CMDCOMP_NOTIFY pfnCmdCompleteNotify, void *hPrivData);
enum PVRSRV_ERROR PVRSRVUnregisterCmdCompleteNotify(void *hNotify);
void PVRSRVCheckStatus(void *hCmdCompCallerHandle);
#define DEBUG_REQUEST_DC 0
#define DEBUG_REQUEST_SERVERSYNC 1
#define DEBUG_REQUEST_SYS 2
#define DEBUG_REQUEST_ANDROIDSYNC 3
#define DEBUG_REQUEST_LINUXFENCE 4
#define DEBUG_REQUEST_SYNCCHECKPOINT 5
#define DEBUG_REQUEST_HTB 6
#define DEBUG_REQUEST_APPHINT 7
#define DEBUG_REQUEST_FALLBACKSYNC 8
#define DEBUG_REQUEST_VERBOSITY_LOW 0
#define DEBUG_REQUEST_VERBOSITY_MEDIUM 1
#define DEBUG_REQUEST_VERBOSITY_HIGH 2
#define DEBUG_REQUEST_VERBOSITY_MAX DEBUG_REQUEST_VERBOSITY_HIGH
#ifndef _DBGNOTIFY_PFNS_
typedef void (DUMPDEBUG_PRINTF_FUNC)(void *pvDumpDebugFile,
const char *fmt, ...) __printf(2, 3);
typedef void (*PFN_DBGREQ_NOTIFY) (void *hDebugRequestHandle,
__u32 ui32VerbLevel,
DUMPDEBUG_PRINTF_FUNC *pfnDumpDebugPrintf,
void *pvDumpDebugFile);
#define _DBGNOTIFY_PFNS_
#endif
enum PVRSRV_ERROR PVRSRVRegisterDbgRequestNotify(void **phNotify,
struct _PVRSRV_DEVICE_NODE_ *psDevNode,
PFN_DBGREQ_NOTIFY pfnDbgRequestNotify,
__u32 ui32RequesterID,
void *hDbgRequestHandle);
enum PVRSRV_ERROR PVRSRVUnregisterDbgRequestNotify(void *hNotify);
/* physmem_dmabuf.h */
struct dma_buf *PhysmemGetDmaBuf(struct _PMR_ *psPMR);
/* pvrsrv.h */
enum PVRSRV_ERROR PVRSRVAcquireGlobalEventObjectKM(void **phGlobalEventObject);
enum PVRSRV_ERROR PVRSRVReleaseGlobalEventObjectKM(void *hGlobalEventObject);
/* sync.h */
enum PVRSRV_ERROR SyncPrimContextCreate(
struct _PVRSRV_DEVICE_NODE_ *psDevConnection,
struct SYNC_PRIM_CONTEXT **phSyncPrimContext);
void SyncPrimContextDestroy(struct SYNC_PRIM_CONTEXT *hSyncPrimContext);
enum PVRSRV_ERROR SyncPrimAlloc(struct SYNC_PRIM_CONTEXT *hSyncPrimContext,
struct PVRSRV_CLIENT_SYNC_PRIM **ppsSync, const char *pszClassName);
enum PVRSRV_ERROR SyncPrimFree(struct PVRSRV_CLIENT_SYNC_PRIM *psSync);
enum PVRSRV_ERROR SyncPrimGetFirmwareAddr(
struct PVRSRV_CLIENT_SYNC_PRIM *psSync,
__u32 *sync_addr);
enum PVRSRV_ERROR SyncPrimSet(struct PVRSRV_CLIENT_SYNC_PRIM *psSync,
__u32 ui32Value);
/* pdump_km.h */
#ifdef PDUMP
enum PVRSRV_ERROR __printf(1, 2) PDumpComment(char *fmt, ...);
#else
static inline enum PVRSRV_ERROR __printf(1, 2) PDumpComment(char *fmt, ...)
{
return PVRSRV_OK;
}
#endif
/* osfunc.h */
#if defined(PVRSRV_USE_BRIDGE_LOCK)
void OSAcquireBridgeLock(void);
void OSReleaseBridgeLock(void);
#endif
enum PVRSRV_ERROR OSEventObjectWait(void *hOSEventKM);
enum PVRSRV_ERROR OSEventObjectOpen(void *hEventObject, void **phOSEventKM);
enum PVRSRV_ERROR OSEventObjectClose(void *hOSEventKM);
__u32 OSGetCurrentClientProcessIDKM(void);
/* srvkm.h */
enum PVRSRV_ERROR PVRSRVDeviceCreate(void *pvOSDevice,
int i32UMIdentifier,
struct _PVRSRV_DEVICE_NODE_ **ppsDeviceNode);
enum PVRSRV_ERROR PVRSRVDeviceDestroy(
struct _PVRSRV_DEVICE_NODE_ *psDeviceNode);
const char *PVRSRVGetErrorStringKM(enum PVRSRV_ERROR eError);
/* This is the function that kick code will call in order to obtain a list of the PSYNC_CHECKPOINTs
* for a given PVRSRV_FENCE passed to a kick function.
* The OS native sync code will allocate the memory to hold the returned list of PSYNC_CHECKPOINT ptrs.
* The caller will free this memory once it has finished referencing it.
*
* Input: fence The input (check) fence
* Output: nr_checkpoints The number of PVRSRV_SYNC_CHECKPOINT ptrs returned in the
* checkpoint_handles parameter.
* Output: fence_uid Unique ID of the check fence
* Input/Output: checkpoint_handles The returned list of PVRSRV_SYNC_CHECKPOINTs.
*/
enum PVRSRV_ERROR
pvr_sync_resolve_fence(PSYNC_CHECKPOINT_CONTEXT psSyncCheckpointContext, PVRSRV_FENCE fence, u32 *nr_checkpoints, PSYNC_CHECKPOINT **checkpoint_handles, u64 *fence_uid);
#ifndef _CHECKPOINT_PFNS_
typedef PVRSRV_ERROR (*PFN_SYNC_CHECKPOINT_FENCE_RESOLVE_FN)(PSYNC_CHECKPOINT_CONTEXT psSyncCheckpointContext, PVRSRV_FENCE fence, u32 *nr_checkpoints, PSYNC_CHECKPOINT **checkpoint_handles, u64 *fence_uid);
/* This is the function that kick code will call in order to obtain a new PVRSRV_FENCE from the
* OS native sync code and the PSYNC_CHECKPOINT used in that fence.
* The OS native sync code needs to implement a function meeting this specification.
*
* Input: fence_name A string to annotate the fence with (for debug).
* Input: timeline The timeline on which the new fence is to be created.
* Output: new_fence The new PVRSRV_FENCE to be returned by the kick call.
* Output: fence_uid Unique ID of the update fence.
* Output: fence_finalise_data Pointer to data needed to finalise the fence.
* Output: new_checkpoint_handle The PSYNC_CHECKPOINT used by the new fence.
*/
enum PVRSRV_ERROR
pvr_sync_create_fence(const char *fence_name,
PVRSRV_TIMELINE timeline,
PSYNC_CHECKPOINT_CONTEXT psSyncCheckpointContext,
PVRSRV_FENCE *new_fence,
u64 *fence_uid,
void **fence_finalise_data,
PSYNC_CHECKPOINT *new_checkpoint_handle,
void **timeline_update_sync,
__u32 *timeline_update_value);
#ifndef _CHECKPOINT_PFNS_
typedef PVRSRV_ERROR (*PFN_SYNC_CHECKPOINT_FENCE_CREATE_FN)(
const char *fence_name,
PVRSRV_TIMELINE timeline,
PSYNC_CHECKPOINT_CONTEXT psSyncCheckpointContext,
PVRSRV_FENCE *new_fence,
u64 *fence_uid,
void **fence_finalise_data,
PSYNC_CHECKPOINT *new_checkpoint_handle,
void **timeline_update_sync,
__u32 *timeline_update_value);
#endif
/* This is the function that kick code will call in order to 'rollback' a created
* output fence should an error occur when submitting the kick.
* The OS native sync code needs to implement a function meeting this specification.
*
* Input: fence_to_rollback The PVRSRV_FENCE to be 'rolled back'. The fence
* should be destroyed and any actions taken due to
* its creation that need to be undone should be
* reverted.
* Input: finalise_data The finalise data for the fence to be 'rolled back'.
*/
enum PVRSRV_ERROR
pvr_sync_rollback_fence_data(PVRSRV_FENCE fence_to_rollback, void* finalise_data);
#ifndef _CHECKPOINT_PFNS_
typedef PVRSRV_ERROR (*PFN_SYNC_CHECKPOINT_FENCE_ROLLBACK_DATA_FN)(PVRSRV_FENCE fence_to_rollback, void *finalise_data);
#endif
/* This is the function that kick code will call in order to 'finalise' a created
* output fence just prior to returning from the kick function.
* The OS native sync code needs to implement a function meeting this
* specification - the implementation may be a nop if the OS does not need to
* perform any actions at this point.
*
* Input: fence_fd The PVRSRV_FENCE to be 'finalised'. This value
* will have been returned by an earlier call to
* pvr_sync_create_fence().
* Input: finalise_data The finalise data returned by an earlier call
* to pvr_sync_create_fence().
*/
enum PVRSRV_ERROR
pvr_sync_finalise_fence (PVRSRV_FENCE fence_fd, void *finalise_data);
#ifndef _CHECKPOINT_PFNS_
typedef PVRSRV_ERROR (*PFN_SYNC_CHECKPOINT_FENCE_FINALISE_FN)(PVRSRV_FENCE fence_to_finalise, void *finalise_data);
#endif
/* This is the function that driver code will call in order to request the
* sync implementation to output debug information relating to any sync
* checkpoints it may have created which appear in the provided array of
* FW addresses of Unified Fence Objects (UFOs).
*
* Input: nr_ufos The number of FW addresses provided in the
* vaddrs parameter.
* Input: vaddrs The array of FW addresses of UFOs. The sync
* implementation should check each of these to
* see if any relate to sync checkpoints it has
* created and where they do output debug information
* pertaining to the native/fallback sync with
* which it is associated.
*/
u32
pvr_sync_dump_info_on_stalled_ufos(u32 nr_ufos, u32 *vaddrs);
#ifndef _CHECKPOINT_PFNS_
typedef __u32 (*PFN_SYNC_CHECKPOINT_DUMP_INFO_ON_STALLED_UFOS_FN)(__u32 num_ufos, __u32 *vaddrs);
#endif
/* This is the function that kick code will call in a NO_HARDWARE build only after
* sync checkpoints have been manually signalled, to allow the OS native sync
* implementation to update its timelines (as the usual callback notification
* of signalled checkpoints is not supported for NO_HARDWARE).
*/
#ifndef _CHECKPOINT_PFNS_
typedef void (*PFN_SYNC_CHECKPOINT_NOHW_UPDATE_TIMELINES_FN)(void *private_data);
typedef void (*PFN_SYNC_CHECKPOINT_FREE_CHECKPOINT_LIST_MEM_FN)(void *mem_ptr);
#define _CHECKPOINT_PFNS_
#endif
enum PVRSRV_ERROR SyncCheckpointRegisterFunctions(PFN_SYNC_CHECKPOINT_FENCE_RESOLVE_FN pfnFenceResolve,
PFN_SYNC_CHECKPOINT_FENCE_CREATE_FN pfnFenceCreate,
PFN_SYNC_CHECKPOINT_FENCE_ROLLBACK_DATA_FN pfnFenceDataRollback,
PFN_SYNC_CHECKPOINT_FENCE_FINALISE_FN pfnFenceFinalise,
PFN_SYNC_CHECKPOINT_NOHW_UPDATE_TIMELINES_FN pfnNoHWUpdateTimelines,
PFN_SYNC_CHECKPOINT_FREE_CHECKPOINT_LIST_MEM_FN pfnFreeCheckpointListMem,
PFN_SYNC_CHECKPOINT_DUMP_INFO_ON_STALLED_UFOS_FN pfnDumpInfoOnStalledUFOs);
/* sync_checkpoint.h */
enum PVRSRV_ERROR SyncCheckpointContextCreate(struct _PVRSRV_DEVICE_NODE_ *psDevConnection, PSYNC_CHECKPOINT_CONTEXT *phSyncCheckpointContext);
enum PVRSRV_ERROR SyncCheckpointContextDestroy(PSYNC_CHECKPOINT_CONTEXT hSyncCheckpointContext);
enum PVRSRV_ERROR SyncCheckpointAlloc(PSYNC_CHECKPOINT_CONTEXT psSyncContext, PVRSRV_TIMELINE timeline, const char *pszCheckpointName, PSYNC_CHECKPOINT *ppsSyncCheckpoint);
void SyncCheckpointSignal(PSYNC_CHECKPOINT psSyncCheckpoint, u32 fence_sync_flags);
void SyncCheckpointError(PSYNC_CHECKPOINT psSyncCheckpoint, u32 fence_sync_flags);
enum tag_img_bool SyncCheckpointIsSignalled(PSYNC_CHECKPOINT psSyncCheckpoint, u32 fence_sync_flags);
enum tag_img_bool SyncCheckpointIsErrored(PSYNC_CHECKPOINT psSyncCheckpoint, u32 fence_sync_flags);
enum PVRSRV_ERROR SyncCheckpointTakeRef(PSYNC_CHECKPOINT psSyncCheckpoint);
enum PVRSRV_ERROR SyncCheckpointDropRef(PSYNC_CHECKPOINT psSyncCheckpoint);
void SyncCheckpointFree(PSYNC_CHECKPOINT psSyncCheckpoint);
__u32 SyncCheckpointGetFirmwareAddr(PSYNC_CHECKPOINT psSyncCheckpoint);
void SyncCheckpointCCBEnqueued(PSYNC_CHECKPOINT psSyncCheckpoint);
__u32 SyncCheckpointGetId(PSYNC_CHECKPOINT psSyncCheckpoint);
__u32 SyncCheckpointGetEnqueuedCount(PSYNC_CHECKPOINT psSyncCheckpoint);
__u32 SyncCheckpointGetReferenceCount(PSYNC_CHECKPOINT psSyncCheckpoint);
PVRSRV_TIMELINE SyncCheckpointGetTimeline(PSYNC_CHECKPOINT psSyncCheckpoint);
const char *SyncCheckpointGetStateString(PSYNC_CHECKPOINT psSyncCheckpoint);
#endif
#endif /* __SERVICES_KERNEL_CLIENT__ */