/********************************************************************** * * 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 _DBGDRVIF_ #define _DBGDRVIF_ #if defined(__linux__) #define FILE_DEVICE_UNKNOWN 0 #define METHOD_BUFFERED 0 #define FILE_ANY_ACCESS 0 #define CTL_CODE( DeviceType, Function, Method, Access ) (Function) #define MAKEIOCTLINDEX(i) ((i) & 0xFFF) #else #include "ioctldef.h" #endif /***************************************************************************** Stream mode stuff. *****************************************************************************/ #define DEBUG_CAPMODE_FRAMED 0x00000001UL #define DEBUG_CAPMODE_CONTINUOUS 0x00000002UL #define DEBUG_CAPMODE_HOTKEY 0x00000004UL #define DEBUG_OUTMODE_STANDARDDBG 0x00000001UL #define DEBUG_OUTMODE_MONO 0x00000002UL #define DEBUG_OUTMODE_STREAMENABLE 0x00000004UL #define DEBUG_OUTMODE_ASYNC 0x00000008UL #define DEBUG_OUTMODE_SGXVGA 0x00000010UL #define DEBUG_FLAGS_USE_NONPAGED_MEM 0x00000001UL #define DEBUG_FLAGS_NO_BUF_EXPANDSION 0x00000002UL #define DEBUG_FLAGS_ENABLESAMPLE 0x00000004UL #define DEBUG_FLAGS_READONLY 0x00000008UL #define DEBUG_FLAGS_WRITEONLY 0x00000010UL #define DEBUG_FLAGS_TEXTSTREAM 0x80000000UL /***************************************************************************** Debug level control. Only bothered with the first 12 levels, I suspect you get the idea... *****************************************************************************/ #define DEBUG_LEVEL_0 0x00000001UL #define DEBUG_LEVEL_1 0x00000003UL #define DEBUG_LEVEL_2 0x00000007UL #define DEBUG_LEVEL_3 0x0000000FUL #define DEBUG_LEVEL_4 0x0000001FUL #define DEBUG_LEVEL_5 0x0000003FUL #define DEBUG_LEVEL_6 0x0000007FUL #define DEBUG_LEVEL_7 0x000000FFUL #define DEBUG_LEVEL_8 0x000001FFUL #define DEBUG_LEVEL_9 0x000003FFUL #define DEBUG_LEVEL_10 0x000007FFUL #define DEBUG_LEVEL_11 0x00000FFFUL #define DEBUG_LEVEL_SEL0 0x00000001UL #define DEBUG_LEVEL_SEL1 0x00000002UL #define DEBUG_LEVEL_SEL2 0x00000004UL #define DEBUG_LEVEL_SEL3 0x00000008UL #define DEBUG_LEVEL_SEL4 0x00000010UL #define DEBUG_LEVEL_SEL5 0x00000020UL #define DEBUG_LEVEL_SEL6 0x00000040UL #define DEBUG_LEVEL_SEL7 0x00000080UL #define DEBUG_LEVEL_SEL8 0x00000100UL #define DEBUG_LEVEL_SEL9 0x00000200UL #define DEBUG_LEVEL_SEL10 0x00000400UL #define DEBUG_LEVEL_SEL11 0x00000800UL /***************************************************************************** IOCTL values. *****************************************************************************/ #define DEBUG_SERVICE_IOCTL_BASE 0x800UL #define DEBUG_SERVICE_CREATESTREAM CTL_CODE(FILE_DEVICE_UNKNOWN, DEBUG_SERVICE_IOCTL_BASE + 0x01, METHOD_BUFFERED, FILE_ANY_ACCESS) #define DEBUG_SERVICE_DESTROYSTREAM CTL_CODE(FILE_DEVICE_UNKNOWN, DEBUG_SERVICE_IOCTL_BASE + 0x02, METHOD_BUFFERED, FILE_ANY_ACCESS) #define DEBUG_SERVICE_GETSTREAM CTL_CODE(FILE_DEVICE_UNKNOWN, DEBUG_SERVICE_IOCTL_BASE + 0x03, METHOD_BUFFERED, FILE_ANY_ACCESS) #define DEBUG_SERVICE_WRITESTRING CTL_CODE(FILE_DEVICE_UNKNOWN, DEBUG_SERVICE_IOCTL_BASE + 0x04, METHOD_BUFFERED, FILE_ANY_ACCESS) #define DEBUG_SERVICE_READSTRING CTL_CODE(FILE_DEVICE_UNKNOWN, DEBUG_SERVICE_IOCTL_BASE + 0x05, METHOD_BUFFERED, FILE_ANY_ACCESS) #define DEBUG_SERVICE_WRITE CTL_CODE(FILE_DEVICE_UNKNOWN, DEBUG_SERVICE_IOCTL_BASE + 0x06, METHOD_BUFFERED, FILE_ANY_ACCESS) #define DEBUG_SERVICE_READ CTL_CODE(FILE_DEVICE_UNKNOWN, DEBUG_SERVICE_IOCTL_BASE + 0x07, METHOD_BUFFERED, FILE_ANY_ACCESS) #define DEBUG_SERVICE_SETDEBUGMODE CTL_CODE(FILE_DEVICE_UNKNOWN, DEBUG_SERVICE_IOCTL_BASE + 0x08, METHOD_BUFFERED, FILE_ANY_ACCESS) #define DEBUG_SERVICE_SETDEBUGOUTMODE CTL_CODE(FILE_DEVICE_UNKNOWN, DEBUG_SERVICE_IOCTL_BASE + 0x09, METHOD_BUFFERED, FILE_ANY_ACCESS) #define DEBUG_SERVICE_SETDEBUGLEVEL CTL_CODE(FILE_DEVICE_UNKNOWN, DEBUG_SERVICE_IOCTL_BASE + 0x0A, METHOD_BUFFERED, FILE_ANY_ACCESS) #define DEBUG_SERVICE_SETFRAME CTL_CODE(FILE_DEVICE_UNKNOWN, DEBUG_SERVICE_IOCTL_BASE + 0x0B, METHOD_BUFFERED, FILE_ANY_ACCESS) #define DEBUG_SERVICE_GETFRAME CTL_CODE(FILE_DEVICE_UNKNOWN, DEBUG_SERVICE_IOCTL_BASE + 0x0C, METHOD_BUFFERED, FILE_ANY_ACCESS) #define DEBUG_SERVICE_OVERRIDEMODE CTL_CODE(FILE_DEVICE_UNKNOWN, DEBUG_SERVICE_IOCTL_BASE + 0x0D, METHOD_BUFFERED, FILE_ANY_ACCESS) #define DEBUG_SERVICE_DEFAULTMODE CTL_CODE(FILE_DEVICE_UNKNOWN, DEBUG_SERVICE_IOCTL_BASE + 0x0E, METHOD_BUFFERED, FILE_ANY_ACCESS) #define DEBUG_SERVICE_GETSERVICETABLE CTL_CODE(FILE_DEVICE_UNKNOWN, DEBUG_SERVICE_IOCTL_BASE + 0x0F, METHOD_BUFFERED, FILE_ANY_ACCESS) #define DEBUG_SERVICE_WRITE2 CTL_CODE(FILE_DEVICE_UNKNOWN, DEBUG_SERVICE_IOCTL_BASE + 0x10, METHOD_BUFFERED, FILE_ANY_ACCESS) #define DEBUG_SERVICE_WRITESTRINGCM CTL_CODE(FILE_DEVICE_UNKNOWN, DEBUG_SERVICE_IOCTL_BASE + 0x11, METHOD_BUFFERED, FILE_ANY_ACCESS) #define DEBUG_SERVICE_WRITECM CTL_CODE(FILE_DEVICE_UNKNOWN, DEBUG_SERVICE_IOCTL_BASE + 0x12, METHOD_BUFFERED, FILE_ANY_ACCESS) #define DEBUG_SERVICE_SETMARKER CTL_CODE(FILE_DEVICE_UNKNOWN, DEBUG_SERVICE_IOCTL_BASE + 0x13, METHOD_BUFFERED, FILE_ANY_ACCESS) #define DEBUG_SERVICE_GETMARKER CTL_CODE(FILE_DEVICE_UNKNOWN, DEBUG_SERVICE_IOCTL_BASE + 0x14, METHOD_BUFFERED, FILE_ANY_ACCESS) #define DEBUG_SERVICE_ISCAPTUREFRAME CTL_CODE(FILE_DEVICE_UNKNOWN, DEBUG_SERVICE_IOCTL_BASE + 0x15, METHOD_BUFFERED, FILE_ANY_ACCESS) #define DEBUG_SERVICE_WRITELF CTL_CODE(FILE_DEVICE_UNKNOWN, DEBUG_SERVICE_IOCTL_BASE + 0x16, METHOD_BUFFERED, FILE_ANY_ACCESS) #define DEBUG_SERVICE_READLF CTL_CODE(FILE_DEVICE_UNKNOWN, DEBUG_SERVICE_IOCTL_BASE + 0x17, METHOD_BUFFERED, FILE_ANY_ACCESS) #define DEBUG_SERVICE_WAITFOREVENT CTL_CODE(FILE_DEVICE_UNKNOWN, DEBUG_SERVICE_IOCTL_BASE + 0x18, METHOD_BUFFERED, FILE_ANY_ACCESS) #define DEBUG_SERVICE_SETCONNNOTIFY CTL_CODE(FILE_DEVICE_UNKNOWN, DEBUG_SERVICE_IOCTL_BASE + 0x19, METHOD_BUFFERED, FILE_ANY_ACCESS) typedef enum _DBG_EVENT_ { DBG_EVENT_STREAM_DATA = 1 } DBG_EVENT; /***************************************************************************** In/Out Structures *****************************************************************************/ typedef struct _DBG_IN_CREATESTREAM_ { union { IMG_CHAR *pszName; IMG_UINT64 ui64Name; } u; IMG_UINT32 ui32Pages; IMG_UINT32 ui32CapMode; IMG_UINT32 ui32OutMode; }DBG_IN_CREATESTREAM, *PDBG_IN_CREATESTREAM; typedef struct _DBG_IN_FINDSTREAM_ { union { IMG_CHAR *pszName; IMG_UINT64 ui64Name; }u; IMG_BOOL bResetStream; }DBG_IN_FINDSTREAM, *PDBG_IN_FINDSTREAM; typedef struct _DBG_IN_WRITESTRING_ { union { IMG_CHAR *pszString; IMG_UINT64 ui64String; } u; IMG_SID hStream; IMG_UINT32 ui32Level; }DBG_IN_WRITESTRING, *PDBG_IN_WRITESTRING; typedef struct _DBG_IN_READSTRING_ { union { IMG_CHAR *pszString; IMG_UINT64 ui64String; } u; IMG_SID hStream; IMG_UINT32 ui32StringLen; } DBG_IN_READSTRING, *PDBG_IN_READSTRING; typedef struct _DBG_IN_SETDEBUGMODE_ { IMG_SID hStream; IMG_UINT32 ui32Mode; IMG_UINT32 ui32Start; IMG_UINT32 ui32End; IMG_UINT32 ui32SampleRate; } DBG_IN_SETDEBUGMODE, *PDBG_IN_SETDEBUGMODE; typedef struct _DBG_IN_SETDEBUGOUTMODE_ { IMG_SID hStream; IMG_UINT32 ui32Mode; } DBG_IN_SETDEBUGOUTMODE, *PDBG_IN_SETDEBUGOUTMODE; typedef struct _DBG_IN_SETDEBUGLEVEL_ { IMG_SID hStream; IMG_UINT32 ui32Level; } DBG_IN_SETDEBUGLEVEL, *PDBG_IN_SETDEBUGLEVEL; typedef struct _DBG_IN_SETFRAME_ { IMG_SID hStream; IMG_UINT32 ui32Frame; } DBG_IN_SETFRAME, *PDBG_IN_SETFRAME; typedef struct _DBG_IN_WRITE_ { union { IMG_UINT8 *pui8InBuffer; IMG_UINT64 ui64InBuffer; } u; IMG_SID hStream; IMG_UINT32 ui32Level; IMG_UINT32 ui32TransferSize; } DBG_IN_WRITE, *PDBG_IN_WRITE; typedef struct _DBG_IN_READ_ { union { IMG_UINT8 *pui8OutBuffer; IMG_UINT64 ui64OutBuffer; } u; IMG_SID hStream; IMG_BOOL bReadInitBuffer; IMG_UINT32 ui32OutBufferSize; } DBG_IN_READ, *PDBG_IN_READ; typedef struct _DBG_IN_OVERRIDEMODE_ { IMG_SID hStream; IMG_UINT32 ui32Mode; } DBG_IN_OVERRIDEMODE, *PDBG_IN_OVERRIDEMODE; typedef struct _DBG_IN_ISCAPTUREFRAME_ { IMG_SID hStream; IMG_BOOL bCheckPreviousFrame; } DBG_IN_ISCAPTUREFRAME, *PDBG_IN_ISCAPTUREFRAME; typedef struct _DBG_IN_SETMARKER_ { IMG_SID hStream; IMG_UINT32 ui32Marker; } DBG_IN_SETMARKER, *PDBG_IN_SETMARKER; typedef struct _DBG_IN_WRITE_LF_ { union { IMG_UINT8 *pui8InBuffer; IMG_UINT64 ui64InBuffer; } u; IMG_UINT32 ui32Flags; IMG_SID hStream; IMG_UINT32 ui32Level; IMG_UINT32 ui32BufferSize; } DBG_IN_WRITE_LF, *PDBG_IN_WRITE_LF; /* Flags for above struct */ #define WRITELF_FLAGS_RESETBUF 0x00000001UL /* Common control structure (don't duplicate control in main stream and init phase stream). */ typedef struct _DBG_STREAM_CONTROL_ { IMG_BOOL bInitPhaseComplete; /*!< init phase has finished */ IMG_UINT32 ui32Flags; /*!< flags (see DEBUG_FLAGS above) */ IMG_UINT32 ui32CapMode; /*!< capturing mode framed/hot key */ IMG_UINT32 ui32OutMode; /*!< output mode, e.g. files */ IMG_UINT32 ui32DebugLevel; IMG_UINT32 ui32DefaultMode; IMG_UINT32 ui32Start; /*!< first capture frame */ IMG_UINT32 ui32End; /*!< last frame */ IMG_UINT32 ui32Current; /*!< current frame */ IMG_UINT32 ui32SampleRate; /*!< capture frequency */ IMG_UINT32 ui32Reserved; } DBG_STREAM_CONTROL, *PDBG_STREAM_CONTROL; /* Per-buffer control structure. */ typedef struct _DBG_STREAM_ { struct _DBG_STREAM_ *psNext; struct _DBG_STREAM_ *psInitStream; DBG_STREAM_CONTROL *psCtrl; IMG_BOOL bCircularAllowed; IMG_PVOID pvBase; IMG_UINT32 ui32Size; IMG_UINT32 ui32RPtr; IMG_UINT32 ui32WPtr; IMG_UINT32 ui32DataWritten; IMG_UINT32 ui32Marker; /*!< marker for file splitting */ IMG_UINT32 ui32InitPhaseWOff; /*!< snapshot offset for init phase end for follow-on pdump */ IMG_CHAR szName[30]; /* Give this a size, some compilers don't like [] */ } DBG_STREAM,*PDBG_STREAM; /* * Allows dbgdrv to notify services when events happen, e.g. pdump.exe starts. * (better than resetting psDevInfo->psKernelCCBInfo->ui32CCBDumpWOff = 0 * in SGXGetClientInfoKM.) */ typedef struct _DBGKM_CONNECT_NOTIFIER_ { IMG_VOID (IMG_CALLCONV *pfnConnectNotifier) (IMG_VOID); } DBGKM_CONNECT_NOTIFIER, *PDBGKM_CONNECT_NOTIFIER; /***************************************************************************** Kernel mode service table *****************************************************************************/ typedef struct _DBGKM_SERVICE_TABLE_ { IMG_UINT32 ui32Size; IMG_VOID * (IMG_CALLCONV *pfnCreateStream) (IMG_CHAR * pszName,IMG_UINT32 ui32CapMode,IMG_UINT32 ui32OutMode,IMG_UINT32 ui32Flags,IMG_UINT32 ui32Pages); IMG_VOID (IMG_CALLCONV *pfnDestroyStream) (PDBG_STREAM psStream); IMG_VOID * (IMG_CALLCONV *pfnFindStream) (IMG_CHAR * pszName, IMG_BOOL bResetInitBuffer); IMG_UINT32 (IMG_CALLCONV *pfnWriteString) (PDBG_STREAM psStream,IMG_CHAR * pszString,IMG_UINT32 ui32Level); IMG_UINT32 (IMG_CALLCONV *pfnReadString) (PDBG_STREAM psStream,IMG_CHAR * pszString,IMG_UINT32 ui32Limit); IMG_UINT32 (IMG_CALLCONV *pfnWriteBIN) (PDBG_STREAM psStream,IMG_UINT8 *pui8InBuf,IMG_UINT32 ui32InBuffSize,IMG_UINT32 ui32Level); IMG_UINT32 (IMG_CALLCONV *pfnReadBIN) (PDBG_STREAM psStream,IMG_BOOL bReadInitBuffer, IMG_UINT32 ui32OutBufferSize,IMG_UINT8 *pui8OutBuf); IMG_VOID (IMG_CALLCONV *pfnSetCaptureMode) (PDBG_STREAM psStream,IMG_UINT32 ui32CapMode,IMG_UINT32 ui32Start,IMG_UINT32 ui32Stop,IMG_UINT32 ui32SampleRate); IMG_VOID (IMG_CALLCONV *pfnSetOutputMode) (PDBG_STREAM psStream,IMG_UINT32 ui32OutMode); IMG_VOID (IMG_CALLCONV *pfnSetDebugLevel) (PDBG_STREAM psStream,IMG_UINT32 ui32DebugLevel); IMG_VOID (IMG_CALLCONV *pfnSetFrame) (PDBG_STREAM psStream,IMG_UINT32 ui32Frame); IMG_UINT32 (IMG_CALLCONV *pfnGetFrame) (PDBG_STREAM psStream); IMG_VOID (IMG_CALLCONV *pfnOverrideMode) (PDBG_STREAM psStream,IMG_UINT32 ui32Mode); IMG_VOID (IMG_CALLCONV *pfnDefaultMode) (PDBG_STREAM psStream); IMG_UINT32 (IMG_CALLCONV *pfnDBGDrivWrite2) (PDBG_STREAM psStream,IMG_UINT8 *pui8InBuf,IMG_UINT32 ui32InBuffSize,IMG_UINT32 ui32Level); IMG_UINT32 (IMG_CALLCONV *pfnWriteStringCM) (PDBG_STREAM psStream,IMG_CHAR * pszString,IMG_UINT32 ui32Level); IMG_UINT32 (IMG_CALLCONV *pfnWriteBINCM) (PDBG_STREAM psStream,IMG_UINT8 *pui8InBuf,IMG_UINT32 ui32InBuffSize,IMG_UINT32 ui32Level); IMG_VOID (IMG_CALLCONV *pfnSetMarker) (PDBG_STREAM psStream,IMG_UINT32 ui32Marker); IMG_UINT32 (IMG_CALLCONV *pfnGetMarker) (PDBG_STREAM psStream); IMG_VOID (IMG_CALLCONV *pfnStartInitPhase) (PDBG_STREAM psStream); IMG_VOID (IMG_CALLCONV *pfnStopInitPhase) (PDBG_STREAM psStream); IMG_BOOL (IMG_CALLCONV *pfnIsCaptureFrame) (PDBG_STREAM psStream, IMG_BOOL bCheckPreviousFrame); IMG_UINT32 (IMG_CALLCONV *pfnWriteLF) (PDBG_STREAM psStream, IMG_UINT8 *pui8InBuf, IMG_UINT32 ui32InBuffSize, IMG_UINT32 ui32Level, IMG_UINT32 ui32Flags); IMG_UINT32 (IMG_CALLCONV *pfnReadLF) (PDBG_STREAM psStream, IMG_UINT32 ui32OutBuffSize, IMG_UINT8 *pui8OutBuf); IMG_UINT32 (IMG_CALLCONV *pfnGetStreamOffset) (PDBG_STREAM psStream); IMG_VOID (IMG_CALLCONV *pfnSetStreamOffset) (PDBG_STREAM psStream, IMG_UINT32 ui32StreamOffset); IMG_BOOL (IMG_CALLCONV *pfnIsLastCaptureFrame) (PDBG_STREAM psStream); IMG_VOID (IMG_CALLCONV *pfnWaitForEvent) (DBG_EVENT eEvent); IMG_VOID (IMG_CALLCONV *pfnSetConnectNotifier) (DBGKM_CONNECT_NOTIFIER fn_notifier); IMG_UINT32 (IMG_CALLCONV *pfnWritePersist) (PDBG_STREAM psStream,IMG_UINT8 *pui8InBuf,IMG_UINT32 ui32InBuffSize,IMG_UINT32 ui32Level); } DBGKM_SERVICE_TABLE, *PDBGKM_SERVICE_TABLE; #endif /***************************************************************************** End of file (DBGDRVIF.H) *****************************************************************************/