2 Montage Technology DS3000 - DVBS/S2 Demodulator driver
3 Copyright (C) 2009-2012 Konstantin Dimitrov <kosio.dimitrov@gmail.com>
5 Copyright (C) 2009-2012 TurboSight.com
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 2 of the License, or
10 (at your option) any later version.
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with this program; if not, write to the Free Software
19 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
22 #include <linux/slab.h>
23 #include <linux/kernel.h>
24 #include <linux/module.h>
25 #include <linux/moduleparam.h>
26 #include <linux/init.h>
27 #include <linux/firmware.h>
29 #include "dvb_frontend.h"
35 #define dprintk(args...) \
41 /* as of March 2009 current DS3000 firmware version is 1.78 */
42 /* DS3000 FW v1.78 MD5: a32d17910c4f370073f9346e71d34b80 */
43 #define DS3000_DEFAULT_FIRMWARE "dvb-fe-ds3000.fw"
45 #define DS3000_SAMPLE_RATE 96000 /* in kHz */
47 /* Register values to initialise the demod in DVB-S mode */
48 static u8 ds3000_dvbs_init_tab
[] = {
132 /* Register values to initialise the demod in DVB-S2 mode */
133 static u8 ds3000_dvbs2_init_tab
[] = {
232 struct ds3000_state
{
233 struct i2c_adapter
*i2c
;
234 const struct ds3000_config
*config
;
235 struct dvb_frontend frontend
;
236 /* previous uncorrected block counter for DVB-S2 */
240 static int ds3000_writereg(struct ds3000_state
*state
, int reg
, int data
)
242 u8 buf
[] = { reg
, data
};
243 struct i2c_msg msg
= { .addr
= state
->config
->demod_address
,
244 .flags
= 0, .buf
= buf
, .len
= 2 };
247 dprintk("%s: write reg 0x%02x, value 0x%02x\n", __func__
, reg
, data
);
249 err
= i2c_transfer(state
->i2c
, &msg
, 1);
251 printk(KERN_ERR
"%s: writereg error(err == %i, reg == 0x%02x,"
252 " value == 0x%02x)\n", __func__
, err
, reg
, data
);
259 static int ds3000_i2c_gate_ctrl(struct dvb_frontend
*fe
, int enable
)
261 struct ds3000_state
*state
= fe
->demodulator_priv
;
264 ds3000_writereg(state
, 0x03, 0x12);
266 ds3000_writereg(state
, 0x03, 0x02);
271 /* I2C write for 8k firmware load */
272 static int ds3000_writeFW(struct ds3000_state
*state
, int reg
,
273 const u8
*data
, u16 len
)
279 buf
= kmalloc(33, GFP_KERNEL
);
281 printk(KERN_ERR
"Unable to kmalloc\n");
287 msg
.addr
= state
->config
->demod_address
;
292 for (i
= 0; i
< len
; i
+= 32) {
293 memcpy(buf
+ 1, data
+ i
, 32);
295 dprintk("%s: write reg 0x%02x, len = %d\n", __func__
, reg
, len
);
297 ret
= i2c_transfer(state
->i2c
, &msg
, 1);
299 printk(KERN_ERR
"%s: write error(err == %i, "
300 "reg == 0x%02x\n", __func__
, ret
, reg
);
313 static int ds3000_readreg(struct ds3000_state
*state
, u8 reg
)
318 struct i2c_msg msg
[] = {
320 .addr
= state
->config
->demod_address
,
325 .addr
= state
->config
->demod_address
,
332 ret
= i2c_transfer(state
->i2c
, msg
, 2);
335 printk(KERN_ERR
"%s: reg=0x%x(error=%d)\n", __func__
, reg
, ret
);
339 dprintk("%s: read reg 0x%02x, value 0x%02x\n", __func__
, reg
, b1
[0]);
344 static int ds3000_load_firmware(struct dvb_frontend
*fe
,
345 const struct firmware
*fw
);
347 static int ds3000_firmware_ondemand(struct dvb_frontend
*fe
)
349 struct ds3000_state
*state
= fe
->demodulator_priv
;
350 const struct firmware
*fw
;
353 dprintk("%s()\n", __func__
);
355 ret
= ds3000_readreg(state
, 0xb2);
360 /* request the firmware, this will block until someone uploads it */
361 printk(KERN_INFO
"%s: Waiting for firmware upload (%s)...\n", __func__
,
362 DS3000_DEFAULT_FIRMWARE
);
363 ret
= request_firmware(&fw
, DS3000_DEFAULT_FIRMWARE
,
364 state
->i2c
->dev
.parent
);
365 printk(KERN_INFO
"%s: Waiting for firmware upload(2)...\n", __func__
);
367 printk(KERN_ERR
"%s: No firmware uploaded (timeout or file not "
368 "found?)\n", __func__
);
372 ret
= ds3000_load_firmware(fe
, fw
);
374 printk("%s: Writing firmware to device failed\n", __func__
);
376 release_firmware(fw
);
378 dprintk("%s: Firmware upload %s\n", __func__
,
379 ret
== 0 ? "complete" : "failed");
384 static int ds3000_load_firmware(struct dvb_frontend
*fe
,
385 const struct firmware
*fw
)
387 struct ds3000_state
*state
= fe
->demodulator_priv
;
390 dprintk("%s\n", __func__
);
391 dprintk("Firmware is %zu bytes (%02x %02x .. %02x %02x)\n",
395 fw
->data
[fw
->size
- 2],
396 fw
->data
[fw
->size
- 1]);
398 /* Begin the firmware load process */
399 ds3000_writereg(state
, 0xb2, 0x01);
400 /* write the entire firmware */
401 ret
= ds3000_writeFW(state
, 0xb0, fw
->data
, fw
->size
);
402 ds3000_writereg(state
, 0xb2, 0x00);
407 static int ds3000_set_voltage(struct dvb_frontend
*fe
,
408 enum fe_sec_voltage voltage
)
410 struct ds3000_state
*state
= fe
->demodulator_priv
;
413 dprintk("%s(%d)\n", __func__
, voltage
);
415 data
= ds3000_readreg(state
, 0xa2);
416 data
|= 0x03; /* bit0 V/H, bit1 off/on */
426 case SEC_VOLTAGE_OFF
:
430 ds3000_writereg(state
, 0xa2, data
);
435 static int ds3000_read_status(struct dvb_frontend
*fe
, enum fe_status
*status
)
437 struct ds3000_state
*state
= fe
->demodulator_priv
;
438 struct dtv_frontend_properties
*c
= &fe
->dtv_property_cache
;
443 switch (c
->delivery_system
) {
445 lock
= ds3000_readreg(state
, 0xd1);
446 if ((lock
& 0x07) == 0x07)
447 *status
= FE_HAS_SIGNAL
| FE_HAS_CARRIER
|
448 FE_HAS_VITERBI
| FE_HAS_SYNC
|
453 lock
= ds3000_readreg(state
, 0x0d);
454 if ((lock
& 0x8f) == 0x8f)
455 *status
= FE_HAS_SIGNAL
| FE_HAS_CARRIER
|
456 FE_HAS_VITERBI
| FE_HAS_SYNC
|
464 if (state
->config
->set_lock_led
)
465 state
->config
->set_lock_led(fe
, *status
== 0 ? 0 : 1);
467 dprintk("%s: status = 0x%02x\n", __func__
, lock
);
472 /* read DS3000 BER value */
473 static int ds3000_read_ber(struct dvb_frontend
*fe
, u32
* ber
)
475 struct ds3000_state
*state
= fe
->demodulator_priv
;
476 struct dtv_frontend_properties
*c
= &fe
->dtv_property_cache
;
478 u32 ber_reading
, lpdc_frames
;
480 dprintk("%s()\n", __func__
);
482 switch (c
->delivery_system
) {
484 /* set the number of bytes checked during
486 ds3000_writereg(state
, 0xf9, 0x04);
487 /* read BER estimation status */
488 data
= ds3000_readreg(state
, 0xf8);
489 /* check if BER estimation is ready */
490 if ((data
& 0x10) == 0) {
491 /* this is the number of error bits,
492 to calculate the bit error rate
494 *ber
= (ds3000_readreg(state
, 0xf7) << 8) |
495 ds3000_readreg(state
, 0xf6);
496 /* start counting error bits */
497 /* need to be set twice
498 otherwise it fails sometimes */
500 ds3000_writereg(state
, 0xf8, data
);
501 ds3000_writereg(state
, 0xf8, data
);
503 /* used to indicate that BER estimation
504 is not ready, i.e. BER is unknown */
508 /* read the number of LPDC decoded frames */
509 lpdc_frames
= (ds3000_readreg(state
, 0xd7) << 16) |
510 (ds3000_readreg(state
, 0xd6) << 8) |
511 ds3000_readreg(state
, 0xd5);
512 /* read the number of packets with bad CRC */
513 ber_reading
= (ds3000_readreg(state
, 0xf8) << 8) |
514 ds3000_readreg(state
, 0xf7);
515 if (lpdc_frames
> 750) {
516 /* clear LPDC frame counters */
517 ds3000_writereg(state
, 0xd1, 0x01);
518 /* clear bad packets counter */
519 ds3000_writereg(state
, 0xf9, 0x01);
520 /* enable bad packets counter */
521 ds3000_writereg(state
, 0xf9, 0x00);
522 /* enable LPDC frame counters */
523 ds3000_writereg(state
, 0xd1, 0x00);
526 /* used to indicate that BER estimation is not ready,
527 i.e. BER is unknown */
537 static int ds3000_read_signal_strength(struct dvb_frontend
*fe
,
538 u16
*signal_strength
)
540 if (fe
->ops
.tuner_ops
.get_rf_strength
)
541 fe
->ops
.tuner_ops
.get_rf_strength(fe
, signal_strength
);
546 /* calculate DS3000 snr value in dB */
547 static int ds3000_read_snr(struct dvb_frontend
*fe
, u16
*snr
)
549 struct ds3000_state
*state
= fe
->demodulator_priv
;
550 struct dtv_frontend_properties
*c
= &fe
->dtv_property_cache
;
551 u8 snr_reading
, snr_value
;
552 u32 dvbs2_signal_reading
, dvbs2_noise_reading
, tmp
;
553 static const u16 dvbs_snr_tab
[] = { /* 20 x Table (rounded up) */
554 0x0000, 0x1b13, 0x2aea, 0x3627, 0x3ede, 0x45fe, 0x4c03,
555 0x513a, 0x55d4, 0x59f2, 0x5dab, 0x6111, 0x6431, 0x6717,
556 0x69c9, 0x6c4e, 0x6eac, 0x70e8, 0x7304, 0x7505
558 static const u16 dvbs2_snr_tab
[] = { /* 80 x Table (rounded up) */
559 0x0000, 0x0bc2, 0x12a3, 0x1785, 0x1b4e, 0x1e65, 0x2103,
560 0x2347, 0x2546, 0x2710, 0x28ae, 0x2a28, 0x2b83, 0x2cc5,
561 0x2df1, 0x2f09, 0x3010, 0x3109, 0x31f4, 0x32d2, 0x33a6,
562 0x3470, 0x3531, 0x35ea, 0x369b, 0x3746, 0x37ea, 0x3888,
563 0x3920, 0x39b3, 0x3a42, 0x3acc, 0x3b51, 0x3bd3, 0x3c51,
564 0x3ccb, 0x3d42, 0x3db6, 0x3e27, 0x3e95, 0x3f00, 0x3f68,
565 0x3fcf, 0x4033, 0x4094, 0x40f4, 0x4151, 0x41ac, 0x4206,
566 0x425e, 0x42b4, 0x4308, 0x435b, 0x43ac, 0x43fc, 0x444a,
567 0x4497, 0x44e2, 0x452d, 0x4576, 0x45bd, 0x4604, 0x4649,
568 0x468e, 0x46d1, 0x4713, 0x4755, 0x4795, 0x47d4, 0x4813,
569 0x4851, 0x488d, 0x48c9, 0x4904, 0x493f, 0x4978, 0x49b1,
570 0x49e9, 0x4a20, 0x4a57
573 dprintk("%s()\n", __func__
);
575 switch (c
->delivery_system
) {
577 snr_reading
= ds3000_readreg(state
, 0xff);
579 if (snr_reading
== 0)
582 if (snr_reading
> 20)
584 snr_value
= dvbs_snr_tab
[snr_reading
- 1] * 10 / 23026;
585 /* cook the value to be suitable for szap-s2
586 human readable output */
587 *snr
= snr_value
* 8 * 655;
589 dprintk("%s: raw / cooked = 0x%02x / 0x%04x\n", __func__
,
593 dvbs2_noise_reading
= (ds3000_readreg(state
, 0x8c) & 0x3f) +
594 (ds3000_readreg(state
, 0x8d) << 4);
595 dvbs2_signal_reading
= ds3000_readreg(state
, 0x8e);
596 tmp
= dvbs2_signal_reading
* dvbs2_signal_reading
>> 1;
601 if (dvbs2_noise_reading
== 0) {
603 /* cook the value to be suitable for szap-s2
604 human readable output */
608 if (tmp
> dvbs2_noise_reading
) {
609 snr_reading
= tmp
/ dvbs2_noise_reading
;
610 if (snr_reading
> 80)
612 snr_value
= dvbs2_snr_tab
[snr_reading
- 1] / 1000;
613 /* cook the value to be suitable for szap-s2
614 human readable output */
615 *snr
= snr_value
* 5 * 655;
617 snr_reading
= dvbs2_noise_reading
/ tmp
;
618 if (snr_reading
> 80)
620 *snr
= -(dvbs2_snr_tab
[snr_reading
- 1] / 1000);
622 dprintk("%s: raw / cooked = 0x%02x / 0x%04x\n", __func__
,
632 /* read DS3000 uncorrected blocks */
633 static int ds3000_read_ucblocks(struct dvb_frontend
*fe
, u32
*ucblocks
)
635 struct ds3000_state
*state
= fe
->demodulator_priv
;
636 struct dtv_frontend_properties
*c
= &fe
->dtv_property_cache
;
640 dprintk("%s()\n", __func__
);
642 switch (c
->delivery_system
) {
644 *ucblocks
= (ds3000_readreg(state
, 0xf5) << 8) |
645 ds3000_readreg(state
, 0xf4);
646 data
= ds3000_readreg(state
, 0xf8);
647 /* clear packet counters */
649 ds3000_writereg(state
, 0xf8, data
);
650 /* enable packet counters */
652 ds3000_writereg(state
, 0xf8, data
);
655 _ucblocks
= (ds3000_readreg(state
, 0xe2) << 8) |
656 ds3000_readreg(state
, 0xe1);
657 if (_ucblocks
> state
->prevUCBS2
)
658 *ucblocks
= _ucblocks
- state
->prevUCBS2
;
660 *ucblocks
= state
->prevUCBS2
- _ucblocks
;
661 state
->prevUCBS2
= _ucblocks
;
670 static int ds3000_set_tone(struct dvb_frontend
*fe
, enum fe_sec_tone_mode tone
)
672 struct ds3000_state
*state
= fe
->demodulator_priv
;
675 dprintk("%s(%d)\n", __func__
, tone
);
676 if ((tone
!= SEC_TONE_ON
) && (tone
!= SEC_TONE_OFF
)) {
677 printk(KERN_ERR
"%s: Invalid, tone=%d\n", __func__
, tone
);
681 data
= ds3000_readreg(state
, 0xa2);
683 ds3000_writereg(state
, 0xa2, data
);
687 dprintk("%s: setting tone on\n", __func__
);
688 data
= ds3000_readreg(state
, 0xa1);
691 ds3000_writereg(state
, 0xa1, data
);
694 dprintk("%s: setting tone off\n", __func__
);
695 data
= ds3000_readreg(state
, 0xa2);
697 ds3000_writereg(state
, 0xa2, data
);
704 static int ds3000_send_diseqc_msg(struct dvb_frontend
*fe
,
705 struct dvb_diseqc_master_cmd
*d
)
707 struct ds3000_state
*state
= fe
->demodulator_priv
;
711 /* Dump DiSEqC message */
712 dprintk("%s(", __func__
);
713 for (i
= 0 ; i
< d
->msg_len
;) {
714 dprintk("0x%02x", d
->msg
[i
]);
715 if (++i
< d
->msg_len
)
719 /* enable DiSEqC message send pin */
720 data
= ds3000_readreg(state
, 0xa2);
722 ds3000_writereg(state
, 0xa2, data
);
725 for (i
= 0; i
< d
->msg_len
; i
++)
726 ds3000_writereg(state
, 0xa3 + i
, d
->msg
[i
]);
728 data
= ds3000_readreg(state
, 0xa1);
729 /* clear DiSEqC message length and status,
730 enable DiSEqC message send */
732 /* set DiSEqC mode, modulation active during 33 pulses,
733 set DiSEqC message length */
734 data
|= ((d
->msg_len
- 1) << 3) | 0x07;
735 ds3000_writereg(state
, 0xa1, data
);
737 /* wait up to 150ms for DiSEqC transmission to complete */
738 for (i
= 0; i
< 15; i
++) {
739 data
= ds3000_readreg(state
, 0xa1);
740 if ((data
& 0x40) == 0)
745 /* DiSEqC timeout after 150ms */
747 data
= ds3000_readreg(state
, 0xa1);
750 ds3000_writereg(state
, 0xa1, data
);
752 data
= ds3000_readreg(state
, 0xa2);
755 ds3000_writereg(state
, 0xa2, data
);
760 data
= ds3000_readreg(state
, 0xa2);
763 ds3000_writereg(state
, 0xa2, data
);
768 /* Send DiSEqC burst */
769 static int ds3000_diseqc_send_burst(struct dvb_frontend
*fe
,
770 enum fe_sec_mini_cmd burst
)
772 struct ds3000_state
*state
= fe
->demodulator_priv
;
776 dprintk("%s()\n", __func__
);
778 data
= ds3000_readreg(state
, 0xa2);
780 ds3000_writereg(state
, 0xa2, data
);
783 if (burst
== SEC_MINI_A
)
784 /* Unmodulated tone burst */
785 ds3000_writereg(state
, 0xa1, 0x02);
786 else if (burst
== SEC_MINI_B
)
787 /* Modulated tone burst */
788 ds3000_writereg(state
, 0xa1, 0x01);
793 for (i
= 0; i
< 5; i
++) {
794 data
= ds3000_readreg(state
, 0xa1);
795 if ((data
& 0x40) == 0)
801 data
= ds3000_readreg(state
, 0xa1);
804 ds3000_writereg(state
, 0xa1, data
);
806 data
= ds3000_readreg(state
, 0xa2);
809 ds3000_writereg(state
, 0xa2, data
);
814 data
= ds3000_readreg(state
, 0xa2);
817 ds3000_writereg(state
, 0xa2, data
);
822 static void ds3000_release(struct dvb_frontend
*fe
)
824 struct ds3000_state
*state
= fe
->demodulator_priv
;
826 if (state
->config
->set_lock_led
)
827 state
->config
->set_lock_led(fe
, 0);
829 dprintk("%s\n", __func__
);
833 static struct dvb_frontend_ops ds3000_ops
;
835 struct dvb_frontend
*ds3000_attach(const struct ds3000_config
*config
,
836 struct i2c_adapter
*i2c
)
838 struct ds3000_state
*state
= NULL
;
841 dprintk("%s\n", __func__
);
843 /* allocate memory for the internal state */
844 state
= kzalloc(sizeof(struct ds3000_state
), GFP_KERNEL
);
846 printk(KERN_ERR
"Unable to kmalloc\n");
850 state
->config
= config
;
852 state
->prevUCBS2
= 0;
854 /* check if the demod is present */
855 ret
= ds3000_readreg(state
, 0x00) & 0xfe;
857 printk(KERN_ERR
"Invalid probe, probably not a DS3000\n");
861 printk(KERN_INFO
"DS3000 chip version: %d.%d attached.\n",
862 ds3000_readreg(state
, 0x02),
863 ds3000_readreg(state
, 0x01));
865 memcpy(&state
->frontend
.ops
, &ds3000_ops
,
866 sizeof(struct dvb_frontend_ops
));
867 state
->frontend
.demodulator_priv
= state
;
870 * Some devices like T480 starts with voltage on. Be sure
871 * to turn voltage off during init, as this can otherwise
872 * interfere with Unicable SCR systems.
874 ds3000_set_voltage(&state
->frontend
, SEC_VOLTAGE_OFF
);
875 return &state
->frontend
;
882 EXPORT_SYMBOL(ds3000_attach
);
884 static int ds3000_set_carrier_offset(struct dvb_frontend
*fe
,
885 s32 carrier_offset_khz
)
887 struct ds3000_state
*state
= fe
->demodulator_priv
;
890 tmp
= carrier_offset_khz
;
892 tmp
= (2 * tmp
+ DS3000_SAMPLE_RATE
) / (2 * DS3000_SAMPLE_RATE
);
897 ds3000_writereg(state
, 0x5f, tmp
>> 8);
898 ds3000_writereg(state
, 0x5e, tmp
& 0xff);
903 static int ds3000_set_frontend(struct dvb_frontend
*fe
)
905 struct ds3000_state
*state
= fe
->demodulator_priv
;
906 struct dtv_frontend_properties
*c
= &fe
->dtv_property_cache
;
909 enum fe_status status
;
914 dprintk("%s() ", __func__
);
916 if (state
->config
->set_ts_params
)
917 state
->config
->set_ts_params(fe
, 0);
919 if (fe
->ops
.tuner_ops
.set_params
)
920 fe
->ops
.tuner_ops
.set_params(fe
);
922 /* ds3000 global reset */
923 ds3000_writereg(state
, 0x07, 0x80);
924 ds3000_writereg(state
, 0x07, 0x00);
925 /* ds3000 build-in uC reset */
926 ds3000_writereg(state
, 0xb2, 0x01);
927 /* ds3000 software reset */
928 ds3000_writereg(state
, 0x00, 0x01);
930 switch (c
->delivery_system
) {
932 /* initialise the demod in DVB-S mode */
933 for (i
= 0; i
< sizeof(ds3000_dvbs_init_tab
); i
+= 2)
934 ds3000_writereg(state
,
935 ds3000_dvbs_init_tab
[i
],
936 ds3000_dvbs_init_tab
[i
+ 1]);
937 value
= ds3000_readreg(state
, 0xfe);
940 ds3000_writereg(state
, 0xfe, value
);
943 /* initialise the demod in DVB-S2 mode */
944 for (i
= 0; i
< sizeof(ds3000_dvbs2_init_tab
); i
+= 2)
945 ds3000_writereg(state
,
946 ds3000_dvbs2_init_tab
[i
],
947 ds3000_dvbs2_init_tab
[i
+ 1]);
948 if (c
->symbol_rate
>= 30000000)
949 ds3000_writereg(state
, 0xfe, 0x54);
951 ds3000_writereg(state
, 0xfe, 0x98);
957 /* enable 27MHz clock output */
958 ds3000_writereg(state
, 0x29, 0x80);
959 /* enable ac coupling */
960 ds3000_writereg(state
, 0x25, 0x8a);
962 /* enhance symbol rate performance */
963 if ((c
->symbol_rate
/ 1000) <= 5000) {
964 value
= 29777 / (c
->symbol_rate
/ 1000) + 1;
967 ds3000_writereg(state
, 0xc3, 0x0d);
968 ds3000_writereg(state
, 0xc8, value
);
969 ds3000_writereg(state
, 0xc4, 0x10);
970 ds3000_writereg(state
, 0xc7, 0x0e);
971 } else if ((c
->symbol_rate
/ 1000) <= 10000) {
972 value
= 92166 / (c
->symbol_rate
/ 1000) + 1;
975 ds3000_writereg(state
, 0xc3, 0x07);
976 ds3000_writereg(state
, 0xc8, value
);
977 ds3000_writereg(state
, 0xc4, 0x09);
978 ds3000_writereg(state
, 0xc7, 0x12);
979 } else if ((c
->symbol_rate
/ 1000) <= 20000) {
980 value
= 64516 / (c
->symbol_rate
/ 1000) + 1;
981 ds3000_writereg(state
, 0xc3, value
);
982 ds3000_writereg(state
, 0xc8, 0x0e);
983 ds3000_writereg(state
, 0xc4, 0x07);
984 ds3000_writereg(state
, 0xc7, 0x18);
986 value
= 129032 / (c
->symbol_rate
/ 1000) + 1;
987 ds3000_writereg(state
, 0xc3, value
);
988 ds3000_writereg(state
, 0xc8, 0x0a);
989 ds3000_writereg(state
, 0xc4, 0x05);
990 ds3000_writereg(state
, 0xc7, 0x24);
993 /* normalized symbol rate rounded to the closest integer */
994 value
= (((c
->symbol_rate
/ 1000) << 16) +
995 (DS3000_SAMPLE_RATE
/ 2)) / DS3000_SAMPLE_RATE
;
996 ds3000_writereg(state
, 0x61, value
& 0x00ff);
997 ds3000_writereg(state
, 0x62, (value
& 0xff00) >> 8);
999 /* co-channel interference cancellation disabled */
1000 ds3000_writereg(state
, 0x56, 0x00);
1002 /* equalizer disabled */
1003 ds3000_writereg(state
, 0x76, 0x00);
1005 /*ds3000_writereg(state, 0x08, 0x03);
1006 ds3000_writereg(state, 0xfd, 0x22);
1007 ds3000_writereg(state, 0x08, 0x07);
1008 ds3000_writereg(state, 0xfd, 0x42);
1009 ds3000_writereg(state, 0x08, 0x07);*/
1011 if (state
->config
->ci_mode
) {
1012 switch (c
->delivery_system
) {
1015 ds3000_writereg(state
, 0xfd, 0x80);
1018 ds3000_writereg(state
, 0xfd, 0x01);
1023 /* ds3000 out of software reset */
1024 ds3000_writereg(state
, 0x00, 0x00);
1025 /* start ds3000 build-in uC */
1026 ds3000_writereg(state
, 0xb2, 0x00);
1028 if (fe
->ops
.tuner_ops
.get_frequency
) {
1029 fe
->ops
.tuner_ops
.get_frequency(fe
, &frequency
);
1030 offset_khz
= frequency
- c
->frequency
;
1031 ds3000_set_carrier_offset(fe
, offset_khz
);
1034 for (i
= 0; i
< 30 ; i
++) {
1035 ds3000_read_status(fe
, &status
);
1036 if (status
& FE_HAS_LOCK
)
1045 static int ds3000_tune(struct dvb_frontend
*fe
,
1047 unsigned int mode_flags
,
1048 unsigned int *delay
,
1049 enum fe_status
*status
)
1052 int ret
= ds3000_set_frontend(fe
);
1059 return ds3000_read_status(fe
, status
);
1062 static enum dvbfe_algo
ds3000_get_algo(struct dvb_frontend
*fe
)
1064 struct ds3000_state
*state
= fe
->demodulator_priv
;
1066 if (state
->config
->set_lock_led
)
1067 state
->config
->set_lock_led(fe
, 0);
1069 dprintk("%s()\n", __func__
);
1070 return DVBFE_ALGO_HW
;
1074 * Initialise or wake up device
1076 * Power config will reset and load initial firmware if required
1078 static int ds3000_initfe(struct dvb_frontend
*fe
)
1080 struct ds3000_state
*state
= fe
->demodulator_priv
;
1083 dprintk("%s()\n", __func__
);
1085 ds3000_writereg(state
, 0x08, 0x01 | ds3000_readreg(state
, 0x08));
1088 /* Load the firmware if required */
1089 ret
= ds3000_firmware_ondemand(fe
);
1091 printk(KERN_ERR
"%s: Unable initialize firmware\n", __func__
);
1098 static struct dvb_frontend_ops ds3000_ops
= {
1099 .delsys
= { SYS_DVBS
, SYS_DVBS2
},
1101 .name
= "Montage Technology DS3000",
1102 .frequency_min
= 950000,
1103 .frequency_max
= 2150000,
1104 .frequency_stepsize
= 1011, /* kHz for QPSK frontends */
1105 .frequency_tolerance
= 5000,
1106 .symbol_rate_min
= 1000000,
1107 .symbol_rate_max
= 45000000,
1108 .caps
= FE_CAN_INVERSION_AUTO
|
1109 FE_CAN_FEC_1_2
| FE_CAN_FEC_2_3
| FE_CAN_FEC_3_4
|
1110 FE_CAN_FEC_4_5
| FE_CAN_FEC_5_6
| FE_CAN_FEC_6_7
|
1111 FE_CAN_FEC_7_8
| FE_CAN_FEC_AUTO
|
1112 FE_CAN_2G_MODULATION
|
1113 FE_CAN_QPSK
| FE_CAN_RECOVER
1116 .release
= ds3000_release
,
1118 .init
= ds3000_initfe
,
1119 .i2c_gate_ctrl
= ds3000_i2c_gate_ctrl
,
1120 .read_status
= ds3000_read_status
,
1121 .read_ber
= ds3000_read_ber
,
1122 .read_signal_strength
= ds3000_read_signal_strength
,
1123 .read_snr
= ds3000_read_snr
,
1124 .read_ucblocks
= ds3000_read_ucblocks
,
1125 .set_voltage
= ds3000_set_voltage
,
1126 .set_tone
= ds3000_set_tone
,
1127 .diseqc_send_master_cmd
= ds3000_send_diseqc_msg
,
1128 .diseqc_send_burst
= ds3000_diseqc_send_burst
,
1129 .get_frontend_algo
= ds3000_get_algo
,
1131 .set_frontend
= ds3000_set_frontend
,
1132 .tune
= ds3000_tune
,
1135 module_param(debug
, int, 0644);
1136 MODULE_PARM_DESC(debug
, "Activates frontend debugging (default:0)");
1138 MODULE_DESCRIPTION("DVB Frontend module for Montage Technology "
1140 MODULE_AUTHOR("Konstantin Dimitrov <kosio.dimitrov@gmail.com>");
1141 MODULE_LICENSE("GPL");
1142 MODULE_FIRMWARE(DS3000_DEFAULT_FIRMWARE
);