xref: /openbmc/linux/drivers/media/i2c/adv7511-v4l2.c (revision aaeb31c0)
1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3  * Analog Devices ADV7511 HDMI Transmitter Device Driver
4  *
5  * Copyright 2013 Cisco Systems, Inc. and/or its affiliates. All rights reserved.
6  */
7 
8 /*
9  * This file is named adv7511-v4l2.c so it doesn't conflict with the Analog
10  * Device ADV7511 (config fragment CONFIG_DRM_I2C_ADV7511).
11  */
12 
13 
14 #include <linux/kernel.h>
15 #include <linux/module.h>
16 #include <linux/slab.h>
17 #include <linux/i2c.h>
18 #include <linux/delay.h>
19 #include <linux/videodev2.h>
20 #include <linux/workqueue.h>
21 #include <linux/hdmi.h>
22 #include <linux/v4l2-dv-timings.h>
23 #include <media/v4l2-device.h>
24 #include <media/v4l2-common.h>
25 #include <media/v4l2-ctrls.h>
26 #include <media/v4l2-dv-timings.h>
27 #include <media/i2c/adv7511.h>
28 #include <media/cec.h>
29 
30 static int debug;
31 module_param(debug, int, 0644);
32 MODULE_PARM_DESC(debug, "debug level (0-2)");
33 
34 MODULE_DESCRIPTION("Analog Devices ADV7511 HDMI Transmitter Device Driver");
35 MODULE_AUTHOR("Hans Verkuil");
36 MODULE_LICENSE("GPL v2");
37 
38 #define MASK_ADV7511_EDID_RDY_INT   0x04
39 #define MASK_ADV7511_MSEN_INT       0x40
40 #define MASK_ADV7511_HPD_INT        0x80
41 
42 #define MASK_ADV7511_HPD_DETECT     0x40
43 #define MASK_ADV7511_MSEN_DETECT    0x20
44 #define MASK_ADV7511_EDID_RDY       0x10
45 
46 #define EDID_MAX_RETRIES (8)
47 #define EDID_DELAY 250
48 #define EDID_MAX_SEGM 8
49 
50 #define ADV7511_MAX_WIDTH 1920
51 #define ADV7511_MAX_HEIGHT 1200
52 #define ADV7511_MIN_PIXELCLOCK 20000000
53 #define ADV7511_MAX_PIXELCLOCK 225000000
54 
55 #define ADV7511_MAX_ADDRS (3)
56 
57 /*
58 **********************************************************************
59 *
60 *  Arrays with configuration parameters for the ADV7511
61 *
62 **********************************************************************
63 */
64 
65 struct i2c_reg_value {
66 	unsigned char reg;
67 	unsigned char value;
68 };
69 
70 struct adv7511_state_edid {
71 	/* total number of blocks */
72 	u32 blocks;
73 	/* Number of segments read */
74 	u32 segments;
75 	u8 data[EDID_MAX_SEGM * 256];
76 	/* Number of EDID read retries left */
77 	unsigned read_retries;
78 	bool complete;
79 };
80 
81 struct adv7511_state {
82 	struct adv7511_platform_data pdata;
83 	struct v4l2_subdev sd;
84 	struct media_pad pad;
85 	struct v4l2_ctrl_handler hdl;
86 	int chip_revision;
87 	u8 i2c_edid_addr;
88 	u8 i2c_pktmem_addr;
89 	u8 i2c_cec_addr;
90 
91 	struct i2c_client *i2c_cec;
92 	struct cec_adapter *cec_adap;
93 	u8   cec_addr[ADV7511_MAX_ADDRS];
94 	u8   cec_valid_addrs;
95 	bool cec_enabled_adap;
96 
97 	/* Is the adv7511 powered on? */
98 	bool power_on;
99 	/* Did we receive hotplug and rx-sense signals? */
100 	bool have_monitor;
101 	bool enabled_irq;
102 	/* timings from s_dv_timings */
103 	struct v4l2_dv_timings dv_timings;
104 	u32 fmt_code;
105 	u32 colorspace;
106 	u32 ycbcr_enc;
107 	u32 quantization;
108 	u32 xfer_func;
109 	u32 content_type;
110 	/* controls */
111 	struct v4l2_ctrl *hdmi_mode_ctrl;
112 	struct v4l2_ctrl *hotplug_ctrl;
113 	struct v4l2_ctrl *rx_sense_ctrl;
114 	struct v4l2_ctrl *have_edid0_ctrl;
115 	struct v4l2_ctrl *rgb_quantization_range_ctrl;
116 	struct v4l2_ctrl *content_type_ctrl;
117 	struct i2c_client *i2c_edid;
118 	struct i2c_client *i2c_pktmem;
119 	struct adv7511_state_edid edid;
120 	/* Running counter of the number of detected EDIDs (for debugging) */
121 	unsigned edid_detect_counter;
122 	struct workqueue_struct *work_queue;
123 	struct delayed_work edid_handler; /* work entry */
124 };
125 
126 static void adv7511_check_monitor_present_status(struct v4l2_subdev *sd);
127 static bool adv7511_check_edid_status(struct v4l2_subdev *sd);
128 static void adv7511_setup(struct v4l2_subdev *sd);
129 static int adv7511_s_i2s_clock_freq(struct v4l2_subdev *sd, u32 freq);
130 static int adv7511_s_clock_freq(struct v4l2_subdev *sd, u32 freq);
131 
132 
133 static const struct v4l2_dv_timings_cap adv7511_timings_cap = {
134 	.type = V4L2_DV_BT_656_1120,
135 	/* keep this initialization for compatibility with GCC < 4.4.6 */
136 	.reserved = { 0 },
137 	V4L2_INIT_BT_TIMINGS(640, ADV7511_MAX_WIDTH, 350, ADV7511_MAX_HEIGHT,
138 		ADV7511_MIN_PIXELCLOCK, ADV7511_MAX_PIXELCLOCK,
139 		V4L2_DV_BT_STD_CEA861 | V4L2_DV_BT_STD_DMT |
140 			V4L2_DV_BT_STD_GTF | V4L2_DV_BT_STD_CVT,
141 		V4L2_DV_BT_CAP_PROGRESSIVE | V4L2_DV_BT_CAP_REDUCED_BLANKING |
142 			V4L2_DV_BT_CAP_CUSTOM)
143 };
144 
get_adv7511_state(struct v4l2_subdev * sd)145 static inline struct adv7511_state *get_adv7511_state(struct v4l2_subdev *sd)
146 {
147 	return container_of(sd, struct adv7511_state, sd);
148 }
149 
to_sd(struct v4l2_ctrl * ctrl)150 static inline struct v4l2_subdev *to_sd(struct v4l2_ctrl *ctrl)
151 {
152 	return &container_of(ctrl->handler, struct adv7511_state, hdl)->sd;
153 }
154 
155 /* ------------------------ I2C ----------------------------------------------- */
156 
adv_smbus_read_byte_data_check(struct i2c_client * client,u8 command,bool check)157 static s32 adv_smbus_read_byte_data_check(struct i2c_client *client,
158 					  u8 command, bool check)
159 {
160 	union i2c_smbus_data data;
161 
162 	if (!i2c_smbus_xfer(client->adapter, client->addr, client->flags,
163 			    I2C_SMBUS_READ, command,
164 			    I2C_SMBUS_BYTE_DATA, &data))
165 		return data.byte;
166 	if (check)
167 		v4l_err(client, "error reading %02x, %02x\n",
168 			client->addr, command);
169 	return -1;
170 }
171 
adv_smbus_read_byte_data(struct i2c_client * client,u8 command)172 static s32 adv_smbus_read_byte_data(struct i2c_client *client, u8 command)
173 {
174 	int i;
175 	for (i = 0; i < 3; i++) {
176 		int ret = adv_smbus_read_byte_data_check(client, command, true);
177 		if (ret >= 0) {
178 			if (i)
179 				v4l_err(client, "read ok after %d retries\n", i);
180 			return ret;
181 		}
182 	}
183 	v4l_err(client, "read failed\n");
184 	return -1;
185 }
186 
adv7511_rd(struct v4l2_subdev * sd,u8 reg)187 static int adv7511_rd(struct v4l2_subdev *sd, u8 reg)
188 {
189 	struct i2c_client *client = v4l2_get_subdevdata(sd);
190 
191 	return adv_smbus_read_byte_data(client, reg);
192 }
193 
adv7511_wr(struct v4l2_subdev * sd,u8 reg,u8 val)194 static int adv7511_wr(struct v4l2_subdev *sd, u8 reg, u8 val)
195 {
196 	struct i2c_client *client = v4l2_get_subdevdata(sd);
197 	int ret;
198 	int i;
199 
200 	for (i = 0; i < 3; i++) {
201 		ret = i2c_smbus_write_byte_data(client, reg, val);
202 		if (ret == 0)
203 			return 0;
204 	}
205 	v4l2_err(sd, "%s: i2c write error\n", __func__);
206 	return ret;
207 }
208 
209 /* To set specific bits in the register, a clear-mask is given (to be AND-ed),
210    and then the value-mask (to be OR-ed). */
adv7511_wr_and_or(struct v4l2_subdev * sd,u8 reg,u8 clr_mask,u8 val_mask)211 static inline void adv7511_wr_and_or(struct v4l2_subdev *sd, u8 reg, u8 clr_mask, u8 val_mask)
212 {
213 	adv7511_wr(sd, reg, (adv7511_rd(sd, reg) & clr_mask) | val_mask);
214 }
215 
adv7511_edid_rd(struct v4l2_subdev * sd,uint16_t len,uint8_t * buf)216 static int adv7511_edid_rd(struct v4l2_subdev *sd, uint16_t len, uint8_t *buf)
217 {
218 	struct adv7511_state *state = get_adv7511_state(sd);
219 	int i;
220 
221 	v4l2_dbg(1, debug, sd, "%s:\n", __func__);
222 
223 	for (i = 0; i < len; i += I2C_SMBUS_BLOCK_MAX) {
224 		s32 ret;
225 
226 		ret = i2c_smbus_read_i2c_block_data(state->i2c_edid, i,
227 						    I2C_SMBUS_BLOCK_MAX, buf + i);
228 		if (ret < 0) {
229 			v4l2_err(sd, "%s: i2c read error\n", __func__);
230 			return ret;
231 		}
232 	}
233 
234 	return 0;
235 }
236 
adv7511_cec_read(struct v4l2_subdev * sd,u8 reg)237 static inline int adv7511_cec_read(struct v4l2_subdev *sd, u8 reg)
238 {
239 	struct adv7511_state *state = get_adv7511_state(sd);
240 
241 	return i2c_smbus_read_byte_data(state->i2c_cec, reg);
242 }
243 
adv7511_cec_write(struct v4l2_subdev * sd,u8 reg,u8 val)244 static int adv7511_cec_write(struct v4l2_subdev *sd, u8 reg, u8 val)
245 {
246 	struct adv7511_state *state = get_adv7511_state(sd);
247 	int ret;
248 	int i;
249 
250 	for (i = 0; i < 3; i++) {
251 		ret = i2c_smbus_write_byte_data(state->i2c_cec, reg, val);
252 		if (ret == 0)
253 			return 0;
254 	}
255 	v4l2_err(sd, "%s: I2C Write Problem\n", __func__);
256 	return ret;
257 }
258 
adv7511_cec_write_and_or(struct v4l2_subdev * sd,u8 reg,u8 mask,u8 val)259 static inline int adv7511_cec_write_and_or(struct v4l2_subdev *sd, u8 reg, u8 mask,
260 				   u8 val)
261 {
262 	return adv7511_cec_write(sd, reg, (adv7511_cec_read(sd, reg) & mask) | val);
263 }
264 
adv7511_pktmem_rd(struct v4l2_subdev * sd,u8 reg)265 static int adv7511_pktmem_rd(struct v4l2_subdev *sd, u8 reg)
266 {
267 	struct adv7511_state *state = get_adv7511_state(sd);
268 
269 	return adv_smbus_read_byte_data(state->i2c_pktmem, reg);
270 }
271 
adv7511_have_hotplug(struct v4l2_subdev * sd)272 static inline bool adv7511_have_hotplug(struct v4l2_subdev *sd)
273 {
274 	return adv7511_rd(sd, 0x42) & MASK_ADV7511_HPD_DETECT;
275 }
276 
adv7511_have_rx_sense(struct v4l2_subdev * sd)277 static inline bool adv7511_have_rx_sense(struct v4l2_subdev *sd)
278 {
279 	return adv7511_rd(sd, 0x42) & MASK_ADV7511_MSEN_DETECT;
280 }
281 
adv7511_csc_conversion_mode(struct v4l2_subdev * sd,u8 mode)282 static void adv7511_csc_conversion_mode(struct v4l2_subdev *sd, u8 mode)
283 {
284 	adv7511_wr_and_or(sd, 0x18, 0x9f, (mode & 0x3)<<5);
285 }
286 
adv7511_csc_coeff(struct v4l2_subdev * sd,u16 A1,u16 A2,u16 A3,u16 A4,u16 B1,u16 B2,u16 B3,u16 B4,u16 C1,u16 C2,u16 C3,u16 C4)287 static void adv7511_csc_coeff(struct v4l2_subdev *sd,
288 			      u16 A1, u16 A2, u16 A3, u16 A4,
289 			      u16 B1, u16 B2, u16 B3, u16 B4,
290 			      u16 C1, u16 C2, u16 C3, u16 C4)
291 {
292 	/* A */
293 	adv7511_wr_and_or(sd, 0x18, 0xe0, A1>>8);
294 	adv7511_wr(sd, 0x19, A1);
295 	adv7511_wr_and_or(sd, 0x1A, 0xe0, A2>>8);
296 	adv7511_wr(sd, 0x1B, A2);
297 	adv7511_wr_and_or(sd, 0x1c, 0xe0, A3>>8);
298 	adv7511_wr(sd, 0x1d, A3);
299 	adv7511_wr_and_or(sd, 0x1e, 0xe0, A4>>8);
300 	adv7511_wr(sd, 0x1f, A4);
301 
302 	/* B */
303 	adv7511_wr_and_or(sd, 0x20, 0xe0, B1>>8);
304 	adv7511_wr(sd, 0x21, B1);
305 	adv7511_wr_and_or(sd, 0x22, 0xe0, B2>>8);
306 	adv7511_wr(sd, 0x23, B2);
307 	adv7511_wr_and_or(sd, 0x24, 0xe0, B3>>8);
308 	adv7511_wr(sd, 0x25, B3);
309 	adv7511_wr_and_or(sd, 0x26, 0xe0, B4>>8);
310 	adv7511_wr(sd, 0x27, B4);
311 
312 	/* C */
313 	adv7511_wr_and_or(sd, 0x28, 0xe0, C1>>8);
314 	adv7511_wr(sd, 0x29, C1);
315 	adv7511_wr_and_or(sd, 0x2A, 0xe0, C2>>8);
316 	adv7511_wr(sd, 0x2B, C2);
317 	adv7511_wr_and_or(sd, 0x2C, 0xe0, C3>>8);
318 	adv7511_wr(sd, 0x2D, C3);
319 	adv7511_wr_and_or(sd, 0x2E, 0xe0, C4>>8);
320 	adv7511_wr(sd, 0x2F, C4);
321 }
322 
adv7511_csc_rgb_full2limit(struct v4l2_subdev * sd,bool enable)323 static void adv7511_csc_rgb_full2limit(struct v4l2_subdev *sd, bool enable)
324 {
325 	if (enable) {
326 		u8 csc_mode = 0;
327 		adv7511_csc_conversion_mode(sd, csc_mode);
328 		adv7511_csc_coeff(sd,
329 				  4096-564, 0, 0, 256,
330 				  0, 4096-564, 0, 256,
331 				  0, 0, 4096-564, 256);
332 		/* enable CSC */
333 		adv7511_wr_and_or(sd, 0x18, 0x7f, 0x80);
334 		/* AVI infoframe: Limited range RGB (16-235) */
335 		adv7511_wr_and_or(sd, 0x57, 0xf3, 0x04);
336 	} else {
337 		/* disable CSC */
338 		adv7511_wr_and_or(sd, 0x18, 0x7f, 0x0);
339 		/* AVI infoframe: Full range RGB (0-255) */
340 		adv7511_wr_and_or(sd, 0x57, 0xf3, 0x08);
341 	}
342 }
343 
adv7511_set_rgb_quantization_mode(struct v4l2_subdev * sd,struct v4l2_ctrl * ctrl)344 static void adv7511_set_rgb_quantization_mode(struct v4l2_subdev *sd, struct v4l2_ctrl *ctrl)
345 {
346 	struct adv7511_state *state = get_adv7511_state(sd);
347 
348 	/* Only makes sense for RGB formats */
349 	if (state->fmt_code != MEDIA_BUS_FMT_RGB888_1X24) {
350 		/* so just keep quantization */
351 		adv7511_csc_rgb_full2limit(sd, false);
352 		return;
353 	}
354 
355 	switch (ctrl->val) {
356 	case V4L2_DV_RGB_RANGE_AUTO:
357 		/* automatic */
358 		if (state->dv_timings.bt.flags & V4L2_DV_FL_IS_CE_VIDEO) {
359 			/* CE format, RGB limited range (16-235) */
360 			adv7511_csc_rgb_full2limit(sd, true);
361 		} else {
362 			/* not CE format, RGB full range (0-255) */
363 			adv7511_csc_rgb_full2limit(sd, false);
364 		}
365 		break;
366 	case V4L2_DV_RGB_RANGE_LIMITED:
367 		/* RGB limited range (16-235) */
368 		adv7511_csc_rgb_full2limit(sd, true);
369 		break;
370 	case V4L2_DV_RGB_RANGE_FULL:
371 		/* RGB full range (0-255) */
372 		adv7511_csc_rgb_full2limit(sd, false);
373 		break;
374 	}
375 }
376 
377 /* ------------------------------ CTRL OPS ------------------------------ */
378 
adv7511_s_ctrl(struct v4l2_ctrl * ctrl)379 static int adv7511_s_ctrl(struct v4l2_ctrl *ctrl)
380 {
381 	struct v4l2_subdev *sd = to_sd(ctrl);
382 	struct adv7511_state *state = get_adv7511_state(sd);
383 
384 	v4l2_dbg(1, debug, sd, "%s: ctrl id: %d, ctrl->val %d\n", __func__, ctrl->id, ctrl->val);
385 
386 	if (state->hdmi_mode_ctrl == ctrl) {
387 		/* Set HDMI or DVI-D */
388 		adv7511_wr_and_or(sd, 0xaf, 0xfd, ctrl->val == V4L2_DV_TX_MODE_HDMI ? 0x02 : 0x00);
389 		return 0;
390 	}
391 	if (state->rgb_quantization_range_ctrl == ctrl) {
392 		adv7511_set_rgb_quantization_mode(sd, ctrl);
393 		return 0;
394 	}
395 	if (state->content_type_ctrl == ctrl) {
396 		u8 itc, cn;
397 
398 		state->content_type = ctrl->val;
399 		itc = state->content_type != V4L2_DV_IT_CONTENT_TYPE_NO_ITC;
400 		cn = itc ? state->content_type : V4L2_DV_IT_CONTENT_TYPE_GRAPHICS;
401 		adv7511_wr_and_or(sd, 0x57, 0x7f, itc << 7);
402 		adv7511_wr_and_or(sd, 0x59, 0xcf, cn << 4);
403 		return 0;
404 	}
405 
406 	return -EINVAL;
407 }
408 
409 static const struct v4l2_ctrl_ops adv7511_ctrl_ops = {
410 	.s_ctrl = adv7511_s_ctrl,
411 };
412 
413 /* ---------------------------- CORE OPS ------------------------------------------- */
414 
415 #ifdef CONFIG_VIDEO_ADV_DEBUG
adv7511_inv_register(struct v4l2_subdev * sd)416 static void adv7511_inv_register(struct v4l2_subdev *sd)
417 {
418 	struct adv7511_state *state = get_adv7511_state(sd);
419 
420 	v4l2_info(sd, "0x000-0x0ff: Main Map\n");
421 	if (state->i2c_cec)
422 		v4l2_info(sd, "0x100-0x1ff: CEC Map\n");
423 }
424 
adv7511_g_register(struct v4l2_subdev * sd,struct v4l2_dbg_register * reg)425 static int adv7511_g_register(struct v4l2_subdev *sd, struct v4l2_dbg_register *reg)
426 {
427 	struct adv7511_state *state = get_adv7511_state(sd);
428 
429 	reg->size = 1;
430 	switch (reg->reg >> 8) {
431 	case 0:
432 		reg->val = adv7511_rd(sd, reg->reg & 0xff);
433 		break;
434 	case 1:
435 		if (state->i2c_cec) {
436 			reg->val = adv7511_cec_read(sd, reg->reg & 0xff);
437 			break;
438 		}
439 		fallthrough;
440 	default:
441 		v4l2_info(sd, "Register %03llx not supported\n", reg->reg);
442 		adv7511_inv_register(sd);
443 		break;
444 	}
445 	return 0;
446 }
447 
adv7511_s_register(struct v4l2_subdev * sd,const struct v4l2_dbg_register * reg)448 static int adv7511_s_register(struct v4l2_subdev *sd, const struct v4l2_dbg_register *reg)
449 {
450 	struct adv7511_state *state = get_adv7511_state(sd);
451 
452 	switch (reg->reg >> 8) {
453 	case 0:
454 		adv7511_wr(sd, reg->reg & 0xff, reg->val & 0xff);
455 		break;
456 	case 1:
457 		if (state->i2c_cec) {
458 			adv7511_cec_write(sd, reg->reg & 0xff, reg->val & 0xff);
459 			break;
460 		}
461 		fallthrough;
462 	default:
463 		v4l2_info(sd, "Register %03llx not supported\n", reg->reg);
464 		adv7511_inv_register(sd);
465 		break;
466 	}
467 	return 0;
468 }
469 #endif
470 
471 struct adv7511_cfg_read_infoframe {
472 	const char *desc;
473 	u8 present_reg;
474 	u8 present_mask;
475 	u8 header[3];
476 	u16 payload_addr;
477 };
478 
hdmi_infoframe_checksum(u8 * ptr,size_t size)479 static u8 hdmi_infoframe_checksum(u8 *ptr, size_t size)
480 {
481 	u8 csum = 0;
482 	size_t i;
483 
484 	/* compute checksum */
485 	for (i = 0; i < size; i++)
486 		csum += ptr[i];
487 
488 	return 256 - csum;
489 }
490 
log_infoframe(struct v4l2_subdev * sd,const struct adv7511_cfg_read_infoframe * cri)491 static void log_infoframe(struct v4l2_subdev *sd, const struct adv7511_cfg_read_infoframe *cri)
492 {
493 	struct i2c_client *client = v4l2_get_subdevdata(sd);
494 	struct device *dev = &client->dev;
495 	union hdmi_infoframe frame;
496 	u8 buffer[32];
497 	u8 len;
498 	int i;
499 
500 	if (!(adv7511_rd(sd, cri->present_reg) & cri->present_mask)) {
501 		v4l2_info(sd, "%s infoframe not transmitted\n", cri->desc);
502 		return;
503 	}
504 
505 	memcpy(buffer, cri->header, sizeof(cri->header));
506 
507 	len = buffer[2];
508 
509 	if (len + 4 > sizeof(buffer)) {
510 		v4l2_err(sd, "%s: invalid %s infoframe length %d\n", __func__, cri->desc, len);
511 		return;
512 	}
513 
514 	if (cri->payload_addr >= 0x100) {
515 		for (i = 0; i < len; i++)
516 			buffer[i + 4] = adv7511_pktmem_rd(sd, cri->payload_addr + i - 0x100);
517 	} else {
518 		for (i = 0; i < len; i++)
519 			buffer[i + 4] = adv7511_rd(sd, cri->payload_addr + i);
520 	}
521 	buffer[3] = 0;
522 	buffer[3] = hdmi_infoframe_checksum(buffer, len + 4);
523 
524 	if (hdmi_infoframe_unpack(&frame, buffer, len + 4) < 0) {
525 		v4l2_err(sd, "%s: unpack of %s infoframe failed\n", __func__, cri->desc);
526 		return;
527 	}
528 
529 	hdmi_infoframe_log(KERN_INFO, dev, &frame);
530 }
531 
adv7511_log_infoframes(struct v4l2_subdev * sd)532 static void adv7511_log_infoframes(struct v4l2_subdev *sd)
533 {
534 	static const struct adv7511_cfg_read_infoframe cri[] = {
535 		{ "AVI", 0x44, 0x10, { 0x82, 2, 13 }, 0x55 },
536 		{ "Audio", 0x44, 0x08, { 0x84, 1, 10 }, 0x73 },
537 		{ "SDP", 0x40, 0x40, { 0x83, 1, 25 }, 0x103 },
538 	};
539 	int i;
540 
541 	for (i = 0; i < ARRAY_SIZE(cri); i++)
542 		log_infoframe(sd, &cri[i]);
543 }
544 
adv7511_log_status(struct v4l2_subdev * sd)545 static int adv7511_log_status(struct v4l2_subdev *sd)
546 {
547 	struct adv7511_state *state = get_adv7511_state(sd);
548 	struct adv7511_state_edid *edid = &state->edid;
549 	int i;
550 
551 	static const char * const states[] = {
552 		"in reset",
553 		"reading EDID",
554 		"idle",
555 		"initializing HDCP",
556 		"HDCP enabled",
557 		"initializing HDCP repeater",
558 		"6", "7", "8", "9", "A", "B", "C", "D", "E", "F"
559 	};
560 	static const char * const errors[] = {
561 		"no error",
562 		"bad receiver BKSV",
563 		"Ri mismatch",
564 		"Pj mismatch",
565 		"i2c error",
566 		"timed out",
567 		"max repeater cascade exceeded",
568 		"hash check failed",
569 		"too many devices",
570 		"9", "A", "B", "C", "D", "E", "F"
571 	};
572 
573 	v4l2_info(sd, "power %s\n", state->power_on ? "on" : "off");
574 	v4l2_info(sd, "%s hotplug, %s Rx Sense, %s EDID (%d block(s))\n",
575 		  (adv7511_rd(sd, 0x42) & MASK_ADV7511_HPD_DETECT) ? "detected" : "no",
576 		  (adv7511_rd(sd, 0x42) & MASK_ADV7511_MSEN_DETECT) ? "detected" : "no",
577 		  edid->segments ? "found" : "no",
578 		  edid->blocks);
579 	v4l2_info(sd, "%s output %s\n",
580 		  (adv7511_rd(sd, 0xaf) & 0x02) ?
581 		  "HDMI" : "DVI-D",
582 		  (adv7511_rd(sd, 0xa1) & 0x3c) ?
583 		  "disabled" : "enabled");
584 	v4l2_info(sd, "state: %s, error: %s, detect count: %u, msk/irq: %02x/%02x\n",
585 			  states[adv7511_rd(sd, 0xc8) & 0xf],
586 			  errors[adv7511_rd(sd, 0xc8) >> 4], state->edid_detect_counter,
587 			  adv7511_rd(sd, 0x94), adv7511_rd(sd, 0x96));
588 	v4l2_info(sd, "RGB quantization: %s range\n", adv7511_rd(sd, 0x18) & 0x80 ? "limited" : "full");
589 	if (adv7511_rd(sd, 0xaf) & 0x02) {
590 		/* HDMI only */
591 		u8 manual_cts = adv7511_rd(sd, 0x0a) & 0x80;
592 		u32 N = (adv7511_rd(sd, 0x01) & 0xf) << 16 |
593 			adv7511_rd(sd, 0x02) << 8 |
594 			adv7511_rd(sd, 0x03);
595 		u8 vic_detect = adv7511_rd(sd, 0x3e) >> 2;
596 		u8 vic_sent = adv7511_rd(sd, 0x3d) & 0x3f;
597 		u32 CTS;
598 
599 		if (manual_cts)
600 			CTS = (adv7511_rd(sd, 0x07) & 0xf) << 16 |
601 			      adv7511_rd(sd, 0x08) << 8 |
602 			      adv7511_rd(sd, 0x09);
603 		else
604 			CTS = (adv7511_rd(sd, 0x04) & 0xf) << 16 |
605 			      adv7511_rd(sd, 0x05) << 8 |
606 			      adv7511_rd(sd, 0x06);
607 		v4l2_info(sd, "CTS %s mode: N %d, CTS %d\n",
608 			  manual_cts ? "manual" : "automatic", N, CTS);
609 		v4l2_info(sd, "VIC: detected %d, sent %d\n",
610 			  vic_detect, vic_sent);
611 		adv7511_log_infoframes(sd);
612 	}
613 	if (state->dv_timings.type == V4L2_DV_BT_656_1120)
614 		v4l2_print_dv_timings(sd->name, "timings: ",
615 				&state->dv_timings, false);
616 	else
617 		v4l2_info(sd, "no timings set\n");
618 	v4l2_info(sd, "i2c edid addr: 0x%x\n", state->i2c_edid_addr);
619 
620 	if (state->i2c_cec == NULL)
621 		return 0;
622 
623 	v4l2_info(sd, "i2c cec addr: 0x%x\n", state->i2c_cec_addr);
624 
625 	v4l2_info(sd, "CEC: %s\n", state->cec_enabled_adap ?
626 			"enabled" : "disabled");
627 	if (state->cec_enabled_adap) {
628 		for (i = 0; i < ADV7511_MAX_ADDRS; i++) {
629 			bool is_valid = state->cec_valid_addrs & (1 << i);
630 
631 			if (is_valid)
632 				v4l2_info(sd, "CEC Logical Address: 0x%x\n",
633 					  state->cec_addr[i]);
634 		}
635 	}
636 	v4l2_info(sd, "i2c pktmem addr: 0x%x\n", state->i2c_pktmem_addr);
637 	return 0;
638 }
639 
640 /* Power up/down adv7511 */
adv7511_s_power(struct v4l2_subdev * sd,int on)641 static int adv7511_s_power(struct v4l2_subdev *sd, int on)
642 {
643 	struct adv7511_state *state = get_adv7511_state(sd);
644 	const int retries = 20;
645 	int i;
646 
647 	v4l2_dbg(1, debug, sd, "%s: power %s\n", __func__, on ? "on" : "off");
648 
649 	state->power_on = on;
650 
651 	if (!on) {
652 		/* Power down */
653 		adv7511_wr_and_or(sd, 0x41, 0xbf, 0x40);
654 		return true;
655 	}
656 
657 	/* Power up */
658 	/* The adv7511 does not always come up immediately.
659 	   Retry multiple times. */
660 	for (i = 0; i < retries; i++) {
661 		adv7511_wr_and_or(sd, 0x41, 0xbf, 0x0);
662 		if ((adv7511_rd(sd, 0x41) & 0x40) == 0)
663 			break;
664 		adv7511_wr_and_or(sd, 0x41, 0xbf, 0x40);
665 		msleep(10);
666 	}
667 	if (i == retries) {
668 		v4l2_dbg(1, debug, sd, "%s: failed to powerup the adv7511!\n", __func__);
669 		adv7511_s_power(sd, 0);
670 		return false;
671 	}
672 	if (i > 1)
673 		v4l2_dbg(1, debug, sd, "%s: needed %d retries to powerup the adv7511\n", __func__, i);
674 
675 	/* Reserved registers that must be set */
676 	adv7511_wr(sd, 0x98, 0x03);
677 	adv7511_wr_and_or(sd, 0x9a, 0xfe, 0x70);
678 	adv7511_wr(sd, 0x9c, 0x30);
679 	adv7511_wr_and_or(sd, 0x9d, 0xfc, 0x01);
680 	adv7511_wr(sd, 0xa2, 0xa4);
681 	adv7511_wr(sd, 0xa3, 0xa4);
682 	adv7511_wr(sd, 0xe0, 0xd0);
683 	adv7511_wr(sd, 0xf9, 0x00);
684 
685 	adv7511_wr(sd, 0x43, state->i2c_edid_addr);
686 	adv7511_wr(sd, 0x45, state->i2c_pktmem_addr);
687 
688 	/* Set number of attempts to read the EDID */
689 	adv7511_wr(sd, 0xc9, 0xf);
690 	return true;
691 }
692 
693 #if IS_ENABLED(CONFIG_VIDEO_ADV7511_CEC)
adv7511_cec_adap_enable(struct cec_adapter * adap,bool enable)694 static int adv7511_cec_adap_enable(struct cec_adapter *adap, bool enable)
695 {
696 	struct adv7511_state *state = cec_get_drvdata(adap);
697 	struct v4l2_subdev *sd = &state->sd;
698 
699 	if (state->i2c_cec == NULL)
700 		return -EIO;
701 
702 	if (!state->cec_enabled_adap && enable) {
703 		/* power up cec section */
704 		adv7511_cec_write_and_or(sd, 0x4e, 0xfc, 0x01);
705 		/* legacy mode and clear all rx buffers */
706 		adv7511_cec_write(sd, 0x4a, 0x00);
707 		adv7511_cec_write(sd, 0x4a, 0x07);
708 		adv7511_cec_write_and_or(sd, 0x11, 0xfe, 0); /* initially disable tx */
709 		/* enabled irqs: */
710 		/* tx: ready */
711 		/* tx: arbitration lost */
712 		/* tx: retry timeout */
713 		/* rx: ready 1 */
714 		if (state->enabled_irq)
715 			adv7511_wr_and_or(sd, 0x95, 0xc0, 0x39);
716 	} else if (state->cec_enabled_adap && !enable) {
717 		if (state->enabled_irq)
718 			adv7511_wr_and_or(sd, 0x95, 0xc0, 0x00);
719 		/* disable address mask 1-3 */
720 		adv7511_cec_write_and_or(sd, 0x4b, 0x8f, 0x00);
721 		/* power down cec section */
722 		adv7511_cec_write_and_or(sd, 0x4e, 0xfc, 0x00);
723 		state->cec_valid_addrs = 0;
724 	}
725 	state->cec_enabled_adap = enable;
726 	return 0;
727 }
728 
adv7511_cec_adap_log_addr(struct cec_adapter * adap,u8 addr)729 static int adv7511_cec_adap_log_addr(struct cec_adapter *adap, u8 addr)
730 {
731 	struct adv7511_state *state = cec_get_drvdata(adap);
732 	struct v4l2_subdev *sd = &state->sd;
733 	unsigned int i, free_idx = ADV7511_MAX_ADDRS;
734 
735 	if (!state->cec_enabled_adap)
736 		return addr == CEC_LOG_ADDR_INVALID ? 0 : -EIO;
737 
738 	if (addr == CEC_LOG_ADDR_INVALID) {
739 		adv7511_cec_write_and_or(sd, 0x4b, 0x8f, 0);
740 		state->cec_valid_addrs = 0;
741 		return 0;
742 	}
743 
744 	for (i = 0; i < ADV7511_MAX_ADDRS; i++) {
745 		bool is_valid = state->cec_valid_addrs & (1 << i);
746 
747 		if (free_idx == ADV7511_MAX_ADDRS && !is_valid)
748 			free_idx = i;
749 		if (is_valid && state->cec_addr[i] == addr)
750 			return 0;
751 	}
752 	if (i == ADV7511_MAX_ADDRS) {
753 		i = free_idx;
754 		if (i == ADV7511_MAX_ADDRS)
755 			return -ENXIO;
756 	}
757 	state->cec_addr[i] = addr;
758 	state->cec_valid_addrs |= 1 << i;
759 
760 	switch (i) {
761 	case 0:
762 		/* enable address mask 0 */
763 		adv7511_cec_write_and_or(sd, 0x4b, 0xef, 0x10);
764 		/* set address for mask 0 */
765 		adv7511_cec_write_and_or(sd, 0x4c, 0xf0, addr);
766 		break;
767 	case 1:
768 		/* enable address mask 1 */
769 		adv7511_cec_write_and_or(sd, 0x4b, 0xdf, 0x20);
770 		/* set address for mask 1 */
771 		adv7511_cec_write_and_or(sd, 0x4c, 0x0f, addr << 4);
772 		break;
773 	case 2:
774 		/* enable address mask 2 */
775 		adv7511_cec_write_and_or(sd, 0x4b, 0xbf, 0x40);
776 		/* set address for mask 1 */
777 		adv7511_cec_write_and_or(sd, 0x4d, 0xf0, addr);
778 		break;
779 	}
780 	return 0;
781 }
782 
adv7511_cec_adap_transmit(struct cec_adapter * adap,u8 attempts,u32 signal_free_time,struct cec_msg * msg)783 static int adv7511_cec_adap_transmit(struct cec_adapter *adap, u8 attempts,
784 				     u32 signal_free_time, struct cec_msg *msg)
785 {
786 	struct adv7511_state *state = cec_get_drvdata(adap);
787 	struct v4l2_subdev *sd = &state->sd;
788 	u8 len = msg->len;
789 	unsigned int i;
790 
791 	v4l2_dbg(1, debug, sd, "%s: len %d\n", __func__, len);
792 
793 	if (len > 16) {
794 		v4l2_err(sd, "%s: len exceeded 16 (%d)\n", __func__, len);
795 		return -EINVAL;
796 	}
797 
798 	/*
799 	 * The number of retries is the number of attempts - 1, but retry
800 	 * at least once. It's not clear if a value of 0 is allowed, so
801 	 * let's do at least one retry.
802 	 */
803 	adv7511_cec_write_and_or(sd, 0x12, ~0x70, max(1, attempts - 1) << 4);
804 
805 	/* clear cec tx irq status */
806 	adv7511_wr(sd, 0x97, 0x38);
807 
808 	/* write data */
809 	for (i = 0; i < len; i++)
810 		adv7511_cec_write(sd, i, msg->msg[i]);
811 
812 	/* set length (data + header) */
813 	adv7511_cec_write(sd, 0x10, len);
814 	/* start transmit, enable tx */
815 	adv7511_cec_write(sd, 0x11, 0x01);
816 	return 0;
817 }
818 
adv_cec_tx_raw_status(struct v4l2_subdev * sd,u8 tx_raw_status)819 static void adv_cec_tx_raw_status(struct v4l2_subdev *sd, u8 tx_raw_status)
820 {
821 	struct adv7511_state *state = get_adv7511_state(sd);
822 
823 	if ((adv7511_cec_read(sd, 0x11) & 0x01) == 0) {
824 		v4l2_dbg(1, debug, sd, "%s: tx raw: tx disabled\n", __func__);
825 		return;
826 	}
827 
828 	if (tx_raw_status & 0x10) {
829 		v4l2_dbg(1, debug, sd,
830 			 "%s: tx raw: arbitration lost\n", __func__);
831 		cec_transmit_done(state->cec_adap, CEC_TX_STATUS_ARB_LOST,
832 				  1, 0, 0, 0);
833 		return;
834 	}
835 	if (tx_raw_status & 0x08) {
836 		u8 status;
837 		u8 nack_cnt;
838 		u8 low_drive_cnt;
839 
840 		v4l2_dbg(1, debug, sd, "%s: tx raw: retry failed\n", __func__);
841 		/*
842 		 * We set this status bit since this hardware performs
843 		 * retransmissions.
844 		 */
845 		status = CEC_TX_STATUS_MAX_RETRIES;
846 		nack_cnt = adv7511_cec_read(sd, 0x14) & 0xf;
847 		if (nack_cnt)
848 			status |= CEC_TX_STATUS_NACK;
849 		low_drive_cnt = adv7511_cec_read(sd, 0x14) >> 4;
850 		if (low_drive_cnt)
851 			status |= CEC_TX_STATUS_LOW_DRIVE;
852 		cec_transmit_done(state->cec_adap, status,
853 				  0, nack_cnt, low_drive_cnt, 0);
854 		return;
855 	}
856 	if (tx_raw_status & 0x20) {
857 		v4l2_dbg(1, debug, sd, "%s: tx raw: ready ok\n", __func__);
858 		cec_transmit_done(state->cec_adap, CEC_TX_STATUS_OK, 0, 0, 0, 0);
859 		return;
860 	}
861 }
862 
863 static const struct cec_adap_ops adv7511_cec_adap_ops = {
864 	.adap_enable = adv7511_cec_adap_enable,
865 	.adap_log_addr = adv7511_cec_adap_log_addr,
866 	.adap_transmit = adv7511_cec_adap_transmit,
867 };
868 #endif
869 
870 /* Enable interrupts */
adv7511_set_isr(struct v4l2_subdev * sd,bool enable)871 static void adv7511_set_isr(struct v4l2_subdev *sd, bool enable)
872 {
873 	struct adv7511_state *state = get_adv7511_state(sd);
874 	u8 irqs = MASK_ADV7511_HPD_INT | MASK_ADV7511_MSEN_INT;
875 	u8 irqs_rd;
876 	int retries = 100;
877 
878 	v4l2_dbg(2, debug, sd, "%s: %s\n", __func__, enable ? "enable" : "disable");
879 
880 	if (state->enabled_irq == enable)
881 		return;
882 	state->enabled_irq = enable;
883 
884 	/* The datasheet says that the EDID ready interrupt should be
885 	   disabled if there is no hotplug. */
886 	if (!enable)
887 		irqs = 0;
888 	else if (adv7511_have_hotplug(sd))
889 		irqs |= MASK_ADV7511_EDID_RDY_INT;
890 
891 	/*
892 	 * This i2c write can fail (approx. 1 in 1000 writes). But it
893 	 * is essential that this register is correct, so retry it
894 	 * multiple times.
895 	 *
896 	 * Note that the i2c write does not report an error, but the readback
897 	 * clearly shows the wrong value.
898 	 */
899 	do {
900 		adv7511_wr(sd, 0x94, irqs);
901 		irqs_rd = adv7511_rd(sd, 0x94);
902 	} while (retries-- && irqs_rd != irqs);
903 
904 	if (irqs_rd != irqs)
905 		v4l2_err(sd, "Could not set interrupts: hw failure?\n");
906 
907 	adv7511_wr_and_or(sd, 0x95, 0xc0,
908 			  (state->cec_enabled_adap && enable) ? 0x39 : 0x00);
909 }
910 
911 /* Interrupt handler */
adv7511_isr(struct v4l2_subdev * sd,u32 status,bool * handled)912 static int adv7511_isr(struct v4l2_subdev *sd, u32 status, bool *handled)
913 {
914 	u8 irq_status;
915 	u8 cec_irq;
916 
917 	/* disable interrupts to prevent a race condition */
918 	adv7511_set_isr(sd, false);
919 	irq_status = adv7511_rd(sd, 0x96);
920 	cec_irq = adv7511_rd(sd, 0x97);
921 	/* clear detected interrupts */
922 	adv7511_wr(sd, 0x96, irq_status);
923 	adv7511_wr(sd, 0x97, cec_irq);
924 
925 	v4l2_dbg(1, debug, sd, "%s: irq 0x%x, cec-irq 0x%x\n", __func__,
926 		 irq_status, cec_irq);
927 
928 	if (irq_status & (MASK_ADV7511_HPD_INT | MASK_ADV7511_MSEN_INT))
929 		adv7511_check_monitor_present_status(sd);
930 	if (irq_status & MASK_ADV7511_EDID_RDY_INT)
931 		adv7511_check_edid_status(sd);
932 
933 #if IS_ENABLED(CONFIG_VIDEO_ADV7511_CEC)
934 	if (cec_irq & 0x38)
935 		adv_cec_tx_raw_status(sd, cec_irq);
936 
937 	if (cec_irq & 1) {
938 		struct adv7511_state *state = get_adv7511_state(sd);
939 		struct cec_msg msg;
940 
941 		msg.len = adv7511_cec_read(sd, 0x25) & 0x1f;
942 
943 		v4l2_dbg(1, debug, sd, "%s: cec msg len %d\n", __func__,
944 			 msg.len);
945 
946 		if (msg.len > CEC_MAX_MSG_SIZE)
947 			msg.len = CEC_MAX_MSG_SIZE;
948 
949 		if (msg.len) {
950 			u8 i;
951 
952 			for (i = 0; i < msg.len; i++)
953 				msg.msg[i] = adv7511_cec_read(sd, i + 0x15);
954 
955 			adv7511_cec_write(sd, 0x4a, 0); /* toggle to re-enable rx 1 */
956 			adv7511_cec_write(sd, 0x4a, 1);
957 			cec_received_msg(state->cec_adap, &msg);
958 		}
959 	}
960 #endif
961 
962 	/* enable interrupts */
963 	adv7511_set_isr(sd, true);
964 
965 	if (handled)
966 		*handled = true;
967 	return 0;
968 }
969 
970 static const struct v4l2_subdev_core_ops adv7511_core_ops = {
971 	.log_status = adv7511_log_status,
972 #ifdef CONFIG_VIDEO_ADV_DEBUG
973 	.g_register = adv7511_g_register,
974 	.s_register = adv7511_s_register,
975 #endif
976 	.s_power = adv7511_s_power,
977 	.interrupt_service_routine = adv7511_isr,
978 };
979 
980 /* ------------------------------ VIDEO OPS ------------------------------ */
981 
982 /* Enable/disable adv7511 output */
adv7511_s_stream(struct v4l2_subdev * sd,int enable)983 static int adv7511_s_stream(struct v4l2_subdev *sd, int enable)
984 {
985 	struct adv7511_state *state = get_adv7511_state(sd);
986 
987 	v4l2_dbg(1, debug, sd, "%s: %sable\n", __func__, (enable ? "en" : "dis"));
988 	adv7511_wr_and_or(sd, 0xa1, ~0x3c, (enable ? 0 : 0x3c));
989 	if (enable) {
990 		adv7511_check_monitor_present_status(sd);
991 	} else {
992 		adv7511_s_power(sd, 0);
993 		state->have_monitor = false;
994 	}
995 	return 0;
996 }
997 
adv7511_s_dv_timings(struct v4l2_subdev * sd,struct v4l2_dv_timings * timings)998 static int adv7511_s_dv_timings(struct v4l2_subdev *sd,
999 			       struct v4l2_dv_timings *timings)
1000 {
1001 	struct adv7511_state *state = get_adv7511_state(sd);
1002 	struct v4l2_bt_timings *bt = &timings->bt;
1003 	u32 fps;
1004 
1005 	v4l2_dbg(1, debug, sd, "%s:\n", __func__);
1006 
1007 	/* quick sanity check */
1008 	if (!v4l2_valid_dv_timings(timings, &adv7511_timings_cap, NULL, NULL))
1009 		return -EINVAL;
1010 
1011 	/* Fill the optional fields .standards and .flags in struct v4l2_dv_timings
1012 	   if the format is one of the CEA or DMT timings. */
1013 	v4l2_find_dv_timings_cap(timings, &adv7511_timings_cap, 0, NULL, NULL);
1014 
1015 	/* save timings */
1016 	state->dv_timings = *timings;
1017 
1018 	/* set h/vsync polarities */
1019 	adv7511_wr_and_or(sd, 0x17, 0x9f,
1020 		((bt->polarities & V4L2_DV_VSYNC_POS_POL) ? 0 : 0x40) |
1021 		((bt->polarities & V4L2_DV_HSYNC_POS_POL) ? 0 : 0x20));
1022 
1023 	fps = (u32)bt->pixelclock / (V4L2_DV_BT_FRAME_WIDTH(bt) * V4L2_DV_BT_FRAME_HEIGHT(bt));
1024 	switch (fps) {
1025 	case 24:
1026 		adv7511_wr_and_or(sd, 0xfb, 0xf9, 1 << 1);
1027 		break;
1028 	case 25:
1029 		adv7511_wr_and_or(sd, 0xfb, 0xf9, 2 << 1);
1030 		break;
1031 	case 30:
1032 		adv7511_wr_and_or(sd, 0xfb, 0xf9, 3 << 1);
1033 		break;
1034 	default:
1035 		adv7511_wr_and_or(sd, 0xfb, 0xf9, 0);
1036 		break;
1037 	}
1038 
1039 	/* update quantization range based on new dv_timings */
1040 	adv7511_set_rgb_quantization_mode(sd, state->rgb_quantization_range_ctrl);
1041 
1042 	return 0;
1043 }
1044 
adv7511_g_dv_timings(struct v4l2_subdev * sd,struct v4l2_dv_timings * timings)1045 static int adv7511_g_dv_timings(struct v4l2_subdev *sd,
1046 				struct v4l2_dv_timings *timings)
1047 {
1048 	struct adv7511_state *state = get_adv7511_state(sd);
1049 
1050 	v4l2_dbg(1, debug, sd, "%s:\n", __func__);
1051 
1052 	if (!timings)
1053 		return -EINVAL;
1054 
1055 	*timings = state->dv_timings;
1056 
1057 	return 0;
1058 }
1059 
adv7511_enum_dv_timings(struct v4l2_subdev * sd,struct v4l2_enum_dv_timings * timings)1060 static int adv7511_enum_dv_timings(struct v4l2_subdev *sd,
1061 				   struct v4l2_enum_dv_timings *timings)
1062 {
1063 	if (timings->pad != 0)
1064 		return -EINVAL;
1065 
1066 	return v4l2_enum_dv_timings_cap(timings, &adv7511_timings_cap, NULL, NULL);
1067 }
1068 
adv7511_dv_timings_cap(struct v4l2_subdev * sd,struct v4l2_dv_timings_cap * cap)1069 static int adv7511_dv_timings_cap(struct v4l2_subdev *sd,
1070 				  struct v4l2_dv_timings_cap *cap)
1071 {
1072 	if (cap->pad != 0)
1073 		return -EINVAL;
1074 
1075 	*cap = adv7511_timings_cap;
1076 	return 0;
1077 }
1078 
1079 static const struct v4l2_subdev_video_ops adv7511_video_ops = {
1080 	.s_stream = adv7511_s_stream,
1081 	.s_dv_timings = adv7511_s_dv_timings,
1082 	.g_dv_timings = adv7511_g_dv_timings,
1083 };
1084 
1085 /* ------------------------------ AUDIO OPS ------------------------------ */
adv7511_s_audio_stream(struct v4l2_subdev * sd,int enable)1086 static int adv7511_s_audio_stream(struct v4l2_subdev *sd, int enable)
1087 {
1088 	v4l2_dbg(1, debug, sd, "%s: %sable\n", __func__, (enable ? "en" : "dis"));
1089 
1090 	if (enable)
1091 		adv7511_wr_and_or(sd, 0x4b, 0x3f, 0x80);
1092 	else
1093 		adv7511_wr_and_or(sd, 0x4b, 0x3f, 0x40);
1094 
1095 	return 0;
1096 }
1097 
adv7511_s_clock_freq(struct v4l2_subdev * sd,u32 freq)1098 static int adv7511_s_clock_freq(struct v4l2_subdev *sd, u32 freq)
1099 {
1100 	u32 N;
1101 
1102 	switch (freq) {
1103 	case 32000:  N = 4096;  break;
1104 	case 44100:  N = 6272;  break;
1105 	case 48000:  N = 6144;  break;
1106 	case 88200:  N = 12544; break;
1107 	case 96000:  N = 12288; break;
1108 	case 176400: N = 25088; break;
1109 	case 192000: N = 24576; break;
1110 	default:
1111 		return -EINVAL;
1112 	}
1113 
1114 	/* Set N (used with CTS to regenerate the audio clock) */
1115 	adv7511_wr(sd, 0x01, (N >> 16) & 0xf);
1116 	adv7511_wr(sd, 0x02, (N >> 8) & 0xff);
1117 	adv7511_wr(sd, 0x03, N & 0xff);
1118 
1119 	return 0;
1120 }
1121 
adv7511_s_i2s_clock_freq(struct v4l2_subdev * sd,u32 freq)1122 static int adv7511_s_i2s_clock_freq(struct v4l2_subdev *sd, u32 freq)
1123 {
1124 	u32 i2s_sf;
1125 
1126 	switch (freq) {
1127 	case 32000:  i2s_sf = 0x30; break;
1128 	case 44100:  i2s_sf = 0x00; break;
1129 	case 48000:  i2s_sf = 0x20; break;
1130 	case 88200:  i2s_sf = 0x80; break;
1131 	case 96000:  i2s_sf = 0xa0; break;
1132 	case 176400: i2s_sf = 0xc0; break;
1133 	case 192000: i2s_sf = 0xe0; break;
1134 	default:
1135 		return -EINVAL;
1136 	}
1137 
1138 	/* Set sampling frequency for I2S audio to 48 kHz */
1139 	adv7511_wr_and_or(sd, 0x15, 0xf, i2s_sf);
1140 
1141 	return 0;
1142 }
1143 
adv7511_s_routing(struct v4l2_subdev * sd,u32 input,u32 output,u32 config)1144 static int adv7511_s_routing(struct v4l2_subdev *sd, u32 input, u32 output, u32 config)
1145 {
1146 	/* Only 2 channels in use for application */
1147 	adv7511_wr_and_or(sd, 0x73, 0xf8, 0x1);
1148 	/* Speaker mapping */
1149 	adv7511_wr(sd, 0x76, 0x00);
1150 
1151 	/* 16 bit audio word length */
1152 	adv7511_wr_and_or(sd, 0x14, 0xf0, 0x02);
1153 
1154 	return 0;
1155 }
1156 
1157 static const struct v4l2_subdev_audio_ops adv7511_audio_ops = {
1158 	.s_stream = adv7511_s_audio_stream,
1159 	.s_clock_freq = adv7511_s_clock_freq,
1160 	.s_i2s_clock_freq = adv7511_s_i2s_clock_freq,
1161 	.s_routing = adv7511_s_routing,
1162 };
1163 
1164 /* ---------------------------- PAD OPS ------------------------------------- */
1165 
adv7511_get_edid(struct v4l2_subdev * sd,struct v4l2_edid * edid)1166 static int adv7511_get_edid(struct v4l2_subdev *sd, struct v4l2_edid *edid)
1167 {
1168 	struct adv7511_state *state = get_adv7511_state(sd);
1169 
1170 	memset(edid->reserved, 0, sizeof(edid->reserved));
1171 
1172 	if (edid->pad != 0)
1173 		return -EINVAL;
1174 
1175 	if (edid->start_block == 0 && edid->blocks == 0) {
1176 		edid->blocks = state->edid.blocks;
1177 		return 0;
1178 	}
1179 
1180 	if (state->edid.blocks == 0)
1181 		return -ENODATA;
1182 
1183 	if (edid->start_block >= state->edid.blocks)
1184 		return -EINVAL;
1185 
1186 	if (edid->start_block + edid->blocks > state->edid.blocks)
1187 		edid->blocks = state->edid.blocks - edid->start_block;
1188 
1189 	memcpy(edid->edid, &state->edid.data[edid->start_block * 128],
1190 	       128 * edid->blocks);
1191 
1192 	return 0;
1193 }
1194 
adv7511_enum_mbus_code(struct v4l2_subdev * sd,struct v4l2_subdev_state * sd_state,struct v4l2_subdev_mbus_code_enum * code)1195 static int adv7511_enum_mbus_code(struct v4l2_subdev *sd,
1196 				  struct v4l2_subdev_state *sd_state,
1197 				  struct v4l2_subdev_mbus_code_enum *code)
1198 {
1199 	if (code->pad != 0)
1200 		return -EINVAL;
1201 
1202 	switch (code->index) {
1203 	case 0:
1204 		code->code = MEDIA_BUS_FMT_RGB888_1X24;
1205 		break;
1206 	case 1:
1207 		code->code = MEDIA_BUS_FMT_YUYV8_1X16;
1208 		break;
1209 	case 2:
1210 		code->code = MEDIA_BUS_FMT_UYVY8_1X16;
1211 		break;
1212 	default:
1213 		return -EINVAL;
1214 	}
1215 	return 0;
1216 }
1217 
adv7511_fill_format(struct adv7511_state * state,struct v4l2_mbus_framefmt * format)1218 static void adv7511_fill_format(struct adv7511_state *state,
1219 				struct v4l2_mbus_framefmt *format)
1220 {
1221 	format->width = state->dv_timings.bt.width;
1222 	format->height = state->dv_timings.bt.height;
1223 	format->field = V4L2_FIELD_NONE;
1224 }
1225 
adv7511_get_fmt(struct v4l2_subdev * sd,struct v4l2_subdev_state * sd_state,struct v4l2_subdev_format * format)1226 static int adv7511_get_fmt(struct v4l2_subdev *sd,
1227 			   struct v4l2_subdev_state *sd_state,
1228 			   struct v4l2_subdev_format *format)
1229 {
1230 	struct adv7511_state *state = get_adv7511_state(sd);
1231 
1232 	if (format->pad != 0)
1233 		return -EINVAL;
1234 
1235 	memset(&format->format, 0, sizeof(format->format));
1236 	adv7511_fill_format(state, &format->format);
1237 
1238 	if (format->which == V4L2_SUBDEV_FORMAT_TRY) {
1239 		struct v4l2_mbus_framefmt *fmt;
1240 
1241 		fmt = v4l2_subdev_get_try_format(sd, sd_state, format->pad);
1242 		format->format.code = fmt->code;
1243 		format->format.colorspace = fmt->colorspace;
1244 		format->format.ycbcr_enc = fmt->ycbcr_enc;
1245 		format->format.quantization = fmt->quantization;
1246 		format->format.xfer_func = fmt->xfer_func;
1247 	} else {
1248 		format->format.code = state->fmt_code;
1249 		format->format.colorspace = state->colorspace;
1250 		format->format.ycbcr_enc = state->ycbcr_enc;
1251 		format->format.quantization = state->quantization;
1252 		format->format.xfer_func = state->xfer_func;
1253 	}
1254 
1255 	return 0;
1256 }
1257 
adv7511_set_fmt(struct v4l2_subdev * sd,struct v4l2_subdev_state * sd_state,struct v4l2_subdev_format * format)1258 static int adv7511_set_fmt(struct v4l2_subdev *sd,
1259 			   struct v4l2_subdev_state *sd_state,
1260 			   struct v4l2_subdev_format *format)
1261 {
1262 	struct adv7511_state *state = get_adv7511_state(sd);
1263 	/*
1264 	 * Bitfield namings come the CEA-861-F standard, table 8 "Auxiliary
1265 	 * Video Information (AVI) InfoFrame Format"
1266 	 *
1267 	 * c = Colorimetry
1268 	 * ec = Extended Colorimetry
1269 	 * y = RGB or YCbCr
1270 	 * q = RGB Quantization Range
1271 	 * yq = YCC Quantization Range
1272 	 */
1273 	u8 c = HDMI_COLORIMETRY_NONE;
1274 	u8 ec = HDMI_EXTENDED_COLORIMETRY_XV_YCC_601;
1275 	u8 y = HDMI_COLORSPACE_RGB;
1276 	u8 q = HDMI_QUANTIZATION_RANGE_DEFAULT;
1277 	u8 yq = HDMI_YCC_QUANTIZATION_RANGE_LIMITED;
1278 	u8 itc = state->content_type != V4L2_DV_IT_CONTENT_TYPE_NO_ITC;
1279 	u8 cn = itc ? state->content_type : V4L2_DV_IT_CONTENT_TYPE_GRAPHICS;
1280 
1281 	if (format->pad != 0)
1282 		return -EINVAL;
1283 	switch (format->format.code) {
1284 	case MEDIA_BUS_FMT_UYVY8_1X16:
1285 	case MEDIA_BUS_FMT_YUYV8_1X16:
1286 	case MEDIA_BUS_FMT_RGB888_1X24:
1287 		break;
1288 	default:
1289 		return -EINVAL;
1290 	}
1291 
1292 	adv7511_fill_format(state, &format->format);
1293 	if (format->which == V4L2_SUBDEV_FORMAT_TRY) {
1294 		struct v4l2_mbus_framefmt *fmt;
1295 
1296 		fmt = v4l2_subdev_get_try_format(sd, sd_state, format->pad);
1297 		fmt->code = format->format.code;
1298 		fmt->colorspace = format->format.colorspace;
1299 		fmt->ycbcr_enc = format->format.ycbcr_enc;
1300 		fmt->quantization = format->format.quantization;
1301 		fmt->xfer_func = format->format.xfer_func;
1302 		return 0;
1303 	}
1304 
1305 	switch (format->format.code) {
1306 	case MEDIA_BUS_FMT_UYVY8_1X16:
1307 		adv7511_wr_and_or(sd, 0x15, 0xf0, 0x01);
1308 		adv7511_wr_and_or(sd, 0x16, 0x03, 0xb8);
1309 		y = HDMI_COLORSPACE_YUV422;
1310 		break;
1311 	case MEDIA_BUS_FMT_YUYV8_1X16:
1312 		adv7511_wr_and_or(sd, 0x15, 0xf0, 0x01);
1313 		adv7511_wr_and_or(sd, 0x16, 0x03, 0xbc);
1314 		y = HDMI_COLORSPACE_YUV422;
1315 		break;
1316 	case MEDIA_BUS_FMT_RGB888_1X24:
1317 	default:
1318 		adv7511_wr_and_or(sd, 0x15, 0xf0, 0x00);
1319 		adv7511_wr_and_or(sd, 0x16, 0x03, 0x00);
1320 		break;
1321 	}
1322 	state->fmt_code = format->format.code;
1323 	state->colorspace = format->format.colorspace;
1324 	state->ycbcr_enc = format->format.ycbcr_enc;
1325 	state->quantization = format->format.quantization;
1326 	state->xfer_func = format->format.xfer_func;
1327 
1328 	switch (format->format.colorspace) {
1329 	case V4L2_COLORSPACE_OPRGB:
1330 		c = HDMI_COLORIMETRY_EXTENDED;
1331 		ec = y ? HDMI_EXTENDED_COLORIMETRY_OPYCC_601 :
1332 			 HDMI_EXTENDED_COLORIMETRY_OPRGB;
1333 		break;
1334 	case V4L2_COLORSPACE_SMPTE170M:
1335 		c = y ? HDMI_COLORIMETRY_ITU_601 : HDMI_COLORIMETRY_NONE;
1336 		if (y && format->format.ycbcr_enc == V4L2_YCBCR_ENC_XV601) {
1337 			c = HDMI_COLORIMETRY_EXTENDED;
1338 			ec = HDMI_EXTENDED_COLORIMETRY_XV_YCC_601;
1339 		}
1340 		break;
1341 	case V4L2_COLORSPACE_REC709:
1342 		c = y ? HDMI_COLORIMETRY_ITU_709 : HDMI_COLORIMETRY_NONE;
1343 		if (y && format->format.ycbcr_enc == V4L2_YCBCR_ENC_XV709) {
1344 			c = HDMI_COLORIMETRY_EXTENDED;
1345 			ec = HDMI_EXTENDED_COLORIMETRY_XV_YCC_709;
1346 		}
1347 		break;
1348 	case V4L2_COLORSPACE_SRGB:
1349 		c = y ? HDMI_COLORIMETRY_EXTENDED : HDMI_COLORIMETRY_NONE;
1350 		ec = y ? HDMI_EXTENDED_COLORIMETRY_S_YCC_601 :
1351 			 HDMI_EXTENDED_COLORIMETRY_XV_YCC_601;
1352 		break;
1353 	case V4L2_COLORSPACE_BT2020:
1354 		c = HDMI_COLORIMETRY_EXTENDED;
1355 		if (y && format->format.ycbcr_enc == V4L2_YCBCR_ENC_BT2020_CONST_LUM)
1356 			ec = 5; /* Not yet available in hdmi.h */
1357 		else
1358 			ec = 6; /* Not yet available in hdmi.h */
1359 		break;
1360 	default:
1361 		break;
1362 	}
1363 
1364 	/*
1365 	 * CEA-861-F says that for RGB formats the YCC range must match the
1366 	 * RGB range, although sources should ignore the YCC range.
1367 	 *
1368 	 * The RGB quantization range shouldn't be non-zero if the EDID doesn't
1369 	 * have the Q bit set in the Video Capabilities Data Block, however this
1370 	 * isn't checked at the moment. The assumption is that the application
1371 	 * knows the EDID and can detect this.
1372 	 *
1373 	 * The same is true for the YCC quantization range: non-standard YCC
1374 	 * quantization ranges should only be sent if the EDID has the YQ bit
1375 	 * set in the Video Capabilities Data Block.
1376 	 */
1377 	switch (format->format.quantization) {
1378 	case V4L2_QUANTIZATION_FULL_RANGE:
1379 		q = y ? HDMI_QUANTIZATION_RANGE_DEFAULT :
1380 			HDMI_QUANTIZATION_RANGE_FULL;
1381 		yq = q ? q - 1 : HDMI_YCC_QUANTIZATION_RANGE_FULL;
1382 		break;
1383 	case V4L2_QUANTIZATION_LIM_RANGE:
1384 		q = y ? HDMI_QUANTIZATION_RANGE_DEFAULT :
1385 			HDMI_QUANTIZATION_RANGE_LIMITED;
1386 		yq = q ? q - 1 : HDMI_YCC_QUANTIZATION_RANGE_LIMITED;
1387 		break;
1388 	}
1389 
1390 	adv7511_wr_and_or(sd, 0x4a, 0xbf, 0);
1391 	adv7511_wr_and_or(sd, 0x55, 0x9f, y << 5);
1392 	adv7511_wr_and_or(sd, 0x56, 0x3f, c << 6);
1393 	adv7511_wr_and_or(sd, 0x57, 0x83, (ec << 4) | (q << 2) | (itc << 7));
1394 	adv7511_wr_and_or(sd, 0x59, 0x0f, (yq << 6) | (cn << 4));
1395 	adv7511_wr_and_or(sd, 0x4a, 0xff, 1);
1396 	adv7511_set_rgb_quantization_mode(sd, state->rgb_quantization_range_ctrl);
1397 
1398 	return 0;
1399 }
1400 
1401 static const struct v4l2_subdev_pad_ops adv7511_pad_ops = {
1402 	.get_edid = adv7511_get_edid,
1403 	.enum_mbus_code = adv7511_enum_mbus_code,
1404 	.get_fmt = adv7511_get_fmt,
1405 	.set_fmt = adv7511_set_fmt,
1406 	.enum_dv_timings = adv7511_enum_dv_timings,
1407 	.dv_timings_cap = adv7511_dv_timings_cap,
1408 };
1409 
1410 /* --------------------- SUBDEV OPS --------------------------------------- */
1411 
1412 static const struct v4l2_subdev_ops adv7511_ops = {
1413 	.core  = &adv7511_core_ops,
1414 	.pad  = &adv7511_pad_ops,
1415 	.video = &adv7511_video_ops,
1416 	.audio = &adv7511_audio_ops,
1417 };
1418 
1419 /* ----------------------------------------------------------------------- */
adv7511_dbg_dump_edid(int lvl,int debug,struct v4l2_subdev * sd,int segment,u8 * buf)1420 static void adv7511_dbg_dump_edid(int lvl, int debug, struct v4l2_subdev *sd, int segment, u8 *buf)
1421 {
1422 	if (debug >= lvl) {
1423 		int i, j;
1424 		v4l2_dbg(lvl, debug, sd, "edid segment %d\n", segment);
1425 		for (i = 0; i < 256; i += 16) {
1426 			u8 b[128];
1427 			u8 *bp = b;
1428 			if (i == 128)
1429 				v4l2_dbg(lvl, debug, sd, "\n");
1430 			for (j = i; j < i + 16; j++) {
1431 				sprintf(bp, "0x%02x, ", buf[j]);
1432 				bp += 6;
1433 			}
1434 			bp[0] = '\0';
1435 			v4l2_dbg(lvl, debug, sd, "%s\n", b);
1436 		}
1437 	}
1438 }
1439 
adv7511_notify_no_edid(struct v4l2_subdev * sd)1440 static void adv7511_notify_no_edid(struct v4l2_subdev *sd)
1441 {
1442 	struct adv7511_state *state = get_adv7511_state(sd);
1443 	struct adv7511_edid_detect ed;
1444 
1445 	/* We failed to read the EDID, so send an event for this. */
1446 	ed.present = false;
1447 	ed.segment = adv7511_rd(sd, 0xc4);
1448 	ed.phys_addr = CEC_PHYS_ADDR_INVALID;
1449 	cec_s_phys_addr(state->cec_adap, ed.phys_addr, false);
1450 	v4l2_subdev_notify(sd, ADV7511_EDID_DETECT, (void *)&ed);
1451 	v4l2_ctrl_s_ctrl(state->have_edid0_ctrl, 0x0);
1452 }
1453 
adv7511_edid_handler(struct work_struct * work)1454 static void adv7511_edid_handler(struct work_struct *work)
1455 {
1456 	struct delayed_work *dwork = to_delayed_work(work);
1457 	struct adv7511_state *state = container_of(dwork, struct adv7511_state, edid_handler);
1458 	struct v4l2_subdev *sd = &state->sd;
1459 
1460 	v4l2_dbg(1, debug, sd, "%s:\n", __func__);
1461 
1462 	if (adv7511_check_edid_status(sd)) {
1463 		/* Return if we received the EDID. */
1464 		return;
1465 	}
1466 
1467 	if (adv7511_have_hotplug(sd)) {
1468 		/* We must retry reading the EDID several times, it is possible
1469 		 * that initially the EDID couldn't be read due to i2c errors
1470 		 * (DVI connectors are particularly prone to this problem). */
1471 		if (state->edid.read_retries) {
1472 			state->edid.read_retries--;
1473 			v4l2_dbg(1, debug, sd, "%s: edid read failed\n", __func__);
1474 			state->have_monitor = false;
1475 			adv7511_s_power(sd, false);
1476 			adv7511_s_power(sd, true);
1477 			queue_delayed_work(state->work_queue, &state->edid_handler, EDID_DELAY);
1478 			return;
1479 		}
1480 	}
1481 
1482 	/* We failed to read the EDID, so send an event for this. */
1483 	adv7511_notify_no_edid(sd);
1484 	v4l2_dbg(1, debug, sd, "%s: no edid found\n", __func__);
1485 }
1486 
adv7511_audio_setup(struct v4l2_subdev * sd)1487 static void adv7511_audio_setup(struct v4l2_subdev *sd)
1488 {
1489 	v4l2_dbg(1, debug, sd, "%s\n", __func__);
1490 
1491 	adv7511_s_i2s_clock_freq(sd, 48000);
1492 	adv7511_s_clock_freq(sd, 48000);
1493 	adv7511_s_routing(sd, 0, 0, 0);
1494 }
1495 
1496 /* Configure hdmi transmitter. */
adv7511_setup(struct v4l2_subdev * sd)1497 static void adv7511_setup(struct v4l2_subdev *sd)
1498 {
1499 	struct adv7511_state *state = get_adv7511_state(sd);
1500 	v4l2_dbg(1, debug, sd, "%s\n", __func__);
1501 
1502 	/* Input format: RGB 4:4:4 */
1503 	adv7511_wr_and_or(sd, 0x15, 0xf0, 0x0);
1504 	/* Output format: RGB 4:4:4 */
1505 	adv7511_wr_and_or(sd, 0x16, 0x7f, 0x0);
1506 	/* 1st order interpolation 4:2:2 -> 4:4:4 up conversion, Aspect ratio: 16:9 */
1507 	adv7511_wr_and_or(sd, 0x17, 0xf9, 0x06);
1508 	/* Disable pixel repetition */
1509 	adv7511_wr_and_or(sd, 0x3b, 0x9f, 0x0);
1510 	/* Disable CSC */
1511 	adv7511_wr_and_or(sd, 0x18, 0x7f, 0x0);
1512 	/* Output format: RGB 4:4:4, Active Format Information is valid,
1513 	 * underscanned */
1514 	adv7511_wr_and_or(sd, 0x55, 0x9c, 0x12);
1515 	/* AVI Info frame packet enable, Audio Info frame disable */
1516 	adv7511_wr_and_or(sd, 0x44, 0xe7, 0x10);
1517 	/* Colorimetry, Active format aspect ratio: same as picure. */
1518 	adv7511_wr(sd, 0x56, 0xa8);
1519 	/* No encryption */
1520 	adv7511_wr_and_or(sd, 0xaf, 0xed, 0x0);
1521 
1522 	/* Positive clk edge capture for input video clock */
1523 	adv7511_wr_and_or(sd, 0xba, 0x1f, 0x60);
1524 
1525 	adv7511_audio_setup(sd);
1526 
1527 	v4l2_ctrl_handler_setup(&state->hdl);
1528 }
1529 
adv7511_notify_monitor_detect(struct v4l2_subdev * sd)1530 static void adv7511_notify_monitor_detect(struct v4l2_subdev *sd)
1531 {
1532 	struct adv7511_monitor_detect mdt;
1533 	struct adv7511_state *state = get_adv7511_state(sd);
1534 
1535 	mdt.present = state->have_monitor;
1536 	v4l2_subdev_notify(sd, ADV7511_MONITOR_DETECT, (void *)&mdt);
1537 }
1538 
adv7511_check_monitor_present_status(struct v4l2_subdev * sd)1539 static void adv7511_check_monitor_present_status(struct v4l2_subdev *sd)
1540 {
1541 	struct adv7511_state *state = get_adv7511_state(sd);
1542 	/* read hotplug and rx-sense state */
1543 	u8 status = adv7511_rd(sd, 0x42);
1544 
1545 	v4l2_dbg(1, debug, sd, "%s: status: 0x%x%s%s\n",
1546 			 __func__,
1547 			 status,
1548 			 status & MASK_ADV7511_HPD_DETECT ? ", hotplug" : "",
1549 			 status & MASK_ADV7511_MSEN_DETECT ? ", rx-sense" : "");
1550 
1551 	/* update read only ctrls */
1552 	v4l2_ctrl_s_ctrl(state->hotplug_ctrl, adv7511_have_hotplug(sd) ? 0x1 : 0x0);
1553 	v4l2_ctrl_s_ctrl(state->rx_sense_ctrl, adv7511_have_rx_sense(sd) ? 0x1 : 0x0);
1554 
1555 	if ((status & MASK_ADV7511_HPD_DETECT) && ((status & MASK_ADV7511_MSEN_DETECT) || state->edid.segments)) {
1556 		v4l2_dbg(1, debug, sd, "%s: hotplug and (rx-sense or edid)\n", __func__);
1557 		if (!state->have_monitor) {
1558 			v4l2_dbg(1, debug, sd, "%s: monitor detected\n", __func__);
1559 			state->have_monitor = true;
1560 			adv7511_set_isr(sd, true);
1561 			if (!adv7511_s_power(sd, true)) {
1562 				v4l2_dbg(1, debug, sd, "%s: monitor detected, powerup failed\n", __func__);
1563 				return;
1564 			}
1565 			adv7511_setup(sd);
1566 			adv7511_notify_monitor_detect(sd);
1567 			state->edid.read_retries = EDID_MAX_RETRIES;
1568 			queue_delayed_work(state->work_queue, &state->edid_handler, EDID_DELAY);
1569 		}
1570 	} else if (status & MASK_ADV7511_HPD_DETECT) {
1571 		v4l2_dbg(1, debug, sd, "%s: hotplug detected\n", __func__);
1572 		state->edid.read_retries = EDID_MAX_RETRIES;
1573 		queue_delayed_work(state->work_queue, &state->edid_handler, EDID_DELAY);
1574 	} else if (!(status & MASK_ADV7511_HPD_DETECT)) {
1575 		v4l2_dbg(1, debug, sd, "%s: hotplug not detected\n", __func__);
1576 		if (state->have_monitor) {
1577 			v4l2_dbg(1, debug, sd, "%s: monitor not detected\n", __func__);
1578 			state->have_monitor = false;
1579 			adv7511_notify_monitor_detect(sd);
1580 		}
1581 		adv7511_s_power(sd, false);
1582 		memset(&state->edid, 0, sizeof(struct adv7511_state_edid));
1583 		adv7511_notify_no_edid(sd);
1584 	}
1585 }
1586 
edid_block_verify_crc(u8 * edid_block)1587 static bool edid_block_verify_crc(u8 *edid_block)
1588 {
1589 	u8 sum = 0;
1590 	int i;
1591 
1592 	for (i = 0; i < 128; i++)
1593 		sum += edid_block[i];
1594 	return sum == 0;
1595 }
1596 
edid_verify_crc(struct v4l2_subdev * sd,u32 segment)1597 static bool edid_verify_crc(struct v4l2_subdev *sd, u32 segment)
1598 {
1599 	struct adv7511_state *state = get_adv7511_state(sd);
1600 	u32 blocks = state->edid.blocks;
1601 	u8 *data = state->edid.data;
1602 
1603 	if (!edid_block_verify_crc(&data[segment * 256]))
1604 		return false;
1605 	if ((segment + 1) * 2 <= blocks)
1606 		return edid_block_verify_crc(&data[segment * 256 + 128]);
1607 	return true;
1608 }
1609 
edid_verify_header(struct v4l2_subdev * sd,u32 segment)1610 static bool edid_verify_header(struct v4l2_subdev *sd, u32 segment)
1611 {
1612 	static const u8 hdmi_header[] = {
1613 		0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00
1614 	};
1615 	struct adv7511_state *state = get_adv7511_state(sd);
1616 	u8 *data = state->edid.data;
1617 
1618 	if (segment != 0)
1619 		return true;
1620 	return !memcmp(data, hdmi_header, sizeof(hdmi_header));
1621 }
1622 
adv7511_check_edid_status(struct v4l2_subdev * sd)1623 static bool adv7511_check_edid_status(struct v4l2_subdev *sd)
1624 {
1625 	struct adv7511_state *state = get_adv7511_state(sd);
1626 	u8 edidRdy = adv7511_rd(sd, 0xc5);
1627 
1628 	v4l2_dbg(1, debug, sd, "%s: edid ready (retries: %d)\n",
1629 			 __func__, EDID_MAX_RETRIES - state->edid.read_retries);
1630 
1631 	if (state->edid.complete)
1632 		return true;
1633 
1634 	if (edidRdy & MASK_ADV7511_EDID_RDY) {
1635 		int segment = adv7511_rd(sd, 0xc4);
1636 		struct adv7511_edid_detect ed;
1637 		int err;
1638 
1639 		if (segment >= EDID_MAX_SEGM) {
1640 			v4l2_err(sd, "edid segment number too big\n");
1641 			return false;
1642 		}
1643 		v4l2_dbg(1, debug, sd, "%s: got segment %d\n", __func__, segment);
1644 		err = adv7511_edid_rd(sd, 256, &state->edid.data[segment * 256]);
1645 		if (!err) {
1646 			adv7511_dbg_dump_edid(2, debug, sd, segment, &state->edid.data[segment * 256]);
1647 			if (segment == 0) {
1648 				state->edid.blocks = state->edid.data[0x7e] + 1;
1649 				v4l2_dbg(1, debug, sd, "%s: %d blocks in total\n",
1650 					 __func__, state->edid.blocks);
1651 			}
1652 		}
1653 
1654 		if (err || !edid_verify_crc(sd, segment) || !edid_verify_header(sd, segment)) {
1655 			/* Couldn't read EDID or EDID is invalid. Force retry! */
1656 			if (!err)
1657 				v4l2_err(sd, "%s: edid crc or header error\n", __func__);
1658 			state->have_monitor = false;
1659 			adv7511_s_power(sd, false);
1660 			adv7511_s_power(sd, true);
1661 			return false;
1662 		}
1663 		/* one more segment read ok */
1664 		state->edid.segments = segment + 1;
1665 		v4l2_ctrl_s_ctrl(state->have_edid0_ctrl, 0x1);
1666 		if (((state->edid.data[0x7e] >> 1) + 1) > state->edid.segments) {
1667 			/* Request next EDID segment */
1668 			v4l2_dbg(1, debug, sd, "%s: request segment %d\n", __func__, state->edid.segments);
1669 			adv7511_wr(sd, 0xc9, 0xf);
1670 			adv7511_wr(sd, 0xc4, state->edid.segments);
1671 			state->edid.read_retries = EDID_MAX_RETRIES;
1672 			queue_delayed_work(state->work_queue, &state->edid_handler, EDID_DELAY);
1673 			return false;
1674 		}
1675 
1676 		v4l2_dbg(1, debug, sd, "%s: edid complete with %d segment(s)\n", __func__, state->edid.segments);
1677 		state->edid.complete = true;
1678 		ed.phys_addr = cec_get_edid_phys_addr(state->edid.data,
1679 						      state->edid.segments * 256,
1680 						      NULL);
1681 		/* report when we have all segments
1682 		   but report only for segment 0
1683 		 */
1684 		ed.present = true;
1685 		ed.segment = 0;
1686 		state->edid_detect_counter++;
1687 		cec_s_phys_addr(state->cec_adap, ed.phys_addr, false);
1688 		v4l2_subdev_notify(sd, ADV7511_EDID_DETECT, (void *)&ed);
1689 		return ed.present;
1690 	}
1691 
1692 	return false;
1693 }
1694 
adv7511_registered(struct v4l2_subdev * sd)1695 static int adv7511_registered(struct v4l2_subdev *sd)
1696 {
1697 	struct adv7511_state *state = get_adv7511_state(sd);
1698 	struct i2c_client *client = v4l2_get_subdevdata(sd);
1699 	int err;
1700 
1701 	err = cec_register_adapter(state->cec_adap, &client->dev);
1702 	if (err)
1703 		cec_delete_adapter(state->cec_adap);
1704 	return err;
1705 }
1706 
adv7511_unregistered(struct v4l2_subdev * sd)1707 static void adv7511_unregistered(struct v4l2_subdev *sd)
1708 {
1709 	struct adv7511_state *state = get_adv7511_state(sd);
1710 
1711 	cec_unregister_adapter(state->cec_adap);
1712 }
1713 
1714 static const struct v4l2_subdev_internal_ops adv7511_int_ops = {
1715 	.registered = adv7511_registered,
1716 	.unregistered = adv7511_unregistered,
1717 };
1718 
1719 /* ----------------------------------------------------------------------- */
1720 /* Setup ADV7511 */
adv7511_init_setup(struct v4l2_subdev * sd)1721 static void adv7511_init_setup(struct v4l2_subdev *sd)
1722 {
1723 	struct adv7511_state *state = get_adv7511_state(sd);
1724 	struct adv7511_state_edid *edid = &state->edid;
1725 	u32 cec_clk = state->pdata.cec_clk;
1726 	u8 ratio;
1727 
1728 	v4l2_dbg(1, debug, sd, "%s\n", __func__);
1729 
1730 	/* clear all interrupts */
1731 	adv7511_wr(sd, 0x96, 0xff);
1732 	adv7511_wr(sd, 0x97, 0xff);
1733 	/*
1734 	 * Stop HPD from resetting a lot of registers.
1735 	 * It might leave the chip in a partly un-initialized state,
1736 	 * in particular with regards to hotplug bounces.
1737 	 */
1738 	adv7511_wr_and_or(sd, 0xd6, 0x3f, 0xc0);
1739 	memset(edid, 0, sizeof(struct adv7511_state_edid));
1740 	state->have_monitor = false;
1741 	adv7511_set_isr(sd, false);
1742 	adv7511_s_stream(sd, false);
1743 	adv7511_s_audio_stream(sd, false);
1744 
1745 	if (state->i2c_cec == NULL)
1746 		return;
1747 
1748 	v4l2_dbg(1, debug, sd, "%s: cec_clk %d\n", __func__, cec_clk);
1749 
1750 	/* cec soft reset */
1751 	adv7511_cec_write(sd, 0x50, 0x01);
1752 	adv7511_cec_write(sd, 0x50, 0x00);
1753 
1754 	/* legacy mode */
1755 	adv7511_cec_write(sd, 0x4a, 0x00);
1756 	adv7511_cec_write(sd, 0x4a, 0x07);
1757 
1758 	if (cec_clk % 750000 != 0)
1759 		v4l2_err(sd, "%s: cec_clk %d, not multiple of 750 Khz\n",
1760 			 __func__, cec_clk);
1761 
1762 	ratio = (cec_clk / 750000) - 1;
1763 	adv7511_cec_write(sd, 0x4e, ratio << 2);
1764 }
1765 
adv7511_probe(struct i2c_client * client)1766 static int adv7511_probe(struct i2c_client *client)
1767 {
1768 	struct adv7511_state *state;
1769 	struct adv7511_platform_data *pdata = client->dev.platform_data;
1770 	struct v4l2_ctrl_handler *hdl;
1771 	struct v4l2_subdev *sd;
1772 	u8 chip_id[2];
1773 	int err = -EIO;
1774 
1775 	/* Check if the adapter supports the needed features */
1776 	if (!i2c_check_functionality(client->adapter, I2C_FUNC_SMBUS_BYTE_DATA))
1777 		return -EIO;
1778 
1779 	state = devm_kzalloc(&client->dev, sizeof(struct adv7511_state), GFP_KERNEL);
1780 	if (!state)
1781 		return -ENOMEM;
1782 
1783 	/* Platform data */
1784 	if (!pdata) {
1785 		v4l_err(client, "No platform data!\n");
1786 		return -ENODEV;
1787 	}
1788 	memcpy(&state->pdata, pdata, sizeof(state->pdata));
1789 	state->fmt_code = MEDIA_BUS_FMT_RGB888_1X24;
1790 	state->colorspace = V4L2_COLORSPACE_SRGB;
1791 
1792 	sd = &state->sd;
1793 
1794 	v4l2_dbg(1, debug, sd, "detecting adv7511 client on address 0x%x\n",
1795 			 client->addr << 1);
1796 
1797 	v4l2_i2c_subdev_init(sd, client, &adv7511_ops);
1798 	sd->internal_ops = &adv7511_int_ops;
1799 
1800 	hdl = &state->hdl;
1801 	v4l2_ctrl_handler_init(hdl, 10);
1802 	/* add in ascending ID order */
1803 	state->hdmi_mode_ctrl = v4l2_ctrl_new_std_menu(hdl, &adv7511_ctrl_ops,
1804 			V4L2_CID_DV_TX_MODE, V4L2_DV_TX_MODE_HDMI,
1805 			0, V4L2_DV_TX_MODE_DVI_D);
1806 	state->hotplug_ctrl = v4l2_ctrl_new_std(hdl, NULL,
1807 			V4L2_CID_DV_TX_HOTPLUG, 0, 1, 0, 0);
1808 	state->rx_sense_ctrl = v4l2_ctrl_new_std(hdl, NULL,
1809 			V4L2_CID_DV_TX_RXSENSE, 0, 1, 0, 0);
1810 	state->have_edid0_ctrl = v4l2_ctrl_new_std(hdl, NULL,
1811 			V4L2_CID_DV_TX_EDID_PRESENT, 0, 1, 0, 0);
1812 	state->rgb_quantization_range_ctrl =
1813 		v4l2_ctrl_new_std_menu(hdl, &adv7511_ctrl_ops,
1814 			V4L2_CID_DV_TX_RGB_RANGE, V4L2_DV_RGB_RANGE_FULL,
1815 			0, V4L2_DV_RGB_RANGE_AUTO);
1816 	state->content_type_ctrl =
1817 		v4l2_ctrl_new_std_menu(hdl, &adv7511_ctrl_ops,
1818 			V4L2_CID_DV_TX_IT_CONTENT_TYPE, V4L2_DV_IT_CONTENT_TYPE_NO_ITC,
1819 			0, V4L2_DV_IT_CONTENT_TYPE_NO_ITC);
1820 	sd->ctrl_handler = hdl;
1821 	if (hdl->error) {
1822 		err = hdl->error;
1823 		goto err_hdl;
1824 	}
1825 	state->pad.flags = MEDIA_PAD_FL_SINK;
1826 	sd->entity.function = MEDIA_ENT_F_DV_ENCODER;
1827 	err = media_entity_pads_init(&sd->entity, 1, &state->pad);
1828 	if (err)
1829 		goto err_hdl;
1830 
1831 	/* EDID and CEC i2c addr */
1832 	state->i2c_edid_addr = state->pdata.i2c_edid << 1;
1833 	state->i2c_cec_addr = state->pdata.i2c_cec << 1;
1834 	state->i2c_pktmem_addr = state->pdata.i2c_pktmem << 1;
1835 
1836 	state->chip_revision = adv7511_rd(sd, 0x0);
1837 	chip_id[0] = adv7511_rd(sd, 0xf5);
1838 	chip_id[1] = adv7511_rd(sd, 0xf6);
1839 	if (chip_id[0] != 0x75 || chip_id[1] != 0x11) {
1840 		v4l2_err(sd, "chip_id != 0x7511, read 0x%02x%02x\n", chip_id[0],
1841 			 chip_id[1]);
1842 		err = -EIO;
1843 		goto err_entity;
1844 	}
1845 
1846 	state->i2c_edid = i2c_new_dummy_device(client->adapter,
1847 					state->i2c_edid_addr >> 1);
1848 	if (IS_ERR(state->i2c_edid)) {
1849 		v4l2_err(sd, "failed to register edid i2c client\n");
1850 		err = PTR_ERR(state->i2c_edid);
1851 		goto err_entity;
1852 	}
1853 
1854 	adv7511_wr(sd, 0xe1, state->i2c_cec_addr);
1855 	if (state->pdata.cec_clk < 3000000 ||
1856 	    state->pdata.cec_clk > 100000000) {
1857 		v4l2_err(sd, "%s: cec_clk %u outside range, disabling cec\n",
1858 				__func__, state->pdata.cec_clk);
1859 		state->pdata.cec_clk = 0;
1860 	}
1861 
1862 	if (state->pdata.cec_clk) {
1863 		state->i2c_cec = i2c_new_dummy_device(client->adapter,
1864 					       state->i2c_cec_addr >> 1);
1865 		if (IS_ERR(state->i2c_cec)) {
1866 			v4l2_err(sd, "failed to register cec i2c client\n");
1867 			err = PTR_ERR(state->i2c_cec);
1868 			goto err_unreg_edid;
1869 		}
1870 		adv7511_wr(sd, 0xe2, 0x00); /* power up cec section */
1871 	} else {
1872 		adv7511_wr(sd, 0xe2, 0x01); /* power down cec section */
1873 	}
1874 
1875 	state->i2c_pktmem = i2c_new_dummy_device(client->adapter, state->i2c_pktmem_addr >> 1);
1876 	if (IS_ERR(state->i2c_pktmem)) {
1877 		v4l2_err(sd, "failed to register pktmem i2c client\n");
1878 		err = PTR_ERR(state->i2c_pktmem);
1879 		goto err_unreg_cec;
1880 	}
1881 
1882 	state->work_queue = create_singlethread_workqueue(sd->name);
1883 	if (state->work_queue == NULL) {
1884 		v4l2_err(sd, "could not create workqueue\n");
1885 		err = -ENOMEM;
1886 		goto err_unreg_pktmem;
1887 	}
1888 
1889 	INIT_DELAYED_WORK(&state->edid_handler, adv7511_edid_handler);
1890 
1891 	adv7511_init_setup(sd);
1892 
1893 #if IS_ENABLED(CONFIG_VIDEO_ADV7511_CEC)
1894 	state->cec_adap = cec_allocate_adapter(&adv7511_cec_adap_ops,
1895 		state, dev_name(&client->dev), CEC_CAP_DEFAULTS,
1896 		ADV7511_MAX_ADDRS);
1897 	err = PTR_ERR_OR_ZERO(state->cec_adap);
1898 	if (err) {
1899 		destroy_workqueue(state->work_queue);
1900 		goto err_unreg_pktmem;
1901 	}
1902 #endif
1903 
1904 	adv7511_set_isr(sd, true);
1905 	adv7511_check_monitor_present_status(sd);
1906 
1907 	v4l2_info(sd, "%s found @ 0x%x (%s)\n", client->name,
1908 			  client->addr << 1, client->adapter->name);
1909 	return 0;
1910 
1911 err_unreg_pktmem:
1912 	i2c_unregister_device(state->i2c_pktmem);
1913 err_unreg_cec:
1914 	i2c_unregister_device(state->i2c_cec);
1915 err_unreg_edid:
1916 	i2c_unregister_device(state->i2c_edid);
1917 err_entity:
1918 	media_entity_cleanup(&sd->entity);
1919 err_hdl:
1920 	v4l2_ctrl_handler_free(&state->hdl);
1921 	return err;
1922 }
1923 
1924 /* ----------------------------------------------------------------------- */
1925 
adv7511_remove(struct i2c_client * client)1926 static void adv7511_remove(struct i2c_client *client)
1927 {
1928 	struct v4l2_subdev *sd = i2c_get_clientdata(client);
1929 	struct adv7511_state *state = get_adv7511_state(sd);
1930 
1931 	state->chip_revision = -1;
1932 
1933 	v4l2_dbg(1, debug, sd, "%s removed @ 0x%x (%s)\n", client->name,
1934 		 client->addr << 1, client->adapter->name);
1935 
1936 	adv7511_set_isr(sd, false);
1937 	adv7511_init_setup(sd);
1938 	cancel_delayed_work_sync(&state->edid_handler);
1939 	i2c_unregister_device(state->i2c_edid);
1940 	i2c_unregister_device(state->i2c_cec);
1941 	i2c_unregister_device(state->i2c_pktmem);
1942 	destroy_workqueue(state->work_queue);
1943 	v4l2_device_unregister_subdev(sd);
1944 	media_entity_cleanup(&sd->entity);
1945 	v4l2_ctrl_handler_free(sd->ctrl_handler);
1946 }
1947 
1948 /* ----------------------------------------------------------------------- */
1949 
1950 static const struct i2c_device_id adv7511_id[] = {
1951 	{ "adv7511-v4l2", 0 },
1952 	{ }
1953 };
1954 MODULE_DEVICE_TABLE(i2c, adv7511_id);
1955 
1956 static struct i2c_driver adv7511_driver = {
1957 	.driver = {
1958 		.name = "adv7511-v4l2",
1959 	},
1960 	.probe = adv7511_probe,
1961 	.remove = adv7511_remove,
1962 	.id_table = adv7511_id,
1963 };
1964 
1965 module_i2c_driver(adv7511_driver);
1966