Index: third_party/libva/va/x11/va_dri2.c |
diff --git a/third_party/libva/va/x11/va_dri2.c b/third_party/libva/va/x11/va_dri2.c |
new file mode 100644 |
index 0000000000000000000000000000000000000000..1c91bca43f61bd4a49c3f3a98dd1dd0da64ed330 |
--- /dev/null |
+++ b/third_party/libva/va/x11/va_dri2.c |
@@ -0,0 +1,368 @@ |
+/* |
+ * Copyright © 2008 Red Hat, Inc. |
+ * |
+ * Permission is hereby granted, free of charge, to any person obtaining a |
+ * copy of this software and associated documentation files (the "Soft- |
+ * ware"), to deal in the Software without restriction, including without |
+ * limitation the rights to use, copy, modify, merge, publish, distribute, |
+ * and/or sell copies of the Software, and to permit persons to whom the |
+ * Software is furnished to do so, provided that the above copyright |
+ * notice(s) and this permission notice appear in all copies of the Soft- |
+ * ware and that both the above copyright notice(s) and this permission |
+ * notice appear in supporting documentation. |
+ * |
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
+ * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABIL- |
+ * ITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF THIRD PARTY |
+ * RIGHTS. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR HOLDERS INCLUDED IN |
+ * THIS NOTICE BE LIABLE FOR ANY CLAIM, OR ANY SPECIAL INDIRECT OR CONSE- |
+ * QUENTIAL DAMAGES, OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, |
+ * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER |
+ * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFOR- |
+ * MANCE OF THIS SOFTWARE. |
+ * |
+ * Except as contained in this notice, the name of a copyright holder shall |
+ * not be used in advertising or otherwise to promote the sale, use or |
+ * other dealings in this Software without prior written authorization of |
+ * the copyright holder. |
+ * |
+ * Authors: |
+ * Kristian Høgsberg (krh@redhat.com) |
+ */ |
+ |
+ |
+#define NEED_REPLIES |
+#include <X11/Xlibint.h> |
+#include <X11/extensions/Xext.h> |
+#include <X11/extensions/extutil.h> |
+#include "xf86drm.h" |
+#include "va_dri2.h" |
+#include "va_dri2str.h" |
+#include "va_dri2tokens.h" |
+ |
+#ifndef DRI2DriverDRI |
+#define DRI2DriverDRI 0 |
+#endif |
+ |
+static int |
+VA_DRI2Error(Display *dpy, xError *err, XExtCodes *codes, int *ret_code); |
+ |
+static char va_dri2ExtensionName[] = DRI2_NAME; |
+static XExtensionInfo _va_dri2_info_data; |
+static XExtensionInfo *va_dri2Info = &_va_dri2_info_data; |
+static XEXT_GENERATE_CLOSE_DISPLAY (VA_DRI2CloseDisplay, va_dri2Info) |
+static /* const */ XExtensionHooks va_dri2ExtensionHooks = { |
+ NULL, /* create_gc */ |
+ NULL, /* copy_gc */ |
+ NULL, /* flush_gc */ |
+ NULL, /* free_gc */ |
+ NULL, /* create_font */ |
+ NULL, /* free_font */ |
+ VA_DRI2CloseDisplay, /* close_display */ |
+ NULL, /* wire_to_event */ |
+ NULL, /* event_to_wire */ |
+ VA_DRI2Error, /* error */ |
+ NULL, /* error_string */ |
+}; |
+ |
+static XEXT_GENERATE_FIND_DISPLAY (DRI2FindDisplay, va_dri2Info, |
+ va_dri2ExtensionName, |
+ &va_dri2ExtensionHooks, |
+ 0, NULL) |
+ |
+static int |
+VA_DRI2Error(Display *dpy, xError *err, XExtCodes *codes, int *ret_code) |
+{ |
+ /* |
+ * If the X drawable was destroyed before the VA drawable, the DRI2 drawable |
+ * will be gone by the time we call VA_DRI2DestroyDrawable(). So, simply |
+ * ignore BadDrawable errors in that case. |
+ */ |
+ if (err->majorCode == codes->major_opcode && |
+ err->errorCode == BadDrawable && |
+ err->minorCode == X_DRI2DestroyDrawable) |
+ return True; |
+ |
+ return False; |
+} |
+ |
+Bool VA_DRI2QueryExtension(Display *dpy, int *eventBase, int *errorBase) |
+{ |
+ XExtDisplayInfo *info = DRI2FindDisplay(dpy); |
+ |
+ if (XextHasExtension(info)) { |
+ *eventBase = info->codes->first_event; |
+ *errorBase = info->codes->first_error; |
+ return True; |
+ } |
+ |
+ return False; |
+} |
+ |
+Bool VA_DRI2QueryVersion(Display *dpy, int *major, int *minor) |
+{ |
+ XExtDisplayInfo *info = DRI2FindDisplay (dpy); |
+ xDRI2QueryVersionReply rep; |
+ xDRI2QueryVersionReq *req; |
+ |
+ XextCheckExtension (dpy, info, va_dri2ExtensionName, False); |
+ |
+ LockDisplay(dpy); |
+ GetReq(DRI2QueryVersion, req); |
+ req->reqType = info->codes->major_opcode; |
+ req->dri2ReqType = X_DRI2QueryVersion; |
+ req->majorVersion = DRI2_MAJOR; |
+ req->minorVersion = DRI2_MINOR; |
+ if (!_XReply(dpy, (xReply *)&rep, 0, xFalse)) { |
+ UnlockDisplay(dpy); |
+ SyncHandle(); |
+ return False; |
+ } |
+ *major = rep.majorVersion; |
+ *minor = rep.minorVersion; |
+ UnlockDisplay(dpy); |
+ SyncHandle(); |
+ |
+ return True; |
+} |
+ |
+Bool VA_DRI2Connect(Display *dpy, XID window, |
+ char **driverName, char **deviceName) |
+{ |
+ XExtDisplayInfo *info = DRI2FindDisplay(dpy); |
+ xDRI2ConnectReply rep; |
+ xDRI2ConnectReq *req; |
+ |
+ XextCheckExtension (dpy, info, va_dri2ExtensionName, False); |
+ |
+ LockDisplay(dpy); |
+ GetReq(DRI2Connect, req); |
+ req->reqType = info->codes->major_opcode; |
+ req->dri2ReqType = X_DRI2Connect; |
+ req->window = window; |
+ req->driverType = DRI2DriverDRI; |
+ if (!_XReply(dpy, (xReply *)&rep, 0, xFalse)) { |
+ UnlockDisplay(dpy); |
+ SyncHandle(); |
+ return False; |
+ } |
+ |
+ if (rep.driverNameLength == 0 && rep.deviceNameLength == 0) { |
+ UnlockDisplay(dpy); |
+ SyncHandle(); |
+ return False; |
+ } |
+ |
+ *driverName = Xmalloc(rep.driverNameLength + 1); |
+ if (*driverName == NULL) { |
+ _XEatData(dpy, |
+ ((rep.driverNameLength + 3) & ~3) + |
+ ((rep.deviceNameLength + 3) & ~3)); |
+ UnlockDisplay(dpy); |
+ SyncHandle(); |
+ return False; |
+ } |
+ _XReadPad(dpy, *driverName, rep.driverNameLength); |
+ (*driverName)[rep.driverNameLength] = '\0'; |
+ |
+ *deviceName = Xmalloc(rep.deviceNameLength + 1); |
+ if (*deviceName == NULL) { |
+ Xfree(*driverName); |
+ _XEatData(dpy, ((rep.deviceNameLength + 3) & ~3)); |
+ UnlockDisplay(dpy); |
+ SyncHandle(); |
+ return False; |
+ } |
+ _XReadPad(dpy, *deviceName, rep.deviceNameLength); |
+ (*deviceName)[rep.deviceNameLength] = '\0'; |
+ |
+ UnlockDisplay(dpy); |
+ SyncHandle(); |
+ |
+ return True; |
+} |
+ |
+Bool VA_DRI2Authenticate(Display *dpy, XID window, drm_magic_t magic) |
+{ |
+ XExtDisplayInfo *info = DRI2FindDisplay(dpy); |
+ xDRI2AuthenticateReq *req; |
+ xDRI2AuthenticateReply rep; |
+ |
+ XextCheckExtension (dpy, info, va_dri2ExtensionName, False); |
+ |
+ LockDisplay(dpy); |
+ GetReq(DRI2Authenticate, req); |
+ req->reqType = info->codes->major_opcode; |
+ req->dri2ReqType = X_DRI2Authenticate; |
+ req->window = window; |
+ req->magic = magic; |
+ |
+ if (!_XReply(dpy, (xReply *)&rep, 0, xFalse)) { |
+ UnlockDisplay(dpy); |
+ SyncHandle(); |
+ return False; |
+ } |
+ |
+ UnlockDisplay(dpy); |
+ SyncHandle(); |
+ |
+ return rep.authenticated; |
+} |
+ |
+void VA_DRI2CreateDrawable(Display *dpy, XID drawable) |
+{ |
+ XExtDisplayInfo *info = DRI2FindDisplay(dpy); |
+ xDRI2CreateDrawableReq *req; |
+ |
+ XextSimpleCheckExtension (dpy, info, va_dri2ExtensionName); |
+ |
+ LockDisplay(dpy); |
+ GetReq(DRI2CreateDrawable, req); |
+ req->reqType = info->codes->major_opcode; |
+ req->dri2ReqType = X_DRI2CreateDrawable; |
+ req->drawable = drawable; |
+ UnlockDisplay(dpy); |
+ SyncHandle(); |
+} |
+ |
+void VA_DRI2DestroyDrawable(Display *dpy, XID drawable) |
+{ |
+ XExtDisplayInfo *info = DRI2FindDisplay(dpy); |
+ xDRI2DestroyDrawableReq *req; |
+ |
+ XextSimpleCheckExtension (dpy, info, va_dri2ExtensionName); |
+ |
+ XSync(dpy, False); |
+ |
+ LockDisplay(dpy); |
+ GetReq(DRI2DestroyDrawable, req); |
+ req->reqType = info->codes->major_opcode; |
+ req->dri2ReqType = X_DRI2DestroyDrawable; |
+ req->drawable = drawable; |
+ UnlockDisplay(dpy); |
+ SyncHandle(); |
+} |
+ |
+VA_DRI2Buffer *VA_DRI2GetBuffers(Display *dpy, XID drawable, |
+ int *width, int *height, |
+ unsigned int *attachments, int count, |
+ int *outCount) |
+{ |
+ XExtDisplayInfo *info = DRI2FindDisplay(dpy); |
+ xDRI2GetBuffersReply rep; |
+ xDRI2GetBuffersReq *req; |
+ VA_DRI2Buffer *buffers; |
+ xDRI2Buffer repBuffer; |
+ CARD32 *p; |
+ int i; |
+ |
+ XextCheckExtension (dpy, info, va_dri2ExtensionName, False); |
+ |
+ LockDisplay(dpy); |
+ GetReqExtra(DRI2GetBuffers, count * 4, req); |
+ req->reqType = info->codes->major_opcode; |
+ req->dri2ReqType = X_DRI2GetBuffers; |
+ req->drawable = drawable; |
+ req->count = count; |
+ p = (CARD32 *) &req[1]; |
+ for (i = 0; i < count; i++) |
+ p[i] = attachments[i]; |
+ |
+ if (!_XReply(dpy, (xReply *)&rep, 0, xFalse)) { |
+ UnlockDisplay(dpy); |
+ SyncHandle(); |
+ return NULL; |
+ } |
+ |
+ *width = rep.width; |
+ *height = rep.height; |
+ *outCount = rep.count; |
+ |
+ buffers = Xmalloc(rep.count * sizeof buffers[0]); |
+ if (buffers == NULL) { |
+ _XEatData(dpy, rep.count * sizeof repBuffer); |
+ UnlockDisplay(dpy); |
+ SyncHandle(); |
+ return NULL; |
+ } |
+ |
+ for (i = 0; i < rep.count; i++) { |
+ _XReadPad(dpy, (char *) &repBuffer, sizeof repBuffer); |
+ buffers[i].attachment = repBuffer.attachment; |
+ buffers[i].name = repBuffer.name; |
+ buffers[i].pitch = repBuffer.pitch; |
+ buffers[i].cpp = repBuffer.cpp; |
+ buffers[i].flags = repBuffer.flags; |
+ } |
+ |
+ UnlockDisplay(dpy); |
+ SyncHandle(); |
+ |
+ return buffers; |
+} |
+ |
+void VA_DRI2CopyRegion(Display *dpy, XID drawable, XserverRegion region, |
+ CARD32 dest, CARD32 src) |
+{ |
+ XExtDisplayInfo *info = DRI2FindDisplay(dpy); |
+ xDRI2CopyRegionReq *req; |
+ xDRI2CopyRegionReply rep; |
+ |
+ XextSimpleCheckExtension (dpy, info, va_dri2ExtensionName); |
+ |
+ LockDisplay(dpy); |
+ GetReq(DRI2CopyRegion, req); |
+ req->reqType = info->codes->major_opcode; |
+ req->dri2ReqType = X_DRI2CopyRegion; |
+ req->drawable = drawable; |
+ req->region = region; |
+ req->dest = dest; |
+ req->src = src; |
+ |
+ _XReply(dpy, (xReply *)&rep, 0, xFalse); |
+ |
+ UnlockDisplay(dpy); |
+ SyncHandle(); |
+} |
+ |
+static void |
+load_swap_req(xDRI2SwapBuffersReq *req, CARD64 target, CARD64 divisor, |
+ CARD64 remainder) |
+{ |
+ req->target_msc_hi = target >> 32; |
+ req->target_msc_lo = target & 0xffffffff; |
+ req->divisor_hi = divisor >> 32; |
+ req->divisor_lo = divisor & 0xffffffff; |
+ req->remainder_hi = remainder >> 32; |
+ req->remainder_lo = remainder & 0xffffffff; |
+} |
+ |
+static CARD64 |
+vals_to_card64(CARD32 lo, CARD32 hi) |
+{ |
+ return (CARD64)hi << 32 | lo; |
+} |
+ |
+void VA_DRI2SwapBuffers(Display *dpy, XID drawable, CARD64 target_msc, |
+ CARD64 divisor, CARD64 remainder, CARD64 *count) |
+{ |
+ XExtDisplayInfo *info = DRI2FindDisplay(dpy); |
+ xDRI2SwapBuffersReq *req; |
+ xDRI2SwapBuffersReply rep; |
+ |
+ XextSimpleCheckExtension (dpy, info, va_dri2ExtensionName); |
+ |
+ LockDisplay(dpy); |
+ GetReq(DRI2SwapBuffers, req); |
+ req->reqType = info->codes->major_opcode; |
+ req->dri2ReqType = X_DRI2SwapBuffers; |
+ req->drawable = drawable; |
+ load_swap_req(req, target_msc, divisor, remainder); |
+ |
+ _XReply(dpy, (xReply *)&rep, 0, xFalse); |
+ |
+ *count = vals_to_card64(rep.swap_lo, rep.swap_hi); |
+ |
+ UnlockDisplay(dpy); |
+ SyncHandle(); |
+} |