summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChris Wilson <chris@chris-wilson.co.uk>2013-04-09 20:43:19 +0100
committerChris Wilson <chris@chris-wilson.co.uk>2013-04-10 12:17:29 +0100
commit092e30de8a3476ab99446264edaf9b250a41736b (patch)
treeb7604b8eadeca4fa7e4f821c27b278dd7c824a7b
parent540802595fee7f8b2c73e74c2b44e9a21f6471ae (diff)
sna/xvmc: Wrap each output adaptor
Each of the overlay, sprite and textured video can support XvMC passthrough, so we need to setup an XvMC adaptor for each of our Xv adaptors. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
-rw-r--r--src/sna/sna_video.c10
-rw-r--r--src/sna/sna_video_hwmc.c73
-rw-r--r--src/sna/sna_video_hwmc.h4
3 files changed, 43 insertions, 44 deletions
diff --git a/src/sna/sna_video.c b/src/sna/sna_video.c
index a0eb0f4e..6d067c76 100644
--- a/src/sna/sna_video.c
+++ b/src/sna/sna_video.c
@@ -66,11 +66,8 @@
#define _SNA_XVMC_SERVER_
#include "sna_video_hwmc.h"
#else
-static inline bool sna_video_xvmc_setup(struct sna *sna,
- ScreenPtr ptr,
- XF86VideoAdaptorPtr target)
+static inline void sna_video_xvmc_setup(struct sna *sna, ScreenPtr ptr)
{
- return false;
}
#endif
@@ -574,9 +571,8 @@ void sna_video_init(struct sna *sna, ScreenPtr screen)
adaptors[num_adaptors++] = overlay;
if (num_adaptors) {
- Bool ok = xf86XVScreenInit(screen, adaptors, num_adaptors);
- if (ok && textured)
- sna_video_xvmc_setup(sna, screen, textured);
+ if (xf86XVScreenInit(screen, adaptors, num_adaptors))
+ sna_video_xvmc_setup(sna, screen);
} else
xf86DrvMsg(sna->scrn->scrnIndex, X_WARNING,
"Disabling Xv because no adaptors could be initialized.\n");
diff --git a/src/sna/sna_video_hwmc.c b/src/sna/sna_video_hwmc.c
index b3e065d9..573fda58 100644
--- a/src/sna/sna_video_hwmc.c
+++ b/src/sna/sna_video_hwmc.c
@@ -197,14 +197,13 @@ static XvMCSurfaceInfoPtr surface_info_vld[] = {
/* check chip type and load xvmc driver */
Bool sna_video_xvmc_setup(struct sna *sna,
- ScreenPtr screen,
- XF86VideoAdaptorPtr target)
+ ScreenPtr screen)
{
XvMCAdaptorRec *adaptors;
XvScreenPtr xv;
const char *name;
char bus[64];
- int i;
+ int i, j;
if (!xf86LoaderCheckSymbol("XvMCScreenInit"))
return FALSE;
@@ -217,43 +216,42 @@ Bool sna_video_xvmc_setup(struct sna *sna,
if (sna->kgem.gen >= 060)
return FALSE;
- adaptors = calloc(1, sizeof(XvMCAdaptorRec));
+ xv = dixLookupPrivate(&screen->devPrivates, XF86XvScreenKey);
+
+ adaptors = calloc(xv->nAdaptors, sizeof(XvMCAdaptorRec));
if (adaptors == NULL)
return FALSE;
- xv = dixLookupPrivate(&screen->devPrivates, XF86XvScreenKey);
- for (i = 0; i< xv->nAdaptors;i++) {
- if (strcmp(xv->pAdaptors[i].name, target->name) == 0) {
- adaptors->xv_adaptor = &xv->pAdaptors[i];
- break;
+ for (i = j = 0; i< xv->nAdaptors;i++) {
+ if (strncmp(xv->pAdaptors[i].name, "Intel(R)", 8))
+ continue;
+
+ adaptors[j].xv_adaptor = &xv->pAdaptors[i];
+
+ adaptors[j].num_subpictures = 0;
+ adaptors[j].subpictures = NULL;
+ adaptors[j].CreateContext = create_context;
+ adaptors[j].DestroyContext = destroy_context;
+ adaptors[j].CreateSurface = create_surface;
+ adaptors[j].DestroySurface = destroy_surface;
+ adaptors[j].CreateSubpicture = create_subpicture;
+ adaptors[j].DestroySubpicture = destroy_subpicture;
+
+ if (sna->kgem.gen >= 045) {
+ adaptors[j].num_surfaces = ARRAY_SIZE(surface_info_vld);
+ adaptors[j].surfaces = surface_info_vld;
+ } else if (sna->kgem.gen >= 040) {
+ adaptors[j].num_surfaces = ARRAY_SIZE(surface_info_i965);
+ adaptors[j].surfaces = surface_info_i965;
+ } else {
+ adaptors[j].num_surfaces = ARRAY_SIZE(surface_info_i915);
+ adaptors[j].surfaces = surface_info_i915;
}
- }
- assert(adaptors->xv_adaptor);
-
- adaptors->num_subpictures = 0;
- adaptors->subpictures = NULL;
- adaptors->CreateContext = create_context;
- adaptors->DestroyContext = destroy_context;
- adaptors->CreateSurface = create_surface;
- adaptors->DestroySurface = destroy_surface;
- adaptors->CreateSubpicture = create_subpicture;
- adaptors->DestroySubpicture = destroy_subpicture;
-
- if (sna->kgem.gen >= 045) {
- name = "xvmc_vld",
- adaptors->num_surfaces = ARRAY_SIZE(surface_info_vld);
- adaptors->surfaces = surface_info_vld;
- } else if (sna->kgem.gen >= 040) {
- name = "i965_xvmc",
- adaptors->num_surfaces = ARRAY_SIZE(surface_info_i965);
- adaptors->surfaces = surface_info_i965;
- } else {
- name = "i915_xvmc",
- adaptors->num_surfaces = ARRAY_SIZE(surface_info_i915);
- adaptors->surfaces = surface_info_i915;
+
+ j++;
}
- if (XvMCScreenInit(screen, 1, adaptors) != Success) {
+ if (XvMCScreenInit(screen, j, adaptors) != Success) {
xf86DrvMsg(sna->scrn->scrnIndex, X_INFO,
"[XvMC] Failed to initialize XvMC.\n");
free(adaptors);
@@ -268,8 +266,15 @@ Bool sna_video_xvmc_setup(struct sna *sna,
SNA_XVMC_MAJOR, SNA_XVMC_MINOR,
SNA_XVMC_PATCHLEVEL);
+ if (sna->kgem.gen >= 045)
+ name = "xvmc_vld";
+ else if (sna->kgem.gen >= 040)
+ name = "i965_xvmc";
+ else
+ name = "i915_xvmc";
xf86DrvMsg(sna->scrn->scrnIndex, X_INFO,
"[XvMC] %s driver initialized.\n",
name);
+
return TRUE;
}
diff --git a/src/sna/sna_video_hwmc.h b/src/sna/sna_video_hwmc.h
index 44de456e..8b0d2cdf 100644
--- a/src/sna/sna_video_hwmc.h
+++ b/src/sna/sna_video_hwmc.h
@@ -40,9 +40,7 @@
#ifdef _SNA_XVMC_SERVER_
#include <xf86xvmc.h>
-Bool sna_video_xvmc_setup(struct sna *sna,
- ScreenPtr screen,
- XF86VideoAdaptorPtr target);
+Bool sna_video_xvmc_setup(struct sna *sna, ScreenPtr screen);
#endif
#endif