2019-05-27 09:55:06 +03:00
/* SPDX-License-Identifier: GPL-2.0-or-later */
2013-02-25 15:39:16 +04:00
/*
2015-04-17 03:36:00 +03:00
* Montage Technology M88DS3103 / M88RS6000 demodulator driver
2013-02-25 15:39:16 +04:00
*
* Copyright ( C ) 2013 Antti Palosaari < crope @ iki . fi >
*/
# ifndef M88DS3103_PRIV_H
# define M88DS3103_PRIV_H
2017-12-28 21:03:51 +03:00
# include <media/dvb_frontend.h>
2013-02-25 15:39:16 +04:00
# include "m88ds3103.h"
2017-12-28 21:03:51 +03:00
# include <media/dvb_math.h>
2013-02-25 15:39:16 +04:00
# include <linux/firmware.h>
2013-11-20 03:32:42 +04:00
# include <linux/i2c-mux.h>
2015-04-17 04:43:52 +03:00
# include <linux/regmap.h>
2014-07-10 15:17:58 +04:00
# include <linux/math64.h>
2013-02-25 15:39:16 +04:00
2020-02-02 00:48:24 +03:00
# define M88DS3103B_FIRMWARE "dvb-demod-m88ds3103b.fw"
# define M88DS3103_FIRMWARE "dvb-demod-m88ds3103.fw"
# define M88RS6000_FIRMWARE "dvb-demod-m88rs6000.fw"
2014-10-30 11:01:14 +03:00
# define M88RS6000_CHIP_ID 0x74
# define M88DS3103_CHIP_ID 0x70
2013-02-25 15:39:16 +04:00
2020-02-02 00:48:24 +03:00
# define M88DS3103_CHIPTYPE_3103 0
# define M88DS3103_CHIPTYPE_RS6000 1
# define M88DS3103_CHIPTYPE_3103B 2
2015-04-17 03:36:00 +03:00
struct m88ds3103_dev {
2015-04-17 02:04:55 +03:00
struct i2c_client * client ;
2020-02-02 00:48:24 +03:00
struct i2c_client * dt_client ;
2015-04-17 04:43:52 +03:00
struct regmap_config regmap_config ;
struct regmap * regmap ;
2015-04-17 02:04:55 +03:00
struct m88ds3103_config config ;
2013-02-25 15:39:16 +04:00
const struct m88ds3103_config * cfg ;
struct dvb_frontend fe ;
2015-06-07 20:53:52 +03:00
enum fe_delivery_system delivery_system ;
enum fe_status fe_status ;
2015-04-14 15:44:20 +03:00
u32 dvbv3_ber ; /* for old DVBv3 API read_ber */
2013-02-25 15:39:16 +04:00
bool warm ; /* FW running */
2016-04-20 09:41:02 +03:00
struct i2c_mux_core * muxc ;
2014-10-30 11:01:14 +03:00
/* auto detect chip id to do different config */
u8 chip_id ;
2020-02-02 00:48:24 +03:00
/* chip type to differentiate m88rs6000 from m88ds3103b */
u8 chiptype ;
2014-10-30 11:01:14 +03:00
/* main mclk is calculated for M88RS6000 dynamically */
2016-06-30 02:39:47 +03:00
s32 mclk ;
2015-04-14 15:44:20 +03:00
u64 post_bit_error ;
u64 post_bit_count ;
2020-02-02 00:48:24 +03:00
u8 dt_addr ;
2013-02-25 15:39:16 +04:00
} ;
struct m88ds3103_reg_val {
u8 reg ;
u8 val ;
} ;
static const struct m88ds3103_reg_val m88ds3103_dvbs_init_reg_vals [ ] = {
{ 0x23 , 0x07 } ,
{ 0x08 , 0x03 } ,
{ 0x0c , 0x02 } ,
{ 0x21 , 0x54 } ,
{ 0x25 , 0x8a } ,
{ 0x27 , 0x31 } ,
{ 0x30 , 0x08 } ,
{ 0x31 , 0x40 } ,
{ 0x32 , 0x32 } ,
{ 0x35 , 0xff } ,
{ 0x3a , 0x00 } ,
{ 0x37 , 0x10 } ,
{ 0x38 , 0x10 } ,
{ 0x39 , 0x02 } ,
{ 0x42 , 0x60 } ,
{ 0x4a , 0x80 } ,
{ 0x4b , 0x04 } ,
{ 0x4d , 0x91 } ,
{ 0x5d , 0xc8 } ,
{ 0x50 , 0x36 } ,
{ 0x51 , 0x36 } ,
{ 0x52 , 0x36 } ,
{ 0x53 , 0x36 } ,
2013-12-02 20:38:53 +04:00
{ 0x56 , 0x01 } ,
2013-02-25 15:39:16 +04:00
{ 0x63 , 0x0f } ,
{ 0x64 , 0x30 } ,
{ 0x65 , 0x40 } ,
{ 0x68 , 0x26 } ,
{ 0x69 , 0x4c } ,
{ 0x70 , 0x20 } ,
{ 0x71 , 0x70 } ,
{ 0x72 , 0x04 } ,
{ 0x73 , 0x00 } ,
{ 0x70 , 0x40 } ,
{ 0x71 , 0x70 } ,
{ 0x72 , 0x04 } ,
{ 0x73 , 0x00 } ,
{ 0x70 , 0x60 } ,
{ 0x71 , 0x70 } ,
{ 0x72 , 0x04 } ,
{ 0x73 , 0x00 } ,
{ 0x70 , 0x80 } ,
{ 0x71 , 0x70 } ,
{ 0x72 , 0x04 } ,
{ 0x73 , 0x00 } ,
{ 0x70 , 0xa0 } ,
{ 0x71 , 0x70 } ,
{ 0x72 , 0x04 } ,
{ 0x73 , 0x00 } ,
{ 0x70 , 0x1f } ,
{ 0x76 , 0x38 } ,
{ 0x77 , 0xa6 } ,
{ 0x78 , 0x0c } ,
{ 0x79 , 0x80 } ,
{ 0x7f , 0x14 } ,
{ 0x7c , 0x00 } ,
{ 0xae , 0x82 } ,
{ 0x80 , 0x64 } ,
{ 0x81 , 0x66 } ,
{ 0x82 , 0x44 } ,
{ 0x85 , 0x04 } ,
{ 0xcd , 0xf4 } ,
{ 0x90 , 0x33 } ,
{ 0xa0 , 0x44 } ,
{ 0xc0 , 0x08 } ,
{ 0xc3 , 0x10 } ,
{ 0xc4 , 0x08 } ,
{ 0xc5 , 0xf0 } ,
{ 0xc6 , 0xff } ,
{ 0xc7 , 0x00 } ,
{ 0xc8 , 0x1a } ,
{ 0xc9 , 0x80 } ,
{ 0xe0 , 0xf8 } ,
{ 0xe6 , 0x8b } ,
{ 0xd0 , 0x40 } ,
{ 0xf8 , 0x20 } ,
{ 0xfa , 0x0f } ,
{ 0x00 , 0x00 } ,
{ 0xbd , 0x01 } ,
{ 0xb8 , 0x00 } ,
} ;
static const struct m88ds3103_reg_val m88ds3103_dvbs2_init_reg_vals [ ] = {
{ 0x23 , 0x07 } ,
{ 0x08 , 0x07 } ,
{ 0x0c , 0x02 } ,
{ 0x21 , 0x54 } ,
{ 0x25 , 0x8a } ,
{ 0x27 , 0x31 } ,
{ 0x30 , 0x08 } ,
{ 0x32 , 0x32 } ,
{ 0x35 , 0xff } ,
{ 0x3a , 0x00 } ,
{ 0x37 , 0x10 } ,
{ 0x38 , 0x10 } ,
{ 0x39 , 0x02 } ,
{ 0x42 , 0x60 } ,
{ 0x4a , 0x80 } ,
{ 0x4b , 0x04 } ,
{ 0x4d , 0x91 } ,
{ 0x5d , 0xc8 } ,
{ 0x50 , 0x36 } ,
{ 0x51 , 0x36 } ,
{ 0x52 , 0x36 } ,
{ 0x53 , 0x36 } ,
2013-12-02 20:38:53 +04:00
{ 0x56 , 0x01 } ,
2013-02-25 15:39:16 +04:00
{ 0x63 , 0x0f } ,
{ 0x64 , 0x10 } ,
{ 0x65 , 0x20 } ,
{ 0x68 , 0x46 } ,
{ 0x69 , 0xcd } ,
{ 0x70 , 0x20 } ,
{ 0x71 , 0x70 } ,
{ 0x72 , 0x04 } ,
{ 0x73 , 0x00 } ,
{ 0x70 , 0x40 } ,
{ 0x71 , 0x70 } ,
{ 0x72 , 0x04 } ,
{ 0x73 , 0x00 } ,
{ 0x70 , 0x60 } ,
{ 0x71 , 0x70 } ,
{ 0x72 , 0x04 } ,
{ 0x73 , 0x00 } ,
{ 0x70 , 0x80 } ,
{ 0x71 , 0x70 } ,
{ 0x72 , 0x04 } ,
{ 0x73 , 0x00 } ,
{ 0x70 , 0xa0 } ,
{ 0x71 , 0x70 } ,
{ 0x72 , 0x04 } ,
{ 0x73 , 0x00 } ,
{ 0x70 , 0x1f } ,
{ 0x76 , 0x38 } ,
{ 0x77 , 0xa6 } ,
{ 0x78 , 0x0c } ,
{ 0x79 , 0x80 } ,
{ 0x7f , 0x14 } ,
{ 0x85 , 0x08 } ,
{ 0xcd , 0xf4 } ,
{ 0x90 , 0x33 } ,
{ 0x86 , 0x00 } ,
{ 0x87 , 0x0f } ,
{ 0x89 , 0x00 } ,
{ 0x8b , 0x44 } ,
{ 0x8c , 0x66 } ,
{ 0x9d , 0xc1 } ,
{ 0x8a , 0x10 } ,
{ 0xad , 0x40 } ,
{ 0xa0 , 0x44 } ,
{ 0xc0 , 0x08 } ,
{ 0xc1 , 0x10 } ,
{ 0xc2 , 0x08 } ,
{ 0xc3 , 0x10 } ,
{ 0xc4 , 0x08 } ,
{ 0xc5 , 0xf0 } ,
{ 0xc6 , 0xff } ,
{ 0xc7 , 0x00 } ,
{ 0xc8 , 0x1a } ,
{ 0xc9 , 0x80 } ,
{ 0xca , 0x23 } ,
{ 0xcb , 0x24 } ,
{ 0xcc , 0xf4 } ,
{ 0xce , 0x74 } ,
{ 0x00 , 0x00 } ,
{ 0xbd , 0x01 } ,
{ 0xb8 , 0x00 } ,
} ;
2014-10-30 11:01:14 +03:00
static const struct m88ds3103_reg_val m88rs6000_dvbs_init_reg_vals [ ] = {
{ 0x23 , 0x07 } ,
{ 0x08 , 0x03 } ,
{ 0x0c , 0x02 } ,
{ 0x20 , 0x00 } ,
{ 0x21 , 0x54 } ,
{ 0x25 , 0x82 } ,
{ 0x27 , 0x31 } ,
{ 0x30 , 0x08 } ,
{ 0x31 , 0x40 } ,
{ 0x32 , 0x32 } ,
{ 0x33 , 0x35 } ,
{ 0x35 , 0xff } ,
{ 0x3a , 0x00 } ,
{ 0x37 , 0x10 } ,
{ 0x38 , 0x10 } ,
{ 0x39 , 0x02 } ,
{ 0x42 , 0x60 } ,
{ 0x4a , 0x80 } ,
{ 0x4b , 0x04 } ,
{ 0x4d , 0x91 } ,
{ 0x5d , 0xc8 } ,
{ 0x50 , 0x36 } ,
{ 0x51 , 0x36 } ,
{ 0x52 , 0x36 } ,
{ 0x53 , 0x36 } ,
{ 0x63 , 0x0f } ,
{ 0x64 , 0x30 } ,
{ 0x65 , 0x40 } ,
{ 0x68 , 0x26 } ,
{ 0x69 , 0x4c } ,
{ 0x70 , 0x20 } ,
{ 0x71 , 0x70 } ,
{ 0x72 , 0x04 } ,
{ 0x73 , 0x00 } ,
{ 0x70 , 0x40 } ,
{ 0x71 , 0x70 } ,
{ 0x72 , 0x04 } ,
{ 0x73 , 0x00 } ,
{ 0x70 , 0x60 } ,
{ 0x71 , 0x70 } ,
{ 0x72 , 0x04 } ,
{ 0x73 , 0x00 } ,
{ 0x70 , 0x80 } ,
{ 0x71 , 0x70 } ,
{ 0x72 , 0x04 } ,
{ 0x73 , 0x00 } ,
{ 0x70 , 0xa0 } ,
{ 0x71 , 0x70 } ,
{ 0x72 , 0x04 } ,
{ 0x73 , 0x00 } ,
{ 0x70 , 0x1f } ,
{ 0x76 , 0x38 } ,
{ 0x77 , 0xa6 } ,
{ 0x78 , 0x0c } ,
{ 0x79 , 0x80 } ,
{ 0x7f , 0x14 } ,
{ 0x7c , 0x00 } ,
{ 0xae , 0x82 } ,
{ 0x80 , 0x64 } ,
{ 0x81 , 0x66 } ,
{ 0x82 , 0x44 } ,
{ 0x85 , 0x04 } ,
{ 0xcd , 0xf4 } ,
{ 0x90 , 0x33 } ,
{ 0xa0 , 0x44 } ,
{ 0xbe , 0x00 } ,
{ 0xc0 , 0x08 } ,
{ 0xc3 , 0x10 } ,
{ 0xc4 , 0x08 } ,
{ 0xc5 , 0xf0 } ,
{ 0xc6 , 0xff } ,
{ 0xc7 , 0x00 } ,
{ 0xc8 , 0x1a } ,
{ 0xc9 , 0x80 } ,
{ 0xe0 , 0xf8 } ,
{ 0xe6 , 0x8b } ,
{ 0xd0 , 0x40 } ,
{ 0xf8 , 0x20 } ,
{ 0xfa , 0x0f } ,
{ 0x00 , 0x00 } ,
{ 0xbd , 0x01 } ,
{ 0xb8 , 0x00 } ,
{ 0x29 , 0x11 } ,
} ;
static const struct m88ds3103_reg_val m88rs6000_dvbs2_init_reg_vals [ ] = {
{ 0x23 , 0x07 } ,
{ 0x08 , 0x07 } ,
{ 0x0c , 0x02 } ,
{ 0x20 , 0x00 } ,
{ 0x21 , 0x54 } ,
{ 0x25 , 0x82 } ,
{ 0x27 , 0x31 } ,
{ 0x30 , 0x08 } ,
{ 0x32 , 0x32 } ,
{ 0x33 , 0x35 } ,
{ 0x35 , 0xff } ,
{ 0x3a , 0x00 } ,
{ 0x37 , 0x10 } ,
{ 0x38 , 0x10 } ,
{ 0x39 , 0x02 } ,
{ 0x42 , 0x60 } ,
{ 0x4a , 0x80 } ,
{ 0x4b , 0x04 } ,
{ 0x4d , 0x91 } ,
{ 0x5d , 0xc8 } ,
{ 0x50 , 0x36 } ,
{ 0x51 , 0x36 } ,
{ 0x52 , 0x36 } ,
{ 0x53 , 0x36 } ,
{ 0x63 , 0x0f } ,
{ 0x64 , 0x10 } ,
{ 0x65 , 0x20 } ,
{ 0x68 , 0x46 } ,
{ 0x69 , 0xcd } ,
{ 0x70 , 0x20 } ,
{ 0x71 , 0x70 } ,
{ 0x72 , 0x04 } ,
{ 0x73 , 0x00 } ,
{ 0x70 , 0x40 } ,
{ 0x71 , 0x70 } ,
{ 0x72 , 0x04 } ,
{ 0x73 , 0x00 } ,
{ 0x70 , 0x60 } ,
{ 0x71 , 0x70 } ,
{ 0x72 , 0x04 } ,
{ 0x73 , 0x00 } ,
{ 0x70 , 0x80 } ,
{ 0x71 , 0x70 } ,
{ 0x72 , 0x04 } ,
{ 0x73 , 0x00 } ,
{ 0x70 , 0xa0 } ,
{ 0x71 , 0x70 } ,
{ 0x72 , 0x04 } ,
{ 0x73 , 0x00 } ,
{ 0x70 , 0x1f } ,
{ 0x76 , 0x38 } ,
{ 0x77 , 0xa6 } ,
{ 0x78 , 0x0c } ,
{ 0x79 , 0x80 } ,
{ 0x7f , 0x14 } ,
{ 0x85 , 0x08 } ,
{ 0xcd , 0xf4 } ,
{ 0x90 , 0x33 } ,
{ 0x86 , 0x00 } ,
{ 0x87 , 0x0f } ,
{ 0x89 , 0x00 } ,
{ 0x8b , 0x44 } ,
{ 0x8c , 0x66 } ,
{ 0x9d , 0xc1 } ,
{ 0x8a , 0x10 } ,
{ 0xad , 0x40 } ,
{ 0xa0 , 0x44 } ,
{ 0xbe , 0x00 } ,
{ 0xc0 , 0x08 } ,
{ 0xc1 , 0x10 } ,
{ 0xc2 , 0x08 } ,
{ 0xc3 , 0x10 } ,
{ 0xc4 , 0x08 } ,
{ 0xc5 , 0xf0 } ,
{ 0xc6 , 0xff } ,
{ 0xc7 , 0x00 } ,
{ 0xc8 , 0x1a } ,
{ 0xc9 , 0x80 } ,
{ 0xca , 0x23 } ,
{ 0xcb , 0x24 } ,
{ 0xcc , 0xf4 } ,
{ 0xce , 0x74 } ,
{ 0x00 , 0x00 } ,
{ 0xbd , 0x01 } ,
{ 0xb8 , 0x00 } ,
{ 0x29 , 0x01 } ,
} ;
2013-02-25 15:39:16 +04:00
# endif