packages: xorg-lib-libXvMC/xvmcinfo.c (NEW) - copy from http://www.mythtv.o...
glen
glen at pld-linux.org
Thu Dec 30 14:17:13 CET 2010
Author: glen Date: Thu Dec 30 13:17:13 2010 GMT
Module: packages Tag: HEAD
---- Log message:
- copy from http://www.mythtv.org/wiki/XvMC
---- Files affected:
packages/xorg-lib-libXvMC:
xvmcinfo.c (NONE -> 1.1) (NEW)
---- Diffs:
================================================================
Index: packages/xorg-lib-libXvMC/xvmcinfo.c
diff -u /dev/null packages/xorg-lib-libXvMC/xvmcinfo.c:1.1
--- /dev/null Thu Dec 30 14:17:13 2010
+++ packages/xorg-lib-libXvMC/xvmcinfo.c Thu Dec 30 14:17:08 2010
@@ -0,0 +1,134 @@
+/*
+ ** XvMC extension info program
+ **
+ ** author:
+ ** Michal Podsiadlik <michal (et) gov.one.pl>
+ ** Ken Harris : fixed some bugs with the "chroma" and "codec" fields, 2005-10-01
+ **
+ ** compile using this command (I hope ;-))
+ ** gcc -o xvmcinfo xvmcinfo.c -lXvMCW
+ * */
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <string.h>
+
+#include <X11/Xlib.h>
+#include <X11/extensions/XvMClib.h>
+
+void usage(char *c)
+{
+ fprintf(stderr, "usage:\n" "%s [-display displayname]\n", c);
+ exit(1);
+}
+
+int main(int argc, char **argv)
+{
+ Display *xserver;
+ int iscreen;
+ char *display = NULL;
+
+ if (argc != 1 && argc != 3)
+ usage(argv[0]);
+
+ if (argc == 3) {
+ if (!strcmp(argv[1], "-display"))
+ display = argv[2];
+ else
+ usage(argv[0]);
+ }
+
+ xserver = XOpenDisplay(display);
+ if (!xserver) {
+ fprintf(stderr, "failed to connect to display: %s\n", display);
+ return 1;
+ }
+
+ {
+ unsigned int xv_major, xv_minor, x, y, z;
+ if (XvQueryExtension(xserver, &xv_major, &xv_minor, &x, &y, &z) !=
+ Success) {
+ fprintf(stderr, "no Xv extension available\n");
+ XCloseDisplay(xserver);
+ return 1;
+ }
+ printf("\n" "Xv version %i.%i\n", xv_major, xv_minor);
+ }
+
+ {
+ int xvmc_major, xvmc_minor;
+ if (XvMCQueryVersion(xserver, &xvmc_major, &xvmc_minor) != Success) {
+ fprintf(stderr, "no XvMC extension available\n");
+ XCloseDisplay(xserver);
+ return 1;
+ }
+
+ printf("XvMC version %i.%i\n\n", xvmc_major, xvmc_minor);
+ }
+
+ for (iscreen = 0; iscreen < ScreenCount(xserver); iscreen++) {
+ unsigned int iadapt, num_adaptors;
+ XvAdaptorInfo *adaptor_info;
+
+ printf("screen number %i\n", iscreen);
+
+ XvQueryAdaptors(xserver, RootWindow(xserver, iscreen),
+ &num_adaptors, &adaptor_info);
+
+ if (!num_adaptors) {
+ printf(" no Xv adaptors found\n");
+ continue;
+ }
+
+ for (iadapt = 0; iadapt < num_adaptors; iadapt++) {
+ int isurf, num_surfaces;
+ XvMCSurfaceInfo *xvmc_info;
+
+ printf(" info for adaptor %i [%s]\n", iadapt,
+ adaptor_info[iadapt].name);
+
+ xvmc_info =
+ XvMCListSurfaceTypes(xserver, adaptor_info[iadapt].base_id,
+ &num_surfaces);
+
+ printf(" number of XvMC surface types: %i\n\n",
+ num_surfaces);
+
+ for (isurf = 0; isurf < num_surfaces; isurf++) {
+ static char *codec[] = { "", "MPEG1", "MPEG2", "H263", "MPEG4" }; // XXXX HACK
+ static char *chroma[] = { "", "XVMC_CHROMA_FORMAT_420 ", "XVMC_CHROMA_FORMAT_422 ", "XVMC_CHROMA_FORMAT_444 " }; // XXXX HACK
+ printf(" info about surface %i:\n"
+ " max_width=%i\n"
+ " max_height=%i\n"
+ " subpicture_max_width=%i\n"
+ " subpicture_max_height=%i\n"
+ " chroma_format:\n"
+ " %s\n"
+ " mc_type:\n"
+ " format : %s\n"
+ " accelaration start from : %s\n"
+ " flags:\n"
+ " %s%s%s%s\n\n",
+ isurf,
+ xvmc_info[isurf].max_width,
+ xvmc_info[isurf].max_height,
+ xvmc_info[isurf].subpicture_max_width,
+ xvmc_info[isurf].subpicture_max_height,
+ /* chroma_format */
+ chroma[xvmc_info[isurf].chroma_format & 0xf],
+ /* mc_type */
+ codec[xvmc_info[isurf].mc_type & 0xf],
+ xvmc_info[isurf].mc_type & XVMC_IDCT ? "IDCT " : "MOCOMP ",
+ /* flags */
+ xvmc_info[isurf].flags & XVMC_OVERLAID_SURFACE ? "XVMC_OVERLAID_SURFACE " : "",
+ xvmc_info[isurf].flags & XVMC_BACKEND_SUBPICTURE ? "XVMC_BACKEND_SUBPICTURE " : "",
+ xvmc_info[isurf].flags & XVMC_SUBPICTURE_INDEPENDENT_SCALING ? "XVMC_SUBPICTURE_INDEPENDENT_SCALING " : "",
+ xvmc_info[isurf].flags & XVMC_INTRA_UNSIGNED ? "XVMC_INTRA_UNSIGNED " : "");
+ }
+ XFree(xvmc_info);
+ }
+ XvFreeAdaptorInfo(adaptor_info);
+ }
+ XCloseDisplay(xserver);
+ return 0;
+}
================================================================
More information about the pld-cvs-commit
mailing list