summaryrefslogtreecommitdiff
path: root/src/sna/sna_video_textured.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/sna/sna_video_textured.c')
-rw-r--r--src/sna/sna_video_textured.c243
1 files changed, 115 insertions, 128 deletions
diff --git a/src/sna/sna_video_textured.c b/src/sna/sna_video_textured.c
index 5f907441..8278606c 100644
--- a/src/sna/sna_video_textured.c
+++ b/src/sna/sna_video_textured.c
@@ -43,19 +43,20 @@
static Atom xvBrightness, xvContrast, xvSyncToVblank;
-static const XvFormatRec Formats[] = {
+#define NUM_FORMATS 3
+static const XF86VideoFormatRec Formats[NUM_FORMATS] = {
{15, TrueColor}, {16, TrueColor}, {24, TrueColor}
};
-#define NUM_FORMATS ARRAY_SIZE(Formats)
-static const XvAttributeRec TexturedAttributes[] = {
+//#define NUM_TEXTURED_ATTRIBUTES 3
+#define NUM_TEXTURED_ATTRIBUTES 1
+static const XF86AttributeRec TexturedAttributes[] = {
{XvSettable | XvGettable, -1, 1, "XV_SYNC_TO_VBLANK"},
- //{XvSettable | XvGettable, -128, 127, "XV_BRIGHTNESS"},
- //{XvSettable | XvGettable, 0, 255, "XV_CONTRAST"},
+ {XvSettable | XvGettable, -128, 127, "XV_BRIGHTNESS"},
+ {XvSettable | XvGettable, 0, 255, "XV_CONTRAST"},
};
-#define NUM_TEXTURED_ATTRIBUTES ARRAY_SIZE(TexturedAttributes)
-static const XvImageRec Images[] = {
+static const XF86ImageRec Images[] = {
XVIMAGE_YUY2,
XVIMAGE_YV12,
XVIMAGE_I420,
@@ -63,27 +64,30 @@ static const XvImageRec Images[] = {
XVMC_YUV,
};
-static int sna_video_textured_stop(ClientPtr client,
- XvPortPtr port,
- DrawablePtr draw)
+static void sna_video_textured_stop(ScrnInfoPtr scrn,
+ pointer data,
+ Bool shutdown)
{
- struct sna_video *video = port->devPriv.ptr;
+ struct sna *sna = to_sna(scrn);
+ struct sna_video *video = data;
DBG(("%s()\n", __FUNCTION__));
- RegionUninit(&video->clip);
- sna_video_free_buffers(video->sna, video);
+ REGION_EMPTY(scrn->pScreen, &video->clip);
- return Success;
+ if (!shutdown)
+ return;
+
+ sna_video_free_buffers(sna, video);
}
static int
-sna_video_textured_set_attribute(ClientPtr client,
- XvPortPtr port,
+sna_video_textured_set_attribute(ScrnInfoPtr scrn,
Atom attribute,
- INT32 value)
+ INT32 value,
+ pointer data)
{
- struct sna_video *video = port->devPriv.ptr;
+ struct sna_video *video = data;
if (attribute == xvBrightness) {
if (value < -128 || value > 127)
@@ -107,12 +111,12 @@ sna_video_textured_set_attribute(ClientPtr client,
}
static int
-sna_video_textured_get_attribute(ClientPtr client,
- XvPortPtr port,
+sna_video_textured_get_attribute(ScrnInfoPtr scrn,
Atom attribute,
- INT32 *value)
+ INT32 *value,
+ pointer data)
{
- struct sna_video *video = port->devPriv.ptr;
+ struct sna_video *video = data;
if (attribute == xvBrightness)
*value = video->brightness;
@@ -126,14 +130,14 @@ sna_video_textured_get_attribute(ClientPtr client,
return Success;
}
-static int
-sna_video_textured_best_size(ClientPtr client,
- XvPortPtr port,
- CARD8 motion,
- CARD16 vid_w, CARD16 vid_h,
- CARD16 drw_w, CARD16 drw_h,
+static void
+sna_video_textured_best_size(ScrnInfoPtr scrn,
+ Bool motion,
+ short vid_w, short vid_h,
+ short drw_w, short drw_h,
unsigned int *p_w,
- unsigned int *p_h)
+ unsigned int *p_h,
+ pointer data)
{
if (vid_w > (drw_w << 1))
drw_w = vid_w >> 1;
@@ -142,8 +146,6 @@ sna_video_textured_best_size(ClientPtr client,
*p_w = drw_w;
*p_h = drw_h;
-
- return Success;
}
/*
@@ -160,49 +162,35 @@ sna_video_textured_best_size(ClientPtr client,
* compositing. It's a new argument to the function in the 1.1 server.
*/
static int
-sna_video_textured_put_image(ClientPtr client,
- DrawablePtr draw,
- XvPortPtr port,
- GCPtr gc,
- INT16 src_x, INT16 src_y,
- CARD16 src_w, CARD16 src_h,
- INT16 drw_x, INT16 drw_y,
- CARD16 drw_w, CARD16 drw_h,
- XvImagePtr format,
- unsigned char *buf,
- Bool sync,
- CARD16 width, CARD16 height)
+sna_video_textured_put_image(ScrnInfoPtr scrn,
+ short src_x, short src_y,
+ short drw_x, short drw_y,
+ short src_w, short src_h,
+ short drw_w, short drw_h,
+ int id, unsigned char *buf,
+ short width, short height,
+ Bool sync, RegionPtr clip, pointer data,
+ DrawablePtr drawable)
{
- struct sna_video *video = port->devPriv.ptr;
- struct sna *sna = video->sna;
+ struct sna *sna = to_sna(scrn);
+ struct sna_video *video = data;
struct sna_video_frame frame;
- PixmapPtr pixmap = get_drawable_pixmap(draw);
+ PixmapPtr pixmap = get_drawable_pixmap(drawable);
BoxRec dstBox;
- RegionRec clip;
xf86CrtcPtr crtc;
bool flush = false;
bool ret;
- clip.extents.x1 = draw->x + drw_x;
- clip.extents.y1 = draw->y + drw_y;
- clip.extents.x2 = clip.extents.x1 + drw_w;
- clip.extents.y2 = clip.extents.y1 + drw_h;
- clip.data = NULL;
-
- RegionIntersect(&clip, &clip, gc->pCompositeClip);
- if (!RegionNotEmpty(&clip))
- return Success;
-
DBG(("%s: src=(%d, %d),(%d, %d), dst=(%d, %d),(%d, %d), id=%d, sizep=%dx%d, sync?=%d\n",
__FUNCTION__,
src_x, src_y, src_w, src_h,
drw_x, drw_y, drw_w, drw_h,
- format->id, width, height, sync));
+ id, width, height, sync));
DBG(("%s: region %d:(%d, %d), (%d, %d)\n", __FUNCTION__,
- RegionNumRects(&clip),
- clip.extents.x1, clip.extents.y1,
- clip.extents.x2, clip.extents.y2));
+ RegionNumRects(clip),
+ clip->extents.x1, clip->extents.y1,
+ clip->extents.x2, clip->extents.y2));
if (buf == 0) {
DBG(("%s: garbage video buffer\n", __FUNCTION__));
@@ -215,16 +203,16 @@ sna_video_textured_put_image(ClientPtr client,
return BadAlloc;
}
- sna_video_frame_init(sna, video, format->id, width, height, &frame);
+ sna_video_frame_init(sna, video, id, width, height, &frame);
- if (!sna_video_clip_helper(sna->scrn, video, &frame,
+ if (!sna_video_clip_helper(scrn, video, &frame,
&crtc, &dstBox,
- src_x, src_y, drw_x + draw->x, drw_y + draw->y,
+ src_x, src_y, drw_x, drw_y,
src_w, src_h, drw_w, drw_h,
- &clip))
+ clip))
return Success;
- if (xvmc_passthrough(format->id)) {
+ if (xvmc_passthrough(id)) {
DBG(("%s: using passthough, name=%d\n",
__FUNCTION__, *(uint32_t *)buf));
@@ -247,19 +235,19 @@ sna_video_textured_put_image(ClientPtr client,
}
}
- if (crtc && sync && video->SyncToVblank != 0 &&
+ if (crtc && video->SyncToVblank != 0 &&
sna_pixmap_is_scanout(sna, pixmap)) {
kgem_set_mode(&sna->kgem, KGEM_RENDER, sna_pixmap(pixmap)->gpu_bo);
flush = sna_wait_for_scanline(sna, pixmap, crtc,
- &clip.extents);
+ &clip->extents);
}
ret = Success;
- if (!sna->render.video(sna, video, &frame, &clip, pixmap)) {
+ if (!sna->render.video(sna, video, &frame, clip, pixmap)) {
DBG(("%s: failed to render video\n", __FUNCTION__));
ret = BadAlloc;
} else
- DamageDamageRegion(draw, &clip);
+ DamageDamageRegion(drawable, clip);
kgem_bo_destroy(&sna->kgem, frame.bo);
@@ -269,19 +257,14 @@ sna_video_textured_put_image(ClientPtr client,
if (flush)
kgem_submit(&sna->kgem);
- RegionUninit(&clip);
-
return ret;
}
static int
-sna_video_textured_query(ClientPtr client,
- XvPortPtr port,
- XvImagePtr format,
- unsigned short *w,
- unsigned short *h,
- int *pitches,
- int *offsets)
+sna_video_textured_query(ScrnInfoPtr scrn,
+ int id,
+ unsigned short *w, unsigned short *h,
+ int *pitches, int *offsets)
{
int size, tmp;
@@ -294,7 +277,7 @@ sna_video_textured_query(ClientPtr client,
if (offsets)
offsets[0] = 0;
- switch (format->id) {
+ switch (id) {
/* IA44 is for XvMC only */
case FOURCC_IA44:
case FOURCC_AI44:
@@ -339,73 +322,87 @@ sna_video_textured_query(ClientPtr client,
return size;
}
-void sna_video_textured_setup(struct sna *sna, ScreenPtr screen)
+XF86VideoAdaptorPtr sna_video_textured_setup(struct sna *sna,
+ ScreenPtr screen)
{
- XvAdaptorPtr adaptor;
+ XF86VideoAdaptorPtr adaptor;
+ XF86AttributePtr attrs;
struct sna_video *video;
+ DevUnion *devUnions;
int nports = 16, i;
if (!sna->render.video) {
- xf86DrvMsg(sna->scrn->scrnIndex, X_INFO,
+ xf86DrvMsg(sna->scrn->scrnIndex, X_WARNING,
"Textured video not supported on this hardware\n");
- return;
+ return NULL;
}
if (wedged(sna)) {
xf86DrvMsg(sna->scrn->scrnIndex, X_WARNING,
"cannot enable XVideo whilst the GPU is wedged\n");
- return;
+ return NULL;
}
- adaptor = sna_xv_adaptor_alloc(sna);
- if (adaptor == NULL)
- return;
-
+ adaptor = calloc(1, sizeof(XF86VideoAdaptorRec));
video = calloc(nports, sizeof(struct sna_video));
- if ( video == NULL) {
- sna->xv.num_adaptors--;
+ devUnions = calloc(nports, sizeof(DevUnion));
+#if NUM_TEXTURED_ATTRIBUTES
+ attrs = calloc(NUM_TEXTURED_ATTRIBUTES, sizeof(XF86AttributeRec));
+ if (adaptor == NULL ||
+ video == NULL ||
+ devUnions == NULL ||
+ attrs == NULL) {
+ free(adaptor);
free(video);
- return;
+ free(devUnions);
+ free(attrs);
+ return NULL;
+ }
+#else
+ if (adaptor == NULL || video == NULL || devUnions == NULL) {
+ free(adaptor);
+ free(video);
+ free(devUnions);
+ return NULL;
}
+ attrs = NULL;
+#endif
- adaptor->type = XvInputMask | XvImageMask;
- adaptor->pScreen = screen;
+ adaptor->type = XvWindowMask | XvInputMask | XvImageMask;
+ adaptor->flags = 0;
adaptor->name = "Intel(R) Textured Video";
adaptor->nEncodings = 1;
- adaptor->pEncodings = xnfalloc(sizeof(XvEncodingRec));
+ adaptor->pEncodings = xnfalloc(sizeof(XF86VideoEncodingRec));
adaptor->pEncodings[0].id = 0;
- adaptor->pEncodings[0].pScreen = screen;
adaptor->pEncodings[0].name = "XV_IMAGE";
adaptor->pEncodings[0].width = sna->render.max_3d_size;
adaptor->pEncodings[0].height = sna->render.max_3d_size;
adaptor->pEncodings[0].rate.numerator = 1;
adaptor->pEncodings[0].rate.denominator = 1;
adaptor->nFormats = NUM_FORMATS;
- adaptor->pFormats = Formats;
+ adaptor->pFormats = (XF86VideoFormatPtr)Formats;
+ adaptor->nPorts = nports;
+ adaptor->pPortPrivates = devUnions;
adaptor->nAttributes = NUM_TEXTURED_ATTRIBUTES;
- adaptor->pAttributes = TexturedAttributes;
+ adaptor->pAttributes = attrs;
+ memcpy(attrs, TexturedAttributes,
+ NUM_TEXTURED_ATTRIBUTES * sizeof(XF86AttributeRec));
adaptor->nImages = ARRAY_SIZE(Images);
- adaptor->pImages = Images;
- adaptor->ddAllocatePort = sna_xv_alloc_port;
- adaptor->ddFreePort = sna_xv_free_port;
- adaptor->ddPutVideo = NULL;
- adaptor->ddPutStill = NULL;
- adaptor->ddGetVideo = NULL;
- adaptor->ddGetStill = NULL;
- adaptor->ddStopVideo = sna_video_textured_stop;
- adaptor->ddSetPortAttribute = sna_video_textured_set_attribute;
- adaptor->ddGetPortAttribute = sna_video_textured_get_attribute;
- adaptor->ddQueryBestSize = sna_video_textured_best_size;
- adaptor->ddPutImage = sna_video_textured_put_image;
- adaptor->ddQueryImageAttributes = sna_video_textured_query;
+ adaptor->pImages = (XF86ImagePtr)Images;
+ adaptor->PutVideo = NULL;
+ adaptor->PutStill = NULL;
+ adaptor->GetVideo = NULL;
+ adaptor->GetStill = NULL;
+ adaptor->StopVideo = sna_video_textured_stop;
+ adaptor->SetPortAttribute = sna_video_textured_set_attribute;
+ adaptor->GetPortAttribute = sna_video_textured_get_attribute;
+ adaptor->QueryBestSize = sna_video_textured_best_size;
+ adaptor->PutImage = sna_video_textured_put_image;
+ adaptor->QueryImageAttributes = sna_video_textured_query;
- adaptor->nPorts = nports;
- adaptor->pPorts = calloc(nports, sizeof(XvPortRec));
for (i = 0; i < nports; i++) {
struct sna_video *v = &video[i];
- XvPortPtr port = &adaptor->pPorts[i];
- v->sna = sna;
v->textured = true;
v->alignment = 4;
v->rotation = RR_Rotate_0;
@@ -414,22 +411,12 @@ void sna_video_textured_setup(struct sna *sna, ScreenPtr screen)
/* gotta uninit this someplace, XXX: shouldn't be necessary for textured */
RegionNull(&v->clip);
- port->id = FakeClientID(0);
- AddResource(port->id, XvGetRTPort(), port);
-
- port->pAdaptor = adaptor;
- port->pNotify = NULL;
- port->pDraw = NULL;
- port->client = NULL;
- port->grab.client = NULL;
- port->time = currentTime;
- port->devPriv.ptr = v;
-
- port++;
+ adaptor->pPortPrivates[i].ptr = v;
}
- adaptor->base_id = adaptor->pPorts[0].id;
xvBrightness = MAKE_ATOM("XV_BRIGHTNESS");
xvContrast = MAKE_ATOM("XV_CONTRAST");
xvSyncToVblank = MAKE_ATOM("XV_SYNC_TO_VBLANK");
+
+ return adaptor;
}