xref: /openbmc/linux/drivers/media/tuners/xc5000.c (revision e65e175b07bef5974045cc42238de99057669ca7)
1 // SPDX-License-Identifier: GPL-2.0-or-later
2 /*
3  *  Driver for Xceive XC5000 "QAM/8VSB single chip tuner"
4  *
5  *  Copyright (c) 2007 Xceive Corporation
6  *  Copyright (c) 2007 Steven Toth <stoth@linuxtv.org>
7  *  Copyright (c) 2009 Devin Heitmueller <dheitmueller@kernellabs.com>
8  */
9 
10 #include <linux/module.h>
11 #include <linux/moduleparam.h>
12 #include <linux/videodev2.h>
13 #include <linux/delay.h>
14 #include <linux/workqueue.h>
15 #include <linux/dvb/frontend.h>
16 #include <linux/i2c.h>
17 
18 #include <media/dvb_frontend.h>
19 
20 #include "xc5000.h"
21 #include "tuner-i2c.h"
22 
23 static int debug;
24 module_param(debug, int, 0644);
25 MODULE_PARM_DESC(debug, "Turn on/off debugging (default:off).");
26 
27 static int no_poweroff;
28 module_param(no_poweroff, int, 0644);
29 MODULE_PARM_DESC(no_poweroff, "0 (default) powers device off when not used.\n"
30 	"\t\t1 keep device energized and with tuner ready all the times.\n"
31 	"\t\tFaster, but consumes more power and keeps the device hotter");
32 
33 static DEFINE_MUTEX(xc5000_list_mutex);
34 static LIST_HEAD(hybrid_tuner_instance_list);
35 
36 #define dprintk(level, fmt, arg...) if (debug >= level) \
37 	printk(KERN_INFO "%s: " fmt, "xc5000", ## arg)
38 
39 struct xc5000_priv {
40 	struct tuner_i2c_props i2c_props;
41 	struct list_head hybrid_tuner_instance_list;
42 
43 	u32 if_khz;
44 	u16 xtal_khz;
45 	u32 freq_hz, freq_offset;
46 	u32 bandwidth;
47 	u8  video_standard;
48 	unsigned int mode;
49 	u8  rf_mode;
50 	u8  radio_input;
51 	u16  output_amp;
52 
53 	int chip_id;
54 	u16 pll_register_no;
55 	u8 init_status_supported;
56 	u8 fw_checksum_supported;
57 
58 	struct dvb_frontend *fe;
59 	struct delayed_work timer_sleep;
60 
61 	const struct firmware   *firmware;
62 };
63 
64 /* Misc Defines */
65 #define MAX_TV_STANDARD			24
66 #define XC_MAX_I2C_WRITE_LENGTH		64
67 
68 /* Time to suspend after the .sleep callback is called */
69 #define XC5000_SLEEP_TIME		5000 /* ms */
70 
71 /* Signal Types */
72 #define XC_RF_MODE_AIR			0
73 #define XC_RF_MODE_CABLE		1
74 
75 /* Product id */
76 #define XC_PRODUCT_ID_FW_NOT_LOADED	0x2000
77 #define XC_PRODUCT_ID_FW_LOADED	0x1388
78 
79 /* Registers */
80 #define XREG_INIT         0x00
81 #define XREG_VIDEO_MODE   0x01
82 #define XREG_AUDIO_MODE   0x02
83 #define XREG_RF_FREQ      0x03
84 #define XREG_D_CODE       0x04
85 #define XREG_IF_OUT       0x05
86 #define XREG_SEEK_MODE    0x07
87 #define XREG_POWER_DOWN   0x0A /* Obsolete */
88 /* Set the output amplitude - SIF for analog, DTVP/DTVN for digital */
89 #define XREG_OUTPUT_AMP   0x0B
90 #define XREG_SIGNALSOURCE 0x0D /* 0=Air, 1=Cable */
91 #define XREG_SMOOTHEDCVBS 0x0E
92 #define XREG_XTALFREQ     0x0F
93 #define XREG_FINERFREQ    0x10
94 #define XREG_DDIMODE      0x11
95 
96 #define XREG_ADC_ENV      0x00
97 #define XREG_QUALITY      0x01
98 #define XREG_FRAME_LINES  0x02
99 #define XREG_HSYNC_FREQ   0x03
100 #define XREG_LOCK         0x04
101 #define XREG_FREQ_ERROR   0x05
102 #define XREG_SNR          0x06
103 #define XREG_VERSION      0x07
104 #define XREG_PRODUCT_ID   0x08
105 #define XREG_BUSY         0x09
106 #define XREG_BUILD        0x0D
107 #define XREG_TOTALGAIN    0x0F
108 #define XREG_FW_CHECKSUM  0x12
109 #define XREG_INIT_STATUS  0x13
110 
111 /*
112    Basic firmware description. This will remain with
113    the driver for documentation purposes.
114 
115    This represents an I2C firmware file encoded as a
116    string of unsigned char. Format is as follows:
117 
118    char[0  ]=len0_MSB  -> len = len_MSB * 256 + len_LSB
119    char[1  ]=len0_LSB  -> length of first write transaction
120    char[2  ]=data0 -> first byte to be sent
121    char[3  ]=data1
122    char[4  ]=data2
123    char[   ]=...
124    char[M  ]=dataN  -> last byte to be sent
125    char[M+1]=len1_MSB  -> len = len_MSB * 256 + len_LSB
126    char[M+2]=len1_LSB  -> length of second write transaction
127    char[M+3]=data0
128    char[M+4]=data1
129    ...
130    etc.
131 
132    The [len] value should be interpreted as follows:
133 
134    len= len_MSB _ len_LSB
135    len=1111_1111_1111_1111   : End of I2C_SEQUENCE
136    len=0000_0000_0000_0000   : Reset command: Do hardware reset
137    len=0NNN_NNNN_NNNN_NNNN   : Normal transaction: number of bytes = {1:32767)
138    len=1WWW_WWWW_WWWW_WWWW   : Wait command: wait for {1:32767} ms
139 
140    For the RESET and WAIT commands, the two following bytes will contain
141    immediately the length of the following transaction.
142 
143 */
144 struct XC_TV_STANDARD {
145 	char *name;
146 	u16 audio_mode;
147 	u16 video_mode;
148 };
149 
150 /* Tuner standards */
151 #define MN_NTSC_PAL_BTSC	0
152 #define MN_NTSC_PAL_A2		1
153 #define MN_NTSC_PAL_EIAJ	2
154 #define MN_NTSC_PAL_MONO	3
155 #define BG_PAL_A2		4
156 #define BG_PAL_NICAM		5
157 #define BG_PAL_MONO		6
158 #define I_PAL_NICAM		7
159 #define I_PAL_NICAM_MONO	8
160 #define DK_PAL_A2		9
161 #define DK_PAL_NICAM		10
162 #define DK_PAL_MONO		11
163 #define DK_SECAM_A2DK1		12
164 #define DK_SECAM_A2LDK3		13
165 #define DK_SECAM_A2MONO		14
166 #define L_SECAM_NICAM		15
167 #define LC_SECAM_NICAM		16
168 #define DTV6			17
169 #define DTV8			18
170 #define DTV7_8			19
171 #define DTV7			20
172 #define FM_RADIO_INPUT2		21
173 #define FM_RADIO_INPUT1		22
174 #define FM_RADIO_INPUT1_MONO	23
175 
176 static struct XC_TV_STANDARD xc5000_standard[MAX_TV_STANDARD] = {
177 	{"M/N-NTSC/PAL-BTSC", 0x0400, 0x8020},
178 	{"M/N-NTSC/PAL-A2",   0x0600, 0x8020},
179 	{"M/N-NTSC/PAL-EIAJ", 0x0440, 0x8020},
180 	{"M/N-NTSC/PAL-Mono", 0x0478, 0x8020},
181 	{"B/G-PAL-A2",        0x0A00, 0x8049},
182 	{"B/G-PAL-NICAM",     0x0C04, 0x8049},
183 	{"B/G-PAL-MONO",      0x0878, 0x8059},
184 	{"I-PAL-NICAM",       0x1080, 0x8009},
185 	{"I-PAL-NICAM-MONO",  0x0E78, 0x8009},
186 	{"D/K-PAL-A2",        0x1600, 0x8009},
187 	{"D/K-PAL-NICAM",     0x0E80, 0x8009},
188 	{"D/K-PAL-MONO",      0x1478, 0x8009},
189 	{"D/K-SECAM-A2 DK1",  0x1200, 0x8009},
190 	{"D/K-SECAM-A2 L/DK3", 0x0E00, 0x8009},
191 	{"D/K-SECAM-A2 MONO", 0x1478, 0x8009},
192 	{"L-SECAM-NICAM",     0x8E82, 0x0009},
193 	{"L'-SECAM-NICAM",    0x8E82, 0x4009},
194 	{"DTV6",              0x00C0, 0x8002},
195 	{"DTV8",              0x00C0, 0x800B},
196 	{"DTV7/8",            0x00C0, 0x801B},
197 	{"DTV7",              0x00C0, 0x8007},
198 	{"FM Radio-INPUT2",   0x9802, 0x9002},
199 	{"FM Radio-INPUT1",   0x0208, 0x9002},
200 	{"FM Radio-INPUT1_MONO", 0x0278, 0x9002}
201 };
202 
203 
204 struct xc5000_fw_cfg {
205 	char *name;
206 	u16 size;
207 	u16 pll_reg;
208 	u8 init_status_supported;
209 	u8 fw_checksum_supported;
210 };
211 
212 #define XC5000A_FIRMWARE "dvb-fe-xc5000-1.6.114.fw"
213 static const struct xc5000_fw_cfg xc5000a_1_6_114 = {
214 	.name = XC5000A_FIRMWARE,
215 	.size = 12401,
216 	.pll_reg = 0x806c,
217 };
218 
219 #define XC5000C_FIRMWARE "dvb-fe-xc5000c-4.1.30.7.fw"
220 static const struct xc5000_fw_cfg xc5000c_41_024_5 = {
221 	.name = XC5000C_FIRMWARE,
222 	.size = 16497,
223 	.pll_reg = 0x13,
224 	.init_status_supported = 1,
225 	.fw_checksum_supported = 1,
226 };
227 
228 static inline const struct xc5000_fw_cfg *xc5000_assign_firmware(int chip_id)
229 {
230 	switch (chip_id) {
231 	default:
232 	case XC5000A:
233 		return &xc5000a_1_6_114;
234 	case XC5000C:
235 		return &xc5000c_41_024_5;
236 	}
237 }
238 
239 static int xc_load_fw_and_init_tuner(struct dvb_frontend *fe, int force);
240 static int xc5000_is_firmware_loaded(struct dvb_frontend *fe);
241 static int xc5000_readreg(struct xc5000_priv *priv, u16 reg, u16 *val);
242 static int xc5000_tuner_reset(struct dvb_frontend *fe);
243 
244 static int xc_send_i2c_data(struct xc5000_priv *priv, u8 *buf, int len)
245 {
246 	struct i2c_msg msg = { .addr = priv->i2c_props.addr,
247 			       .flags = 0, .buf = buf, .len = len };
248 
249 	if (i2c_transfer(priv->i2c_props.adap, &msg, 1) != 1) {
250 		printk(KERN_ERR "xc5000: I2C write failed (len=%i)\n", len);
251 		return -EREMOTEIO;
252 	}
253 	return 0;
254 }
255 
256 #if 0
257 /* This routine is never used because the only time we read data from the
258    i2c bus is when we read registers, and we want that to be an atomic i2c
259    transaction in case we are on a multi-master bus */
260 static int xc_read_i2c_data(struct xc5000_priv *priv, u8 *buf, int len)
261 {
262 	struct i2c_msg msg = { .addr = priv->i2c_props.addr,
263 		.flags = I2C_M_RD, .buf = buf, .len = len };
264 
265 	if (i2c_transfer(priv->i2c_props.adap, &msg, 1) != 1) {
266 		printk(KERN_ERR "xc5000 I2C read failed (len=%i)\n", len);
267 		return -EREMOTEIO;
268 	}
269 	return 0;
270 }
271 #endif
272 
273 static int xc5000_readreg(struct xc5000_priv *priv, u16 reg, u16 *val)
274 {
275 	u8 buf[2] = { reg >> 8, reg & 0xff };
276 	u8 bval[2] = { 0, 0 };
277 	struct i2c_msg msg[2] = {
278 		{ .addr = priv->i2c_props.addr,
279 			.flags = 0, .buf = &buf[0], .len = 2 },
280 		{ .addr = priv->i2c_props.addr,
281 			.flags = I2C_M_RD, .buf = &bval[0], .len = 2 },
282 	};
283 
284 	if (i2c_transfer(priv->i2c_props.adap, msg, 2) != 2) {
285 		printk(KERN_WARNING "xc5000: I2C read failed\n");
286 		return -EREMOTEIO;
287 	}
288 
289 	*val = (bval[0] << 8) | bval[1];
290 	return 0;
291 }
292 
293 static int xc5000_tuner_reset(struct dvb_frontend *fe)
294 {
295 	struct xc5000_priv *priv = fe->tuner_priv;
296 	int ret;
297 
298 	dprintk(1, "%s()\n", __func__);
299 
300 	if (fe->callback) {
301 		ret = fe->callback(((fe->dvb) && (fe->dvb->priv)) ?
302 					   fe->dvb->priv :
303 					   priv->i2c_props.adap->algo_data,
304 					   DVB_FRONTEND_COMPONENT_TUNER,
305 					   XC5000_TUNER_RESET, 0);
306 		if (ret) {
307 			printk(KERN_ERR "xc5000: reset failed\n");
308 			return ret;
309 		}
310 	} else {
311 		printk(KERN_ERR "xc5000: no tuner reset callback function, fatal\n");
312 		return -EINVAL;
313 	}
314 	return 0;
315 }
316 
317 static int xc_write_reg(struct xc5000_priv *priv, u16 reg_addr, u16 i2c_data)
318 {
319 	u8 buf[4];
320 	int watch_dog_timer = 100;
321 	int result;
322 
323 	buf[0] = (reg_addr >> 8) & 0xFF;
324 	buf[1] = reg_addr & 0xFF;
325 	buf[2] = (i2c_data >> 8) & 0xFF;
326 	buf[3] = i2c_data & 0xFF;
327 	result = xc_send_i2c_data(priv, buf, 4);
328 	if (result == 0) {
329 		/* wait for busy flag to clear */
330 		while ((watch_dog_timer > 0) && (result == 0)) {
331 			result = xc5000_readreg(priv, XREG_BUSY, (u16 *)buf);
332 			if (result == 0) {
333 				if ((buf[0] == 0) && (buf[1] == 0)) {
334 					/* busy flag cleared */
335 					break;
336 				} else {
337 					msleep(5); /* wait 5 ms */
338 					watch_dog_timer--;
339 				}
340 			}
341 		}
342 	}
343 	if (watch_dog_timer <= 0)
344 		result = -EREMOTEIO;
345 
346 	return result;
347 }
348 
349 static int xc_load_i2c_sequence(struct dvb_frontend *fe, const u8 *i2c_sequence)
350 {
351 	struct xc5000_priv *priv = fe->tuner_priv;
352 
353 	int i, nbytes_to_send, result;
354 	unsigned int len, pos, index;
355 	u8 buf[XC_MAX_I2C_WRITE_LENGTH];
356 
357 	index = 0;
358 	while ((i2c_sequence[index] != 0xFF) ||
359 		(i2c_sequence[index + 1] != 0xFF)) {
360 		len = i2c_sequence[index] * 256 + i2c_sequence[index+1];
361 		if (len == 0x0000) {
362 			/* RESET command */
363 			result = xc5000_tuner_reset(fe);
364 			index += 2;
365 			if (result != 0)
366 				return result;
367 		} else if (len & 0x8000) {
368 			/* WAIT command */
369 			msleep(len & 0x7FFF);
370 			index += 2;
371 		} else {
372 			/* Send i2c data whilst ensuring individual transactions
373 			 * do not exceed XC_MAX_I2C_WRITE_LENGTH bytes.
374 			 */
375 			index += 2;
376 			buf[0] = i2c_sequence[index];
377 			buf[1] = i2c_sequence[index + 1];
378 			pos = 2;
379 			while (pos < len) {
380 				if ((len - pos) > XC_MAX_I2C_WRITE_LENGTH - 2)
381 					nbytes_to_send =
382 						XC_MAX_I2C_WRITE_LENGTH;
383 				else
384 					nbytes_to_send = (len - pos + 2);
385 				for (i = 2; i < nbytes_to_send; i++) {
386 					buf[i] = i2c_sequence[index + pos +
387 						i - 2];
388 				}
389 				result = xc_send_i2c_data(priv, buf,
390 					nbytes_to_send);
391 
392 				if (result != 0)
393 					return result;
394 
395 				pos += nbytes_to_send - 2;
396 			}
397 			index += len;
398 		}
399 	}
400 	return 0;
401 }
402 
403 static int xc_initialize(struct xc5000_priv *priv)
404 {
405 	dprintk(1, "%s()\n", __func__);
406 	return xc_write_reg(priv, XREG_INIT, 0);
407 }
408 
409 static int xc_set_tv_standard(struct xc5000_priv *priv,
410 	u16 video_mode, u16 audio_mode, u8 radio_mode)
411 {
412 	int ret;
413 	dprintk(1, "%s(0x%04x,0x%04x)\n", __func__, video_mode, audio_mode);
414 	if (radio_mode) {
415 		dprintk(1, "%s() Standard = %s\n",
416 			__func__,
417 			xc5000_standard[radio_mode].name);
418 	} else {
419 		dprintk(1, "%s() Standard = %s\n",
420 			__func__,
421 			xc5000_standard[priv->video_standard].name);
422 	}
423 
424 	ret = xc_write_reg(priv, XREG_VIDEO_MODE, video_mode);
425 	if (ret == 0)
426 		ret = xc_write_reg(priv, XREG_AUDIO_MODE, audio_mode);
427 
428 	return ret;
429 }
430 
431 static int xc_set_signal_source(struct xc5000_priv *priv, u16 rf_mode)
432 {
433 	dprintk(1, "%s(%d) Source = %s\n", __func__, rf_mode,
434 		rf_mode == XC_RF_MODE_AIR ? "ANTENNA" : "CABLE");
435 
436 	if ((rf_mode != XC_RF_MODE_AIR) && (rf_mode != XC_RF_MODE_CABLE)) {
437 		rf_mode = XC_RF_MODE_CABLE;
438 		printk(KERN_ERR
439 			"%s(), Invalid mode, defaulting to CABLE",
440 			__func__);
441 	}
442 	return xc_write_reg(priv, XREG_SIGNALSOURCE, rf_mode);
443 }
444 
445 static const struct dvb_tuner_ops xc5000_tuner_ops;
446 
447 static int xc_set_rf_frequency(struct xc5000_priv *priv, u32 freq_hz)
448 {
449 	u16 freq_code;
450 
451 	dprintk(1, "%s(%u)\n", __func__, freq_hz);
452 
453 	if ((freq_hz > xc5000_tuner_ops.info.frequency_max_hz) ||
454 		(freq_hz < xc5000_tuner_ops.info.frequency_min_hz))
455 		return -EINVAL;
456 
457 	freq_code = (u16)(freq_hz / 15625);
458 
459 	/* Starting in firmware version 1.1.44, Xceive recommends using the
460 	   FINERFREQ for all normal tuning (the doc indicates reg 0x03 should
461 	   only be used for fast scanning for channel lock) */
462 	return xc_write_reg(priv, XREG_FINERFREQ, freq_code);
463 }
464 
465 
466 static int xc_set_IF_frequency(struct xc5000_priv *priv, u32 freq_khz)
467 {
468 	u32 freq_code = (freq_khz * 1024)/1000;
469 	dprintk(1, "%s(freq_khz = %d) freq_code = 0x%x\n",
470 		__func__, freq_khz, freq_code);
471 
472 	return xc_write_reg(priv, XREG_IF_OUT, freq_code);
473 }
474 
475 
476 static int xc_get_adc_envelope(struct xc5000_priv *priv, u16 *adc_envelope)
477 {
478 	return xc5000_readreg(priv, XREG_ADC_ENV, adc_envelope);
479 }
480 
481 static int xc_get_frequency_error(struct xc5000_priv *priv, u32 *freq_error_hz)
482 {
483 	int result;
484 	u16 reg_data;
485 	u32 tmp;
486 
487 	result = xc5000_readreg(priv, XREG_FREQ_ERROR, &reg_data);
488 	if (result != 0)
489 		return result;
490 
491 	tmp = (u32)reg_data;
492 	(*freq_error_hz) = (tmp * 15625) / 1000;
493 	return result;
494 }
495 
496 static int xc_get_lock_status(struct xc5000_priv *priv, u16 *lock_status)
497 {
498 	return xc5000_readreg(priv, XREG_LOCK, lock_status);
499 }
500 
501 static int xc_get_version(struct xc5000_priv *priv,
502 	u8 *hw_majorversion, u8 *hw_minorversion,
503 	u8 *fw_majorversion, u8 *fw_minorversion)
504 {
505 	u16 data;
506 	int result;
507 
508 	result = xc5000_readreg(priv, XREG_VERSION, &data);
509 	if (result != 0)
510 		return result;
511 
512 	(*hw_majorversion) = (data >> 12) & 0x0F;
513 	(*hw_minorversion) = (data >>  8) & 0x0F;
514 	(*fw_majorversion) = (data >>  4) & 0x0F;
515 	(*fw_minorversion) = data & 0x0F;
516 
517 	return 0;
518 }
519 
520 static int xc_get_buildversion(struct xc5000_priv *priv, u16 *buildrev)
521 {
522 	return xc5000_readreg(priv, XREG_BUILD, buildrev);
523 }
524 
525 static int xc_get_hsync_freq(struct xc5000_priv *priv, u32 *hsync_freq_hz)
526 {
527 	u16 reg_data;
528 	int result;
529 
530 	result = xc5000_readreg(priv, XREG_HSYNC_FREQ, &reg_data);
531 	if (result != 0)
532 		return result;
533 
534 	(*hsync_freq_hz) = ((reg_data & 0x0fff) * 763)/100;
535 	return result;
536 }
537 
538 static int xc_get_frame_lines(struct xc5000_priv *priv, u16 *frame_lines)
539 {
540 	return xc5000_readreg(priv, XREG_FRAME_LINES, frame_lines);
541 }
542 
543 static int xc_get_quality(struct xc5000_priv *priv, u16 *quality)
544 {
545 	return xc5000_readreg(priv, XREG_QUALITY, quality);
546 }
547 
548 static int xc_get_analogsnr(struct xc5000_priv *priv, u16 *snr)
549 {
550 	return xc5000_readreg(priv, XREG_SNR, snr);
551 }
552 
553 static int xc_get_totalgain(struct xc5000_priv *priv, u16 *totalgain)
554 {
555 	return xc5000_readreg(priv, XREG_TOTALGAIN, totalgain);
556 }
557 
558 #define XC_TUNE_ANALOG  0
559 #define XC_TUNE_DIGITAL 1
560 static int xc_tune_channel(struct xc5000_priv *priv, u32 freq_hz, int mode)
561 {
562 	dprintk(1, "%s(%u)\n", __func__, freq_hz);
563 
564 	if (xc_set_rf_frequency(priv, freq_hz) != 0)
565 		return -EREMOTEIO;
566 
567 	return 0;
568 }
569 
570 static int xc_set_xtal(struct dvb_frontend *fe)
571 {
572 	struct xc5000_priv *priv = fe->tuner_priv;
573 	int ret = 0;
574 
575 	switch (priv->chip_id) {
576 	default:
577 	case XC5000A:
578 		/* 32.000 MHz xtal is default */
579 		break;
580 	case XC5000C:
581 		switch (priv->xtal_khz) {
582 		default:
583 		case 32000:
584 			/* 32.000 MHz xtal is default */
585 			break;
586 		case 31875:
587 			/* 31.875 MHz xtal configuration */
588 			ret = xc_write_reg(priv, 0x000f, 0x8081);
589 			break;
590 		}
591 		break;
592 	}
593 	return ret;
594 }
595 
596 static int xc5000_fwupload(struct dvb_frontend *fe,
597 			   const struct xc5000_fw_cfg *desired_fw,
598 			   const struct firmware *fw)
599 {
600 	struct xc5000_priv *priv = fe->tuner_priv;
601 	int ret;
602 
603 	/* request the firmware, this will block and timeout */
604 	dprintk(1, "waiting for firmware upload (%s)...\n",
605 		desired_fw->name);
606 
607 	priv->pll_register_no = desired_fw->pll_reg;
608 	priv->init_status_supported = desired_fw->init_status_supported;
609 	priv->fw_checksum_supported = desired_fw->fw_checksum_supported;
610 
611 
612 	dprintk(1, "firmware uploading...\n");
613 	ret = xc_load_i2c_sequence(fe,  fw->data);
614 	if (!ret) {
615 		ret = xc_set_xtal(fe);
616 		dprintk(1, "Firmware upload complete...\n");
617 	} else
618 		printk(KERN_ERR "xc5000: firmware upload failed...\n");
619 
620 	return ret;
621 }
622 
623 static void xc_debug_dump(struct xc5000_priv *priv)
624 {
625 	u16 adc_envelope;
626 	u32 freq_error_hz = 0;
627 	u16 lock_status;
628 	u32 hsync_freq_hz = 0;
629 	u16 frame_lines;
630 	u16 quality;
631 	u16 snr;
632 	u16 totalgain;
633 	u8 hw_majorversion = 0, hw_minorversion = 0;
634 	u8 fw_majorversion = 0, fw_minorversion = 0;
635 	u16 fw_buildversion = 0;
636 	u16 regval;
637 
638 	/* Wait for stats to stabilize.
639 	 * Frame Lines needs two frame times after initial lock
640 	 * before it is valid.
641 	 */
642 	msleep(100);
643 
644 	xc_get_adc_envelope(priv,  &adc_envelope);
645 	dprintk(1, "*** ADC envelope (0-1023) = %d\n", adc_envelope);
646 
647 	xc_get_frequency_error(priv, &freq_error_hz);
648 	dprintk(1, "*** Frequency error = %d Hz\n", freq_error_hz);
649 
650 	xc_get_lock_status(priv,  &lock_status);
651 	dprintk(1, "*** Lock status (0-Wait, 1-Locked, 2-No-signal) = %d\n",
652 		lock_status);
653 
654 	xc_get_version(priv,  &hw_majorversion, &hw_minorversion,
655 		&fw_majorversion, &fw_minorversion);
656 	xc_get_buildversion(priv,  &fw_buildversion);
657 	dprintk(1, "*** HW: V%d.%d, FW: V %d.%d.%d\n",
658 		hw_majorversion, hw_minorversion,
659 		fw_majorversion, fw_minorversion, fw_buildversion);
660 
661 	xc_get_hsync_freq(priv,  &hsync_freq_hz);
662 	dprintk(1, "*** Horizontal sync frequency = %d Hz\n", hsync_freq_hz);
663 
664 	xc_get_frame_lines(priv,  &frame_lines);
665 	dprintk(1, "*** Frame lines = %d\n", frame_lines);
666 
667 	xc_get_quality(priv,  &quality);
668 	dprintk(1, "*** Quality (0:<8dB, 7:>56dB) = %d\n", quality & 0x07);
669 
670 	xc_get_analogsnr(priv,  &snr);
671 	dprintk(1, "*** Unweighted analog SNR = %d dB\n", snr & 0x3f);
672 
673 	xc_get_totalgain(priv,  &totalgain);
674 	dprintk(1, "*** Total gain = %d.%d dB\n", totalgain / 256,
675 		(totalgain % 256) * 100 / 256);
676 
677 	if (priv->pll_register_no) {
678 		if (!xc5000_readreg(priv, priv->pll_register_no, &regval))
679 			dprintk(1, "*** PLL lock status = 0x%04x\n", regval);
680 	}
681 }
682 
683 static int xc5000_tune_digital(struct dvb_frontend *fe)
684 {
685 	struct xc5000_priv *priv = fe->tuner_priv;
686 	int ret;
687 	u32 bw = fe->dtv_property_cache.bandwidth_hz;
688 
689 	ret = xc_set_signal_source(priv, priv->rf_mode);
690 	if (ret != 0) {
691 		printk(KERN_ERR
692 			"xc5000: xc_set_signal_source(%d) failed\n",
693 			priv->rf_mode);
694 		return -EREMOTEIO;
695 	}
696 
697 	ret = xc_set_tv_standard(priv,
698 		xc5000_standard[priv->video_standard].video_mode,
699 		xc5000_standard[priv->video_standard].audio_mode, 0);
700 	if (ret != 0) {
701 		printk(KERN_ERR "xc5000: xc_set_tv_standard failed\n");
702 		return -EREMOTEIO;
703 	}
704 
705 	ret = xc_set_IF_frequency(priv, priv->if_khz);
706 	if (ret != 0) {
707 		printk(KERN_ERR "xc5000: xc_Set_IF_frequency(%d) failed\n",
708 		       priv->if_khz);
709 		return -EIO;
710 	}
711 
712 	dprintk(1, "%s() setting OUTPUT_AMP to 0x%x\n",
713 		__func__, priv->output_amp);
714 	xc_write_reg(priv, XREG_OUTPUT_AMP, priv->output_amp);
715 
716 	xc_tune_channel(priv, priv->freq_hz, XC_TUNE_DIGITAL);
717 
718 	if (debug)
719 		xc_debug_dump(priv);
720 
721 	priv->bandwidth = bw;
722 
723 	return 0;
724 }
725 
726 static int xc5000_set_digital_params(struct dvb_frontend *fe)
727 {
728 	int b;
729 	struct xc5000_priv *priv = fe->tuner_priv;
730 	u32 bw = fe->dtv_property_cache.bandwidth_hz;
731 	u32 freq = fe->dtv_property_cache.frequency;
732 	u32 delsys  = fe->dtv_property_cache.delivery_system;
733 
734 	if (xc_load_fw_and_init_tuner(fe, 0) != 0) {
735 		dprintk(1, "Unable to load firmware and init tuner\n");
736 		return -EINVAL;
737 	}
738 
739 	dprintk(1, "%s() frequency=%d (Hz)\n", __func__, freq);
740 
741 	switch (delsys) {
742 	case SYS_ATSC:
743 		dprintk(1, "%s() VSB modulation\n", __func__);
744 		priv->rf_mode = XC_RF_MODE_AIR;
745 		priv->freq_offset = 1750000;
746 		priv->video_standard = DTV6;
747 		break;
748 	case SYS_DVBC_ANNEX_B:
749 		dprintk(1, "%s() QAM modulation\n", __func__);
750 		priv->rf_mode = XC_RF_MODE_CABLE;
751 		priv->freq_offset = 1750000;
752 		priv->video_standard = DTV6;
753 		break;
754 	case SYS_ISDBT:
755 		/* All ISDB-T are currently for 6 MHz bw */
756 		if (!bw)
757 			bw = 6000000;
758 		/* fall to OFDM handling */
759 		fallthrough;
760 	case SYS_DMBTH:
761 	case SYS_DVBT:
762 	case SYS_DVBT2:
763 		dprintk(1, "%s() OFDM\n", __func__);
764 		switch (bw) {
765 		case 6000000:
766 			priv->video_standard = DTV6;
767 			priv->freq_offset = 1750000;
768 			break;
769 		case 7000000:
770 			priv->video_standard = DTV7;
771 			priv->freq_offset = 2250000;
772 			break;
773 		case 8000000:
774 			priv->video_standard = DTV8;
775 			priv->freq_offset = 2750000;
776 			break;
777 		default:
778 			printk(KERN_ERR "xc5000 bandwidth not set!\n");
779 			return -EINVAL;
780 		}
781 		priv->rf_mode = XC_RF_MODE_AIR;
782 		break;
783 	case SYS_DVBC_ANNEX_A:
784 	case SYS_DVBC_ANNEX_C:
785 		dprintk(1, "%s() QAM modulation\n", __func__);
786 		priv->rf_mode = XC_RF_MODE_CABLE;
787 		if (bw <= 6000000) {
788 			priv->video_standard = DTV6;
789 			priv->freq_offset = 1750000;
790 			b = 6;
791 		} else if (bw <= 7000000) {
792 			priv->video_standard = DTV7;
793 			priv->freq_offset = 2250000;
794 			b = 7;
795 		} else {
796 			priv->video_standard = DTV7_8;
797 			priv->freq_offset = 2750000;
798 			b = 8;
799 		}
800 		dprintk(1, "%s() Bandwidth %dMHz (%d)\n", __func__,
801 			b, bw);
802 		break;
803 	default:
804 		printk(KERN_ERR "xc5000: delivery system is not supported!\n");
805 		return -EINVAL;
806 	}
807 
808 	priv->freq_hz = freq - priv->freq_offset;
809 	priv->mode = V4L2_TUNER_DIGITAL_TV;
810 
811 	dprintk(1, "%s() frequency=%d (compensated to %d)\n",
812 		__func__, freq, priv->freq_hz);
813 
814 	return xc5000_tune_digital(fe);
815 }
816 
817 static int xc5000_is_firmware_loaded(struct dvb_frontend *fe)
818 {
819 	struct xc5000_priv *priv = fe->tuner_priv;
820 	int ret;
821 	u16 id;
822 
823 	ret = xc5000_readreg(priv, XREG_PRODUCT_ID, &id);
824 	if (!ret) {
825 		if (id == XC_PRODUCT_ID_FW_NOT_LOADED)
826 			ret = -ENOENT;
827 		else
828 			ret = 0;
829 		dprintk(1, "%s() returns id = 0x%x\n", __func__, id);
830 	} else {
831 		dprintk(1, "%s() returns error %d\n", __func__, ret);
832 	}
833 
834 	return ret;
835 }
836 
837 static void xc5000_config_tv(struct dvb_frontend *fe,
838 			     struct analog_parameters *params)
839 {
840 	struct xc5000_priv *priv = fe->tuner_priv;
841 
842 	dprintk(1, "%s() frequency=%d (in units of 62.5khz)\n",
843 		__func__, params->frequency);
844 
845 	/* Fix me: it could be air. */
846 	priv->rf_mode = params->mode;
847 	if (params->mode > XC_RF_MODE_CABLE)
848 		priv->rf_mode = XC_RF_MODE_CABLE;
849 
850 	/* params->frequency is in units of 62.5khz */
851 	priv->freq_hz = params->frequency * 62500;
852 
853 	/* FIX ME: Some video standards may have several possible audio
854 		   standards. We simply default to one of them here.
855 	 */
856 	if (params->std & V4L2_STD_MN) {
857 		/* default to BTSC audio standard */
858 		priv->video_standard = MN_NTSC_PAL_BTSC;
859 		return;
860 	}
861 
862 	if (params->std & V4L2_STD_PAL_BG) {
863 		/* default to NICAM audio standard */
864 		priv->video_standard = BG_PAL_NICAM;
865 		return;
866 	}
867 
868 	if (params->std & V4L2_STD_PAL_I) {
869 		/* default to NICAM audio standard */
870 		priv->video_standard = I_PAL_NICAM;
871 		return;
872 	}
873 
874 	if (params->std & V4L2_STD_PAL_DK) {
875 		/* default to NICAM audio standard */
876 		priv->video_standard = DK_PAL_NICAM;
877 		return;
878 	}
879 
880 	if (params->std & V4L2_STD_SECAM_DK) {
881 		/* default to A2 DK1 audio standard */
882 		priv->video_standard = DK_SECAM_A2DK1;
883 		return;
884 	}
885 
886 	if (params->std & V4L2_STD_SECAM_L) {
887 		priv->video_standard = L_SECAM_NICAM;
888 		return;
889 	}
890 
891 	if (params->std & V4L2_STD_SECAM_LC) {
892 		priv->video_standard = LC_SECAM_NICAM;
893 		return;
894 	}
895 }
896 
897 static int xc5000_set_tv_freq(struct dvb_frontend *fe)
898 {
899 	struct xc5000_priv *priv = fe->tuner_priv;
900 	u16 pll_lock_status;
901 	int ret;
902 
903 tune_channel:
904 	ret = xc_set_signal_source(priv, priv->rf_mode);
905 	if (ret != 0) {
906 		printk(KERN_ERR
907 			"xc5000: xc_set_signal_source(%d) failed\n",
908 			priv->rf_mode);
909 		return -EREMOTEIO;
910 	}
911 
912 	ret = xc_set_tv_standard(priv,
913 		xc5000_standard[priv->video_standard].video_mode,
914 		xc5000_standard[priv->video_standard].audio_mode, 0);
915 	if (ret != 0) {
916 		printk(KERN_ERR "xc5000: xc_set_tv_standard failed\n");
917 		return -EREMOTEIO;
918 	}
919 
920 	xc_write_reg(priv, XREG_OUTPUT_AMP, 0x09);
921 
922 	xc_tune_channel(priv, priv->freq_hz, XC_TUNE_ANALOG);
923 
924 	if (debug)
925 		xc_debug_dump(priv);
926 
927 	if (priv->pll_register_no != 0) {
928 		msleep(20);
929 		ret = xc5000_readreg(priv, priv->pll_register_no,
930 				     &pll_lock_status);
931 		if (ret)
932 			return ret;
933 		if (pll_lock_status > 63) {
934 			/* PLL is unlocked, force reload of the firmware */
935 			dprintk(1, "xc5000: PLL not locked (0x%x).  Reloading...\n",
936 				pll_lock_status);
937 			if (xc_load_fw_and_init_tuner(fe, 1) != 0) {
938 				printk(KERN_ERR "xc5000: Unable to reload fw\n");
939 				return -EREMOTEIO;
940 			}
941 			goto tune_channel;
942 		}
943 	}
944 
945 	return 0;
946 }
947 
948 static int xc5000_config_radio(struct dvb_frontend *fe,
949 			       struct analog_parameters *params)
950 
951 {
952 	struct xc5000_priv *priv = fe->tuner_priv;
953 
954 	dprintk(1, "%s() frequency=%d (in units of khz)\n",
955 		__func__, params->frequency);
956 
957 	if (priv->radio_input == XC5000_RADIO_NOT_CONFIGURED) {
958 		dprintk(1, "%s() radio input not configured\n", __func__);
959 		return -EINVAL;
960 	}
961 
962 	priv->freq_hz = params->frequency * 125 / 2;
963 	priv->rf_mode = XC_RF_MODE_AIR;
964 
965 	return 0;
966 }
967 
968 static int xc5000_set_radio_freq(struct dvb_frontend *fe)
969 {
970 	struct xc5000_priv *priv = fe->tuner_priv;
971 	int ret;
972 	u8 radio_input;
973 
974 	if (priv->radio_input == XC5000_RADIO_FM1)
975 		radio_input = FM_RADIO_INPUT1;
976 	else if  (priv->radio_input == XC5000_RADIO_FM2)
977 		radio_input = FM_RADIO_INPUT2;
978 	else if  (priv->radio_input == XC5000_RADIO_FM1_MONO)
979 		radio_input = FM_RADIO_INPUT1_MONO;
980 	else {
981 		dprintk(1, "%s() unknown radio input %d\n", __func__,
982 			priv->radio_input);
983 		return -EINVAL;
984 	}
985 
986 	ret = xc_set_tv_standard(priv, xc5000_standard[radio_input].video_mode,
987 			       xc5000_standard[radio_input].audio_mode, radio_input);
988 
989 	if (ret != 0) {
990 		printk(KERN_ERR "xc5000: xc_set_tv_standard failed\n");
991 		return -EREMOTEIO;
992 	}
993 
994 	ret = xc_set_signal_source(priv, priv->rf_mode);
995 	if (ret != 0) {
996 		printk(KERN_ERR
997 			"xc5000: xc_set_signal_source(%d) failed\n",
998 			priv->rf_mode);
999 		return -EREMOTEIO;
1000 	}
1001 
1002 	if ((priv->radio_input == XC5000_RADIO_FM1) ||
1003 				(priv->radio_input == XC5000_RADIO_FM2))
1004 		xc_write_reg(priv, XREG_OUTPUT_AMP, 0x09);
1005 	else if  (priv->radio_input == XC5000_RADIO_FM1_MONO)
1006 		xc_write_reg(priv, XREG_OUTPUT_AMP, 0x06);
1007 
1008 	xc_tune_channel(priv, priv->freq_hz, XC_TUNE_ANALOG);
1009 
1010 	return 0;
1011 }
1012 
1013 static int xc5000_set_params(struct dvb_frontend *fe)
1014 {
1015 	struct xc5000_priv *priv = fe->tuner_priv;
1016 
1017 	if (xc_load_fw_and_init_tuner(fe, 0) != 0) {
1018 		dprintk(1, "Unable to load firmware and init tuner\n");
1019 		return -EINVAL;
1020 	}
1021 
1022 	switch (priv->mode) {
1023 	case V4L2_TUNER_RADIO:
1024 		return xc5000_set_radio_freq(fe);
1025 	case V4L2_TUNER_ANALOG_TV:
1026 		return xc5000_set_tv_freq(fe);
1027 	case V4L2_TUNER_DIGITAL_TV:
1028 		return xc5000_tune_digital(fe);
1029 	}
1030 
1031 	return 0;
1032 }
1033 
1034 static int xc5000_set_analog_params(struct dvb_frontend *fe,
1035 			     struct analog_parameters *params)
1036 {
1037 	struct xc5000_priv *priv = fe->tuner_priv;
1038 	int ret;
1039 
1040 	if (priv->i2c_props.adap == NULL)
1041 		return -EINVAL;
1042 
1043 	switch (params->mode) {
1044 	case V4L2_TUNER_RADIO:
1045 		ret = xc5000_config_radio(fe, params);
1046 		if (ret)
1047 			return ret;
1048 		break;
1049 	case V4L2_TUNER_ANALOG_TV:
1050 		xc5000_config_tv(fe, params);
1051 		break;
1052 	default:
1053 		break;
1054 	}
1055 	priv->mode = params->mode;
1056 
1057 	return xc5000_set_params(fe);
1058 }
1059 
1060 static int xc5000_get_frequency(struct dvb_frontend *fe, u32 *freq)
1061 {
1062 	struct xc5000_priv *priv = fe->tuner_priv;
1063 	dprintk(1, "%s()\n", __func__);
1064 	*freq = priv->freq_hz + priv->freq_offset;
1065 	return 0;
1066 }
1067 
1068 static int xc5000_get_if_frequency(struct dvb_frontend *fe, u32 *freq)
1069 {
1070 	struct xc5000_priv *priv = fe->tuner_priv;
1071 	dprintk(1, "%s()\n", __func__);
1072 	*freq = priv->if_khz * 1000;
1073 	return 0;
1074 }
1075 
1076 static int xc5000_get_bandwidth(struct dvb_frontend *fe, u32 *bw)
1077 {
1078 	struct xc5000_priv *priv = fe->tuner_priv;
1079 	dprintk(1, "%s()\n", __func__);
1080 
1081 	*bw = priv->bandwidth;
1082 	return 0;
1083 }
1084 
1085 static int xc5000_get_status(struct dvb_frontend *fe, u32 *status)
1086 {
1087 	struct xc5000_priv *priv = fe->tuner_priv;
1088 	u16 lock_status = 0;
1089 
1090 	xc_get_lock_status(priv, &lock_status);
1091 
1092 	dprintk(1, "%s() lock_status = 0x%08x\n", __func__, lock_status);
1093 
1094 	*status = lock_status;
1095 
1096 	return 0;
1097 }
1098 
1099 static int xc_load_fw_and_init_tuner(struct dvb_frontend *fe, int force)
1100 {
1101 	struct xc5000_priv *priv = fe->tuner_priv;
1102 	const struct xc5000_fw_cfg *desired_fw = xc5000_assign_firmware(priv->chip_id);
1103 	const struct firmware *fw;
1104 	int ret, i;
1105 	u16 pll_lock_status;
1106 	u16 fw_ck;
1107 
1108 	cancel_delayed_work(&priv->timer_sleep);
1109 
1110 	if (!force && xc5000_is_firmware_loaded(fe) == 0)
1111 		return 0;
1112 
1113 	if (!priv->firmware) {
1114 		ret = request_firmware(&fw, desired_fw->name,
1115 					priv->i2c_props.adap->dev.parent);
1116 		if (ret) {
1117 			pr_err("xc5000: Upload failed. rc %d\n", ret);
1118 			return ret;
1119 		}
1120 		dprintk(1, "firmware read %zu bytes.\n", fw->size);
1121 
1122 		if (fw->size != desired_fw->size) {
1123 			pr_err("xc5000: Firmware file with incorrect size\n");
1124 			release_firmware(fw);
1125 			return -EINVAL;
1126 		}
1127 		priv->firmware = fw;
1128 	} else
1129 		fw = priv->firmware;
1130 
1131 	/* Try up to 5 times to load firmware */
1132 	for (i = 0; i < 5; i++) {
1133 		if (i)
1134 			printk(KERN_CONT " - retrying to upload firmware.\n");
1135 
1136 		ret = xc5000_fwupload(fe, desired_fw, fw);
1137 		if (ret != 0)
1138 			goto err;
1139 
1140 		msleep(20);
1141 
1142 		if (priv->fw_checksum_supported) {
1143 			if (xc5000_readreg(priv, XREG_FW_CHECKSUM, &fw_ck)) {
1144 				printk(KERN_ERR
1145 				       "xc5000: FW checksum reading failed.");
1146 				continue;
1147 			}
1148 
1149 			if (!fw_ck) {
1150 				printk(KERN_ERR
1151 				       "xc5000: FW checksum failed = 0x%04x.",
1152 				       fw_ck);
1153 				continue;
1154 			}
1155 		}
1156 
1157 		/* Start the tuner self-calibration process */
1158 		ret = xc_initialize(priv);
1159 		if (ret) {
1160 			printk(KERN_ERR "xc5000: Can't request self-calibration.");
1161 			continue;
1162 		}
1163 
1164 		/* Wait for calibration to complete.
1165 		 * We could continue but XC5000 will clock stretch subsequent
1166 		 * I2C transactions until calibration is complete.  This way we
1167 		 * don't have to rely on clock stretching working.
1168 		 */
1169 		msleep(100);
1170 
1171 		if (priv->init_status_supported) {
1172 			if (xc5000_readreg(priv, XREG_INIT_STATUS, &fw_ck)) {
1173 				printk(KERN_ERR
1174 				       "xc5000: FW failed reading init status.");
1175 				continue;
1176 			}
1177 
1178 			if (!fw_ck) {
1179 				printk(KERN_ERR
1180 				       "xc5000: FW init status failed = 0x%04x.",
1181 				       fw_ck);
1182 				continue;
1183 			}
1184 		}
1185 
1186 		if (priv->pll_register_no) {
1187 			ret = xc5000_readreg(priv, priv->pll_register_no,
1188 					     &pll_lock_status);
1189 			if (ret)
1190 				continue;
1191 			if (pll_lock_status > 63) {
1192 				/* PLL is unlocked, force reload of the firmware */
1193 				printk(KERN_ERR
1194 				       "xc5000: PLL not running after fwload.");
1195 				continue;
1196 			}
1197 		}
1198 
1199 		/* Default to "CABLE" mode */
1200 		ret = xc_write_reg(priv, XREG_SIGNALSOURCE, XC_RF_MODE_CABLE);
1201 		if (!ret)
1202 			break;
1203 		printk(KERN_ERR "xc5000: can't set to cable mode.");
1204 	}
1205 
1206 err:
1207 	if (!ret)
1208 		printk(KERN_INFO "xc5000: Firmware %s loaded and running.\n",
1209 		       desired_fw->name);
1210 	else
1211 		printk(KERN_CONT " - too many retries. Giving up\n");
1212 
1213 	return ret;
1214 }
1215 
1216 static void xc5000_do_timer_sleep(struct work_struct *timer_sleep)
1217 {
1218 	struct xc5000_priv *priv =container_of(timer_sleep, struct xc5000_priv,
1219 					       timer_sleep.work);
1220 	struct dvb_frontend *fe = priv->fe;
1221 	int ret;
1222 
1223 	dprintk(1, "%s()\n", __func__);
1224 
1225 	/* According to Xceive technical support, the "powerdown" register
1226 	   was removed in newer versions of the firmware.  The "supported"
1227 	   way to sleep the tuner is to pull the reset pin low for 10ms */
1228 	ret = xc5000_tuner_reset(fe);
1229 	if (ret != 0)
1230 		printk(KERN_ERR
1231 			"xc5000: %s() unable to shutdown tuner\n",
1232 			__func__);
1233 }
1234 
1235 static int xc5000_sleep(struct dvb_frontend *fe)
1236 {
1237 	struct xc5000_priv *priv = fe->tuner_priv;
1238 
1239 	dprintk(1, "%s()\n", __func__);
1240 
1241 	/* Avoid firmware reload on slow devices */
1242 	if (no_poweroff)
1243 		return 0;
1244 
1245 	schedule_delayed_work(&priv->timer_sleep,
1246 			      msecs_to_jiffies(XC5000_SLEEP_TIME));
1247 
1248 	return 0;
1249 }
1250 
1251 static int xc5000_suspend(struct dvb_frontend *fe)
1252 {
1253 	struct xc5000_priv *priv = fe->tuner_priv;
1254 	int ret;
1255 
1256 	dprintk(1, "%s()\n", __func__);
1257 
1258 	cancel_delayed_work(&priv->timer_sleep);
1259 
1260 	ret = xc5000_tuner_reset(fe);
1261 	if (ret != 0)
1262 		printk(KERN_ERR
1263 			"xc5000: %s() unable to shutdown tuner\n",
1264 			__func__);
1265 
1266 	return 0;
1267 }
1268 
1269 static int xc5000_resume(struct dvb_frontend *fe)
1270 {
1271 	struct xc5000_priv *priv = fe->tuner_priv;
1272 
1273 	dprintk(1, "%s()\n", __func__);
1274 
1275 	/* suspended before firmware is loaded.
1276 	   Avoid firmware load in resume path. */
1277 	if (!priv->firmware)
1278 		return 0;
1279 
1280 	return xc5000_set_params(fe);
1281 }
1282 
1283 static int xc5000_init(struct dvb_frontend *fe)
1284 {
1285 	struct xc5000_priv *priv = fe->tuner_priv;
1286 	dprintk(1, "%s()\n", __func__);
1287 
1288 	if (xc_load_fw_and_init_tuner(fe, 0) != 0) {
1289 		printk(KERN_ERR "xc5000: Unable to initialise tuner\n");
1290 		return -EREMOTEIO;
1291 	}
1292 
1293 	if (debug)
1294 		xc_debug_dump(priv);
1295 
1296 	return 0;
1297 }
1298 
1299 static void xc5000_release(struct dvb_frontend *fe)
1300 {
1301 	struct xc5000_priv *priv = fe->tuner_priv;
1302 
1303 	dprintk(1, "%s()\n", __func__);
1304 
1305 	mutex_lock(&xc5000_list_mutex);
1306 
1307 	if (priv) {
1308 		cancel_delayed_work(&priv->timer_sleep);
1309 		if (priv->firmware) {
1310 			release_firmware(priv->firmware);
1311 			priv->firmware = NULL;
1312 		}
1313 		hybrid_tuner_release_state(priv);
1314 	}
1315 
1316 	mutex_unlock(&xc5000_list_mutex);
1317 
1318 	fe->tuner_priv = NULL;
1319 }
1320 
1321 static int xc5000_set_config(struct dvb_frontend *fe, void *priv_cfg)
1322 {
1323 	struct xc5000_priv *priv = fe->tuner_priv;
1324 	struct xc5000_config *p = priv_cfg;
1325 
1326 	dprintk(1, "%s()\n", __func__);
1327 
1328 	if (p->if_khz)
1329 		priv->if_khz = p->if_khz;
1330 
1331 	if (p->radio_input)
1332 		priv->radio_input = p->radio_input;
1333 
1334 	if (p->output_amp)
1335 		priv->output_amp = p->output_amp;
1336 
1337 	return 0;
1338 }
1339 
1340 
1341 static const struct dvb_tuner_ops xc5000_tuner_ops = {
1342 	.info = {
1343 		.name              = "Xceive XC5000",
1344 		.frequency_min_hz  =    1 * MHz,
1345 		.frequency_max_hz  = 1023 * MHz,
1346 		.frequency_step_hz =   50 * kHz,
1347 	},
1348 
1349 	.release	   = xc5000_release,
1350 	.init		   = xc5000_init,
1351 	.sleep		   = xc5000_sleep,
1352 	.suspend	   = xc5000_suspend,
1353 	.resume		   = xc5000_resume,
1354 
1355 	.set_config	   = xc5000_set_config,
1356 	.set_params	   = xc5000_set_digital_params,
1357 	.set_analog_params = xc5000_set_analog_params,
1358 	.get_frequency	   = xc5000_get_frequency,
1359 	.get_if_frequency  = xc5000_get_if_frequency,
1360 	.get_bandwidth	   = xc5000_get_bandwidth,
1361 	.get_status	   = xc5000_get_status
1362 };
1363 
1364 struct dvb_frontend *xc5000_attach(struct dvb_frontend *fe,
1365 				   struct i2c_adapter *i2c,
1366 				   const struct xc5000_config *cfg)
1367 {
1368 	struct xc5000_priv *priv = NULL;
1369 	int instance;
1370 	u16 id = 0;
1371 
1372 	dprintk(1, "%s(%d-%04x)\n", __func__,
1373 		i2c ? i2c_adapter_id(i2c) : -1,
1374 		cfg ? cfg->i2c_address : -1);
1375 
1376 	mutex_lock(&xc5000_list_mutex);
1377 
1378 	instance = hybrid_tuner_request_state(struct xc5000_priv, priv,
1379 					      hybrid_tuner_instance_list,
1380 					      i2c, cfg->i2c_address, "xc5000");
1381 	switch (instance) {
1382 	case 0:
1383 		goto fail;
1384 	case 1:
1385 		/* new tuner instance */
1386 		priv->bandwidth = 6000000;
1387 		fe->tuner_priv = priv;
1388 		priv->fe = fe;
1389 		INIT_DELAYED_WORK(&priv->timer_sleep, xc5000_do_timer_sleep);
1390 		break;
1391 	default:
1392 		/* existing tuner instance */
1393 		fe->tuner_priv = priv;
1394 		break;
1395 	}
1396 
1397 	if (priv->if_khz == 0) {
1398 		/* If the IF hasn't been set yet, use the value provided by
1399 		   the caller (occurs in hybrid devices where the analog
1400 		   call to xc5000_attach occurs before the digital side) */
1401 		priv->if_khz = cfg->if_khz;
1402 	}
1403 
1404 	if (priv->xtal_khz == 0)
1405 		priv->xtal_khz = cfg->xtal_khz;
1406 
1407 	if (priv->radio_input == 0)
1408 		priv->radio_input = cfg->radio_input;
1409 
1410 	/* don't override chip id if it's already been set
1411 	   unless explicitly specified */
1412 	if ((priv->chip_id == 0) || (cfg->chip_id))
1413 		/* use default chip id if none specified, set to 0 so
1414 		   it can be overridden if this is a hybrid driver */
1415 		priv->chip_id = (cfg->chip_id) ? cfg->chip_id : 0;
1416 
1417 	/* don't override output_amp if it's already been set
1418 	   unless explicitly specified */
1419 	if ((priv->output_amp == 0) || (cfg->output_amp))
1420 		/* use default output_amp value if none specified */
1421 		priv->output_amp = (cfg->output_amp) ? cfg->output_amp : 0x8a;
1422 
1423 	/* Check if firmware has been loaded. It is possible that another
1424 	   instance of the driver has loaded the firmware.
1425 	 */
1426 	if (xc5000_readreg(priv, XREG_PRODUCT_ID, &id) != 0)
1427 		goto fail;
1428 
1429 	switch (id) {
1430 	case XC_PRODUCT_ID_FW_LOADED:
1431 		printk(KERN_INFO
1432 			"xc5000: Successfully identified at address 0x%02x\n",
1433 			cfg->i2c_address);
1434 		printk(KERN_INFO
1435 			"xc5000: Firmware has been loaded previously\n");
1436 		break;
1437 	case XC_PRODUCT_ID_FW_NOT_LOADED:
1438 		printk(KERN_INFO
1439 			"xc5000: Successfully identified at address 0x%02x\n",
1440 			cfg->i2c_address);
1441 		printk(KERN_INFO
1442 			"xc5000: Firmware has not been loaded previously\n");
1443 		break;
1444 	default:
1445 		printk(KERN_ERR
1446 			"xc5000: Device not found at addr 0x%02x (0x%x)\n",
1447 			cfg->i2c_address, id);
1448 		goto fail;
1449 	}
1450 
1451 	mutex_unlock(&xc5000_list_mutex);
1452 
1453 	memcpy(&fe->ops.tuner_ops, &xc5000_tuner_ops,
1454 		sizeof(struct dvb_tuner_ops));
1455 
1456 	return fe;
1457 fail:
1458 	mutex_unlock(&xc5000_list_mutex);
1459 
1460 	xc5000_release(fe);
1461 	return NULL;
1462 }
1463 EXPORT_SYMBOL(xc5000_attach);
1464 
1465 MODULE_AUTHOR("Steven Toth");
1466 MODULE_DESCRIPTION("Xceive xc5000 silicon tuner driver");
1467 MODULE_LICENSE("GPL");
1468 MODULE_FIRMWARE(XC5000A_FIRMWARE);
1469 MODULE_FIRMWARE(XC5000C_FIRMWARE);
1470