Commit | Line | Data |
---|---|---|
d3953223 | 1 | /* |
0c9204d3 | 2 | * Copyright (C) 2011 - 2012 Samsung Electronics Co., Ltd. |
d3953223 SN |
3 | * |
4 | * This program is free software; you can redistribute it and/or modify | |
5 | * it under the terms of the GNU General Public License version 2 as | |
6 | * published by the Free Software Foundation. | |
7 | */ | |
8 | ||
9 | #ifndef FIMC_MDEVICE_H_ | |
10 | #define FIMC_MDEVICE_H_ | |
11 | ||
12 | #include <linux/clk.h> | |
13 | #include <linux/platform_device.h> | |
14 | #include <linux/mutex.h> | |
4163851f | 15 | #include <linux/pinctrl/consumer.h> |
d3953223 SN |
16 | #include <media/media-device.h> |
17 | #include <media/media-entity.h> | |
18 | #include <media/v4l2-device.h> | |
19 | #include <media/v4l2-subdev.h> | |
20 | ||
21 | #include "fimc-core.h" | |
4af81310 | 22 | #include "fimc-lite.h" |
d3953223 SN |
23 | #include "mipi-csis.h" |
24 | ||
e2985a26 SN |
25 | #define FIMC_OF_NODE_NAME "fimc" |
26 | #define FIMC_LITE_OF_NODE_NAME "fimc-lite" | |
27 | #define FIMC_IS_OF_NODE_NAME "fimc-is" | |
28 | #define CSIS_OF_NODE_NAME "csis" | |
29 | ||
4163851f SN |
30 | #define PINCTRL_STATE_IDLE "idle" |
31 | ||
4af81310 | 32 | /* Group IDs of sensor, MIPI-CSIS, FIMC-LITE and the writeback subdevs. */ |
588c87be SN |
33 | #define GRP_ID_SENSOR (1 << 8) |
34 | #define GRP_ID_FIMC_IS_SENSOR (1 << 9) | |
35 | #define GRP_ID_WRITEBACK (1 << 10) | |
36 | #define GRP_ID_CSIS (1 << 11) | |
37 | #define GRP_ID_FIMC (1 << 12) | |
38 | #define GRP_ID_FLITE (1 << 13) | |
39 | #define GRP_ID_FIMC_IS (1 << 14) | |
d3953223 SN |
40 | |
41 | #define FIMC_MAX_SENSORS 8 | |
42 | #define FIMC_MAX_CAMCLKS 2 | |
43 | ||
056f4f30 SN |
44 | /* LCD/ISP Writeback clocks (PIXELASYNCMx) */ |
45 | enum { | |
46 | CLK_IDX_WB_A, | |
47 | CLK_IDX_WB_B, | |
48 | FIMC_MAX_WBCLKS | |
49 | }; | |
50 | ||
d3953223 SN |
51 | struct fimc_csis_info { |
52 | struct v4l2_subdev *sd; | |
53 | int id; | |
54 | }; | |
55 | ||
56 | struct fimc_camclk_info { | |
57 | struct clk *clock; | |
58 | int use_count; | |
59 | unsigned long frequency; | |
60 | }; | |
61 | ||
62 | /** | |
63 | * struct fimc_sensor_info - image data source subdev information | |
64 | * @pdata: sensor's atrributes passed as media device's platform data | |
65 | * @subdev: image sensor v4l2 subdev | |
66 | * @host: fimc device the sensor is currently linked to | |
d3953223 SN |
67 | * |
68 | * This data structure applies to image sensor and the writeback subdevs. | |
69 | */ | |
70 | struct fimc_sensor_info { | |
56bc911a | 71 | struct fimc_source_info pdata; |
d3953223 SN |
72 | struct v4l2_subdev *subdev; |
73 | struct fimc_dev *host; | |
d3953223 SN |
74 | }; |
75 | ||
76 | /** | |
77 | * struct fimc_md - fimc media device information | |
78 | * @csis: MIPI CSIS subdevs data | |
79 | * @sensor: array of registered sensor subdevs | |
80 | * @num_sensors: actual number of registered sensors | |
81 | * @camclk: external sensor clock information | |
82 | * @fimc: array of registered fimc devices | |
056f4f30 | 83 | * @use_isp: set to true when FIMC-IS subsystem is used |
3e20c345 | 84 | * @pmf: handle to the CAMCLK clock control FIMC helper device |
d3953223 SN |
85 | * @media_dev: top level media device |
86 | * @v4l2_dev: top level v4l2_device holding up the subdevs | |
87 | * @pdev: platform device this media device is hooked up into | |
4163851f SN |
88 | * @pinctrl: camera port pinctrl handle |
89 | * @state_default: pinctrl default state handle | |
90 | * @state_idle: pinctrl idle state handle | |
d3953223 SN |
91 | * @user_subdev_api: true if subdevs are not configured by the host driver |
92 | * @slock: spinlock protecting @sensor array | |
93 | */ | |
94 | struct fimc_md { | |
95 | struct fimc_csis_info csis[CSIS_MAX_ENTITIES]; | |
96 | struct fimc_sensor_info sensor[FIMC_MAX_SENSORS]; | |
97 | int num_sensors; | |
98 | struct fimc_camclk_info camclk[FIMC_MAX_CAMCLKS]; | |
056f4f30 | 99 | struct clk *wbclk[FIMC_MAX_WBCLKS]; |
4af81310 | 100 | struct fimc_lite *fimc_lite[FIMC_LITE_MAX_DEVS]; |
d3953223 | 101 | struct fimc_dev *fimc[FIMC_MAX_DEVS]; |
056f4f30 | 102 | bool use_isp; |
3e20c345 | 103 | struct device *pmf; |
d3953223 SN |
104 | struct media_device media_dev; |
105 | struct v4l2_device v4l2_dev; | |
106 | struct platform_device *pdev; | |
4163851f SN |
107 | struct fimc_pinctrl { |
108 | struct pinctrl *pinctrl; | |
109 | struct pinctrl_state *state_default; | |
110 | struct pinctrl_state *state_idle; | |
111 | } pinctl; | |
d3953223 SN |
112 | bool user_subdev_api; |
113 | spinlock_t slock; | |
114 | }; | |
115 | ||
116 | #define is_subdev_pad(pad) (pad == NULL || \ | |
117 | media_entity_type(pad->entity) == MEDIA_ENT_T_V4L2_SUBDEV) | |
118 | ||
119 | #define me_subtype(me) \ | |
120 | ((me->type) & (MEDIA_ENT_TYPE_MASK | MEDIA_ENT_SUBTYPE_MASK)) | |
121 | ||
122 | #define subdev_has_devnode(__sd) (__sd->flags & V4L2_SUBDEV_FL_HAS_DEVNODE) | |
123 | ||
124 | static inline struct fimc_md *entity_to_fimc_mdev(struct media_entity *me) | |
125 | { | |
126 | return me->parent == NULL ? NULL : | |
127 | container_of(me->parent, struct fimc_md, media_dev); | |
128 | } | |
129 | ||
130 | static inline void fimc_md_graph_lock(struct fimc_dev *fimc) | |
131 | { | |
31d34d9b | 132 | mutex_lock(&fimc->vid_cap.vfd.entity.parent->graph_mutex); |
d3953223 SN |
133 | } |
134 | ||
135 | static inline void fimc_md_graph_unlock(struct fimc_dev *fimc) | |
136 | { | |
31d34d9b | 137 | mutex_unlock(&fimc->vid_cap.vfd.entity.parent->graph_mutex); |
d3953223 SN |
138 | } |
139 | ||
140 | int fimc_md_set_camclk(struct v4l2_subdev *sd, bool on); | |
d3953223 SN |
141 | |
142 | #endif |