xserver/hw/kdrive/ephyr
Peter Hutterer a94d945065 kdrive: modify ephyr events to use POINTER_DESKTOP and scale them to that
A multi-head Xephyr instance has the pointer stuck on one screen
because of bad coordinate calculation. The coordinates passed to
GetPointerEvents are per-screen, so the cursor gets stuck on the left-most
screen by default.

Adjust and mark the events as POINTER_DESKTOP, so the DIX
can adjust them accordingly.

Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
Reviewed-by: Keith Packard <keithp@keithp.com>
2013-11-14 13:34:23 +10:00
..
man ephyr: add -resizeable to the man page 2013-05-15 09:36:00 +10:00
.gitignore Xephyr: build Xephyr man pages using XORG_MANPAGE_SECTIONS 2011-01-18 15:10:29 -08:00
Makefile.am ephyr: Remove the helper libs for each of the optional components. 2013-09-03 14:35:18 -07:00
README Xephyr grab fix 2004-11-11 14:55:30 +00:00
ephyr.c kdrive: modify ephyr events to use POINTER_DESKTOP and scale them to that 2013-11-14 13:34:23 +10:00
ephyr.h ephyr: Move the host screen info into the kdrive screen private. 2013-09-03 14:34:48 -07:00
ephyr_draw.c Introduce a consistent coding style 2012-03-21 13:54:42 -07:00
ephyrdri.c Xephyr: move ephyrdri over to xcb 2013-09-03 11:01:00 -07:00
ephyrdri.h ephyr: Fix warning about XID vs unsigned long * by changing function args 2013-08-21 09:10:49 -07:00
ephyrdriext.c Fix Xephyr compilation when DEBUG is enabled 2013-10-14 11:07:37 +10:00
ephyrdriext.h Introduce a consistent coding style 2012-03-21 13:54:42 -07:00
ephyrglxext.c ephyr: Expose a single function for detecting extensions. 2013-09-03 14:34:41 -07:00
ephyrglxext.h Introduce a consistent coding style 2012-03-21 13:54:42 -07:00
ephyrhostglx.c Xephyr: we're not using Xlib anymore, no need to undef _XSERVER64 2013-09-03 11:02:03 -07:00
ephyrhostglx.h Xephyr: move glx code to xcb 2013-09-03 11:01:40 -07:00
ephyrinit.c kdrive/ephyr: Remove duplicate ephyrExtensions and ephyrExtensionInit decls 2013-10-04 16:43:41 -07:00
ephyrlog.h Introduce a consistent coding style 2012-03-21 13:54:42 -07:00
ephyrvideo.c ephyr: Garbage collect some dead XV clipping code. 2013-09-03 14:35:21 -07:00
hostx.c ephyr: xcb_connect returns an error, not NULL 2013-11-14 13:34:10 +10:00
hostx.h ephyr: Use host (HW) cursors by default. 2013-09-03 14:35:38 -07:00
os.c kdrive: Fix const cast warnings in arguments processing. 2013-08-21 09:10:46 -07:00

Xephyr README
=============


What Is It ?
============

Xephyr is a a kdrive server that outputs to a window on a pre-existing
'host' X display. Think Xnest but with support for modern extensions
like composite, damage and randr. 

Unlike Xnest which is an X proxy, i.e.  limited to the
capabilities of the host X server, Xephyr is a real X server which
uses the host X server window as "framebuffer" via fast SHM XImages.

It also has support for 'visually' debugging what the server is
painting.


How To Use 
==========

You probably want to run like;

Xephyr :1 -ac -screen 800x600 &

Then set DISPLAY=:1 and run whatever X apps you like.

Use 'xrandr' to change to orientation/size. 

There is a '-parent' switch which works just like Xnests ( for use
with things like matchbox-nest - http://matchbox.handhelds.org ).

There is also a '-host-cursor' switch to set 'cursor acceleration' -
The host's cursor is reused. This is only really there to aid
debugging by avoiding server paints for the cursor. Performance
improvement is negiable. 

Send a SIGUSR1 to the server ( eg kill -USR1 `pidof Xephyr` ) to
toggle the debugging mode. In this mode red rectangles are painted to
screen areas getting painted before painting the actual content. The
delay between this can be altered by setting a XEPHYR_PAUSE env var to
a value in micro seconds.


Caveats
=======

 - Depth is limited to being the same as the host. 
   *Update* As of 8/11/2004. Xephyr can now do 8bpp & 16bpp 
            on 24bpp host.

 - Rotated displays are currently updated via full blits. This
   is slower than a normal oprientated display. Debug mode will
   therefor not be of much use rotated.  

 - The '-host-cursor' cursor is static in its appearence. 

 - The build gets a warning about 'nanosleep'. I think the various '-D'
   build flags are causing this. I havn't figured as yet how to work
   round it. It doesn't appear to break anything however. 

 - Keyboard handling is basic but works. 

 - Mouse button 5 probably wont work. 





Matthew Allum <mallum@o-hand.com> 2004