2003-11-14 17:48:57 +01:00
|
|
|
/***********************************************************
|
|
|
|
Copyright 1991 by Digital Equipment Corporation, Maynard, Massachusetts,
|
|
|
|
and the Massachusetts Institute of Technology, Cambridge, Massachusetts.
|
|
|
|
|
|
|
|
All Rights Reserved
|
|
|
|
|
|
|
|
Permission to use, copy, modify, and distribute this software and its
|
|
|
|
documentation for any purpose and without fee is hereby granted,
|
|
|
|
provided that the above copyright notice appear in all copies and that
|
|
|
|
both that copyright notice and this permission notice appear in
|
|
|
|
supporting documentation, and that the names of Digital or MIT not be
|
|
|
|
used in advertising or publicity pertaining to distribution of the
|
|
|
|
software without specific, written prior permission.
|
|
|
|
|
|
|
|
DIGITAL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING
|
|
|
|
ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL
|
|
|
|
DIGITAL BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL 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 PERFORMANCE OF THIS
|
|
|
|
SOFTWARE.
|
|
|
|
******************************************************************/
|
|
|
|
|
2005-07-03 09:02:09 +02:00
|
|
|
#ifdef HAVE_DIX_CONFIG_H
|
|
|
|
#include <dix-config.h>
|
|
|
|
#endif
|
|
|
|
|
2006-02-10 23:00:30 +01:00
|
|
|
#include <string.h>
|
|
|
|
|
2005-04-20 14:25:48 +02:00
|
|
|
#include <X11/X.h>
|
|
|
|
#include <X11/Xproto.h>
|
2005-07-03 10:53:54 +02:00
|
|
|
#include "misc.h"
|
2003-11-14 17:48:57 +01:00
|
|
|
#include "scrnintstr.h"
|
|
|
|
#include "windowstr.h"
|
|
|
|
#include "pixmapstr.h"
|
|
|
|
#include "gcstruct.h"
|
|
|
|
#include "dixstruct.h"
|
|
|
|
#include "resource.h"
|
|
|
|
#include "opaque.h"
|
|
|
|
|
2005-04-20 14:25:48 +02:00
|
|
|
#include <X11/extensions/Xv.h>
|
|
|
|
#include <X11/extensions/Xvproto.h>
|
2003-11-14 17:48:57 +01:00
|
|
|
#include "xvdix.h"
|
|
|
|
#ifdef MITSHM
|
2009-07-15 08:51:05 +02:00
|
|
|
#include <X11/extensions/shmproto.h>
|
2003-11-14 17:48:57 +01:00
|
|
|
#endif
|
|
|
|
|
2003-11-25 20:29:01 +01:00
|
|
|
#include "xvdisp.h"
|
|
|
|
|
2003-11-14 17:48:57 +01:00
|
|
|
#ifdef PANORAMIX
|
|
|
|
#include "panoramiX.h"
|
|
|
|
#include "panoramiXsrv.h"
|
|
|
|
|
|
|
|
unsigned long XvXRTPort;
|
|
|
|
#endif
|
|
|
|
|
2007-12-02 20:15:36 +01:00
|
|
|
static int
|
|
|
|
SWriteQueryExtensionReply(
|
|
|
|
ClientPtr client,
|
|
|
|
xvQueryExtensionReply *rep
|
|
|
|
){
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&rep->sequenceNumber);
|
|
|
|
swapl(&rep->length);
|
|
|
|
swaps(&rep->version);
|
|
|
|
swaps(&rep->revision);
|
2007-12-02 20:15:36 +01:00
|
|
|
|
2008-01-03 04:27:22 +01:00
|
|
|
(void)WriteToClient(client, sz_xvQueryExtensionReply, (char *)rep);
|
2007-12-02 20:15:36 +01:00
|
|
|
|
|
|
|
return Success;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SWriteQueryAdaptorsReply(
|
|
|
|
ClientPtr client,
|
|
|
|
xvQueryAdaptorsReply *rep
|
|
|
|
){
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&rep->sequenceNumber);
|
|
|
|
swapl(&rep->length);
|
|
|
|
swaps(&rep->num_adaptors);
|
2007-12-02 20:15:36 +01:00
|
|
|
|
2008-01-03 04:27:22 +01:00
|
|
|
(void)WriteToClient(client, sz_xvQueryAdaptorsReply, (char *)rep);
|
2007-12-02 20:15:36 +01:00
|
|
|
|
|
|
|
return Success;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SWriteQueryEncodingsReply(
|
|
|
|
ClientPtr client,
|
|
|
|
xvQueryEncodingsReply *rep
|
|
|
|
){
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&rep->sequenceNumber);
|
|
|
|
swapl(&rep->length);
|
|
|
|
swaps(&rep->num_encodings);
|
2007-12-02 20:15:36 +01:00
|
|
|
|
2008-01-03 04:27:22 +01:00
|
|
|
(void)WriteToClient(client, sz_xvQueryEncodingsReply, (char *)rep);
|
2007-12-02 20:15:36 +01:00
|
|
|
|
|
|
|
return Success;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SWriteAdaptorInfo(
|
|
|
|
ClientPtr client,
|
|
|
|
xvAdaptorInfo *pAdaptor
|
|
|
|
){
|
2011-08-04 21:35:41 +02:00
|
|
|
swapl(&pAdaptor->base_id);
|
|
|
|
swaps(&pAdaptor->name_size);
|
|
|
|
swaps(&pAdaptor->num_ports);
|
|
|
|
swaps(&pAdaptor->num_formats);
|
2007-12-02 20:15:36 +01:00
|
|
|
|
|
|
|
(void)WriteToClient(client, sz_xvAdaptorInfo, (char *)pAdaptor);
|
|
|
|
|
|
|
|
return Success;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SWriteEncodingInfo(
|
|
|
|
ClientPtr client,
|
|
|
|
xvEncodingInfo *pEncoding
|
|
|
|
){
|
|
|
|
|
2011-08-04 21:35:41 +02:00
|
|
|
swapl(&pEncoding->encoding);
|
|
|
|
swaps(&pEncoding->name_size);
|
|
|
|
swaps(&pEncoding->width);
|
|
|
|
swaps(&pEncoding->height);
|
|
|
|
swapl(&pEncoding->rate.numerator);
|
|
|
|
swapl(&pEncoding->rate.denominator);
|
2007-12-02 20:15:36 +01:00
|
|
|
(void)WriteToClient(client, sz_xvEncodingInfo, (char *)pEncoding);
|
|
|
|
|
|
|
|
return Success;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SWriteFormat(
|
|
|
|
ClientPtr client,
|
|
|
|
xvFormat *pFormat
|
|
|
|
){
|
2011-08-04 21:35:41 +02:00
|
|
|
swapl(&pFormat->visual);
|
2007-12-02 20:15:36 +01:00
|
|
|
(void)WriteToClient(client, sz_xvFormat, (char *)pFormat);
|
|
|
|
|
|
|
|
return Success;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SWriteAttributeInfo(
|
|
|
|
ClientPtr client,
|
|
|
|
xvAttributeInfo *pAtt
|
|
|
|
){
|
2011-08-04 21:35:41 +02:00
|
|
|
swapl(&pAtt->flags);
|
|
|
|
swapl(&pAtt->size);
|
|
|
|
swapl(&pAtt->min);
|
|
|
|
swapl(&pAtt->max);
|
2007-12-02 20:15:36 +01:00
|
|
|
(void)WriteToClient(client, sz_xvAttributeInfo, (char *)pAtt);
|
|
|
|
|
|
|
|
return Success;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SWriteImageFormatInfo(
|
|
|
|
ClientPtr client,
|
|
|
|
xvImageFormatInfo *pImage
|
|
|
|
){
|
2011-08-04 21:35:41 +02:00
|
|
|
swapl(&pImage->id);
|
|
|
|
swapl(&pImage->red_mask);
|
|
|
|
swapl(&pImage->green_mask);
|
|
|
|
swapl(&pImage->blue_mask);
|
|
|
|
swapl(&pImage->y_sample_bits);
|
|
|
|
swapl(&pImage->u_sample_bits);
|
|
|
|
swapl(&pImage->v_sample_bits);
|
|
|
|
swapl(&pImage->horz_y_period);
|
|
|
|
swapl(&pImage->horz_u_period);
|
|
|
|
swapl(&pImage->horz_v_period);
|
|
|
|
swapl(&pImage->vert_y_period);
|
|
|
|
swapl(&pImage->vert_u_period);
|
|
|
|
swapl(&pImage->vert_v_period);
|
2007-12-02 20:15:36 +01:00
|
|
|
|
|
|
|
(void)WriteToClient(client, sz_xvImageFormatInfo, (char *)pImage);
|
|
|
|
|
|
|
|
return Success;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SWriteGrabPortReply(
|
|
|
|
ClientPtr client,
|
|
|
|
xvGrabPortReply *rep
|
|
|
|
){
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&rep->sequenceNumber);
|
|
|
|
swapl(&rep->length);
|
2007-12-02 20:15:36 +01:00
|
|
|
|
2008-01-03 04:27:22 +01:00
|
|
|
(void)WriteToClient(client, sz_xvGrabPortReply, (char *)rep);
|
2007-12-02 20:15:36 +01:00
|
|
|
|
|
|
|
return Success;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SWriteGetPortAttributeReply(
|
|
|
|
ClientPtr client,
|
|
|
|
xvGetPortAttributeReply *rep
|
|
|
|
){
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&rep->sequenceNumber);
|
|
|
|
swapl(&rep->length);
|
|
|
|
swapl(&rep->value);
|
2007-12-02 20:15:36 +01:00
|
|
|
|
2008-01-03 04:27:22 +01:00
|
|
|
(void)WriteToClient(client, sz_xvGetPortAttributeReply, (char *)rep);
|
2007-12-02 20:15:36 +01:00
|
|
|
|
|
|
|
return Success;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SWriteQueryBestSizeReply(
|
|
|
|
ClientPtr client,
|
|
|
|
xvQueryBestSizeReply *rep
|
|
|
|
){
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&rep->sequenceNumber);
|
|
|
|
swapl(&rep->length);
|
|
|
|
swaps(&rep->actual_width);
|
|
|
|
swaps(&rep->actual_height);
|
2007-12-02 20:15:36 +01:00
|
|
|
|
2008-01-03 04:27:22 +01:00
|
|
|
(void)WriteToClient(client, sz_xvQueryBestSizeReply, (char *)rep);
|
2007-12-02 20:15:36 +01:00
|
|
|
|
|
|
|
return Success;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SWriteQueryPortAttributesReply(
|
|
|
|
ClientPtr client,
|
|
|
|
xvQueryPortAttributesReply *rep
|
|
|
|
){
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&rep->sequenceNumber);
|
|
|
|
swapl(&rep->length);
|
|
|
|
swapl(&rep->num_attributes);
|
|
|
|
swapl(&rep->text_size);
|
2007-12-02 20:15:36 +01:00
|
|
|
|
2008-01-03 04:27:22 +01:00
|
|
|
(void)WriteToClient(client, sz_xvQueryPortAttributesReply, (char *)rep);
|
2007-12-02 20:15:36 +01:00
|
|
|
|
|
|
|
return Success;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SWriteQueryImageAttributesReply(
|
|
|
|
ClientPtr client,
|
|
|
|
xvQueryImageAttributesReply *rep
|
|
|
|
){
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&rep->sequenceNumber);
|
|
|
|
swapl(&rep->length);
|
|
|
|
swapl(&rep->num_planes);
|
|
|
|
swapl(&rep->data_size);
|
|
|
|
swaps(&rep->width);
|
|
|
|
swaps(&rep->height);
|
2007-12-02 20:15:36 +01:00
|
|
|
|
2008-01-03 04:27:22 +01:00
|
|
|
(void)WriteToClient(client, sz_xvQueryImageAttributesReply, (char *)rep);
|
2007-12-02 20:15:36 +01:00
|
|
|
|
|
|
|
return Success;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SWriteListImageFormatsReply(
|
|
|
|
ClientPtr client,
|
|
|
|
xvListImageFormatsReply *rep
|
|
|
|
){
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&rep->sequenceNumber);
|
|
|
|
swapl(&rep->length);
|
|
|
|
swapl(&rep->num_formats);
|
2007-12-02 20:15:36 +01:00
|
|
|
|
2008-01-03 04:27:22 +01:00
|
|
|
(void)WriteToClient(client, sz_xvListImageFormatsReply, (char *)rep);
|
2007-12-02 20:15:36 +01:00
|
|
|
|
|
|
|
return Success;
|
|
|
|
}
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
#define _WriteQueryAdaptorsReply(_c,_d) \
|
|
|
|
if ((_c)->swapped) SWriteQueryAdaptorsReply(_c, _d); \
|
|
|
|
else WriteToClient(_c, sz_xvQueryAdaptorsReply, (char*)_d)
|
|
|
|
|
|
|
|
#define _WriteQueryExtensionReply(_c,_d) \
|
|
|
|
if ((_c)->swapped) SWriteQueryExtensionReply(_c, _d); \
|
|
|
|
else WriteToClient(_c, sz_xvQueryExtensionReply, (char*)_d)
|
|
|
|
|
|
|
|
#define _WriteQueryEncodingsReply(_c,_d) \
|
|
|
|
if ((_c)->swapped) SWriteQueryEncodingsReply(_c, _d); \
|
|
|
|
else WriteToClient(_c, sz_xvQueryEncodingsReply, (char*)_d)
|
|
|
|
|
|
|
|
#define _WriteAdaptorInfo(_c,_d) \
|
|
|
|
if ((_c)->swapped) SWriteAdaptorInfo(_c, _d); \
|
|
|
|
else WriteToClient(_c, sz_xvAdaptorInfo, (char*)_d)
|
|
|
|
|
|
|
|
#define _WriteAttributeInfo(_c,_d) \
|
|
|
|
if ((_c)->swapped) SWriteAttributeInfo(_c, _d); \
|
|
|
|
else WriteToClient(_c, sz_xvAttributeInfo, (char*)_d)
|
|
|
|
|
|
|
|
#define _WriteEncodingInfo(_c,_d) \
|
|
|
|
if ((_c)->swapped) SWriteEncodingInfo(_c, _d); \
|
|
|
|
else WriteToClient(_c, sz_xvEncodingInfo, (char*)_d)
|
|
|
|
|
|
|
|
#define _WriteFormat(_c,_d) \
|
|
|
|
if ((_c)->swapped) SWriteFormat(_c, _d); \
|
|
|
|
else WriteToClient(_c, sz_xvFormat, (char*)_d)
|
|
|
|
|
|
|
|
#define _WriteGrabPortReply(_c,_d) \
|
|
|
|
if ((_c)->swapped) SWriteGrabPortReply(_c, _d); \
|
|
|
|
else WriteToClient(_c, sz_xvGrabPortReply, (char*)_d)
|
|
|
|
|
|
|
|
#define _WriteGetPortAttributeReply(_c,_d) \
|
|
|
|
if ((_c)->swapped) SWriteGetPortAttributeReply(_c, _d); \
|
|
|
|
else WriteToClient(_c, sz_xvGetPortAttributeReply, (char*)_d)
|
|
|
|
|
|
|
|
#define _WriteQueryBestSizeReply(_c,_d) \
|
|
|
|
if ((_c)->swapped) SWriteQueryBestSizeReply(_c, _d); \
|
|
|
|
else WriteToClient(_c, sz_xvQueryBestSizeReply,(char*) _d)
|
|
|
|
|
|
|
|
#define _WriteQueryPortAttributesReply(_c,_d) \
|
|
|
|
if ((_c)->swapped) SWriteQueryPortAttributesReply(_c, _d); \
|
|
|
|
else WriteToClient(_c, sz_xvQueryPortAttributesReply,(char*) _d)
|
|
|
|
|
|
|
|
#define _WriteQueryImageAttributesReply(_c,_d) \
|
|
|
|
if ((_c)->swapped) SWriteQueryImageAttributesReply(_c, _d); \
|
|
|
|
else WriteToClient(_c, sz_xvQueryImageAttributesReply,(char*) _d)
|
|
|
|
|
|
|
|
#define _WriteListImageFormatsReply(_c,_d) \
|
|
|
|
if ((_c)->swapped) SWriteListImageFormatsReply(_c, _d); \
|
|
|
|
else WriteToClient(_c, sz_xvListImageFormatsReply,(char*) _d)
|
|
|
|
|
|
|
|
#define _WriteImageFormatInfo(_c,_d) \
|
|
|
|
if ((_c)->swapped) SWriteImageFormatInfo(_c, _d); \
|
|
|
|
else WriteToClient(_c, sz_xvImageFormatInfo, (char*)_d)
|
|
|
|
|
|
|
|
#define _AllocatePort(_i,_p) \
|
|
|
|
((_p)->id != _i) ? (* (_p)->pAdaptor->ddAllocatePort)(_i,_p,&_p) : Success
|
|
|
|
|
|
|
|
static int
|
|
|
|
ProcXvQueryExtension(ClientPtr client)
|
|
|
|
{
|
|
|
|
xvQueryExtensionReply rep;
|
|
|
|
/* REQUEST(xvQueryExtensionReq); */
|
|
|
|
REQUEST_SIZE_MATCH(xvQueryExtensionReq);
|
|
|
|
|
|
|
|
rep.type = X_Reply;
|
|
|
|
rep.sequenceNumber = client->sequence;
|
|
|
|
rep.length = 0;
|
|
|
|
rep.version = XvVersion;
|
|
|
|
rep.revision = XvRevision;
|
|
|
|
|
|
|
|
_WriteQueryExtensionReply(client, &rep);
|
|
|
|
|
|
|
|
return Success;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
ProcXvQueryAdaptors(ClientPtr client)
|
|
|
|
{
|
|
|
|
xvFormat format;
|
|
|
|
xvAdaptorInfo ainfo;
|
|
|
|
xvQueryAdaptorsReply rep;
|
2006-12-15 20:11:40 +01:00
|
|
|
int totalSize, na, nf, rc;
|
2008-01-03 04:27:22 +01:00
|
|
|
int nameSize;
|
2003-11-14 17:48:57 +01:00
|
|
|
XvAdaptorPtr pa;
|
|
|
|
XvFormatPtr pf;
|
|
|
|
WindowPtr pWin;
|
|
|
|
ScreenPtr pScreen;
|
|
|
|
XvScreenPtr pxvs;
|
|
|
|
|
|
|
|
REQUEST(xvQueryAdaptorsReq);
|
|
|
|
REQUEST_SIZE_MATCH(xvQueryAdaptorsReq);
|
|
|
|
|
2007-09-25 15:56:00 +02:00
|
|
|
rc = dixLookupWindow(&pWin, stuff->window, client, DixGetAttrAccess);
|
2006-12-15 20:11:40 +01:00
|
|
|
if (rc != Success)
|
|
|
|
return rc;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
pScreen = pWin->drawable.pScreen;
|
2007-08-28 15:28:25 +02:00
|
|
|
pxvs = (XvScreenPtr)dixLookupPrivate(&pScreen->devPrivates,
|
|
|
|
XvGetScreenKey());
|
2003-11-14 17:48:57 +01:00
|
|
|
if (!pxvs)
|
|
|
|
{
|
|
|
|
rep.type = X_Reply;
|
|
|
|
rep.sequenceNumber = client->sequence;
|
|
|
|
rep.num_adaptors = 0;
|
|
|
|
rep.length = 0;
|
|
|
|
|
|
|
|
_WriteQueryAdaptorsReply(client, &rep);
|
|
|
|
|
|
|
|
return Success;
|
|
|
|
}
|
|
|
|
|
|
|
|
(* pxvs->ddQueryAdaptors)(pScreen, &pxvs->pAdaptors, &pxvs->nAdaptors);
|
|
|
|
|
|
|
|
rep.type = X_Reply;
|
|
|
|
rep.sequenceNumber = client->sequence;
|
|
|
|
rep.num_adaptors = pxvs->nAdaptors;
|
|
|
|
|
|
|
|
/* CALCULATE THE TOTAL SIZE OF THE REPLY IN BYTES */
|
|
|
|
|
|
|
|
totalSize = pxvs->nAdaptors * sz_xvAdaptorInfo;
|
|
|
|
|
|
|
|
/* FOR EACH ADPATOR ADD UP THE BYTES FOR ENCODINGS AND FORMATS */
|
|
|
|
|
|
|
|
na = pxvs->nAdaptors;
|
|
|
|
pa = pxvs->pAdaptors;
|
|
|
|
while (na--)
|
|
|
|
{
|
2009-07-06 04:20:21 +02:00
|
|
|
totalSize += pad_to_int32(strlen(pa->name));
|
2003-11-14 17:48:57 +01:00
|
|
|
totalSize += pa->nFormats * sz_xvFormat;
|
|
|
|
pa++;
|
|
|
|
}
|
|
|
|
|
2009-07-06 04:20:21 +02:00
|
|
|
rep.length = bytes_to_int32(totalSize);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
_WriteQueryAdaptorsReply(client, &rep);
|
|
|
|
|
|
|
|
na = pxvs->nAdaptors;
|
|
|
|
pa = pxvs->pAdaptors;
|
|
|
|
while (na--)
|
|
|
|
{
|
|
|
|
|
|
|
|
ainfo.base_id = pa->base_id;
|
|
|
|
ainfo.num_ports = pa->nPorts;
|
|
|
|
ainfo.type = pa->type;
|
2008-01-03 04:27:22 +01:00
|
|
|
ainfo.name_size = nameSize = strlen(pa->name);
|
2003-11-14 17:48:57 +01:00
|
|
|
ainfo.num_formats = pa->nFormats;
|
|
|
|
|
|
|
|
_WriteAdaptorInfo(client, &ainfo);
|
|
|
|
|
2008-01-03 04:27:22 +01:00
|
|
|
WriteToClient(client, nameSize, pa->name);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
nf = pa->nFormats;
|
|
|
|
pf = pa->pFormats;
|
|
|
|
while (nf--)
|
|
|
|
{
|
|
|
|
format.depth = pf->depth;
|
|
|
|
format.visual = pf->visual;
|
|
|
|
_WriteFormat(client, &format);
|
|
|
|
pf++;
|
|
|
|
}
|
|
|
|
|
|
|
|
pa++;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2010-05-11 05:22:05 +02:00
|
|
|
return Success;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
ProcXvQueryEncodings(ClientPtr client)
|
|
|
|
{
|
|
|
|
xvEncodingInfo einfo;
|
|
|
|
xvQueryEncodingsReply rep;
|
|
|
|
int totalSize;
|
2008-01-03 04:27:22 +01:00
|
|
|
int nameSize;
|
2003-11-14 17:48:57 +01:00
|
|
|
XvPortPtr pPort;
|
|
|
|
int ne;
|
|
|
|
XvEncodingPtr pe;
|
|
|
|
int status;
|
|
|
|
|
|
|
|
REQUEST(xvQueryEncodingsReq);
|
|
|
|
REQUEST_SIZE_MATCH(xvQueryEncodingsReq);
|
|
|
|
|
2009-04-29 07:04:37 +02:00
|
|
|
VALIDATE_XV_PORT(stuff->port, pPort, DixReadAccess);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
if ((status = _AllocatePort(stuff->port, pPort)) != Success)
|
|
|
|
{
|
|
|
|
client->errorValue = stuff->port;
|
2010-06-06 16:18:40 +02:00
|
|
|
return status;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
rep.type = X_Reply;
|
|
|
|
rep.sequenceNumber = client->sequence;
|
|
|
|
rep.num_encodings = pPort->pAdaptor->nEncodings;
|
|
|
|
|
|
|
|
/* FOR EACH ENCODING ADD UP THE BYTES FOR ENCODING NAMES */
|
|
|
|
|
|
|
|
ne = pPort->pAdaptor->nEncodings;
|
|
|
|
pe = pPort->pAdaptor->pEncodings;
|
|
|
|
totalSize = ne * sz_xvEncodingInfo;
|
|
|
|
while (ne--)
|
|
|
|
{
|
2009-07-06 04:20:21 +02:00
|
|
|
totalSize += pad_to_int32(strlen(pe->name));
|
2003-11-14 17:48:57 +01:00
|
|
|
pe++;
|
|
|
|
}
|
|
|
|
|
2009-07-06 04:20:21 +02:00
|
|
|
rep.length = bytes_to_int32(totalSize);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
_WriteQueryEncodingsReply(client, &rep);
|
|
|
|
|
|
|
|
ne = pPort->pAdaptor->nEncodings;
|
|
|
|
pe = pPort->pAdaptor->pEncodings;
|
|
|
|
while (ne--)
|
|
|
|
{
|
|
|
|
einfo.encoding = pe->id;
|
2008-01-03 04:27:22 +01:00
|
|
|
einfo.name_size = nameSize = strlen(pe->name);
|
2003-11-14 17:48:57 +01:00
|
|
|
einfo.width = pe->width;
|
|
|
|
einfo.height = pe->height;
|
|
|
|
einfo.rate.numerator = pe->rate.numerator;
|
|
|
|
einfo.rate.denominator = pe->rate.denominator;
|
|
|
|
_WriteEncodingInfo(client, &einfo);
|
2008-01-03 04:27:22 +01:00
|
|
|
WriteToClient(client, nameSize, pe->name);
|
2003-11-14 17:48:57 +01:00
|
|
|
pe++;
|
|
|
|
}
|
|
|
|
|
2010-05-11 05:22:05 +02:00
|
|
|
return Success;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
ProcXvPutVideo(ClientPtr client)
|
|
|
|
{
|
2006-12-15 01:15:21 +01:00
|
|
|
DrawablePtr pDraw;
|
2003-11-14 17:48:57 +01:00
|
|
|
XvPortPtr pPort;
|
2006-12-15 01:15:21 +01:00
|
|
|
GCPtr pGC;
|
2003-11-14 17:48:57 +01:00
|
|
|
int status;
|
|
|
|
|
|
|
|
REQUEST(xvPutVideoReq);
|
|
|
|
REQUEST_SIZE_MATCH(xvPutVideoReq);
|
|
|
|
|
2007-09-25 15:33:51 +02:00
|
|
|
VALIDATE_DRAWABLE_AND_GC(stuff->drawable, pDraw, DixWriteAccess);
|
2009-04-29 07:04:37 +02:00
|
|
|
VALIDATE_XV_PORT(stuff->port, pPort, DixReadAccess);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
if ((status = _AllocatePort(stuff->port, pPort)) != Success)
|
|
|
|
{
|
|
|
|
client->errorValue = stuff->port;
|
2010-06-06 16:18:40 +02:00
|
|
|
return status;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (!(pPort->pAdaptor->type & XvInputMask) ||
|
|
|
|
!(pPort->pAdaptor->type & XvVideoMask))
|
|
|
|
{
|
|
|
|
client->errorValue = stuff->port;
|
2010-06-06 16:18:40 +02:00
|
|
|
return BadMatch;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
2008-12-19 16:27:37 +01:00
|
|
|
status = XvdiMatchPort(pPort, pDraw);
|
2003-11-14 17:48:57 +01:00
|
|
|
if (status != Success)
|
|
|
|
{
|
|
|
|
return status;
|
|
|
|
}
|
|
|
|
|
2008-12-19 16:27:37 +01:00
|
|
|
return XvdiPutVideo(client, pDraw, pPort, pGC, stuff->vid_x, stuff->vid_y,
|
|
|
|
stuff->vid_w, stuff->vid_h, stuff->drw_x, stuff->drw_y,
|
|
|
|
stuff->drw_w, stuff->drw_h);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
ProcXvPutStill(ClientPtr client)
|
|
|
|
{
|
2006-12-15 01:15:21 +01:00
|
|
|
DrawablePtr pDraw;
|
2003-11-14 17:48:57 +01:00
|
|
|
XvPortPtr pPort;
|
2006-12-15 01:15:21 +01:00
|
|
|
GCPtr pGC;
|
2003-11-14 17:48:57 +01:00
|
|
|
int status;
|
|
|
|
|
|
|
|
REQUEST(xvPutStillReq);
|
|
|
|
REQUEST_SIZE_MATCH(xvPutStillReq);
|
|
|
|
|
2007-09-25 15:33:51 +02:00
|
|
|
VALIDATE_DRAWABLE_AND_GC(stuff->drawable, pDraw, DixWriteAccess);
|
2009-04-29 07:04:37 +02:00
|
|
|
VALIDATE_XV_PORT(stuff->port, pPort, DixReadAccess);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
if ((status = _AllocatePort(stuff->port, pPort)) != Success)
|
|
|
|
{
|
|
|
|
client->errorValue = stuff->port;
|
2010-06-06 16:18:40 +02:00
|
|
|
return status;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (!(pPort->pAdaptor->type & XvInputMask) ||
|
|
|
|
!(pPort->pAdaptor->type & XvStillMask))
|
|
|
|
{
|
|
|
|
client->errorValue = stuff->port;
|
2010-06-06 16:18:40 +02:00
|
|
|
return BadMatch;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
2008-12-19 16:27:37 +01:00
|
|
|
status = XvdiMatchPort(pPort, pDraw);
|
2003-11-14 17:48:57 +01:00
|
|
|
if (status != Success)
|
|
|
|
{
|
|
|
|
return status;
|
|
|
|
}
|
|
|
|
|
2008-12-19 16:27:37 +01:00
|
|
|
return XvdiPutStill(client, pDraw, pPort, pGC, stuff->vid_x, stuff->vid_y,
|
|
|
|
stuff->vid_w, stuff->vid_h, stuff->drw_x, stuff->drw_y,
|
|
|
|
stuff->drw_w, stuff->drw_h);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
ProcXvGetVideo(ClientPtr client)
|
|
|
|
{
|
2006-12-15 01:15:21 +01:00
|
|
|
DrawablePtr pDraw;
|
2003-11-14 17:48:57 +01:00
|
|
|
XvPortPtr pPort;
|
2006-12-15 01:15:21 +01:00
|
|
|
GCPtr pGC;
|
2003-11-14 17:48:57 +01:00
|
|
|
int status;
|
|
|
|
|
|
|
|
REQUEST(xvGetVideoReq);
|
|
|
|
REQUEST_SIZE_MATCH(xvGetVideoReq);
|
|
|
|
|
2007-09-25 15:33:51 +02:00
|
|
|
VALIDATE_DRAWABLE_AND_GC(stuff->drawable, pDraw, DixReadAccess);
|
2009-04-29 07:04:37 +02:00
|
|
|
VALIDATE_XV_PORT(stuff->port, pPort, DixReadAccess);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
if ((status = _AllocatePort(stuff->port, pPort)) != Success)
|
|
|
|
{
|
|
|
|
client->errorValue = stuff->port;
|
2010-06-06 16:18:40 +02:00
|
|
|
return status;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (!(pPort->pAdaptor->type & XvOutputMask) ||
|
|
|
|
!(pPort->pAdaptor->type & XvVideoMask))
|
|
|
|
{
|
|
|
|
client->errorValue = stuff->port;
|
2010-06-06 16:18:40 +02:00
|
|
|
return BadMatch;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
2008-12-19 16:27:37 +01:00
|
|
|
status = XvdiMatchPort(pPort, pDraw);
|
2003-11-14 17:48:57 +01:00
|
|
|
if (status != Success)
|
|
|
|
{
|
|
|
|
return status;
|
|
|
|
}
|
|
|
|
|
2008-12-19 16:27:37 +01:00
|
|
|
return XvdiGetVideo(client, pDraw, pPort, pGC, stuff->vid_x, stuff->vid_y,
|
|
|
|
stuff->vid_w, stuff->vid_h, stuff->drw_x, stuff->drw_y,
|
|
|
|
stuff->drw_w, stuff->drw_h);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
ProcXvGetStill(ClientPtr client)
|
|
|
|
{
|
2006-12-15 01:15:21 +01:00
|
|
|
DrawablePtr pDraw;
|
2003-11-14 17:48:57 +01:00
|
|
|
XvPortPtr pPort;
|
2006-12-15 01:15:21 +01:00
|
|
|
GCPtr pGC;
|
2003-11-14 17:48:57 +01:00
|
|
|
int status;
|
|
|
|
|
|
|
|
REQUEST(xvGetStillReq);
|
|
|
|
REQUEST_SIZE_MATCH(xvGetStillReq);
|
|
|
|
|
2007-09-25 15:33:51 +02:00
|
|
|
VALIDATE_DRAWABLE_AND_GC(stuff->drawable, pDraw, DixReadAccess);
|
2009-04-29 07:04:37 +02:00
|
|
|
VALIDATE_XV_PORT(stuff->port, pPort, DixReadAccess);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
if ((status = _AllocatePort(stuff->port, pPort)) != Success)
|
|
|
|
{
|
|
|
|
client->errorValue = stuff->port;
|
2010-06-06 16:18:40 +02:00
|
|
|
return status;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (!(pPort->pAdaptor->type & XvOutputMask) ||
|
|
|
|
!(pPort->pAdaptor->type & XvStillMask))
|
|
|
|
{
|
|
|
|
client->errorValue = stuff->port;
|
2010-06-06 16:18:40 +02:00
|
|
|
return BadMatch;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
2008-12-19 16:27:37 +01:00
|
|
|
status = XvdiMatchPort(pPort, pDraw);
|
2003-11-14 17:48:57 +01:00
|
|
|
if (status != Success)
|
|
|
|
{
|
|
|
|
return status;
|
|
|
|
}
|
|
|
|
|
2008-12-19 16:27:37 +01:00
|
|
|
return XvdiGetStill(client, pDraw, pPort, pGC, stuff->vid_x, stuff->vid_y,
|
|
|
|
stuff->vid_w, stuff->vid_h, stuff->drw_x, stuff->drw_y,
|
|
|
|
stuff->drw_w, stuff->drw_h);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
ProcXvSelectVideoNotify(ClientPtr client)
|
|
|
|
{
|
2006-12-14 23:27:12 +01:00
|
|
|
DrawablePtr pDraw;
|
|
|
|
int rc;
|
2003-11-14 17:48:57 +01:00
|
|
|
REQUEST(xvSelectVideoNotifyReq);
|
|
|
|
REQUEST_SIZE_MATCH(xvSelectVideoNotifyReq);
|
|
|
|
|
2007-09-25 15:56:00 +02:00
|
|
|
rc = dixLookupDrawable(&pDraw, stuff->drawable, client, 0, DixReceiveAccess);
|
2006-12-14 23:27:12 +01:00
|
|
|
if (rc != Success)
|
|
|
|
return rc;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
2008-12-19 16:27:37 +01:00
|
|
|
return XvdiSelectVideoNotify(client, pDraw, stuff->onoff);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
ProcXvSelectPortNotify(ClientPtr client)
|
|
|
|
{
|
|
|
|
int status;
|
|
|
|
XvPortPtr pPort;
|
|
|
|
REQUEST(xvSelectPortNotifyReq);
|
|
|
|
REQUEST_SIZE_MATCH(xvSelectPortNotifyReq);
|
|
|
|
|
2009-04-29 07:04:37 +02:00
|
|
|
VALIDATE_XV_PORT(stuff->port, pPort, DixReadAccess);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
if ((status = _AllocatePort(stuff->port, pPort)) != Success)
|
|
|
|
{
|
|
|
|
client->errorValue = stuff->port;
|
2010-06-06 16:18:40 +02:00
|
|
|
return status;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
2008-12-19 16:27:37 +01:00
|
|
|
return XvdiSelectPortNotify(client, pPort, stuff->onoff);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
ProcXvGrabPort(ClientPtr client)
|
|
|
|
{
|
|
|
|
int result, status;
|
|
|
|
XvPortPtr pPort;
|
|
|
|
xvGrabPortReply rep;
|
|
|
|
REQUEST(xvGrabPortReq);
|
|
|
|
REQUEST_SIZE_MATCH(xvGrabPortReq);
|
|
|
|
|
2009-04-29 07:04:37 +02:00
|
|
|
VALIDATE_XV_PORT(stuff->port, pPort, DixReadAccess);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
if ((status = _AllocatePort(stuff->port, pPort)) != Success)
|
|
|
|
{
|
|
|
|
client->errorValue = stuff->port;
|
2010-06-06 16:18:40 +02:00
|
|
|
return status;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
2008-12-19 16:27:37 +01:00
|
|
|
status = XvdiGrabPort(client, pPort, stuff->time, &result);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
if (status != Success)
|
|
|
|
{
|
|
|
|
return status;
|
|
|
|
}
|
|
|
|
|
|
|
|
rep.type = X_Reply;
|
|
|
|
rep.sequenceNumber = client->sequence;
|
|
|
|
rep.length = 0;
|
|
|
|
rep.result = result;
|
|
|
|
|
|
|
|
_WriteGrabPortReply(client, &rep);
|
|
|
|
|
|
|
|
return Success;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
ProcXvUngrabPort(ClientPtr client)
|
|
|
|
{
|
|
|
|
int status;
|
|
|
|
XvPortPtr pPort;
|
|
|
|
REQUEST(xvGrabPortReq);
|
|
|
|
REQUEST_SIZE_MATCH(xvGrabPortReq);
|
|
|
|
|
2009-04-29 07:04:37 +02:00
|
|
|
VALIDATE_XV_PORT(stuff->port, pPort, DixReadAccess);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
if ((status = _AllocatePort(stuff->port, pPort)) != Success)
|
|
|
|
{
|
|
|
|
client->errorValue = stuff->port;
|
2010-06-06 16:18:40 +02:00
|
|
|
return status;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
2008-12-19 16:27:37 +01:00
|
|
|
return XvdiUngrabPort(client, pPort, stuff->time);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
ProcXvStopVideo(ClientPtr client)
|
|
|
|
{
|
2006-12-14 23:27:12 +01:00
|
|
|
int status, rc;
|
|
|
|
DrawablePtr pDraw;
|
2003-11-14 17:48:57 +01:00
|
|
|
XvPortPtr pPort;
|
|
|
|
REQUEST(xvStopVideoReq);
|
|
|
|
REQUEST_SIZE_MATCH(xvStopVideoReq);
|
|
|
|
|
2009-04-29 07:04:37 +02:00
|
|
|
VALIDATE_XV_PORT(stuff->port, pPort, DixReadAccess);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
if ((status = _AllocatePort(stuff->port, pPort)) != Success)
|
|
|
|
{
|
|
|
|
client->errorValue = stuff->port;
|
2010-06-06 16:18:40 +02:00
|
|
|
return status;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
2007-09-25 15:56:00 +02:00
|
|
|
rc = dixLookupDrawable(&pDraw, stuff->drawable, client, 0, DixWriteAccess);
|
2006-12-14 23:27:12 +01:00
|
|
|
if (rc != Success)
|
|
|
|
return rc;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
2008-12-19 16:27:37 +01:00
|
|
|
return XvdiStopVideo(client, pPort, pDraw);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
ProcXvSetPortAttribute(ClientPtr client)
|
|
|
|
{
|
|
|
|
int status;
|
|
|
|
XvPortPtr pPort;
|
|
|
|
REQUEST(xvSetPortAttributeReq);
|
|
|
|
REQUEST_SIZE_MATCH(xvSetPortAttributeReq);
|
|
|
|
|
2009-04-29 07:04:37 +02:00
|
|
|
VALIDATE_XV_PORT(stuff->port, pPort, DixSetAttrAccess);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
if ((status = _AllocatePort(stuff->port, pPort)) != Success)
|
|
|
|
{
|
|
|
|
client->errorValue = stuff->port;
|
2010-06-06 16:18:40 +02:00
|
|
|
return status;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (!ValidAtom(stuff->attribute))
|
|
|
|
{
|
|
|
|
client->errorValue = stuff->attribute;
|
2010-06-06 16:18:40 +02:00
|
|
|
return BadAtom;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
2008-12-19 16:27:37 +01:00
|
|
|
status = XvdiSetPortAttribute(client, pPort, stuff->attribute, stuff->value);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
if (status == BadMatch)
|
|
|
|
client->errorValue = stuff->attribute;
|
|
|
|
else
|
|
|
|
client->errorValue = stuff->value;
|
|
|
|
|
|
|
|
return status;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
ProcXvGetPortAttribute(ClientPtr client)
|
|
|
|
{
|
|
|
|
INT32 value;
|
|
|
|
int status;
|
|
|
|
XvPortPtr pPort;
|
|
|
|
xvGetPortAttributeReply rep;
|
|
|
|
REQUEST(xvGetPortAttributeReq);
|
|
|
|
REQUEST_SIZE_MATCH(xvGetPortAttributeReq);
|
|
|
|
|
2009-04-29 07:04:37 +02:00
|
|
|
VALIDATE_XV_PORT(stuff->port, pPort, DixGetAttrAccess);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
if ((status = _AllocatePort(stuff->port, pPort)) != Success)
|
|
|
|
{
|
|
|
|
client->errorValue = stuff->port;
|
2010-06-06 16:18:40 +02:00
|
|
|
return status;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (!ValidAtom(stuff->attribute))
|
|
|
|
{
|
|
|
|
client->errorValue = stuff->attribute;
|
2010-06-06 16:18:40 +02:00
|
|
|
return BadAtom;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
2008-12-19 16:27:37 +01:00
|
|
|
status = XvdiGetPortAttribute(client, pPort, stuff->attribute, &value);
|
2003-11-14 17:48:57 +01:00
|
|
|
if (status != Success)
|
|
|
|
{
|
|
|
|
client->errorValue = stuff->attribute;
|
|
|
|
return status;
|
|
|
|
}
|
|
|
|
|
|
|
|
rep.type = X_Reply;
|
|
|
|
rep.sequenceNumber = client->sequence;
|
|
|
|
rep.length = 0;
|
|
|
|
rep.value = value;
|
|
|
|
|
|
|
|
_WriteGetPortAttributeReply(client, &rep);
|
|
|
|
|
|
|
|
return Success;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
ProcXvQueryBestSize(ClientPtr client)
|
|
|
|
{
|
|
|
|
int status;
|
|
|
|
unsigned int actual_width, actual_height;
|
|
|
|
XvPortPtr pPort;
|
|
|
|
xvQueryBestSizeReply rep;
|
|
|
|
REQUEST(xvQueryBestSizeReq);
|
|
|
|
REQUEST_SIZE_MATCH(xvQueryBestSizeReq);
|
|
|
|
|
2009-04-29 07:04:37 +02:00
|
|
|
VALIDATE_XV_PORT(stuff->port, pPort, DixReadAccess);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
if ((status = _AllocatePort(stuff->port, pPort)) != Success)
|
|
|
|
{
|
|
|
|
client->errorValue = stuff->port;
|
2010-06-06 16:18:40 +02:00
|
|
|
return status;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
rep.type = X_Reply;
|
|
|
|
rep.sequenceNumber = client->sequence;
|
|
|
|
rep.length = 0;
|
|
|
|
|
|
|
|
(* pPort->pAdaptor->ddQueryBestSize)(client, pPort, stuff->motion,
|
|
|
|
stuff->vid_w, stuff->vid_h,
|
|
|
|
stuff->drw_w, stuff->drw_h,
|
|
|
|
&actual_width, &actual_height);
|
|
|
|
|
|
|
|
rep.actual_width = actual_width;
|
|
|
|
rep.actual_height = actual_height;
|
|
|
|
|
|
|
|
_WriteQueryBestSizeReply(client, &rep);
|
|
|
|
|
|
|
|
return Success;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static int
|
|
|
|
ProcXvQueryPortAttributes(ClientPtr client)
|
|
|
|
{
|
|
|
|
int status, size, i;
|
|
|
|
XvPortPtr pPort;
|
|
|
|
XvAttributePtr pAtt;
|
|
|
|
xvQueryPortAttributesReply rep;
|
|
|
|
xvAttributeInfo Info;
|
|
|
|
REQUEST(xvQueryPortAttributesReq);
|
|
|
|
REQUEST_SIZE_MATCH(xvQueryPortAttributesReq);
|
|
|
|
|
2009-04-29 07:04:37 +02:00
|
|
|
VALIDATE_XV_PORT(stuff->port, pPort, DixGetAttrAccess);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
if ((status = _AllocatePort(stuff->port, pPort)) != Success)
|
|
|
|
{
|
|
|
|
client->errorValue = stuff->port;
|
2010-06-06 16:18:40 +02:00
|
|
|
return status;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
rep.type = X_Reply;
|
|
|
|
rep.sequenceNumber = client->sequence;
|
|
|
|
rep.num_attributes = pPort->pAdaptor->nAttributes;
|
|
|
|
rep.text_size = 0;
|
|
|
|
|
|
|
|
for(i = 0, pAtt = pPort->pAdaptor->pAttributes;
|
2008-01-03 04:27:22 +01:00
|
|
|
i < pPort->pAdaptor->nAttributes; i++, pAtt++)
|
2003-11-14 17:48:57 +01:00
|
|
|
{
|
2009-07-06 04:20:21 +02:00
|
|
|
rep.text_size += pad_to_int32(strlen(pAtt->name) + 1);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
2008-01-03 04:27:22 +01:00
|
|
|
rep.length = (pPort->pAdaptor->nAttributes * sz_xvAttributeInfo)
|
|
|
|
+ rep.text_size;
|
2003-11-14 17:48:57 +01:00
|
|
|
rep.length >>= 2;
|
|
|
|
|
|
|
|
_WriteQueryPortAttributesReply(client, &rep);
|
|
|
|
|
|
|
|
for(i = 0, pAtt = pPort->pAdaptor->pAttributes;
|
2008-01-03 04:27:22 +01:00
|
|
|
i < pPort->pAdaptor->nAttributes; i++, pAtt++)
|
2003-11-14 17:48:57 +01:00
|
|
|
{
|
|
|
|
size = strlen(pAtt->name) + 1; /* pass the NULL */
|
|
|
|
Info.flags = pAtt->flags;
|
|
|
|
Info.min = pAtt->min_value;
|
|
|
|
Info.max = pAtt->max_value;
|
2009-07-06 04:20:21 +02:00
|
|
|
Info.size = pad_to_int32(size);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
_WriteAttributeInfo(client, &Info);
|
|
|
|
|
|
|
|
WriteToClient(client, size, pAtt->name);
|
|
|
|
}
|
|
|
|
|
|
|
|
return Success;
|
2007-12-02 20:15:36 +01:00
|
|
|
}
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
static int
|
|
|
|
ProcXvPutImage(ClientPtr client)
|
|
|
|
{
|
|
|
|
DrawablePtr pDraw;
|
|
|
|
XvPortPtr pPort;
|
|
|
|
XvImagePtr pImage = NULL;
|
|
|
|
GCPtr pGC;
|
|
|
|
int status, i, size;
|
|
|
|
CARD16 width, height;
|
|
|
|
|
|
|
|
REQUEST(xvPutImageReq);
|
|
|
|
REQUEST_AT_LEAST_SIZE(xvPutImageReq);
|
|
|
|
|
2007-09-25 15:33:51 +02:00
|
|
|
VALIDATE_DRAWABLE_AND_GC(stuff->drawable, pDraw, DixWriteAccess);
|
2009-04-29 07:04:37 +02:00
|
|
|
VALIDATE_XV_PORT(stuff->port, pPort, DixReadAccess);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
if ((status = _AllocatePort(stuff->port, pPort)) != Success)
|
|
|
|
{
|
|
|
|
client->errorValue = stuff->port;
|
2010-06-06 16:18:40 +02:00
|
|
|
return status;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (!(pPort->pAdaptor->type & XvImageMask) ||
|
|
|
|
!(pPort->pAdaptor->type & XvInputMask))
|
|
|
|
{
|
|
|
|
client->errorValue = stuff->port;
|
2010-06-06 16:18:40 +02:00
|
|
|
return BadMatch;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
2008-12-19 16:27:37 +01:00
|
|
|
status = XvdiMatchPort(pPort, pDraw);
|
2003-11-14 17:48:57 +01:00
|
|
|
if (status != Success)
|
|
|
|
{
|
|
|
|
return status;
|
|
|
|
}
|
|
|
|
|
|
|
|
for(i = 0; i < pPort->pAdaptor->nImages; i++) {
|
|
|
|
if(pPort->pAdaptor->pImages[i].id == stuff->id) {
|
|
|
|
pImage = &(pPort->pAdaptor->pImages[i]);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if(!pImage)
|
|
|
|
return BadMatch;
|
|
|
|
|
|
|
|
width = stuff->width;
|
|
|
|
height = stuff->height;
|
|
|
|
size = (*pPort->pAdaptor->ddQueryImageAttributes)(client,
|
|
|
|
pPort, pImage, &width, &height, NULL, NULL);
|
|
|
|
size += sizeof(xvPutImageReq);
|
2009-07-06 04:20:21 +02:00
|
|
|
size = bytes_to_int32(size);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
if((width < stuff->width) || (height < stuff->height))
|
|
|
|
return BadValue;
|
|
|
|
|
|
|
|
if(client->req_len < size)
|
|
|
|
return BadLength;
|
|
|
|
|
2008-12-19 16:27:37 +01:00
|
|
|
return XvdiPutImage(client, pDraw, pPort, pGC, stuff->src_x, stuff->src_y,
|
|
|
|
stuff->src_w, stuff->src_h, stuff->drw_x, stuff->drw_y,
|
|
|
|
stuff->drw_w, stuff->drw_h, pImage,
|
|
|
|
(unsigned char*)(&stuff[1]), FALSE,
|
|
|
|
stuff->width, stuff->height);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef MITSHM
|
|
|
|
/* redefined here since it's not in any header file */
|
|
|
|
typedef struct _ShmDesc {
|
|
|
|
struct _ShmDesc *next;
|
|
|
|
int shmid;
|
|
|
|
int refcnt;
|
|
|
|
char *addr;
|
|
|
|
Bool writable;
|
|
|
|
unsigned long size;
|
|
|
|
} ShmDescRec, *ShmDescPtr;
|
|
|
|
|
|
|
|
extern RESTYPE ShmSegType;
|
|
|
|
extern int ShmCompletionCode;
|
|
|
|
|
|
|
|
static int
|
|
|
|
ProcXvShmPutImage(ClientPtr client)
|
|
|
|
{
|
|
|
|
ShmDescPtr shmdesc;
|
|
|
|
DrawablePtr pDraw;
|
|
|
|
XvPortPtr pPort;
|
|
|
|
XvImagePtr pImage = NULL;
|
|
|
|
GCPtr pGC;
|
|
|
|
int status, size_needed, i;
|
|
|
|
CARD16 width, height;
|
|
|
|
|
|
|
|
REQUEST(xvShmPutImageReq);
|
|
|
|
REQUEST_SIZE_MATCH(xvShmPutImageReq);
|
|
|
|
|
2007-09-25 15:33:51 +02:00
|
|
|
VALIDATE_DRAWABLE_AND_GC(stuff->drawable, pDraw, DixWriteAccess);
|
2009-04-29 07:04:37 +02:00
|
|
|
VALIDATE_XV_PORT(stuff->port, pPort, DixReadAccess);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
if ((status = _AllocatePort(stuff->port, pPort)) != Success)
|
|
|
|
{
|
|
|
|
client->errorValue = stuff->port;
|
2010-06-06 16:18:40 +02:00
|
|
|
return status;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (!(pPort->pAdaptor->type & XvImageMask) ||
|
|
|
|
!(pPort->pAdaptor->type & XvInputMask))
|
|
|
|
{
|
|
|
|
client->errorValue = stuff->port;
|
2010-06-06 16:18:40 +02:00
|
|
|
return BadMatch;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
2008-12-19 16:27:37 +01:00
|
|
|
status = XvdiMatchPort(pPort, pDraw);
|
2003-11-14 17:48:57 +01:00
|
|
|
if (status != Success)
|
|
|
|
{
|
|
|
|
return status;
|
|
|
|
}
|
|
|
|
|
|
|
|
for(i = 0; i < pPort->pAdaptor->nImages; i++) {
|
|
|
|
if(pPort->pAdaptor->pImages[i].id == stuff->id) {
|
|
|
|
pImage = &(pPort->pAdaptor->pImages[i]);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if(!pImage)
|
|
|
|
return BadMatch;
|
|
|
|
|
2009-04-29 07:04:37 +02:00
|
|
|
status = dixLookupResourceByType((pointer *)&shmdesc, stuff->shmseg,
|
|
|
|
ShmSegType, serverClient, DixReadAccess);
|
|
|
|
if (status != Success)
|
2010-04-25 08:56:36 +02:00
|
|
|
return status;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
width = stuff->width;
|
|
|
|
height = stuff->height;
|
|
|
|
size_needed = (*pPort->pAdaptor->ddQueryImageAttributes)(client,
|
|
|
|
pPort, pImage, &width, &height, NULL, NULL);
|
|
|
|
if((size_needed + stuff->offset) > shmdesc->size)
|
|
|
|
return BadAccess;
|
|
|
|
|
|
|
|
if((width < stuff->width) || (height < stuff->height))
|
|
|
|
return BadValue;
|
|
|
|
|
2008-12-19 16:27:37 +01:00
|
|
|
status = XvdiPutImage(client, pDraw, pPort, pGC, stuff->src_x, stuff->src_y,
|
|
|
|
stuff->src_w, stuff->src_h, stuff->drw_x, stuff->drw_y,
|
|
|
|
stuff->drw_w, stuff->drw_h, pImage,
|
|
|
|
(unsigned char *)shmdesc->addr + stuff->offset,
|
|
|
|
stuff->send_event, stuff->width, stuff->height);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
if((status == Success) && stuff->send_event) {
|
|
|
|
xShmCompletionEvent ev;
|
|
|
|
|
|
|
|
ev.type = ShmCompletionCode;
|
|
|
|
ev.drawable = stuff->drawable;
|
|
|
|
ev.minorEvent = xv_ShmPutImage;
|
|
|
|
ev.majorEvent = XvReqCode;
|
|
|
|
ev.shmseg = stuff->shmseg;
|
|
|
|
ev.offset = stuff->offset;
|
|
|
|
WriteEventsToClient(client, 1, (xEvent *) &ev);
|
|
|
|
}
|
|
|
|
|
|
|
|
return status;
|
|
|
|
}
|
2007-12-02 20:15:36 +01:00
|
|
|
#else /* !MITSHM */
|
|
|
|
static int
|
|
|
|
ProcXvShmPutImage(ClientPtr client)
|
|
|
|
{
|
|
|
|
SendErrorToClient(client, XvReqCode, xv_ShmPutImage, 0, BadImplementation);
|
2010-06-06 16:18:40 +02:00
|
|
|
return BadImplementation;
|
2007-12-02 20:15:36 +01:00
|
|
|
}
|
2003-11-14 17:48:57 +01:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef XvMCExtension
|
2003-11-25 20:29:01 +01:00
|
|
|
#include "xvmcext.h"
|
2003-11-14 17:48:57 +01:00
|
|
|
#endif
|
|
|
|
|
|
|
|
static int
|
|
|
|
ProcXvQueryImageAttributes(ClientPtr client)
|
|
|
|
{
|
|
|
|
xvQueryImageAttributesReply rep;
|
|
|
|
int size, num_planes, i;
|
|
|
|
CARD16 width, height;
|
|
|
|
XvImagePtr pImage = NULL;
|
|
|
|
XvPortPtr pPort;
|
|
|
|
int *offsets;
|
|
|
|
int *pitches;
|
2008-01-03 04:27:22 +01:00
|
|
|
int planeLength;
|
2003-11-14 17:48:57 +01:00
|
|
|
REQUEST(xvQueryImageAttributesReq);
|
|
|
|
|
|
|
|
REQUEST_SIZE_MATCH(xvQueryImageAttributesReq);
|
|
|
|
|
2009-04-29 07:04:37 +02:00
|
|
|
VALIDATE_XV_PORT(stuff->port, pPort, DixReadAccess);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
for(i = 0; i < pPort->pAdaptor->nImages; i++) {
|
|
|
|
if(pPort->pAdaptor->pImages[i].id == stuff->id) {
|
|
|
|
pImage = &(pPort->pAdaptor->pImages[i]);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef XvMCExtension
|
|
|
|
if(!pImage)
|
|
|
|
pImage = XvMCFindXvImage(pPort, stuff->id);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
if(!pImage)
|
|
|
|
return BadMatch;
|
|
|
|
|
|
|
|
num_planes = pImage->num_planes;
|
|
|
|
|
2010-05-05 20:44:06 +02:00
|
|
|
if(!(offsets = malloc(num_planes << 3)))
|
2003-11-14 17:48:57 +01:00
|
|
|
return BadAlloc;
|
|
|
|
pitches = offsets + num_planes;
|
|
|
|
|
|
|
|
width = stuff->width;
|
|
|
|
height = stuff->height;
|
|
|
|
|
|
|
|
size = (*pPort->pAdaptor->ddQueryImageAttributes)(client, pPort, pImage,
|
|
|
|
&width, &height, offsets, pitches);
|
|
|
|
|
|
|
|
rep.type = X_Reply;
|
|
|
|
rep.sequenceNumber = client->sequence;
|
2008-01-03 04:27:22 +01:00
|
|
|
rep.length = planeLength = num_planes << 1;
|
2003-11-14 17:48:57 +01:00
|
|
|
rep.num_planes = num_planes;
|
|
|
|
rep.width = width;
|
|
|
|
rep.height = height;
|
|
|
|
rep.data_size = size;
|
|
|
|
|
|
|
|
_WriteQueryImageAttributesReply(client, &rep);
|
|
|
|
if(client->swapped)
|
2008-01-03 04:27:22 +01:00
|
|
|
SwapLongs((CARD32*)offsets, planeLength);
|
|
|
|
WriteToClient(client, planeLength << 2, (char*)offsets);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
2010-05-05 20:44:06 +02:00
|
|
|
free(offsets);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
return Success;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
ProcXvListImageFormats(ClientPtr client)
|
|
|
|
{
|
|
|
|
XvPortPtr pPort;
|
|
|
|
XvImagePtr pImage;
|
|
|
|
int i;
|
|
|
|
xvListImageFormatsReply rep;
|
|
|
|
xvImageFormatInfo info;
|
|
|
|
REQUEST(xvListImageFormatsReq);
|
|
|
|
|
|
|
|
REQUEST_SIZE_MATCH(xvListImageFormatsReq);
|
|
|
|
|
2009-04-29 07:04:37 +02:00
|
|
|
VALIDATE_XV_PORT(stuff->port, pPort, DixReadAccess);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
rep.type = X_Reply;
|
|
|
|
rep.sequenceNumber = client->sequence;
|
|
|
|
rep.num_formats = pPort->pAdaptor->nImages;
|
2009-07-06 04:20:21 +02:00
|
|
|
rep.length = bytes_to_int32(pPort->pAdaptor->nImages * sz_xvImageFormatInfo);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
_WriteListImageFormatsReply(client, &rep);
|
|
|
|
|
|
|
|
pImage = pPort->pAdaptor->pImages;
|
|
|
|
|
2008-01-03 04:27:22 +01:00
|
|
|
for(i = 0; i < pPort->pAdaptor->nImages; i++, pImage++) {
|
2003-11-14 17:48:57 +01:00
|
|
|
info.id = pImage->id;
|
|
|
|
info.type = pImage->type;
|
|
|
|
info.byte_order = pImage->byte_order;
|
|
|
|
memcpy(&info.guid, pImage->guid, 16);
|
|
|
|
info.bpp = pImage->bits_per_pixel;
|
|
|
|
info.num_planes = pImage->num_planes;
|
|
|
|
info.depth = pImage->depth;
|
|
|
|
info.red_mask = pImage->red_mask;
|
|
|
|
info.green_mask = pImage->green_mask;
|
|
|
|
info.blue_mask = pImage->blue_mask;
|
|
|
|
info.format = pImage->format;
|
|
|
|
info.y_sample_bits = pImage->y_sample_bits;
|
|
|
|
info.u_sample_bits = pImage->u_sample_bits;
|
|
|
|
info.v_sample_bits = pImage->v_sample_bits;
|
|
|
|
info.horz_y_period = pImage->horz_y_period;
|
|
|
|
info.horz_u_period = pImage->horz_u_period;
|
|
|
|
info.horz_v_period = pImage->horz_v_period;
|
|
|
|
info.vert_y_period = pImage->vert_y_period;
|
|
|
|
info.vert_u_period = pImage->vert_u_period;
|
|
|
|
info.vert_v_period = pImage->vert_v_period;
|
|
|
|
memcpy(&info.comp_order, pImage->component_order, 32);
|
|
|
|
info.scanline_order = pImage->scanline_order;
|
|
|
|
_WriteImageFormatInfo(client, &info);
|
|
|
|
}
|
|
|
|
|
|
|
|
return Success;
|
|
|
|
}
|
|
|
|
|
2007-12-02 20:15:36 +01:00
|
|
|
static int (*XvProcVector[xvNumRequests])(ClientPtr) = {
|
|
|
|
ProcXvQueryExtension,
|
|
|
|
ProcXvQueryAdaptors,
|
|
|
|
ProcXvQueryEncodings,
|
|
|
|
ProcXvGrabPort,
|
|
|
|
ProcXvUngrabPort,
|
|
|
|
ProcXvPutVideo,
|
|
|
|
ProcXvPutStill,
|
|
|
|
ProcXvGetVideo,
|
|
|
|
ProcXvGetStill,
|
|
|
|
ProcXvStopVideo,
|
|
|
|
ProcXvSelectVideoNotify,
|
|
|
|
ProcXvSelectPortNotify,
|
|
|
|
ProcXvQueryBestSize,
|
|
|
|
ProcXvSetPortAttribute,
|
|
|
|
ProcXvGetPortAttribute,
|
|
|
|
ProcXvQueryPortAttributes,
|
|
|
|
ProcXvListImageFormats,
|
|
|
|
ProcXvQueryImageAttributes,
|
|
|
|
ProcXvPutImage,
|
|
|
|
ProcXvShmPutImage,
|
|
|
|
};
|
|
|
|
|
Rework symbol visibility for easier maintenance
Save in a few special cases, _X_EXPORT should not be used in C source
files. Instead, it should be used in headers, and the proper C source
include that header. Some special cases are symbols that need to be
shared between modules, but not expected to be used by external drivers,
and symbols that are accessible via LoaderSymbol/dlopen.
This patch also adds conditionally some new sdk header files, depending
on extensions enabled. These files were added to match pattern for
other extensions/modules, that is, have the headers "deciding" symbol
visibility in the sdk. These headers are:
o Xext/panoramiXsrv.h, Xext/panoramiX.h
o fbpict.h (unconditionally)
o vidmodeproc.h
o mioverlay.h (unconditionally, used only by xaa)
o xfixes.h (unconditionally, symbols required by dri2)
LoaderSymbol and similar functions now don't have different prototypes,
in loaderProcs.h and xf86Module.h, so that both headers can be included,
without the need of defining IN_LOADER.
xf86NewInputDevice() device prototype readded to xf86Xinput.h, but
not exported (and with a comment about it).
2008-12-03 08:43:34 +01:00
|
|
|
int
|
2007-12-02 20:15:36 +01:00
|
|
|
ProcXvDispatch(ClientPtr client)
|
|
|
|
{
|
|
|
|
REQUEST(xReq);
|
|
|
|
|
|
|
|
UpdateCurrentTime();
|
|
|
|
|
|
|
|
if (stuff->data > xvNumRequests) {
|
|
|
|
SendErrorToClient(client, XvReqCode, stuff->data, 0, BadRequest);
|
2010-06-06 16:18:40 +02:00
|
|
|
return BadRequest;
|
2007-12-02 20:15:36 +01:00
|
|
|
}
|
2003-11-14 17:48:57 +01:00
|
|
|
|
2007-12-02 20:15:36 +01:00
|
|
|
return XvProcVector[stuff->data](client);
|
|
|
|
}
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
/* Swapped Procs */
|
|
|
|
|
|
|
|
static int
|
|
|
|
SProcXvQueryExtension(ClientPtr client)
|
|
|
|
{
|
|
|
|
REQUEST(xvQueryExtensionReq);
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&stuff->length);
|
2007-12-02 20:15:36 +01:00
|
|
|
return XvProcVector[xv_QueryExtension](client);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SProcXvQueryAdaptors(ClientPtr client)
|
|
|
|
{
|
|
|
|
REQUEST(xvQueryAdaptorsReq);
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&stuff->length);
|
|
|
|
swapl(&stuff->window);
|
2007-12-02 20:15:36 +01:00
|
|
|
return XvProcVector[xv_QueryAdaptors](client);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SProcXvQueryEncodings(ClientPtr client)
|
|
|
|
{
|
|
|
|
REQUEST(xvQueryEncodingsReq);
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&stuff->length);
|
|
|
|
swapl(&stuff->port);
|
2007-12-02 20:15:36 +01:00
|
|
|
return XvProcVector[xv_QueryEncodings](client);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SProcXvGrabPort(ClientPtr client)
|
|
|
|
{
|
|
|
|
REQUEST(xvGrabPortReq);
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&stuff->length);
|
|
|
|
swapl(&stuff->port);
|
|
|
|
swapl(&stuff->time);
|
2007-12-02 20:15:36 +01:00
|
|
|
return XvProcVector[xv_GrabPort](client);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SProcXvUngrabPort(ClientPtr client)
|
|
|
|
{
|
|
|
|
REQUEST(xvUngrabPortReq);
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&stuff->length);
|
|
|
|
swapl(&stuff->port);
|
|
|
|
swapl(&stuff->time);
|
2007-12-02 20:15:36 +01:00
|
|
|
return XvProcVector[xv_UngrabPort](client);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SProcXvPutVideo(ClientPtr client)
|
|
|
|
{
|
|
|
|
REQUEST(xvPutVideoReq);
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&stuff->length);
|
|
|
|
swapl(&stuff->port);
|
|
|
|
swapl(&stuff->drawable);
|
|
|
|
swapl(&stuff->gc);
|
|
|
|
swaps(&stuff->vid_x);
|
|
|
|
swaps(&stuff->vid_y);
|
|
|
|
swaps(&stuff->vid_w);
|
|
|
|
swaps(&stuff->vid_h);
|
|
|
|
swaps(&stuff->drw_x);
|
|
|
|
swaps(&stuff->drw_y);
|
|
|
|
swaps(&stuff->drw_w);
|
|
|
|
swaps(&stuff->drw_h);
|
2007-12-02 20:15:36 +01:00
|
|
|
return XvProcVector[xv_PutVideo](client);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SProcXvPutStill(ClientPtr client)
|
|
|
|
{
|
|
|
|
REQUEST(xvPutStillReq);
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&stuff->length);
|
|
|
|
swapl(&stuff->port);
|
|
|
|
swapl(&stuff->drawable);
|
|
|
|
swapl(&stuff->gc);
|
|
|
|
swaps(&stuff->vid_x);
|
|
|
|
swaps(&stuff->vid_y);
|
|
|
|
swaps(&stuff->vid_w);
|
|
|
|
swaps(&stuff->vid_h);
|
|
|
|
swaps(&stuff->drw_x);
|
|
|
|
swaps(&stuff->drw_y);
|
|
|
|
swaps(&stuff->drw_w);
|
|
|
|
swaps(&stuff->drw_h);
|
2007-12-02 20:15:36 +01:00
|
|
|
return XvProcVector[xv_PutStill](client);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SProcXvGetVideo(ClientPtr client)
|
|
|
|
{
|
|
|
|
REQUEST(xvGetVideoReq);
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&stuff->length);
|
|
|
|
swapl(&stuff->port);
|
|
|
|
swapl(&stuff->drawable);
|
|
|
|
swapl(&stuff->gc);
|
|
|
|
swaps(&stuff->vid_x);
|
|
|
|
swaps(&stuff->vid_y);
|
|
|
|
swaps(&stuff->vid_w);
|
|
|
|
swaps(&stuff->vid_h);
|
|
|
|
swaps(&stuff->drw_x);
|
|
|
|
swaps(&stuff->drw_y);
|
|
|
|
swaps(&stuff->drw_w);
|
|
|
|
swaps(&stuff->drw_h);
|
2007-12-02 20:15:36 +01:00
|
|
|
return XvProcVector[xv_GetVideo](client);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SProcXvGetStill(ClientPtr client)
|
|
|
|
{
|
|
|
|
REQUEST(xvGetStillReq);
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&stuff->length);
|
|
|
|
swapl(&stuff->port);
|
|
|
|
swapl(&stuff->drawable);
|
|
|
|
swapl(&stuff->gc);
|
|
|
|
swaps(&stuff->vid_x);
|
|
|
|
swaps(&stuff->vid_y);
|
|
|
|
swaps(&stuff->vid_w);
|
|
|
|
swaps(&stuff->vid_h);
|
|
|
|
swaps(&stuff->drw_x);
|
|
|
|
swaps(&stuff->drw_y);
|
|
|
|
swaps(&stuff->drw_w);
|
|
|
|
swaps(&stuff->drw_h);
|
2007-12-02 20:15:36 +01:00
|
|
|
return XvProcVector[xv_GetStill](client);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SProcXvPutImage(ClientPtr client)
|
|
|
|
{
|
|
|
|
REQUEST(xvPutImageReq);
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&stuff->length);
|
|
|
|
swapl(&stuff->port);
|
|
|
|
swapl(&stuff->drawable);
|
|
|
|
swapl(&stuff->gc);
|
|
|
|
swapl(&stuff->id);
|
|
|
|
swaps(&stuff->src_x);
|
|
|
|
swaps(&stuff->src_y);
|
|
|
|
swaps(&stuff->src_w);
|
|
|
|
swaps(&stuff->src_h);
|
|
|
|
swaps(&stuff->drw_x);
|
|
|
|
swaps(&stuff->drw_y);
|
|
|
|
swaps(&stuff->drw_w);
|
|
|
|
swaps(&stuff->drw_h);
|
|
|
|
swaps(&stuff->width);
|
|
|
|
swaps(&stuff->height);
|
2007-12-02 20:15:36 +01:00
|
|
|
return XvProcVector[xv_PutImage](client);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef MITSHM
|
|
|
|
static int
|
|
|
|
SProcXvShmPutImage(ClientPtr client)
|
|
|
|
{
|
|
|
|
REQUEST(xvShmPutImageReq);
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&stuff->length);
|
|
|
|
swapl(&stuff->port);
|
|
|
|
swapl(&stuff->drawable);
|
|
|
|
swapl(&stuff->gc);
|
|
|
|
swapl(&stuff->shmseg);
|
|
|
|
swapl(&stuff->id);
|
|
|
|
swapl(&stuff->offset);
|
|
|
|
swaps(&stuff->src_x);
|
|
|
|
swaps(&stuff->src_y);
|
|
|
|
swaps(&stuff->src_w);
|
|
|
|
swaps(&stuff->src_h);
|
|
|
|
swaps(&stuff->drw_x);
|
|
|
|
swaps(&stuff->drw_y);
|
|
|
|
swaps(&stuff->drw_w);
|
|
|
|
swaps(&stuff->drw_h);
|
|
|
|
swaps(&stuff->width);
|
|
|
|
swaps(&stuff->height);
|
2007-12-02 20:15:36 +01:00
|
|
|
return XvProcVector[xv_ShmPutImage](client);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
2007-12-02 20:15:36 +01:00
|
|
|
#else /* MITSHM */
|
|
|
|
#define SProcXvShmPutImage ProcXvShmPutImage
|
2003-11-14 17:48:57 +01:00
|
|
|
#endif
|
|
|
|
|
|
|
|
static int
|
|
|
|
SProcXvSelectVideoNotify(ClientPtr client)
|
|
|
|
{
|
|
|
|
REQUEST(xvSelectVideoNotifyReq);
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&stuff->length);
|
|
|
|
swapl(&stuff->drawable);
|
2007-12-02 20:15:36 +01:00
|
|
|
return XvProcVector[xv_SelectVideoNotify](client);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SProcXvSelectPortNotify(ClientPtr client)
|
|
|
|
{
|
|
|
|
REQUEST(xvSelectPortNotifyReq);
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&stuff->length);
|
|
|
|
swapl(&stuff->port);
|
2007-12-02 20:15:36 +01:00
|
|
|
return XvProcVector[xv_SelectPortNotify](client);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SProcXvStopVideo(ClientPtr client)
|
|
|
|
{
|
|
|
|
REQUEST(xvStopVideoReq);
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&stuff->length);
|
|
|
|
swapl(&stuff->port);
|
|
|
|
swapl(&stuff->drawable);
|
2007-12-02 20:15:36 +01:00
|
|
|
return XvProcVector[xv_StopVideo](client);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SProcXvSetPortAttribute(ClientPtr client)
|
|
|
|
{
|
|
|
|
REQUEST(xvSetPortAttributeReq);
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&stuff->length);
|
|
|
|
swapl(&stuff->port);
|
|
|
|
swapl(&stuff->attribute);
|
|
|
|
swapl(&stuff->value);
|
2007-12-02 20:15:36 +01:00
|
|
|
return XvProcVector[xv_SetPortAttribute](client);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SProcXvGetPortAttribute(ClientPtr client)
|
|
|
|
{
|
|
|
|
REQUEST(xvGetPortAttributeReq);
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&stuff->length);
|
|
|
|
swapl(&stuff->port);
|
|
|
|
swapl(&stuff->attribute);
|
2007-12-02 20:15:36 +01:00
|
|
|
return XvProcVector[xv_GetPortAttribute](client);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SProcXvQueryBestSize(ClientPtr client)
|
|
|
|
{
|
|
|
|
REQUEST(xvQueryBestSizeReq);
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&stuff->length);
|
|
|
|
swapl(&stuff->port);
|
|
|
|
swaps(&stuff->vid_w);
|
|
|
|
swaps(&stuff->vid_h);
|
|
|
|
swaps(&stuff->drw_w);
|
|
|
|
swaps(&stuff->drw_h);
|
2007-12-02 20:15:36 +01:00
|
|
|
return XvProcVector[xv_QueryBestSize](client);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SProcXvQueryPortAttributes(ClientPtr client)
|
|
|
|
{
|
|
|
|
REQUEST(xvQueryPortAttributesReq);
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&stuff->length);
|
|
|
|
swapl(&stuff->port);
|
2007-12-02 20:15:36 +01:00
|
|
|
return XvProcVector[xv_QueryPortAttributes](client);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SProcXvQueryImageAttributes(ClientPtr client)
|
|
|
|
{
|
|
|
|
REQUEST(xvQueryImageAttributesReq);
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&stuff->length);
|
|
|
|
swapl(&stuff->port);
|
|
|
|
swapl(&stuff->id);
|
|
|
|
swaps(&stuff->width);
|
|
|
|
swaps(&stuff->height);
|
2007-12-02 20:15:36 +01:00
|
|
|
return XvProcVector[xv_QueryImageAttributes](client);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
SProcXvListImageFormats(ClientPtr client)
|
|
|
|
{
|
|
|
|
REQUEST(xvListImageFormatsReq);
|
2011-08-04 21:35:41 +02:00
|
|
|
swaps(&stuff->length);
|
|
|
|
swapl(&stuff->port);
|
2007-12-02 20:15:36 +01:00
|
|
|
return XvProcVector[xv_ListImageFormats](client);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
2007-12-02 20:15:36 +01:00
|
|
|
static int (*SXvProcVector[xvNumRequests])(ClientPtr) = {
|
|
|
|
SProcXvQueryExtension,
|
|
|
|
SProcXvQueryAdaptors,
|
|
|
|
SProcXvQueryEncodings,
|
|
|
|
SProcXvGrabPort,
|
|
|
|
SProcXvUngrabPort,
|
|
|
|
SProcXvPutVideo,
|
|
|
|
SProcXvPutStill,
|
|
|
|
SProcXvGetVideo,
|
|
|
|
SProcXvGetStill,
|
|
|
|
SProcXvStopVideo,
|
|
|
|
SProcXvSelectVideoNotify,
|
|
|
|
SProcXvSelectPortNotify,
|
|
|
|
SProcXvQueryBestSize,
|
|
|
|
SProcXvSetPortAttribute,
|
|
|
|
SProcXvGetPortAttribute,
|
|
|
|
SProcXvQueryPortAttributes,
|
|
|
|
SProcXvListImageFormats,
|
|
|
|
SProcXvQueryImageAttributes,
|
|
|
|
SProcXvPutImage,
|
|
|
|
SProcXvShmPutImage,
|
|
|
|
};
|
2003-11-14 17:48:57 +01:00
|
|
|
|
Rework symbol visibility for easier maintenance
Save in a few special cases, _X_EXPORT should not be used in C source
files. Instead, it should be used in headers, and the proper C source
include that header. Some special cases are symbols that need to be
shared between modules, but not expected to be used by external drivers,
and symbols that are accessible via LoaderSymbol/dlopen.
This patch also adds conditionally some new sdk header files, depending
on extensions enabled. These files were added to match pattern for
other extensions/modules, that is, have the headers "deciding" symbol
visibility in the sdk. These headers are:
o Xext/panoramiXsrv.h, Xext/panoramiX.h
o fbpict.h (unconditionally)
o vidmodeproc.h
o mioverlay.h (unconditionally, used only by xaa)
o xfixes.h (unconditionally, symbols required by dri2)
LoaderSymbol and similar functions now don't have different prototypes,
in loaderProcs.h and xf86Module.h, so that both headers can be included,
without the need of defining IN_LOADER.
xf86NewInputDevice() device prototype readded to xf86Xinput.h, but
not exported (and with a comment about it).
2008-12-03 08:43:34 +01:00
|
|
|
int
|
2007-12-02 20:15:36 +01:00
|
|
|
SProcXvDispatch(ClientPtr client)
|
|
|
|
{
|
|
|
|
REQUEST(xReq);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
2007-12-02 20:15:36 +01:00
|
|
|
UpdateCurrentTime();
|
2003-11-14 17:48:57 +01:00
|
|
|
|
2007-12-02 20:15:36 +01:00
|
|
|
if (stuff->data > xvNumRequests) {
|
|
|
|
SendErrorToClient(client, XvReqCode, stuff->data, 0, BadRequest);
|
2010-06-06 16:18:40 +02:00
|
|
|
return BadRequest;
|
2007-12-02 20:15:36 +01:00
|
|
|
}
|
2003-11-14 17:48:57 +01:00
|
|
|
|
2007-12-02 20:15:36 +01:00
|
|
|
return SXvProcVector[stuff->data](client);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef PANORAMIX
|
|
|
|
static int
|
|
|
|
XineramaXvStopVideo(ClientPtr client)
|
|
|
|
{
|
2009-04-29 07:04:37 +02:00
|
|
|
int result, i;
|
2003-11-14 17:48:57 +01:00
|
|
|
PanoramiXRes *draw, *port;
|
|
|
|
REQUEST(xvStopVideoReq);
|
|
|
|
REQUEST_SIZE_MATCH(xvStopVideoReq);
|
|
|
|
|
2009-04-29 07:04:37 +02:00
|
|
|
result = dixLookupResourceByClass((pointer *)&draw, stuff->drawable,
|
|
|
|
XRC_DRAWABLE, client, DixWriteAccess);
|
|
|
|
if (result != Success)
|
|
|
|
return (result == BadValue) ? BadDrawable : result;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
2009-04-29 07:04:37 +02:00
|
|
|
result = dixLookupResourceByType((pointer *)&port, stuff->port,
|
|
|
|
XvXRTPort, client, DixReadAccess);
|
|
|
|
if (result != Success)
|
2010-04-25 08:56:36 +02:00
|
|
|
return result;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
FOR_NSCREENS_BACKWARD(i) {
|
|
|
|
if(port->info[i].id) {
|
|
|
|
stuff->drawable = draw->info[i].id;
|
|
|
|
stuff->port = port->info[i].id;
|
|
|
|
result = ProcXvStopVideo(client);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
XineramaXvSetPortAttribute(ClientPtr client)
|
|
|
|
{
|
|
|
|
REQUEST(xvSetPortAttributeReq);
|
|
|
|
PanoramiXRes *port;
|
2009-04-29 07:04:37 +02:00
|
|
|
int result, i;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
REQUEST_SIZE_MATCH(xvSetPortAttributeReq);
|
|
|
|
|
2009-04-29 07:04:37 +02:00
|
|
|
result = dixLookupResourceByType((pointer *)&port, stuff->port,
|
|
|
|
XvXRTPort, client, DixReadAccess);
|
|
|
|
if (result != Success)
|
2010-04-25 08:56:36 +02:00
|
|
|
return result;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
FOR_NSCREENS_BACKWARD(i) {
|
|
|
|
if(port->info[i].id) {
|
|
|
|
stuff->port = port->info[i].id;
|
|
|
|
result = ProcXvSetPortAttribute(client);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef MITSHM
|
|
|
|
static int
|
|
|
|
XineramaXvShmPutImage(ClientPtr client)
|
|
|
|
{
|
|
|
|
REQUEST(xvShmPutImageReq);
|
|
|
|
PanoramiXRes *draw, *gc, *port;
|
|
|
|
Bool send_event = stuff->send_event;
|
|
|
|
Bool isRoot;
|
2009-04-29 07:04:37 +02:00
|
|
|
int result, i, x, y;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
REQUEST_SIZE_MATCH(xvShmPutImageReq);
|
|
|
|
|
2009-04-29 07:04:37 +02:00
|
|
|
result = dixLookupResourceByClass((pointer *)&draw, stuff->drawable,
|
|
|
|
XRC_DRAWABLE, client, DixWriteAccess);
|
|
|
|
if (result != Success)
|
|
|
|
return (result == BadValue) ? BadDrawable : result;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
2009-04-29 07:04:37 +02:00
|
|
|
result = dixLookupResourceByType((pointer *)&gc, stuff->gc,
|
|
|
|
XRT_GC, client, DixReadAccess);
|
|
|
|
if (result != Success)
|
2010-04-25 08:56:36 +02:00
|
|
|
return result;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
2009-04-29 07:04:37 +02:00
|
|
|
result = dixLookupResourceByType((pointer *)&port, stuff->port,
|
|
|
|
XvXRTPort, client, DixReadAccess);
|
|
|
|
if (result != Success)
|
2010-04-25 08:56:36 +02:00
|
|
|
return result;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
2003-11-25 20:29:01 +01:00
|
|
|
isRoot = (draw->type == XRT_WINDOW) && draw->u.win.root;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
x = stuff->drw_x;
|
|
|
|
y = stuff->drw_y;
|
|
|
|
|
|
|
|
FOR_NSCREENS_BACKWARD(i) {
|
|
|
|
if(port->info[i].id) {
|
|
|
|
stuff->drawable = draw->info[i].id;
|
|
|
|
stuff->port = port->info[i].id;
|
|
|
|
stuff->gc = gc->info[i].id;
|
|
|
|
stuff->drw_x = x;
|
|
|
|
stuff->drw_y = y;
|
|
|
|
if(isRoot) {
|
2010-05-23 19:11:47 +02:00
|
|
|
stuff->drw_x -= screenInfo.screens[i]->x;
|
|
|
|
stuff->drw_y -= screenInfo.screens[i]->y;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
stuff->send_event = (send_event && !i) ? 1 : 0;
|
|
|
|
|
|
|
|
result = ProcXvShmPutImage(client);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
2007-12-02 20:15:36 +01:00
|
|
|
#else
|
|
|
|
#define XineramaXvShmPutImage ProcXvShmPutImage
|
2003-11-14 17:48:57 +01:00
|
|
|
#endif
|
|
|
|
|
|
|
|
static int
|
|
|
|
XineramaXvPutImage(ClientPtr client)
|
|
|
|
{
|
|
|
|
REQUEST(xvPutImageReq);
|
|
|
|
PanoramiXRes *draw, *gc, *port;
|
|
|
|
Bool isRoot;
|
2009-04-29 07:04:37 +02:00
|
|
|
int result, i, x, y;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
REQUEST_AT_LEAST_SIZE(xvPutImageReq);
|
|
|
|
|
2009-04-29 07:04:37 +02:00
|
|
|
result = dixLookupResourceByClass((pointer *)&draw, stuff->drawable,
|
|
|
|
XRC_DRAWABLE, client, DixWriteAccess);
|
|
|
|
if (result != Success)
|
|
|
|
return (result == BadValue) ? BadDrawable : result;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
2009-04-29 07:04:37 +02:00
|
|
|
result = dixLookupResourceByType((pointer *)&gc, stuff->gc,
|
|
|
|
XRT_GC, client, DixReadAccess);
|
|
|
|
if (result != Success)
|
2010-04-25 08:56:36 +02:00
|
|
|
return result;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
2009-04-29 07:04:37 +02:00
|
|
|
result = dixLookupResourceByType((pointer *)&port, stuff->port,
|
|
|
|
XvXRTPort, client, DixReadAccess);
|
|
|
|
if (result != Success)
|
2010-04-25 08:56:36 +02:00
|
|
|
return result;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
2003-11-25 20:29:01 +01:00
|
|
|
isRoot = (draw->type == XRT_WINDOW) && draw->u.win.root;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
x = stuff->drw_x;
|
|
|
|
y = stuff->drw_y;
|
|
|
|
|
|
|
|
FOR_NSCREENS_BACKWARD(i) {
|
|
|
|
if(port->info[i].id) {
|
|
|
|
stuff->drawable = draw->info[i].id;
|
|
|
|
stuff->port = port->info[i].id;
|
|
|
|
stuff->gc = gc->info[i].id;
|
|
|
|
stuff->drw_x = x;
|
|
|
|
stuff->drw_y = y;
|
|
|
|
if(isRoot) {
|
2010-05-23 19:11:47 +02:00
|
|
|
stuff->drw_x -= screenInfo.screens[i]->x;
|
|
|
|
stuff->drw_y -= screenInfo.screens[i]->y;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
result = ProcXvPutImage(client);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
XineramaXvPutVideo(ClientPtr client)
|
|
|
|
{
|
|
|
|
REQUEST(xvPutImageReq);
|
|
|
|
PanoramiXRes *draw, *gc, *port;
|
|
|
|
Bool isRoot;
|
2009-04-29 07:04:37 +02:00
|
|
|
int result, i, x, y;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
REQUEST_AT_LEAST_SIZE(xvPutVideoReq);
|
|
|
|
|
2009-04-29 07:04:37 +02:00
|
|
|
result = dixLookupResourceByClass((pointer *)&draw, stuff->drawable,
|
|
|
|
XRC_DRAWABLE, client, DixWriteAccess);
|
|
|
|
if (result != Success)
|
|
|
|
return (result == BadValue) ? BadDrawable : result;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
2009-04-29 07:04:37 +02:00
|
|
|
result = dixLookupResourceByType((pointer *)&gc, stuff->gc,
|
|
|
|
XRT_GC, client, DixReadAccess);
|
|
|
|
if (result != Success)
|
2010-04-25 08:56:36 +02:00
|
|
|
return result;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
2009-04-29 07:04:37 +02:00
|
|
|
result = dixLookupResourceByType((pointer *)&port, stuff->port,
|
|
|
|
XvXRTPort, client, DixReadAccess);
|
|
|
|
if (result != Success)
|
2010-04-25 08:56:36 +02:00
|
|
|
return result;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
2003-11-25 20:29:01 +01:00
|
|
|
isRoot = (draw->type == XRT_WINDOW) && draw->u.win.root;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
x = stuff->drw_x;
|
|
|
|
y = stuff->drw_y;
|
|
|
|
|
|
|
|
FOR_NSCREENS_BACKWARD(i) {
|
|
|
|
if(port->info[i].id) {
|
|
|
|
stuff->drawable = draw->info[i].id;
|
|
|
|
stuff->port = port->info[i].id;
|
|
|
|
stuff->gc = gc->info[i].id;
|
|
|
|
stuff->drw_x = x;
|
|
|
|
stuff->drw_y = y;
|
|
|
|
if(isRoot) {
|
2010-05-23 19:11:47 +02:00
|
|
|
stuff->drw_x -= screenInfo.screens[i]->x;
|
|
|
|
stuff->drw_y -= screenInfo.screens[i]->y;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
result = ProcXvPutVideo(client);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
XineramaXvPutStill(ClientPtr client)
|
|
|
|
{
|
|
|
|
REQUEST(xvPutImageReq);
|
|
|
|
PanoramiXRes *draw, *gc, *port;
|
|
|
|
Bool isRoot;
|
2009-04-29 07:04:37 +02:00
|
|
|
int result, i, x, y;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
REQUEST_AT_LEAST_SIZE(xvPutImageReq);
|
|
|
|
|
2009-04-29 07:04:37 +02:00
|
|
|
result = dixLookupResourceByClass((pointer *)&draw, stuff->drawable,
|
|
|
|
XRC_DRAWABLE, client, DixWriteAccess);
|
|
|
|
if (result != Success)
|
|
|
|
return (result == BadValue) ? BadDrawable : result;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
2009-04-29 07:04:37 +02:00
|
|
|
result = dixLookupResourceByType((pointer *)&gc, stuff->gc,
|
|
|
|
XRT_GC, client, DixReadAccess);
|
|
|
|
if (result != Success)
|
2010-04-25 08:56:36 +02:00
|
|
|
return result;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
2009-04-29 07:04:37 +02:00
|
|
|
result = dixLookupResourceByType((pointer *)&port, stuff->port,
|
|
|
|
XvXRTPort, client, DixReadAccess);
|
|
|
|
if (result != Success)
|
2010-04-25 08:56:36 +02:00
|
|
|
return result;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
2003-11-25 20:29:01 +01:00
|
|
|
isRoot = (draw->type == XRT_WINDOW) && draw->u.win.root;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
x = stuff->drw_x;
|
|
|
|
y = stuff->drw_y;
|
|
|
|
|
|
|
|
FOR_NSCREENS_BACKWARD(i) {
|
|
|
|
if(port->info[i].id) {
|
|
|
|
stuff->drawable = draw->info[i].id;
|
|
|
|
stuff->port = port->info[i].id;
|
|
|
|
stuff->gc = gc->info[i].id;
|
|
|
|
stuff->drw_x = x;
|
|
|
|
stuff->drw_y = y;
|
|
|
|
if(isRoot) {
|
2010-05-23 19:11:47 +02:00
|
|
|
stuff->drw_x -= screenInfo.screens[i]->x;
|
|
|
|
stuff->drw_y -= screenInfo.screens[i]->y;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
result = ProcXvPutStill(client);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2009-10-07 18:00:02 +02:00
|
|
|
static Bool
|
|
|
|
isImageAdaptor(XvAdaptorPtr pAdapt)
|
|
|
|
{
|
|
|
|
return (pAdapt->type & XvImageMask) && (pAdapt->nImages > 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
static Bool
|
|
|
|
hasOverlay(XvAdaptorPtr pAdapt)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
for(i = 0; i < pAdapt->nAttributes; i++)
|
|
|
|
if(!strcmp(pAdapt->pAttributes[i].name, "XV_COLORKEY"))
|
|
|
|
return TRUE;
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static XvAdaptorPtr
|
|
|
|
matchAdaptor(ScreenPtr pScreen, XvAdaptorPtr refAdapt, Bool isOverlay)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
XvScreenPtr xvsp = dixLookupPrivate(&pScreen->devPrivates, XvGetScreenKey());
|
|
|
|
/* Do not try to go on if xv is not supported on this screen */
|
|
|
|
if(xvsp == NULL)
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
/* if the adaptor has the same name it's a perfect match */
|
|
|
|
for(i = 0; i < xvsp->nAdaptors; i++) {
|
|
|
|
XvAdaptorPtr pAdapt = xvsp->pAdaptors + i;
|
|
|
|
if(!strcmp(refAdapt->name, pAdapt->name))
|
|
|
|
return pAdapt;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* otherwise we only look for XvImage adaptors */
|
|
|
|
if(!isImageAdaptor(refAdapt))
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
/* prefer overlay/overlay non-overlay/non-overlay pairing */
|
|
|
|
for(i = 0; i < xvsp->nAdaptors; i++) {
|
|
|
|
XvAdaptorPtr pAdapt = xvsp->pAdaptors + i;
|
|
|
|
if(isImageAdaptor(pAdapt) && isOverlay == hasOverlay(pAdapt))
|
|
|
|
return pAdapt;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* but we'll take any XvImage pairing if we can get it */
|
|
|
|
for(i = 0; i < xvsp->nAdaptors; i++) {
|
|
|
|
XvAdaptorPtr pAdapt = xvsp->pAdaptors + i;
|
|
|
|
if(isImageAdaptor(pAdapt))
|
|
|
|
return pAdapt;
|
|
|
|
}
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2003-11-14 17:48:57 +01:00
|
|
|
void XineramifyXv(void)
|
|
|
|
{
|
2009-10-07 18:00:02 +02:00
|
|
|
XvScreenPtr xvsp0 = dixLookupPrivate(&screenInfo.screens[0]->devPrivates, XvGetScreenKey());
|
2003-11-14 17:48:57 +01:00
|
|
|
XvAdaptorPtr MatchingAdaptors[MAXSCREENS];
|
2009-10-07 18:00:02 +02:00
|
|
|
int i, j, k;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
2009-12-03 02:43:01 +01:00
|
|
|
XvXRTPort = CreateNewResourceType(XineramaDeleteResource, "XvXRTPort");
|
2003-11-14 17:48:57 +01:00
|
|
|
|
2009-12-11 09:46:22 +01:00
|
|
|
if (!xvsp0 || !XvXRTPort) return;
|
2010-04-25 08:56:36 +02:00
|
|
|
SetResourceTypeErrorValue(XvXRTPort, _XvBadPort);
|
2009-12-11 09:46:22 +01:00
|
|
|
|
2003-11-14 17:48:57 +01:00
|
|
|
for(i = 0; i < xvsp0->nAdaptors; i++) {
|
2009-10-07 18:00:02 +02:00
|
|
|
Bool isOverlay;
|
|
|
|
XvAdaptorPtr refAdapt = xvsp0->pAdaptors + i;
|
|
|
|
if(!(refAdapt->type & XvInputMask)) continue;
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
MatchingAdaptors[0] = refAdapt;
|
2009-10-07 18:00:02 +02:00
|
|
|
isOverlay = hasOverlay(refAdapt);
|
2011-03-09 06:05:26 +01:00
|
|
|
FOR_NSCREENS_FORWARD_SKIP(j)
|
2009-10-07 18:00:02 +02:00
|
|
|
MatchingAdaptors[j] = matchAdaptor(screenInfo.screens[j], refAdapt, isOverlay);
|
2003-11-14 17:48:57 +01:00
|
|
|
|
|
|
|
/* now create a resource for each port */
|
|
|
|
for(j = 0; j < refAdapt->nPorts; j++) {
|
2010-05-05 20:44:06 +02:00
|
|
|
PanoramiXRes *port = malloc(sizeof(PanoramiXRes));
|
2009-10-07 18:00:02 +02:00
|
|
|
if(!port)
|
2003-11-14 17:48:57 +01:00
|
|
|
break;
|
|
|
|
|
2011-03-09 06:01:20 +01:00
|
|
|
FOR_NSCREENS(k) {
|
2003-11-14 17:48:57 +01:00
|
|
|
if(MatchingAdaptors[k] && (MatchingAdaptors[k]->nPorts > j))
|
|
|
|
port->info[k].id = MatchingAdaptors[k]->base_id + j;
|
|
|
|
else
|
|
|
|
port->info[k].id = 0;
|
|
|
|
}
|
2009-10-07 18:00:02 +02:00
|
|
|
AddResource(port->info[0].id, XvXRTPort, port);
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
|
|
|
}
|
2007-12-02 20:15:36 +01:00
|
|
|
|
|
|
|
/* munge the dispatch vector */
|
|
|
|
XvProcVector[xv_PutVideo] = XineramaXvPutVideo;
|
|
|
|
XvProcVector[xv_PutStill] = XineramaXvPutStill;
|
|
|
|
XvProcVector[xv_StopVideo] = XineramaXvStopVideo;
|
|
|
|
XvProcVector[xv_SetPortAttribute] = XineramaXvSetPortAttribute;
|
|
|
|
XvProcVector[xv_PutImage] = XineramaXvPutImage;
|
|
|
|
XvProcVector[xv_ShmPutImage] = XineramaXvShmPutImage;
|
2003-11-14 17:48:57 +01:00
|
|
|
}
|
2007-12-02 20:15:36 +01:00
|
|
|
#endif /* PANORAMIX */
|
2003-11-14 17:48:57 +01:00
|
|
|
|
2007-12-02 20:15:36 +01:00
|
|
|
void
|
|
|
|
XvResetProcVector(void)
|
|
|
|
{
|
|
|
|
#ifdef PANORAMIX
|
|
|
|
XvProcVector[xv_PutVideo] = ProcXvPutVideo;
|
|
|
|
XvProcVector[xv_PutStill] = ProcXvPutStill;
|
|
|
|
XvProcVector[xv_StopVideo] = ProcXvStopVideo;
|
|
|
|
XvProcVector[xv_SetPortAttribute] = ProcXvSetPortAttribute;
|
|
|
|
XvProcVector[xv_PutImage] = ProcXvPutImage;
|
|
|
|
XvProcVector[xv_ShmPutImage] = ProcXvShmPutImage;
|
2003-11-14 17:48:57 +01:00
|
|
|
#endif
|
2007-12-02 20:15:36 +01:00
|
|
|
}
|