b9a21c3c91c47e090316e28d759194e46628ed49vboxsync/**************************************************************************
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncCopyright 1998-1999 Precision Insight, Inc., Cedar Park, Texas.
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncAll Rights Reserved.
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncPermission is hereby granted, free of charge, to any person obtaining a
b9a21c3c91c47e090316e28d759194e46628ed49vboxsynccopy of this software and associated documentation files (the
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync"Software"), to deal in the Software without restriction, including
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncwithout limitation the rights to use, copy, modify, merge, publish,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncdistribute, sub license, and/or sell copies of the Software, and to
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncpermit persons to whom the Software is furnished to do so, subject to
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncthe following conditions:
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncThe above copyright notice and this permission notice (including the
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncnext paragraph) shall be included in all copies or substantial portions
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncof the Software.
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncTHE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncOR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncMERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncIN NO EVENT SHALL PRECISION INSIGHT AND/OR ITS SUPPLIERS BE LIABLE FOR
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncTORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncSOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync**************************************************************************/
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync/*
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync * Authors:
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync * Jens Owen <jens@tungstengraphics.com>
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync *
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync */
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync/* Prototypes for DRI functions */
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync#ifndef _DRI_H_
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync#include <pciaccess.h>
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync#include "scrnintstr.h"
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync#include "xf86dri.h"
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsynctypedef int DRISyncType;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync#define DRI_NO_SYNC 0
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync#define DRI_2D_SYNC 1
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync#define DRI_3D_SYNC 2
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsynctypedef int DRIContextType;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsynctypedef struct _DRIContextPrivRec DRIContextPrivRec, *DRIContextPrivPtr;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsynctypedef enum _DRIContextFlags
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync{
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync DRI_CONTEXT_2DONLY = 0x01,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync DRI_CONTEXT_PRESERVED = 0x02,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync DRI_CONTEXT_RESERVED = 0x04 /* DRI Only -- no kernel equivalent */
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync} DRIContextFlags;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync#define DRI_NO_CONTEXT 0
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync#define DRI_2D_CONTEXT 1
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync#define DRI_3D_CONTEXT 2
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsynctypedef int DRISwapMethod;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync#define DRI_HIDE_X_CONTEXT 0
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync#define DRI_SERVER_SWAP 1
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync#define DRI_KERNEL_SWAP 2
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsynctypedef int DRIWindowRequests;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync#define DRI_NO_WINDOWS 0
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync#define DRI_3D_WINDOWS_ONLY 1
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync#define DRI_ALL_WINDOWS 2
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsynctypedef void (*ClipNotifyPtr)( WindowPtr, int, int );
b9a21c3c91c47e090316e28d759194e46628ed49vboxsynctypedef void (*AdjustFramePtr)(int scrnIndex, int x, int y, int flags);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync/*
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync * These functions can be wrapped by the DRI. Each of these have
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync * generic default funcs (initialized in DRICreateInfoRec) and can be
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync * overridden by the driver in its [driver]DRIScreenInit function.
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync */
b9a21c3c91c47e090316e28d759194e46628ed49vboxsynctypedef struct {
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync ScreenWakeupHandlerProcPtr WakeupHandler;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync ScreenBlockHandlerProcPtr BlockHandler;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync WindowExposuresProcPtr WindowExposures;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync CopyWindowProcPtr CopyWindow;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync ValidateTreeProcPtr ValidateTree;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync PostValidateTreeProcPtr PostValidateTree;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync ClipNotifyProcPtr ClipNotify;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync AdjustFramePtr AdjustFrame;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync} DRIWrappedFuncsRec, *DRIWrappedFuncsPtr;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync/*
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync * Prior to Xorg 6.8.99.8, the DRIInfoRec structure was implicitly versioned
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync * by the XF86DRI_*_VERSION defines in xf86dristr.h. These numbers were also
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync * being used to version the XFree86-DRI protocol. Bugs #3066 and #3163
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync * showed that this was inadequate. The DRIInfoRec structure is now versioned
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync * by the DRIINFO_*_VERSION defines in this file. - ajax, 2005-05-18.
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync *
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync * Revision history:
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync * 4.1.0 and earlier: DRIQueryVersion returns XF86DRI_*_VERSION.
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync * 4.2.0: DRIQueryVersion begins returning DRIINFO_*_VERSION.
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync * 5.0.0: frameBufferPhysicalAddress changed from CARD32 to pointer.
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync */
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync#define DRIINFO_MAJOR_VERSION 5
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync#define DRIINFO_MINOR_VERSION 4
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync#define DRIINFO_PATCH_VERSION 0
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsynctypedef unsigned long long (*DRITexOffsetStartProcPtr)(PixmapPtr pPix);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsynctypedef void (*DRITexOffsetFinishProcPtr)(PixmapPtr pPix);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsynctypedef struct {
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync /* driver call back functions
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync *
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync * New fields should be added at the end for backwards compatibility.
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync * Bump the DRIINFO patch number to indicate bugfixes.
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync * Bump the DRIINFO minor number to indicate new fields.
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync * Bump the DRIINFO major number to indicate binary-incompatible changes.
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync */
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync Bool (*CreateContext)(ScreenPtr pScreen,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync VisualPtr visual,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync drm_context_t hHWContext,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync void* pVisualConfigPriv,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync DRIContextType context);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync void (*DestroyContext)(ScreenPtr pScreen,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync drm_context_t hHWContext,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync DRIContextType context);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync void (*SwapContext)(ScreenPtr pScreen,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync DRISyncType syncType,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync DRIContextType readContextType,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync void* readContextStore,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync DRIContextType writeContextType,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync void* writeContextStore);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync void (*InitBuffers)(WindowPtr pWin,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync RegionPtr prgn,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync CARD32 indx);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync void (*MoveBuffers)(WindowPtr pWin,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync DDXPointRec ptOldOrg,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync RegionPtr prgnSrc,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync CARD32 indx);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync void (*TransitionTo3d)(ScreenPtr pScreen);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync void (*TransitionTo2d)(ScreenPtr pScreen);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync void (*SetDrawableIndex)(WindowPtr pWin, CARD32 indx);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync Bool (*OpenFullScreen)(ScreenPtr pScreen);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync Bool (*CloseFullScreen)(ScreenPtr pScreen);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync /* wrapped functions */
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync DRIWrappedFuncsRec wrap;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync /* device info */
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync char* drmDriverName;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync char* clientDriverName;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync char* busIdString;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int ddxDriverMajorVersion;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int ddxDriverMinorVersion;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int ddxDriverPatchVersion;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync pointer frameBufferPhysicalAddress;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync long frameBufferSize;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync long frameBufferStride;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync long SAREASize;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int maxDrawableTableEntry;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int ddxDrawableTableEntry;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync long contextSize;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync DRISwapMethod driverSwapMethod;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync DRIWindowRequests bufferRequests;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int devPrivateSize;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync void* devPrivate;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync Bool createDummyCtx;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync Bool createDummyCtxPriv;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync /* New with DRI version 4.1.0 */
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync void (*TransitionSingleToMulti3D)(ScreenPtr pScreen);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync void (*TransitionMultiToSingle3D)(ScreenPtr pScreen);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync /* New with DRI version 5.1.0 */
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync void (*ClipNotify)(ScreenPtr pScreen, WindowPtr *ppWin, int num);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync /* New with DRI version 5.2.0 */
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync Bool allocSarea;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync Bool keepFDOpen;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync /* New with DRI version 5.3.0 */
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync DRITexOffsetStartProcPtr texOffsetStart;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync DRITexOffsetFinishProcPtr texOffsetFinish;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync /* New with DRI version 5.4.0 */
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int dontMapFrameBuffer;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync drm_handle_t hFrameBuffer; /* Handle to framebuffer, either
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync * mapped by DDX driver or DRI */
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync} DRIInfoRec, *DRIInfoPtr;
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT Bool DRIOpenDRMMaster(ScrnInfoPtr pScrn, unsigned long sAreaSize,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync const char *busID,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync const char *drmDriverName);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT Bool DRIScreenInit(ScreenPtr pScreen,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync DRIInfoPtr pDRIInfo,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int *pDRMFD);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT void DRICloseScreen(ScreenPtr pScreen);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT Bool DRIExtensionInit(void);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT void DRIReset(void);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT Bool DRIQueryDirectRenderingCapable(ScreenPtr pScreen,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync Bool *isCapable);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT Bool DRIOpenConnection(ScreenPtr pScreen,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync drm_handle_t * hSAREA,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync char **busIdString);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT Bool DRIAuthConnection(ScreenPtr pScreen, drm_magic_t magic);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT Bool DRICloseConnection(ScreenPtr pScreen);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT Bool DRIGetClientDriverName(ScreenPtr pScreen,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int* ddxDriverMajorVersion,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int* ddxDriverMinorVersion,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int* ddxDriverPatchVersion,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync char** clientDriverName);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT Bool DRICreateContext(ScreenPtr pScreen,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync VisualPtr visual,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync XID context,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync drm_context_t * pHWContext);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT Bool DRIDestroyContext(ScreenPtr pScreen, XID context);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT Bool DRIContextPrivDelete(pointer pResource, XID id);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT Bool DRICreateDrawable(ScreenPtr pScreen,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync ClientPtr client,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync DrawablePtr pDrawable,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync drm_drawable_t * hHWDrawable);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT Bool DRIDestroyDrawable(ScreenPtr pScreen,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync ClientPtr client,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync DrawablePtr pDrawable);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT Bool DRIDrawablePrivDelete(pointer pResource,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync XID id);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT Bool DRIGetDrawableInfo(ScreenPtr pScreen,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync DrawablePtr pDrawable,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync unsigned int* indx,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync unsigned int* stamp,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int* X,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int* Y,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int* W,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int* H,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int* numClipRects,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync drm_clip_rect_t ** pClipRects,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int* backX,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int* backY,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int* numBackClipRects,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync drm_clip_rect_t ** pBackClipRects);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT Bool DRIGetDeviceInfo(ScreenPtr pScreen,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync drm_handle_t * hFrameBuffer,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int* fbOrigin,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int* fbSize,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int* fbStride,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int* devPrivateSize,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync void** pDevPrivate);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT DRIInfoPtr DRICreateInfoRec(void);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT void DRIDestroyInfoRec(DRIInfoPtr DRIInfo);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT Bool DRIFinishScreenInit(ScreenPtr pScreen);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT void DRIWakeupHandler(pointer wakeupData,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int result,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync pointer pReadmask);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT void DRIBlockHandler(pointer blockData,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync OSTimePtr pTimeout,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync pointer pReadmask);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT void DRIDoWakeupHandler(int screenNum,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync pointer wakeupData,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync unsigned long result,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync pointer pReadmask);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT void DRIDoBlockHandler(int screenNum,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync pointer blockData,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync pointer pTimeout,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync pointer pReadmask);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT void DRISwapContext(int drmFD,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync void *oldctx,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync void *newctx);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT void *DRIGetContextStore(DRIContextPrivPtr context);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT void DRIWindowExposures(WindowPtr pWin,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync RegionPtr prgn,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync RegionPtr bsreg);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT Bool DRIDestroyWindow(WindowPtr pWin);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT void DRICopyWindow(WindowPtr pWin,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync DDXPointRec ptOldOrg,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync RegionPtr prgnSrc);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT int DRIValidateTree(WindowPtr pParent,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync WindowPtr pChild,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync VTKind kind);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT void DRIPostValidateTree(WindowPtr pParent,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync WindowPtr pChild,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync VTKind kind);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT void DRIClipNotify(WindowPtr pWin,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int dx,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int dy);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT CARD32 DRIGetDrawableIndex(WindowPtr pWin);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT void DRIPrintDrawableLock(ScreenPtr pScreen, char *msg);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT void DRILock(ScreenPtr pScreen, int flags);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT void DRIUnlock(ScreenPtr pScreen);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT DRIWrappedFuncsRec *DRIGetWrappedFuncs(ScreenPtr pScreen);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT void *DRIGetSAREAPrivate(ScreenPtr pScreen);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT unsigned int DRIGetDrawableStamp(ScreenPtr pScreen,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync CARD32 drawable_index);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT DRIContextPrivPtr DRICreateContextPriv(ScreenPtr pScreen,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync drm_context_t * pHWContext,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync DRIContextFlags flags);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT DRIContextPrivPtr DRICreateContextPrivFromHandle(ScreenPtr pScreen,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync drm_context_t hHWContext,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync DRIContextFlags flags);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT Bool DRIDestroyContextPriv(DRIContextPrivPtr pDRIContextPriv);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT drm_context_t DRIGetContext(ScreenPtr pScreen);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT void DRIQueryVersion(int *majorVersion,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int *minorVersion,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int *patchVersion);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT void DRIAdjustFrame(int scrnIndex, int x, int y, int flags);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT void DRIMoveBuffersHelper(ScreenPtr pScreen,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int dx,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int dy,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int *xdir,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync int *ydir,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync RegionPtr reg);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT char *DRICreatePCIBusID(const struct pci_device *PciInfo);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT int drmInstallSIGIOHandler(int fd, void (*f)(int, void *, void *));
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT int drmRemoveSIGIOHandler(int fd);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT int DRIMasterFD(ScrnInfoPtr pScrn);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT void *DRIMasterSareaPointer(ScrnInfoPtr pScrn);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT drm_handle_t DRIMasterSareaHandle(ScrnInfoPtr pScrn);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsyncextern _X_EXPORT void DRIGetTexOffsetFuncs(ScreenPtr pScreen,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync DRITexOffsetStartProcPtr *texOffsetStartFunc,
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync DRITexOffsetFinishProcPtr *texOffsetFinishFunc);
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync#define _DRI_H_
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync
b9a21c3c91c47e090316e28d759194e46628ed49vboxsync#endif