• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 #ifndef _LINUX_DSSCOMP_H
2 #define _LINUX_DSSCOMP_H
3 
4 #ifdef __KERNEL__
5 #include <video/omapdss.h>
6 #else
7 
8 /* exporting enumerations from arch/arm/plat-omap/include/plat/display.h */
9 enum omap_plane {
10 	OMAP_DSS_GFX	= 0,
11 	OMAP_DSS_VIDEO1	= 1,
12 	OMAP_DSS_VIDEO2	= 2,
13 	OMAP_DSS_VIDEO3	= 3,
14 	OMAP_DSS_WB		= 4,
15 };
16 
17 enum omap_channel {
18 	OMAP_DSS_CHANNEL_LCD	= 0,
19 	OMAP_DSS_CHANNEL_DIGIT	= 1,
20 	OMAP_DSS_CHANNEL_LCD2	= 2,
21 };
22 
23 enum omap_color_mode {
24 	OMAP_DSS_COLOR_CLUT1		= 1 << 0,  /* BITMAP 1 */
25 	OMAP_DSS_COLOR_CLUT2		= 1 << 1,  /* BITMAP 2 */
26 	OMAP_DSS_COLOR_CLUT4		= 1 << 2,  /* BITMAP 4 */
27 	OMAP_DSS_COLOR_CLUT8		= 1 << 3,  /* BITMAP 8 */
28 
29 	/* also referred to as RGB 12-BPP, 16-bit container  */
30 	OMAP_DSS_COLOR_RGB12U		= 1 << 4,  /* xRGB12-4444 */
31 	OMAP_DSS_COLOR_ARGB16		= 1 << 5,  /* ARGB16-4444 */
32 	OMAP_DSS_COLOR_RGB16		= 1 << 6,  /* RGB16-565 */
33 
34 	/* also referred to as RGB 24-BPP, 32-bit container */
35 	OMAP_DSS_COLOR_RGB24U		= 1 << 7,  /* xRGB24-8888 */
36 	OMAP_DSS_COLOR_RGB24P		= 1 << 8,  /* RGB24-888 */
37 	OMAP_DSS_COLOR_YUV2		= 1 << 9,  /* YUV2 4:2:2 co-sited */
38 	OMAP_DSS_COLOR_UYVY		= 1 << 10, /* UYVY 4:2:2 co-sited */
39 	OMAP_DSS_COLOR_ARGB32		= 1 << 11, /* ARGB32-8888 */
40 	OMAP_DSS_COLOR_RGBA32		= 1 << 12, /* RGBA32-8888 */
41 
42 	/* also referred to as RGBx 32 in TRM */
43 	OMAP_DSS_COLOR_RGBX24		= 1 << 13, /* RGBx32-8888 */
44 	OMAP_DSS_COLOR_RGBX32		= 1 << 13, /* RGBx32-8888 */
45 	OMAP_DSS_COLOR_NV12		= 1 << 14, /* NV12 format: YUV 4:2:0 */
46 
47 	/* also referred to as RGBA12-4444 in TRM */
48 	OMAP_DSS_COLOR_RGBA16		= 1 << 15, /* RGBA16-4444 */
49 
50 	OMAP_DSS_COLOR_RGBX12		= 1 << 16, /* RGBx16-4444 */
51 	OMAP_DSS_COLOR_RGBX16		= 1 << 16, /* RGBx16-4444 */
52 	OMAP_DSS_COLOR_ARGB16_1555	= 1 << 17, /* ARGB16-1555 */
53 
54 	/* also referred to as xRGB16-555 in TRM */
55 	OMAP_DSS_COLOR_XRGB15		= 1 << 18, /* xRGB16-1555 */
56 	OMAP_DSS_COLOR_XRGB16_1555	= 1 << 18, /* xRGB16-1555 */
57 };
58 
59 enum omap_dss_trans_key_type {
60 	OMAP_DSS_COLOR_KEY_GFX_DST = 0,
61 	OMAP_DSS_COLOR_KEY_VID_SRC = 1,
62 };
63 
64 enum omap_dss_display_state {
65 	OMAP_DSS_DISPLAY_DISABLED = 0,
66 	OMAP_DSS_DISPLAY_ACTIVE,
67 	OMAP_DSS_DISPLAY_SUSPENDED,
68 	OMAP_DSS_DISPLAY_TRANSITION,
69 };
70 
71 struct omap_video_timings {
72 	/* Unit: pixels */
73 	__u16 x_res;
74 	/* Unit: pixels */
75 	__u16 y_res;
76 	/* Unit: KHz */
77 	__u32 pixel_clock;
78 	/* Unit: pixel clocks */
79 	__u16 hsw;	/* Horizontal synchronization pulse width */
80 	/* Unit: pixel clocks */
81 	__u16 hfp;	/* Horizontal front porch */
82 	/* Unit: pixel clocks */
83 	__u16 hbp;	/* Horizontal back porch */
84 	/* Unit: line clocks */
85 	__u16 vsw;	/* Vertical synchronization pulse width */
86 	/* Unit: line clocks */
87 	__u16 vfp;	/* Vertical front porch */
88 	/* Unit: line clocks */
89 	__u16 vbp;	/* Vertical back porch */
90 };
91 
92 /* YUV to RGB color conversion info */
93 struct omap_dss_cconv_coefs {
94 	__s16 ry, rcr, rcb;
95 	__s16 gy, gcr, gcb;
96 	__s16 by, bcr, bcb;
97 
98 	/* Y is 16..235, UV is 16..240 if not fullrange.  Otherwise 0..255 */
99 	__u16 full_range;
100 } __attribute__ ((aligned(4)));
101 
102 struct omap_dss_cpr_coefs {
103 	__s16 rr, rg, rb;
104 	__s16 gr, gg, gb;
105 	__s16 br, bg, bb;
106 };
107 
108 #endif
109 
110 /* copy of fb_videomode */
111 struct dsscomp_videomode {
112 	const char *name;	/* optional */
113 	__u32 refresh;		/* optional */
114 	__u32 xres;
115 	__u32 yres;
116 	__u32 pixclock;
117 	__u32 left_margin;
118 	__u32 right_margin;
119 	__u32 upper_margin;
120 	__u32 lower_margin;
121 	__u32 hsync_len;
122 	__u32 vsync_len;
123 	__u32 sync;
124 	__u32 vmode;
125 	__u32 flag;
126 };
127 
128 /*
129  * Stereoscopic Panel types
130  * row, column, overunder, sidebyside options
131  * are with respect to native scan order
132  */
133 enum s3d_disp_type {
134 	S3D_DISP_NONE = 0,
135 	S3D_DISP_FRAME_SEQ,
136 	S3D_DISP_ROW_IL,
137 	S3D_DISP_COL_IL,
138 	S3D_DISP_PIX_IL,
139 	S3D_DISP_CHECKB,
140 	S3D_DISP_OVERUNDER,
141 	S3D_DISP_SIDEBYSIDE,
142 };
143 
144 /* Subsampling direction is based on native panel scan order.*/
145 enum s3d_disp_sub_sampling {
146 	S3D_DISP_SUB_SAMPLE_NONE = 0,
147 	S3D_DISP_SUB_SAMPLE_V,
148 	S3D_DISP_SUB_SAMPLE_H,
149 };
150 
151 /*
152  * Indicates if display expects left view first followed by right or viceversa
153  * For row interlaved displays, defines first row view
154  * For column interleaved displays, defines first column view
155  * For checkerboard, defines first pixel view
156  * For overunder, defines top view
157  * For sidebyside, defines west view
158  */
159 enum s3d_disp_order {
160 	S3D_DISP_ORDER_L = 0,
161 	S3D_DISP_ORDER_R = 1,
162 };
163 
164 /*
165  * Indicates current view
166  * Used mainly for displays that need to trigger a sync signal
167  */
168 enum s3d_disp_view {
169 	S3D_DISP_VIEW_L = 0,
170 	S3D_DISP_VIEW_R,
171 };
172 
173 struct s3d_disp_info {
174 	enum s3d_disp_type type;
175 	enum s3d_disp_sub_sampling sub_samp;
176 	enum s3d_disp_order order;
177 	/*
178 	 * Gap between left and right views
179 	 * For over/under units are lines
180 	 * For sidebyside units are pixels
181 	 * For other types ignored
182 	 */
183 	unsigned int gap;
184 };
185 
186 enum omap_dss_ilace_mode {
187 	OMAP_DSS_ILACE		= (1 << 0),	/* interlaced vs. progressive */
188 	OMAP_DSS_ILACE_SEQ	= (1 << 1),	/* sequential vs interleaved */
189 	OMAP_DSS_ILACE_SWAP	= (1 << 2),	/* swap fields, e.g. TB=>BT */
190 
191 	OMAP_DSS_ILACE_NONE	= 0,
192 	OMAP_DSS_ILACE_IL_TB	= OMAP_DSS_ILACE,
193 	OMAP_DSS_ILACE_IL_BT	= OMAP_DSS_ILACE | OMAP_DSS_ILACE_SWAP,
194 	OMAP_DSS_ILACE_SEQ_TB	= OMAP_DSS_ILACE_IL_TB | OMAP_DSS_ILACE_SEQ,
195 	OMAP_DSS_ILACE_SEQ_BT	= OMAP_DSS_ILACE_IL_BT | OMAP_DSS_ILACE_SEQ,
196 };
197 
198 /* YUV VC1 range mapping info */
199 struct dss2_vc1_range_map_info {
200 	__u8 enable;	/* bool */
201 
202 	__u8 range_y;	/* 0..7 */
203 	__u8 range_uv;	/* 0..7 */
204 } __attribute__ ((aligned(4)));
205 
206 /* standard rectangle */
207 struct dss2_rect_t {
208 	__s32 x;	/* left */
209 	__s32 y;	/* top */
210 	__u32 w;	/* width */
211 	__u32 h;	/* height */
212 } __attribute__ ((aligned(4)));
213 
214 /* decimation constraints */
215 struct dss2_decim {
216 	__u8 min_x;
217 	__u8 max_x;	/* 0 is same as 255 */
218 	__u8 min_y;
219 	__u8 max_y;	/* 0 is same as 255 */
220 } __attribute__ ((aligned(4)));
221 
222 /*
223  * A somewhat more user friendly interface to the DSS2.  This is a
224  * direct interface to the DSS2 overlay and overlay_manager modules.
225  * User-space APIs are provided for HW-specific control of DSS in
226  * contrast with V4L2/FB that are more generic, but in this process
227  * omit HW-specific features.
228  *
229  * For now managers are specified by display index as opposed to manager
230  * type, so that display0 is always the default display (e.g. HDMI on
231  * panda, and LCD blaze.)  For now you would need to query the displays
232  * or use sysfs to find a specific display.
233  *
234  * Userspace operations are as follows:
235  *
236  * 1) check if DSS supports an overlay configuration, use DSSCOMP_CHECK_OVL
237  * ioctl with the manager, overlay, and setup-mode information filled out.
238  * All fields should be filled out as it may influence whether DSS can
239  * display/render the overlay.
240  *
241  * If proper address information is not available, it may be possible to
242  * use a type-of-address enumeration instead for luma/rgb and chroma (if
243  * applicable) frames.
244  *
245  * Do this for each overlay before attempting to configure DSS.
246  *
247  * 2) configure DSS pipelines for display/manager using DSSCOMP_SETUP_MANAGER
248  * ioctl.  You can delay applying the settings until an dss2_manager_apply()
249  * is called for the internal composition object, if the APPLY bit of setup mode
250  * is not set.  However the CAPTURE/DISPLAY bits of the setup mode settings will
251  * determine if at this time a capture will take place (in case of capture
252  * only mode).  You may also set up additional pipelines with
253  * dss2_overlay_setup() before this.
254  *
255  * 3) On OMAP4/5 you can use the DSS WB pipeline to copy (and convert) a buffer
256  * using DSS.  Use the DSSCOMP_WB_COPY ioctl for this.  This is a blocking
257  * call, and it may possibly fail if an ongoing WB capture mode has been
258  * scheduled (which is outside of the current scope of the DSS2 interface.)
259  *
260  * There is also a one-shot configuration API (DSSCOMP_SETUP_DISPC).  This
261  * allows you to set-up all overlays on all managers in one call.  This call
262  * performs additional functionality:
263  *
264  * - it maps userspace 1D buffers into TILER 1D for the duration of the display
265  * - it disables all overlays that were specified before, but are no longer
266  *   specified
267  *
268  */
269 
270 /*
271  * DSS2 overlay information.  This structure contains all information
272  * needed to set up the overlay for a particular buffer to be displayed
273  * at a particular orientation.
274  *
275  * The following information is deemed to be set globally, so it is not
276  * included:
277  *   - whether to enable zorder (always enabled)
278  *   - whether to replicate/truncate color fields (it is decided per the
279  *     whole manager/overlay settings, and is enabled unless overlay is
280  *     directed to WB.)
281  *
282  * There is also no support for CLUT formats
283  *
284  * Requirements:
285  *
286  * 1) 0 <= crop.x <= crop.x + crop.w <= width
287  * 2) 0 <= crop.y <= crop.y + crop.h <= height
288  * 3) win.x <= win.x + win.w and win.w >= 0
289  * 4) win.y <= win.y + win.h and win.h >= 0
290  *
291  * 5) color_mode is supported by overlay
292  * 6) requested scaling is supported by overlay and functional clocks
293  *
294  * Notes:
295  *
296  * 1) Any portions of X:[pos_x, pos_x + out_width] and
297  *    Y:[pos_y, pos_y + out_height] outside of the screen
298  *    X:[0, screen.width], Y:[0, screen.height] will be cropped
299  *    automatically without changing the scaling ratio.
300  *
301  * 2) Crop region will be adjusted to the pixel granularity:
302  *    (2-by-1) for YUV422, (2-by-2) for YUV420.  This will
303  *    not modify the output region.  Crop region is for the
304  *    original (unrotated) buffer, so it does not change with
305  *    rotation.
306  *
307  * 3) Rotation will not modify the output region, specifically
308  *    its height and width.  Also the coordinate system of the
309  *    display is always (0,0) = top left.
310  *
311  * 4) cconv and vc1 only needs to be filled for YUV color modes.
312  *
313  * 5) vc1.range_y and vc1.range_uv only needs to be filled if
314  *    vc1.enable is true.
315  */
316 struct dss2_ovl_cfg {
317 	__u16 width;	/* buffer width */
318 	__u16 height;	/* buffer height */
319 	__u32 stride;	/* buffer stride */
320 
321 	enum omap_color_mode color_mode;
322 	__u8 pre_mult_alpha;	/* bool */
323 	__u8 global_alpha;	/* 0..255 */
324 	__u8 rotation;		/* 0..3 (*90 degrees clockwise) */
325 	__u8 mirror;	/* left-to-right: mirroring is applied after rotation */
326 
327 	enum omap_dss_ilace_mode ilace;	/* interlace mode */
328 
329 	struct dss2_rect_t win;		/* output window - on display */
330 	struct dss2_rect_t crop;	/* crop window - in source buffer */
331 
332 	struct dss2_decim decim;	/* predecimation limits */
333 
334 	struct omap_dss_cconv_coefs cconv;
335 	struct dss2_vc1_range_map_info vc1;
336 
337 	__u8 ix;		/* ovl index same as sysfs/overlay# */
338 	__u8 zorder;	/* 0..3 */
339 	__u8 enabled;	/* bool */
340 	__u8 zonly;	/* only set zorder and enabled bit */
341 	__u8 mgr_ix;	/* mgr index */
342 } __attribute__ ((aligned(4)));
343 
344 enum omapdss_buffer_type {
345 	OMAP_DSS_BUFTYPE_SDMA,
346 	OMAP_DSS_BUFTYPE_TILER_8BIT,
347 	OMAP_DSS_BUFTYPE_TILER_16BIT,
348 	OMAP_DSS_BUFTYPE_TILER_32BIT,
349 	OMAP_DSS_BUFTYPE_TILER_PAGE,
350 };
351 
352 struct dss2_ovl_info {
353 	struct dss2_ovl_cfg cfg;
354 
355 	union {
356 		/* user-space interfaces */
357 		struct {
358 			void *address;	/* main buffer address */
359 
360 			/*
361 			 * For DSSCOMP_CHECK_OVL we allow specifying just the
362 			 * type of each buffer. This is used if we need to
363 			 * check whether DSS will be able to display a buffer
364 			 * if using a particular memory type before spending
365 			 * time to map/copy the buffer into that type of
366 			 * memory.  Default value of 0 uses the address to
367 			 * determine the type.
368 			 */
369 			__u16 ba_type;
370 			__u16 uv_type;
371 		};
372 
373 		/* kernel-space interfaces */
374 		struct {
375 			__u32 ba;	/* base address */
376 			__u32 uv;	/* uv address */
377 		};
378 	};
379 };
380 
381 /*
382  * DSS2 manager information.
383  *
384  * The following information is deemed to be set globally, so it is not
385  * included:
386  *   gamma correction
387  *   whether to enable zorder (always enabled)
388  *   whether to replicate/truncate color fields (it is decided per the
389  *   whole manager/overlay settings, and is enabled unless overlay is
390  *   directed to WB.)
391  * Notes:
392  *
393  * 1) trans_key_type and trans_enabled only need to be filled if
394  *    trans_enabled is true, and alpha_blending is false.
395  */
396 struct dss2_mgr_info {
397 	__u32 ix;		/* display index same as sysfs/display# */
398 
399 	__u32 default_color;
400 
401 	enum omap_dss_trans_key_type trans_key_type;
402 	__u32 trans_key;
403 	struct omap_dss_cpr_coefs cpr_coefs;
404 
405 	__u8 trans_enabled;	/* bool */
406 
407 	__u8 interlaced;	/* bool */
408 	__u8 alpha_blending;	/* bool - overrides trans_enabled */
409 	__u8 cpr_enabled;	/* bool */
410 	__u8 swap_rb;		/* bool - swap red and blue */
411 } __attribute__ ((aligned(4)));
412 
413 /*
414  * ioctl: DSSCOMP_SETUP_MGR, struct dsscomp_setup_mgr_data
415  *
416  * 1. sets manager of each ovl in composition to the display
417  * 2. calls set_dss_ovl_info() for each ovl to set up the
418  *    overlay staging structures (this is a wrapper around ovl->set_info())
419  * 3. calls set_dss_mgr_info() for mgr to set up the manager
420  *    staging structures (this is a wrapper around mgr->set_info())
421  * 4. if update is true:
422  *      calls manager->apply()
423  *      calls driver->update() in a non-blocking fashion
424  *      this will program the DSS synchronously
425  *
426  * Notes:
427  *
428  * 1) x, y, w, h only needs to be set if update is true.
429  *
430  * All non-specified pipelines that currently are on the same display
431  * will remain the same as on the previous frame.  You may want to
432  * disable unused pipelines to avoid surprises.
433  *
434  * If get_sync_obj is false, it returns 0 on success, <0 error value
435  * on failure.
436  *
437  * If get_sync_obj is true, it returns fd on success, or a negative value
438  * on failure.  You can use the fd to wait on (using DSSCOMP_WAIT ioctl()).
439  *
440  * Note: frames do not get eclipsed when the display turns off.  Queue a
441  * blank frame to eclipse old frames.  Blank frames get eclipsed when
442  * programmed into DSS.
443  *
444  * (A blank frame is queued to the display automatically in Android before
445  * the display is turned off.)
446  *
447  * All overlays to be used on the frame must be listed.  There is no way
448  * to add another overlay to a defined frame.
449  */
450 enum dsscomp_setup_mode {
451 	DSSCOMP_SETUP_MODE_APPLY = (1 << 0),	/* applies changes to cache */
452 	DSSCOMP_SETUP_MODE_DISPLAY = (1 << 1),	/* calls display update */
453 	DSSCOMP_SETUP_MODE_CAPTURE = (1 << 2),	/* capture to WB */
454 
455 	/* just apply changes for next vsync/update */
456 	DSSCOMP_SETUP_APPLY = DSSCOMP_SETUP_MODE_APPLY,
457 	/* trigger an update (wait for vsync) */
458 	DSSCOMP_SETUP_DISPLAY =
459 			DSSCOMP_SETUP_MODE_APPLY | DSSCOMP_SETUP_MODE_DISPLAY,
460 	/* capture to WB - WB must be configured */
461 	DSSCOMP_SETUP_CAPTURE =
462 			DSSCOMP_SETUP_MODE_APPLY | DSSCOMP_SETUP_MODE_CAPTURE,
463 	/* display and capture to WB - WB must be configured */
464 	DSSCOMP_SETUP_DISPLAY_CAPTURE =
465 			DSSCOMP_SETUP_DISPLAY | DSSCOMP_SETUP_CAPTURE,
466 };
467 
468 struct dsscomp_setup_mgr_data {
469 	__u32 sync_id;		/* synchronization ID - for debugging */
470 
471 	struct dss2_rect_t win; /* update region, set w/h to 0 for fullscreen */
472 	enum dsscomp_setup_mode mode;
473 	__u16 num_ovls;		/* # of overlays used in the composition */
474 	__u16 get_sync_obj;	/* ioctl should return a sync object */
475 
476 	struct dss2_mgr_info mgr;
477 	struct dss2_ovl_info ovls[0]; /* up to 5 overlays to set up */
478 };
479 
480 /*
481  * ioctl: DSSCOMP_CHECK_OVL, struct dsscomp_check_ovl_data
482  *
483  * DISPLAY and/or CAPTURE bits must be filled for the mode field
484  * correctly to be able to decide correctly if DSS can properly
485  * render the overlay.
486  *
487  * ovl.ix is ignored.
488  *
489  * Returns a positive bitmask regarding which overlay of DSS can
490  * render the overlay as it is configured for the display/display's
491  * manager.  NOTE: that overlays that are assigned to other displays
492  * may be returned.  If there is an invalid configuration (negative
493  * sizes, etc.), a negative error value is returned.
494  *
495  * ovl->decim's min values will be modified to the smallest decimation that
496  * DSS can use to support the overlay configuration.
497  *
498  * Assumptions:
499  * - zorder will be distinct from other pipelines on that manager
500  * - overlay will be enabled and routed to the display specified
501  */
502 struct dsscomp_check_ovl_data {
503 	enum dsscomp_setup_mode mode;
504 	struct dss2_mgr_info mgr;
505 	struct dss2_ovl_info ovl;
506 };
507 
508 /*
509  * This structure is used to set up the entire DISPC (all managers),
510  * and is analogous to dsscomp_setup_mgr_data.
511  *
512  * Additional features:
513  * - all overlays that were specified in a prior use of this
514  * structure, and are no longer specified, will be disabled.
515  * - 1D buffers under 4M will be mapped into TILER1D.
516  *
517  * Limitations:
518  * - only DISPLAY mode is supported (DISPLAY and APPLY bits will
519  *   automatically be set)
520  * - getting a sync object is not supported.
521  */
522 struct dsscomp_setup_dispc_data {
523 	__u32 sync_id;		/* synchronization ID - for debugging */
524 
525 	enum dsscomp_setup_mode mode;
526 	__u16 num_ovls;		/* # of overlays used in the composition */
527 	__u16 num_mgrs;		/* # of managers used in the composition */
528 	__u16 get_sync_obj;	/* ioctl should return a sync object */
529 
530 	struct dss2_mgr_info mgrs[3];
531 	struct dss2_ovl_info ovls[5]; /* up to 5 overlays to set up */
532 };
533 
534 /*
535  * ioctl: DSSCOMP_WB_COPY, struct dsscomp_wb_copy_data
536  *
537  * Requirements:
538  *	wb.ix must be OMAP_DSS_WB.
539  *
540  * Returns 0 on success (copy is completed), non-0 on failure.
541  */
542 struct dsscomp_wb_copy_data {
543 	struct dss2_ovl_info ovl, wb;
544 };
545 
546 /*
547  * ioctl: DSSCOMP_QUERY_DISPLAY, struct dsscomp_display_info
548  *
549  * Gets informations about the display.  Fill in ix and modedb_len before
550  * calling ioctl, and rest of the fields are filled in by ioctl.  Up to
551  * modedb_len timings are retrieved in the order of display preference.
552  *
553  * Returns: 0 on success, non-0 error value on failure.
554  */
555 struct dsscomp_display_info {
556 	__u32 ix;			/* display index (sysfs/display#) */
557 	__u32 overlays_available;	/* bitmask of available overlays */
558 	__u32 overlays_owned;		/* bitmask of owned overlays */
559 	enum omap_channel channel;
560 	enum omap_dss_display_state state;
561 	__u8 enabled;			/* bool: resume-state if suspended */
562 	struct omap_video_timings timings;
563 	struct s3d_disp_info s3d_info;	/* any S3D specific information */
564 	struct dss2_mgr_info mgr;	/* manager information */
565 	__u16 width_in_mm;		/* screen dimensions */
566 	__u16 height_in_mm;
567 
568 	__u32 modedb_len;		/* number of video timings */
569 	struct dsscomp_videomode modedb[];	/* display supported timings */
570 };
571 
572 /*
573  * ioctl: DSSCOMP_SETUP_DISPLAY, struct dsscomp_setup_display_data
574  *
575  * Gets informations about the display.  Fill in ix before calling
576  * ioctl, and rest of the fields are filled in by ioctl.
577  *
578  * Returns: 0 on success, non-0 error value on failure.
579  */
580 struct dsscomp_setup_display_data {
581 	__u32 ix;			/* display index (sysfs/display#) */
582 	struct dsscomp_videomode mode;	/* video timings */
583 };
584 
585 /*
586  * ioctl: DSSCOMP_WAIT, struct dsscomp_wait_data
587  *
588  * Use this ioctl to wait for one of the following events:
589  *
590  * A) the moment a composition is programmed into DSS
591  * B) the moment a composition is first displayed (or captured)
592  * C) the moment when a composition is no longer queued or displayed on a
593  * display (it is released).  (A composition is assumed to be superceded
594  * when another composition has been programmed into DSS, even if that
595  * subsequent composition does not update/specify all overlays used by
596  * the prior composition; moreover, even if it uses the same buffers.)
597  *
598  * Set timeout to desired timeout value in microseconds.
599  *
600  * This ioctl must be used on the sync object returned by the
601  * DSSCOMP_SETUP_MGR or DSSCOMP_SETUP_DISPC ioctls.
602  *
603  * Returns: >=0 on success, <0 error value on failure (e.g. -ETIME).
604  */
605 enum dsscomp_wait_phase {
606 	DSSCOMP_WAIT_PROGRAMMED = 1,
607 	DSSCOMP_WAIT_DISPLAYED,
608 	DSSCOMP_WAIT_RELEASED,
609 };
610 
611 struct dsscomp_wait_data {
612 	__u32 timeout_us;	/* timeout in microseconds */
613 	enum dsscomp_wait_phase phase;	/* phase to wait for */
614 };
615 
616 /* IOCTLS */
617 #define DSSCOMP_SETUP_MGR	_IOW('O', 128, struct dsscomp_setup_mgr_data)
618 #define DSSCOMP_CHECK_OVL	_IOWR('O', 129, struct dsscomp_check_ovl_data)
619 #define DSSCOMP_WB_COPY		_IOW('O', 130, struct dsscomp_wb_copy_data)
620 #define DSSCOMP_QUERY_DISPLAY	_IOWR('O', 131, struct dsscomp_display_info)
621 #define DSSCOMP_WAIT		_IOW('O', 132, struct dsscomp_wait_data)
622 
623 #define DSSCOMP_SETUP_DISPC	_IOW('O', 133, struct dsscomp_setup_dispc_data)
624 #define DSSCOMP_SETUP_DISPLAY	_IOW('O', 134, struct dsscomp_setup_display_data)
625 #endif
626