aboutsummaryrefslogtreecommitdiff
path: root/kernel-headers/camera_pipe_mgr_D2.h
blob: 67adb9d215df2520c0691a7df145032a074f2683 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
/*
* Copyright (C) 2011-2014 MediaTek Inc.
* 
* This program is free software: you can redistribute it and/or modify it under the terms of the 
* GNU General Public License version 2 as published by the Free Software Foundation.
* 
* This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; 
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along with this program.
* If not, see <http://www.gnu.org/licenses/>.
*/

//-----------------------------------------------------------------------------
#ifndef CAMERA_PIPE_MGR_H
#define CAMERA_PIPE_MGR_H
//-----------------------------------------------------------------------------
#define CAM_PIPE_MGR_DEV_NAME       "camera-pipemgr"
#define CAM_PIPE_MGR_MAGIC_NO       'p'
//-----------------------------------------------------------------------------
#define CAM_PIPE_MGR_PIPE_MASK_CAM_IO       ((unsigned long)1 << 0)
#define CAM_PIPE_MGR_PIPE_MASK_POST_PROC    ((unsigned long)1 << 1)
#define CAM_PIPE_MGR_PIPE_MASK_XDP_CAM      ((unsigned long)1 << 2)
//-----------------------------------------------------------------------------
typedef enum
{
    CAM_PIPE_MGR_SCEN_SW_NONE,
    CAM_PIPE_MGR_SCEN_SW_CAM_IDLE,
    CAM_PIPE_MGR_SCEN_SW_CAM_PRV,
    CAM_PIPE_MGR_SCEN_SW_CAM_CAP,
    CAM_PIPE_MGR_SCEN_SW_VIDEO_PRV,
    CAM_PIPE_MGR_SCEN_SW_VIDEO_REC,
    CAM_PIPE_MGR_SCEN_SW_VIDEO_VSS,
    CAM_PIPE_MGR_SCEN_SW_ZSD,
    CAM_PIPE_MGR_SCEN_SW_N3D,
}CAM_PIPE_MGR_SCEN_SW_ENUM;
//
typedef enum
{
    CAM_PIPE_MGR_SCEN_HW_NONE,
    CAM_PIPE_MGR_SCEN_HW_IC,
    CAM_PIPE_MGR_SCEN_HW_VR,
    CAM_PIPE_MGR_SCEN_HW_ZSD,
    CAM_PIPE_MGR_SCEN_HW_IP,
    CAM_PIPE_MGR_SCEN_HW_N3D,
    CAM_PIPE_MGR_SCEN_HW_VSS
}CAM_PIPE_MGR_SCEN_HW_ENUM;
//
typedef enum
{
    CAM_PIPE_MGR_DEV_CAM,
    CAM_PIPE_MGR_DEV_ATV,
    CAM_PIPE_MGR_DEV_VT
}CAM_PIPE_MGR_DEV_ENUM;
//
typedef struct
{
    unsigned int    PipeMask;
    unsigned int    Timeout;
}CAM_PIPE_MGR_LOCK_STRUCT;
//
typedef struct
{
    unsigned int    PipeMask;
}CAM_PIPE_MGR_UNLOCK_STRUCT;
//
typedef struct
{
    CAM_PIPE_MGR_SCEN_SW_ENUM   ScenSw;
    CAM_PIPE_MGR_SCEN_HW_ENUM   ScenHw;
    CAM_PIPE_MGR_DEV_ENUM       Dev;
}CAM_PIPE_MGR_MODE_STRUCT;
//
typedef struct
{
    unsigned int    PipeMask;
}CAM_PIPE_MGR_ENABLE_STRUCT;
//
typedef struct
{
    unsigned int    PipeMask;
}CAM_PIPE_MGR_DISABLE_STRUCT;
//-----------------------------------------------------------------------------
typedef enum
{
    CAM_PIPE_MGR_CMD_VECNPLL_CTRL_SET_HIGH,
    CAM_PIPE_MGR_CMD_VECNPLL_CTRL_SET_LOW
}CAM_PIPE_MGR_CMD_VECNPLL_CTRL_ENUM;
//-----------------------------------------------------------------------------
typedef enum
{
    CAM_PIPE_MGR_CMD_LOCK,
    CAM_PIPE_MGR_CMD_UNLOCK,
    CAM_PIPE_MGR_CMD_DUMP,
    CAM_PIPE_MGR_CMD_SET_MODE,
    CAM_PIPE_MGR_CMD_GET_MODE,
    CAM_PIPE_MGR_CMD_ENABLE_PIPE,
    CAM_PIPE_MGR_CMD_DISABLE_PIPE,
    CAM_PIPE_MGR_CMD_VENC_PLL_CTRL
}CAM_PIPE_MGR_CMD_ENUM;
//-----------------------------------------------------------------------------
#define CAM_PIPE_MGR_LOCK           _IOW(   CAM_PIPE_MGR_MAGIC_NO,  CAM_PIPE_MGR_CMD_LOCK,          CAM_PIPE_MGR_LOCK_STRUCT)
#define CAM_PIPE_MGR_UNLOCK         _IOW(   CAM_PIPE_MGR_MAGIC_NO,  CAM_PIPE_MGR_CMD_UNLOCK,        CAM_PIPE_MGR_UNLOCK_STRUCT)
#define CAM_PIPE_MGR_DUMP           _IO(    CAM_PIPE_MGR_MAGIC_NO,  CAM_PIPE_MGR_CMD_DUMP)
#define CAM_PIPE_MGR_SET_MODE       _IOW(   CAM_PIPE_MGR_MAGIC_NO,  CAM_PIPE_MGR_CMD_SET_MODE,      CAM_PIPE_MGR_MODE_STRUCT)
#define CAM_PIPE_MGR_GET_MODE       _IOW(   CAM_PIPE_MGR_MAGIC_NO,  CAM_PIPE_MGR_CMD_GET_MODE,      CAM_PIPE_MGR_MODE_STRUCT)
#define CAM_PIPE_MGR_ENABLE_PIPE    _IOW(   CAM_PIPE_MGR_MAGIC_NO,  CAM_PIPE_MGR_CMD_ENABLE_PIPE,   CAM_PIPE_MGR_ENABLE_STRUCT)
#define CAM_PIPE_MGR_DISABLE_PIPE   _IOW(   CAM_PIPE_MGR_MAGIC_NO,  CAM_PIPE_MGR_CMD_DISABLE_PIPE,  CAM_PIPE_MGR_DISABLE_STRUCT)
#define CAM_PIPE_MGR_VENCPLL_CTRL   _IOW(   CAM_PIPE_MGR_MAGIC_NO,  CAM_PIPE_MGR_CMD_VENC_PLL_CTRL,  CAM_PIPE_MGR_CMD_VECNPLL_CTRL_ENUM)
//-----------------------------------------------------------------------------
#endif
//-----------------------------------------------------------------------------