WAR: gr3d: limit 3d clock when camera is on
[linux-2.6.git] / include / media / tegra_camera.h
1 /*
2  * include/linux/tegra_camera.h
3  *
4  * Copyright (C) 2010 Google, Inc.
5  * Copyright (c) 2010-2012, NVIDIA Corporation.  All rights reserved.
6  *
7  * This software is licensed under the terms of the GNU General Public
8  * License version 2, as published by the Free Software Foundation, and
9  * may be copied, distributed, and modified under those terms.
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  */
17 #ifndef TEGRA_CAMERA_H
18 #define TEGRA_CAMERA_H
19
20 /* this is to enable VI pattern generator (Null Sensor) */
21 #define TEGRA_CAMERA_ENABLE_PD2VI_CLK 0x1
22
23 enum {
24         TEGRA_CAMERA_MODULE_ISP = 0,
25         TEGRA_CAMERA_MODULE_VI,
26         TEGRA_CAMERA_MODULE_CSI,
27         TEGRA_CAMERA_MODULE_EMC,
28         TEGRA_CAMERA_MODULE_MAX
29 };
30
31 enum {
32         TEGRA_CAMERA_VI_CLK,
33         TEGRA_CAMERA_VI_SENSOR_CLK,
34         TEGRA_CAMERA_EMC_CLK
35 };
36
37 struct tegra_camera_clk_info {
38         uint id;
39         uint clk_id;
40         unsigned long rate;
41         uint flag;      /* to inform if any special bits need to enabled/disabled */
42 };
43
44 enum StereoCameraMode {
45         Main = 0x0,             /* Sets the default camera to Main */
46         StereoCameraMode_Left = 0x01,   /* the left camera is on. */
47         StereoCameraMode_Right = 0x02,  /* the right camera is on. */
48         StereoCameraMode_Stereo = 0x03, /* both cameras are on. */
49         StereoCameraMode_Force32 = 0x7FFFFFFF
50 };
51
52 struct tegra_camera_platform_data {
53         bool limit_3d_emc_clk;
54 };
55
56 #if  defined(CONFIG_TEGRA_CAMERA)
57 int is_tegra_camera_on(void);
58 #else
59 int is_tegra_camera_on(void) { return 0; }
60 #endif
61
62 #define TEGRA_CAMERA_IOCTL_ENABLE               _IOWR('i', 1, uint)
63 #define TEGRA_CAMERA_IOCTL_DISABLE              _IOWR('i', 2, uint)
64 #define TEGRA_CAMERA_IOCTL_CLK_SET_RATE         \
65         _IOWR('i', 3, struct tegra_camera_clk_info)
66 #define TEGRA_CAMERA_IOCTL_RESET                _IOWR('i', 4, uint)
67
68 #endif