1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56#define pr_fmt(fmt) KBUILD_MODNAME ":%s: " fmt, __func__
57
58#include <linux/module.h>
59#include <linux/init.h>
60#include <linux/string.h>
61#include <linux/slab.h>
62#include <asm/div64.h>
63
64#include <media/dvb_frontend.h>
65#include "drx39xxj.h"
66
67#include "drxj.h"
68#include "drxj_map.h"
69
70
71
72
73
74#define DRX39XX_MAIN_FIRMWARE "dvb-fe-drxj-mc-1.0.8.fw"
75
76
77
78
79#ifndef MAX_U32
80#define MAX_U32 ((u32) (0xFFFFFFFFL))
81#endif
82
83
84#ifndef MPEG_SERIAL_OUTPUT_PIN_DRIVE_STRENGTH
85#define MPEG_SERIAL_OUTPUT_PIN_DRIVE_STRENGTH 0x02
86#endif
87
88#ifndef MPEG_PARALLEL_OUTPUT_PIN_DRIVE_STRENGTH
89#define MPEG_PARALLEL_OUTPUT_PIN_DRIVE_STRENGTH 0x02
90#endif
91
92#ifndef MPEG_OUTPUT_CLK_DRIVE_STRENGTH
93#define MPEG_OUTPUT_CLK_DRIVE_STRENGTH 0x06
94#endif
95
96#ifndef OOB_CRX_DRIVE_STRENGTH
97#define OOB_CRX_DRIVE_STRENGTH 0x02
98#endif
99
100#ifndef OOB_DRX_DRIVE_STRENGTH
101#define OOB_DRX_DRIVE_STRENGTH 0x02
102#endif
103
104
105#define ATV_TOP_CR_AMP_TH_FM 0x0
106#define ATV_TOP_CR_AMP_TH_L 0xA
107#define ATV_TOP_CR_AMP_TH_LP 0xA
108#define ATV_TOP_CR_AMP_TH_BG 0x8
109#define ATV_TOP_CR_AMP_TH_DK 0x8
110#define ATV_TOP_CR_AMP_TH_I 0x8
111#define ATV_TOP_CR_CONT_CR_D_MN 0x18
112#define ATV_TOP_CR_CONT_CR_D_FM 0x0
113#define ATV_TOP_CR_CONT_CR_D_L 0x20
114#define ATV_TOP_CR_CONT_CR_D_LP 0x20
115#define ATV_TOP_CR_CONT_CR_D_BG 0x18
116#define ATV_TOP_CR_CONT_CR_D_DK 0x18
117#define ATV_TOP_CR_CONT_CR_D_I 0x18
118#define ATV_TOP_CR_CONT_CR_I_MN 0x80
119#define ATV_TOP_CR_CONT_CR_I_FM 0x0
120#define ATV_TOP_CR_CONT_CR_I_L 0x80
121#define ATV_TOP_CR_CONT_CR_I_LP 0x80
122#define ATV_TOP_CR_CONT_CR_I_BG 0x80
123#define ATV_TOP_CR_CONT_CR_I_DK 0x80
124#define ATV_TOP_CR_CONT_CR_I_I 0x80
125#define ATV_TOP_CR_CONT_CR_P_MN 0x4
126#define ATV_TOP_CR_CONT_CR_P_FM 0x0
127#define ATV_TOP_CR_CONT_CR_P_L 0x4
128#define ATV_TOP_CR_CONT_CR_P_LP 0x4
129#define ATV_TOP_CR_CONT_CR_P_BG 0x4
130#define ATV_TOP_CR_CONT_CR_P_DK 0x4
131#define ATV_TOP_CR_CONT_CR_P_I 0x4
132#define ATV_TOP_CR_OVM_TH_MN 0xA0
133#define ATV_TOP_CR_OVM_TH_FM 0x0
134#define ATV_TOP_CR_OVM_TH_L 0xA0
135#define ATV_TOP_CR_OVM_TH_LP 0xA0
136#define ATV_TOP_CR_OVM_TH_BG 0xA0
137#define ATV_TOP_CR_OVM_TH_DK 0xA0
138#define ATV_TOP_CR_OVM_TH_I 0xA0
139#define ATV_TOP_EQU0_EQU_C0_FM 0x0
140#define ATV_TOP_EQU0_EQU_C0_L 0x3
141#define ATV_TOP_EQU0_EQU_C0_LP 0x3
142#define ATV_TOP_EQU0_EQU_C0_BG 0x7
143#define ATV_TOP_EQU0_EQU_C0_DK 0x0
144#define ATV_TOP_EQU0_EQU_C0_I 0x3
145#define ATV_TOP_EQU1_EQU_C1_FM 0x0
146#define ATV_TOP_EQU1_EQU_C1_L 0x1F6
147#define ATV_TOP_EQU1_EQU_C1_LP 0x1F6
148#define ATV_TOP_EQU1_EQU_C1_BG 0x197
149#define ATV_TOP_EQU1_EQU_C1_DK 0x198
150#define ATV_TOP_EQU1_EQU_C1_I 0x1F6
151#define ATV_TOP_EQU2_EQU_C2_FM 0x0
152#define ATV_TOP_EQU2_EQU_C2_L 0x28
153#define ATV_TOP_EQU2_EQU_C2_LP 0x28
154#define ATV_TOP_EQU2_EQU_C2_BG 0xC5
155#define ATV_TOP_EQU2_EQU_C2_DK 0xB0
156#define ATV_TOP_EQU2_EQU_C2_I 0x28
157#define ATV_TOP_EQU3_EQU_C3_FM 0x0
158#define ATV_TOP_EQU3_EQU_C3_L 0x192
159#define ATV_TOP_EQU3_EQU_C3_LP 0x192
160#define ATV_TOP_EQU3_EQU_C3_BG 0x12E
161#define ATV_TOP_EQU3_EQU_C3_DK 0x18E
162#define ATV_TOP_EQU3_EQU_C3_I 0x192
163#define ATV_TOP_STD_MODE_MN 0x0
164#define ATV_TOP_STD_MODE_FM 0x1
165#define ATV_TOP_STD_MODE_L 0x0
166#define ATV_TOP_STD_MODE_LP 0x0
167#define ATV_TOP_STD_MODE_BG 0x0
168#define ATV_TOP_STD_MODE_DK 0x0
169#define ATV_TOP_STD_MODE_I 0x0
170#define ATV_TOP_STD_VID_POL_MN 0x0
171#define ATV_TOP_STD_VID_POL_FM 0x0
172#define ATV_TOP_STD_VID_POL_L 0x2
173#define ATV_TOP_STD_VID_POL_LP 0x2
174#define ATV_TOP_STD_VID_POL_BG 0x0
175#define ATV_TOP_STD_VID_POL_DK 0x0
176#define ATV_TOP_STD_VID_POL_I 0x0
177#define ATV_TOP_VID_AMP_MN 0x380
178#define ATV_TOP_VID_AMP_FM 0x0
179#define ATV_TOP_VID_AMP_L 0xF50
180#define ATV_TOP_VID_AMP_LP 0xF50
181#define ATV_TOP_VID_AMP_BG 0x380
182#define ATV_TOP_VID_AMP_DK 0x394
183#define ATV_TOP_VID_AMP_I 0x3D8
184#define IQM_CF_OUT_ENA_OFDM__M 0x4
185#define IQM_FS_ADJ_SEL_B_QAM 0x1
186#define IQM_FS_ADJ_SEL_B_OFF 0x0
187#define IQM_FS_ADJ_SEL_B_VSB 0x2
188#define IQM_RC_ADJ_SEL_B_OFF 0x0
189#define IQM_RC_ADJ_SEL_B_QAM 0x1
190#define IQM_RC_ADJ_SEL_B_VSB 0x2
191
192
193#include "drx_driver_version.h"
194
195
196#ifdef DRX_DEBUG
197#include <stdio.h>
198#endif
199
200
201
202
203
204
205
206
207#ifndef DRXJ_WAKE_UP_KEY
208#define DRXJ_WAKE_UP_KEY (demod->my_i2c_dev_addr->i2c_addr)
209#endif
210
211
212
213
214
215#define DRXJ_DEF_I2C_ADDR (0x52)
216
217
218
219
220
221#define DRXJ_DEF_DEMOD_DEV_ID (1)
222
223
224
225
226
227#define DRXJ_SCAN_TIMEOUT 1000
228
229
230
231
232
233
234
235#define HI_I2C_DELAY 42
236
237
238
239
240
241
242
243#define HI_I2C_BRIDGE_DELAY 750
244
245
246
247
248#define VSB_TOP_MEASUREMENT_PERIOD 64
249#define SYMBOLS_PER_SEGMENT 832
250
251
252
253
254
255#define DRXJ_QAM_SL_SIG_POWER_QAM_UNKNOWN 0
256#define DRXJ_QAM_SL_SIG_POWER_QPSK 32768
257#define DRXJ_QAM_SL_SIG_POWER_QAM8 24576
258#define DRXJ_QAM_SL_SIG_POWER_QAM16 40960
259#define DRXJ_QAM_SL_SIG_POWER_QAM32 20480
260#define DRXJ_QAM_SL_SIG_POWER_QAM64 43008
261#define DRXJ_QAM_SL_SIG_POWER_QAM128 20992
262#define DRXJ_QAM_SL_SIG_POWER_QAM256 43520
263
264
265
266#ifndef DRXJ_QAM_SYMBOLRATE_MIN
267#define DRXJ_QAM_SYMBOLRATE_MIN (520000)
268#endif
269
270
271
272
273#ifndef DRXJ_QAM_SYMBOLRATE_MAX
274#define DRXJ_QAM_SYMBOLRATE_MAX (7233000)
275#endif
276
277
278
279
280
281#ifndef DRXJ_QAM_MAX_WAITTIME
282#define DRXJ_QAM_MAX_WAITTIME 900
283#endif
284
285#ifndef DRXJ_QAM_FEC_LOCK_WAITTIME
286#define DRXJ_QAM_FEC_LOCK_WAITTIME 150
287#endif
288
289#ifndef DRXJ_QAM_DEMOD_LOCK_EXT_WAITTIME
290#define DRXJ_QAM_DEMOD_LOCK_EXT_WAITTIME 200
291#endif
292
293
294
295
296
297#define DRX_SCU_READY 0
298#define DRXJ_MAX_WAITTIME 100
299#define FEC_RS_MEASUREMENT_PERIOD 12894
300#define FEC_RS_MEASUREMENT_PRESCALE 1
301
302
303
304
305
306#ifndef DRXJ_AUD_MAX_FM_DEVIATION
307#define DRXJ_AUD_MAX_FM_DEVIATION 100
308#endif
309
310
311
312
313#ifndef DRXJ_AUD_MAX_NICAM_PRESCALE
314#define DRXJ_AUD_MAX_NICAM_PRESCALE (9)
315#endif
316
317
318
319
320#ifndef DRXJ_AUD_MAX_WAITTIME
321#define DRXJ_AUD_MAX_WAITTIME 250
322#endif
323
324
325#define DRXJ_ATV_CHANGED_COEF (0x00000001UL)
326#define DRXJ_ATV_CHANGED_PEAK_FLT (0x00000008UL)
327#define DRXJ_ATV_CHANGED_NOISE_FLT (0x00000010UL)
328#define DRXJ_ATV_CHANGED_OUTPUT (0x00000020UL)
329#define DRXJ_ATV_CHANGED_SIF_ATT (0x00000040UL)
330
331
332#define DRX_UIO_MODE_FIRMWARE_SMA DRX_UIO_MODE_FIRMWARE0
333#define DRX_UIO_MODE_FIRMWARE_SAW DRX_UIO_MODE_FIRMWARE1
334
335
336
337
338
339
340#define DRX_UCODE_MAGIC_WORD ((((u16)'H')<<8)+((u16)'L'))
341
342
343#define DRX_UCODE_CRC_FLAG (0x0001)
344
345
346
347
348
349#define DRX_UCODE_MAX_BUF_SIZE (DRXDAP_MAX_RCHUNKSIZE)
350
351#if DRX_UCODE_MAX_BUF_SIZE & 1
352#error DRX_UCODE_MAX_BUF_SIZE must be an even number
353#endif
354
355
356
357
358
359#define DRX_ISPOWERDOWNMODE(mode) ((mode == DRX_POWER_MODE_9) || \
360 (mode == DRX_POWER_MODE_10) || \
361 (mode == DRX_POWER_MODE_11) || \
362 (mode == DRX_POWER_MODE_12) || \
363 (mode == DRX_POWER_MODE_13) || \
364 (mode == DRX_POWER_MODE_14) || \
365 (mode == DRX_POWER_MODE_15) || \
366 (mode == DRX_POWER_MODE_16) || \
367 (mode == DRX_POWER_DOWN))
368
369
370#define DRXJ_PIN_SAFE_MODE 0x0000
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391#define AUD_DEM_RAM_MODUS_HI__A 0x10204A3
392#define AUD_DEM_RAM_MODUS_HI__M 0xF000
393
394#define AUD_DEM_RAM_MODUS_LO__A 0x10204A4
395#define AUD_DEM_RAM_MODUS_LO__M 0x0FFF
396
397
398
399
400#define AUD_DEM_RAM_I2S_CONFIG1__A 0x10204B1
401#define AUD_DEM_RAM_I2S_CONFIG2__A 0x10204B2
402
403
404
405
406#define AUD_DEM_RAM_DCO_B_HI__A 0x1020461
407#define AUD_DEM_RAM_DCO_B_LO__A 0x1020462
408#define AUD_DEM_RAM_DCO_A_HI__A 0x1020463
409#define AUD_DEM_RAM_DCO_A_LO__A 0x1020464
410
411
412
413
414#define AUD_DEM_RAM_NICAM_THRSHLD__A 0x102045A
415#define AUD_DEM_RAM_A2_THRSHLD__A 0x10204BB
416#define AUD_DEM_RAM_BTSC_THRSHLD__A 0x10204A6
417
418
419
420
421#define AUD_DEM_RAM_CM_A_THRSHLD__A 0x10204AF
422#define AUD_DEM_RAM_CM_B_THRSHLD__A 0x10204B0
423
424
425
426
427#ifdef AUD_DEM_WR_FM_MATRIX__A
428#undef AUD_DEM_WR_FM_MATRIX__A
429#endif
430#define AUD_DEM_WR_FM_MATRIX__A 0x105006F
431
432
433
434
435
436#define AUD_VOLUME_ZERO_DB 115
437#define AUD_VOLUME_DB_MIN -60
438#define AUD_VOLUME_DB_MAX 12
439#define AUD_CARRIER_STRENGTH_QP_0DB 0x4000
440#define AUD_CARRIER_STRENGTH_QP_0DB_LOG10T100 421
441#define AUD_MAX_AVC_REF_LEVEL 15
442#define AUD_I2S_FREQUENCY_MAX 48000UL
443#define AUD_I2S_FREQUENCY_MIN 12000UL
444#define AUD_RDS_ARRAY_SIZE 18
445
446
447
448
449#ifndef DRX_AUD_MAX_FM_DEVIATION
450#define DRX_AUD_MAX_FM_DEVIATION (100)
451#endif
452
453
454
455
456#ifndef DRX_AUD_MAX_NICAM_PRESCALE
457#define DRX_AUD_MAX_NICAM_PRESCALE (9)
458#endif
459
460
461
462#define SIO_PDR_I2S_CL_CFG_MODE__MASTER 0x0004
463#define SIO_PDR_I2S_CL_CFG_DRIVE__MASTER 0x0008
464#define SIO_PDR_I2S_CL_CFG_MODE__SLAVE 0x0004
465#define SIO_PDR_I2S_CL_CFG_DRIVE__SLAVE 0x0000
466
467#define SIO_PDR_I2S_DA_CFG_MODE__MASTER 0x0003
468#define SIO_PDR_I2S_DA_CFG_DRIVE__MASTER 0x0008
469#define SIO_PDR_I2S_DA_CFG_MODE__SLAVE 0x0003
470#define SIO_PDR_I2S_DA_CFG_DRIVE__SLAVE 0x0008
471
472#define SIO_PDR_I2S_WS_CFG_MODE__MASTER 0x0004
473#define SIO_PDR_I2S_WS_CFG_DRIVE__MASTER 0x0008
474#define SIO_PDR_I2S_WS_CFG_MODE__SLAVE 0x0004
475#define SIO_PDR_I2S_WS_CFG_DRIVE__SLAVE 0x0000
476
477
478
479
480
481
482
483
484
485
486
487#define DRXJ_16TO8(x) ((u8) (((u16)x) & 0xFF)), \
488 ((u8)((((u16)x)>>8)&0xFF))
489
490
491
492
493
494#define DRXJ_8TO16(x) ((u16) (x[0] | (x[1] << 8)))
495
496
497
498
499
500
501
502
503
504
505
506
507#define DRXJ_MAX_RETRIES (100)
508
509
510
511
512
513#define DRXJ_ISATVSTD(std) ((std == DRX_STANDARD_PAL_SECAM_BG) || \
514 (std == DRX_STANDARD_PAL_SECAM_DK) || \
515 (std == DRX_STANDARD_PAL_SECAM_I) || \
516 (std == DRX_STANDARD_PAL_SECAM_L) || \
517 (std == DRX_STANDARD_PAL_SECAM_LP) || \
518 (std == DRX_STANDARD_NTSC) || \
519 (std == DRX_STANDARD_FM))
520
521#define DRXJ_ISQAMSTD(std) ((std == DRX_STANDARD_ITU_A) || \
522 (std == DRX_STANDARD_ITU_B) || \
523 (std == DRX_STANDARD_ITU_C) || \
524 (std == DRX_STANDARD_ITU_D))
525
526
527
528
529
530
531
532
533static int drxdap_fasi_read_block(struct i2c_device_addr *dev_addr,
534 u32 addr,
535 u16 datasize,
536 u8 *data, u32 flags);
537
538
539static int drxj_dap_read_modify_write_reg16(struct i2c_device_addr *dev_addr,
540 u32 waddr,
541 u32 raddr,
542 u16 wdata, u16 *rdata);
543
544static int drxj_dap_read_reg16(struct i2c_device_addr *dev_addr,
545 u32 addr,
546 u16 *data, u32 flags);
547
548static int drxdap_fasi_read_reg32(struct i2c_device_addr *dev_addr,
549 u32 addr,
550 u32 *data, u32 flags);
551
552static int drxdap_fasi_write_block(struct i2c_device_addr *dev_addr,
553 u32 addr,
554 u16 datasize,
555 u8 *data, u32 flags);
556
557static int drxj_dap_write_reg16(struct i2c_device_addr *dev_addr,
558 u32 addr,
559 u16 data, u32 flags);
560
561static int drxdap_fasi_write_reg32(struct i2c_device_addr *dev_addr,
562 u32 addr,
563 u32 data, u32 flags);
564
565static struct drxj_data drxj_data_g = {
566 false,
567 false,
568 false,
569 false,
570 false,
571 false,
572 false,
573 false,
574 0,
575
576
577 false,
578
579 DRX_STANDARD_UNKNOWN,
580 DRX_CONSTELLATION_AUTO,
581 0,
582 DRX_BANDWIDTH_UNKNOWN,
583 DRX_MIRROR_NO,
584
585
586
587
588 4000000,
589 5,
590 4,
591 0xFFFF,
592 204 * 8,
593 1,
594 FEC_RS_MEASUREMENT_PERIOD,
595 true,
596 0,
597
598
599 0,
600 0,
601 0,
602 0,
603 0,
604
605 DRX_UIO_MODE_DISABLE,
606 DRX_UIO_MODE_DISABLE,
607 DRX_UIO_MODE_DISABLE,
608 DRX_UIO_MODE_DISABLE,
609
610 0UL,
611 false,
612
613 0UL,
614
615
616
617
618
619
620
621
622
623 0UL,
624
625 {-5,
626 ATV_TOP_EQU0_EQU_C0_FM,
627 ATV_TOP_EQU0_EQU_C0_L,
628 ATV_TOP_EQU0_EQU_C0_LP,
629 ATV_TOP_EQU0_EQU_C0_BG,
630 ATV_TOP_EQU0_EQU_C0_DK,
631 ATV_TOP_EQU0_EQU_C0_I},
632
633 {-50,
634 ATV_TOP_EQU1_EQU_C1_FM,
635 ATV_TOP_EQU1_EQU_C1_L,
636 ATV_TOP_EQU1_EQU_C1_LP,
637 ATV_TOP_EQU1_EQU_C1_BG,
638 ATV_TOP_EQU1_EQU_C1_DK,
639 ATV_TOP_EQU1_EQU_C1_I},
640
641 {210,
642 ATV_TOP_EQU2_EQU_C2_FM,
643 ATV_TOP_EQU2_EQU_C2_L,
644 ATV_TOP_EQU2_EQU_C2_LP,
645 ATV_TOP_EQU2_EQU_C2_BG,
646 ATV_TOP_EQU2_EQU_C2_DK,
647 ATV_TOP_EQU2_EQU_C2_I},
648
649 {-160,
650 ATV_TOP_EQU3_EQU_C3_FM,
651 ATV_TOP_EQU3_EQU_C3_L,
652 ATV_TOP_EQU3_EQU_C3_LP,
653 ATV_TOP_EQU3_EQU_C3_BG,
654 ATV_TOP_EQU3_EQU_C3_DK,
655 ATV_TOP_EQU3_EQU_C3_I},
656 false,
657 ATV_TOP_VID_PEAK__PRE,
658 ATV_TOP_NOISE_TH__PRE,
659 true,
660 false,
661 DRXJ_SIF_ATTENUATION_0DB,
662 {
663 DRX_STANDARD_ITU_B,
664 DRX_AGC_CTRL_AUTO,
665 0,
666 0,
667 0xFFFF,
668 0x0000,
669 0x0000,
670 0x0000
671 },
672 {
673 DRX_STANDARD_ITU_B,
674 DRX_AGC_CTRL_AUTO,
675 0,
676 0,
677 0xFFFF,
678 0x0000,
679 0x0000,
680 0x0000
681 },
682 {
683 DRX_STANDARD_8VSB,
684 DRX_AGC_CTRL_AUTO,
685 0,
686 0,
687 0xFFFF,
688 0x0000,
689 0x0000,
690 0x0000
691 },
692 {
693 DRX_STANDARD_8VSB,
694 DRX_AGC_CTRL_AUTO,
695 0,
696 0,
697 0xFFFF,
698 0x0000,
699 0x0000,
700 0x0000
701 },
702 0,
703 0,
704 {
705 DRX_STANDARD_ITU_B,
706 0,
707 false
708 },
709 {
710 DRX_STANDARD_8VSB,
711 0,
712 false
713 },
714
715
716#ifndef _CH_
717 {
718 "01234567890",
719 "01234567890"
720 },
721 {
722 {
723 DRX_MODULE_UNKNOWN,
724 (char *)(NULL),
725 0,
726 0,
727 0,
728 (char *)(NULL)
729 },
730 {
731 DRX_MODULE_UNKNOWN,
732 (char *)(NULL),
733 0,
734 0,
735 0,
736 (char *)(NULL)
737 }
738 },
739 {
740 {
741 (struct drx_version *) (NULL),
742 (struct drx_version_list *) (NULL)
743 },
744 {
745 (struct drx_version *) (NULL),
746 (struct drx_version_list *) (NULL)
747 }
748 },
749#endif
750 false,
751
752 {
753 12000,
754 9300,
755 6600,
756 5280,
757 3700,
758 3000,
759 2000,
760 0},
761 false,
762 0,
763 false,
764 false,
765 DRXJ_MPEGOUTPUT_CLOCK_RATE_AUTO,
766 DRXJ_MPEG_START_WIDTH_1CLKCYC,
767
768
769 {
770 DRX_STANDARD_NTSC,
771 7,
772 true
773 },
774 {
775 DRX_STANDARD_NTSC,
776 DRX_AGC_CTRL_AUTO,
777 0,
778 0,
779 0,
780 3,
781 9500,
782 4000
783 },
784 {
785 DRX_STANDARD_NTSC,
786 DRX_AGC_CTRL_AUTO,
787 0,
788 0,
789 0,
790 3,
791 2400,
792 0
793 },
794 140,
795 0,
796
797 false,
798 SIO_PDR_GPIO_CFG__PRE,
799 SIO_PDR_VSYNC_CFG__PRE,
800 SIO_PDR_SMA_RX_CFG__PRE,
801 SIO_PDR_SMA_TX_CFG__PRE,
802
803 4,
804 DRXJ_OOB_LO_POW_MINUS10DB,
805 {
806 false
807 },
808};
809
810
811
812
813
814static struct i2c_device_addr drxj_default_addr_g = {
815 DRXJ_DEF_I2C_ADDR,
816 DRXJ_DEF_DEMOD_DEV_ID
817};
818
819
820
821
822
823static struct drx_common_attr drxj_default_comm_attr_g = {
824 NULL,
825 true,
826 {0},
827
828 44000,
829 (151875 - 0),
830 0,
831 0,
832 false,
833 {
834
835 true,
836 false,
837 false,
838 false,
839 false,
840 false,
841 false,
842 false,
843 true,
844
845
846 19392658UL,
847
848 DRX_MPEG_STR_WIDTH_1
849 },
850
851
852
853 false,
854
855
856 NULL,
857 0,
858 0,
859 false,
860 0,
861 0,
862 NULL,
863 NULL,
864 0,
865 DRXJ_DEMOD_LOCK,
866 false,
867
868
869 DRX_POWER_UP,
870
871
872 1,
873 0L,
874 0L,
875 false,
876 false,
877 false,
878
879 {
880 0UL
881 },
882 DRX_STANDARD_UNKNOWN,
883 DRX_STANDARD_UNKNOWN,
884 DRX_STANDARD_UNKNOWN,
885 false,
886 0UL,
887 0
888};
889
890
891
892
893
894static struct drx_demod_instance drxj_default_demod_g = {
895 &drxj_default_addr_g,
896 &drxj_default_comm_attr_g,
897 &drxj_data_g
898};
899
900
901
902
903
904
905
906static struct drx_aud_data drxj_default_aud_data_g = {
907 false,
908 DRX_AUD_STANDARD_AUTO,
909
910
911 {
912 false,
913 48000,
914 DRX_I2S_MODE_MASTER,
915 DRX_I2S_WORDLENGTH_32,
916 DRX_I2S_POLARITY_RIGHT,
917 DRX_I2S_FORMAT_WS_WITH_DATA
918 },
919
920 {
921 true,
922 0,
923 DRX_AUD_AVC_OFF,
924 0,
925 DRX_AUD_AVC_MAX_GAIN_12DB,
926 DRX_AUD_AVC_MAX_ATTEN_24DB,
927 0,
928 0
929 },
930 DRX_AUD_AUTO_SOUND_SELECT_ON_CHANGE_ON,
931
932 {
933 440,
934 12,
935 700,
936 },
937
938 {
939
940 {
941 42,
942 DRX_NO_CARRIER_NOISE,
943 0,
944 0
945 },
946
947 {
948 42,
949 DRX_NO_CARRIER_MUTE,
950 0,
951 0
952 },
953
954 },
955
956 {
957 DRX_AUD_SRC_STEREO_OR_A,
958 DRX_AUD_I2S_MATRIX_STEREO,
959 DRX_AUD_FM_MATRIX_SOUND_A
960 },
961 DRX_AUD_DEVIATION_NORMAL,
962 DRX_AUD_AVSYNC_OFF,
963
964
965 {
966 DRX_AUD_MAX_FM_DEVIATION,
967 DRX_AUD_MAX_NICAM_PRESCALE
968 },
969 DRX_AUD_FM_DEEMPH_75US,
970 DRX_BTSC_STEREO,
971 0,
972 false
973};
974
975
976
977
978struct drxjeq_stat {
979 u16 eq_mse;
980 u8 eq_mode;
981 u8 eq_ctrl;
982 u8 eq_stat;
983};
984
985
986struct drxj_hi_cmd {
987 u16 cmd;
988 u16 param1;
989 u16 param2;
990 u16 param3;
991 u16 param4;
992 u16 param5;
993 u16 param6;
994};
995
996
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009struct drxu_code_block_hdr {
1010 u32 addr;
1011 u16 size;
1012 u16 flags;
1013 u16 CRC;
1014};
1015
1016
1017
1018
1019
1020static int
1021hi_command(struct i2c_device_addr *dev_addr,
1022 const struct drxj_hi_cmd *cmd, u16 *result);
1023
1024static int
1025ctrl_lock_status(struct drx_demod_instance *demod, enum drx_lock_status *lock_stat);
1026
1027static int
1028ctrl_power_mode(struct drx_demod_instance *demod, enum drx_power_mode *mode);
1029
1030static int power_down_aud(struct drx_demod_instance *demod);
1031
1032static int
1033ctrl_set_cfg_pre_saw(struct drx_demod_instance *demod, struct drxj_cfg_pre_saw *pre_saw);
1034
1035static int
1036ctrl_set_cfg_afe_gain(struct drx_demod_instance *demod, struct drxj_cfg_afe_gain *afe_gain);
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
1054
1055
1056
1057
1058
1059
1060
1061
1062
1063
1064
1065
1066
1067static u32 frac28(u32 N, u32 D)
1068{
1069 int i = 0;
1070 u32 Q1 = 0;
1071 u32 R0 = 0;
1072
1073 R0 = (N % D) << 4;
1074 Q1 = N / D;
1075
1076
1077
1078 for (i = 0; i < 7; i++) {
1079 Q1 = (Q1 << 4) | R0 / D;
1080 R0 = (R0 % D) << 4;
1081 }
1082
1083 if ((R0 >> 3) >= D)
1084 Q1++;
1085
1086 return Q1;
1087}
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
1100
1101
1102
1103
1104
1105static u32 log1_times100(u32 x)
1106{
1107 static const u8 scale = 15;
1108 static const u8 index_width = 5;
1109
1110
1111
1112
1113
1114 static const u32 log2lut[] = {
1115 0,
1116 290941,
1117 573196,
1118 847269,
1119 1113620,
1120 1372674,
1121 1624818,
1122 1870412,
1123 2109788,
1124 2343253,
1125 2571091,
1126 2793569,
1127 3010931,
1128 3223408,
1129 3431216,
1130 3634553,
1131 3833610,
1132 4028562,
1133 4219576,
1134 4406807,
1135 4590402,
1136 4770499,
1137 4947231,
1138 5120719,
1139 5291081,
1140 5458428,
1141 5622864,
1142 5784489,
1143 5943398,
1144 6099680,
1145 6253421,
1146 6404702,
1147 6553600,
1148 };
1149
1150 u8 i = 0;
1151 u32 y = 0;
1152 u32 d = 0;
1153 u32 k = 0;
1154 u32 r = 0;
1155
1156 if (x == 0)
1157 return 0;
1158
1159
1160
1161 if ((x & (((u32) (-1)) << (scale + 1))) == 0) {
1162 for (k = scale; k > 0; k--) {
1163 if (x & (((u32) 1) << scale))
1164 break;
1165 x <<= 1;
1166 }
1167 } else {
1168 for (k = scale; k < 31; k++) {
1169 if ((x & (((u32) (-1)) << (scale + 1))) == 0)
1170 break;
1171 x >>= 1;
1172 }
1173 }
1174
1175
1176
1177
1178
1179 y = k * ((((u32) 1) << scale) * 200);
1180
1181
1182 x &= ((((u32) 1) << scale) - 1);
1183
1184 i = (u8) (x >> (scale - index_width));
1185
1186 d = x & ((((u32) 1) << (scale - index_width)) - 1);
1187
1188 y += log2lut[i] +
1189 ((d * (log2lut[i + 1] - log2lut[i])) >> (scale - index_width));
1190
1191 y /= 108853;
1192 r = (y >> 1);
1193
1194 if (y & ((u32)1))
1195 r++;
1196
1197 return r;
1198
1199}
1200
1201
1202
1203
1204
1205
1206
1207
1208
1209
1210
1211static u32 frac_times1e6(u32 N, u32 D)
1212{
1213 u32 remainder = 0;
1214 u32 frac = 0;
1215
1216
1217
1218
1219
1220
1221
1222
1223 frac = (((u32) N) * (1000000 >> 4)) / D;
1224 frac <<= 4;
1225 remainder = (((u32) N) * (1000000 >> 4)) % D;
1226 remainder <<= 4;
1227 frac += remainder / D;
1228 remainder = remainder % D;
1229 if ((remainder * 2) > D)
1230 frac++;
1231
1232 return frac;
1233}
1234
1235
1236
1237
1238
1239
1240
1241
1242
1243#if 0
1244
1245static const u16 nicam_presc_table_val[43] = {
1246 1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 4, 4,
1247 5, 5, 6, 6, 7, 8, 9, 10, 11, 13, 14, 16,
1248 18, 20, 23, 25, 28, 32, 36, 40, 45,
1249 51, 57, 64, 71, 80, 90, 101, 113, 127
1250};
1251#endif
1252
1253
1254
1255
1256
1257
1258
1259
1260
1261
1262
1263
1264
1265
1266
1267
1268
1269
1270
1271
1272
1273
1274
1275
1276
1277
1278
1279#define DRXJ_ISAUDWRITE(addr) (((((addr)>>16)&1) == 1) ? true : false)
1280#define DRXJ_DAP_AUDTRIF_TIMEOUT 80
1281
1282
1283
1284
1285
1286
1287
1288
1289
1290
1291
1292static
1293bool is_handled_by_aud_tr_if(u32 addr)
1294{
1295 bool retval = false;
1296
1297 if ((DRXDAP_FASI_ADDR2BLOCK(addr) == 4) &&
1298 (DRXDAP_FASI_ADDR2BANK(addr) > 1) &&
1299 (DRXDAP_FASI_ADDR2BANK(addr) < 6)) {
1300 retval = true;
1301 }
1302
1303 return retval;
1304}
1305
1306
1307
1308int drxbsp_i2c_write_read(struct i2c_device_addr *w_dev_addr,
1309 u16 w_count,
1310 u8 *wData,
1311 struct i2c_device_addr *r_dev_addr,
1312 u16 r_count, u8 *r_data)
1313{
1314 struct drx39xxj_state *state;
1315 struct i2c_msg msg[2];
1316 unsigned int num_msgs;
1317
1318 if (w_dev_addr == NULL) {
1319
1320 state = r_dev_addr->user_data;
1321 msg[0].addr = r_dev_addr->i2c_addr >> 1;
1322 msg[0].flags = I2C_M_RD;
1323 msg[0].buf = r_data;
1324 msg[0].len = r_count;
1325 num_msgs = 1;
1326 } else if (r_dev_addr == NULL) {
1327
1328 state = w_dev_addr->user_data;
1329 msg[0].addr = w_dev_addr->i2c_addr >> 1;
1330 msg[0].flags = 0;
1331 msg[0].buf = wData;
1332 msg[0].len = w_count;
1333 num_msgs = 1;
1334 } else {
1335
1336 state = w_dev_addr->user_data;
1337 msg[0].addr = w_dev_addr->i2c_addr >> 1;
1338 msg[0].flags = 0;
1339 msg[0].buf = wData;
1340 msg[0].len = w_count;
1341 msg[1].addr = r_dev_addr->i2c_addr >> 1;
1342 msg[1].flags = I2C_M_RD;
1343 msg[1].buf = r_data;
1344 msg[1].len = r_count;
1345 num_msgs = 2;
1346 }
1347
1348 if (state->i2c == NULL) {
1349 pr_err("i2c was zero, aborting\n");
1350 return 0;
1351 }
1352 if (i2c_transfer(state->i2c, msg, num_msgs) != num_msgs) {
1353 pr_warn("drx3933: I2C write/read failed\n");
1354 return -EREMOTEIO;
1355 }
1356
1357#ifdef DJH_DEBUG
1358 if (w_dev_addr == NULL || r_dev_addr == NULL)
1359 return 0;
1360
1361 state = w_dev_addr->user_data;
1362
1363 if (state->i2c == NULL)
1364 return 0;
1365
1366 msg[0].addr = w_dev_addr->i2c_addr;
1367 msg[0].flags = 0;
1368 msg[0].buf = wData;
1369 msg[0].len = w_count;
1370 msg[1].addr = r_dev_addr->i2c_addr;
1371 msg[1].flags = I2C_M_RD;
1372 msg[1].buf = r_data;
1373 msg[1].len = r_count;
1374 num_msgs = 2;
1375
1376 pr_debug("drx3933 i2c operation addr=%x i2c=%p, wc=%x rc=%x\n",
1377 w_dev_addr->i2c_addr, state->i2c, w_count, r_count);
1378
1379 if (i2c_transfer(state->i2c, msg, 2) != 2) {
1380 pr_warn("drx3933: I2C write/read failed\n");
1381 return -EREMOTEIO;
1382 }
1383#endif
1384 return 0;
1385}
1386
1387
1388
1389
1390
1391
1392
1393
1394
1395
1396
1397
1398
1399
1400
1401
1402
1403
1404
1405
1406
1407
1408
1409
1410
1411
1412
1413
1414static int drxdap_fasi_read_block(struct i2c_device_addr *dev_addr,
1415 u32 addr,
1416 u16 datasize,
1417 u8 *data, u32 flags)
1418{
1419 u8 buf[4];
1420 u16 bufx;
1421 int rc;
1422 u16 overhead_size = 0;
1423
1424
1425 if (dev_addr == NULL)
1426 return -EINVAL;
1427
1428 overhead_size = (IS_I2C_10BIT(dev_addr->i2c_addr) ? 2 : 1) +
1429 (DRXDAP_FASI_LONG_FORMAT(addr) ? 4 : 2);
1430
1431 if ((DRXDAP_FASI_OFFSET_TOO_LARGE(addr)) ||
1432 ((!(DRXDAPFASI_LONG_ADDR_ALLOWED)) &&
1433 DRXDAP_FASI_LONG_FORMAT(addr)) ||
1434 (overhead_size > (DRXDAP_MAX_WCHUNKSIZE)) ||
1435 ((datasize != 0) && (data == NULL)) || ((datasize & 1) == 1)) {
1436 return -EINVAL;
1437 }
1438
1439
1440 flags &= (~DRXDAP_FASI_RMW & ~DRXDAP_FASI_MODEFLAGS);
1441#if DRXDAP_SINGLE_MASTER
1442 flags |= DRXDAP_FASI_SINGLE_MASTER;
1443#endif
1444
1445
1446 do {
1447 u16 todo = (datasize < DRXDAP_MAX_RCHUNKSIZE ?
1448 datasize : DRXDAP_MAX_RCHUNKSIZE);
1449
1450 bufx = 0;
1451
1452 addr &= ~DRXDAP_FASI_FLAGS;
1453 addr |= flags;
1454
1455#if ((DRXDAPFASI_LONG_ADDR_ALLOWED == 1) && (DRXDAPFASI_SHORT_ADDR_ALLOWED == 1))
1456
1457 if (DRXDAP_FASI_LONG_FORMAT(addr)) {
1458#endif
1459#if (DRXDAPFASI_LONG_ADDR_ALLOWED == 1)
1460 buf[bufx++] = (u8) (((addr << 1) & 0xFF) | 0x01);
1461 buf[bufx++] = (u8) ((addr >> 16) & 0xFF);
1462 buf[bufx++] = (u8) ((addr >> 24) & 0xFF);
1463 buf[bufx++] = (u8) ((addr >> 7) & 0xFF);
1464#endif
1465#if ((DRXDAPFASI_LONG_ADDR_ALLOWED == 1) && (DRXDAPFASI_SHORT_ADDR_ALLOWED == 1))
1466 } else {
1467#endif
1468#if (DRXDAPFASI_SHORT_ADDR_ALLOWED == 1)
1469 buf[bufx++] = (u8) ((addr << 1) & 0xFF);
1470 buf[bufx++] =
1471 (u8) (((addr >> 16) & 0x0F) |
1472 ((addr >> 18) & 0xF0));
1473#endif
1474#if ((DRXDAPFASI_LONG_ADDR_ALLOWED == 1) && (DRXDAPFASI_SHORT_ADDR_ALLOWED == 1))
1475 }
1476#endif
1477
1478#if DRXDAP_SINGLE_MASTER
1479
1480
1481
1482
1483 rc = drxbsp_i2c_write_read(dev_addr, bufx, buf,
1484 NULL, 0, NULL);
1485 if (rc == 0)
1486 rc = drxbsp_i2c_write_read(NULL, 0, NULL, dev_addr, todo, data);
1487#else
1488
1489 rc = drxbsp_i2c_write_read(dev_addr, bufx, buf, dev_addr, todo,
1490 data);
1491#endif
1492 data += todo;
1493 addr += (todo >> 1);
1494 datasize -= todo;
1495 } while (datasize && rc == 0);
1496
1497 return rc;
1498}
1499
1500
1501
1502
1503
1504
1505
1506
1507
1508
1509
1510
1511
1512
1513
1514
1515
1516
1517
1518
1519static int drxdap_fasi_read_reg16(struct i2c_device_addr *dev_addr,
1520 u32 addr,
1521 u16 *data, u32 flags)
1522{
1523 u8 buf[sizeof(*data)];
1524 int rc;
1525
1526 if (!data)
1527 return -EINVAL;
1528
1529 rc = drxdap_fasi_read_block(dev_addr, addr, sizeof(*data), buf, flags);
1530 *data = buf[0] + (((u16) buf[1]) << 8);
1531 return rc;
1532}
1533
1534
1535
1536
1537
1538
1539
1540
1541
1542
1543
1544
1545
1546
1547
1548
1549
1550
1551
1552static int drxdap_fasi_read_reg32(struct i2c_device_addr *dev_addr,
1553 u32 addr,
1554 u32 *data, u32 flags)
1555{
1556 u8 buf[sizeof(*data)];
1557 int rc;
1558
1559 if (!data)
1560 return -EINVAL;
1561
1562 rc = drxdap_fasi_read_block(dev_addr, addr, sizeof(*data), buf, flags);
1563 *data = (((u32) buf[0]) << 0) +
1564 (((u32) buf[1]) << 8) +
1565 (((u32) buf[2]) << 16) + (((u32) buf[3]) << 24);
1566 return rc;
1567}
1568
1569
1570
1571
1572
1573
1574
1575
1576
1577
1578
1579
1580
1581
1582
1583
1584
1585
1586
1587
1588
1589
1590
1591static int drxdap_fasi_write_block(struct i2c_device_addr *dev_addr,
1592 u32 addr,
1593 u16 datasize,
1594 u8 *data, u32 flags)
1595{
1596 u8 buf[DRXDAP_MAX_WCHUNKSIZE];
1597 int st = -EIO;
1598 int first_err = 0;
1599 u16 overhead_size = 0;
1600 u16 block_size = 0;
1601
1602
1603 if (dev_addr == NULL)
1604 return -EINVAL;
1605
1606 overhead_size = (IS_I2C_10BIT(dev_addr->i2c_addr) ? 2 : 1) +
1607 (DRXDAP_FASI_LONG_FORMAT(addr) ? 4 : 2);
1608
1609 if ((DRXDAP_FASI_OFFSET_TOO_LARGE(addr)) ||
1610 ((!(DRXDAPFASI_LONG_ADDR_ALLOWED)) &&
1611 DRXDAP_FASI_LONG_FORMAT(addr)) ||
1612 (overhead_size > (DRXDAP_MAX_WCHUNKSIZE)) ||
1613 ((datasize != 0) && (data == NULL)) || ((datasize & 1) == 1))
1614 return -EINVAL;
1615
1616 flags &= DRXDAP_FASI_FLAGS;
1617 flags &= ~DRXDAP_FASI_MODEFLAGS;
1618#if DRXDAP_SINGLE_MASTER
1619 flags |= DRXDAP_FASI_SINGLE_MASTER;
1620#endif
1621
1622
1623 block_size = ((DRXDAP_MAX_WCHUNKSIZE) - overhead_size) & ~1;
1624 do {
1625 u16 todo = 0;
1626 u16 bufx = 0;
1627
1628
1629 addr &= ~DRXDAP_FASI_FLAGS;
1630 addr |= flags;
1631#if (((DRXDAPFASI_LONG_ADDR_ALLOWED) == 1) && ((DRXDAPFASI_SHORT_ADDR_ALLOWED) == 1))
1632
1633 if (DRXDAP_FASI_LONG_FORMAT(addr)) {
1634#endif
1635#if ((DRXDAPFASI_LONG_ADDR_ALLOWED) == 1)
1636 buf[bufx++] = (u8) (((addr << 1) & 0xFF) | 0x01);
1637 buf[bufx++] = (u8) ((addr >> 16) & 0xFF);
1638 buf[bufx++] = (u8) ((addr >> 24) & 0xFF);
1639 buf[bufx++] = (u8) ((addr >> 7) & 0xFF);
1640#endif
1641#if (((DRXDAPFASI_LONG_ADDR_ALLOWED) == 1) && ((DRXDAPFASI_SHORT_ADDR_ALLOWED) == 1))
1642 } else {
1643#endif
1644#if ((DRXDAPFASI_SHORT_ADDR_ALLOWED) == 1)
1645 buf[bufx++] = (u8) ((addr << 1) & 0xFF);
1646 buf[bufx++] =
1647 (u8) (((addr >> 16) & 0x0F) |
1648 ((addr >> 18) & 0xF0));
1649#endif
1650#if (((DRXDAPFASI_LONG_ADDR_ALLOWED) == 1) && ((DRXDAPFASI_SHORT_ADDR_ALLOWED) == 1))
1651 }
1652#endif
1653
1654
1655
1656
1657
1658
1659
1660
1661
1662 todo = (block_size < datasize ? block_size : datasize);
1663 if (todo == 0) {
1664 u16 overhead_size_i2c_addr = 0;
1665 u16 data_block_size = 0;
1666
1667 overhead_size_i2c_addr =
1668 (IS_I2C_10BIT(dev_addr->i2c_addr) ? 2 : 1);
1669 data_block_size =
1670 (DRXDAP_MAX_WCHUNKSIZE - overhead_size_i2c_addr) & ~1;
1671
1672
1673 st = drxbsp_i2c_write_read(dev_addr,
1674 (u16) (bufx),
1675 buf,
1676 (struct i2c_device_addr *)(NULL),
1677 0, (u8 *)(NULL));
1678
1679 if ((st != 0) && (first_err == 0)) {
1680
1681 first_err = st;
1682 }
1683 bufx = 0;
1684 todo =
1685 (data_block_size <
1686 datasize ? data_block_size : datasize);
1687 }
1688 memcpy(&buf[bufx], data, todo);
1689
1690 st = drxbsp_i2c_write_read(dev_addr,
1691 (u16) (bufx + todo),
1692 buf,
1693 (struct i2c_device_addr *)(NULL),
1694 0, (u8 *)(NULL));
1695
1696 if ((st != 0) && (first_err == 0)) {
1697
1698 first_err = st;
1699 }
1700 datasize -= todo;
1701 data += todo;
1702 addr += (todo >> 1);
1703 } while (datasize);
1704
1705 return first_err;
1706}
1707
1708
1709
1710
1711
1712
1713
1714
1715
1716
1717
1718
1719
1720
1721
1722
1723
1724
1725static int drxdap_fasi_write_reg16(struct i2c_device_addr *dev_addr,
1726 u32 addr,
1727 u16 data, u32 flags)
1728{
1729 u8 buf[sizeof(data)];
1730
1731 buf[0] = (u8) ((data >> 0) & 0xFF);
1732 buf[1] = (u8) ((data >> 8) & 0xFF);
1733
1734 return drxdap_fasi_write_block(dev_addr, addr, sizeof(data), buf, flags);
1735}
1736
1737
1738
1739
1740
1741
1742
1743
1744
1745
1746
1747
1748
1749
1750
1751
1752
1753
1754
1755
1756
1757
1758
1759
1760
1761
1762static int drxdap_fasi_read_modify_write_reg16(struct i2c_device_addr *dev_addr,
1763 u32 waddr,
1764 u32 raddr,
1765 u16 wdata, u16 *rdata)
1766{
1767 int rc = -EIO;
1768
1769#if (DRXDAPFASI_LONG_ADDR_ALLOWED == 1)
1770 if (rdata == NULL)
1771 return -EINVAL;
1772
1773 rc = drxdap_fasi_write_reg16(dev_addr, waddr, wdata, DRXDAP_FASI_RMW);
1774 if (rc == 0)
1775 rc = drxdap_fasi_read_reg16(dev_addr, raddr, rdata, 0);
1776#endif
1777
1778 return rc;
1779}
1780
1781
1782
1783
1784
1785
1786
1787
1788
1789
1790
1791
1792
1793
1794
1795
1796
1797
1798static int drxdap_fasi_write_reg32(struct i2c_device_addr *dev_addr,
1799 u32 addr,
1800 u32 data, u32 flags)
1801{
1802 u8 buf[sizeof(data)];
1803
1804 buf[0] = (u8) ((data >> 0) & 0xFF);
1805 buf[1] = (u8) ((data >> 8) & 0xFF);
1806 buf[2] = (u8) ((data >> 16) & 0xFF);
1807 buf[3] = (u8) ((data >> 24) & 0xFF);
1808
1809 return drxdap_fasi_write_block(dev_addr, addr, sizeof(data), buf, flags);
1810}
1811
1812
1813
1814
1815
1816
1817
1818
1819
1820
1821
1822
1823
1824
1825
1826
1827
1828
1829
1830
1831
1832
1833
1834#if (DRXDAPFASI_LONG_ADDR_ALLOWED == 0)
1835static int drxj_dap_rm_write_reg16short(struct i2c_device_addr *dev_addr,
1836 u32 waddr,
1837 u32 raddr,
1838 u16 wdata, u16 *rdata)
1839{
1840 int rc;
1841
1842 if (rdata == NULL)
1843 return -EINVAL;
1844
1845
1846 rc = drxdap_fasi_write_reg16(dev_addr,
1847 SIO_HI_RA_RAM_S0_FLG_ACC__A,
1848 SIO_HI_RA_RAM_S0_FLG_ACC_S0_RWM__M,
1849 0x0000);
1850 if (rc == 0) {
1851
1852 rc = drxdap_fasi_write_reg16(dev_addr, waddr, wdata,
1853 0x0000);
1854 }
1855 if (rc == 0) {
1856
1857 rc = drxdap_fasi_read_reg16(dev_addr, raddr, rdata,
1858 0x0000);
1859 }
1860 if (rc == 0) {
1861
1862 rc = drxdap_fasi_write_reg16(dev_addr,
1863 SIO_HI_RA_RAM_S0_FLG_ACC__A,
1864 0, 0x0000);
1865 }
1866
1867 return rc;
1868}
1869#endif
1870
1871
1872
1873static int drxj_dap_read_modify_write_reg16(struct i2c_device_addr *dev_addr,
1874 u32 waddr,
1875 u32 raddr,
1876 u16 wdata, u16 *rdata)
1877{
1878
1879
1880
1881#if (DRXDAPFASI_LONG_ADDR_ALLOWED == 1)
1882 return drxdap_fasi_read_modify_write_reg16(dev_addr,
1883 waddr,
1884 raddr, wdata, rdata);
1885#else
1886 return drxj_dap_rm_write_reg16short(dev_addr, waddr, raddr, wdata, rdata);
1887#endif
1888}
1889
1890
1891
1892
1893
1894
1895
1896
1897
1898
1899
1900
1901
1902
1903
1904
1905
1906static int drxj_dap_read_aud_reg16(struct i2c_device_addr *dev_addr,
1907 u32 addr, u16 *data)
1908{
1909 u32 start_timer = 0;
1910 u32 current_timer = 0;
1911 u32 delta_timer = 0;
1912 u16 tr_status = 0;
1913 int stat = -EIO;
1914
1915
1916 if (DRXDAP_FASI_ADDR2BANK(addr) == 3) {
1917 stat = -EINVAL;
1918 } else {
1919 const u32 write_bit = ((dr_xaddr_t) 1) << 16;
1920
1921
1922 addr &= (~write_bit);
1923
1924
1925 start_timer = jiffies_to_msecs(jiffies);
1926 do {
1927
1928 stat = drxj_dap_read_modify_write_reg16(dev_addr,
1929 addr,
1930 SIO_HI_RA_RAM_S0_RMWBUF__A,
1931 0x0000, &tr_status);
1932
1933 if (stat != 0)
1934 break;
1935
1936 current_timer = jiffies_to_msecs(jiffies);
1937 delta_timer = current_timer - start_timer;
1938 if (delta_timer > DRXJ_DAP_AUDTRIF_TIMEOUT) {
1939 stat = -EIO;
1940 break;
1941 }
1942
1943 } while (((tr_status & AUD_TOP_TR_CTR_FIFO_LOCK__M) ==
1944 AUD_TOP_TR_CTR_FIFO_LOCK_LOCKED) ||
1945 ((tr_status & AUD_TOP_TR_CTR_FIFO_FULL__M) ==
1946 AUD_TOP_TR_CTR_FIFO_FULL_FULL));
1947 }
1948
1949
1950 if (stat == 0) {
1951 start_timer = jiffies_to_msecs(jiffies);
1952
1953 while ((tr_status & AUD_TOP_TR_CTR_FIFO_RD_RDY__M) !=
1954 AUD_TOP_TR_CTR_FIFO_RD_RDY_READY) {
1955 stat = drxj_dap_read_reg16(dev_addr,
1956 AUD_TOP_TR_CTR__A,
1957 &tr_status, 0x0000);
1958 if (stat != 0)
1959 break;
1960
1961 current_timer = jiffies_to_msecs(jiffies);
1962 delta_timer = current_timer - start_timer;
1963 if (delta_timer > DRXJ_DAP_AUDTRIF_TIMEOUT) {
1964 stat = -EIO;
1965 break;
1966 }
1967 }
1968 }
1969
1970
1971 if (stat == 0)
1972 stat = drxj_dap_read_modify_write_reg16(dev_addr,
1973 AUD_TOP_TR_RD_REG__A,
1974 SIO_HI_RA_RAM_S0_RMWBUF__A,
1975 0x0000, data);
1976 return stat;
1977}
1978
1979
1980
1981static int drxj_dap_read_reg16(struct i2c_device_addr *dev_addr,
1982 u32 addr,
1983 u16 *data, u32 flags)
1984{
1985 int stat = -EIO;
1986
1987
1988 if ((dev_addr == NULL) || (data == NULL))
1989 return -EINVAL;
1990
1991 if (is_handled_by_aud_tr_if(addr))
1992 stat = drxj_dap_read_aud_reg16(dev_addr, addr, data);
1993 else
1994 stat = drxdap_fasi_read_reg16(dev_addr, addr, data, flags);
1995
1996 return stat;
1997}
1998
1999
2000
2001
2002
2003
2004
2005
2006
2007
2008
2009
2010
2011
2012
2013static int drxj_dap_write_aud_reg16(struct i2c_device_addr *dev_addr,
2014 u32 addr, u16 data)
2015{
2016 int stat = -EIO;
2017
2018
2019 if (DRXDAP_FASI_ADDR2BANK(addr) == 2) {
2020 stat = -EINVAL;
2021 } else {
2022 u32 start_timer = 0;
2023 u32 current_timer = 0;
2024 u32 delta_timer = 0;
2025 u16 tr_status = 0;
2026 const u32 write_bit = ((dr_xaddr_t) 1) << 16;
2027
2028
2029 addr |= write_bit;
2030 start_timer = jiffies_to_msecs(jiffies);
2031 do {
2032
2033 stat = drxj_dap_read_modify_write_reg16(dev_addr,
2034 addr,
2035 SIO_HI_RA_RAM_S0_RMWBUF__A,
2036 data, &tr_status);
2037 if (stat != 0)
2038 break;
2039
2040 current_timer = jiffies_to_msecs(jiffies);
2041 delta_timer = current_timer - start_timer;
2042 if (delta_timer > DRXJ_DAP_AUDTRIF_TIMEOUT) {
2043 stat = -EIO;
2044 break;
2045 }
2046
2047 } while (((tr_status & AUD_TOP_TR_CTR_FIFO_LOCK__M) ==
2048 AUD_TOP_TR_CTR_FIFO_LOCK_LOCKED) ||
2049 ((tr_status & AUD_TOP_TR_CTR_FIFO_FULL__M) ==
2050 AUD_TOP_TR_CTR_FIFO_FULL_FULL));
2051
2052 }
2053
2054 return stat;
2055}
2056
2057
2058
2059static int drxj_dap_write_reg16(struct i2c_device_addr *dev_addr,
2060 u32 addr,
2061 u16 data, u32 flags)
2062{
2063 int stat = -EIO;
2064
2065
2066 if (dev_addr == NULL)
2067 return -EINVAL;
2068
2069 if (is_handled_by_aud_tr_if(addr))
2070 stat = drxj_dap_write_aud_reg16(dev_addr, addr, data);
2071 else
2072 stat = drxdap_fasi_write_reg16(dev_addr,
2073 addr, data, flags);
2074
2075 return stat;
2076}
2077
2078
2079
2080
2081#define SIO_HI_RA_RAM_USR_BEGIN__A 0x420040
2082#define SIO_HI_RA_RAM_USR_END__A 0x420060
2083
2084#define DRXJ_HI_ATOMIC_BUF_START (SIO_HI_RA_RAM_USR_BEGIN__A)
2085#define DRXJ_HI_ATOMIC_BUF_END (SIO_HI_RA_RAM_USR_BEGIN__A + 7)
2086#define DRXJ_HI_ATOMIC_READ SIO_HI_RA_RAM_PAR_3_ACP_RW_READ
2087#define DRXJ_HI_ATOMIC_WRITE SIO_HI_RA_RAM_PAR_3_ACP_RW_WRITE
2088
2089
2090
2091
2092
2093
2094
2095
2096
2097
2098
2099
2100
2101static
2102int drxj_dap_atomic_read_write_block(struct i2c_device_addr *dev_addr,
2103 u32 addr,
2104 u16 datasize,
2105 u8 *data, bool read_flag)
2106{
2107 struct drxj_hi_cmd hi_cmd;
2108 int rc;
2109 u16 word;
2110 u16 dummy = 0;
2111 u16 i = 0;
2112
2113
2114 if (!data || !dev_addr || ((datasize % 2)) || ((datasize / 2) > 8))
2115 return -EINVAL;
2116
2117
2118 hi_cmd.cmd = SIO_HI_RA_RAM_CMD_ATOMIC_COPY;
2119 hi_cmd.param1 =
2120 (u16) ((DRXDAP_FASI_ADDR2BLOCK(DRXJ_HI_ATOMIC_BUF_START) << 6) +
2121 DRXDAP_FASI_ADDR2BANK(DRXJ_HI_ATOMIC_BUF_START));
2122 hi_cmd.param2 =
2123 (u16) DRXDAP_FASI_ADDR2OFFSET(DRXJ_HI_ATOMIC_BUF_START);
2124 hi_cmd.param3 = (u16) ((datasize / 2) - 1);
2125 if (!read_flag)
2126 hi_cmd.param3 |= DRXJ_HI_ATOMIC_WRITE;
2127 else
2128 hi_cmd.param3 |= DRXJ_HI_ATOMIC_READ;
2129 hi_cmd.param4 = (u16) ((DRXDAP_FASI_ADDR2BLOCK(addr) << 6) +
2130 DRXDAP_FASI_ADDR2BANK(addr));
2131 hi_cmd.param5 = (u16) DRXDAP_FASI_ADDR2OFFSET(addr);
2132
2133 if (!read_flag) {
2134
2135 for (i = 0; i < (datasize / 2); i++) {
2136
2137 word = ((u16) data[2 * i]);
2138 word += (((u16) data[(2 * i) + 1]) << 8);
2139 drxj_dap_write_reg16(dev_addr,
2140 (DRXJ_HI_ATOMIC_BUF_START + i),
2141 word, 0);
2142 }
2143 }
2144
2145 rc = hi_command(dev_addr, &hi_cmd, &dummy);
2146 if (rc != 0) {
2147 pr_err("error %d\n", rc);
2148 goto rw_error;
2149 }
2150
2151 if (read_flag) {
2152
2153 for (i = 0; i < (datasize / 2); i++) {
2154 rc = drxj_dap_read_reg16(dev_addr,
2155 (DRXJ_HI_ATOMIC_BUF_START + i),
2156 &word, 0);
2157 if (rc) {
2158 pr_err("error %d\n", rc);
2159 goto rw_error;
2160 }
2161 data[2 * i] = (u8) (word & 0xFF);
2162 data[(2 * i) + 1] = (u8) (word >> 8);
2163 }
2164 }
2165
2166 return 0;
2167
2168rw_error:
2169 return rc;
2170
2171}
2172
2173
2174
2175
2176
2177
2178
2179static
2180int drxj_dap_atomic_read_reg32(struct i2c_device_addr *dev_addr,
2181 u32 addr,
2182 u32 *data, u32 flags)
2183{
2184 u8 buf[sizeof(*data)] = { 0 };
2185 int rc = -EIO;
2186 u32 word = 0;
2187
2188 if (!data)
2189 return -EINVAL;
2190
2191 rc = drxj_dap_atomic_read_write_block(dev_addr, addr,
2192 sizeof(*data), buf, true);
2193
2194 if (rc < 0)
2195 return 0;
2196
2197 word = (u32) buf[3];
2198 word <<= 8;
2199 word |= (u32) buf[2];
2200 word <<= 8;
2201 word |= (u32) buf[1];
2202 word <<= 8;
2203 word |= (u32) buf[0];
2204
2205 *data = word;
2206
2207 return rc;
2208}
2209
2210
2211
2212
2213
2214
2215
2216
2217
2218
2219
2220
2221
2222
2223
2224
2225
2226
2227
2228
2229
2230
2231
2232
2233static int hi_cfg_command(const struct drx_demod_instance *demod)
2234{
2235 struct drxj_data *ext_attr = (struct drxj_data *) (NULL);
2236 struct drxj_hi_cmd hi_cmd;
2237 u16 result = 0;
2238 int rc;
2239
2240 ext_attr = (struct drxj_data *) demod->my_ext_attr;
2241
2242 hi_cmd.cmd = SIO_HI_RA_RAM_CMD_CONFIG;
2243 hi_cmd.param1 = SIO_HI_RA_RAM_PAR_1_PAR1_SEC_KEY;
2244 hi_cmd.param2 = ext_attr->hi_cfg_timing_div;
2245 hi_cmd.param3 = ext_attr->hi_cfg_bridge_delay;
2246 hi_cmd.param4 = ext_attr->hi_cfg_wake_up_key;
2247 hi_cmd.param5 = ext_attr->hi_cfg_ctrl;
2248 hi_cmd.param6 = ext_attr->hi_cfg_transmit;
2249
2250 rc = hi_command(demod->my_i2c_dev_addr, &hi_cmd, &result);
2251 if (rc != 0) {
2252 pr_err("error %d\n", rc);
2253 goto rw_error;
2254 }
2255
2256
2257 ext_attr->hi_cfg_ctrl &= (~(SIO_HI_RA_RAM_PAR_5_CFG_SLEEP_ZZZ));
2258
2259 return 0;
2260
2261rw_error:
2262 return rc;
2263}
2264
2265
2266
2267
2268
2269
2270
2271
2272
2273
2274
2275
2276static int
2277hi_command(struct i2c_device_addr *dev_addr, const struct drxj_hi_cmd *cmd, u16 *result)
2278{
2279 u16 wait_cmd = 0;
2280 u16 nr_retries = 0;
2281 bool powerdown_cmd = false;
2282 int rc;
2283
2284
2285 switch (cmd->cmd) {
2286
2287 case SIO_HI_RA_RAM_CMD_CONFIG:
2288 case SIO_HI_RA_RAM_CMD_ATOMIC_COPY:
2289 rc = drxj_dap_write_reg16(dev_addr, SIO_HI_RA_RAM_PAR_6__A, cmd->param6, 0);
2290 if (rc != 0) {
2291 pr_err("error %d\n", rc);
2292 goto rw_error;
2293 }
2294 rc = drxj_dap_write_reg16(dev_addr, SIO_HI_RA_RAM_PAR_5__A, cmd->param5, 0);
2295 if (rc != 0) {
2296 pr_err("error %d\n", rc);
2297 goto rw_error;
2298 }
2299 rc = drxj_dap_write_reg16(dev_addr, SIO_HI_RA_RAM_PAR_4__A, cmd->param4, 0);
2300 if (rc != 0) {
2301 pr_err("error %d\n", rc);
2302 goto rw_error;
2303 }
2304 rc = drxj_dap_write_reg16(dev_addr, SIO_HI_RA_RAM_PAR_3__A, cmd->param3, 0);
2305 if (rc != 0) {
2306 pr_err("error %d\n", rc);
2307 goto rw_error;
2308 }
2309
2310 case SIO_HI_RA_RAM_CMD_BRDCTRL:
2311 rc = drxj_dap_write_reg16(dev_addr, SIO_HI_RA_RAM_PAR_2__A, cmd->param2, 0);
2312 if (rc != 0) {
2313 pr_err("error %d\n", rc);
2314 goto rw_error;
2315 }
2316 rc = drxj_dap_write_reg16(dev_addr, SIO_HI_RA_RAM_PAR_1__A, cmd->param1, 0);
2317 if (rc != 0) {
2318 pr_err("error %d\n", rc);
2319 goto rw_error;
2320 }
2321
2322 case SIO_HI_RA_RAM_CMD_NULL:
2323
2324 break;
2325
2326 default:
2327 return -EINVAL;
2328 break;
2329 }
2330
2331
2332 rc = drxj_dap_write_reg16(dev_addr, SIO_HI_RA_RAM_CMD__A, cmd->cmd, 0);
2333 if (rc != 0) {
2334 pr_err("error %d\n", rc);
2335 goto rw_error;
2336 }
2337
2338 if ((cmd->cmd) == SIO_HI_RA_RAM_CMD_RESET)
2339 msleep(1);
2340
2341
2342 powerdown_cmd = (bool) ((cmd->cmd == SIO_HI_RA_RAM_CMD_CONFIG) &&
2343 (((cmd->
2344 param5) & SIO_HI_RA_RAM_PAR_5_CFG_SLEEP__M)
2345 == SIO_HI_RA_RAM_PAR_5_CFG_SLEEP_ZZZ));
2346 if (!powerdown_cmd) {
2347
2348 do {
2349 nr_retries++;
2350 if (nr_retries > DRXJ_MAX_RETRIES) {
2351 pr_err("timeout\n");
2352 goto rw_error;
2353 }
2354
2355 rc = drxj_dap_read_reg16(dev_addr, SIO_HI_RA_RAM_CMD__A, &wait_cmd, 0);
2356 if (rc != 0) {
2357 pr_err("error %d\n", rc);
2358 goto rw_error;
2359 }
2360 } while (wait_cmd != 0);
2361
2362
2363 rc = drxj_dap_read_reg16(dev_addr, SIO_HI_RA_RAM_RES__A, result, 0);
2364 if (rc != 0) {
2365 pr_err("error %d\n", rc);
2366 goto rw_error;
2367 }
2368
2369 }
2370
2371 return 0;
2372rw_error:
2373 return rc;
2374}
2375
2376
2377
2378
2379
2380
2381
2382
2383
2384
2385
2386
2387
2388
2389static int init_hi(const struct drx_demod_instance *demod)
2390{
2391 struct drxj_data *ext_attr = (struct drxj_data *) (NULL);
2392 struct drx_common_attr *common_attr = (struct drx_common_attr *) (NULL);
2393 struct i2c_device_addr *dev_addr = (struct i2c_device_addr *)(NULL);
2394 int rc;
2395
2396 ext_attr = (struct drxj_data *) demod->my_ext_attr;
2397 common_attr = (struct drx_common_attr *) demod->my_common_attr;
2398 dev_addr = demod->my_i2c_dev_addr;
2399
2400
2401 rc = drxj_dap_write_reg16(dev_addr, 0x4301D7, 0x801, 0);
2402 if (rc != 0) {
2403 pr_err("error %d\n", rc);
2404 goto rw_error;
2405 }
2406
2407
2408
2409 ext_attr->hi_cfg_timing_div =
2410 (u16) ((common_attr->sys_clock_freq / 1000) * HI_I2C_DELAY) / 1000;
2411
2412 if ((ext_attr->hi_cfg_timing_div) > SIO_HI_RA_RAM_PAR_2_CFG_DIV__M)
2413 ext_attr->hi_cfg_timing_div = SIO_HI_RA_RAM_PAR_2_CFG_DIV__M;
2414
2415
2416
2417 ext_attr->hi_cfg_bridge_delay =
2418 (u16) ((common_attr->osc_clock_freq / 1000) * HI_I2C_BRIDGE_DELAY) /
2419 1000;
2420
2421 if ((ext_attr->hi_cfg_bridge_delay) > SIO_HI_RA_RAM_PAR_3_CFG_DBL_SDA__M)
2422 ext_attr->hi_cfg_bridge_delay = SIO_HI_RA_RAM_PAR_3_CFG_DBL_SDA__M;
2423
2424 ext_attr->hi_cfg_bridge_delay += ((ext_attr->hi_cfg_bridge_delay) <<
2425 SIO_HI_RA_RAM_PAR_3_CFG_DBL_SCL__B);
2426
2427
2428
2429 ext_attr->hi_cfg_wake_up_key = DRXJ_WAKE_UP_KEY;
2430
2431 ext_attr->hi_cfg_ctrl = (SIO_HI_RA_RAM_PAR_5_CFG_SLV0_SLAVE);
2432
2433 ext_attr->hi_cfg_transmit = SIO_HI_RA_RAM_PAR_6__PRE;
2434
2435 rc = hi_cfg_command(demod);
2436 if (rc != 0) {
2437 pr_err("error %d\n", rc);
2438 goto rw_error;
2439 }
2440
2441 return 0;
2442
2443rw_error:
2444 return rc;
2445}
2446
2447
2448
2449
2450
2451
2452
2453
2454
2455
2456
2457
2458
2459
2460
2461
2462
2463
2464
2465
2466
2467
2468
2469
2470
2471
2472
2473static int get_device_capabilities(struct drx_demod_instance *demod)
2474{
2475 struct drx_common_attr *common_attr = (struct drx_common_attr *) (NULL);
2476 struct drxj_data *ext_attr = (struct drxj_data *) NULL;
2477 struct i2c_device_addr *dev_addr = (struct i2c_device_addr *)(NULL);
2478 u16 sio_pdr_ohw_cfg = 0;
2479 u32 sio_top_jtagid_lo = 0;
2480 u16 bid = 0;
2481 int rc;
2482
2483 common_attr = (struct drx_common_attr *) demod->my_common_attr;
2484 ext_attr = (struct drxj_data *) demod->my_ext_attr;
2485 dev_addr = demod->my_i2c_dev_addr;
2486
2487 rc = drxj_dap_write_reg16(dev_addr, SIO_TOP_COMM_KEY__A, SIO_TOP_COMM_KEY_KEY, 0);
2488 if (rc != 0) {
2489 pr_err("error %d\n", rc);
2490 goto rw_error;
2491 }
2492 rc = drxj_dap_read_reg16(dev_addr, SIO_PDR_OHW_CFG__A, &sio_pdr_ohw_cfg, 0);
2493 if (rc != 0) {
2494 pr_err("error %d\n", rc);
2495 goto rw_error;
2496 }
2497 rc = drxj_dap_write_reg16(dev_addr, SIO_TOP_COMM_KEY__A, SIO_TOP_COMM_KEY__PRE, 0);
2498 if (rc != 0) {
2499 pr_err("error %d\n", rc);
2500 goto rw_error;
2501 }
2502
2503 switch ((sio_pdr_ohw_cfg & SIO_PDR_OHW_CFG_FREF_SEL__M)) {
2504 case 0:
2505
2506 break;
2507 case 1:
2508
2509 common_attr->osc_clock_freq = 27000;
2510 break;
2511 case 2:
2512
2513 common_attr->osc_clock_freq = 20250;
2514 break;
2515 case 3:
2516
2517 common_attr->osc_clock_freq = 4000;
2518 break;
2519 default:
2520 return -EIO;
2521 }
2522
2523
2524
2525
2526
2527 rc = drxdap_fasi_read_reg32(dev_addr, SIO_TOP_JTAGID_LO__A, &sio_top_jtagid_lo, 0);
2528 if (rc != 0) {
2529 pr_err("error %d\n", rc);
2530 goto rw_error;
2531 }
2532 ext_attr->mfx = (u8) ((sio_top_jtagid_lo >> 29) & 0xF);
2533
2534 switch ((sio_top_jtagid_lo >> 12) & 0xFF) {
2535 case 0x31:
2536 rc = drxj_dap_write_reg16(dev_addr, SIO_TOP_COMM_KEY__A, SIO_TOP_COMM_KEY_KEY, 0);
2537 if (rc != 0) {
2538 pr_err("error %d\n", rc);
2539 goto rw_error;
2540 }
2541 rc = drxj_dap_read_reg16(dev_addr, SIO_PDR_UIO_IN_HI__A, &bid, 0);
2542 if (rc != 0) {
2543 pr_err("error %d\n", rc);
2544 goto rw_error;
2545 }
2546 bid = (bid >> 10) & 0xf;
2547 rc = drxj_dap_write_reg16(dev_addr, SIO_TOP_COMM_KEY__A, SIO_TOP_COMM_KEY__PRE, 0);
2548 if (rc != 0) {
2549 pr_err("error %d\n", rc);
2550 goto rw_error;
2551 }
2552
2553 ext_attr->has_lna = true;
2554 ext_attr->has_ntsc = false;
2555 ext_attr->has_btsc = false;
2556 ext_attr->has_oob = false;
2557 ext_attr->has_smatx = true;
2558 ext_attr->has_smarx = false;
2559 ext_attr->has_gpio = false;
2560 ext_attr->has_irqn = false;
2561 break;
2562 case 0x33:
2563 ext_attr->has_lna = false;
2564 ext_attr->has_ntsc = false;
2565 ext_attr->has_btsc = false;
2566 ext_attr->has_oob = false;
2567 ext_attr->has_smatx = true;
2568 ext_attr->has_smarx = false;
2569 ext_attr->has_gpio = false;
2570 ext_attr->has_irqn = false;
2571 break;
2572 case 0x45:
2573 ext_attr->has_lna = true;
2574 ext_attr->has_ntsc = true;
2575 ext_attr->has_btsc = false;
2576 ext_attr->has_oob = false;
2577 ext_attr->has_smatx = true;
2578 ext_attr->has_smarx = true;
2579 ext_attr->has_gpio = true;
2580 ext_attr->has_irqn = false;
2581 break;
2582 case 0x46:
2583 ext_attr->has_lna = false;
2584 ext_attr->has_ntsc = true;
2585 ext_attr->has_btsc = false;
2586 ext_attr->has_oob = false;
2587 ext_attr->has_smatx = true;
2588 ext_attr->has_smarx = true;
2589 ext_attr->has_gpio = true;
2590 ext_attr->has_irqn = false;
2591 break;
2592 case 0x41:
2593 ext_attr->has_lna = true;
2594 ext_attr->has_ntsc = true;
2595 ext_attr->has_btsc = true;
2596 ext_attr->has_oob = false;
2597 ext_attr->has_smatx = true;
2598 ext_attr->has_smarx = true;
2599 ext_attr->has_gpio = true;
2600 ext_attr->has_irqn = false;
2601 break;
2602 case 0x43:
2603 ext_attr->has_lna = false;
2604 ext_attr->has_ntsc = true;
2605 ext_attr->has_btsc = true;
2606 ext_attr->has_oob = false;
2607 ext_attr->has_smatx = true;
2608 ext_attr->has_smarx = true;
2609 ext_attr->has_gpio = true;
2610 ext_attr->has_irqn = false;
2611 break;
2612 case 0x32:
2613 ext_attr->has_lna = true;
2614 ext_attr->has_ntsc = false;
2615 ext_attr->has_btsc = false;
2616 ext_attr->has_oob = true;
2617 ext_attr->has_smatx = true;
2618 ext_attr->has_smarx = true;
2619 ext_attr->has_gpio = true;
2620 ext_attr->has_irqn = true;
2621 break;
2622 case 0x34:
2623 ext_attr->has_lna = false;
2624 ext_attr->has_ntsc = true;
2625 ext_attr->has_btsc = true;
2626 ext_attr->has_oob = true;
2627 ext_attr->has_smatx = true;
2628 ext_attr->has_smarx = true;
2629 ext_attr->has_gpio = true;
2630 ext_attr->has_irqn = true;
2631 break;
2632 case 0x42:
2633 ext_attr->has_lna = true;
2634 ext_attr->has_ntsc = true;
2635 ext_attr->has_btsc = true;
2636 ext_attr->has_oob = true;
2637 ext_attr->has_smatx = true;
2638 ext_attr->has_smarx = true;
2639 ext_attr->has_gpio = true;
2640 ext_attr->has_irqn = true;
2641 break;
2642 case 0x44:
2643 ext_attr->has_lna = false;
2644 ext_attr->has_ntsc = true;
2645 ext_attr->has_btsc = true;
2646 ext_attr->has_oob = true;
2647 ext_attr->has_smatx = true;
2648 ext_attr->has_smarx = true;
2649 ext_attr->has_gpio = true;
2650 ext_attr->has_irqn = true;
2651 break;
2652 default:
2653
2654 return -EIO;
2655 break;
2656 }
2657
2658 return 0;
2659rw_error:
2660 return rc;
2661}
2662
2663
2664
2665
2666
2667
2668
2669
2670
2671
2672
2673#ifndef DRXJ_MAX_RETRIES_POWERUP
2674#define DRXJ_MAX_RETRIES_POWERUP 10
2675#endif
2676
2677static int power_up_device(struct drx_demod_instance *demod)
2678{
2679 struct i2c_device_addr *dev_addr = (struct i2c_device_addr *)(NULL);
2680 u8 data = 0;
2681 u16 retry_count = 0;
2682 struct i2c_device_addr wake_up_addr;
2683
2684 dev_addr = demod->my_i2c_dev_addr;
2685 wake_up_addr.i2c_addr = DRXJ_WAKE_UP_KEY;
2686 wake_up_addr.i2c_dev_id = dev_addr->i2c_dev_id;
2687 wake_up_addr.user_data = dev_addr->user_data;
2688
2689
2690
2691
2692
2693 do {
2694 data = 0;
2695 drxbsp_i2c_write_read(&wake_up_addr, 1, &data,
2696 (struct i2c_device_addr *)(NULL), 0,
2697 (u8 *)(NULL));
2698 msleep(10);
2699 retry_count++;
2700 } while ((drxbsp_i2c_write_read
2701 ((struct i2c_device_addr *) (NULL), 0, (u8 *)(NULL), dev_addr, 1,
2702 &data)
2703 != 0) && (retry_count < DRXJ_MAX_RETRIES_POWERUP));
2704
2705
2706 msleep(10);
2707
2708 if (retry_count == DRXJ_MAX_RETRIES_POWERUP)
2709 return -EIO;
2710
2711 return 0;
2712}
2713
2714
2715
2716
2717
2718
2719
2720
2721
2722
2723
2724
2725
2726
2727static int
2728ctrl_set_cfg_mpeg_output(struct drx_demod_instance *demod, struct drx_cfg_mpeg_output *cfg_data)
2729{
2730 struct i2c_device_addr *dev_addr = (struct i2c_device_addr *)(NULL);
2731 struct drxj_data *ext_attr = (struct drxj_data *) (NULL);
2732 struct drx_common_attr *common_attr = (struct drx_common_attr *) (NULL);
2733 int rc;
2734 u16 fec_oc_reg_mode = 0;
2735 u16 fec_oc_reg_ipr_mode = 0;
2736 u16 fec_oc_reg_ipr_invert = 0;
2737 u32 max_bit_rate = 0;
2738 u32 rcn_rate = 0;
2739 u32 nr_bits = 0;
2740 u16 sio_pdr_md_cfg = 0;
2741
2742 u16 invert_data_mask =
2743 FEC_OC_IPR_INVERT_MD7__M | FEC_OC_IPR_INVERT_MD6__M |
2744 FEC_OC_IPR_INVERT_MD5__M | FEC_OC_IPR_INVERT_MD4__M |
2745 FEC_OC_IPR_INVERT_MD3__M | FEC_OC_IPR_INVERT_MD2__M |
2746 FEC_OC_IPR_INVERT_MD1__M | FEC_OC_IPR_INVERT_MD0__M;
2747
2748
2749 if ((demod == NULL) || (cfg_data == NULL))
2750 return -EINVAL;
2751
2752 dev_addr = demod->my_i2c_dev_addr;
2753 ext_attr = (struct drxj_data *) demod->my_ext_attr;
2754 common_attr = (struct drx_common_attr *) demod->my_common_attr;
2755
2756 if (cfg_data->enable_mpeg_output == true) {
2757
2758
2759 switch (ext_attr->standard) {
2760 case DRX_STANDARD_8VSB:
2761 case DRX_STANDARD_ITU_A:
2762 case DRX_STANDARD_ITU_B:
2763 case DRX_STANDARD_ITU_C:
2764 break;
2765 default:
2766 return 0;
2767 }
2768
2769 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_OCR_INVERT__A, 0, 0);
2770 if (rc != 0) {
2771 pr_err("error %d\n", rc);
2772 goto rw_error;
2773 }
2774 switch (ext_attr->standard) {
2775 case DRX_STANDARD_8VSB:
2776 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_FCT_USAGE__A, 7, 0);
2777 if (rc != 0) {
2778 pr_err("error %d\n", rc);
2779 goto rw_error;
2780 }
2781 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_TMD_CTL_UPD_RATE__A, 10, 0);
2782 if (rc != 0) {
2783 pr_err("error %d\n", rc);
2784 goto rw_error;
2785 }
2786 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_TMD_INT_UPD_RATE__A, 10, 0);
2787 if (rc != 0) {
2788 pr_err("error %d\n", rc);
2789 goto rw_error;
2790 }
2791 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_AVR_PARM_A__A, 5, 0);
2792 if (rc != 0) {
2793 pr_err("error %d\n", rc);
2794 goto rw_error;
2795 }
2796 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_AVR_PARM_B__A, 7, 0);
2797 if (rc != 0) {
2798 pr_err("error %d\n", rc);
2799 goto rw_error;
2800 }
2801 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_RCN_GAIN__A, 10, 0);
2802 if (rc != 0) {
2803 pr_err("error %d\n", rc);
2804 goto rw_error;
2805 }
2806
2807 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_SNC_LWM__A, 3, 0);
2808 if (rc != 0) {
2809 pr_err("error %d\n", rc);
2810 goto rw_error;
2811 }
2812
2813 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_SNC_HWM__A, 5, 0);
2814 if (rc != 0) {
2815 pr_err("error %d\n", rc);
2816 goto rw_error;
2817 }
2818 break;
2819 case DRX_STANDARD_ITU_A:
2820 case DRX_STANDARD_ITU_C:
2821 switch (ext_attr->constellation) {
2822 case DRX_CONSTELLATION_QAM256:
2823 nr_bits = 8;
2824 break;
2825 case DRX_CONSTELLATION_QAM128:
2826 nr_bits = 7;
2827 break;
2828 case DRX_CONSTELLATION_QAM64:
2829 nr_bits = 6;
2830 break;
2831 case DRX_CONSTELLATION_QAM32:
2832 nr_bits = 5;
2833 break;
2834 case DRX_CONSTELLATION_QAM16:
2835 nr_bits = 4;
2836 break;
2837 default:
2838 return -EIO;
2839 }
2840
2841
2842 max_bit_rate =
2843 (ext_attr->curr_symbol_rate / 8) * nr_bits * 188;
2844
2845 case DRX_STANDARD_ITU_B:
2846 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_FCT_USAGE__A, FEC_OC_FCT_USAGE__PRE, 0);
2847 if (rc != 0) {
2848 pr_err("error %d\n", rc);
2849 goto rw_error;
2850 }
2851 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_TMD_CTL_UPD_RATE__A, FEC_OC_TMD_CTL_UPD_RATE__PRE, 0);
2852 if (rc != 0) {
2853 pr_err("error %d\n", rc);
2854 goto rw_error;
2855 }
2856 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_TMD_INT_UPD_RATE__A, 5, 0);
2857 if (rc != 0) {
2858 pr_err("error %d\n", rc);
2859 goto rw_error;
2860 }
2861 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_AVR_PARM_A__A, FEC_OC_AVR_PARM_A__PRE, 0);
2862 if (rc != 0) {
2863 pr_err("error %d\n", rc);
2864 goto rw_error;
2865 }
2866 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_AVR_PARM_B__A, FEC_OC_AVR_PARM_B__PRE, 0);
2867 if (rc != 0) {
2868 pr_err("error %d\n", rc);
2869 goto rw_error;
2870 }
2871 if (cfg_data->static_clk == true) {
2872 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_RCN_GAIN__A, 0xD, 0);
2873 if (rc != 0) {
2874 pr_err("error %d\n", rc);
2875 goto rw_error;
2876 }
2877 } else {
2878 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_RCN_GAIN__A, FEC_OC_RCN_GAIN__PRE, 0);
2879 if (rc != 0) {
2880 pr_err("error %d\n", rc);
2881 goto rw_error;
2882 }
2883 }
2884 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_SNC_LWM__A, 2, 0);
2885 if (rc != 0) {
2886 pr_err("error %d\n", rc);
2887 goto rw_error;
2888 }
2889 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_SNC_HWM__A, 12, 0);
2890 if (rc != 0) {
2891 pr_err("error %d\n", rc);
2892 goto rw_error;
2893 }
2894 break;
2895 default:
2896 break;
2897 }
2898
2899
2900 rc = drxj_dap_read_reg16(dev_addr, FEC_OC_MODE__A, &fec_oc_reg_mode, 0);
2901 if (rc != 0) {
2902 pr_err("error %d\n", rc);
2903 goto rw_error;
2904 }
2905 rc = drxj_dap_read_reg16(dev_addr, FEC_OC_IPR_MODE__A, &fec_oc_reg_ipr_mode, 0);
2906 if (rc != 0) {
2907 pr_err("error %d\n", rc);
2908 goto rw_error;
2909 }
2910 if (cfg_data->insert_rs_byte == true) {
2911
2912 fec_oc_reg_mode |= FEC_OC_MODE_PARITY__M;
2913
2914 fec_oc_reg_ipr_mode |= FEC_OC_IPR_MODE_MVAL_DIS_PAR__M;
2915 switch (ext_attr->standard) {
2916 case DRX_STANDARD_8VSB:
2917 rcn_rate = 0x004854D3;
2918 break;
2919 case DRX_STANDARD_ITU_B:
2920 fec_oc_reg_mode |= FEC_OC_MODE_TRANSPARENT__M;
2921 switch (ext_attr->constellation) {
2922 case DRX_CONSTELLATION_QAM256:
2923 rcn_rate = 0x008945E7;
2924 break;
2925 case DRX_CONSTELLATION_QAM64:
2926 rcn_rate = 0x005F64D4;
2927 break;
2928 default:
2929 return -EIO;
2930 }
2931 break;
2932 case DRX_STANDARD_ITU_A:
2933 case DRX_STANDARD_ITU_C:
2934
2935 rcn_rate =
2936 (frac28
2937 (max_bit_rate,
2938 (u32) (common_attr->sys_clock_freq / 8))) /
2939 188;
2940 break;
2941 default:
2942 return -EIO;
2943 }
2944 } else {
2945
2946
2947 fec_oc_reg_mode &= (~FEC_OC_MODE_PARITY__M);
2948
2949 fec_oc_reg_ipr_mode &= (~FEC_OC_IPR_MODE_MVAL_DIS_PAR__M);
2950 switch (ext_attr->standard) {
2951 case DRX_STANDARD_8VSB:
2952 rcn_rate = 0x0041605C;
2953 break;
2954 case DRX_STANDARD_ITU_B:
2955 fec_oc_reg_mode &= (~FEC_OC_MODE_TRANSPARENT__M);
2956 switch (ext_attr->constellation) {
2957 case DRX_CONSTELLATION_QAM256:
2958 rcn_rate = 0x0082D6A0;
2959 break;
2960 case DRX_CONSTELLATION_QAM64:
2961 rcn_rate = 0x005AEC1A;
2962 break;
2963 default:
2964 return -EIO;
2965 }
2966 break;
2967 case DRX_STANDARD_ITU_A:
2968 case DRX_STANDARD_ITU_C:
2969
2970 rcn_rate =
2971 (frac28
2972 (max_bit_rate,
2973 (u32) (common_attr->sys_clock_freq / 8))) /
2974 204;
2975 break;
2976 default:
2977 return -EIO;
2978 }
2979 }
2980
2981 if (cfg_data->enable_parallel == true) {
2982 fec_oc_reg_ipr_mode &= (~(FEC_OC_IPR_MODE_SERIAL__M));
2983 } else {
2984 fec_oc_reg_ipr_mode |= FEC_OC_IPR_MODE_SERIAL__M;
2985 }
2986
2987
2988 if (cfg_data->invert_data == true)
2989 fec_oc_reg_ipr_invert |= invert_data_mask;
2990 else
2991 fec_oc_reg_ipr_invert &= (~(invert_data_mask));
2992
2993 if (cfg_data->invert_err == true)
2994 fec_oc_reg_ipr_invert |= FEC_OC_IPR_INVERT_MERR__M;
2995 else
2996 fec_oc_reg_ipr_invert &= (~(FEC_OC_IPR_INVERT_MERR__M));
2997
2998 if (cfg_data->invert_str == true)
2999 fec_oc_reg_ipr_invert |= FEC_OC_IPR_INVERT_MSTRT__M;
3000 else
3001 fec_oc_reg_ipr_invert &= (~(FEC_OC_IPR_INVERT_MSTRT__M));
3002
3003 if (cfg_data->invert_val == true)
3004 fec_oc_reg_ipr_invert |= FEC_OC_IPR_INVERT_MVAL__M;
3005 else
3006 fec_oc_reg_ipr_invert &= (~(FEC_OC_IPR_INVERT_MVAL__M));
3007
3008 if (cfg_data->invert_clk == true)
3009 fec_oc_reg_ipr_invert |= FEC_OC_IPR_INVERT_MCLK__M;
3010 else
3011 fec_oc_reg_ipr_invert &= (~(FEC_OC_IPR_INVERT_MCLK__M));
3012
3013
3014 if (cfg_data->static_clk == true) {
3015 u32 dto_rate = 0;
3016 u32 bit_rate = 0;
3017 u16 fec_oc_dto_burst_len = 0;
3018 u16 fec_oc_dto_period = 0;
3019
3020 fec_oc_dto_burst_len = FEC_OC_DTO_BURST_LEN__PRE;
3021
3022 switch (ext_attr->standard) {
3023 case DRX_STANDARD_8VSB:
3024 fec_oc_dto_period = 4;
3025 if (cfg_data->insert_rs_byte == true)
3026 fec_oc_dto_burst_len = 208;
3027 break;
3028 case DRX_STANDARD_ITU_A:
3029 {
3030 u32 symbol_rate_th = 6400000;
3031 if (cfg_data->insert_rs_byte == true) {
3032 fec_oc_dto_burst_len = 204;
3033 symbol_rate_th = 5900000;
3034 }
3035 if (ext_attr->curr_symbol_rate >=
3036 symbol_rate_th) {
3037 fec_oc_dto_period = 0;
3038 } else {
3039 fec_oc_dto_period = 1;
3040 }
3041 }
3042 break;
3043 case DRX_STANDARD_ITU_B:
3044 fec_oc_dto_period = 1;
3045 if (cfg_data->insert_rs_byte == true)
3046 fec_oc_dto_burst_len = 128;
3047 break;
3048 case DRX_STANDARD_ITU_C:
3049 fec_oc_dto_period = 1;
3050 if (cfg_data->insert_rs_byte == true)
3051 fec_oc_dto_burst_len = 204;
3052 break;
3053 default:
3054 return -EIO;
3055 }
3056 bit_rate =
3057 common_attr->sys_clock_freq * 1000 / (fec_oc_dto_period +
3058 2);
3059 dto_rate =
3060 frac28(bit_rate, common_attr->sys_clock_freq * 1000);
3061 dto_rate >>= 3;
3062 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_DTO_RATE_HI__A, (u16)((dto_rate >> 16) & FEC_OC_DTO_RATE_HI__M), 0);
3063 if (rc != 0) {
3064 pr_err("error %d\n", rc);
3065 goto rw_error;
3066 }
3067 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_DTO_RATE_LO__A, (u16)(dto_rate & FEC_OC_DTO_RATE_LO_RATE_LO__M), 0);
3068 if (rc != 0) {
3069 pr_err("error %d\n", rc);
3070 goto rw_error;
3071 }
3072 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_DTO_MODE__A, FEC_OC_DTO_MODE_DYNAMIC__M | FEC_OC_DTO_MODE_OFFSET_ENABLE__M, 0);
3073 if (rc != 0) {
3074 pr_err("error %d\n", rc);
3075 goto rw_error;
3076 }
3077 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_FCT_MODE__A, FEC_OC_FCT_MODE_RAT_ENA__M | FEC_OC_FCT_MODE_VIRT_ENA__M, 0);
3078 if (rc != 0) {
3079 pr_err("error %d\n", rc);
3080 goto rw_error;
3081 }
3082 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_DTO_BURST_LEN__A, fec_oc_dto_burst_len, 0);
3083 if (rc != 0) {
3084 pr_err("error %d\n", rc);
3085 goto rw_error;
3086 }
3087 if (ext_attr->mpeg_output_clock_rate != DRXJ_MPEGOUTPUT_CLOCK_RATE_AUTO)
3088 fec_oc_dto_period = ext_attr->mpeg_output_clock_rate - 1;
3089 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_DTO_PERIOD__A, fec_oc_dto_period, 0);
3090 if (rc != 0) {
3091 pr_err("error %d\n", rc);
3092 goto rw_error;
3093 }
3094 } else {
3095
3096 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_DTO_MODE__A, FEC_OC_DTO_MODE_DYNAMIC__M, 0);
3097 if (rc != 0) {
3098 pr_err("error %d\n", rc);
3099 goto rw_error;
3100 }
3101 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_FCT_MODE__A, 0, 0);
3102 if (rc != 0) {
3103 pr_err("error %d\n", rc);
3104 goto rw_error;
3105 }
3106 }
3107
3108 rc = drxdap_fasi_write_reg32(dev_addr, FEC_OC_RCN_CTL_RATE_LO__A, rcn_rate, 0);
3109 if (rc != 0) {
3110 pr_err("error %d\n", rc);
3111 goto rw_error;
3112 }
3113
3114
3115 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_MODE__A, fec_oc_reg_mode, 0);
3116 if (rc != 0) {
3117 pr_err("error %d\n", rc);
3118 goto rw_error;
3119 }
3120 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_IPR_MODE__A, fec_oc_reg_ipr_mode, 0);
3121 if (rc != 0) {
3122 pr_err("error %d\n", rc);
3123 goto rw_error;
3124 }
3125 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_IPR_INVERT__A, fec_oc_reg_ipr_invert, 0);
3126 if (rc != 0) {
3127 pr_err("error %d\n", rc);
3128 goto rw_error;
3129 }
3130
3131
3132
3133 rc = drxj_dap_write_reg16(dev_addr, SIO_TOP_COMM_KEY__A, 0xFABA, 0);
3134 if (rc != 0) {
3135 pr_err("error %d\n", rc);
3136 goto rw_error;
3137 }
3138
3139 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MSTRT_CFG__A, 0x0013, 0);
3140 if (rc != 0) {
3141 pr_err("error %d\n", rc);
3142 goto rw_error;
3143 }
3144 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MERR_CFG__A, 0x0013, 0);
3145 if (rc != 0) {
3146 pr_err("error %d\n", rc);
3147 goto rw_error;
3148 }
3149 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MCLK_CFG__A, MPEG_OUTPUT_CLK_DRIVE_STRENGTH << SIO_PDR_MCLK_CFG_DRIVE__B | 0x03 << SIO_PDR_MCLK_CFG_MODE__B, 0);
3150 if (rc != 0) {
3151 pr_err("error %d\n", rc);
3152 goto rw_error;
3153 }
3154 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MVAL_CFG__A, 0x0013, 0);
3155 if (rc != 0) {
3156 pr_err("error %d\n", rc);
3157 goto rw_error;
3158 }
3159 sio_pdr_md_cfg =
3160 MPEG_SERIAL_OUTPUT_PIN_DRIVE_STRENGTH <<
3161 SIO_PDR_MD0_CFG_DRIVE__B | 0x03 << SIO_PDR_MD0_CFG_MODE__B;
3162 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MD0_CFG__A, sio_pdr_md_cfg, 0);
3163 if (rc != 0) {
3164 pr_err("error %d\n", rc);
3165 goto rw_error;
3166 }
3167 if (cfg_data->enable_parallel == true) {
3168 sio_pdr_md_cfg =
3169 MPEG_PARALLEL_OUTPUT_PIN_DRIVE_STRENGTH <<
3170 SIO_PDR_MD0_CFG_DRIVE__B | 0x03 <<
3171 SIO_PDR_MD0_CFG_MODE__B;
3172 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MD0_CFG__A, sio_pdr_md_cfg, 0);
3173 if (rc != 0) {
3174 pr_err("error %d\n", rc);
3175 goto rw_error;
3176 }
3177 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MD1_CFG__A, sio_pdr_md_cfg, 0);
3178 if (rc != 0) {
3179 pr_err("error %d\n", rc);
3180 goto rw_error;
3181 }
3182 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MD2_CFG__A, sio_pdr_md_cfg, 0);
3183 if (rc != 0) {
3184 pr_err("error %d\n", rc);
3185 goto rw_error;
3186 }
3187 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MD3_CFG__A, sio_pdr_md_cfg, 0);
3188 if (rc != 0) {
3189 pr_err("error %d\n", rc);
3190 goto rw_error;
3191 }
3192 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MD4_CFG__A, sio_pdr_md_cfg, 0);
3193 if (rc != 0) {
3194 pr_err("error %d\n", rc);
3195 goto rw_error;
3196 }
3197 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MD5_CFG__A, sio_pdr_md_cfg, 0);
3198 if (rc != 0) {
3199 pr_err("error %d\n", rc);
3200 goto rw_error;
3201 }
3202 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MD6_CFG__A, sio_pdr_md_cfg, 0);
3203 if (rc != 0) {
3204 pr_err("error %d\n", rc);
3205 goto rw_error;
3206 }
3207 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MD7_CFG__A, sio_pdr_md_cfg, 0);
3208 if (rc != 0) {
3209 pr_err("error %d\n", rc);
3210 goto rw_error;
3211 }
3212 } else {
3213 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MD1_CFG__A, 0x0000, 0);
3214 if (rc != 0) {
3215 pr_err("error %d\n", rc);
3216 goto rw_error;
3217 }
3218 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MD2_CFG__A, 0x0000, 0);
3219 if (rc != 0) {
3220 pr_err("error %d\n", rc);
3221 goto rw_error;
3222 }
3223 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MD3_CFG__A, 0x0000, 0);
3224 if (rc != 0) {
3225 pr_err("error %d\n", rc);
3226 goto rw_error;
3227 }
3228 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MD4_CFG__A, 0x0000, 0);
3229 if (rc != 0) {
3230 pr_err("error %d\n", rc);
3231 goto rw_error;
3232 }
3233 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MD5_CFG__A, 0x0000, 0);
3234 if (rc != 0) {
3235 pr_err("error %d\n", rc);
3236 goto rw_error;
3237 }
3238 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MD6_CFG__A, 0x0000, 0);
3239 if (rc != 0) {
3240 pr_err("error %d\n", rc);
3241 goto rw_error;
3242 }
3243 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MD7_CFG__A, 0x0000, 0);
3244 if (rc != 0) {
3245 pr_err("error %d\n", rc);
3246 goto rw_error;
3247 }
3248 }
3249
3250 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MON_CFG__A, 0x0000, 0);
3251 if (rc != 0) {
3252 pr_err("error %d\n", rc);
3253 goto rw_error;
3254 }
3255
3256 rc = drxj_dap_write_reg16(dev_addr, SIO_TOP_COMM_KEY__A, 0x0000, 0);
3257 if (rc != 0) {
3258 pr_err("error %d\n", rc);
3259 goto rw_error;
3260 }
3261 } else {
3262
3263 rc = drxj_dap_write_reg16(dev_addr, SIO_TOP_COMM_KEY__A, 0xFABA, 0);
3264 if (rc != 0) {
3265 pr_err("error %d\n", rc);
3266 goto rw_error;
3267 }
3268
3269 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MSTRT_CFG__A, 0x0000, 0);
3270 if (rc != 0) {
3271 pr_err("error %d\n", rc);
3272 goto rw_error;
3273 }
3274 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MERR_CFG__A, 0x0000, 0);
3275 if (rc != 0) {
3276 pr_err("error %d\n", rc);
3277 goto rw_error;
3278 }
3279 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MCLK_CFG__A, 0x0000, 0);
3280 if (rc != 0) {
3281 pr_err("error %d\n", rc);
3282 goto rw_error;
3283 }
3284 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MVAL_CFG__A, 0x0000, 0);
3285 if (rc != 0) {
3286 pr_err("error %d\n", rc);
3287 goto rw_error;
3288 }
3289 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MD0_CFG__A, 0x0000, 0);
3290 if (rc != 0) {
3291 pr_err("error %d\n", rc);
3292 goto rw_error;
3293 }
3294 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MD1_CFG__A, 0x0000, 0);
3295 if (rc != 0) {
3296 pr_err("error %d\n", rc);
3297 goto rw_error;
3298 }
3299 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MD2_CFG__A, 0x0000, 0);
3300 if (rc != 0) {
3301 pr_err("error %d\n", rc);
3302 goto rw_error;
3303 }
3304 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MD3_CFG__A, 0x0000, 0);
3305 if (rc != 0) {
3306 pr_err("error %d\n", rc);
3307 goto rw_error;
3308 }
3309 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MD4_CFG__A, 0x0000, 0);
3310 if (rc != 0) {
3311 pr_err("error %d\n", rc);
3312 goto rw_error;
3313 }
3314 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MD5_CFG__A, 0x0000, 0);
3315 if (rc != 0) {
3316 pr_err("error %d\n", rc);
3317 goto rw_error;
3318 }
3319 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MD6_CFG__A, 0x0000, 0);
3320 if (rc != 0) {
3321 pr_err("error %d\n", rc);
3322 goto rw_error;
3323 }
3324 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MD7_CFG__A, 0x0000, 0);
3325 if (rc != 0) {
3326 pr_err("error %d\n", rc);
3327 goto rw_error;
3328 }
3329
3330 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_MON_CFG__A, 0x0000, 0);
3331 if (rc != 0) {
3332 pr_err("error %d\n", rc);
3333 goto rw_error;
3334 }
3335
3336 rc = drxj_dap_write_reg16(dev_addr, SIO_TOP_COMM_KEY__A, 0x0000, 0);
3337 if (rc != 0) {
3338 pr_err("error %d\n", rc);
3339 goto rw_error;
3340 }
3341 }
3342
3343
3344 common_attr->mpeg_cfg.enable_mpeg_output = cfg_data->enable_mpeg_output;
3345
3346 return 0;
3347rw_error:
3348 return rc;
3349}
3350
3351
3352
3353
3354
3355
3356
3357
3358
3359
3360
3361
3362
3363
3364
3365
3366
3367
3368
3369
3370
3371static int set_mpegtei_handling(struct drx_demod_instance *demod)
3372{
3373 struct drxj_data *ext_attr = (struct drxj_data *) (NULL);
3374 struct i2c_device_addr *dev_addr = (struct i2c_device_addr *)(NULL);
3375 int rc;
3376 u16 fec_oc_dpr_mode = 0;
3377 u16 fec_oc_snc_mode = 0;
3378 u16 fec_oc_ems_mode = 0;
3379
3380 dev_addr = demod->my_i2c_dev_addr;
3381 ext_attr = (struct drxj_data *) demod->my_ext_attr;
3382
3383 rc = drxj_dap_read_reg16(dev_addr, FEC_OC_DPR_MODE__A, &fec_oc_dpr_mode, 0);
3384 if (rc != 0) {
3385 pr_err("error %d\n", rc);
3386 goto rw_error;
3387 }
3388 rc = drxj_dap_read_reg16(dev_addr, FEC_OC_SNC_MODE__A, &fec_oc_snc_mode, 0);
3389 if (rc != 0) {
3390 pr_err("error %d\n", rc);
3391 goto rw_error;
3392 }
3393 rc = drxj_dap_read_reg16(dev_addr, FEC_OC_EMS_MODE__A, &fec_oc_ems_mode, 0);
3394 if (rc != 0) {
3395 pr_err("error %d\n", rc);
3396 goto rw_error;
3397 }
3398
3399
3400 fec_oc_dpr_mode &= (~FEC_OC_DPR_MODE_ERR_DISABLE__M);
3401 fec_oc_snc_mode &= (~(FEC_OC_SNC_MODE_ERROR_CTL__M |
3402 FEC_OC_SNC_MODE_CORR_DISABLE__M));
3403 fec_oc_ems_mode &= (~FEC_OC_EMS_MODE_MODE__M);
3404
3405 if (ext_attr->disable_te_ihandling) {
3406
3407 fec_oc_dpr_mode |= FEC_OC_DPR_MODE_ERR_DISABLE__M;
3408 fec_oc_snc_mode |= FEC_OC_SNC_MODE_CORR_DISABLE__M |
3409 ((0x2) << (FEC_OC_SNC_MODE_ERROR_CTL__B));
3410 fec_oc_ems_mode |= ((0x01) << (FEC_OC_EMS_MODE_MODE__B));
3411 }
3412
3413 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_DPR_MODE__A, fec_oc_dpr_mode, 0);
3414 if (rc != 0) {
3415 pr_err("error %d\n", rc);
3416 goto rw_error;
3417 }
3418 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_SNC_MODE__A, fec_oc_snc_mode, 0);
3419 if (rc != 0) {
3420 pr_err("error %d\n", rc);
3421 goto rw_error;
3422 }
3423 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_EMS_MODE__A, fec_oc_ems_mode, 0);
3424 if (rc != 0) {
3425 pr_err("error %d\n", rc);
3426 goto rw_error;
3427 }
3428
3429 return 0;
3430rw_error:
3431 return rc;
3432}
3433
3434
3435
3436
3437
3438
3439
3440
3441
3442
3443
3444static int bit_reverse_mpeg_output(struct drx_demod_instance *demod)
3445{
3446 struct drxj_data *ext_attr = (struct drxj_data *) (NULL);
3447 struct i2c_device_addr *dev_addr = (struct i2c_device_addr *)(NULL);
3448 int rc;
3449 u16 fec_oc_ipr_mode = 0;
3450
3451 dev_addr = demod->my_i2c_dev_addr;
3452 ext_attr = (struct drxj_data *) demod->my_ext_attr;
3453
3454 rc = drxj_dap_read_reg16(dev_addr, FEC_OC_IPR_MODE__A, &fec_oc_ipr_mode, 0);
3455 if (rc != 0) {
3456 pr_err("error %d\n", rc);
3457 goto rw_error;
3458 }
3459
3460
3461 fec_oc_ipr_mode &= (~FEC_OC_IPR_MODE_REVERSE_ORDER__M);
3462
3463 if (ext_attr->bit_reverse_mpeg_outout)
3464 fec_oc_ipr_mode |= FEC_OC_IPR_MODE_REVERSE_ORDER__M;
3465
3466 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_IPR_MODE__A, fec_oc_ipr_mode, 0);
3467 if (rc != 0) {
3468 pr_err("error %d\n", rc);
3469 goto rw_error;
3470 }
3471
3472 return 0;
3473rw_error:
3474 return rc;
3475}
3476
3477
3478
3479
3480
3481
3482
3483
3484
3485
3486
3487static int set_mpeg_start_width(struct drx_demod_instance *demod)
3488{
3489 struct drxj_data *ext_attr = (struct drxj_data *) (NULL);
3490 struct i2c_device_addr *dev_addr = (struct i2c_device_addr *)(NULL);
3491 struct drx_common_attr *common_attr = (struct drx_common_attr *) NULL;
3492 int rc;
3493 u16 fec_oc_comm_mb = 0;
3494
3495 dev_addr = demod->my_i2c_dev_addr;
3496 ext_attr = (struct drxj_data *) demod->my_ext_attr;
3497 common_attr = demod->my_common_attr;
3498
3499 if ((common_attr->mpeg_cfg.static_clk == true)
3500 && (common_attr->mpeg_cfg.enable_parallel == false)) {
3501 rc = drxj_dap_read_reg16(dev_addr, FEC_OC_COMM_MB__A, &fec_oc_comm_mb, 0);
3502 if (rc != 0) {
3503 pr_err("error %d\n", rc);
3504 goto rw_error;
3505 }
3506 fec_oc_comm_mb &= ~FEC_OC_COMM_MB_CTL_ON;
3507 if (ext_attr->mpeg_start_width == DRXJ_MPEG_START_WIDTH_8CLKCYC)
3508 fec_oc_comm_mb |= FEC_OC_COMM_MB_CTL_ON;
3509 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_COMM_MB__A, fec_oc_comm_mb, 0);
3510 if (rc != 0) {
3511 pr_err("error %d\n", rc);
3512 goto rw_error;
3513 }
3514 }
3515
3516 return 0;
3517rw_error:
3518 return rc;
3519}
3520
3521
3522
3523
3524
3525
3526
3527
3528
3529
3530
3531
3532
3533
3534
3535static int ctrl_set_uio_cfg(struct drx_demod_instance *demod, struct drxuio_cfg *uio_cfg)
3536{
3537 struct drxj_data *ext_attr = (struct drxj_data *) (NULL);
3538 int rc;
3539
3540 if ((uio_cfg == NULL) || (demod == NULL))
3541 return -EINVAL;
3542
3543 ext_attr = (struct drxj_data *) demod->my_ext_attr;
3544
3545
3546 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr, SIO_TOP_COMM_KEY__A, SIO_TOP_COMM_KEY_KEY, 0);
3547 if (rc != 0) {
3548 pr_err("error %d\n", rc);
3549 goto rw_error;
3550 }
3551 switch (uio_cfg->uio) {
3552
3553 case DRX_UIO1:
3554
3555 if (!ext_attr->has_smatx)
3556 return -EIO;
3557 switch (uio_cfg->mode) {
3558 case DRX_UIO_MODE_FIRMWARE_SMA:
3559 case DRX_UIO_MODE_FIRMWARE_SAW:
3560 case DRX_UIO_MODE_READWRITE:
3561 ext_attr->uio_sma_tx_mode = uio_cfg->mode;
3562 break;
3563 case DRX_UIO_MODE_DISABLE:
3564 ext_attr->uio_sma_tx_mode = uio_cfg->mode;
3565
3566 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr, SIO_PDR_SMA_TX_CFG__A, 0, 0);
3567 if (rc != 0) {
3568 pr_err("error %d\n", rc);
3569 goto rw_error;
3570 }
3571 break;
3572 default:
3573 return -EINVAL;
3574 }
3575 break;
3576
3577 case DRX_UIO2:
3578
3579 if (!ext_attr->has_smarx)
3580 return -EIO;
3581 switch (uio_cfg->mode) {
3582 case DRX_UIO_MODE_FIRMWARE0:
3583 case DRX_UIO_MODE_READWRITE:
3584 ext_attr->uio_sma_rx_mode = uio_cfg->mode;
3585 break;
3586 case DRX_UIO_MODE_DISABLE:
3587 ext_attr->uio_sma_rx_mode = uio_cfg->mode;
3588
3589 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr, SIO_PDR_SMA_RX_CFG__A, 0, 0);
3590 if (rc != 0) {
3591 pr_err("error %d\n", rc);
3592 goto rw_error;
3593 }
3594 break;
3595 default:
3596 return -EINVAL;
3597 break;
3598 }
3599 break;
3600
3601 case DRX_UIO3:
3602
3603 if (!ext_attr->has_gpio)
3604 return -EIO;
3605 switch (uio_cfg->mode) {
3606 case DRX_UIO_MODE_FIRMWARE0:
3607 case DRX_UIO_MODE_READWRITE:
3608 ext_attr->uio_gpio_mode = uio_cfg->mode;
3609 break;
3610 case DRX_UIO_MODE_DISABLE:
3611 ext_attr->uio_gpio_mode = uio_cfg->mode;
3612
3613 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr, SIO_PDR_GPIO_CFG__A, 0, 0);
3614 if (rc != 0) {
3615 pr_err("error %d\n", rc);
3616 goto rw_error;
3617 }
3618 break;
3619 default:
3620 return -EINVAL;
3621 break;
3622 }
3623 break;
3624
3625 case DRX_UIO4:
3626
3627 if (!ext_attr->has_irqn)
3628 return -EIO;
3629 switch (uio_cfg->mode) {
3630 case DRX_UIO_MODE_READWRITE:
3631 ext_attr->uio_irqn_mode = uio_cfg->mode;
3632 break;
3633 case DRX_UIO_MODE_DISABLE:
3634
3635 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr, SIO_PDR_IRQN_CFG__A, 0, 0);
3636 if (rc != 0) {
3637 pr_err("error %d\n", rc);
3638 goto rw_error;
3639 }
3640 ext_attr->uio_irqn_mode = uio_cfg->mode;
3641 break;
3642 case DRX_UIO_MODE_FIRMWARE0:
3643 default:
3644 return -EINVAL;
3645 break;
3646 }
3647 break;
3648
3649 default:
3650 return -EINVAL;
3651 }
3652
3653
3654 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr, SIO_TOP_COMM_KEY__A, 0x0000, 0);
3655 if (rc != 0) {
3656 pr_err("error %d\n", rc);
3657 goto rw_error;
3658 }
3659
3660 return 0;
3661rw_error:
3662 return rc;
3663}
3664
3665
3666
3667
3668
3669
3670
3671
3672static int
3673ctrl_uio_write(struct drx_demod_instance *demod, struct drxuio_data *uio_data)
3674{
3675 struct drxj_data *ext_attr = (struct drxj_data *) (NULL);
3676 int rc;
3677 u16 pin_cfg_value = 0;
3678 u16 value = 0;
3679
3680 if ((uio_data == NULL) || (demod == NULL))
3681 return -EINVAL;
3682
3683 ext_attr = (struct drxj_data *) demod->my_ext_attr;
3684
3685
3686 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr, SIO_TOP_COMM_KEY__A, SIO_TOP_COMM_KEY_KEY, 0);
3687 if (rc != 0) {
3688 pr_err("error %d\n", rc);
3689 goto rw_error;
3690 }
3691 switch (uio_data->uio) {
3692
3693 case DRX_UIO1:
3694
3695 if (!ext_attr->has_smatx)
3696 return -EIO;
3697 if ((ext_attr->uio_sma_tx_mode != DRX_UIO_MODE_READWRITE)
3698 && (ext_attr->uio_sma_tx_mode != DRX_UIO_MODE_FIRMWARE_SAW)) {
3699 return -EIO;
3700 }
3701 pin_cfg_value = 0;
3702
3703 pin_cfg_value |= 0x0113;
3704
3705
3706
3707
3708 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr, SIO_PDR_SMA_TX_CFG__A, pin_cfg_value, 0);
3709 if (rc != 0) {
3710 pr_err("error %d\n", rc);
3711 goto rw_error;
3712 }
3713
3714
3715 rc = drxj_dap_read_reg16(demod->my_i2c_dev_addr, SIO_PDR_UIO_OUT_LO__A, &value, 0);
3716 if (rc != 0) {
3717 pr_err("error %d\n", rc);
3718 goto rw_error;
3719 }
3720 if (!uio_data->value)
3721 value &= 0x7FFF;
3722 else
3723 value |= 0x8000;
3724
3725
3726 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr, SIO_PDR_UIO_OUT_LO__A, value, 0);
3727 if (rc != 0) {
3728 pr_err("error %d\n", rc);
3729 goto rw_error;
3730 }
3731 break;
3732
3733 case DRX_UIO2:
3734
3735 if (!ext_attr->has_smarx)
3736 return -EIO;
3737 if (ext_attr->uio_sma_rx_mode != DRX_UIO_MODE_READWRITE)
3738 return -EIO;
3739
3740 pin_cfg_value = 0;
3741
3742 pin_cfg_value |= 0x0113;
3743
3744
3745
3746
3747 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr, SIO_PDR_SMA_RX_CFG__A, pin_cfg_value, 0);
3748 if (rc != 0) {
3749 pr_err("error %d\n", rc);
3750 goto rw_error;
3751 }
3752
3753
3754 rc = drxj_dap_read_reg16(demod->my_i2c_dev_addr, SIO_PDR_UIO_OUT_LO__A, &value, 0);
3755 if (rc != 0) {
3756 pr_err("error %d\n", rc);
3757 goto rw_error;
3758 }
3759 if (!uio_data->value)
3760 value &= 0xBFFF;
3761 else
3762 value |= 0x4000;
3763
3764
3765 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr, SIO_PDR_UIO_OUT_LO__A, value, 0);
3766 if (rc != 0) {
3767 pr_err("error %d\n", rc);
3768 goto rw_error;
3769 }
3770 break;
3771
3772 case DRX_UIO3:
3773
3774 if (!ext_attr->has_gpio)
3775 return -EIO;
3776 if (ext_attr->uio_gpio_mode != DRX_UIO_MODE_READWRITE)
3777 return -EIO;
3778
3779 pin_cfg_value = 0;
3780
3781 pin_cfg_value |= 0x0113;
3782
3783
3784
3785
3786 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr, SIO_PDR_GPIO_CFG__A, pin_cfg_value, 0);
3787 if (rc != 0) {
3788 pr_err("error %d\n", rc);
3789 goto rw_error;
3790 }
3791
3792
3793 rc = drxj_dap_read_reg16(demod->my_i2c_dev_addr, SIO_PDR_UIO_OUT_HI__A, &value, 0);
3794 if (rc != 0) {
3795 pr_err("error %d\n", rc);
3796 goto rw_error;
3797 }
3798 if (!uio_data->value)
3799 value &= 0xFFFB;
3800 else
3801 value |= 0x0004;
3802
3803
3804 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr, SIO_PDR_UIO_OUT_HI__A, value, 0);
3805 if (rc != 0) {
3806 pr_err("error %d\n", rc);
3807 goto rw_error;
3808 }
3809 break;
3810
3811 case DRX_UIO4:
3812
3813 if (!ext_attr->has_irqn)
3814 return -EIO;
3815
3816 if (ext_attr->uio_irqn_mode != DRX_UIO_MODE_READWRITE)
3817 return -EIO;
3818
3819 pin_cfg_value = 0;
3820
3821 pin_cfg_value |= 0x0113;
3822
3823
3824
3825
3826 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr, SIO_PDR_IRQN_CFG__A, pin_cfg_value, 0);
3827 if (rc != 0) {
3828 pr_err("error %d\n", rc);
3829 goto rw_error;
3830 }
3831
3832
3833 rc = drxj_dap_read_reg16(demod->my_i2c_dev_addr, SIO_PDR_UIO_OUT_LO__A, &value, 0);
3834 if (rc != 0) {
3835 pr_err("error %d\n", rc);
3836 goto rw_error;
3837 }
3838 if (uio_data->value == false)
3839 value &= 0xEFFF;
3840 else
3841 value |= 0x1000;
3842
3843
3844 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr, SIO_PDR_UIO_OUT_LO__A, value, 0);
3845 if (rc != 0) {
3846 pr_err("error %d\n", rc);
3847 goto rw_error;
3848 }
3849 break;
3850
3851 default:
3852 return -EINVAL;
3853 }
3854
3855
3856 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr, SIO_TOP_COMM_KEY__A, 0x0000, 0);
3857 if (rc != 0) {
3858 pr_err("error %d\n", rc);
3859 goto rw_error;
3860 }
3861
3862 return 0;
3863rw_error:
3864 return rc;
3865}
3866
3867
3868
3869
3870
3871
3872
3873
3874
3875
3876
3877
3878
3879
3880
3881
3882static int
3883ctrl_i2c_bridge(struct drx_demod_instance *demod, bool *bridge_closed)
3884{
3885 struct drxj_hi_cmd hi_cmd;
3886 u16 result = 0;
3887
3888
3889 if (bridge_closed == NULL)
3890 return -EINVAL;
3891
3892 hi_cmd.cmd = SIO_HI_RA_RAM_CMD_BRDCTRL;
3893 hi_cmd.param1 = SIO_HI_RA_RAM_PAR_1_PAR1_SEC_KEY;
3894 if (*bridge_closed)
3895 hi_cmd.param2 = SIO_HI_RA_RAM_PAR_2_BRD_CFG_CLOSED;
3896 else
3897 hi_cmd.param2 = SIO_HI_RA_RAM_PAR_2_BRD_CFG_OPEN;
3898
3899 return hi_command(demod->my_i2c_dev_addr, &hi_cmd, &result);
3900}
3901
3902
3903
3904
3905
3906
3907
3908
3909
3910
3911
3912
3913
3914
3915
3916static int smart_ant_init(struct drx_demod_instance *demod)
3917{
3918 struct drxj_data *ext_attr = NULL;
3919 struct i2c_device_addr *dev_addr = NULL;
3920 struct drxuio_cfg uio_cfg = { DRX_UIO1, DRX_UIO_MODE_FIRMWARE_SMA };
3921 int rc;
3922 u16 data = 0;
3923
3924 dev_addr = demod->my_i2c_dev_addr;
3925 ext_attr = (struct drxj_data *) demod->my_ext_attr;
3926
3927
3928 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr, SIO_TOP_COMM_KEY__A, SIO_TOP_COMM_KEY_KEY, 0);
3929 if (rc != 0) {
3930 pr_err("error %d\n", rc);
3931 goto rw_error;
3932 }
3933
3934 rc = drxj_dap_read_reg16(dev_addr, SIO_SA_TX_COMMAND__A, &data, 0);
3935 if (rc != 0) {
3936 pr_err("error %d\n", rc);
3937 goto rw_error;
3938 }
3939 if (ext_attr->smart_ant_inverted) {
3940 rc = drxj_dap_write_reg16(dev_addr, SIO_SA_TX_COMMAND__A, (data | SIO_SA_TX_COMMAND_TX_INVERT__M) | SIO_SA_TX_COMMAND_TX_ENABLE__M, 0);
3941 if (rc != 0) {
3942 pr_err("error %d\n", rc);
3943 goto rw_error;
3944 }
3945 } else {
3946 rc = drxj_dap_write_reg16(dev_addr, SIO_SA_TX_COMMAND__A, (data & (~SIO_SA_TX_COMMAND_TX_INVERT__M)) | SIO_SA_TX_COMMAND_TX_ENABLE__M, 0);
3947 if (rc != 0) {
3948 pr_err("error %d\n", rc);
3949 goto rw_error;
3950 }
3951 }
3952
3953
3954 rc = ctrl_set_uio_cfg(demod, &uio_cfg);
3955 if (rc != 0) {
3956 pr_err("error %d\n", rc);
3957 goto rw_error;
3958 }
3959 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr, SIO_PDR_SMA_TX_CFG__A, 0x13, 0);
3960 if (rc != 0) {
3961 pr_err("error %d\n", rc);
3962 goto rw_error;
3963 }
3964 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr, SIO_PDR_SMA_TX_GPIO_FNC__A, 0x03, 0);
3965 if (rc != 0) {
3966 pr_err("error %d\n", rc);
3967 goto rw_error;
3968 }
3969
3970
3971 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr, SIO_TOP_COMM_KEY__A, 0x0000, 0);
3972 if (rc != 0) {
3973 pr_err("error %d\n", rc);
3974 goto rw_error;
3975 }
3976
3977 return 0;
3978rw_error:
3979 return rc;
3980}
3981
3982static int scu_command(struct i2c_device_addr *dev_addr, struct drxjscu_cmd *cmd)
3983{
3984 int rc;
3985 u16 cur_cmd = 0;
3986 unsigned long timeout;
3987
3988
3989 if (cmd == NULL)
3990 return -EINVAL;
3991
3992
3993 rc = drxj_dap_read_reg16(dev_addr, SCU_RAM_COMMAND__A, &cur_cmd, 0);
3994 if (rc != 0) {
3995 pr_err("error %d\n", rc);
3996 goto rw_error;
3997 }
3998 if (cur_cmd != DRX_SCU_READY)
3999 return -EIO;
4000
4001 switch (cmd->parameter_len) {
4002 case 5:
4003 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_PARAM_4__A, *(cmd->parameter + 4), 0);
4004 if (rc != 0) {
4005 pr_err("error %d\n", rc);
4006 goto rw_error;
4007 }
4008 case 4:
4009 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_PARAM_3__A, *(cmd->parameter + 3), 0);
4010 if (rc != 0) {
4011 pr_err("error %d\n", rc);
4012 goto rw_error;
4013 }
4014 case 3:
4015 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_PARAM_2__A, *(cmd->parameter + 2), 0);
4016 if (rc != 0) {
4017 pr_err("error %d\n", rc);
4018 goto rw_error;
4019 }
4020 case 2:
4021 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_PARAM_1__A, *(cmd->parameter + 1), 0);
4022 if (rc != 0) {
4023 pr_err("error %d\n", rc);
4024 goto rw_error;
4025 }
4026 case 1:
4027 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_PARAM_0__A, *(cmd->parameter + 0), 0);
4028 if (rc != 0) {
4029 pr_err("error %d\n", rc);
4030 goto rw_error;
4031 }
4032 case 0:
4033
4034 break;
4035 default:
4036
4037 return -EIO;
4038 }
4039 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_COMMAND__A, cmd->command, 0);
4040 if (rc != 0) {
4041 pr_err("error %d\n", rc);
4042 goto rw_error;
4043 }
4044
4045
4046 timeout = jiffies + msecs_to_jiffies(DRXJ_MAX_WAITTIME);
4047 while (time_is_after_jiffies(timeout)) {
4048 rc = drxj_dap_read_reg16(dev_addr, SCU_RAM_COMMAND__A, &cur_cmd, 0);
4049 if (rc != 0) {
4050 pr_err("error %d\n", rc);
4051 goto rw_error;
4052 }
4053 if (cur_cmd == DRX_SCU_READY)
4054 break;
4055 usleep_range(1000, 2000);
4056 }
4057
4058 if (cur_cmd != DRX_SCU_READY)
4059 return -EIO;
4060
4061
4062 if ((cmd->result_len > 0) && (cmd->result != NULL)) {
4063 s16 err;
4064
4065 switch (cmd->result_len) {
4066 case 4:
4067 rc = drxj_dap_read_reg16(dev_addr, SCU_RAM_PARAM_3__A, cmd->result + 3, 0);
4068 if (rc != 0) {
4069 pr_err("error %d\n", rc);
4070 goto rw_error;
4071 }
4072 case 3:
4073 rc = drxj_dap_read_reg16(dev_addr, SCU_RAM_PARAM_2__A, cmd->result + 2, 0);
4074 if (rc != 0) {
4075 pr_err("error %d\n", rc);
4076 goto rw_error;
4077 }
4078 case 2:
4079 rc = drxj_dap_read_reg16(dev_addr, SCU_RAM_PARAM_1__A, cmd->result + 1, 0);
4080 if (rc != 0) {
4081 pr_err("error %d\n", rc);
4082 goto rw_error;
4083 }
4084 case 1:
4085 rc = drxj_dap_read_reg16(dev_addr, SCU_RAM_PARAM_0__A, cmd->result + 0, 0);
4086 if (rc != 0) {
4087 pr_err("error %d\n", rc);
4088 goto rw_error;
4089 }
4090 case 0:
4091
4092 break;
4093 default:
4094
4095 return -EIO;
4096 }
4097
4098
4099 err = cmd->result[0];
4100
4101
4102 if ((err == (s16) SCU_RAM_PARAM_0_RESULT_UNKSTD)
4103 || (err == (s16) SCU_RAM_PARAM_0_RESULT_UNKCMD)
4104 || (err == (s16) SCU_RAM_PARAM_0_RESULT_INVPAR)
4105 || (err == (s16) SCU_RAM_PARAM_0_RESULT_SIZE)
4106 ) {
4107 return -EINVAL;
4108 }
4109
4110 else if (err < 0)
4111 return -EIO;
4112 else
4113 return 0;
4114 }
4115
4116 return 0;
4117
4118rw_error:
4119 return rc;
4120}
4121
4122
4123
4124
4125
4126
4127
4128
4129
4130
4131
4132
4133
4134#define ADDR_AT_SCU_SPACE(x) ((x - 0x82E000) * 2)
4135static
4136int drxj_dap_scu_atomic_read_write_block(struct i2c_device_addr *dev_addr, u32 addr, u16 datasize,
4137 u8 *data, bool read_flag)
4138{
4139 struct drxjscu_cmd scu_cmd;
4140 int rc;
4141 u16 set_param_parameters[18];
4142 u16 cmd_result[15];
4143
4144
4145 if (!data || !dev_addr || (datasize % 2) || ((datasize / 2) > 16))
4146 return -EINVAL;
4147
4148 set_param_parameters[1] = (u16) ADDR_AT_SCU_SPACE(addr);
4149 if (read_flag) {
4150 set_param_parameters[0] = ((~(0x0080)) & datasize);
4151 scu_cmd.parameter_len = 2;
4152 scu_cmd.result_len = datasize / 2 + 2;
4153 } else {
4154 int i = 0;
4155
4156 set_param_parameters[0] = 0x0080 | datasize;
4157 for (i = 0; i < (datasize / 2); i++) {
4158 set_param_parameters[i + 2] =
4159 (data[2 * i] | (data[(2 * i) + 1] << 8));
4160 }
4161 scu_cmd.parameter_len = datasize / 2 + 2;
4162 scu_cmd.result_len = 1;
4163 }
4164
4165 scu_cmd.command =
4166 SCU_RAM_COMMAND_STANDARD_TOP |
4167 SCU_RAM_COMMAND_CMD_AUX_SCU_ATOMIC_ACCESS;
4168 scu_cmd.result = cmd_result;
4169 scu_cmd.parameter = set_param_parameters;
4170 rc = scu_command(dev_addr, &scu_cmd);
4171 if (rc != 0) {
4172 pr_err("error %d\n", rc);
4173 goto rw_error;
4174 }
4175
4176 if (read_flag) {
4177 int i = 0;
4178
4179 for (i = 0; i < (datasize / 2); i++) {
4180 data[2 * i] = (u8) (scu_cmd.result[i + 2] & 0xFF);
4181 data[(2 * i) + 1] = (u8) (scu_cmd.result[i + 2] >> 8);
4182 }
4183 }
4184
4185 return 0;
4186
4187rw_error:
4188 return rc;
4189
4190}
4191
4192
4193
4194
4195
4196
4197
4198static
4199int drxj_dap_scu_atomic_read_reg16(struct i2c_device_addr *dev_addr,
4200 u32 addr,
4201 u16 *data, u32 flags)
4202{
4203 u8 buf[2] = { 0 };
4204 int rc = -EIO;
4205 u16 word = 0;
4206
4207 if (!data)
4208 return -EINVAL;
4209
4210 rc = drxj_dap_scu_atomic_read_write_block(dev_addr, addr, 2, buf, true);
4211 if (rc < 0)
4212 return rc;
4213
4214 word = (u16) (buf[0] + (buf[1] << 8));
4215
4216 *data = word;
4217
4218 return rc;
4219}
4220
4221
4222
4223
4224
4225
4226static
4227int drxj_dap_scu_atomic_write_reg16(struct i2c_device_addr *dev_addr,
4228 u32 addr,
4229 u16 data, u32 flags)
4230{
4231 u8 buf[2];
4232 int rc = -EIO;
4233
4234 buf[0] = (u8) (data & 0xff);
4235 buf[1] = (u8) ((data >> 8) & 0xff);
4236
4237 rc = drxj_dap_scu_atomic_read_write_block(dev_addr, addr, 2, buf, false);
4238
4239 return rc;
4240}
4241
4242
4243
4244
4245
4246
4247
4248
4249
4250
4251
4252static int adc_sync_measurement(struct drx_demod_instance *demod, u16 *count)
4253{
4254 struct i2c_device_addr *dev_addr = NULL;
4255 int rc;
4256 u16 data = 0;
4257
4258 dev_addr = demod->my_i2c_dev_addr;
4259
4260
4261 rc = drxj_dap_write_reg16(dev_addr, IQM_AF_COMM_EXEC__A, IQM_AF_COMM_EXEC_ACTIVE, 0);
4262 if (rc != 0) {
4263 pr_err("error %d\n", rc);
4264 goto rw_error;
4265 }
4266 rc = drxj_dap_write_reg16(dev_addr, IQM_AF_START_LOCK__A, 1, 0);
4267 if (rc != 0) {
4268 pr_err("error %d\n", rc);
4269 goto rw_error;
4270 }
4271
4272
4273 msleep(1);
4274
4275 *count = 0;
4276 rc = drxj_dap_read_reg16(dev_addr, IQM_AF_PHASE0__A, &data, 0);
4277 if (rc != 0) {
4278 pr_err("error %d\n", rc);
4279 goto rw_error;
4280 }
4281 if (data == 127)
4282 *count = *count + 1;
4283 rc = drxj_dap_read_reg16(dev_addr, IQM_AF_PHASE1__A, &data, 0);
4284 if (rc != 0) {
4285 pr_err("error %d\n", rc);
4286 goto rw_error;
4287 }
4288 if (data == 127)
4289 *count = *count + 1;
4290 rc = drxj_dap_read_reg16(dev_addr, IQM_AF_PHASE2__A, &data, 0);
4291 if (rc != 0) {
4292 pr_err("error %d\n", rc);
4293 goto rw_error;
4294 }
4295 if (data == 127)
4296 *count = *count + 1;
4297
4298 return 0;
4299rw_error:
4300 return rc;
4301}
4302
4303
4304
4305
4306
4307
4308
4309
4310
4311
4312
4313
4314
4315static int adc_synchronization(struct drx_demod_instance *demod)
4316{
4317 struct i2c_device_addr *dev_addr = NULL;
4318 int rc;
4319 u16 count = 0;
4320
4321 dev_addr = demod->my_i2c_dev_addr;
4322
4323 rc = adc_sync_measurement(demod, &count);
4324 if (rc != 0) {
4325 pr_err("error %d\n", rc);
4326 goto rw_error;
4327 }
4328
4329 if (count == 1) {
4330
4331 u16 clk_neg = 0;
4332
4333 rc = drxj_dap_read_reg16(dev_addr, IQM_AF_CLKNEG__A, &clk_neg, 0);
4334 if (rc != 0) {
4335 pr_err("error %d\n", rc);
4336 goto rw_error;
4337 }
4338
4339 clk_neg ^= IQM_AF_CLKNEG_CLKNEGDATA__M;
4340 rc = drxj_dap_write_reg16(dev_addr, IQM_AF_CLKNEG__A, clk_neg, 0);
4341 if (rc != 0) {
4342 pr_err("error %d\n", rc);
4343 goto rw_error;
4344 }
4345
4346 rc = adc_sync_measurement(demod, &count);
4347 if (rc != 0) {
4348 pr_err("error %d\n", rc);
4349 goto rw_error;
4350 }
4351 }
4352
4353
4354 if (count < 2)
4355 return -EIO;
4356
4357 return 0;
4358rw_error:
4359 return rc;
4360}
4361
4362
4363
4364
4365
4366
4367
4368
4369
4370
4371
4372
4373
4374
4375
4376
4377
4378static int init_agc(struct drx_demod_instance *demod)
4379{
4380 struct i2c_device_addr *dev_addr = NULL;
4381 struct drx_common_attr *common_attr = NULL;
4382 struct drxj_data *ext_attr = NULL;
4383 struct drxj_cfg_agc *p_agc_rf_settings = NULL;
4384 struct drxj_cfg_agc *p_agc_if_settings = NULL;
4385 int rc;
4386 u16 ingain_tgt_max = 0;
4387 u16 clp_dir_to = 0;
4388 u16 sns_sum_max = 0;
4389 u16 clp_sum_max = 0;
4390 u16 sns_dir_to = 0;
4391 u16 ki_innergain_min = 0;
4392 u16 agc_ki = 0;
4393 u16 ki_max = 0;
4394 u16 if_iaccu_hi_tgt_min = 0;
4395 u16 data = 0;
4396 u16 agc_ki_dgain = 0;
4397 u16 ki_min = 0;
4398 u16 clp_ctrl_mode = 0;
4399 u16 agc_rf = 0;
4400 u16 agc_if = 0;
4401
4402 dev_addr = demod->my_i2c_dev_addr;
4403 common_attr = (struct drx_common_attr *) demod->my_common_attr;
4404 ext_attr = (struct drxj_data *) demod->my_ext_attr;
4405
4406 switch (ext_attr->standard) {
4407 case DRX_STANDARD_8VSB:
4408 clp_sum_max = 1023;
4409 clp_dir_to = (u16) (-9);
4410 sns_sum_max = 1023;
4411 sns_dir_to = (u16) (-9);
4412 ki_innergain_min = (u16) (-32768);
4413 ki_max = 0x032C;
4414 agc_ki_dgain = 0xC;
4415 if_iaccu_hi_tgt_min = 2047;
4416 ki_min = 0x0117;
4417 ingain_tgt_max = 16383;
4418 clp_ctrl_mode = 0;
4419 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_KI_MINGAIN__A, 0x7fff, 0);
4420 if (rc != 0) {
4421 pr_err("error %d\n", rc);
4422 goto rw_error;
4423 }
4424 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_KI_MAXGAIN__A, 0x0, 0);
4425 if (rc != 0) {
4426 pr_err("error %d\n", rc);
4427 goto rw_error;
4428 }
4429 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_CLP_SUM__A, 0, 0);
4430 if (rc != 0) {
4431 pr_err("error %d\n", rc);
4432 goto rw_error;
4433 }
4434 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_CLP_CYCCNT__A, 0, 0);
4435 if (rc != 0) {
4436 pr_err("error %d\n", rc);
4437 goto rw_error;
4438 }
4439 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_CLP_DIR_WD__A, 0, 0);
4440 if (rc != 0) {
4441 pr_err("error %d\n", rc);
4442 goto rw_error;
4443 }
4444 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_CLP_DIR_STP__A, 1, 0);
4445 if (rc != 0) {
4446 pr_err("error %d\n", rc);
4447 goto rw_error;
4448 }
4449 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_SNS_SUM__A, 0, 0);
4450 if (rc != 0) {
4451 pr_err("error %d\n", rc);
4452 goto rw_error;
4453 }
4454 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_SNS_CYCCNT__A, 0, 0);
4455 if (rc != 0) {
4456 pr_err("error %d\n", rc);
4457 goto rw_error;
4458 }
4459 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_SNS_DIR_WD__A, 0, 0);
4460 if (rc != 0) {
4461 pr_err("error %d\n", rc);
4462 goto rw_error;
4463 }
4464 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_SNS_DIR_STP__A, 1, 0);
4465 if (rc != 0) {
4466 pr_err("error %d\n", rc);
4467 goto rw_error;
4468 }
4469 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_INGAIN__A, 1024, 0);
4470 if (rc != 0) {
4471 pr_err("error %d\n", rc);
4472 goto rw_error;
4473 }
4474 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_VSB_AGC_POW_TGT__A, 22600, 0);
4475 if (rc != 0) {
4476 pr_err("error %d\n", rc);
4477 goto rw_error;
4478 }
4479 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_INGAIN_TGT__A, 13200, 0);
4480 if (rc != 0) {
4481 pr_err("error %d\n", rc);
4482 goto rw_error;
4483 }
4484 p_agc_if_settings = &(ext_attr->vsb_if_agc_cfg);
4485 p_agc_rf_settings = &(ext_attr->vsb_rf_agc_cfg);
4486 break;
4487#ifndef DRXJ_VSB_ONLY
4488 case DRX_STANDARD_ITU_A:
4489 case DRX_STANDARD_ITU_C:
4490 case DRX_STANDARD_ITU_B:
4491 ingain_tgt_max = 5119;
4492 clp_sum_max = 1023;
4493 clp_dir_to = (u16) (-5);
4494 sns_sum_max = 127;
4495 sns_dir_to = (u16) (-3);
4496 ki_innergain_min = 0;
4497 ki_max = 0x0657;
4498 if_iaccu_hi_tgt_min = 2047;
4499 agc_ki_dgain = 0x7;
4500 ki_min = 0x0117;
4501 clp_ctrl_mode = 0;
4502 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_KI_MINGAIN__A, 0x7fff, 0);
4503 if (rc != 0) {
4504 pr_err("error %d\n", rc);
4505 goto rw_error;
4506 }
4507 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_KI_MAXGAIN__A, 0x0, 0);
4508 if (rc != 0) {
4509 pr_err("error %d\n", rc);
4510 goto rw_error;
4511 }
4512 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_CLP_SUM__A, 0, 0);
4513 if (rc != 0) {
4514 pr_err("error %d\n", rc);
4515 goto rw_error;
4516 }
4517 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_CLP_CYCCNT__A, 0, 0);
4518 if (rc != 0) {
4519 pr_err("error %d\n", rc);
4520 goto rw_error;
4521 }
4522 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_CLP_DIR_WD__A, 0, 0);
4523 if (rc != 0) {
4524 pr_err("error %d\n", rc);
4525 goto rw_error;
4526 }
4527 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_CLP_DIR_STP__A, 1, 0);
4528 if (rc != 0) {
4529 pr_err("error %d\n", rc);
4530 goto rw_error;
4531 }
4532 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_SNS_SUM__A, 0, 0);
4533 if (rc != 0) {
4534 pr_err("error %d\n", rc);
4535 goto rw_error;
4536 }
4537 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_SNS_CYCCNT__A, 0, 0);
4538 if (rc != 0) {
4539 pr_err("error %d\n", rc);
4540 goto rw_error;
4541 }
4542 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_SNS_DIR_WD__A, 0, 0);
4543 if (rc != 0) {
4544 pr_err("error %d\n", rc);
4545 goto rw_error;
4546 }
4547 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_SNS_DIR_STP__A, 1, 0);
4548 if (rc != 0) {
4549 pr_err("error %d\n", rc);
4550 goto rw_error;
4551 }
4552 p_agc_if_settings = &(ext_attr->qam_if_agc_cfg);
4553 p_agc_rf_settings = &(ext_attr->qam_rf_agc_cfg);
4554 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_INGAIN_TGT__A, p_agc_if_settings->top, 0);
4555 if (rc != 0) {
4556 pr_err("error %d\n", rc);
4557 goto rw_error;
4558 }
4559
4560 rc = drxj_dap_read_reg16(dev_addr, SCU_RAM_AGC_KI__A, &agc_ki, 0);
4561 if (rc != 0) {
4562 pr_err("error %d\n", rc);
4563 goto rw_error;
4564 }
4565 agc_ki &= 0xf000;
4566 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_KI__A, agc_ki, 0);
4567 if (rc != 0) {
4568 pr_err("error %d\n", rc);
4569 goto rw_error;
4570 }
4571 break;
4572#endif
4573 default:
4574 return -EINVAL;
4575 }
4576
4577
4578 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_INGAIN_TGT_MIN__A, p_agc_if_settings->top, 0);
4579 if (rc != 0) {
4580 pr_err("error %d\n", rc);
4581 goto rw_error;
4582 }
4583 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_INGAIN__A, p_agc_if_settings->top, 0);
4584 if (rc != 0) {
4585 pr_err("error %d\n", rc);
4586 goto rw_error;
4587 }
4588 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_INGAIN_TGT_MAX__A, ingain_tgt_max, 0);
4589 if (rc != 0) {
4590 pr_err("error %d\n", rc);
4591 goto rw_error;
4592 }
4593 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_IF_IACCU_HI_TGT_MIN__A, if_iaccu_hi_tgt_min, 0);
4594 if (rc != 0) {
4595 pr_err("error %d\n", rc);
4596 goto rw_error;
4597 }
4598 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_IF_IACCU_HI__A, 0, 0);
4599 if (rc != 0) {
4600 pr_err("error %d\n", rc);
4601 goto rw_error;
4602 }
4603 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_IF_IACCU_LO__A, 0, 0);
4604 if (rc != 0) {
4605 pr_err("error %d\n", rc);
4606 goto rw_error;
4607 }
4608 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_RF_IACCU_HI__A, 0, 0);
4609 if (rc != 0) {
4610 pr_err("error %d\n", rc);
4611 goto rw_error;
4612 }
4613 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_RF_IACCU_LO__A, 0, 0);
4614 if (rc != 0) {
4615 pr_err("error %d\n", rc);
4616 goto rw_error;
4617 }
4618 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_RF_MAX__A, 32767, 0);
4619 if (rc != 0) {
4620 pr_err("error %d\n", rc);
4621 goto rw_error;
4622 }
4623 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_CLP_SUM_MAX__A, clp_sum_max, 0);
4624 if (rc != 0) {
4625 pr_err("error %d\n", rc);
4626 goto rw_error;
4627 }
4628 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_SNS_SUM_MAX__A, sns_sum_max, 0);
4629 if (rc != 0) {
4630 pr_err("error %d\n", rc);
4631 goto rw_error;
4632 }
4633 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_KI_INNERGAIN_MIN__A, ki_innergain_min, 0);
4634 if (rc != 0) {
4635 pr_err("error %d\n", rc);
4636 goto rw_error;
4637 }
4638 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_FAST_SNS_CTRL_DELAY__A, 50, 0);
4639 if (rc != 0) {
4640 pr_err("error %d\n", rc);
4641 goto rw_error;
4642 }
4643 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_KI_CYCLEN__A, 500, 0);
4644 if (rc != 0) {
4645 pr_err("error %d\n", rc);
4646 goto rw_error;
4647 }
4648 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_SNS_CYCLEN__A, 500, 0);
4649 if (rc != 0) {
4650 pr_err("error %d\n", rc);
4651 goto rw_error;
4652 }
4653 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_KI_MAXMINGAIN_TH__A, 20, 0);
4654 if (rc != 0) {
4655 pr_err("error %d\n", rc);
4656 goto rw_error;
4657 }
4658 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_KI_MIN__A, ki_min, 0);
4659 if (rc != 0) {
4660 pr_err("error %d\n", rc);
4661 goto rw_error;
4662 }
4663 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_KI_MAX__A, ki_max, 0);
4664 if (rc != 0) {
4665 pr_err("error %d\n", rc);
4666 goto rw_error;
4667 }
4668 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_KI_RED__A, 0, 0);
4669 if (rc != 0) {
4670 pr_err("error %d\n", rc);
4671 goto rw_error;
4672 }
4673 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_CLP_SUM_MIN__A, 8, 0);
4674 if (rc != 0) {
4675 pr_err("error %d\n", rc);
4676 goto rw_error;
4677 }
4678 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_CLP_CYCLEN__A, 500, 0);
4679 if (rc != 0) {
4680 pr_err("error %d\n", rc);
4681 goto rw_error;
4682 }
4683 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_CLP_DIR_TO__A, clp_dir_to, 0);
4684 if (rc != 0) {
4685 pr_err("error %d\n", rc);
4686 goto rw_error;
4687 }
4688 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_SNS_SUM_MIN__A, 8, 0);
4689 if (rc != 0) {
4690 pr_err("error %d\n", rc);
4691 goto rw_error;
4692 }
4693 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_SNS_DIR_TO__A, sns_dir_to, 0);
4694 if (rc != 0) {
4695 pr_err("error %d\n", rc);
4696 goto rw_error;
4697 }
4698 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_FAST_CLP_CTRL_DELAY__A, 50, 0);
4699 if (rc != 0) {
4700 pr_err("error %d\n", rc);
4701 goto rw_error;
4702 }
4703 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_CLP_CTRL_MODE__A, clp_ctrl_mode, 0);
4704 if (rc != 0) {
4705 pr_err("error %d\n", rc);
4706 goto rw_error;
4707 }
4708
4709 agc_rf = 0x800 + p_agc_rf_settings->cut_off_current;
4710 if (common_attr->tuner_rf_agc_pol == true)
4711 agc_rf = 0x87ff - agc_rf;
4712
4713 agc_if = 0x800;
4714 if (common_attr->tuner_if_agc_pol == true)
4715 agc_rf = 0x87ff - agc_rf;
4716
4717 rc = drxj_dap_write_reg16(dev_addr, IQM_AF_AGC_RF__A, agc_rf, 0);
4718 if (rc != 0) {
4719 pr_err("error %d\n", rc);
4720 goto rw_error;
4721 }
4722 rc = drxj_dap_write_reg16(dev_addr, IQM_AF_AGC_IF__A, agc_if, 0);
4723 if (rc != 0) {
4724 pr_err("error %d\n", rc);
4725 goto rw_error;
4726 }
4727
4728
4729 rc = drxj_dap_read_reg16(dev_addr, SCU_RAM_AGC_KI__A, &data, 0);
4730 if (rc != 0) {
4731 pr_err("error %d\n", rc);
4732 goto rw_error;
4733 }
4734 data &= ~SCU_RAM_AGC_KI_DGAIN__M;
4735 data |= (agc_ki_dgain << SCU_RAM_AGC_KI_DGAIN__B);
4736 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_AGC_KI__A, data, 0);
4737 if (rc != 0) {
4738 pr_err("error %d\n", rc);
4739 goto rw_error;
4740 }
4741
4742 return 0;
4743rw_error:
4744 return rc;
4745}
4746
4747
4748
4749
4750
4751
4752
4753
4754
4755static int
4756set_frequency(struct drx_demod_instance *demod,
4757 struct drx_channel *channel, s32 tuner_freq_offset)
4758{
4759 struct i2c_device_addr *dev_addr = demod->my_i2c_dev_addr;
4760 struct drxj_data *ext_attr = demod->my_ext_attr;
4761 int rc;
4762 s32 sampling_frequency = 0;
4763 s32 frequency_shift = 0;
4764 s32 if_freq_actual = 0;
4765 s32 rf_freq_residual = -1 * tuner_freq_offset;
4766 s32 adc_freq = 0;
4767 s32 intermediate_freq = 0;
4768 u32 iqm_fs_rate_ofs = 0;
4769 bool adc_flip = true;
4770 bool select_pos_image = false;
4771 bool rf_mirror;
4772 bool tuner_mirror;
4773 bool image_to_select = true;
4774 s32 fm_frequency_shift = 0;
4775
4776 rf_mirror = (ext_attr->mirror == DRX_MIRROR_YES) ? true : false;
4777 tuner_mirror = demod->my_common_attr->mirror_freq_spect ? false : true;
4778
4779
4780
4781
4782 switch (ext_attr->standard) {
4783 case DRX_STANDARD_ITU_A:
4784 case DRX_STANDARD_ITU_C:
4785 case DRX_STANDARD_PAL_SECAM_LP:
4786 case DRX_STANDARD_8VSB:
4787 select_pos_image = true;
4788 break;
4789 case DRX_STANDARD_FM:
4790
4791
4792
4793 fm_frequency_shift = 1000;
4794
4795 case DRX_STANDARD_ITU_B:
4796 case DRX_STANDARD_NTSC:
4797 case DRX_STANDARD_PAL_SECAM_BG:
4798 case DRX_STANDARD_PAL_SECAM_DK:
4799 case DRX_STANDARD_PAL_SECAM_I:
4800 case DRX_STANDARD_PAL_SECAM_L:
4801 select_pos_image = false;
4802 break;
4803 default:
4804 return -EINVAL;
4805 }
4806 intermediate_freq = demod->my_common_attr->intermediate_freq;
4807 sampling_frequency = demod->my_common_attr->sys_clock_freq / 3;
4808 if (tuner_mirror)
4809 if_freq_actual = intermediate_freq + rf_freq_residual + fm_frequency_shift;
4810 else
4811 if_freq_actual = intermediate_freq - rf_freq_residual - fm_frequency_shift;
4812 if (if_freq_actual > sampling_frequency / 2) {
4813
4814 adc_freq = sampling_frequency - if_freq_actual;
4815 adc_flip = true;
4816 } else {
4817
4818 adc_freq = if_freq_actual;
4819 adc_flip = false;
4820 }
4821
4822 frequency_shift = adc_freq;
4823 image_to_select =
4824 (bool) (rf_mirror ^ tuner_mirror ^ adc_flip ^ select_pos_image);
4825 iqm_fs_rate_ofs = frac28(frequency_shift, sampling_frequency);
4826
4827 if (image_to_select)
4828 iqm_fs_rate_ofs = ~iqm_fs_rate_ofs + 1;
4829
4830
4831
4832 rc = drxdap_fasi_write_reg32(dev_addr, IQM_FS_RATE_OFS_LO__A, iqm_fs_rate_ofs, 0);
4833 if (rc != 0) {
4834 pr_err("error %d\n", rc);
4835 goto rw_error;
4836 }
4837 ext_attr->iqm_fs_rate_ofs = iqm_fs_rate_ofs;
4838 ext_attr->pos_image = (bool) (rf_mirror ^ tuner_mirror ^ select_pos_image);
4839
4840 return 0;
4841rw_error:
4842 return rc;
4843}
4844
4845
4846
4847
4848
4849
4850
4851
4852
4853
4854
4855#ifdef DRXJ_SIGNAL_ACCUM_ERR
4856static int get_acc_pkt_err(struct drx_demod_instance *demod, u16 *packet_err)
4857{
4858 int rc;
4859 static u16 pkt_err;
4860 static u16 last_pkt_err;
4861 u16 data = 0;
4862 struct drxj_data *ext_attr = NULL;
4863 struct i2c_device_addr *dev_addr = NULL;
4864
4865 ext_attr = (struct drxj_data *) demod->my_ext_attr;
4866 dev_addr = demod->my_i2c_dev_addr;
4867
4868 rc = drxj_dap_read_reg16(dev_addr, SCU_RAM_FEC_ACCUM_PKT_FAILURES__A, &data, 0);
4869 if (rc != 0) {
4870 pr_err("error %d\n", rc);
4871 goto rw_error;
4872 }
4873 if (ext_attr->reset_pkt_err_acc) {
4874 last_pkt_err = data;
4875 pkt_err = 0;
4876 ext_attr->reset_pkt_err_acc = false;
4877 }
4878
4879 if (data < last_pkt_err) {
4880 pkt_err += 0xffff - last_pkt_err;
4881 pkt_err += data;
4882 } else {
4883 pkt_err += (data - last_pkt_err);
4884 }
4885 *packet_err = pkt_err;
4886 last_pkt_err = data;
4887
4888 return 0;
4889rw_error:
4890 return rc;
4891}
4892#endif
4893
4894
4895
4896
4897
4898
4899
4900
4901
4902
4903
4904static int
4905set_agc_rf(struct drx_demod_instance *demod, struct drxj_cfg_agc *agc_settings, bool atomic)
4906{
4907 struct i2c_device_addr *dev_addr = NULL;
4908 struct drxj_data *ext_attr = NULL;
4909 struct drxj_cfg_agc *p_agc_settings = NULL;
4910 struct drx_common_attr *common_attr = NULL;
4911 int rc;
4912 drx_write_reg16func_t scu_wr16 = NULL;
4913 drx_read_reg16func_t scu_rr16 = NULL;
4914
4915 common_attr = (struct drx_common_attr *) demod->my_common_attr;
4916 dev_addr = demod->my_i2c_dev_addr;
4917 ext_attr = (struct drxj_data *) demod->my_ext_attr;
4918
4919 if (atomic) {
4920 scu_rr16 = drxj_dap_scu_atomic_read_reg16;
4921 scu_wr16 = drxj_dap_scu_atomic_write_reg16;
4922 } else {
4923 scu_rr16 = drxj_dap_read_reg16;
4924 scu_wr16 = drxj_dap_write_reg16;
4925 }
4926
4927
4928 if ((ext_attr->standard == agc_settings->standard) ||
4929 (DRXJ_ISQAMSTD(ext_attr->standard) &&
4930 DRXJ_ISQAMSTD(agc_settings->standard)) ||
4931 (DRXJ_ISATVSTD(ext_attr->standard) &&
4932 DRXJ_ISATVSTD(agc_settings->standard))) {
4933 u16 data = 0;
4934
4935 switch (agc_settings->ctrl_mode) {
4936 case DRX_AGC_CTRL_AUTO:
4937
4938
4939 rc = drxj_dap_read_reg16(dev_addr, IQM_AF_STDBY__A, &data, 0);
4940 if (rc != 0) {
4941 pr_err("error %d\n", rc);
4942 goto rw_error;
4943 }
4944 data |= IQM_AF_STDBY_STDBY_TAGC_RF_A2_ACTIVE;
4945 rc = drxj_dap_write_reg16(dev_addr, IQM_AF_STDBY__A, data, 0);
4946 if (rc != 0) {
4947 pr_err("error %d\n", rc);
4948 goto rw_error;
4949 }
4950
4951
4952 rc = (*scu_rr16)(dev_addr, SCU_RAM_AGC_KI__A, &data, 0);
4953 if (rc != 0) {
4954 pr_err("error %d\n", rc);
4955 goto rw_error;
4956 }
4957 data &= ~SCU_RAM_AGC_KI_RF__M;
4958 if (ext_attr->standard == DRX_STANDARD_8VSB)
4959 data |= (2 << SCU_RAM_AGC_KI_RF__B);
4960 else if (DRXJ_ISQAMSTD(ext_attr->standard))
4961 data |= (5 << SCU_RAM_AGC_KI_RF__B);
4962 else
4963 data |= (4 << SCU_RAM_AGC_KI_RF__B);
4964
4965 if (common_attr->tuner_rf_agc_pol)
4966 data |= SCU_RAM_AGC_KI_INV_RF_POL__M;
4967 else
4968 data &= ~SCU_RAM_AGC_KI_INV_RF_POL__M;
4969 rc = (*scu_wr16)(dev_addr, SCU_RAM_AGC_KI__A, data, 0);
4970 if (rc != 0) {
4971 pr_err("error %d\n", rc);
4972 goto rw_error;
4973 }
4974
4975
4976 rc = (*scu_rr16)(dev_addr, SCU_RAM_AGC_KI_RED__A, &data, 0);
4977 if (rc != 0) {
4978 pr_err("error %d\n", rc);
4979 goto rw_error;
4980 }
4981 data &= ~SCU_RAM_AGC_KI_RED_RAGC_RED__M;
4982 rc = (*scu_wr16)(dev_addr, SCU_RAM_AGC_KI_RED__A, (~(agc_settings->speed << SCU_RAM_AGC_KI_RED_RAGC_RED__B) & SCU_RAM_AGC_KI_RED_RAGC_RED__M) | data, 0);
4983 if (rc != 0) {
4984 pr_err("error %d\n", rc);
4985 goto rw_error;
4986 }
4987
4988 if (agc_settings->standard == DRX_STANDARD_8VSB)
4989 p_agc_settings = &(ext_attr->vsb_if_agc_cfg);
4990 else if (DRXJ_ISQAMSTD(agc_settings->standard))
4991 p_agc_settings = &(ext_attr->qam_if_agc_cfg);
4992 else if (DRXJ_ISATVSTD(agc_settings->standard))
4993 p_agc_settings = &(ext_attr->atv_if_agc_cfg);
4994 else
4995 return -EINVAL;
4996
4997
4998 if (p_agc_settings->ctrl_mode == DRX_AGC_CTRL_AUTO) {
4999 rc = (*scu_wr16)(dev_addr, SCU_RAM_AGC_IF_IACCU_HI_TGT_MAX__A, agc_settings->top, 0);
5000 if (rc != 0) {
5001 pr_err("error %d\n", rc);
5002 goto rw_error;
5003 }
5004 rc = (*scu_wr16)(dev_addr, SCU_RAM_AGC_IF_IACCU_HI_TGT__A, agc_settings->top, 0);
5005 if (rc != 0) {
5006 pr_err("error %d\n", rc);
5007 goto rw_error;
5008 }
5009 }
5010
5011
5012 rc = (*scu_wr16)(dev_addr, SCU_RAM_AGC_RF_IACCU_HI_CO__A, agc_settings->cut_off_current, 0);
5013 if (rc != 0) {
5014 pr_err("error %d\n", rc);
5015 goto rw_error;
5016 }
5017 break;
5018 case DRX_AGC_CTRL_USER:
5019
5020
5021 rc = drxj_dap_read_reg16(dev_addr, IQM_AF_STDBY__A, &data, 0);
5022 if (rc != 0) {
5023 pr_err("error %d\n", rc);
5024 goto rw_error;
5025 }
5026 data |= IQM_AF_STDBY_STDBY_TAGC_RF_A2_ACTIVE;
5027 rc = drxj_dap_write_reg16(dev_addr, IQM_AF_STDBY__A, data, 0);
5028 if (rc != 0) {
5029 pr_err("error %d\n", rc);
5030 goto rw_error;
5031 }
5032
5033
5034 rc = (*scu_rr16)(dev_addr, SCU_RAM_AGC_KI__A, &data, 0);
5035 if (rc != 0) {
5036 pr_err("error %d\n", rc);
5037 goto rw_error;
5038 }
5039 data &= ~SCU_RAM_AGC_KI_RF__M;
5040 if (common_attr->tuner_rf_agc_pol)
5041 data |= SCU_RAM_AGC_KI_INV_RF_POL__M;
5042 else
5043 data &= ~SCU_RAM_AGC_KI_INV_RF_POL__M;
5044 rc = (*scu_wr16)(dev_addr, SCU_RAM_AGC_KI__A, data, 0);
5045 if (rc != 0) {
5046 pr_err("error %d\n", rc);
5047 goto rw_error;
5048 }
5049
5050
5051 rc = (*scu_wr16)(dev_addr, SCU_RAM_AGC_RF_IACCU_HI__A, agc_settings->output_level, 0);
5052 if (rc != 0) {
5053 pr_err("error %d\n", rc);
5054 goto rw_error;
5055 }
5056 break;
5057 case DRX_AGC_CTRL_OFF:
5058
5059
5060 rc = drxj_dap_read_reg16(dev_addr, IQM_AF_STDBY__A, &data, 0);
5061 if (rc != 0) {
5062 pr_err("error %d\n", rc);
5063 goto rw_error;
5064 }
5065 data &= (~IQM_AF_STDBY_STDBY_TAGC_RF_A2_ACTIVE);
5066 rc = drxj_dap_write_reg16(dev_addr, IQM_AF_STDBY__A, data, 0);
5067 if (rc != 0) {
5068 pr_err("error %d\n", rc);
5069 goto rw_error;
5070 }
5071
5072
5073 rc = (*scu_rr16)(dev_addr, SCU_RAM_AGC_KI__A, &data, 0);
5074 if (rc != 0) {
5075 pr_err("error %d\n", rc);
5076 goto rw_error;
5077 }
5078 data &= ~SCU_RAM_AGC_KI_RF__M;
5079 rc = (*scu_wr16)(dev_addr, SCU_RAM_AGC_KI__A, data, 0);
5080 if (rc != 0) {
5081 pr_err("error %d\n", rc);
5082 goto rw_error;
5083 }
5084 break;
5085 default:
5086 return -EINVAL;
5087 }
5088 }
5089
5090
5091 switch (agc_settings->standard) {
5092 case DRX_STANDARD_8VSB:
5093 ext_attr->vsb_rf_agc_cfg = *agc_settings;
5094 break;
5095#ifndef DRXJ_VSB_ONLY
5096 case DRX_STANDARD_ITU_A:
5097 case DRX_STANDARD_ITU_B:
5098 case DRX_STANDARD_ITU_C:
5099 ext_attr->qam_rf_agc_cfg = *agc_settings;
5100 break;
5101#endif
5102 default:
5103 return -EIO;
5104 }
5105
5106 return 0;
5107rw_error:
5108 return rc;
5109}
5110
5111
5112
5113
5114
5115
5116
5117
5118static int
5119set_agc_if(struct drx_demod_instance *demod, struct drxj_cfg_agc *agc_settings, bool atomic)
5120{
5121 struct i2c_device_addr *dev_addr = NULL;
5122 struct drxj_data *ext_attr = NULL;
5123 struct drxj_cfg_agc *p_agc_settings = NULL;
5124 struct drx_common_attr *common_attr = NULL;
5125 drx_write_reg16func_t scu_wr16 = NULL;
5126 drx_read_reg16func_t scu_rr16 = NULL;
5127 int rc;
5128
5129 common_attr = (struct drx_common_attr *) demod->my_common_attr;
5130 dev_addr = demod->my_i2c_dev_addr;
5131 ext_attr = (struct drxj_data *) demod->my_ext_attr;
5132
5133 if (atomic) {
5134 scu_rr16 = drxj_dap_scu_atomic_read_reg16;
5135 scu_wr16 = drxj_dap_scu_atomic_write_reg16;
5136 } else {
5137 scu_rr16 = drxj_dap_read_reg16;
5138 scu_wr16 = drxj_dap_write_reg16;
5139 }
5140
5141
5142 if ((ext_attr->standard == agc_settings->standard) ||
5143 (DRXJ_ISQAMSTD(ext_attr->standard) &&
5144 DRXJ_ISQAMSTD(agc_settings->standard)) ||
5145 (DRXJ_ISATVSTD(ext_attr->standard) &&
5146 DRXJ_ISATVSTD(agc_settings->standard))) {
5147 u16 data = 0;
5148
5149 switch (agc_settings->ctrl_mode) {
5150 case DRX_AGC_CTRL_AUTO:
5151
5152 rc = drxj_dap_read_reg16(dev_addr, IQM_AF_STDBY__A, &data, 0);
5153 if (rc != 0) {
5154 pr_err("error %d\n", rc);
5155 goto rw_error;
5156 }
5157 data |= IQM_AF_STDBY_STDBY_TAGC_IF_A2_ACTIVE;
5158 rc = drxj_dap_write_reg16(dev_addr, IQM_AF_STDBY__A, data, 0);
5159 if (rc != 0) {
5160 pr_err("error %d\n", rc);
5161 goto rw_error;
5162 }
5163
5164
5165 rc = (*scu_rr16)(dev_addr, SCU_RAM_AGC_KI__A, &data, 0);
5166 if (rc != 0) {
5167 pr_err("error %d\n", rc);
5168 goto rw_error;
5169 }
5170 data &= ~SCU_RAM_AGC_KI_IF_AGC_DISABLE__M;
5171 data &= ~SCU_RAM_AGC_KI_IF__M;
5172 if (ext_attr->standard == DRX_STANDARD_8VSB)
5173 data |= (3 << SCU_RAM_AGC_KI_IF__B);
5174 else if (DRXJ_ISQAMSTD(ext_attr->standard))
5175 data |= (6 << SCU_RAM_AGC_KI_IF__B);
5176 else
5177 data |= (5 << SCU_RAM_AGC_KI_IF__B);
5178
5179 if (common_attr->tuner_if_agc_pol)
5180 data |= SCU_RAM_AGC_KI_INV_IF_POL__M;
5181 else
5182 data &= ~SCU_RAM_AGC_KI_INV_IF_POL__M;
5183 rc = (*scu_wr16)(dev_addr, SCU_RAM_AGC_KI__A, data, 0);
5184 if (rc != 0) {
5185 pr_err("error %d\n", rc);
5186 goto rw_error;
5187 }
5188
5189
5190 rc = (*scu_rr16)(dev_addr, SCU_RAM_AGC_KI_RED__A, &data, 0);
5191 if (rc != 0) {
5192 pr_err("error %d\n", rc);
5193 goto rw_error;
5194 }
5195 data &= ~SCU_RAM_AGC_KI_RED_IAGC_RED__M;
5196 rc = (*scu_wr16) (dev_addr, SCU_RAM_AGC_KI_RED__A, (~(agc_settings->speed << SCU_RAM_AGC_KI_RED_IAGC_RED__B) & SCU_RAM_AGC_KI_RED_IAGC_RED__M) | data, 0);
5197 if (rc != 0) {
5198 pr_err("error %d\n", rc);
5199 goto rw_error;
5200 }
5201
5202 if (agc_settings->standard == DRX_STANDARD_8VSB)
5203 p_agc_settings = &(ext_attr->vsb_rf_agc_cfg);
5204 else if (DRXJ_ISQAMSTD(agc_settings->standard))
5205 p_agc_settings = &(ext_attr->qam_rf_agc_cfg);
5206 else if (DRXJ_ISATVSTD(agc_settings->standard))
5207 p_agc_settings = &(ext_attr->atv_rf_agc_cfg);
5208 else
5209 return -EINVAL;
5210
5211
5212 if (p_agc_settings->ctrl_mode == DRX_AGC_CTRL_AUTO) {
5213 rc = (*scu_wr16)(dev_addr, SCU_RAM_AGC_IF_IACCU_HI_TGT_MAX__A, p_agc_settings->top, 0);
5214 if (rc != 0) {
5215 pr_err("error %d\n", rc);
5216 goto rw_error;
5217 }
5218 rc = (*scu_wr16)(dev_addr, SCU_RAM_AGC_IF_IACCU_HI_TGT__A, p_agc_settings->top, 0);
5219 if (rc != 0) {
5220 pr_err("error %d\n", rc);
5221 goto rw_error;
5222 }
5223 } else {
5224 rc = (*scu_wr16)(dev_addr, SCU_RAM_AGC_IF_IACCU_HI_TGT_MAX__A, 0, 0);
5225 if (rc != 0) {
5226 pr_err("error %d\n", rc);
5227 goto rw_error;
5228 }
5229 rc = (*scu_wr16)(dev_addr, SCU_RAM_AGC_IF_IACCU_HI_TGT__A, 0, 0);
5230 if (rc != 0) {
5231 pr_err("error %d\n", rc);
5232 goto rw_error;
5233 }
5234 }
5235 break;
5236
5237 case DRX_AGC_CTRL_USER:
5238
5239
5240 rc = drxj_dap_read_reg16(dev_addr, IQM_AF_STDBY__A, &data, 0);
5241 if (rc != 0) {
5242 pr_err("error %d\n", rc);
5243 goto rw_error;
5244 }
5245 data |= IQM_AF_STDBY_STDBY_TAGC_IF_A2_ACTIVE;
5246 rc = drxj_dap_write_reg16(dev_addr, IQM_AF_STDBY__A, data, 0);
5247 if (rc != 0) {
5248 pr_err("error %d\n", rc);
5249 goto rw_error;
5250 }
5251
5252
5253 rc = (*scu_rr16)(dev_addr, SCU_RAM_AGC_KI__A, &data, 0);
5254 if (rc != 0) {
5255 pr_err("error %d\n", rc);
5256 goto rw_error;
5257 }
5258 data &= ~SCU_RAM_AGC_KI_IF_AGC_DISABLE__M;
5259 data |= SCU_RAM_AGC_KI_IF_AGC_DISABLE__M;
5260 if (common_attr->tuner_if_agc_pol)
5261 data |= SCU_RAM_AGC_KI_INV_IF_POL__M;
5262 else
5263 data &= ~SCU_RAM_AGC_KI_INV_IF_POL__M;
5264 rc = (*scu_wr16)(dev_addr, SCU_RAM_AGC_KI__A, data, 0);
5265 if (rc != 0) {
5266 pr_err("error %d\n", rc);
5267 goto rw_error;
5268 }
5269
5270
5271 rc = (*scu_wr16)(dev_addr, SCU_RAM_AGC_IF_IACCU_HI_TGT_MAX__A, agc_settings->output_level, 0);
5272 if (rc != 0) {
5273 pr_err("error %d\n", rc);
5274 goto rw_error;
5275 }
5276 break;
5277
5278 case DRX_AGC_CTRL_OFF:
5279
5280
5281 rc = drxj_dap_read_reg16(dev_addr, IQM_AF_STDBY__A, &data, 0);
5282 if (rc != 0) {
5283 pr_err("error %d\n", rc);
5284 goto rw_error;
5285 }
5286 data &= (~IQM_AF_STDBY_STDBY_TAGC_IF_A2_ACTIVE);
5287 rc = drxj_dap_write_reg16(dev_addr, IQM_AF_STDBY__A, data, 0);
5288 if (rc != 0) {
5289 pr_err("error %d\n", rc);
5290 goto rw_error;
5291 }
5292
5293
5294 rc = (*scu_rr16)(dev_addr, SCU_RAM_AGC_KI__A, &data, 0);
5295 if (rc != 0) {
5296 pr_err("error %d\n", rc);
5297 goto rw_error;
5298 }
5299 data &= ~SCU_RAM_AGC_KI_IF_AGC_DISABLE__M;
5300 data |= SCU_RAM_AGC_KI_IF_AGC_DISABLE__M;
5301 rc = (*scu_wr16)(dev_addr, SCU_RAM_AGC_KI__A, data, 0);
5302 if (rc != 0) {
5303 pr_err("error %d\n", rc);
5304 goto rw_error;
5305 }
5306 break;
5307 default:
5308 return -EINVAL;
5309 }
5310
5311
5312 rc = (*scu_wr16) (dev_addr, SCU_RAM_AGC_INGAIN_TGT_MIN__A, agc_settings->top, 0);
5313 if (rc != 0) {
5314 pr_err("error %d\n", rc);
5315 goto rw_error;
5316 }
5317 }
5318
5319
5320 switch (agc_settings->standard) {
5321 case DRX_STANDARD_8VSB:
5322 ext_attr->vsb_if_agc_cfg = *agc_settings;
5323 break;
5324#ifndef DRXJ_VSB_ONLY
5325 case DRX_STANDARD_ITU_A:
5326 case DRX_STANDARD_ITU_B:
5327 case DRX_STANDARD_ITU_C:
5328 ext_attr->qam_if_agc_cfg = *agc_settings;
5329 break;
5330#endif
5331 default:
5332 return -EIO;
5333 }
5334
5335 return 0;
5336rw_error:
5337 return rc;
5338}
5339
5340
5341
5342
5343
5344
5345
5346
5347static int set_iqm_af(struct drx_demod_instance *demod, bool active)
5348{
5349 u16 data = 0;
5350 struct i2c_device_addr *dev_addr = NULL;
5351 int rc;
5352
5353 dev_addr = demod->my_i2c_dev_addr;
5354
5355
5356 rc = drxj_dap_read_reg16(dev_addr, IQM_AF_STDBY__A, &data, 0);
5357 if (rc != 0) {
5358 pr_err("error %d\n", rc);
5359 goto rw_error;
5360 }
5361 if (!active)
5362 data &= ((~IQM_AF_STDBY_STDBY_ADC_A2_ACTIVE) & (~IQM_AF_STDBY_STDBY_AMP_A2_ACTIVE) & (~IQM_AF_STDBY_STDBY_PD_A2_ACTIVE) & (~IQM_AF_STDBY_STDBY_TAGC_IF_A2_ACTIVE) & (~IQM_AF_STDBY_STDBY_TAGC_RF_A2_ACTIVE));
5363 else
5364 data |= (IQM_AF_STDBY_STDBY_ADC_A2_ACTIVE | IQM_AF_STDBY_STDBY_AMP_A2_ACTIVE | IQM_AF_STDBY_STDBY_PD_A2_ACTIVE | IQM_AF_STDBY_STDBY_TAGC_IF_A2_ACTIVE | IQM_AF_STDBY_STDBY_TAGC_RF_A2_ACTIVE);
5365 rc = drxj_dap_write_reg16(dev_addr, IQM_AF_STDBY__A, data, 0);
5366 if (rc != 0) {
5367 pr_err("error %d\n", rc);
5368 goto rw_error;
5369 }
5370
5371 return 0;
5372rw_error:
5373 return rc;
5374}
5375
5376
5377
5378
5379
5380
5381
5382
5383
5384
5385
5386
5387
5388
5389
5390
5391
5392
5393static int power_down_vsb(struct drx_demod_instance *demod, bool primary)
5394{
5395 struct i2c_device_addr *dev_addr = demod->my_i2c_dev_addr;
5396 struct drxjscu_cmd cmd_scu = { 0,
5397 0,
5398 0,
5399 NULL,
5400 NULL
5401 };
5402 struct drx_cfg_mpeg_output cfg_mpeg_output;
5403 int rc;
5404 u16 cmd_result = 0;
5405
5406
5407
5408
5409
5410 cmd_scu.command = SCU_RAM_COMMAND_STANDARD_VSB |
5411 SCU_RAM_COMMAND_CMD_DEMOD_STOP;
5412 cmd_scu.parameter_len = 0;
5413 cmd_scu.result_len = 1;
5414 cmd_scu.parameter = NULL;
5415 cmd_scu.result = &cmd_result;
5416 rc = scu_command(dev_addr, &cmd_scu);
5417 if (rc != 0) {
5418 pr_err("error %d\n", rc);
5419 goto rw_error;
5420 }
5421
5422
5423 rc = drxj_dap_write_reg16(dev_addr, FEC_COMM_EXEC__A, FEC_COMM_EXEC_STOP, 0);
5424 if (rc != 0) {
5425 pr_err("error %d\n", rc);
5426 goto rw_error;
5427 }
5428 rc = drxj_dap_write_reg16(dev_addr, VSB_COMM_EXEC__A, VSB_COMM_EXEC_STOP, 0);
5429 if (rc != 0) {
5430 pr_err("error %d\n", rc);
5431 goto rw_error;
5432 }
5433 if (primary) {
5434 rc = drxj_dap_write_reg16(dev_addr, IQM_COMM_EXEC__A, IQM_COMM_EXEC_STOP, 0);
5435 if (rc != 0) {
5436 pr_err("error %d\n", rc);
5437 goto rw_error;
5438 }
5439 rc = set_iqm_af(demod, false);
5440 if (rc != 0) {
5441 pr_err("error %d\n", rc);
5442 goto rw_error;
5443 }
5444 } else {
5445 rc = drxj_dap_write_reg16(dev_addr, IQM_FS_COMM_EXEC__A, IQM_FS_COMM_EXEC_STOP, 0);
5446 if (rc != 0) {
5447 pr_err("error %d\n", rc);
5448 goto rw_error;
5449 }
5450 rc = drxj_dap_write_reg16(dev_addr, IQM_FD_COMM_EXEC__A, IQM_FD_COMM_EXEC_STOP, 0);
5451 if (rc != 0) {
5452 pr_err("error %d\n", rc);
5453 goto rw_error;
5454 }
5455 rc = drxj_dap_write_reg16(dev_addr, IQM_RC_COMM_EXEC__A, IQM_RC_COMM_EXEC_STOP, 0);
5456 if (rc != 0) {
5457 pr_err("error %d\n", rc);
5458 goto rw_error;
5459 }
5460 rc = drxj_dap_write_reg16(dev_addr, IQM_RT_COMM_EXEC__A, IQM_RT_COMM_EXEC_STOP, 0);
5461 if (rc != 0) {
5462 pr_err("error %d\n", rc);
5463 goto rw_error;
5464 }
5465 rc = drxj_dap_write_reg16(dev_addr, IQM_CF_COMM_EXEC__A, IQM_CF_COMM_EXEC_STOP, 0);
5466 if (rc != 0) {
5467 pr_err("error %d\n", rc);
5468 goto rw_error;
5469 }
5470 }
5471
5472 cfg_mpeg_output.enable_mpeg_output = false;
5473 rc = ctrl_set_cfg_mpeg_output(demod, &cfg_mpeg_output);
5474 if (rc != 0) {
5475 pr_err("error %d\n", rc);
5476 goto rw_error;
5477 }
5478
5479 return 0;
5480rw_error:
5481 return rc;
5482}
5483
5484
5485
5486
5487
5488
5489
5490static int set_vsb_leak_n_gain(struct drx_demod_instance *demod)
5491{
5492 struct i2c_device_addr *dev_addr = NULL;
5493 int rc;
5494
5495 static const u8 vsb_ffe_leak_gain_ram0[] = {
5496 DRXJ_16TO8(0x8),
5497 DRXJ_16TO8(0x8),
5498 DRXJ_16TO8(0x8),
5499 DRXJ_16TO8(0xf),
5500 DRXJ_16TO8(0xf),
5501 DRXJ_16TO8(0xf),
5502 DRXJ_16TO8(0xf),
5503 DRXJ_16TO8(0xf),
5504 DRXJ_16TO8(0xf),
5505 DRXJ_16TO8(0x8),
5506 DRXJ_16TO8(0x8),
5507 DRXJ_16TO8(0x8),
5508 DRXJ_16TO8(0x10),
5509 DRXJ_16TO8(0x10),
5510 DRXJ_16TO8(0x10),
5511 DRXJ_16TO8(0x20),
5512 DRXJ_16TO8(0x20),
5513 DRXJ_16TO8(0x20),
5514 DRXJ_16TO8(0x20),
5515 DRXJ_16TO8(0x20),
5516 DRXJ_16TO8(0x20),
5517 DRXJ_16TO8(0x10),
5518 DRXJ_16TO8(0x10),
5519 DRXJ_16TO8(0x10),
5520 DRXJ_16TO8(0x10),
5521 DRXJ_16TO8(0x10),
5522 DRXJ_16TO8(0x10),
5523 DRXJ_16TO8(0x20),
5524 DRXJ_16TO8(0x20),
5525 DRXJ_16TO8(0x20),
5526 DRXJ_16TO8(0x20),
5527 DRXJ_16TO8(0x20),
5528 DRXJ_16TO8(0x20),
5529 DRXJ_16TO8(0x10),
5530 DRXJ_16TO8(0x10),
5531 DRXJ_16TO8(0x10),
5532 DRXJ_16TO8(0x10),
5533 DRXJ_16TO8(0x10),
5534 DRXJ_16TO8(0x10),
5535 DRXJ_16TO8(0x20),
5536 DRXJ_16TO8(0x20),
5537 DRXJ_16TO8(0x20),
5538 DRXJ_16TO8(0x20),
5539 DRXJ_16TO8(0x20),
5540 DRXJ_16TO8(0x20),
5541 DRXJ_16TO8(0x10),
5542 DRXJ_16TO8(0x10),
5543 DRXJ_16TO8(0x10),
5544 DRXJ_16TO8(0x10),
5545 DRXJ_16TO8(0x10),
5546 DRXJ_16TO8(0x10),
5547 DRXJ_16TO8(0x20),
5548 DRXJ_16TO8(0x20),
5549 DRXJ_16TO8(0x20),
5550 DRXJ_16TO8(0x20),
5551 DRXJ_16TO8(0x20),
5552 DRXJ_16TO8(0x20),
5553 DRXJ_16TO8(0x10),
5554 DRXJ_16TO8(0x10),
5555 DRXJ_16TO8(0x10),
5556 DRXJ_16TO8(0x07),
5557 DRXJ_16TO8(0x07),
5558 DRXJ_16TO8(0x07),
5559 DRXJ_16TO8(0x0e),
5560 DRXJ_16TO8(0x0e),
5561 DRXJ_16TO8(0x0e),
5562 DRXJ_16TO8(0x0e),
5563 DRXJ_16TO8(0x0e),
5564 DRXJ_16TO8(0x0e),
5565 DRXJ_16TO8(0x07),
5566 DRXJ_16TO8(0x07),
5567 DRXJ_16TO8(0x07),
5568 DRXJ_16TO8(0x07),
5569 DRXJ_16TO8(0x07),
5570 DRXJ_16TO8(0x07),
5571 DRXJ_16TO8(0x0e),
5572 DRXJ_16TO8(0x0e),
5573 DRXJ_16TO8(0x0e),
5574 DRXJ_16TO8(0x0e),
5575 DRXJ_16TO8(0x0e),
5576 DRXJ_16TO8(0x0e),
5577 DRXJ_16TO8(0x07),
5578 DRXJ_16TO8(0x07),
5579 DRXJ_16TO8(0x07),
5580 DRXJ_16TO8(0x06),
5581 DRXJ_16TO8(0x06),
5582 DRXJ_16TO8(0x06),
5583 DRXJ_16TO8(0x0c),
5584 DRXJ_16TO8(0x0c),
5585 DRXJ_16TO8(0x0c),
5586 DRXJ_16TO8(0x0c),
5587 DRXJ_16TO8(0x0c),
5588 DRXJ_16TO8(0x0c),
5589 DRXJ_16TO8(0x06),
5590 DRXJ_16TO8(0x06),
5591 DRXJ_16TO8(0x06),
5592 DRXJ_16TO8(0x06),
5593 DRXJ_16TO8(0x06),
5594 DRXJ_16TO8(0x06),
5595 DRXJ_16TO8(0x0c),
5596 DRXJ_16TO8(0x0c),
5597 DRXJ_16TO8(0x0c),
5598 DRXJ_16TO8(0x0c),
5599 DRXJ_16TO8(0x0c),
5600 DRXJ_16TO8(0x0c),
5601 DRXJ_16TO8(0x06),
5602 DRXJ_16TO8(0x06),
5603 DRXJ_16TO8(0x06),
5604 DRXJ_16TO8(0x2020),
5605 DRXJ_16TO8(0x2020),
5606 DRXJ_16TO8(0x2020),
5607 DRXJ_16TO8(0x4040),
5608 DRXJ_16TO8(0x4040),
5609 DRXJ_16TO8(0x4040),
5610 DRXJ_16TO8(0x4040),
5611 DRXJ_16TO8(0x4040),
5612 DRXJ_16TO8(0x4040),
5613 DRXJ_16TO8(0x2020),
5614 DRXJ_16TO8(0x2020),
5615 DRXJ_16TO8(0x2020),
5616 DRXJ_16TO8(0x0808),
5617 DRXJ_16TO8(0x0808),
5618 DRXJ_16TO8(0x0808),
5619 DRXJ_16TO8(0x1010),
5620 DRXJ_16TO8(0x1010),
5621 DRXJ_16TO8(0x1010),
5622 DRXJ_16TO8(0x1010),
5623 DRXJ_16TO8(0x1010)
5624 };
5625
5626 static const u8 vsb_ffe_leak_gain_ram1[] = {
5627 DRXJ_16TO8(0x1010),
5628 DRXJ_16TO8(0x0808),
5629 DRXJ_16TO8(0x0808),
5630 DRXJ_16TO8(0x0808),
5631 DRXJ_16TO8(0x0808),
5632 DRXJ_16TO8(0x0808),
5633 DRXJ_16TO8(0x0808),
5634 DRXJ_16TO8(0x1010),
5635 DRXJ_16TO8(0x1010),
5636 DRXJ_16TO8(0x1010),
5637 DRXJ_16TO8(0x1010),
5638 DRXJ_16TO8(0x1010),
5639 DRXJ_16TO8(0x1010),
5640 DRXJ_16TO8(0x0808),
5641 DRXJ_16TO8(0x0808),
5642 DRXJ_16TO8(0x0808),
5643 DRXJ_16TO8(0x0303),
5644 DRXJ_16TO8(0x0303),
5645 DRXJ_16TO8(0x0303),
5646 DRXJ_16TO8(0x0606),
5647 DRXJ_16TO8(0x0606),
5648 DRXJ_16TO8(0x0606),
5649 DRXJ_16TO8(0x0606),
5650 DRXJ_16TO8(0x0606),
5651 DRXJ_16TO8(0x0606),
5652 DRXJ_16TO8(0x0303),
5653 DRXJ_16TO8(0x0303),
5654 DRXJ_16TO8(0x0303),
5655 DRXJ_16TO8(0x0303),
5656 DRXJ_16TO8(0x0303),
5657 DRXJ_16TO8(0x0303),
5658 DRXJ_16TO8(0x0505),
5659 DRXJ_16TO8(0x0505),
5660 DRXJ_16TO8(0x0505),
5661 DRXJ_16TO8(0x0505),
5662 DRXJ_16TO8(0x0505),
5663 DRXJ_16TO8(0x0505),
5664 DRXJ_16TO8(0x0303),
5665 DRXJ_16TO8(0x0303),
5666 DRXJ_16TO8(0x0303),
5667 DRXJ_16TO8(0x001f),
5668 DRXJ_16TO8(0x01ff),
5669 DRXJ_16TO8(0x01ff),
5670 DRXJ_16TO8(0x004f),
5671 DRXJ_16TO8(0x004f),
5672 DRXJ_16TO8(0x01ff),
5673 DRXJ_16TO8(0x01ff),
5674 DRXJ_16TO8(0x0352),
5675 DRXJ_16TO8(0x0352),
5676 DRXJ_16TO8(0x0000),
5677 DRXJ_16TO8(0x2020),
5678 DRXJ_16TO8(0x1010),
5679 DRXJ_16TO8(0x1818),
5680 DRXJ_16TO8(0x1212)
5681 };
5682
5683 dev_addr = demod->my_i2c_dev_addr;
5684 rc = drxdap_fasi_write_block(dev_addr, VSB_SYSCTRL_RAM0_FFETRAINLKRATIO1__A, sizeof(vsb_ffe_leak_gain_ram0), ((u8 *)vsb_ffe_leak_gain_ram0), 0);
5685 if (rc != 0) {
5686 pr_err("error %d\n", rc);
5687 goto rw_error;
5688 }
5689 rc = drxdap_fasi_write_block(dev_addr, VSB_SYSCTRL_RAM1_FIRRCA1GAIN9__A, sizeof(vsb_ffe_leak_gain_ram1), ((u8 *)vsb_ffe_leak_gain_ram1), 0);
5690 if (rc != 0) {
5691 pr_err("error %d\n", rc);
5692 goto rw_error;
5693 }
5694
5695 return 0;
5696rw_error:
5697 return rc;
5698}
5699
5700
5701
5702
5703
5704
5705
5706
5707static int set_vsb(struct drx_demod_instance *demod)
5708{
5709 struct i2c_device_addr *dev_addr = NULL;
5710 int rc;
5711 struct drx_common_attr *common_attr = NULL;
5712 struct drxjscu_cmd cmd_scu;
5713 struct drxj_data *ext_attr = NULL;
5714 u16 cmd_result = 0;
5715 u16 cmd_param = 0;
5716 static const u8 vsb_taps_re[] = {
5717 DRXJ_16TO8(-2),
5718 DRXJ_16TO8(4),
5719 DRXJ_16TO8(1),
5720 DRXJ_16TO8(-4),
5721 DRXJ_16TO8(1),
5722 DRXJ_16TO8(4),
5723 DRXJ_16TO8(-3),
5724 DRXJ_16TO8(-3),
5725 DRXJ_16TO8(6),
5726 DRXJ_16TO8(1),
5727 DRXJ_16TO8(-9),
5728 DRXJ_16TO8(3),
5729 DRXJ_16TO8(12),
5730 DRXJ_16TO8(-9),
5731 DRXJ_16TO8(-15),
5732 DRXJ_16TO8(17),
5733 DRXJ_16TO8(19),
5734 DRXJ_16TO8(-29),
5735 DRXJ_16TO8(-22),
5736 DRXJ_16TO8(45),
5737 DRXJ_16TO8(25),
5738 DRXJ_16TO8(-70),
5739 DRXJ_16TO8(-28),
5740 DRXJ_16TO8(111),
5741 DRXJ_16TO8(30),
5742 DRXJ_16TO8(-201),
5743 DRXJ_16TO8(-31),
5744 DRXJ_16TO8(629)
5745 };
5746
5747 dev_addr = demod->my_i2c_dev_addr;
5748 common_attr = (struct drx_common_attr *) demod->my_common_attr;
5749 ext_attr = (struct drxj_data *) demod->my_ext_attr;
5750
5751
5752 rc = drxj_dap_write_reg16(dev_addr, FEC_COMM_EXEC__A, FEC_COMM_EXEC_STOP, 0);
5753 if (rc != 0) {
5754 pr_err("error %d\n", rc);
5755 goto rw_error;
5756 }
5757 rc = drxj_dap_write_reg16(dev_addr, VSB_COMM_EXEC__A, VSB_COMM_EXEC_STOP, 0);
5758 if (rc != 0) {
5759 pr_err("error %d\n", rc);
5760 goto rw_error;
5761 }
5762 rc = drxj_dap_write_reg16(dev_addr, IQM_FS_COMM_EXEC__A, IQM_FS_COMM_EXEC_STOP, 0);
5763 if (rc != 0) {
5764 pr_err("error %d\n", rc);
5765 goto rw_error;
5766 }
5767 rc = drxj_dap_write_reg16(dev_addr, IQM_FD_COMM_EXEC__A, IQM_FD_COMM_EXEC_STOP, 0);
5768 if (rc != 0) {
5769 pr_err("error %d\n", rc);
5770 goto rw_error;
5771 }
5772 rc = drxj_dap_write_reg16(dev_addr, IQM_RC_COMM_EXEC__A, IQM_RC_COMM_EXEC_STOP, 0);
5773 if (rc != 0) {
5774 pr_err("error %d\n", rc);
5775 goto rw_error;
5776 }
5777 rc = drxj_dap_write_reg16(dev_addr, IQM_RT_COMM_EXEC__A, IQM_RT_COMM_EXEC_STOP, 0);
5778 if (rc != 0) {
5779 pr_err("error %d\n", rc);
5780 goto rw_error;
5781 }
5782 rc = drxj_dap_write_reg16(dev_addr, IQM_CF_COMM_EXEC__A, IQM_CF_COMM_EXEC_STOP, 0);
5783 if (rc != 0) {
5784 pr_err("error %d\n", rc);
5785 goto rw_error;
5786 }
5787
5788
5789 cmd_scu.command = SCU_RAM_COMMAND_STANDARD_VSB
5790 | SCU_RAM_COMMAND_CMD_DEMOD_RESET;
5791 cmd_scu.parameter_len = 0;
5792 cmd_scu.result_len = 1;
5793 cmd_scu.parameter = NULL;
5794 cmd_scu.result = &cmd_result;
5795 rc = scu_command(dev_addr, &cmd_scu);
5796 if (rc != 0) {
5797 pr_err("error %d\n", rc);
5798 goto rw_error;
5799 }
5800
5801 rc = drxj_dap_write_reg16(dev_addr, IQM_AF_DCF_BYPASS__A, 1, 0);
5802 if (rc != 0) {
5803 pr_err("error %d\n", rc);
5804 goto rw_error;
5805 }
5806 rc = drxj_dap_write_reg16(dev_addr, IQM_FS_ADJ_SEL__A, IQM_FS_ADJ_SEL_B_VSB, 0);
5807 if (rc != 0) {
5808 pr_err("error %d\n", rc);
5809 goto rw_error;
5810 }
5811 rc = drxj_dap_write_reg16(dev_addr, IQM_RC_ADJ_SEL__A, IQM_RC_ADJ_SEL_B_VSB, 0);
5812 if (rc != 0) {
5813 pr_err("error %d\n", rc);
5814 goto rw_error;
5815 }
5816 ext_attr->iqm_rc_rate_ofs = 0x00AD0D79;
5817 rc = drxdap_fasi_write_reg32(dev_addr, IQM_RC_RATE_OFS_LO__A, ext_attr->iqm_rc_rate_ofs, 0);
5818 if (rc != 0) {
5819 pr_err("error %d\n", rc);
5820 goto rw_error;
5821 }
5822 rc = drxj_dap_write_reg16(dev_addr, VSB_TOP_CFAGC_GAINSHIFT__A, 4, 0);
5823 if (rc != 0) {
5824 pr_err("error %d\n", rc);
5825 goto rw_error;
5826 }
5827 rc = drxj_dap_write_reg16(dev_addr, VSB_TOP_CYGN1TRK__A, 1, 0);
5828 if (rc != 0) {
5829 pr_err("error %d\n", rc);
5830 goto rw_error;
5831 }
5832
5833 rc = drxj_dap_write_reg16(dev_addr, IQM_RC_CROUT_ENA__A, 1, 0);
5834 if (rc != 0) {
5835 pr_err("error %d\n", rc);
5836 goto rw_error;
5837 }
5838 rc = drxj_dap_write_reg16(dev_addr, IQM_RC_STRETCH__A, 28, 0);
5839 if (rc != 0) {
5840 pr_err("error %d\n", rc);
5841 goto rw_error;
5842 }
5843 rc = drxj_dap_write_reg16(dev_addr, IQM_RT_ACTIVE__A, 0, 0);
5844 if (rc != 0) {
5845 pr_err("error %d\n", rc);
5846 goto rw_error;
5847 }
5848 rc = drxj_dap_write_reg16(dev_addr, IQM_CF_SYMMETRIC__A, 0, 0);
5849 if (rc != 0) {
5850 pr_err("error %d\n", rc);
5851 goto rw_error;
5852 }
5853 rc = drxj_dap_write_reg16(dev_addr, IQM_CF_MIDTAP__A, 3, 0);
5854 if (rc != 0) {
5855 pr_err("error %d\n", rc);
5856 goto rw_error;
5857 }
5858 rc = drxj_dap_write_reg16(dev_addr, IQM_CF_OUT_ENA__A, IQM_CF_OUT_ENA_VSB__M, 0);
5859 if (rc != 0) {
5860 pr_err("error %d\n", rc);
5861 goto rw_error;
5862 }
5863 rc = drxj_dap_write_reg16(dev_addr, IQM_CF_SCALE__A, 1393, 0);
5864 if (rc != 0) {
5865 pr_err("error %d\n", rc);
5866 goto rw_error;
5867 }
5868 rc = drxj_dap_write_reg16(dev_addr, IQM_CF_SCALE_SH__A, 0, 0);
5869 if (rc != 0) {
5870 pr_err("error %d\n", rc);
5871 goto rw_error;
5872 }
5873 rc = drxj_dap_write_reg16(dev_addr, IQM_CF_POW_MEAS_LEN__A, 1, 0);
5874 if (rc != 0) {
5875 pr_err("error %d\n", rc);
5876 goto rw_error;
5877 }
5878
5879 rc = drxdap_fasi_write_block(dev_addr, IQM_CF_TAP_RE0__A, sizeof(vsb_taps_re), ((u8 *)vsb_taps_re), 0);
5880 if (rc != 0) {
5881 pr_err("error %d\n", rc);
5882 goto rw_error;
5883 }
5884 rc = drxdap_fasi_write_block(dev_addr, IQM_CF_TAP_IM0__A, sizeof(vsb_taps_re), ((u8 *)vsb_taps_re), 0);
5885 if (rc != 0) {
5886 pr_err("error %d\n", rc);
5887 goto rw_error;
5888 }
5889
5890 rc = drxj_dap_write_reg16(dev_addr, VSB_TOP_BNTHRESH__A, 330, 0);
5891 if (rc != 0) {
5892 pr_err("error %d\n", rc);
5893 goto rw_error;
5894 }
5895 rc = drxj_dap_write_reg16(dev_addr, VSB_TOP_CLPLASTNUM__A, 90, 0);
5896 if (rc != 0) {
5897 pr_err("error %d\n", rc);
5898 goto rw_error;
5899 }
5900 rc = drxj_dap_write_reg16(dev_addr, VSB_TOP_SNRTH_RCA1__A, 0x0042, 0);
5901 if (rc != 0) {
5902 pr_err("error %d\n", rc);
5903 goto rw_error;
5904 }
5905 rc = drxj_dap_write_reg16(dev_addr, VSB_TOP_SNRTH_RCA2__A, 0x0053, 0);
5906 if (rc != 0) {
5907 pr_err("error %d\n", rc);
5908 goto rw_error;
5909 }
5910 rc = drxj_dap_write_reg16(dev_addr, VSB_TOP_EQCTRL__A, 0x1, 0);
5911 if (rc != 0) {
5912 pr_err("error %d\n", rc);
5913 goto rw_error;
5914 }
5915 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_GPIO__A, 0, 0);
5916 if (rc != 0) {
5917 pr_err("error %d\n", rc);
5918 goto rw_error;
5919 }
5920
5921
5922 rc = drxj_dap_write_reg16(dev_addr, FEC_TOP_ANNEX__A, FEC_TOP_ANNEX_D, 0);
5923 if (rc != 0) {
5924 pr_err("error %d\n", rc);
5925 goto rw_error;
5926 }
5927 {
5928 u16 fec_oc_snc_mode = 0;
5929 rc = drxj_dap_read_reg16(dev_addr, FEC_OC_SNC_MODE__A, &fec_oc_snc_mode, 0);
5930 if (rc != 0) {
5931 pr_err("error %d\n", rc);
5932 goto rw_error;
5933 }
5934
5935 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_SNC_MODE__A, fec_oc_snc_mode | FEC_OC_SNC_MODE_UNLOCK_ENABLE__M, 0);
5936 if (rc != 0) {
5937 pr_err("error %d\n", rc);
5938 goto rw_error;
5939 }
5940 }
5941
5942
5943 rc = drxj_dap_write_reg16(dev_addr, IQM_AF_CLP_LEN__A, 0, 0);
5944 if (rc != 0) {
5945 pr_err("error %d\n", rc);
5946 goto rw_error;
5947 }
5948 rc = drxj_dap_write_reg16(dev_addr, IQM_AF_CLP_TH__A, 470, 0);
5949 if (rc != 0) {
5950 pr_err("error %d\n", rc);
5951 goto rw_error;
5952 }
5953 rc = drxj_dap_write_reg16(dev_addr, IQM_AF_SNS_LEN__A, 0, 0);
5954 if (rc != 0) {
5955 pr_err("error %d\n", rc);
5956 goto rw_error;
5957 }
5958 rc = drxj_dap_write_reg16(dev_addr, VSB_TOP_SNRTH_PT__A, 0xD4, 0);
5959 if (rc != 0) {
5960 pr_err("error %d\n", rc);
5961 goto rw_error;
5962 }
5963
5964 {
5965 u16 fec_oc_reg_mode = 0;
5966 rc = drxj_dap_read_reg16(dev_addr, FEC_OC_MODE__A, &fec_oc_reg_mode, 0);
5967 if (rc != 0) {
5968 pr_err("error %d\n", rc);
5969 goto rw_error;
5970 }
5971 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_MODE__A, fec_oc_reg_mode & (~(FEC_OC_MODE_TRANSPARENT__M | FEC_OC_MODE_CLEAR__M | FEC_OC_MODE_RETAIN_FRAMING__M)), 0);
5972 if (rc != 0) {
5973 pr_err("error %d\n", rc);
5974 goto rw_error;
5975 }
5976 }
5977
5978 rc = drxj_dap_write_reg16(dev_addr, FEC_DI_TIMEOUT_LO__A, 0, 0);
5979 if (rc != 0) {
5980 pr_err("error %d\n", rc);
5981 goto rw_error;
5982 }
5983 rc = drxj_dap_write_reg16(dev_addr, FEC_DI_TIMEOUT_HI__A, 3, 0);
5984 if (rc != 0) {
5985 pr_err("error %d\n", rc);
5986 goto rw_error;
5987 }
5988 rc = drxj_dap_write_reg16(dev_addr, FEC_RS_MODE__A, 0, 0);
5989 if (rc != 0) {
5990 pr_err("error %d\n", rc);
5991 goto rw_error;
5992 }
5993
5994 rc = drxj_dap_write_reg16(dev_addr, FEC_RS_MEASUREMENT_PERIOD__A, FEC_RS_MEASUREMENT_PERIOD, 0);
5995 if (rc != 0) {
5996 pr_err("error %d\n", rc);
5997 goto rw_error;
5998 }
5999 rc = drxj_dap_write_reg16(dev_addr, FEC_RS_MEASUREMENT_PRESCALE__A, FEC_RS_MEASUREMENT_PRESCALE, 0);
6000 if (rc != 0) {
6001 pr_err("error %d\n", rc);
6002 goto rw_error;
6003 }
6004
6005
6006 rc = drxj_dap_write_reg16(dev_addr, VSB_TOP_MEASUREMENT_PERIOD__A, VSB_TOP_MEASUREMENT_PERIOD, 0);
6007 if (rc != 0) {
6008 pr_err("error %d\n", rc);
6009 goto rw_error;
6010 }
6011 rc = drxdap_fasi_write_reg32(dev_addr, SCU_RAM_FEC_ACCUM_CW_CORRECTED_LO__A, 0, 0);
6012 if (rc != 0) {
6013 pr_err("error %d\n", rc);
6014 goto rw_error;
6015 }
6016 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_FEC_MEAS_COUNT__A, 0, 0);
6017 if (rc != 0) {
6018 pr_err("error %d\n", rc);
6019 goto rw_error;
6020 }
6021 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_FEC_ACCUM_PKT_FAILURES__A, 0, 0);
6022 if (rc != 0) {
6023 pr_err("error %d\n", rc);
6024 goto rw_error;
6025 }
6026
6027 rc = drxj_dap_write_reg16(dev_addr, VSB_TOP_CKGN1TRK__A, 128, 0);
6028 if (rc != 0) {
6029 pr_err("error %d\n", rc);
6030 goto rw_error;
6031 }
6032
6033 if (!ext_attr->has_lna) {
6034 rc = drxj_dap_write_reg16(dev_addr, IQM_AF_AMUX__A, 0x02, 0);
6035 if (rc != 0) {
6036 pr_err("error %d\n", rc);
6037 goto rw_error;
6038 }
6039 }
6040
6041
6042 rc = set_iqm_af(demod, true);
6043 if (rc != 0) {
6044 pr_err("error %d\n", rc);
6045 goto rw_error;
6046 }
6047 rc = adc_synchronization(demod);
6048 if (rc != 0) {
6049 pr_err("error %d\n", rc);
6050 goto rw_error;
6051 }
6052
6053 rc = init_agc(demod);
6054 if (rc != 0) {
6055 pr_err("error %d\n", rc);
6056 goto rw_error;
6057 }
6058 rc = set_agc_if(demod, &(ext_attr->vsb_if_agc_cfg), false);
6059 if (rc != 0) {
6060 pr_err("error %d\n", rc);
6061 goto rw_error;
6062 }
6063 rc = set_agc_rf(demod, &(ext_attr->vsb_rf_agc_cfg), false);
6064 if (rc != 0) {
6065 pr_err("error %d\n", rc);
6066 goto rw_error;
6067 }
6068 {
6069
6070
6071 struct drxj_cfg_afe_gain vsb_pga_cfg = { DRX_STANDARD_8VSB, 0 };
6072
6073 vsb_pga_cfg.gain = ext_attr->vsb_pga_cfg;
6074 rc = ctrl_set_cfg_afe_gain(demod, &vsb_pga_cfg);
6075 if (rc != 0) {
6076 pr_err("error %d\n", rc);
6077 goto rw_error;
6078 }
6079 }
6080 rc = ctrl_set_cfg_pre_saw(demod, &(ext_attr->vsb_pre_saw_cfg));
6081 if (rc != 0) {
6082 pr_err("error %d\n", rc);
6083 goto rw_error;
6084 }
6085
6086
6087 rc = set_mpegtei_handling(demod);
6088 if (rc != 0) {
6089 pr_err("error %d\n", rc);
6090 goto rw_error;
6091 }
6092 rc = bit_reverse_mpeg_output(demod);
6093 if (rc != 0) {
6094 pr_err("error %d\n", rc);
6095 goto rw_error;
6096 }
6097 rc = set_mpeg_start_width(demod);
6098 if (rc != 0) {
6099 pr_err("error %d\n", rc);
6100 goto rw_error;
6101 }
6102 {
6103
6104
6105 struct drx_cfg_mpeg_output cfg_mpeg_output;
6106
6107 memcpy(&cfg_mpeg_output, &common_attr->mpeg_cfg, sizeof(cfg_mpeg_output));
6108 cfg_mpeg_output.enable_mpeg_output = true;
6109
6110 rc = ctrl_set_cfg_mpeg_output(demod, &cfg_mpeg_output);
6111 if (rc != 0) {
6112 pr_err("error %d\n", rc);
6113 goto rw_error;
6114 }
6115 }
6116
6117
6118 cmd_param = 0x00;
6119 cmd_scu.command = SCU_RAM_COMMAND_STANDARD_VSB
6120 | SCU_RAM_COMMAND_CMD_DEMOD_SET_PARAM;
6121 cmd_scu.parameter_len = 1;
6122 cmd_scu.result_len = 1;
6123 cmd_scu.parameter = &cmd_param;
6124 cmd_scu.result = &cmd_result;
6125 rc = scu_command(dev_addr, &cmd_scu);
6126 if (rc != 0) {
6127 pr_err("error %d\n", rc);
6128 goto rw_error;
6129 }
6130
6131 rc = drxj_dap_write_reg16(dev_addr, VSB_TOP_BEAGC_GAINSHIFT__A, 0x0004, 0);
6132 if (rc != 0) {
6133 pr_err("error %d\n", rc);
6134 goto rw_error;
6135 }
6136 rc = drxj_dap_write_reg16(dev_addr, VSB_TOP_SNRTH_PT__A, 0x00D2, 0);
6137 if (rc != 0) {
6138 pr_err("error %d\n", rc);
6139 goto rw_error;
6140 }
6141 rc = drxj_dap_write_reg16(dev_addr, VSB_TOP_SYSSMTRNCTRL__A, VSB_TOP_SYSSMTRNCTRL__PRE | VSB_TOP_SYSSMTRNCTRL_NCOTIMEOUTCNTEN__M, 0);
6142 if (rc != 0) {
6143 pr_err("error %d\n", rc);
6144 goto rw_error;
6145 }
6146 rc = drxj_dap_write_reg16(dev_addr, VSB_TOP_BEDETCTRL__A, 0x142, 0);
6147 if (rc != 0) {
6148 pr_err("error %d\n", rc);
6149 goto rw_error;
6150 }
6151 rc = drxj_dap_write_reg16(dev_addr, VSB_TOP_LBAGCREFLVL__A, 640, 0);
6152 if (rc != 0) {
6153 pr_err("error %d\n", rc);
6154 goto rw_error;
6155 }
6156 rc = drxj_dap_write_reg16(dev_addr, VSB_TOP_CYGN1ACQ__A, 4, 0);
6157 if (rc != 0) {
6158 pr_err("error %d\n", rc);
6159 goto rw_error;
6160 }
6161 rc = drxj_dap_write_reg16(dev_addr, VSB_TOP_CYGN1TRK__A, 2, 0);
6162 if (rc != 0) {
6163 pr_err("error %d\n", rc);
6164 goto rw_error;
6165 }
6166 rc = drxj_dap_write_reg16(dev_addr, VSB_TOP_CYGN2TRK__A, 3, 0);
6167 if (rc != 0) {
6168 pr_err("error %d\n", rc);
6169 goto rw_error;
6170 }
6171
6172
6173 cmd_scu.command = SCU_RAM_COMMAND_STANDARD_VSB
6174 | SCU_RAM_COMMAND_CMD_DEMOD_START;
6175 cmd_scu.parameter_len = 0;
6176 cmd_scu.result_len = 1;
6177 cmd_scu.parameter = NULL;
6178 cmd_scu.result = &cmd_result;
6179 rc = scu_command(dev_addr, &cmd_scu);
6180 if (rc != 0) {
6181 pr_err("error %d\n", rc);
6182 goto rw_error;
6183 }
6184
6185 rc = drxj_dap_write_reg16(dev_addr, IQM_COMM_EXEC__A, IQM_COMM_EXEC_ACTIVE, 0);
6186 if (rc != 0) {
6187 pr_err("error %d\n", rc);
6188 goto rw_error;
6189 }
6190 rc = drxj_dap_write_reg16(dev_addr, VSB_COMM_EXEC__A, VSB_COMM_EXEC_ACTIVE, 0);
6191 if (rc != 0) {
6192 pr_err("error %d\n", rc);
6193 goto rw_error;
6194 }
6195 rc = drxj_dap_write_reg16(dev_addr, FEC_COMM_EXEC__A, FEC_COMM_EXEC_ACTIVE, 0);
6196 if (rc != 0) {
6197 pr_err("error %d\n", rc);
6198 goto rw_error;
6199 }
6200
6201 return 0;
6202rw_error:
6203 return rc;
6204}
6205
6206
6207
6208
6209
6210
6211static int get_vsb_post_rs_pck_err(struct i2c_device_addr *dev_addr,
6212 u32 *pck_errs, u32 *pck_count)
6213{
6214 int rc;
6215 u16 data = 0;
6216 u16 period = 0;
6217 u16 prescale = 0;
6218 u16 packet_errors_mant = 0;
6219 u16 packet_errors_exp = 0;
6220
6221 rc = drxj_dap_read_reg16(dev_addr, FEC_RS_NR_FAILURES__A, &data, 0);
6222 if (rc != 0) {
6223 pr_err("error %d\n", rc);
6224 goto rw_error;
6225 }
6226 packet_errors_mant = data & FEC_RS_NR_FAILURES_FIXED_MANT__M;
6227 packet_errors_exp = (data & FEC_RS_NR_FAILURES_EXP__M)
6228 >> FEC_RS_NR_FAILURES_EXP__B;
6229 period = FEC_RS_MEASUREMENT_PERIOD;
6230 prescale = FEC_RS_MEASUREMENT_PRESCALE;
6231
6232
6233 if (period * prescale == 0) {
6234 pr_err("error: period and/or prescale is zero!\n");
6235 return -EIO;
6236 }
6237 *pck_errs = packet_errors_mant * (1 << packet_errors_exp);
6238 *pck_count = period * prescale * 77;
6239
6240 return 0;
6241rw_error:
6242 return rc;
6243}
6244
6245
6246
6247
6248
6249
6250static int get_vs_bpost_viterbi_ber(struct i2c_device_addr *dev_addr,
6251 u32 *ber, u32 *cnt)
6252{
6253 int rc;
6254 u16 data = 0;
6255 u16 period = 0;
6256 u16 prescale = 0;
6257 u16 bit_errors_mant = 0;
6258 u16 bit_errors_exp = 0;
6259
6260 rc = drxj_dap_read_reg16(dev_addr, FEC_RS_NR_BIT_ERRORS__A, &data, 0);
6261 if (rc != 0) {
6262 pr_err("error %d\n", rc);
6263 goto rw_error;
6264 }
6265 period = FEC_RS_MEASUREMENT_PERIOD;
6266 prescale = FEC_RS_MEASUREMENT_PRESCALE;
6267
6268 bit_errors_mant = data & FEC_RS_NR_BIT_ERRORS_FIXED_MANT__M;
6269 bit_errors_exp = (data & FEC_RS_NR_BIT_ERRORS_EXP__M)
6270 >> FEC_RS_NR_BIT_ERRORS_EXP__B;
6271
6272 *cnt = period * prescale * 207 * ((bit_errors_exp > 2) ? 1 : 8);
6273
6274 if (((bit_errors_mant << bit_errors_exp) >> 3) > 68700)
6275 *ber = (*cnt) * 26570;
6276 else {
6277 if (period * prescale == 0) {
6278 pr_err("error: period and/or prescale is zero!\n");
6279 return -EIO;
6280 }
6281 *ber = bit_errors_mant << ((bit_errors_exp > 2) ?
6282 (bit_errors_exp - 3) : bit_errors_exp);
6283 }
6284
6285 return 0;
6286rw_error:
6287 return rc;
6288}
6289
6290
6291
6292
6293
6294
6295static int get_vs_bpre_viterbi_ber(struct i2c_device_addr *dev_addr,
6296 u32 *ber, u32 *cnt)
6297{
6298 u16 data = 0;
6299 int rc;
6300
6301 rc = drxj_dap_read_reg16(dev_addr, VSB_TOP_NR_SYM_ERRS__A, &data, 0);
6302 if (rc != 0) {
6303 pr_err("error %d\n", rc);
6304 return -EIO;
6305 }
6306 *ber = data;
6307 *cnt = VSB_TOP_MEASUREMENT_PERIOD * SYMBOLS_PER_SEGMENT;
6308
6309 return 0;
6310}
6311
6312
6313
6314
6315
6316
6317static int get_vsbmer(struct i2c_device_addr *dev_addr, u16 *mer)
6318{
6319 int rc;
6320 u16 data_hi = 0;
6321
6322 rc = drxj_dap_read_reg16(dev_addr, VSB_TOP_ERR_ENERGY_H__A, &data_hi, 0);
6323 if (rc != 0) {
6324 pr_err("error %d\n", rc);
6325 goto rw_error;
6326 }
6327 *mer =
6328 (u16) (log1_times100(21504) - log1_times100((data_hi << 6) / 52));
6329
6330 return 0;
6331rw_error:
6332 return rc;
6333}
6334
6335
6336
6337
6338
6339
6340
6341
6342
6343
6344
6345
6346
6347
6348
6349
6350
6351
6352
6353static int power_down_qam(struct drx_demod_instance *demod, bool primary)
6354{
6355 struct drxjscu_cmd cmd_scu = { 0,
6356 0,
6357 0,
6358 NULL,
6359 NULL
6360 };
6361 int rc;
6362 struct i2c_device_addr *dev_addr = demod->my_i2c_dev_addr;
6363 struct drx_cfg_mpeg_output cfg_mpeg_output;
6364 struct drx_common_attr *common_attr = demod->my_common_attr;
6365 u16 cmd_result = 0;
6366
6367
6368
6369
6370
6371
6372 rc = drxj_dap_write_reg16(dev_addr, FEC_COMM_EXEC__A, FEC_COMM_EXEC_STOP, 0);
6373 if (rc != 0) {
6374 pr_err("error %d\n", rc);
6375 goto rw_error;
6376 }
6377 rc = drxj_dap_write_reg16(dev_addr, QAM_COMM_EXEC__A, QAM_COMM_EXEC_STOP, 0);
6378 if (rc != 0) {
6379 pr_err("error %d\n", rc);
6380 goto rw_error;
6381 }
6382
6383 cmd_scu.command = SCU_RAM_COMMAND_STANDARD_QAM |
6384 SCU_RAM_COMMAND_CMD_DEMOD_STOP;
6385 cmd_scu.parameter_len = 0;
6386 cmd_scu.result_len = 1;
6387 cmd_scu.parameter = NULL;
6388 cmd_scu.result = &cmd_result;
6389 rc = scu_command(dev_addr, &cmd_scu);
6390 if (rc != 0) {
6391 pr_err("error %d\n", rc);
6392 goto rw_error;
6393 }
6394
6395 if (primary) {
6396 rc = drxj_dap_write_reg16(dev_addr, IQM_COMM_EXEC__A, IQM_COMM_EXEC_STOP, 0);
6397 if (rc != 0) {
6398 pr_err("error %d\n", rc);
6399 goto rw_error;
6400 }
6401 rc = set_iqm_af(demod, false);
6402 if (rc != 0) {
6403 pr_err("error %d\n", rc);
6404 goto rw_error;
6405 }
6406 } else {
6407 rc = drxj_dap_write_reg16(dev_addr, IQM_FS_COMM_EXEC__A, IQM_FS_COMM_EXEC_STOP, 0);
6408 if (rc != 0) {
6409 pr_err("error %d\n", rc);
6410 goto rw_error;
6411 }
6412 rc = drxj_dap_write_reg16(dev_addr, IQM_FD_COMM_EXEC__A, IQM_FD_COMM_EXEC_STOP, 0);
6413 if (rc != 0) {
6414 pr_err("error %d\n", rc);
6415 goto rw_error;
6416 }
6417 rc = drxj_dap_write_reg16(dev_addr, IQM_RC_COMM_EXEC__A, IQM_RC_COMM_EXEC_STOP, 0);
6418 if (rc != 0) {
6419 pr_err("error %d\n", rc);
6420 goto rw_error;
6421 }
6422 rc = drxj_dap_write_reg16(dev_addr, IQM_RT_COMM_EXEC__A, IQM_RT_COMM_EXEC_STOP, 0);
6423 if (rc != 0) {
6424 pr_err("error %d\n", rc);
6425 goto rw_error;
6426 }
6427 rc = drxj_dap_write_reg16(dev_addr, IQM_CF_COMM_EXEC__A, IQM_CF_COMM_EXEC_STOP, 0);
6428 if (rc != 0) {
6429 pr_err("error %d\n", rc);
6430 goto rw_error;
6431 }
6432 }
6433
6434 memcpy(&cfg_mpeg_output, &common_attr->mpeg_cfg, sizeof(cfg_mpeg_output));
6435 cfg_mpeg_output.enable_mpeg_output = false;
6436
6437 rc = ctrl_set_cfg_mpeg_output(demod, &cfg_mpeg_output);
6438 if (rc != 0) {
6439 pr_err("error %d\n", rc);
6440 goto rw_error;
6441 }
6442
6443 return 0;
6444rw_error:
6445 return rc;
6446}
6447
6448
6449
6450
6451
6452
6453
6454
6455
6456
6457
6458
6459
6460
6461
6462
6463
6464
6465
6466#ifndef DRXJ_VSB_ONLY
6467static int
6468set_qam_measurement(struct drx_demod_instance *demod,
6469 enum drx_modulation constellation, u32 symbol_rate)
6470{
6471 struct i2c_device_addr *dev_addr = NULL;
6472 struct drxj_data *ext_attr = NULL;
6473 int rc;
6474 u32 fec_bits_desired = 0;
6475 u16 fec_rs_plen = 0;
6476 u16 fec_rs_prescale = 0;
6477 u32 fec_rs_period = 0;
6478 u32 fec_rs_bit_cnt = 0;
6479 u32 fec_oc_snc_fail_period = 0;
6480 u32 qam_vd_period = 0;
6481 u32 qam_vd_bit_cnt = 0;
6482 u16 fec_vd_plen = 0;
6483 u16 qam_vd_prescale = 0;
6484
6485 dev_addr = demod->my_i2c_dev_addr;
6486 ext_attr = (struct drxj_data *) demod->my_ext_attr;
6487
6488 fec_bits_desired = ext_attr->fec_bits_desired;
6489 fec_rs_prescale = ext_attr->fec_rs_prescale;
6490
6491 switch (constellation) {
6492 case DRX_CONSTELLATION_QAM16:
6493 fec_bits_desired = 4 * symbol_rate;
6494 break;
6495 case DRX_CONSTELLATION_QAM32:
6496 fec_bits_desired = 5 * symbol_rate;
6497 break;
6498 case DRX_CONSTELLATION_QAM64:
6499 fec_bits_desired = 6 * symbol_rate;
6500 break;
6501 case DRX_CONSTELLATION_QAM128:
6502 fec_bits_desired = 7 * symbol_rate;
6503 break;
6504 case DRX_CONSTELLATION_QAM256:
6505 fec_bits_desired = 8 * symbol_rate;
6506 break;
6507 default:
6508 return -EINVAL;
6509 }
6510
6511
6512
6513
6514
6515
6516
6517
6518 switch (ext_attr->standard) {
6519 case DRX_STANDARD_ITU_A:
6520 case DRX_STANDARD_ITU_C:
6521 fec_rs_plen = 204 * 8;
6522 break;
6523 case DRX_STANDARD_ITU_B:
6524 fec_rs_plen = 128 * 7;
6525 break;
6526 default:
6527 return -EINVAL;
6528 }
6529
6530 ext_attr->fec_rs_plen = fec_rs_plen;
6531 fec_rs_bit_cnt = fec_rs_prescale * fec_rs_plen;
6532 if (fec_rs_bit_cnt == 0) {
6533 pr_err("error: fec_rs_bit_cnt is zero!\n");
6534 return -EIO;
6535 }
6536 fec_rs_period = fec_bits_desired / fec_rs_bit_cnt + 1;
6537 if (ext_attr->standard != DRX_STANDARD_ITU_B)
6538 fec_oc_snc_fail_period = fec_rs_period;
6539
6540
6541 if (fec_rs_period > 0xFFFF)
6542 fec_rs_period = 0xFFFF;
6543
6544
6545 switch (ext_attr->standard) {
6546 case DRX_STANDARD_ITU_A:
6547 case DRX_STANDARD_ITU_C:
6548 break;
6549 case DRX_STANDARD_ITU_B:
6550 switch (constellation) {
6551 case DRX_CONSTELLATION_QAM64:
6552 fec_rs_period = 31581;
6553 fec_oc_snc_fail_period = 17932;
6554 break;
6555 case DRX_CONSTELLATION_QAM256:
6556 fec_rs_period = 45446;
6557 fec_oc_snc_fail_period = 25805;
6558 break;
6559 default:
6560 return -EINVAL;
6561 }
6562 break;
6563 default:
6564 return -EINVAL;
6565 }
6566
6567 rc = drxj_dap_write_reg16(dev_addr, FEC_OC_SNC_FAIL_PERIOD__A, (u16)fec_oc_snc_fail_period, 0);
6568 if (rc != 0) {
6569 pr_err("error %d\n", rc);
6570 goto rw_error;
6571 }
6572 rc = drxj_dap_write_reg16(dev_addr, FEC_RS_MEASUREMENT_PERIOD__A, (u16)fec_rs_period, 0);
6573 if (rc != 0) {
6574 pr_err("error %d\n", rc);
6575 goto rw_error;
6576 }
6577 rc = drxj_dap_write_reg16(dev_addr, FEC_RS_MEASUREMENT_PRESCALE__A, fec_rs_prescale, 0);
6578 if (rc != 0) {
6579 pr_err("error %d\n", rc);
6580 goto rw_error;
6581 }
6582 ext_attr->fec_rs_period = (u16) fec_rs_period;
6583 ext_attr->fec_rs_prescale = fec_rs_prescale;
6584 rc = drxdap_fasi_write_reg32(dev_addr, SCU_RAM_FEC_ACCUM_CW_CORRECTED_LO__A, 0, 0);
6585 if (rc != 0) {
6586 pr_err("error %d\n", rc);
6587 goto rw_error;
6588 }
6589 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_FEC_MEAS_COUNT__A, 0, 0);
6590 if (rc != 0) {
6591 pr_err("error %d\n", rc);
6592 goto rw_error;
6593 }
6594 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_FEC_ACCUM_PKT_FAILURES__A, 0, 0);
6595 if (rc != 0) {
6596 pr_err("error %d\n", rc);
6597 goto rw_error;
6598 }
6599
6600 if (ext_attr->standard == DRX_STANDARD_ITU_B) {
6601
6602
6603
6604
6605
6606
6607
6608
6609 fec_vd_plen = ext_attr->fec_vd_plen;
6610 qam_vd_prescale = ext_attr->qam_vd_prescale;
6611 qam_vd_bit_cnt = qam_vd_prescale * fec_vd_plen;
6612
6613 switch (constellation) {
6614 case DRX_CONSTELLATION_QAM64:
6615
6616 qam_vd_period =
6617 qam_vd_bit_cnt * (QAM_TOP_CONSTELLATION_QAM64 + 1)
6618 * (QAM_TOP_CONSTELLATION_QAM64 + 1);
6619 break;
6620 case DRX_CONSTELLATION_QAM256:
6621
6622 qam_vd_period =
6623 qam_vd_bit_cnt * (QAM_TOP_CONSTELLATION_QAM256 + 1)
6624 * (QAM_TOP_CONSTELLATION_QAM256 + 1);
6625 break;
6626 default:
6627 return -EINVAL;
6628 }
6629 if (qam_vd_period == 0) {
6630 pr_err("error: qam_vd_period is zero!\n");
6631 return -EIO;
6632 }
6633 qam_vd_period = fec_bits_desired / qam_vd_period;
6634
6635 if (qam_vd_period > 0xFFFF)
6636 qam_vd_period = 0xFFFF;
6637
6638
6639 qam_vd_bit_cnt *= qam_vd_period;
6640
6641 rc = drxj_dap_write_reg16(dev_addr, QAM_VD_MEASUREMENT_PERIOD__A, (u16)qam_vd_period, 0);
6642 if (rc != 0) {
6643 pr_err("error %d\n", rc);
6644 goto rw_error;
6645 }
6646 rc = drxj_dap_write_reg16(dev_addr, QAM_VD_MEASUREMENT_PRESCALE__A, qam_vd_prescale, 0);
6647 if (rc != 0) {
6648 pr_err("error %d\n", rc);
6649 goto rw_error;
6650 }
6651 ext_attr->qam_vd_period = (u16) qam_vd_period;
6652 ext_attr->qam_vd_prescale = qam_vd_prescale;
6653 }
6654
6655 return 0;
6656rw_error:
6657 return rc;
6658}
6659
6660
6661
6662
6663
6664
6665
6666
6667
6668static int set_qam16(struct drx_demod_instance *demod)
6669{
6670 struct i2c_device_addr *dev_addr = demod->my_i2c_dev_addr;
6671 int rc;
6672 static const u8 qam_dq_qual_fun[] = {
6673 DRXJ_16TO8(2),
6674 DRXJ_16TO8(2),
6675 DRXJ_16TO8(2),
6676 DRXJ_16TO8(2),
6677 DRXJ_16TO8(3),
6678 DRXJ_16TO8(3),
6679 };
6680 static const u8 qam_eq_cma_rad[] = {
6681 DRXJ_16TO8(13517),
6682 DRXJ_16TO8(13517),
6683 DRXJ_16TO8(13517),
6684 DRXJ_16TO8(13517),
6685 DRXJ_16TO8(13517),
6686 DRXJ_16TO8(13517),
6687 };
6688
6689 rc = drxdap_fasi_write_block(dev_addr, QAM_DQ_QUAL_FUN0__A, sizeof(qam_dq_qual_fun), ((u8 *)qam_dq_qual_fun), 0);
6690 if (rc != 0) {
6691 pr_err("error %d\n", rc);
6692 goto rw_error;
6693 }
6694 rc = drxdap_fasi_write_block(dev_addr, SCU_RAM_QAM_EQ_CMA_RAD0__A, sizeof(qam_eq_cma_rad), ((u8 *)qam_eq_cma_rad), 0);
6695 if (rc != 0) {
6696 pr_err("error %d\n", rc);
6697 goto rw_error;
6698 }
6699
6700 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_RTH__A, 140, 0);
6701 if (rc != 0) {
6702 pr_err("error %d\n", rc);
6703 goto rw_error;
6704 }
6705 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_FTH__A, 50, 0);
6706 if (rc != 0) {
6707 pr_err("error %d\n", rc);
6708 goto rw_error;
6709 }
6710 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_PTH__A, 120, 0);
6711 if (rc != 0) {
6712 pr_err("error %d\n", rc);
6713 goto rw_error;
6714 }
6715 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_QTH__A, 230, 0);
6716 if (rc != 0) {
6717 pr_err("error %d\n", rc);
6718 goto rw_error;
6719 }
6720 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_CTH__A, 95, 0);
6721 if (rc != 0) {
6722 pr_err("error %d\n", rc);
6723 goto rw_error;
6724 }
6725 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_MTH__A, 105, 0);
6726 if (rc != 0) {
6727 pr_err("error %d\n", rc);
6728 goto rw_error;
6729 }
6730
6731 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_RATE_LIM__A, 40, 0);
6732 if (rc != 0) {
6733 pr_err("error %d\n", rc);
6734 goto rw_error;
6735 }
6736 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_FREQ_LIM__A, 56, 0);
6737 if (rc != 0) {
6738 pr_err("error %d\n", rc);
6739 goto rw_error;
6740 }
6741 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_COUNT_LIM__A, 3, 0);
6742 if (rc != 0) {
6743 pr_err("error %d\n", rc);
6744 goto rw_error;
6745 }
6746
6747 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_MEDIAN_AV_MULT__A, 16, 0);
6748 if (rc != 0) {
6749 pr_err("error %d\n", rc);
6750 goto rw_error;
6751 }
6752 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_RADIUS_AV_LIMIT__A, 220, 0);
6753 if (rc != 0) {
6754 pr_err("error %d\n", rc);
6755 goto rw_error;
6756 }
6757 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_LCAVG_OFFSET1__A, 25, 0);
6758 if (rc != 0) {
6759 pr_err("error %d\n", rc);
6760 goto rw_error;
6761 }
6762 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_LCAVG_OFFSET2__A, 6, 0);
6763 if (rc != 0) {
6764 pr_err("error %d\n", rc);
6765 goto rw_error;
6766 }
6767 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_LCAVG_OFFSET3__A, (u16)(-24), 0);
6768 if (rc != 0) {
6769 pr_err("error %d\n", rc);
6770 goto rw_error;
6771 }
6772 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_LCAVG_OFFSET4__A, (u16)(-65), 0);
6773 if (rc != 0) {
6774 pr_err("error %d\n", rc);
6775 goto rw_error;
6776 }
6777 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_LCAVG_OFFSET5__A, (u16)(-127), 0);
6778 if (rc != 0) {
6779 pr_err("error %d\n", rc);
6780 goto rw_error;
6781 }
6782
6783 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CA_FINE__A, 15, 0);
6784 if (rc != 0) {
6785 pr_err("error %d\n", rc);
6786 goto rw_error;
6787 }
6788 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CA_COARSE__A, 40, 0);
6789 if (rc != 0) {
6790 pr_err("error %d\n", rc);
6791 goto rw_error;
6792 }
6793 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CP_FINE__A, 2, 0);
6794 if (rc != 0) {
6795 pr_err("error %d\n", rc);
6796 goto rw_error;
6797 }
6798 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CP_MEDIUM__A, 20, 0);
6799 if (rc != 0) {
6800 pr_err("error %d\n", rc);
6801 goto rw_error;
6802 }
6803 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CP_COARSE__A, 255, 0);
6804 if (rc != 0) {
6805 pr_err("error %d\n", rc);
6806 goto rw_error;
6807 }
6808 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CI_FINE__A, 2, 0);
6809 if (rc != 0) {
6810 pr_err("error %d\n", rc);
6811 goto rw_error;
6812 }
6813 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CI_MEDIUM__A, 10, 0);
6814 if (rc != 0) {
6815 pr_err("error %d\n", rc);
6816 goto rw_error;
6817 }
6818 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CI_COARSE__A, 50, 0);
6819 if (rc != 0) {
6820 pr_err("error %d\n", rc);
6821 goto rw_error;
6822 }
6823 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EP_FINE__A, 12, 0);
6824 if (rc != 0) {
6825 pr_err("error %d\n", rc);
6826 goto rw_error;
6827 }
6828 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EP_MEDIUM__A, 24, 0);
6829 if (rc != 0) {
6830 pr_err("error %d\n", rc);
6831 goto rw_error;
6832 }
6833 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EP_COARSE__A, 24, 0);
6834 if (rc != 0) {
6835 pr_err("error %d\n", rc);
6836 goto rw_error;
6837 }
6838 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EI_FINE__A, 12, 0);
6839 if (rc != 0) {
6840 pr_err("error %d\n", rc);
6841 goto rw_error;
6842 }
6843 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EI_MEDIUM__A, 16, 0);
6844 if (rc != 0) {
6845 pr_err("error %d\n", rc);
6846 goto rw_error;
6847 }
6848 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EI_COARSE__A, 16, 0);
6849 if (rc != 0) {
6850 pr_err("error %d\n", rc);
6851 goto rw_error;
6852 }
6853 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF_FINE__A, 16, 0);
6854 if (rc != 0) {
6855 pr_err("error %d\n", rc);
6856 goto rw_error;
6857 }
6858 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF_MEDIUM__A, 32, 0);
6859 if (rc != 0) {
6860 pr_err("error %d\n", rc);
6861 goto rw_error;
6862 }
6863 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF_COARSE__A, 240, 0);
6864 if (rc != 0) {
6865 pr_err("error %d\n", rc);
6866 goto rw_error;
6867 }
6868 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF1_FINE__A, 5, 0);
6869 if (rc != 0) {
6870 pr_err("error %d\n", rc);
6871 goto rw_error;
6872 }
6873 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF1_MEDIUM__A, 15, 0);
6874 if (rc != 0) {
6875 pr_err("error %d\n", rc);
6876 goto rw_error;
6877 }
6878 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF1_COARSE__A, 32, 0);
6879 if (rc != 0) {
6880 pr_err("error %d\n", rc);
6881 goto rw_error;
6882 }
6883
6884 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_SL_SIG_POWER__A, 40960, 0);
6885 if (rc != 0) {
6886 pr_err("error %d\n", rc);
6887 goto rw_error;
6888 }
6889
6890 return 0;
6891rw_error:
6892 return rc;
6893}
6894
6895
6896
6897
6898
6899
6900
6901
6902
6903static int set_qam32(struct drx_demod_instance *demod)
6904{
6905 struct i2c_device_addr *dev_addr = demod->my_i2c_dev_addr;
6906 int rc;
6907 static const u8 qam_dq_qual_fun[] = {
6908 DRXJ_16TO8(3),
6909 DRXJ_16TO8(3),
6910 DRXJ_16TO8(3),
6911 DRXJ_16TO8(3),
6912 DRXJ_16TO8(4),
6913 DRXJ_16TO8(4),
6914 };
6915 static const u8 qam_eq_cma_rad[] = {
6916 DRXJ_16TO8(6707),
6917 DRXJ_16TO8(6707),
6918 DRXJ_16TO8(6707),
6919 DRXJ_16TO8(6707),
6920 DRXJ_16TO8(6707),
6921 DRXJ_16TO8(6707),
6922 };
6923
6924 rc = drxdap_fasi_write_block(dev_addr, QAM_DQ_QUAL_FUN0__A, sizeof(qam_dq_qual_fun), ((u8 *)qam_dq_qual_fun), 0);
6925 if (rc != 0) {
6926 pr_err("error %d\n", rc);
6927 goto rw_error;
6928 }
6929 rc = drxdap_fasi_write_block(dev_addr, SCU_RAM_QAM_EQ_CMA_RAD0__A, sizeof(qam_eq_cma_rad), ((u8 *)qam_eq_cma_rad), 0);
6930 if (rc != 0) {
6931 pr_err("error %d\n", rc);
6932 goto rw_error;
6933 }
6934
6935 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_RTH__A, 90, 0);
6936 if (rc != 0) {
6937 pr_err("error %d\n", rc);
6938 goto rw_error;
6939 }
6940 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_FTH__A, 50, 0);
6941 if (rc != 0) {
6942 pr_err("error %d\n", rc);
6943 goto rw_error;
6944 }
6945 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_PTH__A, 100, 0);
6946 if (rc != 0) {
6947 pr_err("error %d\n", rc);
6948 goto rw_error;
6949 }
6950 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_QTH__A, 170, 0);
6951 if (rc != 0) {
6952 pr_err("error %d\n", rc);
6953 goto rw_error;
6954 }
6955 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_CTH__A, 80, 0);
6956 if (rc != 0) {
6957 pr_err("error %d\n", rc);
6958 goto rw_error;
6959 }
6960 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_MTH__A, 100, 0);
6961 if (rc != 0) {
6962 pr_err("error %d\n", rc);
6963 goto rw_error;
6964 }
6965
6966 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_RATE_LIM__A, 40, 0);
6967 if (rc != 0) {
6968 pr_err("error %d\n", rc);
6969 goto rw_error;
6970 }
6971 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_FREQ_LIM__A, 56, 0);
6972 if (rc != 0) {
6973 pr_err("error %d\n", rc);
6974 goto rw_error;
6975 }
6976 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_COUNT_LIM__A, 3, 0);
6977 if (rc != 0) {
6978 pr_err("error %d\n", rc);
6979 goto rw_error;
6980 }
6981
6982 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_MEDIAN_AV_MULT__A, 12, 0);
6983 if (rc != 0) {
6984 pr_err("error %d\n", rc);
6985 goto rw_error;
6986 }
6987 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_RADIUS_AV_LIMIT__A, 140, 0);
6988 if (rc != 0) {
6989 pr_err("error %d\n", rc);
6990 goto rw_error;
6991 }
6992 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_LCAVG_OFFSET1__A, (u16)(-8), 0);
6993 if (rc != 0) {
6994 pr_err("error %d\n", rc);
6995 goto rw_error;
6996 }
6997 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_LCAVG_OFFSET2__A, (u16)(-16), 0);
6998 if (rc != 0) {
6999 pr_err("error %d\n", rc);
7000 goto rw_error;
7001 }
7002 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_LCAVG_OFFSET3__A, (u16)(-26), 0);
7003 if (rc != 0) {
7004 pr_err("error %d\n", rc);
7005 goto rw_error;
7006 }
7007 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_LCAVG_OFFSET4__A, (u16)(-56), 0);
7008 if (rc != 0) {
7009 pr_err("error %d\n", rc);
7010 goto rw_error;
7011 }
7012 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_LCAVG_OFFSET5__A, (u16)(-86), 0);
7013 if (rc != 0) {
7014 pr_err("error %d\n", rc);
7015 goto rw_error;
7016 }
7017
7018 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CA_FINE__A, 15, 0);
7019 if (rc != 0) {
7020 pr_err("error %d\n", rc);
7021 goto rw_error;
7022 }
7023 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CA_COARSE__A, 40, 0);
7024 if (rc != 0) {
7025 pr_err("error %d\n", rc);
7026 goto rw_error;
7027 }
7028 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CP_FINE__A, 2, 0);
7029 if (rc != 0) {
7030 pr_err("error %d\n", rc);
7031 goto rw_error;
7032 }
7033 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CP_MEDIUM__A, 20, 0);
7034 if (rc != 0) {
7035 pr_err("error %d\n", rc);
7036 goto rw_error;
7037 }
7038 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CP_COARSE__A, 255, 0);
7039 if (rc != 0) {
7040 pr_err("error %d\n", rc);
7041 goto rw_error;
7042 }
7043 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CI_FINE__A, 2, 0);
7044 if (rc != 0) {
7045 pr_err("error %d\n", rc);
7046 goto rw_error;
7047 }
7048 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CI_MEDIUM__A, 10, 0);
7049 if (rc != 0) {
7050 pr_err("error %d\n", rc);
7051 goto rw_error;
7052 }
7053 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CI_COARSE__A, 50, 0);
7054 if (rc != 0) {
7055 pr_err("error %d\n", rc);
7056 goto rw_error;
7057 }
7058 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EP_FINE__A, 12, 0);
7059 if (rc != 0) {
7060 pr_err("error %d\n", rc);
7061 goto rw_error;
7062 }
7063 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EP_MEDIUM__A, 24, 0);
7064 if (rc != 0) {
7065 pr_err("error %d\n", rc);
7066 goto rw_error;
7067 }
7068 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EP_COARSE__A, 24, 0);
7069 if (rc != 0) {
7070 pr_err("error %d\n", rc);
7071 goto rw_error;
7072 }
7073 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EI_FINE__A, 12, 0);
7074 if (rc != 0) {
7075 pr_err("error %d\n", rc);
7076 goto rw_error;
7077 }
7078 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EI_MEDIUM__A, 16, 0);
7079 if (rc != 0) {
7080 pr_err("error %d\n", rc);
7081 goto rw_error;
7082 }
7083 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EI_COARSE__A, 16, 0);
7084 if (rc != 0) {
7085 pr_err("error %d\n", rc);
7086 goto rw_error;
7087 }
7088 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF_FINE__A, 16, 0);
7089 if (rc != 0) {
7090 pr_err("error %d\n", rc);
7091 goto rw_error;
7092 }
7093 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF_MEDIUM__A, 32, 0);
7094 if (rc != 0) {
7095 pr_err("error %d\n", rc);
7096 goto rw_error;
7097 }
7098 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF_COARSE__A, 176, 0);
7099 if (rc != 0) {
7100 pr_err("error %d\n", rc);
7101 goto rw_error;
7102 }
7103 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF1_FINE__A, 5, 0);
7104 if (rc != 0) {
7105 pr_err("error %d\n", rc);
7106 goto rw_error;
7107 }
7108 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF1_MEDIUM__A, 15, 0);
7109 if (rc != 0) {
7110 pr_err("error %d\n", rc);
7111 goto rw_error;
7112 }
7113 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF1_COARSE__A, 8, 0);
7114 if (rc != 0) {
7115 pr_err("error %d\n", rc);
7116 goto rw_error;
7117 }
7118
7119 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_SL_SIG_POWER__A, 20480, 0);
7120 if (rc != 0) {
7121 pr_err("error %d\n", rc);
7122 goto rw_error;
7123 }
7124
7125 return 0;
7126rw_error:
7127 return rc;
7128}
7129
7130
7131
7132
7133
7134
7135
7136
7137
7138static int set_qam64(struct drx_demod_instance *demod)
7139{
7140 struct i2c_device_addr *dev_addr = demod->my_i2c_dev_addr;
7141 int rc;
7142 static const u8 qam_dq_qual_fun[] = {
7143
7144 DRXJ_16TO8(4),
7145 DRXJ_16TO8(4),
7146 DRXJ_16TO8(4),
7147 DRXJ_16TO8(4),
7148 DRXJ_16TO8(6),
7149 DRXJ_16TO8(6),
7150 };
7151 static const u8 qam_eq_cma_rad[] = {
7152 DRXJ_16TO8(13336),
7153 DRXJ_16TO8(12618),
7154 DRXJ_16TO8(11988),
7155 DRXJ_16TO8(13809),
7156 DRXJ_16TO8(13809),
7157 DRXJ_16TO8(15609),
7158 };
7159
7160 rc = drxdap_fasi_write_block(dev_addr, QAM_DQ_QUAL_FUN0__A, sizeof(qam_dq_qual_fun), ((u8 *)qam_dq_qual_fun), 0);
7161 if (rc != 0) {
7162 pr_err("error %d\n", rc);
7163 goto rw_error;
7164 }
7165 rc = drxdap_fasi_write_block(dev_addr, SCU_RAM_QAM_EQ_CMA_RAD0__A, sizeof(qam_eq_cma_rad), ((u8 *)qam_eq_cma_rad), 0);
7166 if (rc != 0) {
7167 pr_err("error %d\n", rc);
7168 goto rw_error;
7169 }
7170
7171 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_RTH__A, 105, 0);
7172 if (rc != 0) {
7173 pr_err("error %d\n", rc);
7174 goto rw_error;
7175 }
7176 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_FTH__A, 60, 0);
7177 if (rc != 0) {
7178 pr_err("error %d\n", rc);
7179 goto rw_error;
7180 }
7181 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_PTH__A, 100, 0);
7182 if (rc != 0) {
7183 pr_err("error %d\n", rc);
7184 goto rw_error;
7185 }
7186 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_QTH__A, 195, 0);
7187 if (rc != 0) {
7188 pr_err("error %d\n", rc);
7189 goto rw_error;
7190 }
7191 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_CTH__A, 80, 0);
7192 if (rc != 0) {
7193 pr_err("error %d\n", rc);
7194 goto rw_error;
7195 }
7196 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_MTH__A, 84, 0);
7197 if (rc != 0) {
7198 pr_err("error %d\n", rc);
7199 goto rw_error;
7200 }
7201
7202 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_RATE_LIM__A, 40, 0);
7203 if (rc != 0) {
7204 pr_err("error %d\n", rc);
7205 goto rw_error;
7206 }
7207 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_FREQ_LIM__A, 32, 0);
7208 if (rc != 0) {
7209 pr_err("error %d\n", rc);
7210 goto rw_error;
7211 }
7212 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_COUNT_LIM__A, 3, 0);
7213 if (rc != 0) {
7214 pr_err("error %d\n", rc);
7215 goto rw_error;
7216 }
7217
7218 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_MEDIAN_AV_MULT__A, 12, 0);
7219 if (rc != 0) {
7220 pr_err("error %d\n", rc);
7221 goto rw_error;
7222 }
7223 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_RADIUS_AV_LIMIT__A, 141, 0);
7224 if (rc != 0) {
7225 pr_err("error %d\n", rc);
7226 goto rw_error;
7227 }
7228 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_LCAVG_OFFSET1__A, 7, 0);
7229 if (rc != 0) {
7230 pr_err("error %d\n", rc);
7231 goto rw_error;
7232 }
7233 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_LCAVG_OFFSET2__A, 0, 0);
7234 if (rc != 0) {
7235 pr_err("error %d\n", rc);
7236 goto rw_error;
7237 }
7238 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_LCAVG_OFFSET3__A, (u16)(-15), 0);
7239 if (rc != 0) {
7240 pr_err("error %d\n", rc);
7241 goto rw_error;
7242 }
7243 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_LCAVG_OFFSET4__A, (u16)(-45), 0);
7244 if (rc != 0) {
7245 pr_err("error %d\n", rc);
7246 goto rw_error;
7247 }
7248 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_LCAVG_OFFSET5__A, (u16)(-80), 0);
7249 if (rc != 0) {
7250 pr_err("error %d\n", rc);
7251 goto rw_error;
7252 }
7253
7254 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CA_FINE__A, 15, 0);
7255 if (rc != 0) {
7256 pr_err("error %d\n", rc);
7257 goto rw_error;
7258 }
7259 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CA_COARSE__A, 40, 0);
7260 if (rc != 0) {
7261 pr_err("error %d\n", rc);
7262 goto rw_error;
7263 }
7264 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CP_FINE__A, 2, 0);
7265 if (rc != 0) {
7266 pr_err("error %d\n", rc);
7267 goto rw_error;
7268 }
7269 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CP_MEDIUM__A, 30, 0);
7270 if (rc != 0) {
7271 pr_err("error %d\n", rc);
7272 goto rw_error;
7273 }
7274 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CP_COARSE__A, 255, 0);
7275 if (rc != 0) {
7276 pr_err("error %d\n", rc);
7277 goto rw_error;
7278 }
7279 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CI_FINE__A, 2, 0);
7280 if (rc != 0) {
7281 pr_err("error %d\n", rc);
7282 goto rw_error;
7283 }
7284 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CI_MEDIUM__A, 15, 0);
7285 if (rc != 0) {
7286 pr_err("error %d\n", rc);
7287 goto rw_error;
7288 }
7289 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CI_COARSE__A, 80, 0);
7290 if (rc != 0) {
7291 pr_err("error %d\n", rc);
7292 goto rw_error;
7293 }
7294 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EP_FINE__A, 12, 0);
7295 if (rc != 0) {
7296 pr_err("error %d\n", rc);
7297 goto rw_error;
7298 }
7299 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EP_MEDIUM__A, 24, 0);
7300 if (rc != 0) {
7301 pr_err("error %d\n", rc);
7302 goto rw_error;
7303 }
7304 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EP_COARSE__A, 24, 0);
7305 if (rc != 0) {
7306 pr_err("error %d\n", rc);
7307 goto rw_error;
7308 }
7309 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EI_FINE__A, 12, 0);
7310 if (rc != 0) {
7311 pr_err("error %d\n", rc);
7312 goto rw_error;
7313 }
7314 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EI_MEDIUM__A, 16, 0);
7315 if (rc != 0) {
7316 pr_err("error %d\n", rc);
7317 goto rw_error;
7318 }
7319 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EI_COARSE__A, 16, 0);
7320 if (rc != 0) {
7321 pr_err("error %d\n", rc);
7322 goto rw_error;
7323 }
7324 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF_FINE__A, 16, 0);
7325 if (rc != 0) {
7326 pr_err("error %d\n", rc);
7327 goto rw_error;
7328 }
7329 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF_MEDIUM__A, 48, 0);
7330 if (rc != 0) {
7331 pr_err("error %d\n", rc);
7332 goto rw_error;
7333 }
7334 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF_COARSE__A, 160, 0);
7335 if (rc != 0) {
7336 pr_err("error %d\n", rc);
7337 goto rw_error;
7338 }
7339 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF1_FINE__A, 5, 0);
7340 if (rc != 0) {
7341 pr_err("error %d\n", rc);
7342 goto rw_error;
7343 }
7344 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF1_MEDIUM__A, 15, 0);
7345 if (rc != 0) {
7346 pr_err("error %d\n", rc);
7347 goto rw_error;
7348 }
7349 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF1_COARSE__A, 32, 0);
7350 if (rc != 0) {
7351 pr_err("error %d\n", rc);
7352 goto rw_error;
7353 }
7354
7355 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_SL_SIG_POWER__A, 43008, 0);
7356 if (rc != 0) {
7357 pr_err("error %d\n", rc);
7358 goto rw_error;
7359 }
7360
7361 return 0;
7362rw_error:
7363 return rc;
7364}
7365
7366
7367
7368
7369
7370
7371
7372
7373
7374static int set_qam128(struct drx_demod_instance *demod)
7375{
7376 struct i2c_device_addr *dev_addr = demod->my_i2c_dev_addr;
7377 int rc;
7378 static const u8 qam_dq_qual_fun[] = {
7379 DRXJ_16TO8(6),
7380 DRXJ_16TO8(6),
7381 DRXJ_16TO8(6),
7382 DRXJ_16TO8(6),
7383 DRXJ_16TO8(9),
7384 DRXJ_16TO8(9),
7385 };
7386 static const u8 qam_eq_cma_rad[] = {
7387 DRXJ_16TO8(6164),
7388 DRXJ_16TO8(6598),
7389 DRXJ_16TO8(6394),
7390 DRXJ_16TO8(6409),
7391 DRXJ_16TO8(6656),
7392 DRXJ_16TO8(7238),
7393 };
7394
7395 rc = drxdap_fasi_write_block(dev_addr, QAM_DQ_QUAL_FUN0__A, sizeof(qam_dq_qual_fun), ((u8 *)qam_dq_qual_fun), 0);
7396 if (rc != 0) {
7397 pr_err("error %d\n", rc);
7398 goto rw_error;
7399 }
7400 rc = drxdap_fasi_write_block(dev_addr, SCU_RAM_QAM_EQ_CMA_RAD0__A, sizeof(qam_eq_cma_rad), ((u8 *)qam_eq_cma_rad), 0);
7401 if (rc != 0) {
7402 pr_err("error %d\n", rc);
7403 goto rw_error;
7404 }
7405
7406 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_RTH__A, 50, 0);
7407 if (rc != 0) {
7408 pr_err("error %d\n", rc);
7409 goto rw_error;
7410 }
7411 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_FTH__A, 60, 0);
7412 if (rc != 0) {
7413 pr_err("error %d\n", rc);
7414 goto rw_error;
7415 }
7416 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_PTH__A, 100, 0);
7417 if (rc != 0) {
7418 pr_err("error %d\n", rc);
7419 goto rw_error;
7420 }
7421 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_QTH__A, 140, 0);
7422 if (rc != 0) {
7423 pr_err("error %d\n", rc);
7424 goto rw_error;
7425 }
7426 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_CTH__A, 80, 0);
7427 if (rc != 0) {
7428 pr_err("error %d\n", rc);
7429 goto rw_error;
7430 }
7431 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_MTH__A, 100, 0);
7432 if (rc != 0) {
7433 pr_err("error %d\n", rc);
7434 goto rw_error;
7435 }
7436
7437 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_RATE_LIM__A, 40, 0);
7438 if (rc != 0) {
7439 pr_err("error %d\n", rc);
7440 goto rw_error;
7441 }
7442 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_FREQ_LIM__A, 32, 0);
7443 if (rc != 0) {
7444 pr_err("error %d\n", rc);
7445 goto rw_error;
7446 }
7447 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_COUNT_LIM__A, 3, 0);
7448 if (rc != 0) {
7449 pr_err("error %d\n", rc);
7450 goto rw_error;
7451 }
7452
7453 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_MEDIAN_AV_MULT__A, 8, 0);
7454 if (rc != 0) {
7455 pr_err("error %d\n", rc);
7456 goto rw_error;
7457 }
7458 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_RADIUS_AV_LIMIT__A, 65, 0);
7459 if (rc != 0) {
7460 pr_err("error %d\n", rc);
7461 goto rw_error;
7462 }
7463 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_LCAVG_OFFSET1__A, 5, 0);
7464 if (rc != 0) {
7465 pr_err("error %d\n", rc);
7466 goto rw_error;
7467 }
7468 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_LCAVG_OFFSET2__A, 3, 0);
7469 if (rc != 0) {
7470 pr_err("error %d\n", rc);
7471 goto rw_error;
7472 }
7473 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_LCAVG_OFFSET3__A, (u16)(-1), 0);
7474 if (rc != 0) {
7475 pr_err("error %d\n", rc);
7476 goto rw_error;
7477 }
7478 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_LCAVG_OFFSET4__A, 12, 0);
7479 if (rc != 0) {
7480 pr_err("error %d\n", rc);
7481 goto rw_error;
7482 }
7483 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_LCAVG_OFFSET5__A, (u16)(-23), 0);
7484 if (rc != 0) {
7485 pr_err("error %d\n", rc);
7486 goto rw_error;
7487 }
7488
7489 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CA_FINE__A, 15, 0);
7490 if (rc != 0) {
7491 pr_err("error %d\n", rc);
7492 goto rw_error;
7493 }
7494 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CA_COARSE__A, 40, 0);
7495 if (rc != 0) {
7496 pr_err("error %d\n", rc);
7497 goto rw_error;
7498 }
7499 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CP_FINE__A, 2, 0);
7500 if (rc != 0) {
7501 pr_err("error %d\n", rc);
7502 goto rw_error;
7503 }
7504 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CP_MEDIUM__A, 40, 0);
7505 if (rc != 0) {
7506 pr_err("error %d\n", rc);
7507 goto rw_error;
7508 }
7509 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CP_COARSE__A, 255, 0);
7510 if (rc != 0) {
7511 pr_err("error %d\n", rc);
7512 goto rw_error;
7513 }
7514 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CI_FINE__A, 2, 0);
7515 if (rc != 0) {
7516 pr_err("error %d\n", rc);
7517 goto rw_error;
7518 }
7519 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CI_MEDIUM__A, 20, 0);
7520 if (rc != 0) {
7521 pr_err("error %d\n", rc);
7522 goto rw_error;
7523 }
7524 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CI_COARSE__A, 80, 0);
7525 if (rc != 0) {
7526 pr_err("error %d\n", rc);
7527 goto rw_error;
7528 }
7529 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EP_FINE__A, 12, 0);
7530 if (rc != 0) {
7531 pr_err("error %d\n", rc);
7532 goto rw_error;
7533 }
7534 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EP_MEDIUM__A, 24, 0);
7535 if (rc != 0) {
7536 pr_err("error %d\n", rc);
7537 goto rw_error;
7538 }
7539 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EP_COARSE__A, 24, 0);
7540 if (rc != 0) {
7541 pr_err("error %d\n", rc);
7542 goto rw_error;
7543 }
7544 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EI_FINE__A, 12, 0);
7545 if (rc != 0) {
7546 pr_err("error %d\n", rc);
7547 goto rw_error;
7548 }
7549 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EI_MEDIUM__A, 16, 0);
7550 if (rc != 0) {
7551 pr_err("error %d\n", rc);
7552 goto rw_error;
7553 }
7554 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EI_COARSE__A, 16, 0);
7555 if (rc != 0) {
7556 pr_err("error %d\n", rc);
7557 goto rw_error;
7558 }
7559 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF_FINE__A, 16, 0);
7560 if (rc != 0) {
7561 pr_err("error %d\n", rc);
7562 goto rw_error;
7563 }
7564 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF_MEDIUM__A, 32, 0);
7565 if (rc != 0) {
7566 pr_err("error %d\n", rc);
7567 goto rw_error;
7568 }
7569 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF_COARSE__A, 144, 0);
7570 if (rc != 0) {
7571 pr_err("error %d\n", rc);
7572 goto rw_error;
7573 }
7574 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF1_FINE__A, 5, 0);
7575 if (rc != 0) {
7576 pr_err("error %d\n", rc);
7577 goto rw_error;
7578 }
7579 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF1_MEDIUM__A, 15, 0);
7580 if (rc != 0) {
7581 pr_err("error %d\n", rc);
7582 goto rw_error;
7583 }
7584 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF1_COARSE__A, 16, 0);
7585 if (rc != 0) {
7586 pr_err("error %d\n", rc);
7587 goto rw_error;
7588 }
7589
7590 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_SL_SIG_POWER__A, 20992, 0);
7591 if (rc != 0) {
7592 pr_err("error %d\n", rc);
7593 goto rw_error;
7594 }
7595
7596 return 0;
7597rw_error:
7598 return rc;
7599}
7600
7601
7602
7603
7604
7605
7606
7607
7608
7609static int set_qam256(struct drx_demod_instance *demod)
7610{
7611 struct i2c_device_addr *dev_addr = demod->my_i2c_dev_addr;
7612 int rc;
7613 static const u8 qam_dq_qual_fun[] = {
7614 DRXJ_16TO8(8),
7615 DRXJ_16TO8(8),
7616 DRXJ_16TO8(8),
7617 DRXJ_16TO8(8),
7618 DRXJ_16TO8(12),
7619 DRXJ_16TO8(12),
7620 };
7621 static const u8 qam_eq_cma_rad[] = {
7622 DRXJ_16TO8(12345),
7623 DRXJ_16TO8(12345),
7624 DRXJ_16TO8(13626),
7625 DRXJ_16TO8(12931),
7626 DRXJ_16TO8(14719),
7627 DRXJ_16TO8(15356),
7628 };
7629
7630 rc = drxdap_fasi_write_block(dev_addr, QAM_DQ_QUAL_FUN0__A, sizeof(qam_dq_qual_fun), ((u8 *)qam_dq_qual_fun), 0);
7631 if (rc != 0) {
7632 pr_err("error %d\n", rc);
7633 goto rw_error;
7634 }
7635 rc = drxdap_fasi_write_block(dev_addr, SCU_RAM_QAM_EQ_CMA_RAD0__A, sizeof(qam_eq_cma_rad), ((u8 *)qam_eq_cma_rad), 0);
7636 if (rc != 0) {
7637 pr_err("error %d\n", rc);
7638 goto rw_error;
7639 }
7640
7641 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_RTH__A, 50, 0);
7642 if (rc != 0) {
7643 pr_err("error %d\n", rc);
7644 goto rw_error;
7645 }
7646 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_FTH__A, 60, 0);
7647 if (rc != 0) {
7648 pr_err("error %d\n", rc);
7649 goto rw_error;
7650 }
7651 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_PTH__A, 100, 0);
7652 if (rc != 0) {
7653 pr_err("error %d\n", rc);
7654 goto rw_error;
7655 }
7656 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_QTH__A, 150, 0);
7657 if (rc != 0) {
7658 pr_err("error %d\n", rc);
7659 goto rw_error;
7660 }
7661 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_CTH__A, 80, 0);
7662 if (rc != 0) {
7663 pr_err("error %d\n", rc);
7664 goto rw_error;
7665 }
7666 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_MTH__A, 110, 0);
7667 if (rc != 0) {
7668 pr_err("error %d\n", rc);
7669 goto rw_error;
7670 }
7671
7672 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_RATE_LIM__A, 40, 0);
7673 if (rc != 0) {
7674 pr_err("error %d\n", rc);
7675 goto rw_error;
7676 }
7677 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_FREQ_LIM__A, 16, 0);
7678 if (rc != 0) {
7679 pr_err("error %d\n", rc);
7680 goto rw_error;
7681 }
7682 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_COUNT_LIM__A, 3, 0);
7683 if (rc != 0) {
7684 pr_err("error %d\n", rc);
7685 goto rw_error;
7686 }
7687
7688 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_MEDIAN_AV_MULT__A, 8, 0);
7689 if (rc != 0) {
7690 pr_err("error %d\n", rc);
7691 goto rw_error;
7692 }
7693 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_RADIUS_AV_LIMIT__A, 74, 0);
7694 if (rc != 0) {
7695 pr_err("error %d\n", rc);
7696 goto rw_error;
7697 }
7698 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_LCAVG_OFFSET1__A, 18, 0);
7699 if (rc != 0) {
7700 pr_err("error %d\n", rc);
7701 goto rw_error;
7702 }
7703 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_LCAVG_OFFSET2__A, 13, 0);
7704 if (rc != 0) {
7705 pr_err("error %d\n", rc);
7706 goto rw_error;
7707 }
7708 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_LCAVG_OFFSET3__A, 7, 0);
7709 if (rc != 0) {
7710 pr_err("error %d\n", rc);
7711 goto rw_error;
7712 }
7713 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_LCAVG_OFFSET4__A, 0, 0);
7714 if (rc != 0) {
7715 pr_err("error %d\n", rc);
7716 goto rw_error;
7717 }
7718 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_LCAVG_OFFSET5__A, (u16)(-8), 0);
7719 if (rc != 0) {
7720 pr_err("error %d\n", rc);
7721 goto rw_error;
7722 }
7723
7724 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CA_FINE__A, 15, 0);
7725 if (rc != 0) {
7726 pr_err("error %d\n", rc);
7727 goto rw_error;
7728 }
7729 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CA_COARSE__A, 40, 0);
7730 if (rc != 0) {
7731 pr_err("error %d\n", rc);
7732 goto rw_error;
7733 }
7734 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CP_FINE__A, 2, 0);
7735 if (rc != 0) {
7736 pr_err("error %d\n", rc);
7737 goto rw_error;
7738 }
7739 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CP_MEDIUM__A, 50, 0);
7740 if (rc != 0) {
7741 pr_err("error %d\n", rc);
7742 goto rw_error;
7743 }
7744 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CP_COARSE__A, 255, 0);
7745 if (rc != 0) {
7746 pr_err("error %d\n", rc);
7747 goto rw_error;
7748 }
7749 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CI_FINE__A, 2, 0);
7750 if (rc != 0) {
7751 pr_err("error %d\n", rc);
7752 goto rw_error;
7753 }
7754 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CI_MEDIUM__A, 25, 0);
7755 if (rc != 0) {
7756 pr_err("error %d\n", rc);
7757 goto rw_error;
7758 }
7759 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CI_COARSE__A, 80, 0);
7760 if (rc != 0) {
7761 pr_err("error %d\n", rc);
7762 goto rw_error;
7763 }
7764 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EP_FINE__A, 12, 0);
7765 if (rc != 0) {
7766 pr_err("error %d\n", rc);
7767 goto rw_error;
7768 }
7769 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EP_MEDIUM__A, 24, 0);
7770 if (rc != 0) {
7771 pr_err("error %d\n", rc);
7772 goto rw_error;
7773 }
7774 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EP_COARSE__A, 24, 0);
7775 if (rc != 0) {
7776 pr_err("error %d\n", rc);
7777 goto rw_error;
7778 }
7779 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EI_FINE__A, 12, 0);
7780 if (rc != 0) {
7781 pr_err("error %d\n", rc);
7782 goto rw_error;
7783 }
7784 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EI_MEDIUM__A, 16, 0);
7785 if (rc != 0) {
7786 pr_err("error %d\n", rc);
7787 goto rw_error;
7788 }
7789 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_EI_COARSE__A, 16, 0);
7790 if (rc != 0) {
7791 pr_err("error %d\n", rc);
7792 goto rw_error;
7793 }
7794 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF_FINE__A, 16, 0);
7795 if (rc != 0) {
7796 pr_err("error %d\n", rc);
7797 goto rw_error;
7798 }
7799 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF_MEDIUM__A, 48, 0);
7800 if (rc != 0) {
7801 pr_err("error %d\n", rc);
7802 goto rw_error;
7803 }
7804 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF_COARSE__A, 80, 0);
7805 if (rc != 0) {
7806 pr_err("error %d\n", rc);
7807 goto rw_error;
7808 }
7809 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF1_FINE__A, 5, 0);
7810 if (rc != 0) {
7811 pr_err("error %d\n", rc);
7812 goto rw_error;
7813 }
7814 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF1_MEDIUM__A, 15, 0);
7815 if (rc != 0) {
7816 pr_err("error %d\n", rc);
7817 goto rw_error;
7818 }
7819 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_LC_CF1_COARSE__A, 16, 0);
7820 if (rc != 0) {
7821 pr_err("error %d\n", rc);
7822 goto rw_error;
7823 }
7824
7825 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_SL_SIG_POWER__A, 43520, 0);
7826 if (rc != 0) {
7827 pr_err("error %d\n", rc);
7828 goto rw_error;
7829 }
7830
7831 return 0;
7832rw_error:
7833 return rc;
7834}
7835
7836
7837#define QAM_SET_OP_ALL 0x1
7838#define QAM_SET_OP_CONSTELLATION 0x2
7839#define QAM_SET_OP_SPECTRUM 0X4
7840
7841
7842
7843
7844
7845
7846
7847
7848static int
7849set_qam(struct drx_demod_instance *demod,
7850 struct drx_channel *channel, s32 tuner_freq_offset, u32 op)
7851{
7852 struct i2c_device_addr *dev_addr = NULL;
7853 struct drxj_data *ext_attr = NULL;
7854 struct drx_common_attr *common_attr = NULL;
7855 int rc;
7856 u32 adc_frequency = 0;
7857 u32 iqm_rc_rate = 0;
7858 u16 cmd_result = 0;
7859 u16 lc_symbol_freq = 0;
7860 u16 iqm_rc_stretch = 0;
7861 u16 set_env_parameters = 0;
7862 u16 set_param_parameters[2] = { 0 };
7863 struct drxjscu_cmd cmd_scu = { 0,
7864 0,
7865 0,
7866 NULL,
7867 NULL
7868 };
7869 static const u8 qam_a_taps[] = {
7870 DRXJ_16TO8(-1),
7871 DRXJ_16TO8(1),
7872 DRXJ_16TO8(1),
7873 DRXJ_16TO8(-1),
7874 DRXJ_16TO8(-1),
7875 DRXJ_16TO8(2),
7876 DRXJ_16TO8(1),
7877 DRXJ_16TO8(-2),
7878 DRXJ_16TO8(0),
7879 DRXJ_16TO8(3),
7880 DRXJ_16TO8(-1),
7881 DRXJ_16TO8(-3),
7882 DRXJ_16TO8(4),
7883 DRXJ_16TO8(1),
7884 DRXJ_16TO8(-8),
7885 DRXJ_16TO8(4),
7886 DRXJ_16TO8(13),
7887 DRXJ_16TO8(-13),
7888 DRXJ_16TO8(-19),
7889 DRXJ_16TO8(28),
7890 DRXJ_16TO8(25),
7891 DRXJ_16TO8(-53),
7892 DRXJ_16TO8(-31),
7893 DRXJ_16TO8(96),
7894 DRXJ_16TO8(37),
7895 DRXJ_16TO8(-190),
7896 DRXJ_16TO8(-40),
7897 DRXJ_16TO8(619)
7898 };
7899 static const u8 qam_b64_taps[] = {
7900 DRXJ_16TO8(0),
7901 DRXJ_16TO8(-2),
7902 DRXJ_16TO8(1),
7903 DRXJ_16TO8(2),
7904 DRXJ_16TO8(-2),
7905 DRXJ_16TO8(0),
7906 DRXJ_16TO8(4),
7907 DRXJ_16TO8(-2),
7908 DRXJ_16TO8(-4),
7909 DRXJ_16TO8(4),
7910 DRXJ_16TO8(3),
7911 DRXJ_16TO8(-6),
7912 DRXJ_16TO8(0),
7913 DRXJ_16TO8(6),
7914 DRXJ_16TO8(-5),
7915 DRXJ_16TO8(-3),
7916 DRXJ_16TO8(11),
7917 DRXJ_16TO8(-4),
7918 DRXJ_16TO8(-19),
7919 DRXJ_16TO8(19),
7920 DRXJ_16TO8(28),
7921 DRXJ_16TO8(-45),
7922 DRXJ_16TO8(-36),
7923 DRXJ_16TO8(90),
7924 DRXJ_16TO8(42),
7925 DRXJ_16TO8(-185),
7926 DRXJ_16TO8(-46),
7927 DRXJ_16TO8(614)
7928 };
7929 static const u8 qam_b256_taps[] = {
7930 DRXJ_16TO8(-2),
7931 DRXJ_16TO8(4),
7932 DRXJ_16TO8(1),
7933 DRXJ_16TO8(-4),
7934 DRXJ_16TO8(0),
7935 DRXJ_16TO8(4),
7936 DRXJ_16TO8(-2),
7937 DRXJ_16TO8(-4),
7938 DRXJ_16TO8(5),
7939 DRXJ_16TO8(2),
7940 DRXJ_16TO8(-8),
7941 DRXJ_16TO8(2),
7942 DRXJ_16TO8(11),
7943 DRXJ_16TO8(-8),
7944 DRXJ_16TO8(-15),
7945 DRXJ_16TO8(16),
7946 DRXJ_16TO8(19),
7947 DRXJ_16TO8(-27),
7948 DRXJ_16TO8(-22),
7949 DRXJ_16TO8(44),
7950 DRXJ_16TO8(26),
7951 DRXJ_16TO8(-69),
7952 DRXJ_16TO8(-28),
7953 DRXJ_16TO8(110),
7954 DRXJ_16TO8(31),
7955 DRXJ_16TO8(-201),
7956 DRXJ_16TO8(-32),
7957 DRXJ_16TO8(628)
7958 };
7959 static const u8 qam_c_taps[] = {
7960 DRXJ_16TO8(-3),
7961 DRXJ_16TO8(3),
7962 DRXJ_16TO8(2),
7963 DRXJ_16TO8(-4),
7964 DRXJ_16TO8(0),
7965 DRXJ_16TO8(4),
7966 DRXJ_16TO8(-1),
7967 DRXJ_16TO8(-4),
7968 DRXJ_16TO8(3),
7969 DRXJ_16TO8(3),
7970 DRXJ_16TO8(-5),
7971 DRXJ_16TO8(0),
7972 DRXJ_16TO8(9),
7973 DRXJ_16TO8(-4),
7974 DRXJ_16TO8(-12),
7975 DRXJ_16TO8(10),
7976 DRXJ_16TO8(16),
7977 DRXJ_16TO8(-21),
7978 DRXJ_16TO8(-20),
7979 DRXJ_16TO8(37),
7980 DRXJ_16TO8(25),
7981 DRXJ_16TO8(-62),
7982 DRXJ_16TO8(-28),
7983 DRXJ_16TO8(105),
7984 DRXJ_16TO8(31),
7985 DRXJ_16TO8(-197),
7986 DRXJ_16TO8(-33),
7987 DRXJ_16TO8(626)
7988 };
7989
7990 dev_addr = demod->my_i2c_dev_addr;
7991 ext_attr = (struct drxj_data *) demod->my_ext_attr;
7992 common_attr = (struct drx_common_attr *) demod->my_common_attr;
7993
7994 if ((op & QAM_SET_OP_ALL) || (op & QAM_SET_OP_CONSTELLATION)) {
7995 if (ext_attr->standard == DRX_STANDARD_ITU_B) {
7996 switch (channel->constellation) {
7997 case DRX_CONSTELLATION_QAM256:
7998 iqm_rc_rate = 0x00AE3562;
7999 lc_symbol_freq =
8000 QAM_LC_SYMBOL_FREQ_FREQ_QAM_B_256;
8001 channel->symbolrate = 5360537;
8002 iqm_rc_stretch = IQM_RC_STRETCH_QAM_B_256;
8003 break;
8004 case DRX_CONSTELLATION_QAM64:
8005 iqm_rc_rate = 0x00C05A0E;
8006 lc_symbol_freq = 409;
8007 channel->symbolrate = 5056941;
8008 iqm_rc_stretch = IQM_RC_STRETCH_QAM_B_64;
8009 break;
8010 default:
8011 return -EINVAL;
8012 }
8013 } else {
8014 adc_frequency = (common_attr->sys_clock_freq * 1000) / 3;
8015 if (channel->symbolrate == 0) {
8016 pr_err("error: channel symbolrate is zero!\n");
8017 return -EIO;
8018 }
8019 iqm_rc_rate =
8020 (adc_frequency / channel->symbolrate) * (1 << 21) +
8021 (frac28
8022 ((adc_frequency % channel->symbolrate),
8023 channel->symbolrate) >> 7) - (1 << 23);
8024 lc_symbol_freq =
8025 (u16) (frac28
8026 (channel->symbolrate +
8027 (adc_frequency >> 13),
8028 adc_frequency) >> 16);
8029 if (lc_symbol_freq > 511)
8030 lc_symbol_freq = 511;
8031
8032 iqm_rc_stretch = 21;
8033 }
8034
8035 if (ext_attr->standard == DRX_STANDARD_ITU_A) {
8036 set_env_parameters = QAM_TOP_ANNEX_A;
8037 set_param_parameters[0] = channel->constellation;
8038 set_param_parameters[1] = DRX_INTERLEAVEMODE_I12_J17;
8039 } else if (ext_attr->standard == DRX_STANDARD_ITU_B) {
8040 set_env_parameters = QAM_TOP_ANNEX_B;
8041 set_param_parameters[0] = channel->constellation;
8042 set_param_parameters[1] = channel->interleavemode;
8043 } else if (ext_attr->standard == DRX_STANDARD_ITU_C) {
8044 set_env_parameters = QAM_TOP_ANNEX_C;
8045 set_param_parameters[0] = channel->constellation;
8046 set_param_parameters[1] = DRX_INTERLEAVEMODE_I12_J17;
8047 } else {
8048 return -EINVAL;
8049 }
8050 }
8051
8052 if (op & QAM_SET_OP_ALL) {
8053
8054
8055
8056
8057
8058
8059 rc = drxj_dap_write_reg16(dev_addr, FEC_COMM_EXEC__A, FEC_COMM_EXEC_STOP, 0);
8060 if (rc != 0) {
8061 pr_err("error %d\n", rc);
8062 goto rw_error;
8063 }
8064 rc = drxj_dap_write_reg16(dev_addr, QAM_COMM_EXEC__A, QAM_COMM_EXEC_STOP, 0);
8065 if (rc != 0) {
8066 pr_err("error %d\n", rc);
8067 goto rw_error;
8068 }
8069 rc = drxj_dap_write_reg16(dev_addr, IQM_FS_COMM_EXEC__A, IQM_FS_COMM_EXEC_STOP, 0);
8070 if (rc != 0) {
8071 pr_err("error %d\n", rc);
8072 goto rw_error;
8073 }
8074 rc = drxj_dap_write_reg16(dev_addr, IQM_FD_COMM_EXEC__A, IQM_FD_COMM_EXEC_STOP, 0);
8075 if (rc != 0) {
8076 pr_err("error %d\n", rc);
8077 goto rw_error;
8078 }
8079 rc = drxj_dap_write_reg16(dev_addr, IQM_RC_COMM_EXEC__A, IQM_RC_COMM_EXEC_STOP, 0);
8080 if (rc != 0) {
8081 pr_err("error %d\n", rc);
8082 goto rw_error;
8083 }
8084 rc = drxj_dap_write_reg16(dev_addr, IQM_RT_COMM_EXEC__A, IQM_RT_COMM_EXEC_STOP, 0);
8085 if (rc != 0) {
8086 pr_err("error %d\n", rc);
8087 goto rw_error;
8088 }
8089 rc = drxj_dap_write_reg16(dev_addr, IQM_CF_COMM_EXEC__A, IQM_CF_COMM_EXEC_STOP, 0);
8090 if (rc != 0) {
8091 pr_err("error %d\n", rc);
8092 goto rw_error;
8093 }
8094
8095 cmd_scu.command = SCU_RAM_COMMAND_STANDARD_QAM |
8096 SCU_RAM_COMMAND_CMD_DEMOD_RESET;
8097 cmd_scu.parameter_len = 0;
8098 cmd_scu.result_len = 1;
8099 cmd_scu.parameter = NULL;
8100 cmd_scu.result = &cmd_result;
8101 rc = scu_command(dev_addr, &cmd_scu);
8102 if (rc != 0) {
8103 pr_err("error %d\n", rc);
8104 goto rw_error;
8105 }
8106 }
8107
8108 if ((op & QAM_SET_OP_ALL) || (op & QAM_SET_OP_CONSTELLATION)) {
8109
8110
8111
8112
8113
8114 cmd_scu.command = SCU_RAM_COMMAND_STANDARD_QAM |
8115 SCU_RAM_COMMAND_CMD_DEMOD_SET_ENV;
8116 cmd_scu.parameter_len = 1;
8117 cmd_scu.result_len = 1;
8118 cmd_scu.parameter = &set_env_parameters;
8119 cmd_scu.result = &cmd_result;
8120 rc = scu_command(dev_addr, &cmd_scu);
8121 if (rc != 0) {
8122 pr_err("error %d\n", rc);
8123 goto rw_error;
8124 }
8125
8126 cmd_scu.command = SCU_RAM_COMMAND_STANDARD_QAM |
8127 SCU_RAM_COMMAND_CMD_DEMOD_SET_PARAM;
8128 cmd_scu.parameter_len = 2;
8129 cmd_scu.result_len = 1;
8130 cmd_scu.parameter = set_param_parameters;
8131 cmd_scu.result = &cmd_result;
8132 rc = scu_command(dev_addr, &cmd_scu);
8133 if (rc != 0) {
8134 pr_err("error %d\n", rc);
8135 goto rw_error;
8136 }
8137
8138 rc = drxdap_fasi_write_reg32(dev_addr, IQM_RC_RATE_OFS_LO__A, iqm_rc_rate, 0);
8139 if (rc != 0) {
8140 pr_err("error %d\n", rc);
8141 goto rw_error;
8142 }
8143 ext_attr->iqm_rc_rate_ofs = iqm_rc_rate;
8144 rc = set_qam_measurement(demod, channel->constellation, channel->symbolrate);
8145 if (rc != 0) {
8146 pr_err("error %d\n", rc);
8147 goto rw_error;
8148 }
8149 }
8150
8151
8152
8153
8154 if ((op & QAM_SET_OP_ALL) || (op & QAM_SET_OP_SPECTRUM)) {
8155 rc = set_frequency(demod, channel, tuner_freq_offset);
8156 if (rc != 0) {
8157 pr_err("error %d\n", rc);
8158 goto rw_error;
8159 }
8160 }
8161
8162 if ((op & QAM_SET_OP_ALL) || (op & QAM_SET_OP_CONSTELLATION)) {
8163
8164 rc = drxj_dap_write_reg16(dev_addr, QAM_LC_SYMBOL_FREQ__A, lc_symbol_freq, 0);
8165 if (rc != 0) {
8166 pr_err("error %d\n", rc);
8167 goto rw_error;
8168 }
8169 rc = drxj_dap_write_reg16(dev_addr, IQM_RC_STRETCH__A, iqm_rc_stretch, 0);
8170 if (rc != 0) {
8171 pr_err("error %d\n", rc);
8172 goto rw_error;
8173 }
8174 }
8175
8176 if (op & QAM_SET_OP_ALL) {
8177 if (!ext_attr->has_lna) {
8178 rc = drxj_dap_write_reg16(dev_addr, IQM_AF_AMUX__A, 0x02, 0);
8179 if (rc != 0) {
8180 pr_err("error %d\n", rc);
8181 goto rw_error;
8182 }
8183 }
8184 rc = drxj_dap_write_reg16(dev_addr, IQM_CF_SYMMETRIC__A, 0, 0);
8185 if (rc != 0) {
8186 pr_err("error %d\n", rc);
8187 goto rw_error;
8188 }
8189 rc = drxj_dap_write_reg16(dev_addr, IQM_CF_MIDTAP__A, 3, 0);
8190 if (rc != 0) {
8191 pr_err("error %d\n", rc);
8192 goto rw_error;
8193 }
8194 rc = drxj_dap_write_reg16(dev_addr, IQM_CF_OUT_ENA__A, IQM_CF_OUT_ENA_QAM__M, 0);
8195 if (rc != 0) {
8196 pr_err("error %d\n", rc);
8197 goto rw_error;
8198 }
8199
8200 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_WR_RSV_0__A, 0x5f, 0);
8201 if (rc != 0) {
8202 pr_err("error %d\n", rc);
8203 goto rw_error;
8204 }
8205
8206 rc = drxj_dap_write_reg16(dev_addr, IQM_AF_SYNC_SEL__A, 3, 0);
8207 if (rc != 0) {
8208 pr_err("error %d\n", rc);
8209 goto rw_error;
8210 }
8211 rc = drxj_dap_write_reg16(dev_addr, IQM_AF_CLP_LEN__A, 0, 0);
8212 if (rc != 0) {
8213 pr_err("error %d\n", rc);
8214 goto rw_error;
8215 }
8216 rc = drxj_dap_write_reg16(dev_addr, IQM_AF_CLP_TH__A, 448, 0);
8217 if (rc != 0) {
8218 pr_err("error %d\n", rc);
8219 goto rw_error;
8220 }
8221 rc = drxj_dap_write_reg16(dev_addr, IQM_AF_SNS_LEN__A, 0, 0);
8222 if (rc != 0) {
8223 pr_err("error %d\n", rc);
8224 goto rw_error;
8225 }
8226 rc = drxj_dap_write_reg16(dev_addr, IQM_AF_PDREF__A, 4, 0);
8227 if (rc != 0) {
8228 pr_err("error %d\n", rc);
8229 goto rw_error;
8230 }
8231 rc = drxj_dap_write_reg16(dev_addr, IQM_AF_STDBY__A, 0x10, 0);
8232 if (rc != 0) {
8233 pr_err("error %d\n", rc);
8234 goto rw_error;
8235 }
8236 rc = drxj_dap_write_reg16(dev_addr, IQM_AF_PGA_GAIN__A, 11, 0);
8237 if (rc != 0) {
8238 pr_err("error %d\n", rc);
8239 goto rw_error;
8240 }
8241
8242 rc = drxj_dap_write_reg16(dev_addr, IQM_CF_POW_MEAS_LEN__A, 1, 0);
8243 if (rc != 0) {
8244 pr_err("error %d\n", rc);
8245 goto rw_error;
8246 }
8247 rc = drxj_dap_write_reg16(dev_addr, IQM_CF_SCALE_SH__A, IQM_CF_SCALE_SH__PRE, 0);
8248 if (rc != 0) {
8249 pr_err("error %d\n", rc);
8250 goto rw_error;
8251 }
8252
8253 rc = drxj_dap_write_reg16(dev_addr, QAM_SY_TIMEOUT__A, QAM_SY_TIMEOUT__PRE, 0);
8254 if (rc != 0) {
8255 pr_err("error %d\n", rc);
8256 goto rw_error;
8257 }
8258 if (ext_attr->standard == DRX_STANDARD_ITU_B) {
8259 rc = drxj_dap_write_reg16(dev_addr, QAM_SY_SYNC_LWM__A, QAM_SY_SYNC_LWM__PRE, 0);
8260 if (rc != 0) {
8261 pr_err("error %d\n", rc);
8262 goto rw_error;
8263 }
8264 rc = drxj_dap_write_reg16(dev_addr, QAM_SY_SYNC_AWM__A, QAM_SY_SYNC_AWM__PRE, 0);
8265 if (rc != 0) {
8266 pr_err("error %d\n", rc);
8267 goto rw_error;
8268 }
8269 rc = drxj_dap_write_reg16(dev_addr, QAM_SY_SYNC_HWM__A, QAM_SY_SYNC_HWM__PRE, 0);
8270 if (rc != 0) {
8271 pr_err("error %d\n", rc);
8272 goto rw_error;
8273 }
8274 } else {
8275 switch (channel->constellation) {
8276 case DRX_CONSTELLATION_QAM16:
8277 case DRX_CONSTELLATION_QAM64:
8278 case DRX_CONSTELLATION_QAM256:
8279 rc = drxj_dap_write_reg16(dev_addr, QAM_SY_SYNC_LWM__A, 0x03, 0);
8280 if (rc != 0) {
8281 pr_err("error %d\n", rc);
8282 goto rw_error;
8283 }
8284 rc = drxj_dap_write_reg16(dev_addr, QAM_SY_SYNC_AWM__A, 0x04, 0);
8285 if (rc != 0) {
8286 pr_err("error %d\n", rc);
8287 goto rw_error;
8288 }
8289 rc = drxj_dap_write_reg16(dev_addr, QAM_SY_SYNC_HWM__A, QAM_SY_SYNC_HWM__PRE, 0);
8290 if (rc != 0) {
8291 pr_err("error %d\n", rc);
8292 goto rw_error;
8293 }
8294 break;
8295 case DRX_CONSTELLATION_QAM32:
8296 case DRX_CONSTELLATION_QAM128:
8297 rc = drxj_dap_write_reg16(dev_addr, QAM_SY_SYNC_LWM__A, 0x03, 0);
8298 if (rc != 0) {
8299 pr_err("error %d\n", rc);
8300 goto rw_error;
8301 }
8302 rc = drxj_dap_write_reg16(dev_addr, QAM_SY_SYNC_AWM__A, 0x05, 0);
8303 if (rc != 0) {
8304 pr_err("error %d\n", rc);
8305 goto rw_error;
8306 }
8307 rc = drxj_dap_write_reg16(dev_addr, QAM_SY_SYNC_HWM__A, 0x06, 0);
8308 if (rc != 0) {
8309 pr_err("error %d\n", rc);
8310 goto rw_error;
8311 }
8312 break;
8313 default:
8314 return -EIO;
8315 }
8316 }
8317
8318 rc = drxj_dap_write_reg16(dev_addr, QAM_LC_MODE__A, QAM_LC_MODE__PRE, 0);
8319 if (rc != 0) {
8320 pr_err("error %d\n", rc);
8321 goto rw_error;
8322 }
8323 rc = drxj_dap_write_reg16(dev_addr, QAM_LC_RATE_LIMIT__A, 3, 0);
8324 if (rc != 0) {
8325 pr_err("error %d\n", rc);
8326 goto rw_error;
8327 }
8328 rc = drxj_dap_write_reg16(dev_addr, QAM_LC_LPF_FACTORP__A, 4, 0);
8329 if (rc != 0) {
8330 pr_err("error %d\n", rc);
8331 goto rw_error;
8332 }
8333 rc = drxj_dap_write_reg16(dev_addr, QAM_LC_LPF_FACTORI__A, 4, 0);
8334 if (rc != 0) {
8335 pr_err("error %d\n", rc);
8336 goto rw_error;
8337 }
8338 rc = drxj_dap_write_reg16(dev_addr, QAM_LC_MODE__A, 7, 0);
8339 if (rc != 0) {
8340 pr_err("error %d\n", rc);
8341 goto rw_error;
8342 }
8343 rc = drxj_dap_write_reg16(dev_addr, QAM_LC_QUAL_TAB0__A, 1, 0);
8344 if (rc != 0) {
8345 pr_err("error %d\n", rc);
8346 goto rw_error;
8347 }
8348 rc = drxj_dap_write_reg16(dev_addr, QAM_LC_QUAL_TAB1__A, 1, 0);
8349 if (rc != 0) {
8350 pr_err("error %d\n", rc);
8351 goto rw_error;
8352 }
8353 rc = drxj_dap_write_reg16(dev_addr, QAM_LC_QUAL_TAB2__A, 1, 0);
8354 if (rc != 0) {
8355 pr_err("error %d\n", rc);
8356 goto rw_error;
8357 }
8358 rc = drxj_dap_write_reg16(dev_addr, QAM_LC_QUAL_TAB3__A, 1, 0);
8359 if (rc != 0) {
8360 pr_err("error %d\n", rc);
8361 goto rw_error;
8362 }
8363 rc = drxj_dap_write_reg16(dev_addr, QAM_LC_QUAL_TAB4__A, 2, 0);
8364 if (rc != 0) {
8365 pr_err("error %d\n", rc);
8366 goto rw_error;
8367 }
8368 rc = drxj_dap_write_reg16(dev_addr, QAM_LC_QUAL_TAB5__A, 2, 0);
8369 if (rc != 0) {
8370 pr_err("error %d\n", rc);
8371 goto rw_error;
8372 }
8373 rc = drxj_dap_write_reg16(dev_addr, QAM_LC_QUAL_TAB6__A, 2, 0);
8374 if (rc != 0) {
8375 pr_err("error %d\n", rc);
8376 goto rw_error;
8377 }
8378 rc = drxj_dap_write_reg16(dev_addr, QAM_LC_QUAL_TAB8__A, 2, 0);
8379 if (rc != 0) {
8380 pr_err("error %d\n", rc);
8381 goto rw_error;
8382 }
8383 rc = drxj_dap_write_reg16(dev_addr, QAM_LC_QUAL_TAB9__A, 2, 0);
8384 if (rc != 0) {
8385 pr_err("error %d\n", rc);
8386 goto rw_error;
8387 }
8388 rc = drxj_dap_write_reg16(dev_addr, QAM_LC_QUAL_TAB10__A, 2, 0);
8389 if (rc != 0) {
8390 pr_err("error %d\n", rc);
8391 goto rw_error;
8392 }
8393 rc = drxj_dap_write_reg16(dev_addr, QAM_LC_QUAL_TAB12__A, 2, 0);
8394 if (rc != 0) {
8395 pr_err("error %d\n", rc);
8396 goto rw_error;
8397 }
8398 rc = drxj_dap_write_reg16(dev_addr, QAM_LC_QUAL_TAB15__A, 3, 0);
8399 if (rc != 0) {
8400 pr_err("error %d\n", rc);
8401 goto rw_error;
8402 }
8403 rc = drxj_dap_write_reg16(dev_addr, QAM_LC_QUAL_TAB16__A, 3, 0);
8404 if (rc != 0) {
8405 pr_err("error %d\n", rc);
8406 goto rw_error;
8407 }
8408 rc = drxj_dap_write_reg16(dev_addr, QAM_LC_QUAL_TAB20__A, 4, 0);
8409 if (rc != 0) {
8410 pr_err("error %d\n", rc);
8411 goto rw_error;
8412 }
8413 rc = drxj_dap_write_reg16(dev_addr, QAM_LC_QUAL_TAB25__A, 4, 0);
8414 if (rc != 0) {
8415 pr_err("error %d\n", rc);
8416 goto rw_error;
8417 }
8418
8419 rc = drxj_dap_write_reg16(dev_addr, IQM_FS_ADJ_SEL__A, 1, 0);
8420 if (rc != 0) {
8421 pr_err("error %d\n", rc);
8422 goto rw_error;
8423 }
8424 rc = drxj_dap_write_reg16(dev_addr, IQM_RC_ADJ_SEL__A, 1, 0);
8425 if (rc != 0) {
8426 pr_err("error %d\n", rc);
8427 goto rw_error;
8428 }
8429 rc = drxj_dap_write_reg16(dev_addr, IQM_CF_ADJ_SEL__A, 1, 0);
8430 if (rc != 0) {
8431 pr_err("error %d\n", rc);
8432 goto rw_error;
8433 }
8434 rc = drxj_dap_write_reg16(dev_addr, IQM_CF_POW_MEAS_LEN__A, 0, 0);
8435 if (rc != 0) {
8436 pr_err("error %d\n", rc);
8437 goto rw_error;
8438 }
8439 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_GPIO__A, 0, 0);
8440 if (rc != 0) {
8441 pr_err("error %d\n", rc);
8442 goto rw_error;
8443 }
8444
8445
8446
8447
8448 rc = set_iqm_af(demod, true);
8449 if (rc != 0) {
8450 pr_err("error %d\n", rc);
8451 goto rw_error;
8452 }
8453 rc = adc_synchronization(demod);
8454 if (rc != 0) {
8455 pr_err("error %d\n", rc);
8456 goto rw_error;
8457 }
8458
8459 rc = init_agc(demod);
8460 if (rc != 0) {
8461 pr_err("error %d\n", rc);
8462 goto rw_error;
8463 }
8464 rc = set_agc_if(demod, &(ext_attr->qam_if_agc_cfg), false);
8465 if (rc != 0) {
8466 pr_err("error %d\n", rc);
8467 goto rw_error;
8468 }
8469 rc = set_agc_rf(demod, &(ext_attr->qam_rf_agc_cfg), false);
8470 if (rc != 0) {
8471 pr_err("error %d\n", rc);
8472 goto rw_error;
8473 }
8474 {
8475
8476
8477 struct drxj_cfg_afe_gain qam_pga_cfg = { DRX_STANDARD_ITU_B, 0 };
8478
8479 qam_pga_cfg.gain = ext_attr->qam_pga_cfg;
8480 rc = ctrl_set_cfg_afe_gain(demod, &qam_pga_cfg);
8481 if (rc != 0) {
8482 pr_err("error %d\n", rc);
8483 goto rw_error;
8484 }
8485 }
8486 rc = ctrl_set_cfg_pre_saw(demod, &(ext_attr->qam_pre_saw_cfg));
8487 if (rc != 0) {
8488 pr_err("error %d\n", rc);
8489 goto rw_error;
8490 }
8491 }
8492
8493 if ((op & QAM_SET_OP_ALL) || (op & QAM_SET_OP_CONSTELLATION)) {
8494 if (ext_attr->standard == DRX_STANDARD_ITU_A) {
8495 rc = drxdap_fasi_write_block(dev_addr, IQM_CF_TAP_RE0__A, sizeof(qam_a_taps), ((u8 *)qam_a_taps), 0);
8496 if (rc != 0) {
8497 pr_err("error %d\n", rc);
8498 goto rw_error;
8499 }
8500 rc = drxdap_fasi_write_block(dev_addr, IQM_CF_TAP_IM0__A, sizeof(qam_a_taps), ((u8 *)qam_a_taps), 0);
8501 if (rc != 0) {
8502 pr_err("error %d\n", rc);
8503 goto rw_error;
8504 }
8505 } else if (ext_attr->standard == DRX_STANDARD_ITU_B) {
8506 switch (channel->constellation) {
8507 case DRX_CONSTELLATION_QAM64:
8508 rc = drxdap_fasi_write_block(dev_addr, IQM_CF_TAP_RE0__A, sizeof(qam_b64_taps), ((u8 *)qam_b64_taps), 0);
8509 if (rc != 0) {
8510 pr_err("error %d\n", rc);
8511 goto rw_error;
8512 }
8513 rc = drxdap_fasi_write_block(dev_addr, IQM_CF_TAP_IM0__A, sizeof(qam_b64_taps), ((u8 *)qam_b64_taps), 0);
8514 if (rc != 0) {
8515 pr_err("error %d\n", rc);
8516 goto rw_error;
8517 }
8518 break;
8519 case DRX_CONSTELLATION_QAM256:
8520 rc = drxdap_fasi_write_block(dev_addr, IQM_CF_TAP_RE0__A, sizeof(qam_b256_taps), ((u8 *)qam_b256_taps), 0);
8521 if (rc != 0) {
8522 pr_err("error %d\n", rc);
8523 goto rw_error;
8524 }
8525 rc = drxdap_fasi_write_block(dev_addr, IQM_CF_TAP_IM0__A, sizeof(qam_b256_taps), ((u8 *)qam_b256_taps), 0);
8526 if (rc != 0) {
8527 pr_err("error %d\n", rc);
8528 goto rw_error;
8529 }
8530 break;
8531 default:
8532 return -EIO;
8533 }
8534 } else if (ext_attr->standard == DRX_STANDARD_ITU_C) {
8535 rc = drxdap_fasi_write_block(dev_addr, IQM_CF_TAP_RE0__A, sizeof(qam_c_taps), ((u8 *)qam_c_taps), 0);
8536 if (rc != 0) {
8537 pr_err("error %d\n", rc);
8538 goto rw_error;
8539 }
8540 rc = drxdap_fasi_write_block(dev_addr, IQM_CF_TAP_IM0__A, sizeof(qam_c_taps), ((u8 *)qam_c_taps), 0);
8541 if (rc != 0) {
8542 pr_err("error %d\n", rc);
8543 goto rw_error;
8544 }
8545 }
8546
8547
8548 switch (channel->constellation) {
8549 case DRX_CONSTELLATION_QAM16:
8550 rc = set_qam16(demod);
8551 if (rc != 0) {
8552 pr_err("error %d\n", rc);
8553 goto rw_error;
8554 }
8555 break;
8556 case DRX_CONSTELLATION_QAM32:
8557 rc = set_qam32(demod);
8558 if (rc != 0) {
8559 pr_err("error %d\n", rc);
8560 goto rw_error;
8561 }
8562 break;
8563 case DRX_CONSTELLATION_QAM64:
8564 rc = set_qam64(demod);
8565 if (rc != 0) {
8566 pr_err("error %d\n", rc);
8567 goto rw_error;
8568 }
8569 break;
8570 case DRX_CONSTELLATION_QAM128:
8571 rc = set_qam128(demod);
8572 if (rc != 0) {
8573 pr_err("error %d\n", rc);
8574 goto rw_error;
8575 }
8576 break;
8577 case DRX_CONSTELLATION_QAM256:
8578 rc = set_qam256(demod);
8579 if (rc != 0) {
8580 pr_err("error %d\n", rc);
8581 goto rw_error;
8582 }
8583 break;
8584 default:
8585 return -EIO;
8586 }
8587 }
8588
8589 if ((op & QAM_SET_OP_ALL)) {
8590 rc = drxj_dap_write_reg16(dev_addr, IQM_CF_SCALE_SH__A, 0, 0);
8591 if (rc != 0) {
8592 pr_err("error %d\n", rc);
8593 goto rw_error;
8594 }
8595
8596
8597 rc = set_mpegtei_handling(demod);
8598 if (rc != 0) {
8599 pr_err("error %d\n", rc);
8600 goto rw_error;
8601 }
8602 rc = bit_reverse_mpeg_output(demod);
8603 if (rc != 0) {
8604 pr_err("error %d\n", rc);
8605 goto rw_error;
8606 }
8607 rc = set_mpeg_start_width(demod);
8608 if (rc != 0) {
8609 pr_err("error %d\n", rc);
8610 goto rw_error;
8611 }
8612 {
8613
8614
8615 struct drx_cfg_mpeg_output cfg_mpeg_output;
8616
8617 memcpy(&cfg_mpeg_output, &common_attr->mpeg_cfg, sizeof(cfg_mpeg_output));
8618 cfg_mpeg_output.enable_mpeg_output = true;
8619
8620 rc = ctrl_set_cfg_mpeg_output(demod, &cfg_mpeg_output);
8621 if (rc != 0) {
8622 pr_err("error %d\n", rc);
8623 goto rw_error;
8624 }
8625 }
8626 }
8627
8628 if ((op & QAM_SET_OP_ALL) || (op & QAM_SET_OP_CONSTELLATION)) {
8629
8630
8631 cmd_scu.command = SCU_RAM_COMMAND_STANDARD_QAM |
8632 SCU_RAM_COMMAND_CMD_DEMOD_START;
8633 cmd_scu.parameter_len = 0;
8634 cmd_scu.result_len = 1;
8635 cmd_scu.parameter = NULL;
8636 cmd_scu.result = &cmd_result;
8637 rc = scu_command(dev_addr, &cmd_scu);
8638 if (rc != 0) {
8639 pr_err("error %d\n", rc);
8640 goto rw_error;
8641 }
8642 }
8643
8644 rc = drxj_dap_write_reg16(dev_addr, IQM_COMM_EXEC__A, IQM_COMM_EXEC_ACTIVE, 0);
8645 if (rc != 0) {
8646 pr_err("error %d\n", rc);
8647 goto rw_error;
8648 }
8649 rc = drxj_dap_write_reg16(dev_addr, QAM_COMM_EXEC__A, QAM_COMM_EXEC_ACTIVE, 0);
8650 if (rc != 0) {
8651 pr_err("error %d\n", rc);
8652 goto rw_error;
8653 }
8654 rc = drxj_dap_write_reg16(dev_addr, FEC_COMM_EXEC__A, FEC_COMM_EXEC_ACTIVE, 0);
8655 if (rc != 0) {
8656 pr_err("error %d\n", rc);
8657 goto rw_error;
8658 }
8659
8660 return 0;
8661rw_error:
8662 return rc;
8663}
8664
8665
8666static int ctrl_get_qam_sig_quality(struct drx_demod_instance *demod);
8667
8668static int qam_flip_spec(struct drx_demod_instance *demod, struct drx_channel *channel)
8669{
8670 struct i2c_device_addr *dev_addr = demod->my_i2c_dev_addr;
8671 struct drxj_data *ext_attr = demod->my_ext_attr;
8672 int rc;
8673 u32 iqm_fs_rate_ofs = 0;
8674 u32 iqm_fs_rate_lo = 0;
8675 u16 qam_ctl_ena = 0;
8676 u16 data = 0;
8677 u16 equ_mode = 0;
8678 u16 fsm_state = 0;
8679 int i = 0;
8680 int ofsofs = 0;
8681
8682
8683 rc = drxj_dap_read_reg16(dev_addr, SCU_RAM_QAM_CTL_ENA__A, &qam_ctl_ena, 0);
8684 if (rc != 0) {
8685 pr_err("error %d\n", rc);
8686 goto rw_error;
8687 }
8688 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_CTL_ENA__A, qam_ctl_ena & ~(SCU_RAM_QAM_CTL_ENA_ACQ__M | SCU_RAM_QAM_CTL_ENA_EQU__M | SCU_RAM_QAM_CTL_ENA_LC__M), 0);
8689 if (rc != 0) {
8690 pr_err("error %d\n", rc);
8691 goto rw_error;
8692 }
8693
8694
8695 rc = drxj_dap_write_reg16(dev_addr, QAM_LC_CF__A, 0, 0);
8696 if (rc != 0) {
8697 pr_err("error %d\n", rc);
8698 goto rw_error;
8699 }
8700 rc = drxj_dap_write_reg16(dev_addr, QAM_LC_CF1__A, 0, 0);
8701 if (rc != 0) {
8702 pr_err("error %d\n", rc);
8703 goto rw_error;
8704 }
8705
8706 rc = drxj_dap_atomic_read_reg32(dev_addr, IQM_FS_RATE_OFS_LO__A, &iqm_fs_rate_ofs, 0);
8707 if (rc != 0) {
8708 pr_err("error %d\n", rc);
8709 goto rw_error;
8710 }
8711 rc = drxj_dap_atomic_read_reg32(dev_addr, IQM_FS_RATE_LO__A, &iqm_fs_rate_lo, 0);
8712 if (rc != 0) {
8713 pr_err("error %d\n", rc);
8714 goto rw_error;
8715 }
8716 ofsofs = iqm_fs_rate_lo - iqm_fs_rate_ofs;
8717 iqm_fs_rate_ofs = ~iqm_fs_rate_ofs + 1;
8718 iqm_fs_rate_ofs -= 2 * ofsofs;
8719
8720
8721 rc = drxj_dap_read_reg16(dev_addr, QAM_DQ_MODE__A, &data, 0);
8722 if (rc != 0) {
8723 pr_err("error %d\n", rc);
8724 goto rw_error;
8725 }
8726 data = (data & 0xfff9);
8727 rc = drxj_dap_write_reg16(dev_addr, QAM_DQ_MODE__A, data, 0);
8728 if (rc != 0) {
8729 pr_err("error %d\n", rc);
8730 goto rw_error;
8731 }
8732 rc = drxj_dap_write_reg16(dev_addr, QAM_FQ_MODE__A, data, 0);
8733 if (rc != 0) {
8734 pr_err("error %d\n", rc);
8735 goto rw_error;
8736 }
8737
8738
8739 rc = drxj_dap_write_reg16(dev_addr, QAM_LC_CI__A, 0, 0);
8740 if (rc != 0) {
8741 pr_err("error %d\n", rc);
8742 goto rw_error;
8743 }
8744 rc = drxj_dap_write_reg16(dev_addr, QAM_LC_EP__A, 0, 0);
8745 if (rc != 0) {
8746 pr_err("error %d\n", rc);
8747 goto rw_error;
8748 }
8749 rc = drxj_dap_write_reg16(dev_addr, QAM_FQ_LA_FACTOR__A, 0, 0);
8750 if (rc != 0) {
8751 pr_err("error %d\n", rc);
8752 goto rw_error;
8753 }
8754
8755
8756 rc = drxdap_fasi_write_reg32(dev_addr, IQM_FS_RATE_OFS_LO__A, iqm_fs_rate_ofs, 0);
8757 if (rc != 0) {
8758 pr_err("error %d\n", rc);
8759 goto rw_error;
8760 }
8761 ext_attr->iqm_fs_rate_ofs = iqm_fs_rate_ofs;
8762 ext_attr->pos_image = (ext_attr->pos_image) ? false : true;
8763
8764
8765 rc = drxj_dap_read_reg16(dev_addr, QAM_DQ_MODE__A, &data, 0);
8766 if (rc != 0) {
8767 pr_err("error %d\n", rc);
8768 goto rw_error;
8769 }
8770 equ_mode = data;
8771 data = (data & 0xfff9);
8772 rc = drxj_dap_write_reg16(dev_addr, QAM_DQ_MODE__A, data, 0);
8773 if (rc != 0) {
8774 pr_err("error %d\n", rc);
8775 goto rw_error;
8776 }
8777 rc = drxj_dap_write_reg16(dev_addr, QAM_FQ_MODE__A, data, 0);
8778 if (rc != 0) {
8779 pr_err("error %d\n", rc);
8780 goto rw_error;
8781 }
8782
8783 for (i = 0; i < 28; i++) {
8784 rc = drxj_dap_read_reg16(dev_addr, QAM_DQ_TAP_IM_EL0__A + (2 * i), &data, 0);
8785 if (rc != 0) {
8786 pr_err("error %d\n", rc);
8787 goto rw_error;
8788 }
8789 rc = drxj_dap_write_reg16(dev_addr, QAM_DQ_TAP_IM_EL0__A + (2 * i), -data, 0);
8790 if (rc != 0) {
8791 pr_err("error %d\n", rc);
8792 goto rw_error;
8793 }
8794 }
8795
8796 for (i = 0; i < 24; i++) {
8797 rc = drxj_dap_read_reg16(dev_addr, QAM_FQ_TAP_IM_EL0__A + (2 * i), &data, 0);
8798 if (rc != 0) {
8799 pr_err("error %d\n", rc);
8800 goto rw_error;
8801 }
8802 rc = drxj_dap_write_reg16(dev_addr, QAM_FQ_TAP_IM_EL0__A + (2 * i), -data, 0);
8803 if (rc != 0) {
8804 pr_err("error %d\n", rc);
8805 goto rw_error;
8806 }
8807 }
8808
8809 data = equ_mode;
8810 rc = drxj_dap_write_reg16(dev_addr, QAM_DQ_MODE__A, data, 0);
8811 if (rc != 0) {
8812 pr_err("error %d\n", rc);
8813 goto rw_error;
8814 }
8815 rc = drxj_dap_write_reg16(dev_addr, QAM_FQ_MODE__A, data, 0);
8816 if (rc != 0) {
8817 pr_err("error %d\n", rc);
8818 goto rw_error;
8819 }
8820
8821 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_FSM_STATE_TGT__A, 4, 0);
8822 if (rc != 0) {
8823 pr_err("error %d\n", rc);
8824 goto rw_error;
8825 }
8826
8827 i = 0;
8828 while ((fsm_state != 4) && (i++ < 100)) {
8829 rc = drxj_dap_read_reg16(dev_addr, SCU_RAM_QAM_FSM_STATE__A, &fsm_state, 0);
8830 if (rc != 0) {
8831 pr_err("error %d\n", rc);
8832 goto rw_error;
8833 }
8834 }
8835 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_QAM_CTL_ENA__A, (qam_ctl_ena | 0x0016), 0);
8836 if (rc != 0) {
8837 pr_err("error %d\n", rc);
8838 goto rw_error;
8839 }
8840
8841 return 0;
8842rw_error:
8843 return rc;
8844
8845}
8846
8847#define NO_LOCK 0x0
8848#define DEMOD_LOCKED 0x1
8849#define SYNC_FLIPPED 0x2
8850#define SPEC_MIRRORED 0x4
8851
8852
8853
8854
8855
8856
8857
8858
8859
8860static int
8861qam64auto(struct drx_demod_instance *demod,
8862 struct drx_channel *channel,
8863 s32 tuner_freq_offset, enum drx_lock_status *lock_status)
8864{
8865 struct drxj_data *ext_attr = demod->my_ext_attr;
8866 struct i2c_device_addr *dev_addr = demod->my_i2c_dev_addr;
8867 struct drx39xxj_state *state = dev_addr->user_data;
8868 struct dtv_frontend_properties *p = &state->frontend.dtv_property_cache;
8869 int rc;
8870 u32 lck_state = NO_LOCK;
8871 u32 start_time = 0;
8872 u32 d_locked_time = 0;
8873 u32 timeout_ofs = 0;
8874 u16 data = 0;
8875
8876
8877 *lock_status = DRX_NOT_LOCKED;
8878 start_time = jiffies_to_msecs(jiffies);
8879 lck_state = NO_LOCK;
8880 do {
8881 rc = ctrl_lock_status(demod, lock_status);
8882 if (rc != 0) {
8883 pr_err("error %d\n", rc);
8884 goto rw_error;
8885 }
8886
8887 switch (lck_state) {
8888 case NO_LOCK:
8889 if (*lock_status == DRXJ_DEMOD_LOCK) {
8890 rc = ctrl_get_qam_sig_quality(demod);
8891 if (rc != 0) {
8892 pr_err("error %d\n", rc);
8893 goto rw_error;
8894 }
8895 if (p->cnr.stat[0].svalue > 20800) {
8896 lck_state = DEMOD_LOCKED;
8897
8898 timeout_ofs += DRXJ_QAM_DEMOD_LOCK_EXT_WAITTIME;
8899 d_locked_time = jiffies_to_msecs(jiffies);
8900 }
8901 }
8902 break;
8903 case DEMOD_LOCKED:
8904 if ((*lock_status == DRXJ_DEMOD_LOCK) &&
8905 ((jiffies_to_msecs(jiffies) - d_locked_time) >
8906 DRXJ_QAM_FEC_LOCK_WAITTIME)) {
8907 rc = drxj_dap_read_reg16(demod->my_i2c_dev_addr, QAM_SY_TIMEOUT__A, &data, 0);
8908 if (rc != 0) {
8909 pr_err("error %d\n", rc);
8910 goto rw_error;
8911 }
8912 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr, QAM_SY_TIMEOUT__A, data | 0x1, 0);
8913 if (rc != 0) {
8914 pr_err("error %d\n", rc);
8915 goto rw_error;
8916 }
8917 lck_state = SYNC_FLIPPED;
8918 msleep(10);
8919 }
8920 break;
8921 case SYNC_FLIPPED:
8922 if (*lock_status == DRXJ_DEMOD_LOCK) {
8923 if (channel->mirror == DRX_MIRROR_AUTO) {
8924
8925 rc = drxj_dap_read_reg16(demod->my_i2c_dev_addr, QAM_SY_TIMEOUT__A, &data, 0);
8926 if (rc != 0) {
8927 pr_err("error %d\n", rc);
8928 goto rw_error;
8929 }
8930 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr, QAM_SY_TIMEOUT__A, data & 0xFFFE, 0);
8931 if (rc != 0) {
8932 pr_err("error %d\n", rc);
8933 goto rw_error;
8934 }
8935
8936 ext_attr->mirror = DRX_MIRROR_YES;
8937 rc = qam_flip_spec(demod, channel);
8938 if (rc != 0) {
8939 pr_err("error %d\n", rc);
8940 goto rw_error;
8941 }
8942 lck_state = SPEC_MIRRORED;
8943
8944 start_time = d_locked_time =
8945 jiffies_to_msecs(jiffies);
8946 timeout_ofs = 0;
8947 } else {
8948
8949 start_time =
8950 jiffies_to_msecs(jiffies) -
8951 DRXJ_QAM_MAX_WAITTIME - timeout_ofs;
8952 }
8953 }
8954 break;
8955 case SPEC_MIRRORED:
8956 if ((*lock_status == DRXJ_DEMOD_LOCK) &&
8957 ((jiffies_to_msecs(jiffies) - d_locked_time) >
8958 DRXJ_QAM_FEC_LOCK_WAITTIME)) {
8959 rc = ctrl_get_qam_sig_quality(demod);
8960 if (rc != 0) {
8961 pr_err("error %d\n", rc);
8962 goto rw_error;
8963 }
8964 if (p->cnr.stat[0].svalue > 20800) {
8965 rc = drxj_dap_read_reg16(demod->my_i2c_dev_addr, QAM_SY_TIMEOUT__A, &data, 0);
8966 if (rc != 0) {
8967 pr_err("error %d\n", rc);
8968 goto rw_error;
8969 }
8970 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr, QAM_SY_TIMEOUT__A, data | 0x1, 0);
8971 if (rc != 0) {
8972 pr_err("error %d\n", rc);
8973 goto rw_error;
8974 }
8975
8976 start_time =
8977 jiffies_to_msecs(jiffies) -
8978 DRXJ_QAM_MAX_WAITTIME - timeout_ofs;
8979 }
8980 }
8981 break;
8982 default:
8983 break;
8984 }
8985 msleep(10);
8986 } while
8987 ((*lock_status != DRX_LOCKED) &&
8988 (*lock_status != DRX_NEVER_LOCK) &&
8989 ((jiffies_to_msecs(jiffies) - start_time) <
8990 (DRXJ_QAM_MAX_WAITTIME + timeout_ofs))
8991 );
8992
8993
8994 return 0;
8995rw_error:
8996 return rc;
8997}
8998
8999
9000
9001
9002
9003
9004
9005
9006
9007
9008static int
9009qam256auto(struct drx_demod_instance *demod,
9010 struct drx_channel *channel,
9011 s32 tuner_freq_offset, enum drx_lock_status *lock_status)
9012{
9013 struct drxj_data *ext_attr = demod->my_ext_attr;
9014 struct i2c_device_addr *dev_addr = demod->my_i2c_dev_addr;
9015 struct drx39xxj_state *state = dev_addr->user_data;
9016 struct dtv_frontend_properties *p = &state->frontend.dtv_property_cache;
9017 int rc;
9018 u32 lck_state = NO_LOCK;
9019 u32 start_time = 0;
9020 u32 d_locked_time = 0;
9021 u32 timeout_ofs = DRXJ_QAM_DEMOD_LOCK_EXT_WAITTIME;
9022
9023
9024 *lock_status = DRX_NOT_LOCKED;
9025 start_time = jiffies_to_msecs(jiffies);
9026 lck_state = NO_LOCK;
9027 do {
9028 rc = ctrl_lock_status(demod, lock_status);
9029 if (rc != 0) {
9030 pr_err("error %d\n", rc);
9031 goto rw_error;
9032 }
9033 switch (lck_state) {
9034 case NO_LOCK:
9035 if (*lock_status == DRXJ_DEMOD_LOCK) {
9036 rc = ctrl_get_qam_sig_quality(demod);
9037 if (rc != 0) {
9038 pr_err("error %d\n", rc);
9039 goto rw_error;
9040 }
9041 if (p->cnr.stat[0].svalue > 26800) {
9042 lck_state = DEMOD_LOCKED;
9043 timeout_ofs += DRXJ_QAM_DEMOD_LOCK_EXT_WAITTIME;
9044 d_locked_time = jiffies_to_msecs(jiffies);
9045 }
9046 }
9047 break;
9048 case DEMOD_LOCKED:
9049 if (*lock_status == DRXJ_DEMOD_LOCK) {
9050 if ((channel->mirror == DRX_MIRROR_AUTO) &&
9051 ((jiffies_to_msecs(jiffies) - d_locked_time) >
9052 DRXJ_QAM_FEC_LOCK_WAITTIME)) {
9053 ext_attr->mirror = DRX_MIRROR_YES;
9054 rc = qam_flip_spec(demod, channel);
9055 if (rc != 0) {
9056 pr_err("error %d\n", rc);
9057 goto rw_error;
9058 }
9059 lck_state = SPEC_MIRRORED;
9060
9061 start_time = jiffies_to_msecs(jiffies);
9062 timeout_ofs = -DRXJ_QAM_MAX_WAITTIME / 2;
9063 }
9064 }
9065 break;
9066 case SPEC_MIRRORED:
9067 break;
9068 default:
9069 break;
9070 }
9071 msleep(10);
9072 } while
9073 ((*lock_status < DRX_LOCKED) &&
9074 (*lock_status != DRX_NEVER_LOCK) &&
9075 ((jiffies_to_msecs(jiffies) - start_time) <
9076 (DRXJ_QAM_MAX_WAITTIME + timeout_ofs)));
9077
9078 return 0;
9079rw_error:
9080 return rc;
9081}
9082
9083
9084
9085
9086
9087
9088
9089
9090static int
9091set_qam_channel(struct drx_demod_instance *demod,
9092 struct drx_channel *channel, s32 tuner_freq_offset)
9093{
9094 struct drxj_data *ext_attr = NULL;
9095 int rc;
9096 enum drx_lock_status lock_status = DRX_NOT_LOCKED;
9097 bool auto_flag = false;
9098
9099
9100 ext_attr = (struct drxj_data *) demod->my_ext_attr;
9101
9102
9103 switch (channel->constellation) {
9104 case DRX_CONSTELLATION_QAM16:
9105 case DRX_CONSTELLATION_QAM32:
9106 case DRX_CONSTELLATION_QAM128:
9107 return -EINVAL;
9108 case DRX_CONSTELLATION_QAM64:
9109 case DRX_CONSTELLATION_QAM256:
9110 if (ext_attr->standard != DRX_STANDARD_ITU_B)
9111 return -EINVAL;
9112
9113 ext_attr->constellation = channel->constellation;
9114 if (channel->mirror == DRX_MIRROR_AUTO)
9115 ext_attr->mirror = DRX_MIRROR_NO;
9116 else
9117 ext_attr->mirror = channel->mirror;
9118
9119 rc = set_qam(demod, channel, tuner_freq_offset, QAM_SET_OP_ALL);
9120 if (rc != 0) {
9121 pr_err("error %d\n", rc);
9122 goto rw_error;
9123 }
9124
9125 if (channel->constellation == DRX_CONSTELLATION_QAM64)
9126 rc = qam64auto(demod, channel, tuner_freq_offset,
9127 &lock_status);
9128 else
9129 rc = qam256auto(demod, channel, tuner_freq_offset,
9130 &lock_status);
9131 if (rc != 0) {
9132 pr_err("error %d\n", rc);
9133 goto rw_error;
9134 }
9135 break;
9136 case DRX_CONSTELLATION_AUTO:
9137 if (ext_attr->standard == DRX_STANDARD_ITU_B) {
9138 u16 qam_ctl_ena = 0;
9139
9140 auto_flag = true;
9141
9142
9143 channel->constellation = DRX_CONSTELLATION_QAM256;
9144 ext_attr->constellation = DRX_CONSTELLATION_QAM256;
9145 if (channel->mirror == DRX_MIRROR_AUTO)
9146 ext_attr->mirror = DRX_MIRROR_NO;
9147 else
9148 ext_attr->mirror = channel->mirror;
9149 rc = set_qam(demod, channel, tuner_freq_offset,
9150 QAM_SET_OP_ALL);
9151 if (rc != 0) {
9152 pr_err("error %d\n", rc);
9153 goto rw_error;
9154 }
9155 rc = qam256auto(demod, channel, tuner_freq_offset,
9156 &lock_status);
9157 if (rc != 0) {
9158 pr_err("error %d\n", rc);
9159 goto rw_error;
9160 }
9161
9162 if (lock_status >= DRX_LOCKED) {
9163 channel->constellation = DRX_CONSTELLATION_AUTO;
9164 break;
9165 }
9166
9167
9168 channel->constellation = DRX_CONSTELLATION_QAM64;
9169 ext_attr->constellation = DRX_CONSTELLATION_QAM64;
9170 if (channel->mirror == DRX_MIRROR_AUTO)
9171 ext_attr->mirror = DRX_MIRROR_NO;
9172 else
9173 ext_attr->mirror = channel->mirror;
9174
9175 rc = drxj_dap_read_reg16(demod->my_i2c_dev_addr,
9176 SCU_RAM_QAM_CTL_ENA__A,
9177 &qam_ctl_ena, 0);
9178 if (rc != 0) {
9179 pr_err("error %d\n", rc);
9180 goto rw_error;
9181 }
9182 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr,
9183 SCU_RAM_QAM_CTL_ENA__A,
9184 qam_ctl_ena & ~SCU_RAM_QAM_CTL_ENA_ACQ__M, 0);
9185 if (rc != 0) {
9186 pr_err("error %d\n", rc);
9187 goto rw_error;
9188 }
9189 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr,
9190 SCU_RAM_QAM_FSM_STATE_TGT__A,
9191 0x2, 0);
9192 if (rc != 0) {
9193 pr_err("error %d\n", rc);
9194 goto rw_error;
9195 }
9196
9197 rc = set_qam(demod, channel, tuner_freq_offset,
9198 QAM_SET_OP_CONSTELLATION);
9199 if (rc != 0) {
9200 pr_err("error %d\n", rc);
9201 goto rw_error;
9202 }
9203 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr,
9204 SCU_RAM_QAM_CTL_ENA__A,
9205 qam_ctl_ena, 0);
9206 if (rc != 0) {
9207 pr_err("error %d\n", rc);
9208 goto rw_error;
9209 }
9210
9211 rc = qam64auto(demod, channel, tuner_freq_offset,
9212 &lock_status);
9213 if (rc != 0) {
9214 pr_err("error %d\n", rc);
9215 goto rw_error;
9216 }
9217
9218 channel->constellation = DRX_CONSTELLATION_AUTO;
9219 } else if (ext_attr->standard == DRX_STANDARD_ITU_C) {
9220 u16 qam_ctl_ena = 0;
9221
9222 channel->constellation = DRX_CONSTELLATION_QAM64;
9223 ext_attr->constellation = DRX_CONSTELLATION_QAM64;
9224 auto_flag = true;
9225
9226 if (channel->mirror == DRX_MIRROR_AUTO)
9227 ext_attr->mirror = DRX_MIRROR_NO;
9228 else
9229 ext_attr->mirror = channel->mirror;
9230 rc = drxj_dap_read_reg16(demod->my_i2c_dev_addr,
9231 SCU_RAM_QAM_CTL_ENA__A,
9232 &qam_ctl_ena, 0);
9233 if (rc != 0) {
9234 pr_err("error %d\n", rc);
9235 goto rw_error;
9236 }
9237 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr,
9238 SCU_RAM_QAM_CTL_ENA__A,
9239 qam_ctl_ena & ~SCU_RAM_QAM_CTL_ENA_ACQ__M, 0);
9240 if (rc != 0) {
9241 pr_err("error %d\n", rc);
9242 goto rw_error;
9243 }
9244 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr,
9245 SCU_RAM_QAM_FSM_STATE_TGT__A,
9246 0x2, 0);
9247 if (rc != 0) {
9248 pr_err("error %d\n", rc);
9249 goto rw_error;
9250 }
9251
9252 rc = set_qam(demod, channel, tuner_freq_offset,
9253 QAM_SET_OP_CONSTELLATION);
9254 if (rc != 0) {
9255 pr_err("error %d\n", rc);
9256 goto rw_error;
9257 }
9258 rc = drxj_dap_write_reg16(demod->my_i2c_dev_addr,
9259 SCU_RAM_QAM_CTL_ENA__A,
9260 qam_ctl_ena, 0);
9261 if (rc != 0) {
9262 pr_err("error %d\n", rc);
9263 goto rw_error;
9264 }
9265 rc = qam64auto(demod, channel, tuner_freq_offset,
9266 &lock_status);
9267 if (rc != 0) {
9268 pr_err("error %d\n", rc);
9269 goto rw_error;
9270 }
9271 channel->constellation = DRX_CONSTELLATION_AUTO;
9272 } else {
9273 return -EINVAL;
9274 }
9275 break;
9276 default:
9277 return -EINVAL;
9278 }
9279
9280 return 0;
9281rw_error:
9282
9283 if (auto_flag)
9284 channel->constellation = DRX_CONSTELLATION_AUTO;
9285 return rc;
9286}
9287
9288
9289
9290
9291
9292
9293
9294
9295
9296
9297
9298static int
9299get_qamrs_err_count(struct i2c_device_addr *dev_addr,
9300 struct drxjrs_errors *rs_errors)
9301{
9302 int rc;
9303 u16 nr_bit_errors = 0,
9304 nr_symbol_errors = 0,
9305 nr_packet_errors = 0, nr_failures = 0, nr_snc_par_fail_count = 0;
9306
9307
9308 if (dev_addr == NULL)
9309 return -EINVAL;
9310
9311
9312
9313
9314 rc = drxj_dap_read_reg16(dev_addr, FEC_RS_NR_BIT_ERRORS__A, &nr_bit_errors, 0);
9315 if (rc != 0) {
9316 pr_err("error %d\n", rc);
9317 goto rw_error;
9318 }
9319
9320 rc = drxj_dap_read_reg16(dev_addr, FEC_RS_NR_SYMBOL_ERRORS__A, &nr_symbol_errors, 0);
9321 if (rc != 0) {
9322 pr_err("error %d\n", rc);
9323 goto rw_error;
9324 }
9325
9326 rc = drxj_dap_read_reg16(dev_addr, FEC_RS_NR_PACKET_ERRORS__A, &nr_packet_errors, 0);
9327 if (rc != 0) {
9328 pr_err("error %d\n", rc);
9329 goto rw_error;
9330 }
9331
9332 rc = drxj_dap_read_reg16(dev_addr, FEC_RS_NR_FAILURES__A, &nr_failures, 0);
9333 if (rc != 0) {
9334 pr_err("error %d\n", rc);
9335 goto rw_error;
9336 }
9337
9338 rc = drxj_dap_read_reg16(dev_addr, FEC_OC_SNC_FAIL_COUNT__A, &nr_snc_par_fail_count, 0);
9339 if (rc != 0) {
9340 pr_err("error %d\n", rc);
9341 goto rw_error;
9342 }
9343
9344
9345
9346
9347 rs_errors->nr_bit_errors = nr_bit_errors & FEC_RS_NR_BIT_ERRORS__M;
9348 rs_errors->nr_symbol_errors = nr_symbol_errors & FEC_RS_NR_SYMBOL_ERRORS__M;
9349 rs_errors->nr_packet_errors = nr_packet_errors & FEC_RS_NR_PACKET_ERRORS__M;
9350 rs_errors->nr_failures = nr_failures & FEC_RS_NR_FAILURES__M;
9351 rs_errors->nr_snc_par_fail_count =
9352 nr_snc_par_fail_count & FEC_OC_SNC_FAIL_COUNT__M;
9353
9354 return 0;
9355rw_error:
9356 return rc;
9357}
9358
9359
9360
9361
9362
9363
9364
9365
9366
9367
9368
9369
9370
9371#define DRXJ_AGC_TOP 0x2800
9372#define DRXJ_AGC_SNS 0x1600
9373#define DRXJ_RFAGC_MAX 0x3fff
9374#define DRXJ_RFAGC_MIN 0x800
9375
9376static int get_sig_strength(struct drx_demod_instance *demod, u16 *sig_strength)
9377{
9378 struct i2c_device_addr *dev_addr = demod->my_i2c_dev_addr;
9379 int rc;
9380 u16 rf_gain = 0;
9381 u16 if_gain = 0;
9382 u16 if_agc_sns = 0;
9383 u16 if_agc_top = 0;
9384 u16 rf_agc_max = 0;
9385 u16 rf_agc_min = 0;
9386
9387 rc = drxj_dap_read_reg16(dev_addr, IQM_AF_AGC_IF__A, &if_gain, 0);
9388 if (rc != 0) {
9389 pr_err("error %d\n", rc);
9390 goto rw_error;
9391 }
9392 if_gain &= IQM_AF_AGC_IF__M;
9393 rc = drxj_dap_read_reg16(dev_addr, IQM_AF_AGC_RF__A, &rf_gain, 0);
9394 if (rc != 0) {
9395 pr_err("error %d\n", rc);
9396 goto rw_error;
9397 }
9398 rf_gain &= IQM_AF_AGC_RF__M;
9399
9400 if_agc_sns = DRXJ_AGC_SNS;
9401 if_agc_top = DRXJ_AGC_TOP;
9402 rf_agc_max = DRXJ_RFAGC_MAX;
9403 rf_agc_min = DRXJ_RFAGC_MIN;
9404
9405 if (if_gain > if_agc_top) {
9406 if (rf_gain > rf_agc_max)
9407 *sig_strength = 100;
9408 else if (rf_gain > rf_agc_min) {
9409 if (rf_agc_max == rf_agc_min) {
9410 pr_err("error: rf_agc_max == rf_agc_min\n");
9411 return -EIO;
9412 }
9413 *sig_strength =
9414 75 + 25 * (rf_gain - rf_agc_min) / (rf_agc_max -
9415 rf_agc_min);
9416 } else
9417 *sig_strength = 75;
9418 } else if (if_gain > if_agc_sns) {
9419 if (if_agc_top == if_agc_sns) {
9420 pr_err("error: if_agc_top == if_agc_sns\n");
9421 return -EIO;
9422 }
9423 *sig_strength =
9424 20 + 55 * (if_gain - if_agc_sns) / (if_agc_top - if_agc_sns);
9425 } else {
9426 if (!if_agc_sns) {
9427 pr_err("error: if_agc_sns is zero!\n");
9428 return -EIO;
9429 }
9430 *sig_strength = (20 * if_gain / if_agc_sns);
9431 }
9432
9433 if (*sig_strength <= 7)
9434 *sig_strength = 0;
9435
9436 return 0;
9437rw_error:
9438 return rc;
9439}
9440
9441
9442
9443
9444
9445
9446
9447
9448
9449
9450
9451
9452
9453static int
9454ctrl_get_qam_sig_quality(struct drx_demod_instance *demod)
9455{
9456 struct i2c_device_addr *dev_addr = demod->my_i2c_dev_addr;
9457 struct drxj_data *ext_attr = demod->my_ext_attr;
9458 struct drx39xxj_state *state = dev_addr->user_data;
9459 struct dtv_frontend_properties *p = &state->frontend.dtv_property_cache;
9460 struct drxjrs_errors measuredrs_errors = { 0, 0, 0, 0, 0 };
9461 enum drx_modulation constellation = ext_attr->constellation;
9462 int rc;
9463
9464 u32 pre_bit_err_rs = 0;
9465 u32 post_bit_err_rs = 0;
9466 u32 pkt_errs = 0;
9467 u16 qam_sl_err_power = 0;
9468 u16 qsym_err_vd = 0;
9469 u16 fec_oc_period = 0;
9470 u16 fec_rs_prescale = 0;
9471 u16 fec_rs_period = 0;
9472
9473 u32 rs_bit_cnt = 0;
9474 u32 qam_sl_sig_power = 0;
9475
9476 u32 e = 0;
9477 u32 m = 0;
9478 u32 ber_cnt = 0;
9479
9480 u32 qam_sl_mer = 0;
9481 u32 qam_pre_rs_ber = 0;
9482 u32 qam_post_rs_ber = 0;
9483 u32 qam_vd_ser = 0;
9484 u16 qam_vd_prescale = 0;
9485 u16 qam_vd_period = 0;
9486 u32 vd_bit_cnt = 0;
9487
9488 p->block_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
9489
9490
9491
9492 rc = get_qamrs_err_count(dev_addr, &measuredrs_errors);
9493 if (rc != 0) {
9494 pr_err("error %d\n", rc);
9495 goto rw_error;
9496 }
9497
9498 rc = drxj_dap_read_reg16(dev_addr, QAM_SL_ERR_POWER__A, &qam_sl_err_power, 0);
9499 if (rc != 0) {
9500 pr_err("error %d\n", rc);
9501 goto rw_error;
9502 }
9503
9504 rc = drxj_dap_read_reg16(dev_addr, FEC_OC_SNC_FAIL_PERIOD__A, &fec_oc_period, 0);
9505 if (rc != 0) {
9506 pr_err("error %d\n", rc);
9507 goto rw_error;
9508 }
9509
9510
9511 fec_rs_period = ext_attr->fec_rs_period;
9512 fec_rs_prescale = ext_attr->fec_rs_prescale;
9513 rs_bit_cnt = fec_rs_period * fec_rs_prescale * ext_attr->fec_rs_plen;
9514 qam_vd_period = ext_attr->qam_vd_period;
9515 qam_vd_prescale = ext_attr->qam_vd_prescale;
9516 vd_bit_cnt = qam_vd_period * qam_vd_prescale * ext_attr->fec_vd_plen;
9517
9518
9519 switch (constellation) {
9520 case DRX_CONSTELLATION_QAM16:
9521 qam_sl_sig_power = DRXJ_QAM_SL_SIG_POWER_QAM16 << 2;
9522 break;
9523 case DRX_CONSTELLATION_QAM32:
9524 qam_sl_sig_power = DRXJ_QAM_SL_SIG_POWER_QAM32 << 2;
9525 break;
9526 case DRX_CONSTELLATION_QAM64:
9527 qam_sl_sig_power = DRXJ_QAM_SL_SIG_POWER_QAM64 << 2;
9528 break;
9529 case DRX_CONSTELLATION_QAM128:
9530 qam_sl_sig_power = DRXJ_QAM_SL_SIG_POWER_QAM128 << 2;
9531 break;
9532 case DRX_CONSTELLATION_QAM256:
9533 qam_sl_sig_power = DRXJ_QAM_SL_SIG_POWER_QAM256 << 2;
9534 break;
9535 default:
9536 return -EIO;
9537 }
9538
9539
9540
9541
9542
9543
9544
9545 if (qam_sl_err_power == 0)
9546 qam_sl_mer = 0;
9547 else
9548 qam_sl_mer = log1_times100(qam_sl_sig_power) - log1_times100((u32)qam_sl_err_power);
9549
9550
9551
9552
9553
9554
9555
9556
9557 rc = drxj_dap_read_reg16(dev_addr, QAM_VD_NR_QSYM_ERRORS__A, &qsym_err_vd, 0);
9558 if (rc != 0) {
9559 pr_err("error %d\n", rc);
9560 goto rw_error;
9561 }
9562
9563
9564 e = (qsym_err_vd & QAM_VD_NR_QSYM_ERRORS_EXP__M) >>
9565 QAM_VD_NR_QSYM_ERRORS_EXP__B;
9566 m = (qsym_err_vd & QAM_VD_NR_SYMBOL_ERRORS_FIXED_MANT__M) >>
9567 QAM_VD_NR_SYMBOL_ERRORS_FIXED_MANT__B;
9568
9569 if ((m << e) >> 3 > 549752)
9570 qam_vd_ser = 500000 * vd_bit_cnt * ((e > 2) ? 1 : 8) / 8;
9571 else
9572 qam_vd_ser = m << ((e > 2) ? (e - 3) : e);
9573
9574
9575
9576
9577
9578
9579
9580 pre_bit_err_rs = (u32) measuredrs_errors.nr_bit_errors;
9581 pkt_errs = post_bit_err_rs = (u32) measuredrs_errors.nr_snc_par_fail_count;
9582
9583
9584
9585 e = (pre_bit_err_rs & FEC_RS_NR_BIT_ERRORS_EXP__M) >>
9586 FEC_RS_NR_BIT_ERRORS_EXP__B;
9587 m = (pre_bit_err_rs & FEC_RS_NR_BIT_ERRORS_FIXED_MANT__M) >>
9588 FEC_RS_NR_BIT_ERRORS_FIXED_MANT__B;
9589
9590 ber_cnt = m << e;
9591
9592
9593 if (m > (rs_bit_cnt >> (e + 1)) || (rs_bit_cnt >> e) == 0)
9594 qam_pre_rs_ber = 500000 * rs_bit_cnt >> e;
9595 else
9596 qam_pre_rs_ber = ber_cnt;
9597
9598
9599
9600
9601
9602
9603
9604
9605
9606
9607
9608
9609 if (!fec_oc_period) {
9610 qam_post_rs_ber = 0xFFFFFFFF;
9611 } else {
9612 e = post_bit_err_rs * 742686;
9613 m = fec_oc_period * 100;
9614 qam_post_rs_ber = e / m;
9615 }
9616
9617
9618 p->pre_bit_count.stat[0].scale = FE_SCALE_COUNTER;
9619 p->post_bit_count.stat[0].scale = FE_SCALE_COUNTER;
9620 p->pre_bit_error.stat[0].scale = FE_SCALE_COUNTER;
9621 p->post_bit_error.stat[0].scale = FE_SCALE_COUNTER;
9622 p->block_error.stat[0].scale = FE_SCALE_COUNTER;
9623 p->cnr.stat[0].scale = FE_SCALE_DECIBEL;
9624
9625 p->cnr.stat[0].svalue = ((u16) qam_sl_mer) * 100;
9626 if (ext_attr->standard == DRX_STANDARD_ITU_B) {
9627 p->pre_bit_error.stat[0].uvalue += qam_vd_ser;
9628 p->pre_bit_count.stat[0].uvalue += vd_bit_cnt * ((e > 2) ? 1 : 8) / 8;
9629 } else {
9630 p->pre_bit_error.stat[0].uvalue += qam_pre_rs_ber;
9631 p->pre_bit_count.stat[0].uvalue += rs_bit_cnt >> e;
9632 }
9633
9634 p->post_bit_error.stat[0].uvalue += qam_post_rs_ber;
9635 p->post_bit_count.stat[0].uvalue += rs_bit_cnt >> e;
9636
9637 p->block_error.stat[0].uvalue += pkt_errs;
9638
9639#ifdef DRXJ_SIGNAL_ACCUM_ERR
9640 rc = get_acc_pkt_err(demod, &sig_quality->packet_error);
9641 if (rc != 0) {
9642 pr_err("error %d\n", rc);
9643 goto rw_error;
9644 }
9645#endif
9646
9647 return 0;
9648rw_error:
9649 p->pre_bit_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
9650 p->post_bit_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
9651 p->pre_bit_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
9652 p->post_bit_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
9653 p->block_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
9654 p->cnr.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
9655
9656 return rc;
9657}
9658
9659#endif
9660
9661
9662
9663
9664
9665
9666
9667
9668
9669
9670
9671
9672
9673
9674
9675
9676
9677
9678
9679
9680
9681
9682
9683
9684
9685
9686
9687
9688
9689
9690
9691
9692
9693
9694
9695
9696
9697
9698
9699
9700
9701
9702
9703
9704
9705
9706
9707
9708
9709
9710
9711
9712
9713
9714
9715
9716
9717
9718
9719
9720
9721
9722
9723
9724
9725
9726
9727
9728
9729
9730
9731
9732
9733
9734
9735
9736
9737
9738static int
9739power_down_atv(struct drx_demod_instance *demod, enum drx_standard standard, bool primary)
9740{
9741 struct i2c_device_addr *dev_addr = demod->my_i2c_dev_addr;
9742 struct drxjscu_cmd cmd_scu = { 0,
9743 0,
9744 0,
9745 NULL,
9746 NULL
9747 };
9748 int rc;
9749 u16 cmd_result = 0;
9750
9751
9752
9753
9754 cmd_scu.command = SCU_RAM_COMMAND_STANDARD_ATV |
9755 SCU_RAM_COMMAND_CMD_DEMOD_STOP;
9756 cmd_scu.parameter_len = 0;
9757 cmd_scu.result_len = 1;
9758 cmd_scu.parameter = NULL;
9759 cmd_scu.result = &cmd_result;
9760 rc = scu_command(dev_addr, &cmd_scu);
9761 if (rc != 0) {
9762 pr_err("error %d\n", rc);
9763 goto rw_error;
9764 }
9765
9766 rc = drxj_dap_write_reg16(dev_addr, ATV_TOP_STDBY__A, (ATV_TOP_STDBY_SIF_STDBY_STANDBY & (~ATV_TOP_STDBY_CVBS_STDBY_A2_ACTIVE)), 0);
9767 if (rc != 0) {
9768 pr_err("error %d\n", rc);
9769 goto rw_error;
9770 }
9771
9772 rc = drxj_dap_write_reg16(dev_addr, ATV_COMM_EXEC__A, ATV_COMM_EXEC_STOP, 0);
9773 if (rc != 0) {
9774 pr_err("error %d\n", rc);
9775 goto rw_error;
9776 }
9777 if (primary) {
9778 rc = drxj_dap_write_reg16(dev_addr, IQM_COMM_EXEC__A, IQM_COMM_EXEC_STOP, 0);
9779 if (rc != 0) {
9780 pr_err("error %d\n", rc);
9781 goto rw_error;
9782 }
9783 rc = set_iqm_af(demod, false);
9784 if (rc != 0) {
9785 pr_err("error %d\n", rc);
9786 goto rw_error;
9787 }
9788 } else {
9789 rc = drxj_dap_write_reg16(dev_addr, IQM_FS_COMM_EXEC__A, IQM_FS_COMM_EXEC_STOP, 0);
9790 if (rc != 0) {
9791 pr_err("error %d\n", rc);
9792 goto rw_error;
9793 }
9794 rc = drxj_dap_write_reg16(dev_addr, IQM_FD_COMM_EXEC__A, IQM_FD_COMM_EXEC_STOP, 0);
9795 if (rc != 0) {
9796 pr_err("error %d\n", rc);
9797 goto rw_error;
9798 }
9799 rc = drxj_dap_write_reg16(dev_addr, IQM_RC_COMM_EXEC__A, IQM_RC_COMM_EXEC_STOP, 0);
9800 if (rc != 0) {
9801 pr_err("error %d\n", rc);
9802 goto rw_error;
9803 }
9804 rc = drxj_dap_write_reg16(dev_addr, IQM_RT_COMM_EXEC__A, IQM_RT_COMM_EXEC_STOP, 0);
9805 if (rc != 0) {
9806 pr_err("error %d\n", rc);
9807 goto rw_error;
9808 }
9809 rc = drxj_dap_write_reg16(dev_addr, IQM_CF_COMM_EXEC__A, IQM_CF_COMM_EXEC_STOP, 0);
9810 if (rc != 0) {
9811 pr_err("error %d\n", rc);
9812 goto rw_error;
9813 }
9814 }
9815 rc = power_down_aud(demod);
9816 if (rc != 0) {
9817 pr_err("error %d\n", rc);
9818 goto rw_error;
9819 }
9820
9821 return 0;
9822rw_error:
9823 return rc;
9824}
9825
9826
9827
9828
9829
9830
9831
9832
9833
9834static int power_down_aud(struct drx_demod_instance *demod)
9835{
9836 struct i2c_device_addr *dev_addr = NULL;
9837 struct drxj_data *ext_attr = NULL;
9838 int rc;
9839
9840 dev_addr = (struct i2c_device_addr *)demod->my_i2c_dev_addr;
9841 ext_attr = (struct drxj_data *) demod->my_ext_attr;
9842
9843 rc = drxj_dap_write_reg16(dev_addr, AUD_COMM_EXEC__A, AUD_COMM_EXEC_STOP, 0);
9844 if (rc != 0) {
9845 pr_err("error %d\n", rc);
9846 goto rw_error;
9847 }
9848
9849 ext_attr->aud_data.audio_is_active = false;
9850
9851 return 0;
9852rw_error:
9853 return rc;
9854}
9855
9856
9857
9858
9859
9860
9861
9862
9863static int set_orx_nsu_aox(struct drx_demod_instance *demod, bool active)
9864{
9865 struct i2c_device_addr *dev_addr = demod->my_i2c_dev_addr;
9866 int rc;
9867 u16 data = 0;
9868
9869
9870 rc = drxj_dap_read_reg16(dev_addr, ORX_NSU_AOX_STDBY_W__A, &data, 0);
9871 if (rc != 0) {
9872 pr_err("error %d\n", rc);
9873 goto rw_error;
9874 }
9875 if (!active)
9876 data &= ((~ORX_NSU_AOX_STDBY_W_STDBYADC_A2_ON) & (~ORX_NSU_AOX_STDBY_W_STDBYAMP_A2_ON) & (~ORX_NSU_AOX_STDBY_W_STDBYBIAS_A2_ON) & (~ORX_NSU_AOX_STDBY_W_STDBYPLL_A2_ON) & (~ORX_NSU_AOX_STDBY_W_STDBYPD_A2_ON) & (~ORX_NSU_AOX_STDBY_W_STDBYTAGC_IF_A2_ON) & (~ORX_NSU_AOX_STDBY_W_STDBYTAGC_RF_A2_ON) & (~ORX_NSU_AOX_STDBY_W_STDBYFLT_A2_ON));
9877 else
9878 data |= (ORX_NSU_AOX_STDBY_W_STDBYADC_A2_ON | ORX_NSU_AOX_STDBY_W_STDBYAMP_A2_ON | ORX_NSU_AOX_STDBY_W_STDBYBIAS_A2_ON | ORX_NSU_AOX_STDBY_W_STDBYPLL_A2_ON | ORX_NSU_AOX_STDBY_W_STDBYPD_A2_ON | ORX_NSU_AOX_STDBY_W_STDBYTAGC_IF_A2_ON | ORX_NSU_AOX_STDBY_W_STDBYTAGC_RF_A2_ON | ORX_NSU_AOX_STDBY_W_STDBYFLT_A2_ON);
9879 rc = drxj_dap_write_reg16(dev_addr, ORX_NSU_AOX_STDBY_W__A, data, 0);
9880 if (rc != 0) {
9881 pr_err("error %d\n", rc);
9882 goto rw_error;
9883 }
9884
9885 return 0;
9886rw_error:
9887 return rc;
9888}
9889
9890
9891
9892
9893
9894
9895
9896
9897
9898
9899
9900
9901
9902
9903
9904
9905
9906
9907#define IMPULSE_COSINE_ALPHA_0_3 {-3, -4, -1, 6, 10, 7, -5, -20, -25, -10, 29, 79, 123, 140}
9908#define IMPULSE_COSINE_ALPHA_0_5 { 2, 0, -2, -2, 2, 5, 2, -10, -20, -14, 20, 74, 125, 145}
9909#define IMPULSE_COSINE_ALPHA_RO_0_5 { 0, 0, 1, 2, 3, 0, -7, -15, -16, 0, 34, 77, 114, 128}
9910
9911
9912#define NYQFILTERLEN 27
9913
9914static int ctrl_set_oob(struct drx_demod_instance *demod, struct drxoob *oob_param)
9915{
9916 int rc;
9917 s32 freq = 0;
9918 struct i2c_device_addr *dev_addr = NULL;
9919 struct drxj_data *ext_attr = NULL;
9920 u16 i = 0;
9921 bool mirror_freq_spect_oob = false;
9922 u16 trk_filter_value = 0;
9923 struct drxjscu_cmd scu_cmd;
9924 u16 set_param_parameters[3];
9925 u16 cmd_result[2] = { 0, 0 };
9926 s16 nyquist_coeffs[4][(NYQFILTERLEN + 1) / 2] = {
9927 IMPULSE_COSINE_ALPHA_0_3,
9928 IMPULSE_COSINE_ALPHA_0_3,
9929 IMPULSE_COSINE_ALPHA_0_5,
9930 IMPULSE_COSINE_ALPHA_RO_0_5
9931 };
9932 u8 mode_val[4] = { 2, 2, 0, 1 };
9933 u8 pfi_coeffs[4][6] = {
9934 {DRXJ_16TO8(-92), DRXJ_16TO8(-108), DRXJ_16TO8(100)},
9935 {DRXJ_16TO8(-64), DRXJ_16TO8(-80), DRXJ_16TO8(80)},
9936 {DRXJ_16TO8(-80), DRXJ_16TO8(-98), DRXJ_16TO8(92)},
9937 {DRXJ_16TO8(-80), DRXJ_16TO8(-98), DRXJ_16TO8(92)}
9938 };
9939 u16 mode_index;
9940
9941 dev_addr = demod->my_i2c_dev_addr;
9942 ext_attr = (struct drxj_data *) demod->my_ext_attr;
9943 mirror_freq_spect_oob = ext_attr->mirror_freq_spect_oob;
9944
9945
9946 if (oob_param == NULL) {
9947
9948 scu_cmd.command = SCU_RAM_COMMAND_STANDARD_OOB
9949 | SCU_RAM_COMMAND_CMD_DEMOD_STOP;
9950 scu_cmd.parameter_len = 0;
9951 scu_cmd.result_len = 1;
9952 scu_cmd.result = cmd_result;
9953 rc = scu_command(dev_addr, &scu_cmd);
9954 if (rc != 0) {
9955 pr_err("error %d\n", rc);
9956 goto rw_error;
9957 }
9958 rc = set_orx_nsu_aox(demod, false);
9959 if (rc != 0) {
9960 pr_err("error %d\n", rc);
9961 goto rw_error;
9962 }
9963 rc = drxj_dap_write_reg16(dev_addr, ORX_COMM_EXEC__A, ORX_COMM_EXEC_STOP, 0);
9964 if (rc != 0) {
9965 pr_err("error %d\n", rc);
9966 goto rw_error;
9967 }
9968
9969 ext_attr->oob_power_on = false;
9970 return 0;
9971 }
9972
9973 freq = oob_param->frequency;
9974 if ((freq < 70000) || (freq > 130000))
9975 return -EIO;
9976 freq = (freq - 50000) / 50;
9977
9978 {
9979 u16 index = 0;
9980 u16 remainder = 0;
9981 u16 *trk_filtercfg = ext_attr->oob_trk_filter_cfg;
9982
9983 index = (u16) ((freq - 400) / 200);
9984 remainder = (u16) ((freq - 400) % 200);
9985 trk_filter_value =
9986 trk_filtercfg[index] - (trk_filtercfg[index] -
9987 trk_filtercfg[index +
9988 1]) / 10 * remainder /
9989 20;
9990 }
9991
9992
9993
9994
9995 rc = drxj_dap_write_reg16(dev_addr, ORX_COMM_EXEC__A, ORX_COMM_EXEC_STOP, 0);
9996 if (rc != 0) {
9997 pr_err("error %d\n", rc);
9998 goto rw_error;
9999 }
10000 scu_cmd.command = SCU_RAM_COMMAND_STANDARD_OOB
10001 | SCU_RAM_COMMAND_CMD_DEMOD_STOP;
10002 scu_cmd.parameter_len = 0;
10003 scu_cmd.result_len = 1;
10004 scu_cmd.result = cmd_result;
10005 rc = scu_command(dev_addr, &scu_cmd);
10006 if (rc != 0) {
10007 pr_err("error %d\n", rc);
10008 goto rw_error;
10009 }
10010
10011
10012
10013 scu_cmd.command = SCU_RAM_COMMAND_STANDARD_OOB
10014 | SCU_RAM_COMMAND_CMD_DEMOD_RESET;
10015 scu_cmd.parameter_len = 0;
10016 scu_cmd.result_len = 1;
10017 scu_cmd.result = cmd_result;
10018 rc = scu_command(dev_addr, &scu_cmd);
10019 if (rc != 0) {
10020 pr_err("error %d\n", rc);
10021 goto rw_error;
10022 }
10023
10024
10025
10026
10027 scu_cmd.command = SCU_RAM_COMMAND_STANDARD_OOB
10028 | SCU_RAM_COMMAND_CMD_DEMOD_SET_ENV;
10029 scu_cmd.parameter_len = 3;
10030
10031 switch (oob_param->standard) {
10032 case DRX_OOB_MODE_A:
10033 if (
10034
10035 ((oob_param->spectrum_inverted == true) &&
10036
10037 (!mirror_freq_spect_oob)) |
10038
10039
10040 ((oob_param->spectrum_inverted == false) &&
10041
10042 (mirror_freq_spect_oob))
10043 )
10044 set_param_parameters[0] =
10045 SCU_RAM_ORX_RF_RX_DATA_RATE_2048KBPS_INVSPEC;
10046 else
10047 set_param_parameters[0] =
10048 SCU_RAM_ORX_RF_RX_DATA_RATE_2048KBPS_REGSPEC;
10049 break;
10050 case DRX_OOB_MODE_B_GRADE_A:
10051 if (
10052
10053 ((oob_param->spectrum_inverted == true) &&
10054
10055 (!mirror_freq_spect_oob)) |
10056
10057
10058 ((oob_param->spectrum_inverted == false) &&
10059
10060 (mirror_freq_spect_oob))
10061 )
10062 set_param_parameters[0] =
10063 SCU_RAM_ORX_RF_RX_DATA_RATE_1544KBPS_INVSPEC;
10064 else
10065 set_param_parameters[0] =
10066 SCU_RAM_ORX_RF_RX_DATA_RATE_1544KBPS_REGSPEC;
10067 break;
10068 case DRX_OOB_MODE_B_GRADE_B:
10069 default:
10070 if (
10071
10072 ((oob_param->spectrum_inverted == true) &&
10073
10074 (!mirror_freq_spect_oob)) |
10075
10076
10077 ((oob_param->spectrum_inverted == false) &&
10078
10079 (mirror_freq_spect_oob))
10080 )
10081 set_param_parameters[0] =
10082 SCU_RAM_ORX_RF_RX_DATA_RATE_3088KBPS_INVSPEC;
10083 else
10084 set_param_parameters[0] =
10085 SCU_RAM_ORX_RF_RX_DATA_RATE_3088KBPS_REGSPEC;
10086 break;
10087 }
10088 set_param_parameters[1] = (u16) (freq & 0xFFFF);
10089 set_param_parameters[2] = trk_filter_value;
10090 scu_cmd.parameter = set_param_parameters;
10091 scu_cmd.result_len = 1;
10092 scu_cmd.result = cmd_result;
10093 mode_index = mode_val[(set_param_parameters[0] & 0xC0) >> 6];
10094 rc = scu_command(dev_addr, &scu_cmd);
10095 if (rc != 0) {
10096 pr_err("error %d\n", rc);
10097 goto rw_error;
10098 }
10099
10100 rc = drxj_dap_write_reg16(dev_addr, SIO_TOP_COMM_KEY__A, 0xFABA, 0);
10101 if (rc != 0) {
10102 pr_err("error %d\n", rc);
10103 goto rw_error;
10104 }
10105 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_OOB_CRX_CFG__A, OOB_CRX_DRIVE_STRENGTH << SIO_PDR_OOB_CRX_CFG_DRIVE__B | 0x03 << SIO_PDR_OOB_CRX_CFG_MODE__B, 0);
10106 if (rc != 0) {
10107 pr_err("error %d\n", rc);
10108 goto rw_error;
10109 }
10110 rc = drxj_dap_write_reg16(dev_addr, SIO_PDR_OOB_DRX_CFG__A, OOB_DRX_DRIVE_STRENGTH << SIO_PDR_OOB_DRX_CFG_DRIVE__B | 0x03 << SIO_PDR_OOB_DRX_CFG_MODE__B, 0);
10111 if (rc != 0) {
10112 pr_err("error %d\n", rc);
10113 goto rw_error;
10114 }
10115 rc = drxj_dap_write_reg16(dev_addr, SIO_TOP_COMM_KEY__A, 0x0000, 0);
10116 if (rc != 0) {
10117 pr_err("error %d\n", rc);
10118 goto rw_error;
10119 }
10120
10121 rc = drxj_dap_write_reg16(dev_addr, ORX_TOP_COMM_KEY__A, 0, 0);
10122 if (rc != 0) {
10123 pr_err("error %d\n", rc);
10124 goto rw_error;
10125 }
10126 rc = drxj_dap_write_reg16(dev_addr, ORX_FWP_AAG_LEN_W__A, 16000, 0);
10127 if (rc != 0) {
10128 pr_err("error %d\n", rc);
10129 goto rw_error;
10130 }
10131 rc = drxj_dap_write_reg16(dev_addr, ORX_FWP_AAG_THR_W__A, 40, 0);
10132 if (rc != 0) {
10133 pr_err("error %d\n", rc);
10134 goto rw_error;
10135 }
10136
10137
10138 rc = drxj_dap_write_reg16(dev_addr, ORX_DDC_OFO_SET_W__A, ORX_DDC_OFO_SET_W__PRE, 0);
10139 if (rc != 0) {
10140 pr_err("error %d\n", rc);
10141 goto rw_error;
10142 }
10143
10144
10145 rc = drxj_dap_write_reg16(dev_addr, ORX_NSU_AOX_LOPOW_W__A, ext_attr->oob_lo_pow, 0);
10146 if (rc != 0) {
10147 pr_err("error %d\n", rc);
10148 goto rw_error;
10149 }
10150
10151
10152 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_TARGET_MODE__A, SCU_RAM_ORX_TARGET_MODE_2048KBPS_SQRT, 0);
10153 if (rc != 0) {
10154 pr_err("error %d\n", rc);
10155 goto rw_error;
10156 }
10157 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_FREQ_GAIN_CORR__A, SCU_RAM_ORX_FREQ_GAIN_CORR_2048KBPS, 0);
10158 if (rc != 0) {
10159 pr_err("error %d\n", rc);
10160 goto rw_error;
10161 }
10162
10163
10164 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_RST_CPH__A, 0x0001, 0);
10165 if (rc != 0) {
10166 pr_err("error %d\n", rc);
10167 goto rw_error;
10168 }
10169 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_RST_CTI__A, 0x0002, 0);
10170 if (rc != 0) {
10171 pr_err("error %d\n", rc);
10172 goto rw_error;
10173 }
10174 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_RST_KRN__A, 0x0004, 0);
10175 if (rc != 0) {
10176 pr_err("error %d\n", rc);
10177 goto rw_error;
10178 }
10179 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_RST_KRP__A, 0x0008, 0);
10180 if (rc != 0) {
10181 pr_err("error %d\n", rc);
10182 goto rw_error;
10183 }
10184
10185
10186 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_AGN_LOCK_TH__A, 2048 >> 3, 0);
10187 if (rc != 0) {
10188 pr_err("error %d\n", rc);
10189 goto rw_error;
10190 }
10191 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_AGN_LOCK_TOTH__A, (u16)(-2048), 0);
10192 if (rc != 0) {
10193 pr_err("error %d\n", rc);
10194 goto rw_error;
10195 }
10196 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_AGN_ONLOCK_TTH__A, 8, 0);
10197 if (rc != 0) {
10198 pr_err("error %d\n", rc);
10199 goto rw_error;
10200 }
10201 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_AGN_UNLOCK_TTH__A, (u16)(-8), 0);
10202 if (rc != 0) {
10203 pr_err("error %d\n", rc);
10204 goto rw_error;
10205 }
10206 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_AGN_LOCK_MASK__A, 1, 0);
10207 if (rc != 0) {
10208 pr_err("error %d\n", rc);
10209 goto rw_error;
10210 }
10211
10212
10213 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_DGN_LOCK_TH__A, 10, 0);
10214 if (rc != 0) {
10215 pr_err("error %d\n", rc);
10216 goto rw_error;
10217 }
10218 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_DGN_LOCK_TOTH__A, (u16)(-2048), 0);
10219 if (rc != 0) {
10220 pr_err("error %d\n", rc);
10221 goto rw_error;
10222 }
10223 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_DGN_ONLOCK_TTH__A, 8, 0);
10224 if (rc != 0) {
10225 pr_err("error %d\n", rc);
10226 goto rw_error;
10227 }
10228 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_DGN_UNLOCK_TTH__A, (u16)(-8), 0);
10229 if (rc != 0) {
10230 pr_err("error %d\n", rc);
10231 goto rw_error;
10232 }
10233 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_DGN_LOCK_MASK__A, 1 << 1, 0);
10234 if (rc != 0) {
10235 pr_err("error %d\n", rc);
10236 goto rw_error;
10237 }
10238
10239
10240 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_FRQ_LOCK_TH__A, 17, 0);
10241 if (rc != 0) {
10242 pr_err("error %d\n", rc);
10243 goto rw_error;
10244 }
10245 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_FRQ_LOCK_TOTH__A, (u16)(-2048), 0);
10246 if (rc != 0) {
10247 pr_err("error %d\n", rc);
10248 goto rw_error;
10249 }
10250 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_FRQ_ONLOCK_TTH__A, 8, 0);
10251 if (rc != 0) {
10252 pr_err("error %d\n", rc);
10253 goto rw_error;
10254 }
10255 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_FRQ_UNLOCK_TTH__A, (u16)(-8), 0);
10256 if (rc != 0) {
10257 pr_err("error %d\n", rc);
10258 goto rw_error;
10259 }
10260 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_FRQ_LOCK_MASK__A, 1 << 2, 0);
10261 if (rc != 0) {
10262 pr_err("error %d\n", rc);
10263 goto rw_error;
10264 }
10265
10266
10267 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_PHA_LOCK_TH__A, 3000, 0);
10268 if (rc != 0) {
10269 pr_err("error %d\n", rc);
10270 goto rw_error;
10271 }
10272 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_PHA_LOCK_TOTH__A, (u16)(-2048), 0);
10273 if (rc != 0) {
10274 pr_err("error %d\n", rc);
10275 goto rw_error;
10276 }
10277 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_PHA_ONLOCK_TTH__A, 8, 0);
10278 if (rc != 0) {
10279 pr_err("error %d\n", rc);
10280 goto rw_error;
10281 }
10282 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_PHA_UNLOCK_TTH__A, (u16)(-8), 0);
10283 if (rc != 0) {
10284 pr_err("error %d\n", rc);
10285 goto rw_error;
10286 }
10287 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_PHA_LOCK_MASK__A, 1 << 3, 0);
10288 if (rc != 0) {
10289 pr_err("error %d\n", rc);
10290 goto rw_error;
10291 }
10292
10293
10294 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_TIM_LOCK_TH__A, 400, 0);
10295 if (rc != 0) {
10296 pr_err("error %d\n", rc);
10297 goto rw_error;
10298 }
10299 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_TIM_LOCK_TOTH__A, (u16)(-2048), 0);
10300 if (rc != 0) {
10301 pr_err("error %d\n", rc);
10302 goto rw_error;
10303 }
10304 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_TIM_ONLOCK_TTH__A, 8, 0);
10305 if (rc != 0) {
10306 pr_err("error %d\n", rc);
10307 goto rw_error;
10308 }
10309 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_TIM_UNLOCK_TTH__A, (u16)(-8), 0);
10310 if (rc != 0) {
10311 pr_err("error %d\n", rc);
10312 goto rw_error;
10313 }
10314 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_TIM_LOCK_MASK__A, 1 << 4, 0);
10315 if (rc != 0) {
10316 pr_err("error %d\n", rc);
10317 goto rw_error;
10318 }
10319
10320
10321 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_EQU_LOCK_TH__A, 20, 0);
10322 if (rc != 0) {
10323 pr_err("error %d\n", rc);
10324 goto rw_error;
10325 }
10326 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_EQU_LOCK_TOTH__A, (u16)(-2048), 0);
10327 if (rc != 0) {
10328 pr_err("error %d\n", rc);
10329 goto rw_error;
10330 }
10331 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_EQU_ONLOCK_TTH__A, 4, 0);
10332 if (rc != 0) {
10333 pr_err("error %d\n", rc);
10334 goto rw_error;
10335 }
10336 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_EQU_UNLOCK_TTH__A, (u16)(-4), 0);
10337 if (rc != 0) {
10338 pr_err("error %d\n", rc);
10339 goto rw_error;
10340 }
10341 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_ORX_EQU_LOCK_MASK__A, 1 << 5, 0);
10342 if (rc != 0) {
10343 pr_err("error %d\n", rc);
10344 goto rw_error;
10345 }
10346
10347
10348 rc = drxdap_fasi_write_block(dev_addr, ORX_FWP_PFI_A_W__A, sizeof(pfi_coeffs[mode_index]), ((u8 *)pfi_coeffs[mode_index]), 0);
10349 if (rc != 0) {
10350 pr_err("error %d\n", rc);
10351 goto rw_error;
10352 }
10353 rc = drxj_dap_write_reg16(dev_addr, ORX_TOP_MDE_W__A, mode_index, 0);
10354 if (rc != 0) {
10355 pr_err("error %d\n", rc);
10356 goto rw_error;
10357 }
10358
10359
10360 for (i = 0; i < (NYQFILTERLEN + 1) / 2; i++) {
10361 rc = drxj_dap_write_reg16(dev_addr, ORX_FWP_NYQ_ADR_W__A, i, 0);
10362 if (rc != 0) {
10363 pr_err("error %d\n", rc);
10364 goto rw_error;
10365 }
10366 rc = drxj_dap_write_reg16(dev_addr, ORX_FWP_NYQ_COF_RW__A, nyquist_coeffs[mode_index][i], 0);
10367 if (rc != 0) {
10368 pr_err("error %d\n", rc);
10369 goto rw_error;
10370 }
10371 }
10372 rc = drxj_dap_write_reg16(dev_addr, ORX_FWP_NYQ_ADR_W__A, 31, 0);
10373 if (rc != 0) {
10374 pr_err("error %d\n", rc);
10375 goto rw_error;
10376 }
10377 rc = drxj_dap_write_reg16(dev_addr, ORX_COMM_EXEC__A, ORX_COMM_EXEC_ACTIVE, 0);
10378 if (rc != 0) {
10379 pr_err("error %d\n", rc);
10380 goto rw_error;
10381 }
10382
10383
10384
10385 scu_cmd.command = SCU_RAM_COMMAND_STANDARD_OOB
10386 | SCU_RAM_COMMAND_CMD_DEMOD_START;
10387 scu_cmd.parameter_len = 0;
10388 scu_cmd.result_len = 1;
10389 scu_cmd.result = cmd_result;
10390 rc = scu_command(dev_addr, &scu_cmd);
10391 if (rc != 0) {
10392 pr_err("error %d\n", rc);
10393 goto rw_error;
10394 }
10395
10396 rc = set_orx_nsu_aox(demod, true);
10397 if (rc != 0) {
10398 pr_err("error %d\n", rc);
10399 goto rw_error;
10400 }
10401 rc = drxj_dap_write_reg16(dev_addr, ORX_NSU_AOX_STHR_W__A, ext_attr->oob_pre_saw, 0);
10402 if (rc != 0) {
10403 pr_err("error %d\n", rc);
10404 goto rw_error;
10405 }
10406
10407 ext_attr->oob_power_on = true;
10408
10409 return 0;
10410rw_error:
10411 return rc;
10412}
10413
10414
10415
10416
10417
10418
10419
10420
10421
10422
10423
10424
10425
10426
10427
10428
10429
10430
10431
10432
10433
10434
10435
10436static int
10437ctrl_set_channel(struct drx_demod_instance *demod, struct drx_channel *channel)
10438{
10439 int rc;
10440 s32 tuner_freq_offset = 0;
10441 struct drxj_data *ext_attr = NULL;
10442 struct i2c_device_addr *dev_addr = NULL;
10443 enum drx_standard standard = DRX_STANDARD_UNKNOWN;
10444#ifndef DRXJ_VSB_ONLY
10445 u32 min_symbol_rate = 0;
10446 u32 max_symbol_rate = 0;
10447 int bandwidth_temp = 0;
10448 int bandwidth = 0;
10449#endif
10450
10451 if ((demod == NULL) || (channel == NULL))
10452 return -EINVAL;
10453
10454 dev_addr = demod->my_i2c_dev_addr;
10455 ext_attr = (struct drxj_data *) demod->my_ext_attr;
10456 standard = ext_attr->standard;
10457
10458
10459 switch (standard) {
10460 case DRX_STANDARD_8VSB:
10461#ifndef DRXJ_VSB_ONLY
10462 case DRX_STANDARD_ITU_A:
10463 case DRX_STANDARD_ITU_B:
10464 case DRX_STANDARD_ITU_C:
10465#endif
10466 break;
10467 case DRX_STANDARD_UNKNOWN:
10468 default:
10469 return -EINVAL;
10470 }
10471
10472
10473 if ((standard == DRX_STANDARD_ITU_B) ||
10474 (standard == DRX_STANDARD_8VSB) ||
10475 (standard == DRX_STANDARD_NTSC)) {
10476 switch (channel->bandwidth) {
10477 case DRX_BANDWIDTH_6MHZ:
10478 case DRX_BANDWIDTH_UNKNOWN:
10479 channel->bandwidth = DRX_BANDWIDTH_6MHZ;
10480 break;
10481 case DRX_BANDWIDTH_8MHZ:
10482 case DRX_BANDWIDTH_7MHZ:
10483 default:
10484 return -EINVAL;
10485 }
10486 }
10487
10488
10489
10490
10491
10492#ifndef DRXJ_VSB_ONLY
10493 if ((standard == DRX_STANDARD_ITU_A) ||
10494 (standard == DRX_STANDARD_ITU_C)) {
10495 struct drxuio_cfg uio_cfg = { DRX_UIO1, DRX_UIO_MODE_FIRMWARE_SAW };
10496 int bw_rolloff_factor = 0;
10497
10498 bw_rolloff_factor = (standard == DRX_STANDARD_ITU_A) ? 115 : 113;
10499 min_symbol_rate = DRXJ_QAM_SYMBOLRATE_MIN;
10500 max_symbol_rate = DRXJ_QAM_SYMBOLRATE_MAX;
10501
10502 rc = ctrl_set_uio_cfg(demod, &uio_cfg);
10503 if (rc != 0) {
10504 pr_err("error %d\n", rc);
10505 goto rw_error;
10506 }
10507
10508 if (channel->symbolrate < min_symbol_rate ||
10509 channel->symbolrate > max_symbol_rate) {
10510 return -EINVAL;
10511 }
10512
10513 switch (channel->constellation) {
10514 case DRX_CONSTELLATION_QAM16:
10515 case DRX_CONSTELLATION_QAM32:
10516 case DRX_CONSTELLATION_QAM64:
10517 case DRX_CONSTELLATION_QAM128:
10518 case DRX_CONSTELLATION_QAM256:
10519 bandwidth_temp = channel->symbolrate * bw_rolloff_factor;
10520 bandwidth = bandwidth_temp / 100;
10521
10522 if ((bandwidth_temp % 100) >= 50)
10523 bandwidth++;
10524
10525 if (bandwidth <= 6100000) {
10526 channel->bandwidth = DRX_BANDWIDTH_6MHZ;
10527 } else if ((bandwidth > 6100000)
10528 && (bandwidth <= 7100000)) {
10529 channel->bandwidth = DRX_BANDWIDTH_7MHZ;
10530 } else if (bandwidth > 7100000) {
10531 channel->bandwidth = DRX_BANDWIDTH_8MHZ;
10532 }
10533 break;
10534 default:
10535 return -EINVAL;
10536 }
10537 }
10538
10539
10540
10541
10542 if (standard == DRX_STANDARD_ITU_B) {
10543 switch (channel->constellation) {
10544 case DRX_CONSTELLATION_AUTO:
10545 case DRX_CONSTELLATION_QAM256:
10546 case DRX_CONSTELLATION_QAM64:
10547 break;
10548 default:
10549 return -EINVAL;
10550 }
10551
10552 switch (channel->interleavemode) {
10553 case DRX_INTERLEAVEMODE_I128_J1:
10554 case DRX_INTERLEAVEMODE_I128_J1_V2:
10555 case DRX_INTERLEAVEMODE_I128_J2:
10556 case DRX_INTERLEAVEMODE_I64_J2:
10557 case DRX_INTERLEAVEMODE_I128_J3:
10558 case DRX_INTERLEAVEMODE_I32_J4:
10559 case DRX_INTERLEAVEMODE_I128_J4:
10560 case DRX_INTERLEAVEMODE_I16_J8:
10561 case DRX_INTERLEAVEMODE_I128_J5:
10562 case DRX_INTERLEAVEMODE_I8_J16:
10563 case DRX_INTERLEAVEMODE_I128_J6:
10564 case DRX_INTERLEAVEMODE_I128_J7:
10565 case DRX_INTERLEAVEMODE_I128_J8:
10566 case DRX_INTERLEAVEMODE_I12_J17:
10567 case DRX_INTERLEAVEMODE_I5_J4:
10568 case DRX_INTERLEAVEMODE_B52_M240:
10569 case DRX_INTERLEAVEMODE_B52_M720:
10570 case DRX_INTERLEAVEMODE_UNKNOWN:
10571 case DRX_INTERLEAVEMODE_AUTO:
10572 break;
10573 default:
10574 return -EINVAL;
10575 }
10576 }
10577
10578 if ((ext_attr->uio_sma_tx_mode) == DRX_UIO_MODE_FIRMWARE_SAW) {
10579
10580 struct drxuio_data uio1 = { DRX_UIO1, false };
10581
10582 switch (channel->bandwidth) {
10583 case DRX_BANDWIDTH_8MHZ:
10584 uio1.value = true;
10585 break;
10586 case DRX_BANDWIDTH_7MHZ:
10587 uio1.value = false;
10588 break;
10589 case DRX_BANDWIDTH_6MHZ:
10590 uio1.value = false;
10591 break;
10592 case DRX_BANDWIDTH_UNKNOWN:
10593 default:
10594 return -EINVAL;
10595 }
10596
10597 rc = ctrl_uio_write(demod, &uio1);
10598 if (rc != 0) {
10599 pr_err("error %d\n", rc);
10600 goto rw_error;
10601 }
10602 }
10603#endif
10604 rc = drxj_dap_write_reg16(dev_addr, SCU_COMM_EXEC__A, SCU_COMM_EXEC_ACTIVE, 0);
10605 if (rc != 0) {
10606 pr_err("error %d\n", rc);
10607 goto rw_error;
10608 }
10609
10610 tuner_freq_offset = 0;
10611
10612
10613 switch (standard) {
10614 case DRX_STANDARD_8VSB:
10615 if (channel->mirror == DRX_MIRROR_AUTO)
10616 ext_attr->mirror = DRX_MIRROR_NO;
10617 else
10618 ext_attr->mirror = channel->mirror;
10619 rc = set_vsb(demod);
10620 if (rc != 0) {
10621 pr_err("error %d\n", rc);
10622 goto rw_error;
10623 }
10624 rc = set_frequency(demod, channel, tuner_freq_offset);
10625 if (rc != 0) {
10626 pr_err("error %d\n", rc);
10627 goto rw_error;
10628 }
10629 break;
10630#ifndef DRXJ_VSB_ONLY
10631 case DRX_STANDARD_ITU_A:
10632 case DRX_STANDARD_ITU_B:
10633 case DRX_STANDARD_ITU_C:
10634 rc = set_qam_channel(demod, channel, tuner_freq_offset);
10635 if (rc != 0) {
10636 pr_err("error %d\n", rc);
10637 goto rw_error;
10638 }
10639 break;
10640#endif
10641 case DRX_STANDARD_UNKNOWN:
10642 default:
10643 return -EIO;
10644 }
10645
10646
10647 ext_attr->reset_pkt_err_acc = true;
10648
10649 return 0;
10650rw_error:
10651 return rc;
10652}
10653
10654
10655
10656
10657
10658
10659
10660
10661
10662
10663
10664
10665
10666
10667
10668
10669static int
10670ctrl_sig_quality(struct drx_demod_instance *demod,
10671 enum drx_lock_status lock_status)
10672{
10673 struct i2c_device_addr *dev_addr = demod->my_i2c_dev_addr;
10674 struct drxj_data *ext_attr = demod->my_ext_attr;
10675 struct drx39xxj_state *state = dev_addr->user_data;
10676 struct dtv_frontend_properties *p = &state->frontend.dtv_property_cache;
10677 enum drx_standard standard = ext_attr->standard;
10678 int rc;
10679 u32 ber, cnt, err, pkt;
10680 u16 mer, strength = 0;
10681
10682 rc = get_sig_strength(demod, &strength);
10683 if (rc < 0) {
10684 pr_err("error getting signal strength %d\n", rc);
10685 p->strength.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
10686 } else {
10687 p->strength.stat[0].scale = FE_SCALE_RELATIVE;
10688 p->strength.stat[0].uvalue = 65535UL * strength/ 100;
10689 }
10690
10691 switch (standard) {
10692 case DRX_STANDARD_8VSB:
10693#ifdef DRXJ_SIGNAL_ACCUM_ERR
10694 rc = get_acc_pkt_err(demod, &pkt);
10695 if (rc != 0) {
10696 pr_err("error %d\n", rc);
10697 goto rw_error;
10698 }
10699#endif
10700 if (lock_status != DRXJ_DEMOD_LOCK && lock_status != DRX_LOCKED) {
10701 p->pre_bit_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
10702 p->pre_bit_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
10703 p->post_bit_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
10704 p->post_bit_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
10705 p->block_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
10706 p->block_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
10707 p->cnr.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
10708 } else {
10709 rc = get_vsb_post_rs_pck_err(dev_addr, &err, &pkt);
10710 if (rc != 0) {
10711 pr_err("error %d getting UCB\n", rc);
10712 p->block_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
10713 } else {
10714 p->block_error.stat[0].scale = FE_SCALE_COUNTER;
10715 p->block_error.stat[0].uvalue += err;
10716 p->block_count.stat[0].scale = FE_SCALE_COUNTER;
10717 p->block_count.stat[0].uvalue += pkt;
10718 }
10719
10720
10721 rc = get_vs_bpre_viterbi_ber(dev_addr, &ber, &cnt);
10722 if (rc != 0) {
10723 pr_err("error %d getting pre-ber\n", rc);
10724 p->pre_bit_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
10725 } else {
10726 p->pre_bit_error.stat[0].scale = FE_SCALE_COUNTER;
10727 p->pre_bit_error.stat[0].uvalue += ber;
10728 p->pre_bit_count.stat[0].scale = FE_SCALE_COUNTER;
10729 p->pre_bit_count.stat[0].uvalue += cnt;
10730 }
10731
10732 rc = get_vs_bpost_viterbi_ber(dev_addr, &ber, &cnt);
10733 if (rc != 0) {
10734 pr_err("error %d getting post-ber\n", rc);
10735 p->post_bit_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
10736 } else {
10737 p->post_bit_error.stat[0].scale = FE_SCALE_COUNTER;
10738 p->post_bit_error.stat[0].uvalue += ber;
10739 p->post_bit_count.stat[0].scale = FE_SCALE_COUNTER;
10740 p->post_bit_count.stat[0].uvalue += cnt;
10741 }
10742 rc = get_vsbmer(dev_addr, &mer);
10743 if (rc != 0) {
10744 pr_err("error %d getting MER\n", rc);
10745 p->cnr.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
10746 } else {
10747 p->cnr.stat[0].svalue = mer * 100;
10748 p->cnr.stat[0].scale = FE_SCALE_DECIBEL;
10749 }
10750 }
10751 break;
10752#ifndef DRXJ_VSB_ONLY
10753 case DRX_STANDARD_ITU_A:
10754 case DRX_STANDARD_ITU_B:
10755 case DRX_STANDARD_ITU_C:
10756 rc = ctrl_get_qam_sig_quality(demod);
10757 if (rc != 0) {
10758 pr_err("error %d\n", rc);
10759 goto rw_error;
10760 }
10761 break;
10762#endif
10763 default:
10764 return -EIO;
10765 }
10766
10767 return 0;
10768rw_error:
10769 return rc;
10770}
10771
10772
10773
10774
10775
10776
10777
10778
10779
10780
10781
10782static int
10783ctrl_lock_status(struct drx_demod_instance *demod, enum drx_lock_status *lock_stat)
10784{
10785 enum drx_standard standard = DRX_STANDARD_UNKNOWN;
10786 struct drxj_data *ext_attr = NULL;
10787 struct i2c_device_addr *dev_addr = NULL;
10788 struct drxjscu_cmd cmd_scu = { 0,
10789 0,
10790 0,
10791 NULL,
10792 NULL
10793 };
10794 int rc;
10795 u16 cmd_result[2] = { 0, 0 };
10796 u16 demod_lock = SCU_RAM_PARAM_1_RES_DEMOD_GET_LOCK_DEMOD_LOCKED;
10797
10798
10799 if ((demod == NULL) || (lock_stat == NULL))
10800 return -EINVAL;
10801
10802 dev_addr = demod->my_i2c_dev_addr;
10803 ext_attr = (struct drxj_data *) demod->my_ext_attr;
10804 standard = ext_attr->standard;
10805
10806 *lock_stat = DRX_NOT_LOCKED;
10807
10808
10809 switch (standard) {
10810 case DRX_STANDARD_8VSB:
10811 cmd_scu.command = SCU_RAM_COMMAND_STANDARD_VSB |
10812 SCU_RAM_COMMAND_CMD_DEMOD_GET_LOCK;
10813 demod_lock |= 0x6;
10814 break;
10815#ifndef DRXJ_VSB_ONLY
10816 case DRX_STANDARD_ITU_A:
10817 case DRX_STANDARD_ITU_B:
10818 case DRX_STANDARD_ITU_C:
10819 cmd_scu.command = SCU_RAM_COMMAND_STANDARD_QAM |
10820 SCU_RAM_COMMAND_CMD_DEMOD_GET_LOCK;
10821 break;
10822#endif
10823 case DRX_STANDARD_UNKNOWN:
10824 default:
10825 return -EIO;
10826 }
10827
10828
10829 cmd_scu.parameter_len = 0;
10830 cmd_scu.result_len = 2;
10831 cmd_scu.parameter = NULL;
10832 cmd_scu.result = cmd_result;
10833 rc = scu_command(dev_addr, &cmd_scu);
10834 if (rc != 0) {
10835 pr_err("error %d\n", rc);
10836 goto rw_error;
10837 }
10838
10839
10840 if (cmd_scu.result[1] < demod_lock) {
10841
10842 *lock_stat = DRX_NOT_LOCKED;
10843 } else if (cmd_scu.result[1] < SCU_RAM_PARAM_1_RES_DEMOD_GET_LOCK_LOCKED) {
10844 *lock_stat = DRXJ_DEMOD_LOCK;
10845 } else if (cmd_scu.result[1] <
10846 SCU_RAM_PARAM_1_RES_DEMOD_GET_LOCK_NEVER_LOCK) {
10847
10848 *lock_stat = DRX_LOCKED;
10849 } else {
10850
10851
10852 *lock_stat = DRX_NEVER_LOCK;
10853 }
10854
10855 return 0;
10856rw_error:
10857 return rc;
10858}
10859
10860
10861
10862
10863
10864
10865
10866
10867
10868
10869
10870
10871
10872static int
10873ctrl_set_standard(struct drx_demod_instance *demod, enum drx_standard *standard)
10874{
10875 struct drxj_data *ext_attr = NULL;
10876 int rc;
10877 enum drx_standard prev_standard;
10878
10879
10880 if ((standard == NULL) || (demod == NULL))
10881 return -EINVAL;
10882
10883 ext_attr = (struct drxj_data *) demod->my_ext_attr;
10884 prev_standard = ext_attr->standard;
10885
10886
10887
10888
10889 switch (prev_standard) {
10890#ifndef DRXJ_VSB_ONLY
10891 case DRX_STANDARD_ITU_A:
10892 case DRX_STANDARD_ITU_B:
10893 case DRX_STANDARD_ITU_C:
10894 rc = power_down_qam(demod, false);
10895 if (rc != 0) {
10896 pr_err("error %d\n", rc);
10897 goto rw_error;
10898 }
10899 break;
10900#endif
10901 case DRX_STANDARD_8VSB:
10902 rc = power_down_vsb(demod, false);
10903 if (rc != 0) {
10904 pr_err("error %d\n", rc);
10905 goto rw_error;
10906 }
10907 break;
10908 case DRX_STANDARD_UNKNOWN:
10909
10910 break;
10911 case DRX_STANDARD_AUTO:
10912 default:
10913 return -EINVAL;
10914 }
10915
10916
10917
10918
10919
10920 ext_attr->standard = *standard;
10921
10922 switch (*standard) {
10923#ifndef DRXJ_VSB_ONLY
10924 case DRX_STANDARD_ITU_A:
10925 case DRX_STANDARD_ITU_B:
10926 case DRX_STANDARD_ITU_C:
10927 do {
10928 u16 dummy;
10929 rc = drxj_dap_read_reg16(demod->my_i2c_dev_addr, SCU_RAM_VERSION_HI__A, &dummy, 0);
10930 if (rc != 0) {
10931 pr_err("error %d\n", rc);
10932 goto rw_error;
10933 }
10934 } while (0);
10935 break;
10936#endif
10937 case DRX_STANDARD_8VSB:
10938 rc = set_vsb_leak_n_gain(demod);
10939 if (rc != 0) {
10940 pr_err("error %d\n", rc);
10941 goto rw_error;
10942 }
10943 break;
10944 default:
10945 ext_attr->standard = DRX_STANDARD_UNKNOWN;
10946 return -EINVAL;
10947 break;
10948 }
10949
10950 return 0;
10951rw_error:
10952
10953 ext_attr->standard = DRX_STANDARD_UNKNOWN;
10954 return rc;
10955}
10956
10957
10958
10959static void drxj_reset_mode(struct drxj_data *ext_attr)
10960{
10961
10962 if (ext_attr->has_lna) {
10963
10964#ifndef DRXJ_VSB_ONLY
10965 ext_attr->qam_if_agc_cfg.standard = DRX_STANDARD_ITU_B;
10966 ext_attr->qam_if_agc_cfg.ctrl_mode = DRX_AGC_CTRL_OFF;
10967 ext_attr->qam_pga_cfg = 140 + (11 * 13);
10968#endif
10969 ext_attr->vsb_if_agc_cfg.standard = DRX_STANDARD_8VSB;
10970 ext_attr->vsb_if_agc_cfg.ctrl_mode = DRX_AGC_CTRL_OFF;
10971 ext_attr->vsb_pga_cfg = 140 + (11 * 13);
10972 } else {
10973
10974#ifndef DRXJ_VSB_ONLY
10975 ext_attr->qam_if_agc_cfg.standard = DRX_STANDARD_ITU_B;
10976 ext_attr->qam_if_agc_cfg.ctrl_mode = DRX_AGC_CTRL_AUTO;
10977 ext_attr->qam_if_agc_cfg.min_output_level = 0;
10978 ext_attr->qam_if_agc_cfg.max_output_level = 0x7FFF;
10979 ext_attr->qam_if_agc_cfg.speed = 3;
10980 ext_attr->qam_if_agc_cfg.top = 1297;
10981 ext_attr->qam_pga_cfg = 140;
10982#endif
10983 ext_attr->vsb_if_agc_cfg.standard = DRX_STANDARD_8VSB;
10984 ext_attr->vsb_if_agc_cfg.ctrl_mode = DRX_AGC_CTRL_AUTO;
10985 ext_attr->vsb_if_agc_cfg.min_output_level = 0;
10986 ext_attr->vsb_if_agc_cfg.max_output_level = 0x7FFF;
10987 ext_attr->vsb_if_agc_cfg.speed = 3;
10988 ext_attr->vsb_if_agc_cfg.top = 1024;
10989 ext_attr->vsb_pga_cfg = 140;
10990 }
10991
10992
10993#ifndef DRXJ_VSB_ONLY
10994 ext_attr->qam_rf_agc_cfg.standard = DRX_STANDARD_ITU_B;
10995 ext_attr->qam_rf_agc_cfg.ctrl_mode = DRX_AGC_CTRL_AUTO;
10996 ext_attr->qam_rf_agc_cfg.min_output_level = 0;
10997 ext_attr->qam_rf_agc_cfg.max_output_level = 0x7FFF;
10998 ext_attr->qam_rf_agc_cfg.speed = 3;
10999 ext_attr->qam_rf_agc_cfg.top = 9500;
11000 ext_attr->qam_rf_agc_cfg.cut_off_current = 4000;
11001 ext_attr->qam_pre_saw_cfg.standard = DRX_STANDARD_ITU_B;
11002 ext_attr->qam_pre_saw_cfg.reference = 0x07;
11003 ext_attr->qam_pre_saw_cfg.use_pre_saw = true;
11004#endif
11005
11006 ext_attr->vsb_rf_agc_cfg.standard = DRX_STANDARD_8VSB;
11007 ext_attr->vsb_rf_agc_cfg.ctrl_mode = DRX_AGC_CTRL_AUTO;
11008 ext_attr->vsb_rf_agc_cfg.min_output_level = 0;
11009 ext_attr->vsb_rf_agc_cfg.max_output_level = 0x7FFF;
11010 ext_attr->vsb_rf_agc_cfg.speed = 3;
11011 ext_attr->vsb_rf_agc_cfg.top = 9500;
11012 ext_attr->vsb_rf_agc_cfg.cut_off_current = 4000;
11013 ext_attr->vsb_pre_saw_cfg.standard = DRX_STANDARD_8VSB;
11014 ext_attr->vsb_pre_saw_cfg.reference = 0x07;
11015 ext_attr->vsb_pre_saw_cfg.use_pre_saw = true;
11016}
11017
11018
11019
11020
11021
11022
11023
11024
11025
11026
11027
11028
11029
11030static int
11031ctrl_power_mode(struct drx_demod_instance *demod, enum drx_power_mode *mode)
11032{
11033 struct drx_common_attr *common_attr = (struct drx_common_attr *) NULL;
11034 struct drxj_data *ext_attr = (struct drxj_data *) NULL;
11035 struct i2c_device_addr *dev_addr = (struct i2c_device_addr *)NULL;
11036 int rc;
11037 u16 sio_cc_pwd_mode = 0;
11038
11039 common_attr = (struct drx_common_attr *) demod->my_common_attr;
11040 ext_attr = (struct drxj_data *) demod->my_ext_attr;
11041 dev_addr = demod->my_i2c_dev_addr;
11042
11043
11044 if (mode == NULL)
11045 return -EINVAL;
11046
11047
11048 if (common_attr->current_power_mode == *mode)
11049 return 0;
11050
11051 switch (*mode) {
11052 case DRX_POWER_UP:
11053 case DRXJ_POWER_DOWN_MAIN_PATH:
11054 sio_cc_pwd_mode = SIO_CC_PWD_MODE_LEVEL_NONE;
11055 break;
11056 case DRXJ_POWER_DOWN_CORE:
11057 sio_cc_pwd_mode = SIO_CC_PWD_MODE_LEVEL_CLOCK;
11058 break;
11059 case DRXJ_POWER_DOWN_PLL:
11060 sio_cc_pwd_mode = SIO_CC_PWD_MODE_LEVEL_PLL;
11061 break;
11062 case DRX_POWER_DOWN:
11063 sio_cc_pwd_mode = SIO_CC_PWD_MODE_LEVEL_OSC;
11064 break;
11065 default:
11066
11067 return -EINVAL;
11068 break;
11069 }
11070
11071
11072 if ((common_attr->current_power_mode != DRX_POWER_UP)) {
11073 rc = power_up_device(demod);
11074 if (rc != 0) {
11075 pr_err("error %d\n", rc);
11076 goto rw_error;
11077 }
11078 }
11079
11080 if (*mode == DRX_POWER_UP) {
11081
11082
11083
11084 drxj_reset_mode(ext_attr);
11085 } else {
11086
11087
11088
11089
11090
11091
11092
11093
11094
11095
11096
11097 switch (ext_attr->standard) {
11098 case DRX_STANDARD_ITU_A:
11099 case DRX_STANDARD_ITU_B:
11100 case DRX_STANDARD_ITU_C:
11101 rc = power_down_qam(demod, true);
11102 if (rc != 0) {
11103 pr_err("error %d\n", rc);
11104 goto rw_error;
11105 }
11106 break;
11107 case DRX_STANDARD_8VSB:
11108 rc = power_down_vsb(demod, true);
11109 if (rc != 0) {
11110 pr_err("error %d\n", rc);
11111 goto rw_error;
11112 }
11113 break;
11114 case DRX_STANDARD_PAL_SECAM_BG:
11115 case DRX_STANDARD_PAL_SECAM_DK:
11116 case DRX_STANDARD_PAL_SECAM_I:
11117 case DRX_STANDARD_PAL_SECAM_L:
11118 case DRX_STANDARD_PAL_SECAM_LP:
11119 case DRX_STANDARD_NTSC:
11120 case DRX_STANDARD_FM:
11121 rc = power_down_atv(demod, ext_attr->standard, true);
11122 if (rc != 0) {
11123 pr_err("error %d\n", rc);
11124 goto rw_error;
11125 }
11126 break;
11127 case DRX_STANDARD_UNKNOWN:
11128
11129 break;
11130 case DRX_STANDARD_AUTO:
11131 default:
11132 return -EIO;
11133 }
11134 ext_attr->standard = DRX_STANDARD_UNKNOWN;
11135 }
11136
11137 if (*mode != DRXJ_POWER_DOWN_MAIN_PATH) {
11138 rc = drxj_dap_write_reg16(dev_addr, SIO_CC_PWD_MODE__A, sio_cc_pwd_mode, 0);
11139 if (rc != 0) {
11140 pr_err("error %d\n", rc);
11141 goto rw_error;
11142 }
11143 rc = drxj_dap_write_reg16(dev_addr, SIO_CC_UPDATE__A, SIO_CC_UPDATE_KEY, 0);
11144 if (rc != 0) {
11145 pr_err("error %d\n", rc);
11146 goto rw_error;
11147 }
11148
11149 if ((*mode != DRX_POWER_UP)) {
11150
11151 rc = init_hi(demod);
11152 if (rc != 0) {
11153 pr_err("error %d\n", rc);
11154 goto rw_error;
11155 }
11156
11157 ext_attr->hi_cfg_ctrl |= SIO_HI_RA_RAM_PAR_5_CFG_SLEEP_ZZZ;
11158 rc = hi_cfg_command(demod);
11159 if (rc != 0) {
11160 pr_err("error %d\n", rc);
11161 goto rw_error;
11162 }
11163 }
11164 }
11165
11166 common_attr->current_power_mode = *mode;
11167
11168 return 0;
11169rw_error:
11170 return rc;
11171}
11172
11173
11174
11175
11176
11177
11178
11179
11180
11181
11182
11183
11184
11185
11186
11187
11188static int
11189ctrl_set_cfg_pre_saw(struct drx_demod_instance *demod, struct drxj_cfg_pre_saw *pre_saw)
11190{
11191 struct i2c_device_addr *dev_addr = NULL;
11192 struct drxj_data *ext_attr = NULL;
11193 int rc;
11194
11195 dev_addr = demod->my_i2c_dev_addr;
11196 ext_attr = (struct drxj_data *) demod->my_ext_attr;
11197
11198
11199 if ((pre_saw == NULL) || (pre_saw->reference > IQM_AF_PDREF__M)
11200 ) {
11201 return -EINVAL;
11202 }
11203
11204
11205 if ((ext_attr->standard == pre_saw->standard) ||
11206 (DRXJ_ISQAMSTD(ext_attr->standard) &&
11207 DRXJ_ISQAMSTD(pre_saw->standard)) ||
11208 (DRXJ_ISATVSTD(ext_attr->standard) &&
11209 DRXJ_ISATVSTD(pre_saw->standard))) {
11210 rc = drxj_dap_write_reg16(dev_addr, IQM_AF_PDREF__A, pre_saw->reference, 0);
11211 if (rc != 0) {
11212 pr_err("error %d\n", rc);
11213 goto rw_error;
11214 }
11215 }
11216
11217
11218 switch (pre_saw->standard) {
11219 case DRX_STANDARD_8VSB:
11220 ext_attr->vsb_pre_saw_cfg = *pre_saw;
11221 break;
11222#ifndef DRXJ_VSB_ONLY
11223 case DRX_STANDARD_ITU_A:
11224 case DRX_STANDARD_ITU_B:
11225 case DRX_STANDARD_ITU_C:
11226 ext_attr->qam_pre_saw_cfg = *pre_saw;
11227 break;
11228#endif
11229 default:
11230 return -EINVAL;
11231 }
11232
11233 return 0;
11234rw_error:
11235 return rc;
11236}
11237
11238
11239
11240
11241
11242
11243
11244
11245
11246
11247
11248
11249
11250
11251static int
11252ctrl_set_cfg_afe_gain(struct drx_demod_instance *demod, struct drxj_cfg_afe_gain *afe_gain)
11253{
11254 struct i2c_device_addr *dev_addr = NULL;
11255 struct drxj_data *ext_attr = NULL;
11256 int rc;
11257 u8 gain = 0;
11258
11259
11260 if (afe_gain == NULL)
11261 return -EINVAL;
11262
11263 dev_addr = demod->my_i2c_dev_addr;
11264 ext_attr = (struct drxj_data *) demod->my_ext_attr;
11265
11266 switch (afe_gain->standard) {
11267 case DRX_STANDARD_8VSB:
11268#ifndef DRXJ_VSB_ONLY
11269 case DRX_STANDARD_ITU_A:
11270 case DRX_STANDARD_ITU_B:
11271 case DRX_STANDARD_ITU_C:
11272#endif
11273
11274 break;
11275 default:
11276 return -EINVAL;
11277 }
11278
11279
11280
11281
11282 if (afe_gain->gain >= 329)
11283 gain = 15;
11284 else if (afe_gain->gain <= 147)
11285 gain = 0;
11286 else
11287 gain = (afe_gain->gain - 140 + 6) / 13;
11288
11289
11290 if (ext_attr->standard == afe_gain->standard) {
11291 rc = drxj_dap_write_reg16(dev_addr, IQM_AF_PGA_GAIN__A, gain, 0);
11292 if (rc != 0) {
11293 pr_err("error %d\n", rc);
11294 goto rw_error;
11295 }
11296 }
11297
11298
11299 switch (afe_gain->standard) {
11300 case DRX_STANDARD_8VSB:
11301 ext_attr->vsb_pga_cfg = gain * 13 + 140;
11302 break;
11303#ifndef DRXJ_VSB_ONLY
11304 case DRX_STANDARD_ITU_A:
11305 case DRX_STANDARD_ITU_B:
11306 case DRX_STANDARD_ITU_C:
11307 ext_attr->qam_pga_cfg = gain * 13 + 140;
11308 break;
11309#endif
11310 default:
11311 return -EIO;
11312 }
11313
11314 return 0;
11315rw_error:
11316 return rc;
11317}
11318
11319
11320
11321
11322
11323
11324
11325static int drx_ctrl_u_code(struct drx_demod_instance *demod,
11326 struct drxu_code_info *mc_info,
11327 enum drxu_code_action action);
11328static int drxj_set_lna_state(struct drx_demod_instance *demod, bool state);
11329
11330
11331
11332
11333
11334
11335
11336
11337
11338
11339
11340
11341static int drxj_open(struct drx_demod_instance *demod)
11342{
11343 struct i2c_device_addr *dev_addr = NULL;
11344 struct drxj_data *ext_attr = NULL;
11345 struct drx_common_attr *common_attr = NULL;
11346 u32 driver_version = 0;
11347 struct drxu_code_info ucode_info;
11348 struct drx_cfg_mpeg_output cfg_mpeg_output;
11349 int rc;
11350 enum drx_power_mode power_mode = DRX_POWER_UP;
11351
11352 if ((demod == NULL) ||
11353 (demod->my_common_attr == NULL) ||
11354 (demod->my_ext_attr == NULL) ||
11355 (demod->my_i2c_dev_addr == NULL) ||
11356 (demod->my_common_attr->is_opened)) {
11357 return -EINVAL;
11358 }
11359
11360
11361 if (demod->my_ext_attr == NULL)
11362 return -EINVAL;
11363
11364 dev_addr = demod->my_i2c_dev_addr;
11365 ext_attr = (struct drxj_data *) demod->my_ext_attr;
11366 common_attr = (struct drx_common_attr *) demod->my_common_attr;
11367
11368 rc = ctrl_power_mode(demod, &power_mode);
11369 if (rc != 0) {
11370 pr_err("error %d\n", rc);
11371 goto rw_error;
11372 }
11373 if (power_mode != DRX_POWER_UP) {
11374 rc = -EINVAL;
11375 pr_err("failed to powerup device\n");
11376 goto rw_error;
11377 }
11378
11379
11380 rc = get_device_capabilities(demod);
11381 if (rc != 0) {
11382 pr_err("error %d\n", rc);
11383 goto rw_error;
11384 }
11385
11386
11387
11388
11389
11390
11391
11392
11393
11394 rc = drxj_dap_write_reg16(dev_addr, SIO_CC_SOFT_RST__A, (0x04 | SIO_CC_SOFT_RST_SYS__M | SIO_CC_SOFT_RST_OSC__M), 0);
11395 if (rc != 0) {
11396 pr_err("error %d\n", rc);
11397 goto rw_error;
11398 }
11399 rc = drxj_dap_write_reg16(dev_addr, SIO_CC_UPDATE__A, SIO_CC_UPDATE_KEY, 0);
11400 if (rc != 0) {
11401 pr_err("error %d\n", rc);
11402 goto rw_error;
11403 }
11404 msleep(1);
11405
11406
11407
11408 rc = drxj_dap_write_reg16(dev_addr, ATV_TOP_STDBY__A, (~ATV_TOP_STDBY_CVBS_STDBY_A2_ACTIVE) | ATV_TOP_STDBY_SIF_STDBY_STANDBY, 0);
11409 if (rc != 0) {
11410 pr_err("error %d\n", rc);
11411 goto rw_error;
11412 }
11413
11414 rc = set_iqm_af(demod, false);
11415 if (rc != 0) {
11416 pr_err("error %d\n", rc);
11417 goto rw_error;
11418 }
11419 rc = set_orx_nsu_aox(demod, false);
11420 if (rc != 0) {
11421 pr_err("error %d\n", rc);
11422 goto rw_error;
11423 }
11424
11425 rc = init_hi(demod);
11426 if (rc != 0) {
11427 pr_err("error %d\n", rc);
11428 goto rw_error;
11429 }
11430
11431
11432 memcpy(&cfg_mpeg_output, &common_attr->mpeg_cfg, sizeof(cfg_mpeg_output));
11433 cfg_mpeg_output.enable_mpeg_output = false;
11434
11435 rc = ctrl_set_cfg_mpeg_output(demod, &cfg_mpeg_output);
11436 if (rc != 0) {
11437 pr_err("error %d\n", rc);
11438 goto rw_error;
11439 }
11440
11441 rc = power_down_aud(demod);
11442 if (rc != 0) {
11443 pr_err("error %d\n", rc);
11444 goto rw_error;
11445 }
11446
11447 rc = drxj_dap_write_reg16(dev_addr, SCU_COMM_EXEC__A, SCU_COMM_EXEC_STOP, 0);
11448 if (rc != 0) {
11449 pr_err("error %d\n", rc);
11450 goto rw_error;
11451 }
11452
11453
11454 if (common_attr->microcode_file != NULL) {
11455
11456
11457 common_attr->is_opened = true;
11458 ucode_info.mc_file = common_attr->microcode_file;
11459
11460 if (DRX_ISPOWERDOWNMODE(demod->my_common_attr->current_power_mode)) {
11461 pr_err("Should powerup before loading the firmware.");
11462 return -EINVAL;
11463 }
11464
11465 rc = drx_ctrl_u_code(demod, &ucode_info, UCODE_UPLOAD);
11466 if (rc != 0) {
11467 pr_err("error %d while uploading the firmware\n", rc);
11468 goto rw_error;
11469 }
11470 if (common_attr->verify_microcode == true) {
11471 rc = drx_ctrl_u_code(demod, &ucode_info, UCODE_VERIFY);
11472 if (rc != 0) {
11473 pr_err("error %d while verifying the firmware\n",
11474 rc);
11475 goto rw_error;
11476 }
11477 }
11478 common_attr->is_opened = false;
11479 }
11480
11481
11482 rc = drxj_dap_write_reg16(dev_addr, SCU_COMM_EXEC__A, SCU_COMM_EXEC_ACTIVE, 0);
11483 if (rc != 0) {
11484 pr_err("error %d\n", rc);
11485 goto rw_error;
11486 }
11487
11488
11489 common_attr->scan_demod_lock_timeout = DRXJ_SCAN_TIMEOUT;
11490 common_attr->scan_desired_lock = DRX_LOCKED;
11491
11492 drxj_reset_mode(ext_attr);
11493 ext_attr->standard = DRX_STANDARD_UNKNOWN;
11494
11495 rc = smart_ant_init(demod);
11496 if (rc != 0) {
11497 pr_err("error %d\n", rc);
11498 goto rw_error;
11499 }
11500
11501
11502
11503
11504
11505 driver_version = (VERSION_MAJOR / 100) % 10;
11506 driver_version <<= 4;
11507 driver_version += (VERSION_MAJOR / 10) % 10;
11508 driver_version <<= 4;
11509 driver_version += (VERSION_MAJOR % 10);
11510 driver_version <<= 4;
11511 driver_version += (VERSION_MINOR % 10);
11512 driver_version <<= 4;
11513 driver_version += (VERSION_PATCH / 1000) % 10;
11514 driver_version <<= 4;
11515 driver_version += (VERSION_PATCH / 100) % 10;
11516 driver_version <<= 4;
11517 driver_version += (VERSION_PATCH / 10) % 10;
11518 driver_version <<= 4;
11519 driver_version += (VERSION_PATCH % 10);
11520 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_DRIVER_VER_HI__A, (u16)(driver_version >> 16), 0);
11521 if (rc != 0) {
11522 pr_err("error %d\n", rc);
11523 goto rw_error;
11524 }
11525 rc = drxj_dap_write_reg16(dev_addr, SCU_RAM_DRIVER_VER_LO__A, (u16)(driver_version & 0xFFFF), 0);
11526 if (rc != 0) {
11527 pr_err("error %d\n", rc);
11528 goto rw_error;
11529 }
11530
11531 rc = ctrl_set_oob(demod, NULL);
11532 if (rc != 0) {
11533 pr_err("error %d\n", rc);
11534 goto rw_error;
11535 }
11536
11537
11538 ext_attr->aud_data = drxj_default_aud_data_g;
11539
11540 demod->my_common_attr->is_opened = true;
11541 drxj_set_lna_state(demod, false);
11542 return 0;
11543rw_error:
11544 common_attr->is_opened = false;
11545 return rc;
11546}
11547
11548
11549
11550
11551
11552
11553
11554
11555static int drxj_close(struct drx_demod_instance *demod)
11556{
11557 struct i2c_device_addr *dev_addr = demod->my_i2c_dev_addr;
11558 int rc;
11559 enum drx_power_mode power_mode = DRX_POWER_UP;
11560
11561 if ((demod->my_common_attr == NULL) ||
11562 (demod->my_ext_attr == NULL) ||
11563 (demod->my_i2c_dev_addr == NULL) ||
11564 (!demod->my_common_attr->is_opened)) {
11565 return -EINVAL;
11566 }
11567
11568
11569 rc = ctrl_power_mode(demod, &power_mode);
11570 if (rc != 0) {
11571 pr_err("error %d\n", rc);
11572 goto rw_error;
11573 }
11574
11575 rc = drxj_dap_write_reg16(dev_addr, SCU_COMM_EXEC__A, SCU_COMM_EXEC_ACTIVE, 0);
11576 if (rc != 0) {
11577 pr_err("error %d\n", rc);
11578 goto rw_error;
11579 }
11580 power_mode = DRX_POWER_DOWN;
11581 rc = ctrl_power_mode(demod, &power_mode);
11582 if (rc != 0) {
11583 pr_err("error %d\n", rc);
11584 goto rw_error;
11585 }
11586
11587 DRX_ATTR_ISOPENED(demod) = false;
11588
11589 return 0;
11590rw_error:
11591 DRX_ATTR_ISOPENED(demod) = false;
11592
11593 return rc;
11594}
11595
11596
11597
11598
11599
11600
11601
11602
11603
11604
11605
11606
11607static u16 drx_u_code_compute_crc(u8 *block_data, u16 nr_words)
11608{
11609 u16 i = 0;
11610 u16 j = 0;
11611 u32 crc_word = 0;
11612 u32 carry = 0;
11613
11614 while (i < nr_words) {
11615 crc_word |= (u32)be16_to_cpu(*(__be16 *)(block_data));
11616 for (j = 0; j < 16; j++) {
11617 crc_word <<= 1;
11618 if (carry != 0)
11619 crc_word ^= 0x80050000UL;
11620 carry = crc_word & 0x80000000UL;
11621 }
11622 i++;
11623 block_data += (sizeof(u16));
11624 }
11625 return (u16)(crc_word >> 16);
11626}
11627
11628
11629
11630
11631
11632
11633
11634
11635static int drx_check_firmware(struct drx_demod_instance *demod, u8 *mc_data,
11636 unsigned size)
11637{
11638 struct drxu_code_block_hdr block_hdr;
11639 int i;
11640 unsigned count = 2 * sizeof(u16);
11641 u32 mc_dev_type, mc_version, mc_base_version;
11642 u16 mc_nr_of_blks = be16_to_cpu(*(__be16 *)(mc_data + sizeof(u16)));
11643
11644
11645
11646
11647
11648
11649
11650 DRX_ATTR_MCRECORD(demod).aux_type = 0;
11651 DRX_ATTR_MCRECORD(demod).mc_dev_type = 0;
11652 DRX_ATTR_MCRECORD(demod).mc_version = 0;
11653 DRX_ATTR_MCRECORD(demod).mc_base_version = 0;
11654
11655 for (i = 0; i < mc_nr_of_blks; i++) {
11656 if (count + 3 * sizeof(u16) + sizeof(u32) > size)
11657 goto eof;
11658
11659
11660 block_hdr.addr = be32_to_cpu(*(__be32 *)(mc_data + count));
11661 count += sizeof(u32);
11662 block_hdr.size = be16_to_cpu(*(__be16 *)(mc_data + count));
11663 count += sizeof(u16);
11664 block_hdr.flags = be16_to_cpu(*(__be16 *)(mc_data + count));
11665 count += sizeof(u16);
11666 block_hdr.CRC = be16_to_cpu(*(__be16 *)(mc_data + count));
11667 count += sizeof(u16);
11668
11669 pr_debug("%u: addr %u, size %u, flags 0x%04x, CRC 0x%04x\n",
11670 count, block_hdr.addr, block_hdr.size, block_hdr.flags,
11671 block_hdr.CRC);
11672
11673 if (block_hdr.flags & 0x8) {
11674 u8 *auxblk = ((void *)mc_data) + block_hdr.addr;
11675 u16 auxtype;
11676
11677 if (block_hdr.addr + sizeof(u16) > size)
11678 goto eof;
11679
11680 auxtype = be16_to_cpu(*(__be16 *)(auxblk));
11681
11682
11683 if (DRX_ISMCVERTYPE(auxtype)) {
11684 if (block_hdr.addr + 2 * sizeof(u16) + 2 * sizeof (u32) > size)
11685 goto eof;
11686
11687 auxblk += sizeof(u16);
11688 mc_dev_type = be32_to_cpu(*(__be32 *)(auxblk));
11689 auxblk += sizeof(u32);
11690 mc_version = be32_to_cpu(*(__be32 *)(auxblk));
11691 auxblk += sizeof(u32);
11692 mc_base_version = be32_to_cpu(*(__be32 *)(auxblk));
11693
11694 DRX_ATTR_MCRECORD(demod).aux_type = auxtype;
11695 DRX_ATTR_MCRECORD(demod).mc_dev_type = mc_dev_type;
11696 DRX_ATTR_MCRECORD(demod).mc_version = mc_version;
11697 DRX_ATTR_MCRECORD(demod).mc_base_version = mc_base_version;
11698
11699 pr_info("Firmware dev %x, ver %x, base ver %x\n",
11700 mc_dev_type, mc_version, mc_base_version);
11701
11702 }
11703 } else if (count + block_hdr.size * sizeof(u16) > size)
11704 goto eof;
11705
11706 count += block_hdr.size * sizeof(u16);
11707 }
11708 return 0;
11709eof:
11710 pr_err("Firmware is truncated at pos %u/%u\n", count, size);
11711 return -EINVAL;
11712}
11713
11714
11715
11716
11717
11718
11719
11720
11721
11722
11723
11724
11725
11726
11727
11728
11729
11730
11731
11732
11733static int drx_ctrl_u_code(struct drx_demod_instance *demod,
11734 struct drxu_code_info *mc_info,
11735 enum drxu_code_action action)
11736{
11737 struct i2c_device_addr *dev_addr = demod->my_i2c_dev_addr;
11738 int rc;
11739 u16 i = 0;
11740 u16 mc_nr_of_blks = 0;
11741 u16 mc_magic_word = 0;
11742 const u8 *mc_data_init = NULL;
11743 u8 *mc_data = NULL;
11744 unsigned size;
11745 char *mc_file;
11746
11747
11748 if (!mc_info || !mc_info->mc_file)
11749 return -EINVAL;
11750
11751 mc_file = mc_info->mc_file;
11752
11753 if (!demod->firmware) {
11754 const struct firmware *fw = NULL;
11755
11756 rc = request_firmware(&fw, mc_file, demod->i2c->dev.parent);
11757 if (rc < 0) {
11758 pr_err("Couldn't read firmware %s\n", mc_file);
11759 return rc;
11760 }
11761 demod->firmware = fw;
11762
11763 if (demod->firmware->size < 2 * sizeof(u16)) {
11764 rc = -EINVAL;
11765 pr_err("Firmware is too short!\n");
11766 goto release;
11767 }
11768
11769 pr_info("Firmware %s, size %zu\n",
11770 mc_file, demod->firmware->size);
11771 }
11772
11773 mc_data_init = demod->firmware->data;
11774 size = demod->firmware->size;
11775
11776 mc_data = (void *)mc_data_init;
11777
11778 mc_magic_word = be16_to_cpu(*(__be16 *)(mc_data));
11779 mc_data += sizeof(u16);
11780 mc_nr_of_blks = be16_to_cpu(*(__be16 *)(mc_data));
11781 mc_data += sizeof(u16);
11782
11783 if ((mc_magic_word != DRX_UCODE_MAGIC_WORD) || (mc_nr_of_blks == 0)) {
11784 rc = -EINVAL;
11785 pr_err("Firmware magic word doesn't match\n");
11786 goto release;
11787 }
11788
11789 if (action == UCODE_UPLOAD) {
11790 rc = drx_check_firmware(demod, (u8 *)mc_data_init, size);
11791 if (rc)
11792 goto release;
11793 pr_info("Uploading firmware %s\n", mc_file);
11794 } else {
11795 pr_info("Verifying if firmware upload was ok.\n");
11796 }
11797
11798
11799 for (i = 0; i < mc_nr_of_blks; i++) {
11800 struct drxu_code_block_hdr block_hdr;
11801 u16 mc_block_nr_bytes = 0;
11802
11803
11804 block_hdr.addr = be32_to_cpu(*(__be32 *)(mc_data));
11805 mc_data += sizeof(u32);
11806 block_hdr.size = be16_to_cpu(*(__be16 *)(mc_data));
11807 mc_data += sizeof(u16);
11808 block_hdr.flags = be16_to_cpu(*(__be16 *)(mc_data));
11809 mc_data += sizeof(u16);
11810 block_hdr.CRC = be16_to_cpu(*(__be16 *)(mc_data));
11811 mc_data += sizeof(u16);
11812
11813 pr_debug("%zd: addr %u, size %u, flags 0x%04x, CRC 0x%04x\n",
11814 (mc_data - mc_data_init), block_hdr.addr,
11815 block_hdr.size, block_hdr.flags, block_hdr.CRC);
11816
11817
11818
11819
11820
11821 if ((block_hdr.size > 0x7FFF) ||
11822 (((block_hdr.flags & DRX_UCODE_CRC_FLAG) != 0) &&
11823 (block_hdr.CRC != drx_u_code_compute_crc(mc_data, block_hdr.size)))
11824 ) {
11825
11826 rc = -EINVAL;
11827 pr_err("firmware CRC is wrong\n");
11828 goto release;
11829 }
11830
11831 if (!block_hdr.size)
11832 continue;
11833
11834 mc_block_nr_bytes = block_hdr.size * ((u16) sizeof(u16));
11835
11836
11837 switch (action) {
11838 case UCODE_UPLOAD:
11839 if (drxdap_fasi_write_block(dev_addr,
11840 block_hdr.addr,
11841 mc_block_nr_bytes,
11842 mc_data, 0x0000)) {
11843 rc = -EIO;
11844 pr_err("error writing firmware at pos %zd\n",
11845 mc_data - mc_data_init);
11846 goto release;
11847 }
11848 break;
11849 case UCODE_VERIFY: {
11850 int result = 0;
11851 u8 mc_data_buffer[DRX_UCODE_MAX_BUF_SIZE];
11852 u32 bytes_to_comp = 0;
11853 u32 bytes_left = mc_block_nr_bytes;
11854 u32 curr_addr = block_hdr.addr;
11855 u8 *curr_ptr = mc_data;
11856
11857 while (bytes_left != 0) {
11858 if (bytes_left > DRX_UCODE_MAX_BUF_SIZE)
11859 bytes_to_comp = DRX_UCODE_MAX_BUF_SIZE;
11860 else
11861 bytes_to_comp = bytes_left;
11862
11863 if (drxdap_fasi_read_block(dev_addr,
11864 curr_addr,
11865 (u16)bytes_to_comp,
11866 (u8 *)mc_data_buffer,
11867 0x0000)) {
11868 pr_err("error reading firmware at pos %zd\n",
11869 mc_data - mc_data_init);
11870 return -EIO;
11871 }
11872
11873 result = memcmp(curr_ptr, mc_data_buffer,
11874 bytes_to_comp);
11875
11876 if (result) {
11877 pr_err("error verifying firmware at pos %zd\n",
11878 mc_data - mc_data_init);
11879 return -EIO;
11880 }
11881
11882 curr_addr += ((dr_xaddr_t)(bytes_to_comp / 2));
11883 curr_ptr =&(curr_ptr[bytes_to_comp]);
11884 bytes_left -=((u32) bytes_to_comp);
11885 }
11886 break;
11887 }
11888 default:
11889 return -EINVAL;
11890 break;
11891
11892 }
11893 mc_data += mc_block_nr_bytes;
11894 }
11895
11896 return 0;
11897
11898release:
11899 release_firmware(demod->firmware);
11900 demod->firmware = NULL;
11901
11902 return rc;
11903}
11904
11905
11906static int drxj_set_lna_state(struct drx_demod_instance *demod, bool state)
11907{
11908 struct drxuio_cfg uio_cfg;
11909 struct drxuio_data uio_data;
11910 int result;
11911
11912 uio_cfg.uio = DRX_UIO1;
11913 uio_cfg.mode = DRX_UIO_MODE_READWRITE;
11914
11915 result = ctrl_set_uio_cfg(demod, &uio_cfg);
11916 if (result) {
11917 pr_err("Failed to setup LNA GPIO!\n");
11918 return result;
11919 }
11920
11921 uio_data.uio = DRX_UIO1;
11922 uio_data.value = state;
11923 result = ctrl_uio_write(demod, &uio_data);
11924 if (result != 0) {
11925 pr_err("Failed to %sable LNA!\n",
11926 state ? "en" : "dis");
11927 return result;
11928 }
11929 return 0;
11930}
11931
11932
11933
11934
11935
11936
11937
11938static int drx39xxj_set_powerstate(struct dvb_frontend *fe, int enable)
11939{
11940 struct drx39xxj_state *state = fe->demodulator_priv;
11941 struct drx_demod_instance *demod = state->demod;
11942 int result;
11943 enum drx_power_mode power_mode;
11944
11945 if (enable)
11946 power_mode = DRX_POWER_UP;
11947 else
11948 power_mode = DRX_POWER_DOWN;
11949
11950 result = ctrl_power_mode(demod, &power_mode);
11951 if (result != 0) {
11952 pr_err("Power state change failed\n");
11953 return 0;
11954 }
11955
11956 return 0;
11957}
11958
11959static int drx39xxj_read_status(struct dvb_frontend *fe, enum fe_status *status)
11960{
11961 struct drx39xxj_state *state = fe->demodulator_priv;
11962 struct drx_demod_instance *demod = state->demod;
11963 int result;
11964 enum drx_lock_status lock_status;
11965
11966 *status = 0;
11967
11968 result = ctrl_lock_status(demod, &lock_status);
11969 if (result != 0) {
11970 pr_err("drx39xxj: could not get lock status!\n");
11971 *status = 0;
11972 }
11973
11974 switch (lock_status) {
11975 case DRX_NEVER_LOCK:
11976 *status = 0;
11977 pr_err("drx says NEVER_LOCK\n");
11978 break;
11979 case DRX_NOT_LOCKED:
11980 *status = 0;
11981 break;
11982 case DRX_LOCK_STATE_1:
11983 case DRX_LOCK_STATE_2:
11984 case DRX_LOCK_STATE_3:
11985 case DRX_LOCK_STATE_4:
11986 case DRX_LOCK_STATE_5:
11987 case DRX_LOCK_STATE_6:
11988 case DRX_LOCK_STATE_7:
11989 case DRX_LOCK_STATE_8:
11990 case DRX_LOCK_STATE_9:
11991 *status = FE_HAS_SIGNAL
11992 | FE_HAS_CARRIER | FE_HAS_VITERBI | FE_HAS_SYNC;
11993 break;
11994 case DRX_LOCKED:
11995 *status = FE_HAS_SIGNAL
11996 | FE_HAS_CARRIER
11997 | FE_HAS_VITERBI | FE_HAS_SYNC | FE_HAS_LOCK;
11998 break;
11999 default:
12000 pr_err("Lock state unknown %d\n", lock_status);
12001 }
12002 ctrl_sig_quality(demod, lock_status);
12003
12004 return 0;
12005}
12006
12007static int drx39xxj_read_ber(struct dvb_frontend *fe, u32 *ber)
12008{
12009 struct dtv_frontend_properties *p = &fe->dtv_property_cache;
12010
12011 if (p->pre_bit_error.stat[0].scale == FE_SCALE_NOT_AVAILABLE) {
12012 *ber = 0;
12013 return 0;
12014 }
12015
12016 if (!p->pre_bit_count.stat[0].uvalue) {
12017 if (!p->pre_bit_error.stat[0].uvalue)
12018 *ber = 0;
12019 else
12020 *ber = 1000000;
12021 } else {
12022 *ber = frac_times1e6(p->pre_bit_error.stat[0].uvalue,
12023 p->pre_bit_count.stat[0].uvalue);
12024 }
12025 return 0;
12026}
12027
12028static int drx39xxj_read_signal_strength(struct dvb_frontend *fe,
12029 u16 *strength)
12030{
12031 struct dtv_frontend_properties *p = &fe->dtv_property_cache;
12032
12033 if (p->strength.stat[0].scale == FE_SCALE_NOT_AVAILABLE) {
12034 *strength = 0;
12035 return 0;
12036 }
12037
12038 *strength = p->strength.stat[0].uvalue;
12039 return 0;
12040}
12041
12042static int drx39xxj_read_snr(struct dvb_frontend *fe, u16 *snr)
12043{
12044 struct dtv_frontend_properties *p = &fe->dtv_property_cache;
12045 u64 tmp64;
12046
12047 if (p->cnr.stat[0].scale == FE_SCALE_NOT_AVAILABLE) {
12048 *snr = 0;
12049 return 0;
12050 }
12051
12052 tmp64 = p->cnr.stat[0].svalue;
12053 do_div(tmp64, 10);
12054 *snr = tmp64;
12055 return 0;
12056}
12057
12058static int drx39xxj_read_ucblocks(struct dvb_frontend *fe, u32 *ucb)
12059{
12060 struct dtv_frontend_properties *p = &fe->dtv_property_cache;
12061
12062 if (p->block_error.stat[0].scale == FE_SCALE_NOT_AVAILABLE) {
12063 *ucb = 0;
12064 return 0;
12065 }
12066
12067 *ucb = p->block_error.stat[0].uvalue;
12068 return 0;
12069}
12070
12071static int drx39xxj_set_frontend(struct dvb_frontend *fe)
12072{
12073#ifdef DJH_DEBUG
12074 int i;
12075#endif
12076 struct dtv_frontend_properties *p = &fe->dtv_property_cache;
12077 struct drx39xxj_state *state = fe->demodulator_priv;
12078 struct drx_demod_instance *demod = state->demod;
12079 enum drx_standard standard = DRX_STANDARD_8VSB;
12080 struct drx_channel channel;
12081 int result;
12082 static const struct drx_channel def_channel = {
12083 0,
12084 DRX_BANDWIDTH_6MHZ,
12085 DRX_MIRROR_NO,
12086 DRX_CONSTELLATION_AUTO,
12087 DRX_HIERARCHY_UNKNOWN,
12088 DRX_PRIORITY_UNKNOWN,
12089 DRX_CODERATE_UNKNOWN,
12090 DRX_GUARD_UNKNOWN,
12091 DRX_FFTMODE_UNKNOWN,
12092 DRX_CLASSIFICATION_AUTO,
12093 5057000,
12094 DRX_INTERLEAVEMODE_UNKNOWN,
12095 DRX_LDPC_UNKNOWN,
12096 DRX_CARRIER_UNKNOWN,
12097 DRX_FRAMEMODE_UNKNOWN
12098 };
12099 u32 constellation = DRX_CONSTELLATION_AUTO;
12100
12101
12102 drx39xxj_set_powerstate(fe, 1);
12103
12104 if (fe->ops.tuner_ops.set_params) {
12105 u32 int_freq;
12106
12107 if (fe->ops.i2c_gate_ctrl)
12108 fe->ops.i2c_gate_ctrl(fe, 1);
12109
12110
12111 fe->ops.tuner_ops.set_params(fe);
12112
12113
12114 if (fe->ops.tuner_ops.get_if_frequency) {
12115 fe->ops.tuner_ops.get_if_frequency(fe, &int_freq);
12116 demod->my_common_attr->intermediate_freq = int_freq / 1000;
12117 }
12118
12119 if (fe->ops.i2c_gate_ctrl)
12120 fe->ops.i2c_gate_ctrl(fe, 0);
12121 }
12122
12123 switch (p->delivery_system) {
12124 case SYS_ATSC:
12125 standard = DRX_STANDARD_8VSB;
12126 break;
12127 case SYS_DVBC_ANNEX_B:
12128 standard = DRX_STANDARD_ITU_B;
12129
12130 switch (p->modulation) {
12131 case QAM_64:
12132 constellation = DRX_CONSTELLATION_QAM64;
12133 break;
12134 case QAM_256:
12135 constellation = DRX_CONSTELLATION_QAM256;
12136 break;
12137 default:
12138 constellation = DRX_CONSTELLATION_AUTO;
12139 break;
12140 }
12141 break;
12142 default:
12143 return -EINVAL;
12144 }
12145
12146 result = ctrl_set_standard(demod, &standard);
12147 if (result != 0) {
12148 pr_err("Failed to set standard! result=%02x\n",
12149 result);
12150 return -EINVAL;
12151 }
12152
12153
12154 channel = def_channel;
12155 channel.frequency = p->frequency / 1000;
12156 channel.bandwidth = DRX_BANDWIDTH_6MHZ;
12157 channel.constellation = constellation;
12158
12159
12160 result = ctrl_set_channel(demod, &channel);
12161 if (result != 0) {
12162 pr_err("Failed to set channel!\n");
12163 return -EINVAL;
12164 }
12165
12166 drxj_set_lna_state(demod, false);
12167
12168
12169 p->strength.stat[0].scale = FE_SCALE_RELATIVE;
12170
12171 return 0;
12172}
12173
12174static int drx39xxj_sleep(struct dvb_frontend *fe)
12175{
12176
12177 return drx39xxj_set_powerstate(fe, 0);
12178}
12179
12180static int drx39xxj_i2c_gate_ctrl(struct dvb_frontend *fe, int enable)
12181{
12182 struct drx39xxj_state *state = fe->demodulator_priv;
12183 struct drx_demod_instance *demod = state->demod;
12184 bool i2c_gate_state;
12185 int result;
12186
12187#ifdef DJH_DEBUG
12188 pr_debug("i2c gate call: enable=%d state=%d\n", enable,
12189 state->i2c_gate_open);
12190#endif
12191
12192 if (enable)
12193 i2c_gate_state = true;
12194 else
12195 i2c_gate_state = false;
12196
12197 if (state->i2c_gate_open == enable) {
12198
12199 return 0;
12200 }
12201
12202 result = ctrl_i2c_bridge(demod, &i2c_gate_state);
12203 if (result != 0) {
12204 pr_err("drx39xxj: could not open i2c gate [%d]\n",
12205 result);
12206 dump_stack();
12207 } else {
12208 state->i2c_gate_open = enable;
12209 }
12210 return 0;
12211}
12212
12213static int drx39xxj_init(struct dvb_frontend *fe)
12214{
12215 struct drx39xxj_state *state = fe->demodulator_priv;
12216 struct drx_demod_instance *demod = state->demod;
12217 int rc = 0;
12218
12219 if (fe->exit == DVB_FE_DEVICE_RESUME) {
12220
12221 demod->my_common_attr->is_opened = false;
12222 rc = drxj_open(demod);
12223 if (rc != 0)
12224 pr_err("drx39xxj_init(): DRX open failed rc=%d!\n", rc);
12225 } else
12226 drx39xxj_set_powerstate(fe, 1);
12227
12228 return rc;
12229}
12230
12231static int drx39xxj_set_lna(struct dvb_frontend *fe)
12232{
12233 struct dtv_frontend_properties *c = &fe->dtv_property_cache;
12234 struct drx39xxj_state *state = fe->demodulator_priv;
12235 struct drx_demod_instance *demod = state->demod;
12236 struct drxj_data *ext_attr = demod->my_ext_attr;
12237
12238 if (c->lna) {
12239 if (!ext_attr->has_lna) {
12240 pr_err("LNA is not supported on this device!\n");
12241 return -EINVAL;
12242
12243 }
12244 }
12245
12246 return drxj_set_lna_state(demod, c->lna);
12247}
12248
12249static int drx39xxj_get_tune_settings(struct dvb_frontend *fe,
12250 struct dvb_frontend_tune_settings *tune)
12251{
12252 tune->min_delay_ms = 1000;
12253 return 0;
12254}
12255
12256static void drx39xxj_release(struct dvb_frontend *fe)
12257{
12258 struct drx39xxj_state *state = fe->demodulator_priv;
12259 struct drx_demod_instance *demod = state->demod;
12260
12261
12262 if (fe->exit != DVB_FE_DEVICE_REMOVED)
12263 drxj_close(demod);
12264
12265 kfree(demod->my_ext_attr);
12266 kfree(demod->my_common_attr);
12267 kfree(demod->my_i2c_dev_addr);
12268 release_firmware(demod->firmware);
12269 kfree(demod);
12270 kfree(state);
12271}
12272
12273static const struct dvb_frontend_ops drx39xxj_ops;
12274
12275struct dvb_frontend *drx39xxj_attach(struct i2c_adapter *i2c)
12276{
12277 struct drx39xxj_state *state = NULL;
12278 struct i2c_device_addr *demod_addr = NULL;
12279 struct drx_common_attr *demod_comm_attr = NULL;
12280 struct drxj_data *demod_ext_attr = NULL;
12281 struct drx_demod_instance *demod = NULL;
12282 struct dtv_frontend_properties *p;
12283 int result;
12284
12285
12286 state = kzalloc(sizeof(struct drx39xxj_state), GFP_KERNEL);
12287 if (state == NULL)
12288 goto error;
12289
12290 demod = kmemdup(&drxj_default_demod_g,
12291 sizeof(struct drx_demod_instance), GFP_KERNEL);
12292 if (demod == NULL)
12293 goto error;
12294
12295 demod_addr = kmemdup(&drxj_default_addr_g,
12296 sizeof(struct i2c_device_addr), GFP_KERNEL);
12297 if (demod_addr == NULL)
12298 goto error;
12299
12300 demod_comm_attr = kmemdup(&drxj_default_comm_attr_g,
12301 sizeof(struct drx_common_attr), GFP_KERNEL);
12302 if (demod_comm_attr == NULL)
12303 goto error;
12304
12305 demod_ext_attr = kmemdup(&drxj_data_g, sizeof(struct drxj_data),
12306 GFP_KERNEL);
12307 if (demod_ext_attr == NULL)
12308 goto error;
12309
12310
12311 state->i2c = i2c;
12312 state->demod = demod;
12313
12314
12315 demod->my_i2c_dev_addr = demod_addr;
12316 demod->my_common_attr = demod_comm_attr;
12317 demod->my_i2c_dev_addr->user_data = state;
12318 demod->my_common_attr->microcode_file = DRX39XX_MAIN_FIRMWARE;
12319 demod->my_common_attr->verify_microcode = true;
12320 demod->my_common_attr->intermediate_freq = 5000;
12321 demod->my_common_attr->current_power_mode = DRX_POWER_DOWN;
12322 demod->my_ext_attr = demod_ext_attr;
12323 ((struct drxj_data *)demod_ext_attr)->uio_sma_tx_mode = DRX_UIO_MODE_READWRITE;
12324 demod->i2c = i2c;
12325
12326 result = drxj_open(demod);
12327 if (result != 0) {
12328 pr_err("DRX open failed! Aborting\n");
12329 goto error;
12330 }
12331
12332
12333 memcpy(&state->frontend.ops, &drx39xxj_ops,
12334 sizeof(struct dvb_frontend_ops));
12335
12336 state->frontend.demodulator_priv = state;
12337
12338
12339 p = &state->frontend.dtv_property_cache;
12340 p->strength.len = 1;
12341 p->pre_bit_count.len = 1;
12342 p->pre_bit_error.len = 1;
12343 p->post_bit_count.len = 1;
12344 p->post_bit_error.len = 1;
12345 p->block_count.len = 1;
12346 p->block_error.len = 1;
12347 p->cnr.len = 1;
12348
12349 p->strength.stat[0].scale = FE_SCALE_RELATIVE;
12350 p->pre_bit_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
12351 p->pre_bit_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
12352 p->post_bit_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
12353 p->post_bit_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
12354 p->block_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
12355 p->block_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
12356 p->cnr.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
12357
12358 return &state->frontend;
12359
12360error:
12361 kfree(demod_ext_attr);
12362 kfree(demod_comm_attr);
12363 kfree(demod_addr);
12364 kfree(demod);
12365 kfree(state);
12366
12367 return NULL;
12368}
12369EXPORT_SYMBOL(drx39xxj_attach);
12370
12371static const struct dvb_frontend_ops drx39xxj_ops = {
12372 .delsys = { SYS_ATSC, SYS_DVBC_ANNEX_B },
12373 .info = {
12374 .name = "Micronas DRX39xxj family Frontend",
12375 .frequency_min_hz = 51 * MHz,
12376 .frequency_max_hz = 858 * MHz,
12377 .frequency_stepsize_hz = 62500,
12378 .caps = FE_CAN_QAM_64 | FE_CAN_QAM_256 | FE_CAN_8VSB
12379 },
12380
12381 .init = drx39xxj_init,
12382 .i2c_gate_ctrl = drx39xxj_i2c_gate_ctrl,
12383 .sleep = drx39xxj_sleep,
12384 .set_frontend = drx39xxj_set_frontend,
12385 .get_tune_settings = drx39xxj_get_tune_settings,
12386 .read_status = drx39xxj_read_status,
12387 .read_ber = drx39xxj_read_ber,
12388 .read_signal_strength = drx39xxj_read_signal_strength,
12389 .read_snr = drx39xxj_read_snr,
12390 .read_ucblocks = drx39xxj_read_ucblocks,
12391 .release = drx39xxj_release,
12392 .set_lna = drx39xxj_set_lna,
12393};
12394
12395MODULE_DESCRIPTION("Micronas DRX39xxj Frontend");
12396MODULE_AUTHOR("Devin Heitmueller");
12397MODULE_LICENSE("GPL");
12398MODULE_FIRMWARE(DRX39XX_MAIN_FIRMWARE);
12399