2007-07-21 12:08:39 +02:00
|
|
|
/*
|
|
|
|
* Xephyr - A kdrive X server thats runs in a host X window.
|
|
|
|
* Authored by Matthew Allum <mallum@openedhand.com>
|
|
|
|
*
|
|
|
|
* Copyright © 2007 OpenedHand Ltd
|
|
|
|
*
|
|
|
|
* 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, and that the name of OpenedHand Ltd not be used in
|
|
|
|
* advertising or publicity pertaining to distribution of the software without
|
|
|
|
* specific, written prior permission. OpenedHand Ltd makes no
|
|
|
|
* representations about the suitability of this software for any purpose. It
|
|
|
|
* is provided "as is" without express or implied warranty.
|
|
|
|
*
|
|
|
|
* OpenedHand Ltd DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
|
|
|
|
* INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
|
|
|
|
* EVENT SHALL OpenedHand Ltd 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.
|
|
|
|
*
|
|
|
|
* Authors:
|
|
|
|
* Dodji Seketeli <dodji@openedhand.com>
|
|
|
|
*/
|
|
|
|
#ifndef __EPHYRHOSTVIDEO_H__
|
|
|
|
#define __EPHYRHOSTVIDEO_H__
|
|
|
|
|
|
|
|
typedef void* EphyrHostXVAdaptor ;
|
|
|
|
typedef struct _EphyrHostXVAdaptorArray EphyrHostXVAdaptorArray ;
|
|
|
|
|
|
|
|
typedef struct _EphyrHostVideoFormat {
|
|
|
|
char depth ;
|
2007-07-23 12:43:43 +02:00
|
|
|
short visual_class;
|
2007-07-21 12:08:39 +02:00
|
|
|
} EphyrHostVideoFormat ;
|
|
|
|
|
|
|
|
typedef struct _EphyrHostRational {
|
|
|
|
int numerator ;
|
|
|
|
int denominator ;
|
|
|
|
} EphyrHostRational;
|
|
|
|
|
|
|
|
typedef struct _EphyrHostEncoding {
|
|
|
|
int id ;
|
|
|
|
char *name ;
|
|
|
|
unsigned short width, height ;
|
|
|
|
EphyrHostRational rate ;
|
|
|
|
} EphyrHostEncoding ;
|
|
|
|
|
|
|
|
typedef struct _EphyrHostAttribute {
|
|
|
|
int flags;
|
|
|
|
int min_value;
|
|
|
|
int max_value;
|
|
|
|
char *name;
|
|
|
|
} EphyrHostAttribute ;
|
|
|
|
|
|
|
|
typedef struct _EphyrHostImageFormat {
|
|
|
|
int id; /* Unique descriptor for the format */
|
|
|
|
int type; /* XvRGB, XvYUV */
|
|
|
|
int byte_order; /* LSBFirst, MSBFirst */
|
|
|
|
char guid[16]; /* Globally Unique IDentifier */
|
|
|
|
int bits_per_pixel;
|
|
|
|
int format; /* XvPacked, XvPlanar */
|
|
|
|
int num_planes;
|
|
|
|
|
|
|
|
/* for RGB formats only */
|
|
|
|
int depth;
|
|
|
|
unsigned int red_mask;
|
|
|
|
unsigned int green_mask;
|
|
|
|
unsigned int blue_mask;
|
|
|
|
|
|
|
|
/* for YUV formats only */
|
|
|
|
unsigned int y_sample_bits;
|
|
|
|
unsigned int u_sample_bits;
|
|
|
|
unsigned int v_sample_bits;
|
|
|
|
unsigned int horz_y_period;
|
|
|
|
unsigned int horz_u_period;
|
|
|
|
unsigned int horz_v_period;
|
|
|
|
unsigned int vert_y_period;
|
|
|
|
unsigned int vert_u_period;
|
|
|
|
unsigned int vert_v_period;
|
|
|
|
char component_order[32]; /* eg. UYVY */
|
|
|
|
int scanline_order; /* XvTopToBottom, XvBottomToTop */
|
|
|
|
} EphyrHostImageFormat ;
|
|
|
|
|
2007-08-09 10:55:10 +02:00
|
|
|
typedef struct {
|
|
|
|
unsigned short x1, y1, x2, y2 ;
|
|
|
|
} EphyrHostBox ;
|
|
|
|
|
2007-08-04 01:13:38 +02:00
|
|
|
void ephyrHostXVInit (void) ;
|
|
|
|
|
|
|
|
void ephyrHostFree (void *a_pointer) ;
|
2007-08-02 12:49:36 +02:00
|
|
|
|
2007-07-21 12:08:39 +02:00
|
|
|
/*
|
|
|
|
* host adaptor array
|
|
|
|
*/
|
2007-08-04 01:13:38 +02:00
|
|
|
Bool ephyrHostXVQueryAdaptors (EphyrHostXVAdaptorArray **a_adaptors) ;
|
|
|
|
void ephyrHostXVAdaptorArrayDelete (EphyrHostXVAdaptorArray *a_adaptors) ;
|
|
|
|
int ephyrHostXVAdaptorArrayGetSize (const EphyrHostXVAdaptorArray *a_this) ;
|
|
|
|
EphyrHostXVAdaptor* ephyrHostXVAdaptorArrayAt (const EphyrHostXVAdaptorArray *a_this,
|
2007-07-21 12:08:39 +02:00
|
|
|
int a_index) ;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* host adaptor
|
|
|
|
*/
|
|
|
|
|
2007-08-04 01:13:38 +02:00
|
|
|
char ephyrHostXVAdaptorGetType (const EphyrHostXVAdaptor *a_this) ;
|
|
|
|
const char* ephyrHostXVAdaptorGetName (const EphyrHostXVAdaptor *a_this) ;
|
|
|
|
EphyrHostVideoFormat* ephyrHostXVAdaptorGetVideoFormats
|
2007-07-21 12:08:39 +02:00
|
|
|
(const EphyrHostXVAdaptor *a_this,
|
|
|
|
int *a_nb_formats) ;
|
2007-08-04 01:13:38 +02:00
|
|
|
int ephyrHostXVAdaptorGetNbPorts (const EphyrHostXVAdaptor *a_this) ;
|
|
|
|
int ephyrHostXVAdaptorGetFirstPortID (const EphyrHostXVAdaptor *a_this) ;
|
2007-07-21 12:08:39 +02:00
|
|
|
|
2007-08-06 18:38:54 +02:00
|
|
|
Bool ephyrHostXVAdaptorHasPutVideo (const EphyrHostXVAdaptor *a_this,
|
|
|
|
Bool *a_result) ;
|
2007-08-07 14:16:13 +02:00
|
|
|
Bool ephyrHostXVAdaptorHasGetVideo (const EphyrHostXVAdaptor *a_this,
|
|
|
|
Bool *a_result) ;
|
2007-08-06 18:38:54 +02:00
|
|
|
Bool ephyrHostXVAdaptorHasPutStill (const EphyrHostXVAdaptor *a_this,
|
|
|
|
Bool *a_result) ;
|
2007-08-07 14:16:13 +02:00
|
|
|
Bool ephyrHostXVAdaptorHasGetStill (const EphyrHostXVAdaptor *a_this,
|
|
|
|
Bool *a_result) ;
|
2007-08-06 18:38:54 +02:00
|
|
|
Bool ephyrHostXVAdaptorHasPutImage (const EphyrHostXVAdaptor *a_this,
|
|
|
|
Bool *a_result) ;
|
|
|
|
|
2007-07-21 12:08:39 +02:00
|
|
|
/*
|
|
|
|
* encoding
|
|
|
|
*/
|
2007-08-04 01:13:38 +02:00
|
|
|
Bool ephyrHostXVQueryEncodings (int a_port_id,
|
2007-07-21 12:08:39 +02:00
|
|
|
EphyrHostEncoding **a_encodings,
|
|
|
|
unsigned int *a_num_encodings) ;
|
|
|
|
|
2007-08-04 01:13:38 +02:00
|
|
|
void ephyrHostEncodingsDelete (EphyrHostEncoding *a_encodings,
|
2007-07-21 12:08:39 +02:00
|
|
|
int a_num_encodings) ;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* attribute
|
|
|
|
*/
|
2007-08-04 01:13:38 +02:00
|
|
|
Bool ephyrHostXVQueryPortAttributes (int a_port_id,
|
2007-07-21 12:08:39 +02:00
|
|
|
EphyrHostAttribute **a_attributes,
|
|
|
|
int *a_num_attributes) ;
|
|
|
|
|
2007-08-04 01:13:38 +02:00
|
|
|
void ephyrHostAttributesDelete (EphyrHostAttribute *a_attributes) ;
|
2007-07-21 12:08:39 +02:00
|
|
|
/*
|
|
|
|
* image format
|
|
|
|
*/
|
|
|
|
|
2007-08-04 01:13:38 +02:00
|
|
|
Bool ephyrHostXVQueryImageFormats (int a_port_id,
|
2007-07-21 12:08:39 +02:00
|
|
|
EphyrHostImageFormat **a_formats,
|
|
|
|
int *a_num_format) ;
|
2007-07-31 23:18:52 +02:00
|
|
|
/*
|
|
|
|
* Port Attribute Get/Set
|
|
|
|
*/
|
2007-08-04 01:13:38 +02:00
|
|
|
Bool ephyrHostXVSetPortAttribute (int a_port_id,
|
2007-07-31 23:18:52 +02:00
|
|
|
int a_atom,
|
|
|
|
int a_attr_value) ;
|
2007-08-04 01:13:38 +02:00
|
|
|
Bool ephyrHostXVGetPortAttribute (int a_port_id,
|
2007-07-31 23:18:52 +02:00
|
|
|
int a_atom,
|
|
|
|
int *a_attr_value) ;
|
2007-08-02 12:49:36 +02:00
|
|
|
/*
|
|
|
|
*size query
|
|
|
|
*/
|
2007-08-04 01:13:38 +02:00
|
|
|
Bool ephyrHostXVQueryBestSize (int a_port_id,
|
2007-08-02 12:49:36 +02:00
|
|
|
Bool a_motion,
|
|
|
|
unsigned int a_frame_w,
|
|
|
|
unsigned int a_frame_h,
|
|
|
|
unsigned int a_drw_w,
|
|
|
|
unsigned int a_drw_h,
|
|
|
|
unsigned int *a_actual_w,
|
|
|
|
unsigned int *a_actual_h) ;
|
|
|
|
|
2007-08-04 01:13:38 +02:00
|
|
|
Bool ephyrHostXVQueryImageAttributes (int a_port_id,
|
2007-08-02 12:49:36 +02:00
|
|
|
int a_image_id /*image fourcc code*/,
|
|
|
|
unsigned short *a_width,
|
|
|
|
unsigned short *a_height,
|
|
|
|
int *a_image_size,
|
|
|
|
int *a_pitches,
|
|
|
|
int *a_offsets) ;
|
|
|
|
/*
|
|
|
|
* atom
|
|
|
|
*/
|
2007-08-04 01:13:38 +02:00
|
|
|
Bool ephyrHostGetAtom (const char* a_name,
|
2007-08-02 12:49:36 +02:00
|
|
|
Bool a_create_if_not_exists,
|
|
|
|
int *a_atom) ;
|
2007-08-04 01:13:38 +02:00
|
|
|
char* ephyrHostGetAtomName (int a_atom) ;
|
2007-08-02 12:49:36 +02:00
|
|
|
|
2007-08-03 01:10:39 +02:00
|
|
|
/*
|
|
|
|
*PutImage
|
|
|
|
* (ignore clipping for now)
|
|
|
|
*/
|
Xephyr: port XV/GL stuff of the new multiscreen architecture
We can now launch GL or XV apps in any of the
Xephyr screens we want.
* hw/kdrive/ephyr/hostx.c,h:
(hostx_get_window):
(hostx_create_window): make these functions be screen
number aware.
* hw/kdrive/ephyr/XF86dri.c : fix some compiler warnings.
* hw/kdrive/ephyr/ephyrdri.c:
(ephyrDRIQueryDirectRenderingCapable),
(ephyrDRIOpenConnection),
(ephyrDRIAuthConnection),
(ephyrDRICloseConnection),
(ephyrDRIGetClientDriverName),
(ephyrDRICreateContext),
(ephyrDRIDestroyContext),
(ephyrDRICreateDrawable),
(ephyrDRIGetDrawableInfo),
(ephyrDRIGetDeviceInfo): in all those functions, don't forward
the screen number we receive - from the client - to the host X.
We (Xephyr) are always targetting the same X display screen, which is
the one Xephyr got launched against. So we enforce that in the code.
* hw/kdrive/ephyr/ephyrdriext.c:
(EphyrMirrorHostVisuals): make this duplicate the visuals of the host X
default screen into a given Xephyr screen. This way we have a chance
to update the visuals of all Xephyr screen to make them mirror those
of the host X.
(many other places): specify screen number where required by the api
change in hostx.h.
* hw/kdrive/ephyr/ephyrglxext.c: specify screen number where required
by the api change in hostx.h
* hw/kdrive/ephyr/ephyrhostglx.c: don't forward the screen number we
receive - from the client - to the host X.
We (Xephyr) are always targetting the same
X display screen, which is
the one Xephyr got launched against. So we enforce that in the code.
* hw/kdrive/ephyr/ephyrhostvideo.c,h: take in account the screen number received
from the client app. This is useful to know on which Xephyr screen we
need to display video stuff.
* hw/kdrive/ephyr/ephyrvideo.c: update this to reflect the API change
in hw/kdrive/ephyr/ephyrhostvideo.h.
(ephyrSetPortAttribute): when parameters are not valid
- they exceed their validity range - send them to the host anyway
and do not return an error to clients.
Some host expose buggy validity range, so rejecting client for that
is too harsh.
2007-10-03 13:03:34 +02:00
|
|
|
Bool ephyrHostXVPutImage (int a_screen_num,
|
|
|
|
int a_port_id,
|
2007-08-03 01:10:39 +02:00
|
|
|
int a_image_id,
|
|
|
|
int a_drw_x,
|
|
|
|
int a_drw_y,
|
|
|
|
int a_drw_w,
|
|
|
|
int a_drw_h,
|
|
|
|
int a_src_x,
|
|
|
|
int a_src_y,
|
|
|
|
int a_src_w,
|
|
|
|
int a_src_h,
|
|
|
|
int a_image_width,
|
|
|
|
int a_image_height,
|
2007-08-09 10:55:10 +02:00
|
|
|
unsigned char *a_buf,
|
|
|
|
EphyrHostBox *a_clip_rects,
|
|
|
|
int a_clip_rect_nums) ;
|
2007-08-02 12:49:36 +02:00
|
|
|
|
2007-08-07 14:16:13 +02:00
|
|
|
/*
|
|
|
|
* Putvideo/PutStill/GetVideo
|
|
|
|
*/
|
Xephyr: port XV/GL stuff of the new multiscreen architecture
We can now launch GL or XV apps in any of the
Xephyr screens we want.
* hw/kdrive/ephyr/hostx.c,h:
(hostx_get_window):
(hostx_create_window): make these functions be screen
number aware.
* hw/kdrive/ephyr/XF86dri.c : fix some compiler warnings.
* hw/kdrive/ephyr/ephyrdri.c:
(ephyrDRIQueryDirectRenderingCapable),
(ephyrDRIOpenConnection),
(ephyrDRIAuthConnection),
(ephyrDRICloseConnection),
(ephyrDRIGetClientDriverName),
(ephyrDRICreateContext),
(ephyrDRIDestroyContext),
(ephyrDRICreateDrawable),
(ephyrDRIGetDrawableInfo),
(ephyrDRIGetDeviceInfo): in all those functions, don't forward
the screen number we receive - from the client - to the host X.
We (Xephyr) are always targetting the same X display screen, which is
the one Xephyr got launched against. So we enforce that in the code.
* hw/kdrive/ephyr/ephyrdriext.c:
(EphyrMirrorHostVisuals): make this duplicate the visuals of the host X
default screen into a given Xephyr screen. This way we have a chance
to update the visuals of all Xephyr screen to make them mirror those
of the host X.
(many other places): specify screen number where required by the api
change in hostx.h.
* hw/kdrive/ephyr/ephyrglxext.c: specify screen number where required
by the api change in hostx.h
* hw/kdrive/ephyr/ephyrhostglx.c: don't forward the screen number we
receive - from the client - to the host X.
We (Xephyr) are always targetting the same
X display screen, which is
the one Xephyr got launched against. So we enforce that in the code.
* hw/kdrive/ephyr/ephyrhostvideo.c,h: take in account the screen number received
from the client app. This is useful to know on which Xephyr screen we
need to display video stuff.
* hw/kdrive/ephyr/ephyrvideo.c: update this to reflect the API change
in hw/kdrive/ephyr/ephyrhostvideo.h.
(ephyrSetPortAttribute): when parameters are not valid
- they exceed their validity range - send them to the host anyway
and do not return an error to clients.
Some host expose buggy validity range, so rejecting client for that
is too harsh.
2007-10-03 13:03:34 +02:00
|
|
|
Bool ephyrHostXVPutVideo (int a_screen_num,
|
|
|
|
int a_port_id,
|
2007-08-07 14:16:13 +02:00
|
|
|
int a_vid_x, int a_vid_y, int a_vid_w, int a_vid_h,
|
|
|
|
int a_drw_x, int a_drw_y, int a_drw_w, int a_drw_h) ;
|
|
|
|
|
Xephyr: port XV/GL stuff of the new multiscreen architecture
We can now launch GL or XV apps in any of the
Xephyr screens we want.
* hw/kdrive/ephyr/hostx.c,h:
(hostx_get_window):
(hostx_create_window): make these functions be screen
number aware.
* hw/kdrive/ephyr/XF86dri.c : fix some compiler warnings.
* hw/kdrive/ephyr/ephyrdri.c:
(ephyrDRIQueryDirectRenderingCapable),
(ephyrDRIOpenConnection),
(ephyrDRIAuthConnection),
(ephyrDRICloseConnection),
(ephyrDRIGetClientDriverName),
(ephyrDRICreateContext),
(ephyrDRIDestroyContext),
(ephyrDRICreateDrawable),
(ephyrDRIGetDrawableInfo),
(ephyrDRIGetDeviceInfo): in all those functions, don't forward
the screen number we receive - from the client - to the host X.
We (Xephyr) are always targetting the same X display screen, which is
the one Xephyr got launched against. So we enforce that in the code.
* hw/kdrive/ephyr/ephyrdriext.c:
(EphyrMirrorHostVisuals): make this duplicate the visuals of the host X
default screen into a given Xephyr screen. This way we have a chance
to update the visuals of all Xephyr screen to make them mirror those
of the host X.
(many other places): specify screen number where required by the api
change in hostx.h.
* hw/kdrive/ephyr/ephyrglxext.c: specify screen number where required
by the api change in hostx.h
* hw/kdrive/ephyr/ephyrhostglx.c: don't forward the screen number we
receive - from the client - to the host X.
We (Xephyr) are always targetting the same
X display screen, which is
the one Xephyr got launched against. So we enforce that in the code.
* hw/kdrive/ephyr/ephyrhostvideo.c,h: take in account the screen number received
from the client app. This is useful to know on which Xephyr screen we
need to display video stuff.
* hw/kdrive/ephyr/ephyrvideo.c: update this to reflect the API change
in hw/kdrive/ephyr/ephyrhostvideo.h.
(ephyrSetPortAttribute): when parameters are not valid
- they exceed their validity range - send them to the host anyway
and do not return an error to clients.
Some host expose buggy validity range, so rejecting client for that
is too harsh.
2007-10-03 13:03:34 +02:00
|
|
|
Bool ephyrHostXVGetVideo (int a_screen_num,
|
|
|
|
int a_port_id,
|
2007-08-07 14:16:13 +02:00
|
|
|
int a_vid_x, int a_vid_y, int a_vid_w, int a_vid_h,
|
|
|
|
int a_drw_x, int a_drw_y, int a_drw_w, int a_drw_h) ;
|
|
|
|
|
Xephyr: port XV/GL stuff of the new multiscreen architecture
We can now launch GL or XV apps in any of the
Xephyr screens we want.
* hw/kdrive/ephyr/hostx.c,h:
(hostx_get_window):
(hostx_create_window): make these functions be screen
number aware.
* hw/kdrive/ephyr/XF86dri.c : fix some compiler warnings.
* hw/kdrive/ephyr/ephyrdri.c:
(ephyrDRIQueryDirectRenderingCapable),
(ephyrDRIOpenConnection),
(ephyrDRIAuthConnection),
(ephyrDRICloseConnection),
(ephyrDRIGetClientDriverName),
(ephyrDRICreateContext),
(ephyrDRIDestroyContext),
(ephyrDRICreateDrawable),
(ephyrDRIGetDrawableInfo),
(ephyrDRIGetDeviceInfo): in all those functions, don't forward
the screen number we receive - from the client - to the host X.
We (Xephyr) are always targetting the same X display screen, which is
the one Xephyr got launched against. So we enforce that in the code.
* hw/kdrive/ephyr/ephyrdriext.c:
(EphyrMirrorHostVisuals): make this duplicate the visuals of the host X
default screen into a given Xephyr screen. This way we have a chance
to update the visuals of all Xephyr screen to make them mirror those
of the host X.
(many other places): specify screen number where required by the api
change in hostx.h.
* hw/kdrive/ephyr/ephyrglxext.c: specify screen number where required
by the api change in hostx.h
* hw/kdrive/ephyr/ephyrhostglx.c: don't forward the screen number we
receive - from the client - to the host X.
We (Xephyr) are always targetting the same
X display screen, which is
the one Xephyr got launched against. So we enforce that in the code.
* hw/kdrive/ephyr/ephyrhostvideo.c,h: take in account the screen number received
from the client app. This is useful to know on which Xephyr screen we
need to display video stuff.
* hw/kdrive/ephyr/ephyrvideo.c: update this to reflect the API change
in hw/kdrive/ephyr/ephyrhostvideo.h.
(ephyrSetPortAttribute): when parameters are not valid
- they exceed their validity range - send them to the host anyway
and do not return an error to clients.
Some host expose buggy validity range, so rejecting client for that
is too harsh.
2007-10-03 13:03:34 +02:00
|
|
|
Bool ephyrHostXVPutStill (int a_screen_num,
|
|
|
|
int a_port_id,
|
2007-08-07 14:16:13 +02:00
|
|
|
int a_vid_x, int a_vid_y, int a_vid_w, int a_vid_h,
|
|
|
|
int a_drw_x, int a_drw_y, int a_drw_w, int a_drw_h) ;
|
|
|
|
|
Xephyr: port XV/GL stuff of the new multiscreen architecture
We can now launch GL or XV apps in any of the
Xephyr screens we want.
* hw/kdrive/ephyr/hostx.c,h:
(hostx_get_window):
(hostx_create_window): make these functions be screen
number aware.
* hw/kdrive/ephyr/XF86dri.c : fix some compiler warnings.
* hw/kdrive/ephyr/ephyrdri.c:
(ephyrDRIQueryDirectRenderingCapable),
(ephyrDRIOpenConnection),
(ephyrDRIAuthConnection),
(ephyrDRICloseConnection),
(ephyrDRIGetClientDriverName),
(ephyrDRICreateContext),
(ephyrDRIDestroyContext),
(ephyrDRICreateDrawable),
(ephyrDRIGetDrawableInfo),
(ephyrDRIGetDeviceInfo): in all those functions, don't forward
the screen number we receive - from the client - to the host X.
We (Xephyr) are always targetting the same X display screen, which is
the one Xephyr got launched against. So we enforce that in the code.
* hw/kdrive/ephyr/ephyrdriext.c:
(EphyrMirrorHostVisuals): make this duplicate the visuals of the host X
default screen into a given Xephyr screen. This way we have a chance
to update the visuals of all Xephyr screen to make them mirror those
of the host X.
(many other places): specify screen number where required by the api
change in hostx.h.
* hw/kdrive/ephyr/ephyrglxext.c: specify screen number where required
by the api change in hostx.h
* hw/kdrive/ephyr/ephyrhostglx.c: don't forward the screen number we
receive - from the client - to the host X.
We (Xephyr) are always targetting the same
X display screen, which is
the one Xephyr got launched against. So we enforce that in the code.
* hw/kdrive/ephyr/ephyrhostvideo.c,h: take in account the screen number received
from the client app. This is useful to know on which Xephyr screen we
need to display video stuff.
* hw/kdrive/ephyr/ephyrvideo.c: update this to reflect the API change
in hw/kdrive/ephyr/ephyrhostvideo.h.
(ephyrSetPortAttribute): when parameters are not valid
- they exceed their validity range - send them to the host anyway
and do not return an error to clients.
Some host expose buggy validity range, so rejecting client for that
is too harsh.
2007-10-03 13:03:34 +02:00
|
|
|
Bool ephyrHostXVGetStill (int a_screen_num,
|
|
|
|
int a_port_id,
|
2007-08-07 14:16:13 +02:00
|
|
|
int a_vid_x, int a_vid_y, int a_vid_w, int a_vid_h,
|
|
|
|
int a_drw_x, int a_drw_y, int a_drw_w, int a_drw_h) ;
|
2007-08-16 17:30:13 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
* StopVideo
|
|
|
|
*/
|
Xephyr: port XV/GL stuff of the new multiscreen architecture
We can now launch GL or XV apps in any of the
Xephyr screens we want.
* hw/kdrive/ephyr/hostx.c,h:
(hostx_get_window):
(hostx_create_window): make these functions be screen
number aware.
* hw/kdrive/ephyr/XF86dri.c : fix some compiler warnings.
* hw/kdrive/ephyr/ephyrdri.c:
(ephyrDRIQueryDirectRenderingCapable),
(ephyrDRIOpenConnection),
(ephyrDRIAuthConnection),
(ephyrDRICloseConnection),
(ephyrDRIGetClientDriverName),
(ephyrDRICreateContext),
(ephyrDRIDestroyContext),
(ephyrDRICreateDrawable),
(ephyrDRIGetDrawableInfo),
(ephyrDRIGetDeviceInfo): in all those functions, don't forward
the screen number we receive - from the client - to the host X.
We (Xephyr) are always targetting the same X display screen, which is
the one Xephyr got launched against. So we enforce that in the code.
* hw/kdrive/ephyr/ephyrdriext.c:
(EphyrMirrorHostVisuals): make this duplicate the visuals of the host X
default screen into a given Xephyr screen. This way we have a chance
to update the visuals of all Xephyr screen to make them mirror those
of the host X.
(many other places): specify screen number where required by the api
change in hostx.h.
* hw/kdrive/ephyr/ephyrglxext.c: specify screen number where required
by the api change in hostx.h
* hw/kdrive/ephyr/ephyrhostglx.c: don't forward the screen number we
receive - from the client - to the host X.
We (Xephyr) are always targetting the same
X display screen, which is
the one Xephyr got launched against. So we enforce that in the code.
* hw/kdrive/ephyr/ephyrhostvideo.c,h: take in account the screen number received
from the client app. This is useful to know on which Xephyr screen we
need to display video stuff.
* hw/kdrive/ephyr/ephyrvideo.c: update this to reflect the API change
in hw/kdrive/ephyr/ephyrhostvideo.h.
(ephyrSetPortAttribute): when parameters are not valid
- they exceed their validity range - send them to the host anyway
and do not return an error to clients.
Some host expose buggy validity range, so rejecting client for that
is too harsh.
2007-10-03 13:03:34 +02:00
|
|
|
Bool ephyrHostXVStopVideo (int a_screen_num, int a_port_id) ;
|
2007-08-16 17:30:13 +02:00
|
|
|
|
2007-07-21 12:08:39 +02:00
|
|
|
#endif /*__EPHYRHOSTVIDEO_H__*/
|
|
|
|
|