hc
2024-01-05 071106ecf68c401173c58808b1cf5f68cc50d390
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
/* SPDX-License-Identifier: GPL-2.0 */
 
#ifndef __RK1608_DPHY_H__
#define __RK1608_DPHY_H__
 
#define RK1608_MAX_FMTINF    4
 
struct rk1608_chinf {
   u32 width;
   u32 height;
   u32 data_id;
   u32 decode_format;
   u32 flag;
};
 
struct rk1608_fmt_inf {
   u32 data_type;
   u32 mipi_lane;
   u32 mipi_lane_out;
   u32 hactive;
   u32 vactive;
   u32 htotal;
   u32 vtotal;
   struct v4l2_mbus_framefmt mf;
   struct rk1608_chinf in_ch[4];
   struct rk1608_chinf out_ch[4];
   u32 hcrop;
   u32 vcrop;
};
 
struct rk1608_sub_sensor_cfg {
   u32 id;
   u32 in_mipi;
   u32 out_mipi;
   u32 reserved;
};
 
struct rk1608_dphy {
   struct v4l2_subdev sd;
   struct v4l2_subdev *rk1608_sd;
   struct platform_device *pdev;
   struct device *dev;
   struct media_pad pad;
   struct v4l2_ctrl *link_freq;
   struct v4l2_ctrl *pixel_rate;
   struct v4l2_ctrl *hblank;
   struct v4l2_ctrl *vblank;
   struct v4l2_ctrl *exposure;
   struct v4l2_ctrl *gain;
   struct v4l2_ctrl *h_flip;
   struct v4l2_ctrl *v_flip;
   struct v4l2_ctrl_handler ctrl_handler;
 
   u32 cam_nums;
   u32 in_mipi;
   u32 out_mipi;
   s64 link_freqs;
 
   u32 i2c_bus;
   u32 i2c_addr;
   const char *sensor_name;
 
   u32 module_index;
   const char *module_facing;
   const char *module_name;
   const char *len_name;
 
   u32 fmt_inf_num;
   u32 fmt_inf_idx;
   struct rk1608_fmt_inf fmt_inf[RK1608_MAX_FMTINF];
 
   bool first_stream;
 
   /* for virtual sub sensor */
   u32 sub_sensor_num;
   struct rk1608_sub_sensor_cfg sub_sensor[4];
   struct i2c_client *link_sensor_client;
};
 
#endif