xserver/hw/kdrive/ephyr
Adam Jackson 7f88489963 ephyr: Sync less in hostx_paint_rect
Move the xcb_aux_sync into the shm path, where we do still need it to
synchronize access with the host. In the non-shm path the image is
copied to the host anyway so the sync just adds latency and keeps you
from using all your network bandwidth.

Only the non-shm-putimage path benefits from this, but the benefit is
significant even on the local machine (here a 3.2GHz Core i7-8700, using
XEPHYR_NO_SHM=1):

      before                  after   Operation
------------   --------------------   -------------------------
 228000000.0    225000000.0 (0.987)   Dot
  40900000.0     41600000.0 (1.017)   1x1 rectangle
  10400000.0     10700000.0 (1.029)   10x10 rectangle
    477000.0       471000.0 (0.987)   100x100 rectangle
     30900.0        31800.0 (1.029)   500x500 rectangle
    760000.0       981000.0 (1.291)   PutImage 10x10 square
     14700.0        19200.0 (1.306)   PutImage 100x100 square
       320.0          382.0 (1.194)   PutImage 500x500 square
    749000.0       984000.0 (1.314)   ShmPutImage 10x10 square
    268000.0       304000.0 (1.134)   ShmPutImage 100x100 square
     16600.0        18500.0 (1.114)   ShmPutImage 500x500 square

Reviewed-by: Emma Anholt <emma@anholt.net>
2022-06-27 16:39:49 -04:00
..
man Remove autotools support 2021-10-27 13:15:40 +03:00
.gitignore Xephyr: build Xephyr man pages using XORG_MANPAGE_SECTIONS 2011-01-18 15:10:29 -08:00
README Fix spelling/wording issues 2020-07-05 13:07:33 -07:00
ephyr.c ephyr/glamor: Port to EGL 2021-09-15 19:14:23 +00:00
ephyr.h ephyr/glamor: Port to EGL 2021-09-15 19:14:23 +00:00
ephyr_draw.c kdrive: Drop kdrive-config.h. 2017-03-23 13:17:36 -04:00
ephyr_glamor.c glamor: Require EGL_KHR_no_config_context 2021-09-15 19:14:23 +00:00
ephyr_glamor.h ephyr/glamor: Port to EGL 2021-09-15 19:14:23 +00:00
ephyr_glamor_xv.c kdrive: Drop kdrive-config.h. 2017-03-23 13:17:36 -04:00
ephyrcursor.c kdrive: Drop kdrive-config.h. 2017-03-23 13:17:36 -04:00
ephyrinit.c xephyr: Don't check for SeatId anymore 2022-02-03 22:34:03 +00:00
ephyrlog.h Fix spelling/wording issues 2020-07-05 13:07:33 -07:00
ephyrvideo.c Fix spelling/wording issues 2020-07-05 13:07:33 -07:00
hostx.c ephyr: Sync less in hostx_paint_rect 2022-06-27 16:39:49 -04:00
hostx.h Fix spelling/wording issues 2020-07-05 13:07:33 -07:00
meson.build ephyr/glamor: Port to EGL 2021-09-15 19:14:23 +00: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 Xnest's ( 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 negligible.

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 microseconds.


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
   therefore not be of much use rotated.

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

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

 - Keyboard handling is basic but works.

 - Mouse button 5 probably won't work.





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