0df289a209
The DVB API was originally defined using typedefs. This is against Kernel CodingStyle, and there's no good usage here. While we can't remove its usage on userspace, we can avoid its usage in Kernelspace. So, let's do it. This patch was generated by this shell script: for j in $(grep typedef include/uapi/linux/dvb/frontend.h |cut -d' ' -f 3); do for i in $(find drivers/media -name '*.[ch]' -type f) $(find drivers/staging/media -name '*.[ch]' -type f); do sed "s,${j}_t,enum $j," <$i >a && mv a $i; done; done While here, make CodingStyle fixes on the affected lines. Signed-off-by: Mauro Carvalho Chehab <mchehab@osg.samsung.com> Acked-by: Stefan Richter <stefanr@s5r6.in-berlin.de> # for drivers/media/firewire/*
403 lines
6.8 KiB
C
403 lines
6.8 KiB
C
/*
|
|
* Montage M88DS3103 demodulator driver
|
|
*
|
|
* Copyright (C) 2013 Antti Palosaari <crope@iki.fi>
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*/
|
|
|
|
#ifndef M88DS3103_PRIV_H
|
|
#define M88DS3103_PRIV_H
|
|
|
|
#include "dvb_frontend.h"
|
|
#include "m88ds3103.h"
|
|
#include "dvb_math.h"
|
|
#include <linux/firmware.h>
|
|
#include <linux/i2c-mux.h>
|
|
#include <linux/math64.h>
|
|
|
|
#define M88DS3103_FIRMWARE "dvb-demod-m88ds3103.fw"
|
|
#define M88RS6000_FIRMWARE "dvb-demod-m88rs6000.fw"
|
|
#define M88DS3103_MCLK_KHZ 96000
|
|
#define M88RS6000_CHIP_ID 0x74
|
|
#define M88DS3103_CHIP_ID 0x70
|
|
|
|
struct m88ds3103_priv {
|
|
struct i2c_adapter *i2c;
|
|
struct i2c_client *client;
|
|
/* mutex needed due to own tuner I2C adapter */
|
|
struct mutex i2c_mutex;
|
|
struct m88ds3103_config config;
|
|
const struct m88ds3103_config *cfg;
|
|
struct dvb_frontend fe;
|
|
enum fe_delivery_system delivery_system;
|
|
enum fe_status fe_status;
|
|
u32 dvbv3_ber; /* for old DVBv3 API read_ber */
|
|
bool warm; /* FW running */
|
|
struct i2c_adapter *i2c_adapter;
|
|
/* auto detect chip id to do different config */
|
|
u8 chip_id;
|
|
/* main mclk is calculated for M88RS6000 dynamically */
|
|
u32 mclk_khz;
|
|
u64 post_bit_error;
|
|
u64 post_bit_count;
|
|
};
|
|
|
|
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},
|
|
{0x56, 0x01},
|
|
{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},
|
|
{0x56, 0x01},
|
|
{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},
|
|
};
|
|
|
|
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},
|
|
};
|
|
#endif
|