61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsyncextern _X_EXPORT VisualID PanoramiXTranslateVisualID(int screen, VisualID orig);
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsyncextern _X_EXPORT Bool PanoramiXCreateConnectionBlock(void);
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsyncextern _X_EXPORT PanoramiXRes *PanoramiXFindIDByScrnum(RESTYPE, XID, int);
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsyncXineramaRegisterConnectionBlockCallback(void (*func) (void));
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsyncextern _X_EXPORT int XineramaDeleteResource(void *, XID);
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync * Drivers are allowed to wrap this function. Each wrapper can decide that the
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync * two visuals are unequal, but if they are deemed equal, the wrapper must call
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync * down and return FALSE if the wrapped function does. This ensures that all
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync * layers agree that the visuals are equal. The first visual is always from
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync * screen 0.
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsynctypedef Bool (*XineramaVisualsEqualProcPtr) (VisualPtr, ScreenPtr, VisualPtr);
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsyncextern _X_EXPORT XineramaVisualsEqualProcPtr XineramaVisualsEqualPtr;
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsyncextern _X_EXPORT void XineramaGetImageData(DrawablePtr *pDrawables,
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync unsigned int format,
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync unsigned long planemask,
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsyncstatic inline void
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsyncpanoramix_setup_ids(PanoramiXRes * resource, ClientPtr client, XID base_id)
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync resource->info[j].id = FakeClientID(client->index);
61cb83a8ccd1dd7f671f31fa93c9d8b7be09b4ccvboxsync#endif /* _PANORAMIXSRV_H_ */