video: tegra: Add an ioctl() implementation.
[linux-2.6.git] / include / video / tegra_dc_ext.h
1 /*
2  * Copyright (C) 2011, NVIDIA Corporation
3  *
4  * Author: Robert Morell <rmorell@nvidia.com>
5  * Some code based on fbdev extensions written by:
6  *      Erik Gilling <konkers@android.com>
7  *
8  * This program is free software; you can redistribute it and/or modify
9  * it under the terms of the GNU General Public License as published by
10  * the Free Software Foundation; either version 2 of the License, or
11  * (at your option) any later version.
12  *
13  * This program is distributed in the hope that it will be useful, but WITHOUT
14  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
15  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
16  * more details.
17  */
18
19 #ifndef __TEGRA_DC_EXT_H
20 #define __TEGRA_DC_EXT_H
21
22 #include <linux/types.h>
23 #include <linux/ioctl.h>
24
25 #define TEGRA_DC_EXT_FMT_P1             0
26 #define TEGRA_DC_EXT_FMT_P2             1
27 #define TEGRA_DC_EXT_FMT_P4             2
28 #define TEGRA_DC_EXT_FMT_P8             3
29 #define TEGRA_DC_EXT_FMT_B4G4R4A4       4
30 #define TEGRA_DC_EXT_FMT_B5G5R5A        5
31 #define TEGRA_DC_EXT_FMT_B5G6R5         6
32 #define TEGRA_DC_EXT_FMT_AB5G5R5        7
33 #define TEGRA_DC_EXT_FMT_B8G8R8A8       12
34 #define TEGRA_DC_EXT_FMT_R8G8B8A8       13
35 #define TEGRA_DC_EXT_FMT_B6x2G6x2R6x2A8 14
36 #define TEGRA_DC_EXT_FMT_R6x2G6x2B6x2A8 15
37 #define TEGRA_DC_EXT_FMT_YCbCr422       16
38 #define TEGRA_DC_EXT_FMT_YUV422         17
39 #define TEGRA_DC_EXT_FMT_YCbCr420P      18
40 #define TEGRA_DC_EXT_FMT_YUV420P        19
41 #define TEGRA_DC_EXT_FMT_YCbCr422P      20
42 #define TEGRA_DC_EXT_FMT_YUV422P        21
43 #define TEGRA_DC_EXT_FMT_YCbCr422R      22
44 #define TEGRA_DC_EXT_FMT_YUV422R        23
45 #define TEGRA_DC_EXT_FMT_YCbCr422RA     24
46 #define TEGRA_DC_EXT_FMT_YUV422RA       25
47
48 #define TEGRA_DC_EXT_BLEND_NONE         0
49 #define TEGRA_DC_EXT_BLEND_PREMULT      1
50 #define TEGRA_DC_EXT_BLEND_COVERAGE     2
51
52 struct tegra_dc_ext_flip_windowattr {
53         __s32   index;
54         __u32   buff_id;
55         __u32   blend;
56         __u32   offset;
57         __u32   offset_u;
58         __u32   offset_v;
59         __u32   stride;
60         __u32   stride_uv;
61         __u32   pixformat;
62         __u32   x;
63         __u32   y;
64         __u32   w;
65         __u32   h;
66         __u32   out_x;
67         __u32   out_y;
68         __u32   out_w;
69         __u32   out_h;
70         __u32   z;
71         __u32   pre_syncpt_id;
72         __u32   pre_syncpt_val;
73 };
74
75 #define TEGRA_DC_EXT_FLIP_N_WINDOWS     3
76
77 struct tegra_dc_ext_flip {
78         struct tegra_dc_ext_flip_windowattr win[TEGRA_DC_EXT_FLIP_N_WINDOWS];
79 };
80
81 #define TEGRA_DC_EXT_SET_NVMAP_FD \
82         _IOW('D', 0x00, __s32)
83
84 #define TEGRA_DC_EXT_GET_WINDOW \
85         _IOW('D', 0x01, __u32)
86 #define TEGRA_DC_EXT_PUT_WINDOW \
87         _IOW('D', 0x02, __u32)
88
89 #define TEGRA_DC_EXT_FLIP \
90         _IOWR('D', 0x03, struct tegra_dc_ext_flip)
91
92
93 #endif /* __TEGRA_DC_EXT_H */