summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLaxmikant Rashinkar <LK.Rashinkar@gmail.com>2013-06-15 13:37:01 -0700
committerLaxmikant Rashinkar <LK.Rashinkar@gmail.com>2013-06-15 13:37:01 -0700
commit74f3388a61f0f6b378da342dfa27d4c3191eb817 (patch)
tree2c0004db5fa8536e03ed165b73afc0bef8bccacd
parent374cb93ded0f8e0e9a43e7b5c888f36e197edebe (diff)
parent62c16bad5a92c98d3bfaed297cb9eb4f99b0a3a4 (diff)
downloadxrdp-proprietary-74f3388a61f0f6b378da342dfa27d4c3191eb817.tar.gz
xrdp-proprietary-74f3388a61f0f6b378da342dfa27d4c3191eb817.zip
Merge branch 'master' of github.com:neutrinolabs/xrdp
-rw-r--r--configure.ac2
-rwxr-xr-xxorg/X11R7.6/buildx.sh5
-rw-r--r--xorg/X11R7.6/rdp/Makefile2
-rw-r--r--xorg/X11R7.6/rdp/rdp.h3
-rw-r--r--xorg/X11R7.6/rdp/rdpmain.c2
-rw-r--r--xorg/X11R7.6/rdp/rdpxv.c448
-rw-r--r--xorg/X11R7.6/x11_file_list.txt2
7 files changed, 459 insertions, 5 deletions
diff --git a/configure.ac b/configure.ac
index 92655612..a2a80aa2 100644
--- a/configure.ac
+++ b/configure.ac
@@ -2,7 +2,7 @@
AC_PREREQ(2.59)
AC_INIT([xrdp], [0.6.0], [xrdp-devel@lists.sourceforge.net])
-AM_CONFIG_HEADER(config_ac.h:config_ac-h.in)
+AC_CONFIG_HEADERS(config_ac.h:config_ac-h.in)
AM_INIT_AUTOMAKE([1.6 foreign])
AC_PROG_CC
AC_C_CONST
diff --git a/xorg/X11R7.6/buildx.sh b/xorg/X11R7.6/buildx.sh
index b778a605..18bbba46 100755
--- a/xorg/X11R7.6/buildx.sh
+++ b/xorg/X11R7.6/buildx.sh
@@ -52,8 +52,9 @@ download_file()
status=$?
cd ..
return $status
- elif [ "$file" = "pixman-0.15.20.tar.bz2" ]; then
- wget -cq http://ftp.x.org/pub/individual/lib/$file
+# note pixman updated
+ elif [ "$file" = "pixman-0.30.0.tar.bz2" ]; then
+ wget -cq http://xorg.freedesktop.org/archive/individual/lib/$file
status=$?
cd ..
return $status
diff --git a/xorg/X11R7.6/rdp/Makefile b/xorg/X11R7.6/rdp/Makefile
index 7373f51a..2eb5e777 100644
--- a/xorg/X11R7.6/rdp/Makefile
+++ b/xorg/X11R7.6/rdp/Makefile
@@ -12,7 +12,7 @@ rdpPolylines.o rdpPolySegment.o rdpFillSpans.o rdpSetSpans.o \
rdpCopyPlane.o rdpPolyPoint.o rdpPolyArc.o rdpFillPolygon.o \
rdpPolyFillArc.o rdpPolyText8.o rdpPolyText16.o \
rdpImageText8.o rdpImageText16.o rdpImageGlyphBlt.o rdpPolyGlyphBlt.o \
-rdpPushPixels.o \
+rdpPushPixels.o rdpxv.o \
miinitext.o \
fbcmap_mi.o
diff --git a/xorg/X11R7.6/rdp/rdp.h b/xorg/X11R7.6/rdp/rdp.h
index ae08f38d..22dcdbf7 100644
--- a/xorg/X11R7.6/rdp/rdp.h
+++ b/xorg/X11R7.6/rdp/rdp.h
@@ -525,6 +525,9 @@ rdpup_check_dirty_screen(rdpPixmapRec* pDirtyPriv);
void
rdpScheduleDeferredUpdate(void);
+int
+rdpXvInit(ScreenPtr pScreen);
+
#if defined(X_BYTE_ORDER)
# if X_BYTE_ORDER == X_LITTLE_ENDIAN
# define L_ENDIAN
diff --git a/xorg/X11R7.6/rdp/rdpmain.c b/xorg/X11R7.6/rdp/rdpmain.c
index 2254f128..ffb43d1f 100644
--- a/xorg/X11R7.6/rdp/rdpmain.c
+++ b/xorg/X11R7.6/rdp/rdpmain.c
@@ -527,6 +527,8 @@ rdpScreenInit(int index, ScreenPtr pScreen, int argc, char **argv)
}
+ //rdpXvInit(pScreen);
+
ErrorF("rdpScreenInit: ret %d\n", ret);
return ret;
diff --git a/xorg/X11R7.6/rdp/rdpxv.c b/xorg/X11R7.6/rdp/rdpxv.c
new file mode 100644
index 00000000..d0ce8345
--- /dev/null
+++ b/xorg/X11R7.6/rdp/rdpxv.c
@@ -0,0 +1,448 @@
+/*
+Copyright 2013 Jay Sorg
+
+Permission to use, copy, modify, distribute, and sell this software and its
+documentation for any purpose is hereby granted without fee, provided that
+the above copyright notice appear in all copies and that both that
+copyright notice and this permission notice appear in supporting
+documentation.
+
+The above copyright notice and this permission notice shall be included in
+all copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
+AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
+CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+
+XVideo extension
+
+*/
+
+#include "rdp.h"
+
+#include <X11/extensions/Xv.h>
+#include <X11/extensions/Xvproto.h>
+#include "xvdix.h"
+
+#include <fourcc.h>
+
+extern rdpScreenInfoRec g_rdpScreen; /* from rdpmain.c */
+
+static DevPrivateKey g_XvScreenKey;
+static char g_xv_adaptor_name[] = "xrdp XVideo adaptor";
+static char g_xv_encoding_name[] = "XV_IMAGE";
+
+#define GET_XV_SCREEN(pScreen) \
+ ((XvScreenPtr)dixLookupPrivate(&(pScreen)->devPrivates, g_XvScreenKey))
+
+#define LOG_LEVEL 1
+#define LLOG(_level, _args) \
+ do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0)
+#define LLOGLN(_level, _args) \
+ do { if (_level < LOG_LEVEL) { ErrorF _args ; ErrorF("\n"); } } while (0)
+
+#define T_NUM_ENCODINGS 1
+static XvEncodingRec g_encodings[T_NUM_ENCODINGS];
+
+#define T_NUM_FORMATS 1
+static XvFormatRec g_formats[T_NUM_FORMATS];
+
+#define T_NUM_PORTS 1
+static XvPortRec g_ports[T_NUM_PORTS];
+
+#define FOURCC_RV15 0x35315652
+#define FOURCC_RV16 0x36315652
+#define FOURCC_RV24 0x34325652
+#define FOURCC_RV32 0x32335652
+
+#define T_NUM_IMAGES 8
+static XvImageRec g_images[T_NUM_IMAGES] =
+{
+ {
+ FOURCC_RV15,XvRGB,LSBFirst,
+ {'R','V','1','5',0,0,0,0,0,0,0,0,0,0,0,0},
+ 16, XvPacked, 1, 15, 0x001f, 0x03e0, 0x7c00, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ {'R','V','B',0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
+ XvTopToBottom
+ },
+ {
+ FOURCC_RV16,XvRGB,LSBFirst,
+ {'R','V','1','6',0,0,0,0,0,0,0,0,0,0,0,0},
+ 16, XvPacked, 1, 16, 0x001f, 0x07e0, 0xf800, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ {'R','V','B',0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
+ XvTopToBottom
+ },
+ {
+ FOURCC_RV24,XvRGB,LSBFirst,
+ {'R','V','2','4',0,0,0,0,0,0,0,0,0,0,0,0},
+ 32, XvPacked, 1, 24, 0x000000ff, 0x0000ff00, 0x00ff0000, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ {'R','V','B',0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
+ XvTopToBottom
+ },
+ {
+ FOURCC_RV32, XvRGB, LSBFirst,
+ {'R','V','3','2',0,0,0,0,0,0,0,0,0,0,0,0},
+ 32, XvPacked, 1, 32, 0x000000ff, 0x0000ff00, 0x00ff0000, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ {'R','V','B',0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
+ XvTopToBottom
+ },
+ XVIMAGE_YV12,
+ XVIMAGE_YUY2,
+ XVIMAGE_UYVY,
+ XVIMAGE_I420
+};
+
+/*****************************************************************************/
+static int
+rdpXvAllocatePort(unsigned long port, XvPortPtr pPort, XvPortPtr* ppPort)
+{
+ LLOGLN(0, ("rdpXvAllocatePort:"));
+ *ppPort = pPort;
+ return Success;
+}
+
+/*****************************************************************************/
+static int
+rdpXvFreePort(XvPortPtr pPort)
+{
+ LLOGLN(0, ("rdpXvFreePort:"));
+ return Success;
+}
+
+/*****************************************************************************/
+static int
+rdpXvPutVideo(ClientPtr client, DrawablePtr pDraw, XvPortPtr pPort, GCPtr pGC,
+ INT16 vid_x, INT16 vid_y, CARD16 vid_w, CARD16 vid_h,
+ INT16 drw_x, INT16 drw_y, CARD16 drw_w, CARD16 drw_h)
+{
+ LLOGLN(0, ("rdpXvPutVideo:"));
+ return Success;
+}
+
+/*****************************************************************************/
+static int
+rdpXvPutStill(ClientPtr client, DrawablePtr pDraw, XvPortPtr pPort, GCPtr pGC,
+ INT16 vid_x, INT16 vid_y, CARD16 vid_w, CARD16 vid_h,
+ INT16 drw_x, INT16 drw_y, CARD16 drw_w, CARD16 drw_h)
+{
+ LLOGLN(0, ("rdpXvPutStill:"));
+ return Success;
+}
+
+/*****************************************************************************/
+static int
+rdpXvGetVideo(ClientPtr client, DrawablePtr pDraw, XvPortPtr pPort, GCPtr pGC,
+ INT16 vid_x, INT16 vid_y, CARD16 vid_w, CARD16 vid_h,
+ INT16 drw_x, INT16 drw_y, CARD16 drw_w, CARD16 drw_h)
+{
+ LLOGLN(0, ("rdpXvGetVideo:"));
+ return Success;
+}
+
+/*****************************************************************************/
+static int
+rdpXvGetStill(ClientPtr client, DrawablePtr pDraw, XvPortPtr pPort, GCPtr pGC,
+ INT16 vid_x, INT16 vid_y, CARD16 vid_w, CARD16 vid_h,
+ INT16 drw_x, INT16 drw_y, CARD16 drw_w, CARD16 drw_h)
+{
+ LLOGLN(0, ("rdpXvGetStill:"));
+ return Success;
+}
+
+/*****************************************************************************/
+static int
+rdpXvStopVideo(ClientPtr client, XvPortPtr pPort, DrawablePtr pDraw)
+{
+ LLOGLN(0, ("rdpXvStopVideo:"));
+ return Success;
+}
+
+/*****************************************************************************/
+static int
+rdpXvSetPortAttribute(ClientPtr client, XvPortPtr pPort, Atom attribute,
+ INT32 value)
+{
+ LLOGLN(0, ("rdpXvxSetPortAttribute:"));
+ return Success;
+}
+
+/*****************************************************************************/
+static int
+rdpXvGetPortAttribute(ClientPtr client, XvPortPtr pPort, Atom attribute,
+ INT32* p_value)
+{
+ LLOGLN(0, ("rdpXvGetPortAttribute:"));
+ return Success;
+}
+
+/*****************************************************************************/
+static int
+rdpXvQueryBestSize(ClientPtr client, XvPortPtr pPort, CARD8 motion,
+ CARD16 vid_w, CARD16 vid_h, CARD16 drw_w, CARD16 drw_h,
+ unsigned int *p_w, unsigned int *p_h)
+{
+ LLOGLN(0, ("rdpXvQueryBestSize:"));
+ return Success;
+}
+
+/*****************************************************************************/
+static int
+rdpXvPutImage(ClientPtr client, DrawablePtr pDraw, XvPortPtr pPort, GCPtr pGC,
+ 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* data, Bool sync,
+ CARD16 width, CARD16 height)
+{
+ LLOGLN(0, ("rdpXvPutImage:"));
+ return Success;
+}
+
+/*****************************************************************************/
+static int
+rdpXvPrintFormat(int id)
+{
+ switch (id)
+ {
+ case FOURCC_YV12:
+ /* big buck bunny 480p h264 */
+ /* vob files too */
+ LLOGLN(0, ("FOURCC_YV12"));
+ break;
+ case FOURCC_I420:
+ LLOGLN(0, ("FOURCC_I420"));
+ break;
+ case FOURCC_RV15:
+ LLOGLN(0, ("FOURCC_RV15"));
+ break;
+ case FOURCC_RV16:
+ LLOGLN(0, ("FOURCC_RV16"));
+ break;
+ case FOURCC_YUY2:
+ LLOGLN(0, ("FOURCC_YUY2"));
+ break;
+ case FOURCC_UYVY:
+ LLOGLN(0, ("FOURCC_UYVY"));
+ break;
+ case FOURCC_RV24:
+ LLOGLN(0, ("FOURCC_RV24"));
+ break;
+ default:
+ LLOGLN(0, ("other"));
+ break;
+ }
+ return 0;
+}
+
+/*****************************************************************************/
+static int
+rdpXvQueryImageAttributes(ClientPtr client, XvPortPtr pPort, XvImagePtr format,
+ CARD16* width, CARD16* height, int* pitches,
+ int* offsets)
+{
+ int size;
+ int tmp;
+
+ LLOGLN(0, ("rdpXvQueryImageAttributes:"));
+
+
+ size = 0;
+ /* this is same code as all drivers currently have */
+ if (*width > 2046)
+ {
+ *width = 2046;
+ }
+ if (*height > 2046)
+ {
+ *height = 2046;
+ }
+ /* make w multiple of 4 so that resizing works properly */
+ *width = (*width + 3) & ~3;
+ if (offsets)
+ {
+ offsets[0] = 0;
+ }
+ LLOGLN(0, ("format %x", format->id));
+ rdpXvPrintFormat(format->id);
+ switch (format->id)
+ {
+ case FOURCC_YV12:
+ case FOURCC_I420:
+ /* make h be even */
+ *height = (*height + 1) & ~1;
+ /* make w be multiple of 4 (ie. pad it) */
+ size = (*width + 3) & ~3;
+ /* width of a Y row => width of image */
+ if (pitches != 0)
+ {
+ pitches[0] = size;
+ }
+ /* offset of U plane => w*h */
+ size *= *height;
+ if (offsets != 0)
+ {
+ offsets[1] = size;
+ }
+ /* width of U, V row => width/2 */
+ tmp = ((*width >> 1) +3) & ~3;
+ if (pitches != 0)
+ {
+ pitches[1] = pitches[2] = tmp;
+ }
+ /* offset of V => Y plane + U plane (w*h + w/2*h/2) */
+ tmp *= (*height >> 1);
+ size += tmp;
+ size += tmp;
+ if (offsets != 0)
+ {
+ offsets[2] = size;
+ }
+ size += tmp;
+ break;
+ case FOURCC_RV15:
+ case FOURCC_RV16:
+ case FOURCC_YUY2:
+ case FOURCC_UYVY:
+ size = (*width) * 2;
+ if (pitches)
+ {
+ pitches[0] = size;
+ }
+ size *= *height;
+ break;
+ case FOURCC_RV24:
+ size = (*width) * 3;
+ if (pitches)
+ {
+ pitches[0] = size;
+ }
+ size *= *height;
+ break;
+ default:
+ LLOGLN(0, ("rdpXvQueryImageAttributes: error"));
+ break;
+ }
+ return size;
+}
+
+/*****************************************************************************/
+static Bool
+rdpXvCloseScreen(int i, ScreenPtr pScreen)
+{
+ XvScreenPtr pxvs = GET_XV_SCREEN(pScreen);
+
+ LLOGLN(0, ("rdpXvCloseScreen:"));
+ free(pxvs->pAdaptors);
+ return 0;
+}
+
+/*****************************************************************************/
+static int
+rdpXvQueryAdaptors(ScreenPtr pScreen, XvAdaptorPtr* p_pAdaptors,
+ int* p_nAdaptors)
+{
+ XvScreenPtr pxvs = GET_XV_SCREEN(pScreen);
+
+ LLOGLN(0, ("rdpXvQueryAdaptors:"));
+ *p_nAdaptors = pxvs->nAdaptors;
+ *p_pAdaptors = pxvs->pAdaptors;
+ return Success;
+}
+
+#ifdef MITSHM
+#endif
+
+/*****************************************************************************/
+static int
+rdpXvInitAdaptors(ScreenPtr pScreen)
+{
+ XvScreenPtr pxvs = GET_XV_SCREEN(pScreen);
+ XvAdaptorPtr pAdaptor;
+
+ pAdaptor = malloc(sizeof(XvAdaptorRec));
+ memset(pAdaptor, 0, sizeof(XvAdaptorRec));
+ pAdaptor->type = XvInputMask | XvOutputMask | XvImageMask |
+ XvVideoMask | XvStillMask;
+ pAdaptor->pScreen = pScreen;
+
+ pAdaptor->name = g_xv_adaptor_name;
+
+ pAdaptor->nEncodings = T_NUM_ENCODINGS;
+ pAdaptor->pEncodings = g_encodings;
+
+ pAdaptor->nFormats = T_NUM_FORMATS;
+ pAdaptor->pFormats = g_formats;
+
+ pAdaptor->nImages = T_NUM_IMAGES;
+ pAdaptor->pImages = g_images;
+
+ pAdaptor->nPorts = T_NUM_PORTS;
+ pAdaptor->pPorts = g_ports;
+
+ pAdaptor->ddAllocatePort = rdpXvAllocatePort;
+ pAdaptor->ddFreePort = rdpXvFreePort;
+ pAdaptor->ddPutVideo = rdpXvPutVideo;
+ pAdaptor->ddPutStill = rdpXvPutStill;
+ pAdaptor->ddGetVideo = rdpXvGetVideo;
+ pAdaptor->ddGetStill = rdpXvGetStill;
+ pAdaptor->ddStopVideo = rdpXvStopVideo;
+ pAdaptor->ddSetPortAttribute = rdpXvSetPortAttribute;
+ pAdaptor->ddGetPortAttribute = rdpXvGetPortAttribute;
+ pAdaptor->ddQueryBestSize = rdpXvQueryBestSize;
+ pAdaptor->ddPutImage = rdpXvPutImage;
+ pAdaptor->ddQueryImageAttributes = rdpXvQueryImageAttributes;
+
+ pxvs->pAdaptors = pAdaptor;
+
+ memset(g_encodings, 0, sizeof(g_encodings));
+ g_encodings[0].id = FakeClientID(0);
+ g_encodings[0].pScreen = pScreen;
+ g_encodings[0].name = g_xv_encoding_name;
+ g_encodings[0].width = 2046;
+ g_encodings[0].height = 2046;
+ g_encodings[0].rate.numerator = 1;
+ g_encodings[0].rate.denominator = 1;
+
+ memset(g_formats, 0, sizeof(g_formats));
+ g_formats[0].depth = g_rdpScreen.depth;
+ g_formats[0].visual = pScreen->rootVisual;
+
+ memset(g_ports, 0, sizeof(g_ports));
+ g_ports[0].id = FakeClientID(0);
+ g_ports[0].pAdaptor = pAdaptor;
+ g_ports[0].pNotify = 0;
+ g_ports[0].pDraw = 0;
+ g_ports[0].grab.id = 0;
+ g_ports[0].grab.client = 0;
+ g_ports[0].time = currentTime;
+ g_ports[0].devPriv.ptr = 0;
+
+ pAdaptor->base_id = g_ports[0].id;
+
+ AddResource(g_ports[0].id, XvRTPort, g_ports);
+
+ pxvs->nAdaptors = 1;
+ pxvs->pAdaptors = pAdaptor;
+
+ return 0;
+}
+
+/*****************************************************************************/
+/* returns error */
+int
+rdpXvInit(ScreenPtr pScreen)
+{
+ XvScreenPtr pxvs;
+
+ LLOGLN(0, ("rdpXvInit:"));
+ XvScreenInit(pScreen);
+ g_XvScreenKey = XvGetScreenKey();
+ pxvs = GET_XV_SCREEN(pScreen);
+ pxvs->nAdaptors = 0;
+ pxvs->ddCloseScreen = rdpXvCloseScreen;
+ pxvs->ddQueryAdaptors = rdpXvQueryAdaptors;
+ rdpXvInitAdaptors(pScreen);
+ return 0;
+}
diff --git a/xorg/X11R7.6/x11_file_list.txt b/xorg/X11R7.6/x11_file_list.txt
index 1223e812..d6f86892 100644
--- a/xorg/X11R7.6/x11_file_list.txt
+++ b/xorg/X11R7.6/x11_file_list.txt
@@ -10,7 +10,7 @@ damageproto-1.2.1.tar.bz2 : damageproto-1.2.1
makedepend-1.0.3.tar.bz2 : makedepend-1.0.3 :
libxml2-sources-2.7.8.tar.gz : libxml2-2.7.8 :
libpng-1.2.46.tar.gz : libpng-1.2.46 :
-pixman-0.15.20.tar.bz2 : pixman-0.15.20 : --disable-gtk
+pixman-0.30.0.tar.bz2 : pixman-0.30.0 : --disable-gtk
freetype-2.4.6.tar.bz2 : freetype-2.4.6 :
fontconfig-2.8.0.tar.gz : fontconfig-2.8.0 :
cairo-1.8.8.tar.gz : cairo-1.8.8 :