cgroup: superblock can't be released with active dentries
[firefly-linux-kernel-4.4.55.git] / drivers / media / dvb / frontends / it913x-fe.c
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
34 static int it913x_debug;
35
36 module_param_named(debug, it913x_debug, int, 0644);
37 MODULE_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
52 struct 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
73 static 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
95 static 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
103 static 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
127 static 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
153 static 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
172 static 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
236 static 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
383 static 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
465 static 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*/
505 int it913x_qpsk_pval[] = {0, -93, -91, -90, 0, -89, -88};
506 int it913x_16qam_pval[] = {0, -87, -85, -84, 0, -83, -82};
507 int it913x_64qam_pval[] = {0, -82, -80, -78, 0, -77, -76};
508
509 static 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
570 static 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
587 static 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
633 static 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
645 static 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
657 static 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
690 static 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
768 static 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
799 static 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
805 static 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
830 static 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
942 static 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
958 static void it913x_fe_release(struct dvb_frontend *fe)
959 {
960         struct it913x_fe_state *state = fe->demodulator_priv;
961         kfree(state);
962 }
963
964 static struct dvb_frontend_ops it913x_fe_ofdm_ops;
965
966 struct 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;
1007 error:
1008         kfree(state);
1009         return NULL;
1010 }
1011 EXPORT_SYMBOL(it913x_fe_attach);
1012
1013 static 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
1044 MODULE_DESCRIPTION("it913x Frontend and it9137 tuner");
1045 MODULE_AUTHOR("Malcolm Priestley tvboxspy@gmail.com");
1046 MODULE_VERSION("1.15");
1047 MODULE_LICENSE("GPL");