1/*
2 *  Driver for it913x-fe Frontend
3 *
4 *  with support for on chip it9137 integral tuner
5 *
6 *  Copyright (C) 2011 Malcolm Priestley (tvboxspy@gmail.com)
7 *  IT9137 Copyright (C) ITE Tech Inc.
8 *
9 *  This program is free software; you can redistribute it and/or modify
10 *  it under the terms of the GNU General Public License as published by
11 *  the Free Software Foundation; either version 2 of the License, or
12 *  (at your option) any later version.
13 *
14 *  This program is distributed in the hope that it will be useful,
15 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
16 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17 *
18 *  GNU General Public License for more details.
19 *
20 *  You should have received a copy of the GNU General Public License
21 *  along with this program; if not, write to the Free Software
22 *  Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.=
23 */
24
25#include <linux/module.h>
26#include <linux/init.h>
27#include <linux/slab.h>
28#include <linux/types.h>
29
30#include "dvb_frontend.h"
31#include "it913x-fe.h"
32#include "it913x-fe-priv.h"
33
34static int it913x_debug;
35
36module_param_named(debug, it913x_debug, int, 0644);
37MODULE_PARM_DESC(debug, "set debugging level (1=info (or-able)).");
38
39#define dprintk(level, args...) do { \
40	if (level & it913x_debug) \
41		printk(KERN_DEBUG "it913x-fe: " args); \
42} while (0)
43
44#define deb_info(args...)  dprintk(0x01, args)
45#define debug_data_snipet(level, name, p) \
46	  dprintk(level, name" (%02x%02x%02x%02x%02x%02x%02x%02x)", \
47		*p, *(p+1), *(p+2), *(p+3), *(p+4), \
48			*(p+5), *(p+6), *(p+7));
49#define info(format, arg...) \
50	printk(KERN_INFO "it913x-fe: " format "\n" , ## arg)
51
52struct it913x_fe_state {
53	struct dvb_frontend frontend;
54	struct i2c_adapter *i2c_adap;
55	struct ite_config *config;
56	u8 i2c_addr;
57	u32 frequency;
58	fe_modulation_t constellation;
59	fe_transmit_mode_t transmission_mode;
60	u8 priority;
61	u32 crystalFrequency;
62	u32 adcFrequency;
63	u8 tuner_type;
64	struct adctable *table;
65	fe_status_t it913x_status;
66	u16 tun_xtal;
67	u8 tun_fdiv;
68	u8 tun_clk_mode;
69	u32 tun_fn_min;
70	u32 ucblocks;
71};
72
73static int it913x_read_reg(struct it913x_fe_state *state,
74		u32 reg, u8 *data, u8 count)
75{
76	int ret;
77	u8 pro = PRO_DMOD; /* All reads from demodulator */
78	u8 b[4];
79	struct i2c_msg msg[2] = {
80		{ .addr = state->i2c_addr + (pro << 1), .flags = 0,
81			.buf = b, .len = sizeof(b) },
82		{ .addr = state->i2c_addr + (pro << 1), .flags = I2C_M_RD,
83			.buf = data, .len = count }
84	};
85	b[0] = (u8) reg >> 24;
86	b[1] = (u8)(reg >> 16) & 0xff;
87	b[2] = (u8)(reg >> 8) & 0xff;
88	b[3] = (u8) reg & 0xff;
89
90	ret = i2c_transfer(state->i2c_adap, msg, 2);
91
92	return ret;
93}
94
95static int it913x_read_reg_u8(struct it913x_fe_state *state, u32 reg)
96{
97	int ret;
98	u8 b[1];
99	ret = it913x_read_reg(state, reg, &b[0], sizeof(b));
100	return (ret < 0) ? -ENODEV : b[0];
101}
102
103static int it913x_write(struct it913x_fe_state *state,
104		u8 pro, u32 reg, u8 buf[], u8 count)
105{
106	u8 b[256];
107	struct i2c_msg msg[1] = {
108		{ .addr = state->i2c_addr + (pro << 1), .flags = 0,
109		  .buf = b, .len = count + 4 }
110	};
111	int ret;
112
113	b[0] = (u8) reg >> 24;
114	b[1] = (u8)(reg >> 16) & 0xff;
115	b[2] = (u8)(reg >> 8) & 0xff;
116	b[3] = (u8) reg & 0xff;
117	memcpy(&b[4], buf, count);
118
119	ret = i2c_transfer(state->i2c_adap, msg, 1);
120
121	if (ret < 0)
122		return -EIO;
123
124	return 0;
125}
126
127static int it913x_write_reg(struct it913x_fe_state *state,
128		u8 pro, u32 reg, u32 data)
129{
130	int ret;
131	u8 b[4];
132	u8 s;
133
134	b[0] = data >> 24;
135	b[1] = (data >> 16) & 0xff;
136	b[2] = (data >> 8) & 0xff;
137	b[3] = data & 0xff;
138	/* expand write as needed */
139	if (data < 0x100)
140		s = 3;
141	else if (data < 0x1000)
142		s = 2;
143	else if (data < 0x100000)
144		s = 1;
145	else
146		s = 0;
147
148	ret = it913x_write(state, pro, reg, &b[s], sizeof(b) - s);
149
150	return ret;
151}
152
153static int it913x_fe_script_loader(struct it913x_fe_state *state,
154		struct it913xset *loadscript)
155{
156	int ret, i;
157	if (loadscript == NULL)
158		return -EINVAL;
159
160	for (i = 0; i < 1000; ++i) {
161		if (loadscript[i].pro == 0xff)
162			break;
163		ret = it913x_write(state, loadscript[i].pro,
164			loadscript[i].address,
165			loadscript[i].reg, loadscript[i].count);
166		if (ret < 0)
167			return -ENODEV;
168	}
169	return 0;
170}
171
172static int it913x_init_tuner(struct it913x_fe_state *state)
173{
174	int ret, i, reg;
175	u8 val, nv_val;
176	u8 nv[] = {48, 32, 24, 16, 12, 8, 6, 4, 2};
177	u8 b[2];
178
179	reg = it913x_read_reg_u8(state, 0xec86);
180	switch (reg) {
181	case 0:
182		state->tun_clk_mode = reg;
183		state->tun_xtal = 2000;
184		state->tun_fdiv = 3;
185		val = 16;
186		break;
187	case -ENODEV:
188		return -ENODEV;
189	case 1:
190	default:
191		state->tun_clk_mode = reg;
192		state->tun_xtal = 640;
193		state->tun_fdiv = 1;
194		val = 6;
195		break;
196	}
197
198	reg = it913x_read_reg_u8(state, 0xed03);
199
200	if (reg < 0)
201		return -ENODEV;
202	else if (reg < sizeof(nv))
203		nv_val = nv[reg];
204	else
205		nv_val = 2;
206
207	for (i = 0; i < 50; i++) {
208		ret = it913x_read_reg(state, 0xed23, &b[0], sizeof(b));
209		reg = (b[1] << 8) + b[0];
210		if (reg > 0)
211			break;
212		if (ret < 0)
213			return -ENODEV;
214		udelay(2000);
215	}
216	state->tun_fn_min = state->tun_xtal * reg;
217	state->tun_fn_min /= (state->tun_fdiv * nv_val);
218	deb_info("Tuner fn_min %d", state->tun_fn_min);
219
220	if (state->config->chip_ver > 1)
221		msleep(50);
222	else {
223		for (i = 0; i < 50; i++) {
224			reg = it913x_read_reg_u8(state, 0xec82);
225			if (reg > 0)
226				break;
227			if (reg < 0)
228				return -ENODEV;
229			udelay(2000);
230		}
231	}
232
233	return it913x_write_reg(state, PRO_DMOD, 0xed81, val);
234}
235
236static int it9137_set_tuner(struct it913x_fe_state *state,
237		u32 bandwidth, u32 frequency_m)
238{
239	struct it913xset *set_tuner = set_it9137_template;
240	int ret, reg;
241	u32 frequency = frequency_m / 1000;
242	u32 freq, temp_f, tmp;
243	u16 iqik_m_cal;
244	u16 n_div;
245	u8 n;
246	u8 l_band;
247	u8 lna_band;
248	u8 bw;
249
250	if (state->config->firmware_ver == 1)
251		set_tuner = set_it9135_template;
252	else
253		set_tuner = set_it9137_template;
254
255	deb_info("Tuner Frequency %d Bandwidth %d", frequency, bandwidth);
256
257	if (frequency >= 51000 && frequency <= 440000) {
258		l_band = 0;
259		lna_band = 0;
260	} else if (frequency > 440000 && frequency <= 484000) {
261		l_band = 1;
262		lna_band = 1;
263	} else if (frequency > 484000 && frequency <= 533000) {
264		l_band = 1;
265		lna_band = 2;
266	} else if (frequency > 533000 && frequency <= 587000) {
267		l_band = 1;
268		lna_band = 3;
269	} else if (frequency > 587000 && frequency <= 645000) {
270		l_band = 1;
271		lna_band = 4;
272	} else if (frequency > 645000 && frequency <= 710000) {
273		l_band = 1;
274		lna_band = 5;
275	} else if (frequency > 710000 && frequency <= 782000) {
276		l_band = 1;
277		lna_band = 6;
278	} else if (frequency > 782000 && frequency <= 860000) {
279		l_band = 1;
280		lna_band = 7;
281	} else if (frequency > 1450000 && frequency <= 1492000) {
282		l_band = 1;
283		lna_band = 0;
284	} else if (frequency > 1660000 && frequency <= 1685000) {
285		l_band = 1;
286		lna_band = 1;
287	} else
288		return -EINVAL;
289	set_tuner[0].reg[0] = lna_band;
290
291	switch (bandwidth) {
292	case 5000000:
293		bw = 0;
294		break;
295	case 6000000:
296		bw = 2;
297		break;
298	case 7000000:
299		bw = 4;
300		break;
301	default:
302	case 8000000:
303		bw = 6;
304		break;
305	}
306
307	set_tuner[1].reg[0] = bw;
308	set_tuner[2].reg[0] = 0xa0 | (l_band << 3);
309
310	if (frequency > 53000 && frequency <= 74000) {
311		n_div = 48;
312		n = 0;
313	} else if (frequency > 74000 && frequency <= 111000) {
314		n_div = 32;
315		n = 1;
316	} else if (frequency > 111000 && frequency <= 148000) {
317		n_div = 24;
318		n = 2;
319	} else if (frequency > 148000 && frequency <= 222000) {
320		n_div = 16;
321		n = 3;
322	} else if (frequency > 222000 && frequency <= 296000) {
323		n_div = 12;
324		n = 4;
325	} else if (frequency > 296000 && frequency <= 445000) {
326		n_div = 8;
327		n = 5;
328	} else if (frequency > 445000 && frequency <= state->tun_fn_min) {
329		n_div = 6;
330		n = 6;
331	} else if (frequency > state->tun_fn_min && frequency <= 950000) {
332		n_div = 4;
333		n = 7;
334	} else if (frequency > 1450000 && frequency <= 1680000) {
335		n_div = 2;
336		n = 0;
337	} else
338		return -EINVAL;
339
340	reg = it913x_read_reg_u8(state, 0xed81);
341	iqik_m_cal = (u16)reg * n_div;
342
343	if (reg < 0x20) {
344		if (state->tun_clk_mode == 0)
345			iqik_m_cal = (iqik_m_cal * 9) >> 5;
346		else
347			iqik_m_cal >>= 1;
348	} else {
349		iqik_m_cal = 0x40 - iqik_m_cal;
350		if (state->tun_clk_mode == 0)
351			iqik_m_cal = ~((iqik_m_cal * 9) >> 5);
352		else
353			iqik_m_cal = ~(iqik_m_cal >> 1);
354	}
355
356	temp_f = frequency * (u32)n_div * (u32)state->tun_fdiv;
357	freq = temp_f / state->tun_xtal;
358	tmp = freq * state->tun_xtal;
359
360	if ((temp_f - tmp) >= (state->tun_xtal >> 1))
361		freq++;
362
363	freq += (u32) n << 13;
364	/* Frequency OMEGA_IQIK_M_CAL_MID*/
365	temp_f = freq + (u32)iqik_m_cal;
366
367	set_tuner[3].reg[0] =  temp_f & 0xff;
368	set_tuner[4].reg[0] =  (temp_f >> 8) & 0xff;
369
370	deb_info("High Frequency = %04x", temp_f);
371
372	/* Lower frequency */
373	set_tuner[5].reg[0] =  freq & 0xff;
374	set_tuner[6].reg[0] =  (freq >> 8) & 0xff;
375
376	deb_info("low Frequency = %04x", freq);
377
378	ret = it913x_fe_script_loader(state, set_tuner);
379
380	return (ret < 0) ? -ENODEV : 0;
381}
382
383static int it913x_fe_select_bw(struct it913x_fe_state *state,
384			u32 bandwidth, u32 adcFrequency)
385{
386	int ret, i;
387	u8 buffer[256];
388	u32 coeff[8];
389	u16 bfsfcw_fftinx_ratio;
390	u16 fftinx_bfsfcw_ratio;
391	u8 count;
392	u8 bw;
393	u8 adcmultiplier;
394
395	deb_info("Bandwidth %d Adc %d", bandwidth, adcFrequency);
396
397	switch (bandwidth) {
398	case 5000000:
399		bw = 3;
400		break;
401	case 6000000:
402		bw = 0;
403		break;
404	case 7000000:
405		bw = 1;
406		break;
407	default:
408	case 8000000:
409		bw = 2;
410		break;
411	}
412	ret = it913x_write_reg(state, PRO_DMOD, REG_BW, bw);
413
414	if (state->table == NULL)
415		return -EINVAL;
416
417	/* In write order */
418	coeff[0] = state->table[bw].coeff_1_2048;
419	coeff[1] = state->table[bw].coeff_2_2k;
420	coeff[2] = state->table[bw].coeff_1_8191;
421	coeff[3] = state->table[bw].coeff_1_8192;
422	coeff[4] = state->table[bw].coeff_1_8193;
423	coeff[5] = state->table[bw].coeff_2_8k;
424	coeff[6] = state->table[bw].coeff_1_4096;
425	coeff[7] = state->table[bw].coeff_2_4k;
426	bfsfcw_fftinx_ratio = state->table[bw].bfsfcw_fftinx_ratio;
427	fftinx_bfsfcw_ratio = state->table[bw].fftinx_bfsfcw_ratio;
428
429	/* ADC multiplier */
430	ret = it913x_read_reg_u8(state, ADC_X_2);
431	if (ret < 0)
432		return -EINVAL;
433
434	adcmultiplier = ret;
435
436	count = 0;
437
438	/*  Build Buffer for COEFF Registers */
439	for (i = 0; i < 8; i++) {
440		if (adcmultiplier == 1)
441			coeff[i] /= 2;
442		buffer[count++] = (coeff[i] >> 24) & 0x3;
443		buffer[count++] = (coeff[i] >> 16) & 0xff;
444		buffer[count++] = (coeff[i] >> 8) & 0xff;
445		buffer[count++] = coeff[i] & 0xff;
446	}
447
448	/* bfsfcw_fftinx_ratio register 0x21-0x22 */
449	buffer[count++] = bfsfcw_fftinx_ratio & 0xff;
450	buffer[count++] = (bfsfcw_fftinx_ratio >> 8) & 0xff;
451	/* fftinx_bfsfcw_ratio register 0x23-0x24 */
452	buffer[count++] = fftinx_bfsfcw_ratio & 0xff;
453	buffer[count++] = (fftinx_bfsfcw_ratio >> 8) & 0xff;
454	/* start at COEFF_1_2048 and write through to fftinx_bfsfcw_ratio*/
455	ret = it913x_write(state, PRO_DMOD, COEFF_1_2048, buffer, count);
456
457	for (i = 0; i < 42; i += 8)
458		debug_data_snipet(0x1, "Buffer", &buffer[i]);
459
460	return ret;
461}
462
463
464
465static int it913x_fe_read_status(struct dvb_frontend *fe, fe_status_t *status)
466{
467	struct it913x_fe_state *state = fe->demodulator_priv;
468	int ret, i;
469	fe_status_t old_status = state->it913x_status;
470	*status = 0;
471
472	if (state->it913x_status == 0) {
473		ret = it913x_read_reg_u8(state, EMPTY_CHANNEL_STATUS);
474		if (ret == 0x1) {
475			*status |= FE_HAS_SIGNAL;
476			for (i = 0; i < 40; i++) {
477				ret = it913x_read_reg_u8(state, MP2IF_SYNC_LK);
478				if (ret == 0x1)
479					break;
480				msleep(25);
481			}
482			if (ret == 0x1)
483				*status |= FE_HAS_CARRIER
484					| FE_HAS_VITERBI
485					| FE_HAS_SYNC;
486			state->it913x_status = *status;
487		}
488	}
489
490	if (state->it913x_status & FE_HAS_SYNC) {
491		ret = it913x_read_reg_u8(state, TPSD_LOCK);
492		if (ret == 0x1)
493			*status |= FE_HAS_LOCK
494				| state->it913x_status;
495		else
496			state->it913x_status = 0;
497		if (old_status != state->it913x_status)
498			ret = it913x_write_reg(state, PRO_LINK, GPIOH3_O, ret);
499	}
500
501	return 0;
502}
503
504/* FEC values based on fe_code_rate_t non supported values 0*/
505int it913x_qpsk_pval[] = {0, -93, -91, -90, 0, -89, -88};
506int it913x_16qam_pval[] = {0, -87, -85, -84, 0, -83, -82};
507int it913x_64qam_pval[] = {0, -82, -80, -78, 0, -77, -76};
508
509static int it913x_get_signal_strength(struct dvb_frontend *fe)
510{
511	struct dtv_frontend_properties *p = &fe->dtv_property_cache;
512	struct it913x_fe_state *state = fe->demodulator_priv;
513	u8 code_rate;
514	int ret, temp;
515	u8 lna_gain_os;
516
517	ret = it913x_read_reg_u8(state, VAR_P_INBAND);
518	if (ret < 0)
519		return ret;
520
521	/* VHF/UHF gain offset */
522	if (state->frequency < 300000000)
523		lna_gain_os = 7;
524	else
525		lna_gain_os = 14;
526
527	temp = (ret - 100) - lna_gain_os;
528
529	if (state->priority == PRIORITY_HIGH)
530		code_rate = p->code_rate_HP;
531	else
532		code_rate = p->code_rate_LP;
533
534	if (code_rate >= ARRAY_SIZE(it913x_qpsk_pval))
535		return -EINVAL;
536
537	deb_info("Reg VAR_P_INBAND:%d Calc Offset Value:%d", ret, temp);
538
539	/* Apply FEC offset values*/
540	switch (p->modulation) {
541	case QPSK:
542		temp -= it913x_qpsk_pval[code_rate];
543		break;
544	case QAM_16:
545		temp -= it913x_16qam_pval[code_rate];
546		break;
547	case QAM_64:
548		temp -= it913x_64qam_pval[code_rate];
549		break;
550	default:
551		return -EINVAL;
552	}
553
554	if (temp < -15)
555		ret = 0;
556	else if ((-15 <= temp) && (temp < 0))
557		ret = (2 * (temp + 15)) / 3;
558	else if ((0 <= temp) && (temp < 20))
559		ret = 4 * temp + 10;
560	else if ((20 <= temp) && (temp < 35))
561		ret = (2 * (temp - 20)) / 3 + 90;
562	else if (temp >= 35)
563		ret = 100;
564
565	deb_info("Signal Strength :%d", ret);
566
567	return ret;
568}
569
570static int it913x_fe_read_signal_strength(struct dvb_frontend *fe,
571		u16 *strength)
572{
573	struct it913x_fe_state *state = fe->demodulator_priv;
574	int ret = 0;
575	if (state->config->read_slevel) {
576		if (state->it913x_status & FE_HAS_SIGNAL)
577			ret = it913x_read_reg_u8(state, SIGNAL_LEVEL);
578	} else
579		ret = it913x_get_signal_strength(fe);
580
581	if (ret >= 0)
582		*strength = (u16)((u32)ret * 0xffff / 0x64);
583
584	return (ret < 0) ? -ENODEV : 0;
585}
586
587static int it913x_fe_read_snr(struct dvb_frontend *fe, u16 *snr)
588{
589	struct it913x_fe_state *state = fe->demodulator_priv;
590	int ret;
591	u8 reg[3];
592	u32 snr_val, snr_min, snr_max;
593	u32 temp;
594
595	ret = it913x_read_reg(state, 0x2c, reg, sizeof(reg));
596
597	snr_val = (u32)(reg[2] << 16) | (reg[1] << 8) | reg[0];
598
599	ret |= it913x_read_reg(state, 0xf78b, reg, 1);
600	if (reg[0])
601		snr_val /= reg[0];
602
603	if (state->transmission_mode == TRANSMISSION_MODE_2K)
604		snr_val *= 4;
605	else if (state->transmission_mode == TRANSMISSION_MODE_4K)
606		snr_val *= 2;
607
608	if (state->constellation == QPSK) {
609		snr_min = 0xb4711;
610		snr_max = 0x191451;
611	} else if (state->constellation == QAM_16) {
612		snr_min = 0x4f0d5;
613		snr_max = 0xc7925;
614	} else if (state->constellation == QAM_64) {
615		snr_min = 0x256d0;
616		snr_max = 0x626be;
617	} else
618		return -EINVAL;
619
620	if (snr_val < snr_min)
621		*snr = 0;
622	else if (snr_val < snr_max) {
623		temp = (snr_val - snr_min) >> 5;
624		temp *= 0xffff;
625		temp /= (snr_max - snr_min) >> 5;
626		*snr = (u16)temp;
627	} else
628		*snr = 0xffff;
629
630	return (ret < 0) ? -ENODEV : 0;
631}
632
633static int it913x_fe_read_ber(struct dvb_frontend *fe, u32 *ber)
634{
635	struct it913x_fe_state *state = fe->demodulator_priv;
636	int ret;
637	u8 reg[5];
638	/* Read Aborted Packets and Pre-Viterbi error rate 5 bytes */
639	ret = it913x_read_reg(state, RSD_ABORT_PKT_LSB, reg, sizeof(reg));
640	state->ucblocks += (u32)(reg[1] << 8) | reg[0];
641	*ber = (u32)(reg[4] << 16) | (reg[3] << 8) | reg[2];
642	return 0;
643}
644
645static int it913x_fe_read_ucblocks(struct dvb_frontend *fe, u32 *ucblocks)
646{
647	struct it913x_fe_state *state = fe->demodulator_priv;
648	int ret;
649	u8 reg[2];
650	/* Aborted Packets */
651	ret = it913x_read_reg(state, RSD_ABORT_PKT_LSB, reg, sizeof(reg));
652	state->ucblocks += (u32)(reg[1] << 8) | reg[0];
653	*ucblocks = state->ucblocks;
654	return ret;
655}
656
657static int it913x_fe_get_frontend(struct dvb_frontend *fe)
658{
659	struct dtv_frontend_properties *p = &fe->dtv_property_cache;
660	struct it913x_fe_state *state = fe->demodulator_priv;
661	int ret;
662	u8 reg[8];
663
664	ret = it913x_read_reg(state, REG_TPSD_TX_MODE, reg, sizeof(reg));
665
666	if (reg[3] < 3)
667		p->modulation = fe_con[reg[3]];
668
669	if (reg[0] < 3)
670		p->transmission_mode = fe_mode[reg[0]];
671
672	if (reg[1] < 4)
673		p->guard_interval = fe_gi[reg[1]];
674
675	if (reg[2] < 4)
676		p->hierarchy = fe_hi[reg[2]];
677
678	state->priority = reg[5];
679
680	p->code_rate_HP = (reg[6] < 6) ? fe_code[reg[6]] : FEC_NONE;
681	p->code_rate_LP = (reg[7] < 6) ? fe_code[reg[7]] : FEC_NONE;
682
683	/* Update internal state to reflect the autodetected props */
684	state->constellation = p->modulation;
685	state->transmission_mode = p->transmission_mode;
686
687	return 0;
688}
689
690static int it913x_fe_set_frontend(struct dvb_frontend *fe)
691{
692	struct dtv_frontend_properties *p = &fe->dtv_property_cache;
693	struct it913x_fe_state *state = fe->demodulator_priv;
694	int ret, i;
695	u8 empty_ch, last_ch;
696
697	state->it913x_status = 0;
698
699	/* Set bw*/
700	ret = it913x_fe_select_bw(state, p->bandwidth_hz,
701		state->adcFrequency);
702
703	/* Training Mode Off */
704	ret = it913x_write_reg(state, PRO_LINK, TRAINING_MODE, 0x0);
705
706	/* Clear Empty Channel */
707	ret = it913x_write_reg(state, PRO_DMOD, EMPTY_CHANNEL_STATUS, 0x0);
708
709	/* Clear bits */
710	ret = it913x_write_reg(state, PRO_DMOD, MP2IF_SYNC_LK, 0x0);
711	/* LED on */
712	ret = it913x_write_reg(state, PRO_LINK, GPIOH3_O, 0x1);
713	/* Select Band*/
714	if ((p->frequency >= 51000000) && (p->frequency <= 230000000))
715		i = 0;
716	else if ((p->frequency >= 350000000) && (p->frequency <= 900000000))
717			i = 1;
718	else if ((p->frequency >= 1450000000) && (p->frequency <= 1680000000))
719			i = 2;
720	else
721		return -EOPNOTSUPP;
722
723	ret = it913x_write_reg(state, PRO_DMOD, FREE_BAND, i);
724
725	deb_info("Frontend Set Tuner Type %02x", state->tuner_type);
726	switch (state->tuner_type) {
727	case IT9135_38:
728	case IT9135_51:
729	case IT9135_52:
730	case IT9135_60:
731	case IT9135_61:
732	case IT9135_62:
733		ret = it9137_set_tuner(state,
734			p->bandwidth_hz, p->frequency);
735		break;
736	default:
737		if (fe->ops.tuner_ops.set_params) {
738			fe->ops.tuner_ops.set_params(fe);
739			if (fe->ops.i2c_gate_ctrl)
740				fe->ops.i2c_gate_ctrl(fe, 0);
741		}
742		break;
743	}
744	/* LED off */
745	ret = it913x_write_reg(state, PRO_LINK, GPIOH3_O, 0x0);
746	/* Trigger ofsm */
747	ret = it913x_write_reg(state, PRO_DMOD, TRIGGER_OFSM, 0x0);
748	last_ch = 2;
749	for (i = 0; i < 40; ++i) {
750		empty_ch = it913x_read_reg_u8(state, EMPTY_CHANNEL_STATUS);
751		if (last_ch == 1 && empty_ch == 1)
752			break;
753		if (last_ch == 2 && empty_ch == 2)
754			return 0;
755		last_ch = empty_ch;
756		msleep(25);
757	}
758	for (i = 0; i < 40; ++i) {
759		if (it913x_read_reg_u8(state, D_TPSD_LOCK) == 1)
760			break;
761		msleep(25);
762	}
763
764	state->frequency = p->frequency;
765	return 0;
766}
767
768static int it913x_fe_suspend(struct it913x_fe_state *state)
769{
770	int ret, i;
771	u8 b;
772
773	ret = it913x_write_reg(state, PRO_DMOD, SUSPEND_FLAG, 0x1);
774
775	ret |= it913x_write_reg(state, PRO_DMOD, TRIGGER_OFSM, 0x0);
776
777	for (i = 0; i < 128; i++) {
778		ret = it913x_read_reg(state, SUSPEND_FLAG, &b, 1);
779		if (ret < 0)
780			return -ENODEV;
781		if (b == 0)
782			break;
783
784	}
785
786	ret |= it913x_write_reg(state, PRO_DMOD, AFE_MEM0, 0x8);
787	/* Turn LED off */
788	ret |= it913x_write_reg(state, PRO_LINK, GPIOH3_O, 0x0);
789
790	ret |= it913x_fe_script_loader(state, it9137_tuner_off);
791
792	return (ret < 0) ? -ENODEV : 0;
793}
794
795/* Power sequence */
796/* Power Up	Tuner on -> Frontend suspend off -> Tuner clk on */
797/* Power Down	Frontend suspend on -> Tuner clk off -> Tuner off */
798
799static int it913x_fe_sleep(struct dvb_frontend *fe)
800{
801	struct it913x_fe_state *state = fe->demodulator_priv;
802	return it913x_fe_suspend(state);
803}
804
805static u32 compute_div(u32 a, u32 b, u32 x)
806{
807	u32 res = 0;
808	u32 c = 0;
809	u32 i = 0;
810
811	if (a > b) {
812		c = a / b;
813		a = a - c * b;
814	}
815
816	for (i = 0; i < x; i++) {
817		if (a >= b) {
818			res += 1;
819			a -= b;
820		}
821		a <<= 1;
822		res <<= 1;
823	}
824
825	res = (c << x) + res;
826
827	return res;
828}
829
830static int it913x_fe_start(struct it913x_fe_state *state)
831{
832	struct it913xset *set_lna;
833	struct it913xset *set_mode;
834	int ret;
835	u8 adf = (state->config->adf & 0xf);
836	u32 adc, xtal;
837	u8 b[4];
838
839	if (state->config->chip_ver == 1)
840		ret = it913x_init_tuner(state);
841
842	info("ADF table value	:%02x", adf);
843
844	if (adf < 10) {
845		state->crystalFrequency = fe_clockTable[adf].xtal ;
846		state->table = fe_clockTable[adf].table;
847		state->adcFrequency = state->table->adcFrequency;
848
849		adc = compute_div(state->adcFrequency, 1000000ul, 19ul);
850		xtal = compute_div(state->crystalFrequency, 1000000ul, 19ul);
851
852	} else
853		return -EINVAL;
854
855	/* Set LED indicator on GPIOH3 */
856	ret = it913x_write_reg(state, PRO_LINK, GPIOH3_EN, 0x1);
857	ret |= it913x_write_reg(state, PRO_LINK, GPIOH3_ON, 0x1);
858	ret |= it913x_write_reg(state, PRO_LINK, GPIOH3_O, 0x1);
859
860	ret |= it913x_write_reg(state, PRO_LINK, 0xf641, state->tuner_type);
861	ret |= it913x_write_reg(state, PRO_DMOD, 0xf5ca, 0x01);
862	ret |= it913x_write_reg(state, PRO_DMOD, 0xf715, 0x01);
863
864	b[0] = xtal & 0xff;
865	b[1] = (xtal >> 8) & 0xff;
866	b[2] = (xtal >> 16) & 0xff;
867	b[3] = (xtal >> 24);
868	ret |= it913x_write(state, PRO_DMOD, XTAL_CLK, b , 4);
869
870	b[0] = adc & 0xff;
871	b[1] = (adc >> 8) & 0xff;
872	b[2] = (adc >> 16) & 0xff;
873	ret |= it913x_write(state, PRO_DMOD, ADC_FREQ, b, 3);
874
875	if (state->config->adc_x2)
876		ret |= it913x_write_reg(state, PRO_DMOD, ADC_X_2, 0x01);
877	b[0] = 0;
878	b[1] = 0;
879	b[2] = 0;
880	ret |= it913x_write(state, PRO_DMOD, 0x0029, b, 3);
881
882	info("Crystal Frequency :%d Adc Frequency :%d ADC X2: %02x",
883		state->crystalFrequency, state->adcFrequency,
884			state->config->adc_x2);
885	deb_info("Xtal value :%04x Adc value :%04x", xtal, adc);
886
887	if (ret < 0)
888		return -ENODEV;
889
890	/* v1 or v2 tuner script */
891	if (state->config->chip_ver > 1)
892		ret = it913x_fe_script_loader(state, it9135_v2);
893	else
894		ret = it913x_fe_script_loader(state, it9135_v1);
895	if (ret < 0)
896		return ret;
897
898	/* LNA Scripts */
899	switch (state->tuner_type) {
900	case IT9135_51:
901		set_lna = it9135_51;
902		break;
903	case IT9135_52:
904		set_lna = it9135_52;
905		break;
906	case IT9135_60:
907		set_lna = it9135_60;
908		break;
909	case IT9135_61:
910		set_lna = it9135_61;
911		break;
912	case IT9135_62:
913		set_lna = it9135_62;
914		break;
915	case IT9135_38:
916	default:
917		set_lna = it9135_38;
918	}
919	info("Tuner LNA type :%02x", state->tuner_type);
920
921	ret = it913x_fe_script_loader(state, set_lna);
922	if (ret < 0)
923		return ret;
924
925	if (state->config->chip_ver == 2) {
926		ret = it913x_write_reg(state, PRO_DMOD, TRIGGER_OFSM, 0x1);
927		ret |= it913x_write_reg(state, PRO_LINK, PADODPU, 0x0);
928		ret |= it913x_write_reg(state, PRO_LINK, AGC_O_D, 0x0);
929		ret |= it913x_init_tuner(state);
930	}
931	if (ret < 0)
932		return -ENODEV;
933
934	/* Always solo frontend */
935	set_mode = set_solo_fe;
936	ret |= it913x_fe_script_loader(state, set_mode);
937
938	ret |= it913x_fe_suspend(state);
939	return (ret < 0) ? -ENODEV : 0;
940}
941
942static int it913x_fe_init(struct dvb_frontend *fe)
943{
944	struct it913x_fe_state *state = fe->demodulator_priv;
945	int ret = 0;
946	/* Power Up Tuner - common all versions */
947	ret = it913x_write_reg(state, PRO_DMOD, 0xec40, 0x1);
948
949	ret |= it913x_fe_script_loader(state, init_1);
950
951	ret |= it913x_write_reg(state, PRO_DMOD, AFE_MEM0, 0x0);
952
953	ret |= it913x_write_reg(state, PRO_DMOD, 0xfba8, 0x0);
954
955	return (ret < 0) ? -ENODEV : 0;
956}
957
958static void it913x_fe_release(struct dvb_frontend *fe)
959{
960	struct it913x_fe_state *state = fe->demodulator_priv;
961	kfree(state);
962}
963
964static struct dvb_frontend_ops it913x_fe_ofdm_ops;
965
966struct dvb_frontend *it913x_fe_attach(struct i2c_adapter *i2c_adap,
967		u8 i2c_addr, struct ite_config *config)
968{
969	struct it913x_fe_state *state = NULL;
970	int ret;
971
972	/* allocate memory for the internal state */
973	state = kzalloc(sizeof(struct it913x_fe_state), GFP_KERNEL);
974	if (state == NULL)
975		return NULL;
976	if (config == NULL)
977		goto error;
978
979	state->i2c_adap = i2c_adap;
980	state->i2c_addr = i2c_addr;
981	state->config = config;
982
983	switch (state->config->tuner_id_0) {
984	case IT9135_51:
985	case IT9135_52:
986	case IT9135_60:
987	case IT9135_61:
988	case IT9135_62:
989		state->tuner_type = state->config->tuner_id_0;
990		break;
991	default:
992	case IT9135_38:
993		state->tuner_type = IT9135_38;
994	}
995
996	ret = it913x_fe_start(state);
997	if (ret < 0)
998		goto error;
999
1000
1001	/* create dvb_frontend */
1002	memcpy(&state->frontend.ops, &it913x_fe_ofdm_ops,
1003			sizeof(struct dvb_frontend_ops));
1004	state->frontend.demodulator_priv = state;
1005
1006	return &state->frontend;
1007error:
1008	kfree(state);
1009	return NULL;
1010}
1011EXPORT_SYMBOL(it913x_fe_attach);
1012
1013static struct dvb_frontend_ops it913x_fe_ofdm_ops = {
1014	.delsys = { SYS_DVBT },
1015	.info = {
1016		.name			= "it913x-fe DVB-T",
1017		.frequency_min		= 51000000,
1018		.frequency_max		= 1680000000,
1019		.frequency_stepsize	= 62500,
1020		.caps = FE_CAN_FEC_1_2 | FE_CAN_FEC_2_3 | FE_CAN_FEC_3_4 |
1021			FE_CAN_FEC_4_5 | FE_CAN_FEC_5_6 | FE_CAN_FEC_6_7 |
1022			FE_CAN_FEC_7_8 | FE_CAN_FEC_8_9 | FE_CAN_FEC_AUTO |
1023			FE_CAN_QAM_16 | FE_CAN_QAM_64 | FE_CAN_QAM_AUTO |
1024			FE_CAN_TRANSMISSION_MODE_AUTO |
1025			FE_CAN_GUARD_INTERVAL_AUTO |
1026			FE_CAN_HIERARCHY_AUTO,
1027	},
1028
1029	.release = it913x_fe_release,
1030
1031	.init = it913x_fe_init,
1032	.sleep = it913x_fe_sleep,
1033
1034	.set_frontend = it913x_fe_set_frontend,
1035	.get_frontend = it913x_fe_get_frontend,
1036
1037	.read_status = it913x_fe_read_status,
1038	.read_signal_strength = it913x_fe_read_signal_strength,
1039	.read_snr = it913x_fe_read_snr,
1040	.read_ber = it913x_fe_read_ber,
1041	.read_ucblocks = it913x_fe_read_ucblocks,
1042};
1043
1044MODULE_DESCRIPTION("it913x Frontend and it9137 tuner");
1045MODULE_AUTHOR("Malcolm Priestley tvboxspy@gmail.com");
1046MODULE_VERSION("1.15");
1047MODULE_LICENSE("GPL");
1048