2 * adv7393 - ADV7393 Video Encoder Driver
4 * The encoder hardware does not support SECAM.
6 * Copyright (C) 2010-2012 ADVANSEE - http://www.advansee.com/
7 * Benoît Thébaudeau <benoit.thebaudeau@advansee.com>
9 * Based on ADV7343 driver,
11 * Copyright (C) 2009 Texas Instruments Incorporated - http://www.ti.com/
13 * This program is free software; you can redistribute it and/or
14 * modify it under the terms of the GNU General Public License as
15 * published by the Free Software Foundation version 2.
17 * This program is distributed .as is. WITHOUT ANY WARRANTY of any
18 * kind, whether express or implied; without even the implied warranty
19 * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20 * GNU General Public License for more details.
23 #include <linux/kernel.h>
24 #include <linux/init.h>
25 #include <linux/ctype.h>
26 #include <linux/slab.h>
27 #include <linux/i2c.h>
28 #include <linux/device.h>
29 #include <linux/delay.h>
30 #include <linux/module.h>
31 #include <linux/videodev2.h>
32 #include <linux/uaccess.h>
34 #include <media/i2c/adv7393.h>
35 #include <media/v4l2-device.h>
36 #include <media/v4l2-ctrls.h>
38 #include "adv7393_regs.h"
40 MODULE_DESCRIPTION("ADV7393 video encoder driver");
41 MODULE_LICENSE("GPL");
44 module_param(debug
, bool, 0644);
45 MODULE_PARM_DESC(debug
, "Debug level 0-1");
47 struct adv7393_state
{
48 struct v4l2_subdev sd
;
49 struct v4l2_ctrl_handler hdl
;
60 static inline struct adv7393_state
*to_state(struct v4l2_subdev
*sd
)
62 return container_of(sd
, struct adv7393_state
, sd
);
65 static inline struct v4l2_subdev
*to_sd(struct v4l2_ctrl
*ctrl
)
67 return &container_of(ctrl
->handler
, struct adv7393_state
, hdl
)->sd
;
70 static inline int adv7393_write(struct v4l2_subdev
*sd
, u8 reg
, u8 value
)
72 struct i2c_client
*client
= v4l2_get_subdevdata(sd
);
74 return i2c_smbus_write_byte_data(client
, reg
, value
);
77 static const u8 adv7393_init_reg_val
[] = {
78 ADV7393_SOFT_RESET
, ADV7393_SOFT_RESET_DEFAULT
,
79 ADV7393_POWER_MODE_REG
, ADV7393_POWER_MODE_REG_DEFAULT
,
81 ADV7393_HD_MODE_REG1
, ADV7393_HD_MODE_REG1_DEFAULT
,
82 ADV7393_HD_MODE_REG2
, ADV7393_HD_MODE_REG2_DEFAULT
,
83 ADV7393_HD_MODE_REG3
, ADV7393_HD_MODE_REG3_DEFAULT
,
84 ADV7393_HD_MODE_REG4
, ADV7393_HD_MODE_REG4_DEFAULT
,
85 ADV7393_HD_MODE_REG5
, ADV7393_HD_MODE_REG5_DEFAULT
,
86 ADV7393_HD_MODE_REG6
, ADV7393_HD_MODE_REG6_DEFAULT
,
87 ADV7393_HD_MODE_REG7
, ADV7393_HD_MODE_REG7_DEFAULT
,
89 ADV7393_SD_MODE_REG1
, ADV7393_SD_MODE_REG1_DEFAULT
,
90 ADV7393_SD_MODE_REG2
, ADV7393_SD_MODE_REG2_DEFAULT
,
91 ADV7393_SD_MODE_REG3
, ADV7393_SD_MODE_REG3_DEFAULT
,
92 ADV7393_SD_MODE_REG4
, ADV7393_SD_MODE_REG4_DEFAULT
,
93 ADV7393_SD_MODE_REG5
, ADV7393_SD_MODE_REG5_DEFAULT
,
94 ADV7393_SD_MODE_REG6
, ADV7393_SD_MODE_REG6_DEFAULT
,
95 ADV7393_SD_MODE_REG7
, ADV7393_SD_MODE_REG7_DEFAULT
,
96 ADV7393_SD_MODE_REG8
, ADV7393_SD_MODE_REG8_DEFAULT
,
98 ADV7393_SD_TIMING_REG0
, ADV7393_SD_TIMING_REG0_DEFAULT
,
100 ADV7393_SD_HUE_ADJUST
, ADV7393_SD_HUE_ADJUST_DEFAULT
,
101 ADV7393_SD_CGMS_WSS0
, ADV7393_SD_CGMS_WSS0_DEFAULT
,
102 ADV7393_SD_BRIGHTNESS_WSS
, ADV7393_SD_BRIGHTNESS_WSS_DEFAULT
,
107 * FSC(reg) = FSC (HZ) * --------
110 static const struct adv7393_std_info stdinfo
[] = {
112 /* FSC(Hz) = 4,433,618.75 Hz */
113 SD_STD_NTSC
, 705268427, V4L2_STD_NTSC_443
,
115 /* FSC(Hz) = 3,579,545.45 Hz */
116 SD_STD_NTSC
, 569408542, V4L2_STD_NTSC
,
118 /* FSC(Hz) = 3,575,611.00 Hz */
119 SD_STD_PAL_M
, 568782678, V4L2_STD_PAL_M
,
121 /* FSC(Hz) = 3,582,056.00 Hz */
122 SD_STD_PAL_N
, 569807903, V4L2_STD_PAL_Nc
,
124 /* FSC(Hz) = 4,433,618.75 Hz */
125 SD_STD_PAL_N
, 705268427, V4L2_STD_PAL_N
,
127 /* FSC(Hz) = 4,433,618.75 Hz */
128 SD_STD_PAL_M
, 705268427, V4L2_STD_PAL_60
,
130 /* FSC(Hz) = 4,433,618.75 Hz */
131 SD_STD_PAL_BDGHI
, 705268427, V4L2_STD_PAL
,
135 static int adv7393_setstd(struct v4l2_subdev
*sd
, v4l2_std_id std
)
137 struct adv7393_state
*state
= to_state(sd
);
138 const struct adv7393_std_info
*std_info
;
145 num_std
= ARRAY_SIZE(stdinfo
);
147 for (i
= 0; i
< num_std
; i
++) {
148 if (stdinfo
[i
].stdid
& std
)
153 v4l2_dbg(1, debug
, sd
,
154 "Invalid std or std is not supported: %llx\n",
155 (unsigned long long)std
);
159 std_info
= &stdinfo
[i
];
161 /* Set the standard */
162 val
= state
->reg80
& ~SD_STD_MASK
;
163 val
|= std_info
->standard_val3
;
164 err
= adv7393_write(sd
, ADV7393_SD_MODE_REG1
, val
);
170 /* Configure the input mode register */
171 val
= state
->reg01
& ~INPUT_MODE_MASK
;
172 val
|= SD_INPUT_MODE
;
173 err
= adv7393_write(sd
, ADV7393_MODE_SELECT_REG
, val
);
179 /* Program the sub carrier frequency registers */
180 val
= std_info
->fsc_val
;
181 for (reg
= ADV7393_FSC_REG0
; reg
<= ADV7393_FSC_REG3
; reg
++) {
182 err
= adv7393_write(sd
, reg
, val
);
190 /* Pedestal settings */
191 if (std
& (V4L2_STD_NTSC
| V4L2_STD_NTSC_443
))
192 val
|= SD_PEDESTAL_EN
;
194 val
&= SD_PEDESTAL_DI
;
196 err
= adv7393_write(sd
, ADV7393_SD_MODE_REG2
, val
);
204 v4l2_err(sd
, "Error setting std, write failed\n");
209 static int adv7393_setoutput(struct v4l2_subdev
*sd
, u32 output_type
)
211 struct adv7393_state
*state
= to_state(sd
);
215 if (output_type
> ADV7393_SVIDEO_ID
) {
216 v4l2_dbg(1, debug
, sd
,
217 "Invalid output type or output type not supported:%d\n",
222 /* Enable Appropriate DAC */
223 val
= state
->reg00
& 0x03;
225 if (output_type
== ADV7393_COMPOSITE_ID
)
226 val
|= ADV7393_COMPOSITE_POWER_VALUE
;
227 else if (output_type
== ADV7393_COMPONENT_ID
)
228 val
|= ADV7393_COMPONENT_POWER_VALUE
;
230 val
|= ADV7393_SVIDEO_POWER_VALUE
;
232 err
= adv7393_write(sd
, ADV7393_POWER_MODE_REG
, val
);
238 /* Enable YUV output */
239 val
= state
->reg02
| YUV_OUTPUT_SELECT
;
240 err
= adv7393_write(sd
, ADV7393_MODE_REG0
, val
);
246 /* configure SD DAC Output 1 bit */
248 if (output_type
== ADV7393_COMPONENT_ID
)
249 val
&= SD_DAC_OUT1_DI
;
251 val
|= SD_DAC_OUT1_EN
;
252 err
= adv7393_write(sd
, ADV7393_SD_MODE_REG2
, val
);
258 /* configure ED/HD Color DAC Swap bit to zero */
259 val
= state
->reg35
& HD_DAC_SWAP_DI
;
260 err
= adv7393_write(sd
, ADV7393_HD_MODE_REG6
, val
);
268 v4l2_err(sd
, "Error setting output, write failed\n");
273 static int adv7393_log_status(struct v4l2_subdev
*sd
)
275 struct adv7393_state
*state
= to_state(sd
);
277 v4l2_info(sd
, "Standard: %llx\n", (unsigned long long)state
->std
);
278 v4l2_info(sd
, "Output: %s\n", (state
->output
== 0) ? "Composite" :
279 ((state
->output
== 1) ? "Component" : "S-Video"));
283 static int adv7393_s_ctrl(struct v4l2_ctrl
*ctrl
)
285 struct v4l2_subdev
*sd
= to_sd(ctrl
);
288 case V4L2_CID_BRIGHTNESS
:
289 return adv7393_write(sd
, ADV7393_SD_BRIGHTNESS_WSS
,
290 ctrl
->val
& SD_BRIGHTNESS_VALUE_MASK
);
293 return adv7393_write(sd
, ADV7393_SD_HUE_ADJUST
,
294 ctrl
->val
- ADV7393_HUE_MIN
);
297 return adv7393_write(sd
, ADV7393_DAC123_OUTPUT_LEVEL
,
303 static const struct v4l2_ctrl_ops adv7393_ctrl_ops
= {
304 .s_ctrl
= adv7393_s_ctrl
,
307 static const struct v4l2_subdev_core_ops adv7393_core_ops
= {
308 .log_status
= adv7393_log_status
,
311 static int adv7393_s_std_output(struct v4l2_subdev
*sd
, v4l2_std_id std
)
313 struct adv7393_state
*state
= to_state(sd
);
316 if (state
->std
== std
)
319 err
= adv7393_setstd(sd
, std
);
326 static int adv7393_s_routing(struct v4l2_subdev
*sd
,
327 u32 input
, u32 output
, u32 config
)
329 struct adv7393_state
*state
= to_state(sd
);
332 if (state
->output
== output
)
335 err
= adv7393_setoutput(sd
, output
);
337 state
->output
= output
;
342 static const struct v4l2_subdev_video_ops adv7393_video_ops
= {
343 .s_std_output
= adv7393_s_std_output
,
344 .s_routing
= adv7393_s_routing
,
347 static const struct v4l2_subdev_ops adv7393_ops
= {
348 .core
= &adv7393_core_ops
,
349 .video
= &adv7393_video_ops
,
352 static int adv7393_initialize(struct v4l2_subdev
*sd
)
354 struct adv7393_state
*state
= to_state(sd
);
358 for (i
= 0; i
< ARRAY_SIZE(adv7393_init_reg_val
); i
+= 2) {
360 err
= adv7393_write(sd
, adv7393_init_reg_val
[i
],
361 adv7393_init_reg_val
[i
+1]);
363 v4l2_err(sd
, "Error initializing\n");
368 /* Configure for default video standard */
369 err
= adv7393_setoutput(sd
, state
->output
);
371 v4l2_err(sd
, "Error setting output during init\n");
375 err
= adv7393_setstd(sd
, state
->std
);
377 v4l2_err(sd
, "Error setting std during init\n");
384 static int adv7393_probe(struct i2c_client
*client
,
385 const struct i2c_device_id
*id
)
387 struct adv7393_state
*state
;
390 if (!i2c_check_functionality(client
->adapter
, I2C_FUNC_SMBUS_BYTE_DATA
))
393 v4l_info(client
, "chip found @ 0x%x (%s)\n",
394 client
->addr
<< 1, client
->adapter
->name
);
396 state
= devm_kzalloc(&client
->dev
, sizeof(*state
), GFP_KERNEL
);
400 state
->reg00
= ADV7393_POWER_MODE_REG_DEFAULT
;
403 state
->reg35
= ADV7393_HD_MODE_REG6_DEFAULT
;
404 state
->reg80
= ADV7393_SD_MODE_REG1_DEFAULT
;
405 state
->reg82
= ADV7393_SD_MODE_REG2_DEFAULT
;
407 state
->output
= ADV7393_COMPOSITE_ID
;
408 state
->std
= V4L2_STD_NTSC
;
410 v4l2_i2c_subdev_init(&state
->sd
, client
, &adv7393_ops
);
412 v4l2_ctrl_handler_init(&state
->hdl
, 3);
413 v4l2_ctrl_new_std(&state
->hdl
, &adv7393_ctrl_ops
,
414 V4L2_CID_BRIGHTNESS
, ADV7393_BRIGHTNESS_MIN
,
415 ADV7393_BRIGHTNESS_MAX
, 1,
416 ADV7393_BRIGHTNESS_DEF
);
417 v4l2_ctrl_new_std(&state
->hdl
, &adv7393_ctrl_ops
,
418 V4L2_CID_HUE
, ADV7393_HUE_MIN
,
421 v4l2_ctrl_new_std(&state
->hdl
, &adv7393_ctrl_ops
,
422 V4L2_CID_GAIN
, ADV7393_GAIN_MIN
,
425 state
->sd
.ctrl_handler
= &state
->hdl
;
426 if (state
->hdl
.error
) {
427 int err
= state
->hdl
.error
;
429 v4l2_ctrl_handler_free(&state
->hdl
);
432 v4l2_ctrl_handler_setup(&state
->hdl
);
434 err
= adv7393_initialize(&state
->sd
);
436 v4l2_ctrl_handler_free(&state
->hdl
);
440 static int adv7393_remove(struct i2c_client
*client
)
442 struct v4l2_subdev
*sd
= i2c_get_clientdata(client
);
443 struct adv7393_state
*state
= to_state(sd
);
445 v4l2_device_unregister_subdev(sd
);
446 v4l2_ctrl_handler_free(&state
->hdl
);
451 static const struct i2c_device_id adv7393_id
[] = {
455 MODULE_DEVICE_TABLE(i2c
, adv7393_id
);
457 static struct i2c_driver adv7393_driver
= {
459 .owner
= THIS_MODULE
,
462 .probe
= adv7393_probe
,
463 .remove
= adv7393_remove
,
464 .id_table
= adv7393_id
,
466 module_i2c_driver(adv7393_driver
);