summaryrefslogtreecommitdiff
path: root/linux/drivers/media/dvb/frontends/mt352.c
diff options
context:
space:
mode:
authorHolger Waechtler <devnull@localhost>2004-05-10 09:18:10 +0000
committerHolger Waechtler <devnull@localhost>2004-05-10 09:18:10 +0000
commit03d3518e326d236180969bc1bc84023f8ed0c280 (patch)
treebf2f60118d9881e5d8897842e172fe9737beb21a /linux/drivers/media/dvb/frontends/mt352.c
parent133924f0d0b13244d42187e76661f07965383078 (diff)
downloadmediapointer-dvb-s2-03d3518e326d236180969bc1bc84023f8ed0c280.tar.gz
mediapointer-dvb-s2-03d3518e326d236180969bc1bc84023f8ed0c280.tar.bz2
some functional fixes, not tested in kernel space -- sorry, don't have 2.6 running...
Diffstat (limited to 'linux/drivers/media/dvb/frontends/mt352.c')
-rw-r--r--linux/drivers/media/dvb/frontends/mt352.c264
1 files changed, 140 insertions, 124 deletions
diff --git a/linux/drivers/media/dvb/frontends/mt352.c b/linux/drivers/media/dvb/frontends/mt352.c
index e2c69b2e6..5d8f6aee1 100644
--- a/linux/drivers/media/dvb/frontends/mt352.c
+++ b/linux/drivers/media/dvb/frontends/mt352.c
@@ -2,7 +2,7 @@
* Driver for Zarlink DVB-T MT352 demodulator
*
* Written by Holger Waechtler <holger@qanu.de>
- * and Daniel Mack <daniel@qanu.de>
+ * and Daniel Mack <daniel@qanu.de>
*
* 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
@@ -30,83 +30,89 @@
#define I2C_MT352_ADDR 0x0f
#define I2C_TUNER_ADDR 0xc2
-#define mt352_write(ibuf, ilen) \
-do { \
- struct i2c_msg msg = { .addr = I2C_MT352_ADDR, .flags = 0, \
- .buf = ibuf, .len = ilen }; \
- int err = i2c->xfer(i2c, &msg, 1); \
- if (err != 1) { \
- printk(KERN_WARNING "mt352_write() failed (err = %d)!\n", err); \
- return err; \
- } \
+#define mt352_write(ibuf, ilen) \
+do { \
+ struct i2c_msg msg = { .addr = I2C_MT352_ADDR, .flags = 0, \
+ .buf = ibuf, .len = ilen }; \
+ int err = i2c->xfer(i2c, &msg, 1); \
+ if (err != 1) { \
+ printk(KERN_WARNING \
+ "mt352_write() failed (err = %d)!\n", err); \
+ return err; \
+ } \
} while (0)
#define msb(x) (((x) >> 8) & 0xff)
#define lsb(x) ((x) & 0xff)
+
static struct dvb_frontend_info mt352_info = {
.name = "DVB-T Zarlink MT352 demodulator driver",
.type = FE_OFDM,
.frequency_min = 174000000,
.frequency_max = 862000000,
.frequency_stepsize = 166667,
-/* .frequency_tolerance = ,
+/*
+ .frequency_tolerance = 0,
.symbol_rate_min = 1000000,
.symbol_rate_max = 45000000,
- .symbol_rate_tolerance = ???,*/
+ .symbol_rate_tolerance = ???,
+*/
.notifier_delay = 0,
.caps = FE_CAN_INVERSION_AUTO | FE_CAN_FEC_1_2 | FE_CAN_FEC_2_3 |
- FE_CAN_FEC_3_4 | FE_CAN_FEC_5_6 | FE_CAN_FEC_7_8 | FE_CAN_FEC_AUTO |
- FE_CAN_QPSK | FE_CAN_QAM_16 | FE_CAN_QAM_64 | FE_CAN_QAM_AUTO |
+ FE_CAN_FEC_3_4 | FE_CAN_FEC_5_6 | FE_CAN_FEC_7_8 |
+ FE_CAN_FEC_AUTO |
+ FE_CAN_QPSK | FE_CAN_QAM_16 | FE_CAN_QAM_64 | FE_CAN_QAM_AUTO |
FE_CAN_TRANSMISSION_MODE_AUTO | FE_CAN_GUARD_INTERVAL_AUTO |
- FE_CAN_HIERARCHY_AUTO | FE_CAN_RECOVER |
+ FE_CAN_HIERARCHY_AUTO | FE_CAN_RECOVER |
FE_CAN_MUTE_TS
};
+
int mt352_init (struct dvb_i2c_bus *i2c)
{
- /**
- * all register write sequence have the register address of the
- * first register in the first byte, thenafter the value to write
- * into this and the following registers.
- */
- static unsigned char mt352_reset [] = { 0x50, 0x80 };
- static unsigned char mt352_clock_config [] = { 0x89, 0x38, 0x2d };
- static unsigned char mt352_adc_ctl_1_cfg [] = { 0x8e, 0x40 };
- static unsigned char mt352_agc_cfg [] = { 0x67, 0x19, 0xa0 };
+ /**
+ * all register write sequence have the register address of the
+ * first register in the first byte, thenafter the value to write
+ * into this and the following registers.
+ */
+ static unsigned char mt352_reset [] = { 0x50, 0x80 };
+ static unsigned char mt352_clock_config [] = { 0x89, 0x38, 0x2d };
+ static unsigned char mt352_adc_ctl_1_cfg [] = { 0x8e, 0x40 };
+ static unsigned char mt352_agc_cfg [] = { 0x67, 0x19, 0xa0 };
static unsigned char mt352_acq_ctl [] = { 0x53, 0x50 };
- /**
- * We only write non-default settings, all default settings are
- * restored by the full mt352_reset sequence.
- */
- mt352_write(mt352_clock_config, sizeof(mt352_clock_config));
- udelay(2000);
- mt352_write(mt352_reset, sizeof(mt352_reset));
- mt352_write(mt352_adc_ctl_1_cfg, sizeof(mt352_adc_ctl_1_cfg));
+ /**
+ * We only write non-default settings, all default settings are
+ * restored by the full mt352_reset sequence.
+ */
+ mt352_write(mt352_clock_config, sizeof(mt352_clock_config));
+ udelay(2000);
+ mt352_write(mt352_reset, sizeof(mt352_reset));
+ mt352_write(mt352_adc_ctl_1_cfg, sizeof(mt352_adc_ctl_1_cfg));
mt352_write(mt352_acq_ctl, sizeof(mt352_acq_ctl));
- /**
- * The optimal AGC target value and slope might vary from tuner
- * type to tuner type, so check whether you need to adjust this one...
- */
- mt352_write(mt352_agc_cfg, sizeof(mt352_agc_cfg));
+ /**
+ * The optimal AGC target value and slope might vary from tuner
+ * type to tuner type, so check whether you need to adjust this one...
+ */
+ mt352_write(mt352_agc_cfg, sizeof(mt352_agc_cfg));
- return 0;
+ return 0;
}
int mt352_set_parameters (struct dvb_i2c_bus *i2c,
struct dvb_frontend_parameters *param)
{
- unsigned char buf[14];
+ unsigned char buf[14];
unsigned int tps = 0;
struct dvb_ofdm_parameters *op = &param->u.ofdm;
- u32 freq = param->frequency / 1000000;
+ u32 freq = param->frequency / 1000;
switch (op->code_rate_HP) {
- case FEC_2_3:
+ case FEC_2_3:
tps |= (1 << 9);
break;
case FEC_3_4:
@@ -125,7 +131,7 @@ int mt352_set_parameters (struct dvb_i2c_bus *i2c,
}
switch (op->code_rate_LP) {
- case FEC_2_3:
+ case FEC_2_3:
tps |= (1 << 6);
break;
case FEC_3_4:
@@ -191,103 +197,111 @@ int mt352_set_parameters (struct dvb_i2c_bus *i2c,
}
- buf[0] = 0x51; /* TPS_GIVEN_1 and following registers */
+ buf[0] = 0x51; /* TPS_GIVEN_1 and following registers */
- buf[1] = msb(tps); /* TPS_GIVEN_(1|0) */
- buf[2] = lsb(tps);
+ buf[1] = msb(tps); /* TPS_GIVEN_(1|0) */
+ buf[2] = lsb(tps);
// buf[3] = 0xf3; /* ACQ_CTL, force parameters, automatic spectral inv */
- buf[3] = 0x50; /* ACQ_CTL, fully automatic parameter search */
-
- /**
- * these settings assume 20.48MHz f_ADC, for other tuners you might
- * need other values. See p. 33 in the MT352 Design Manual.
- */
- if (op->bandwidth == BANDWIDTH_8_MHZ) {
- buf[4] = 0x72; /* TRL_NOMINAL_RATE_(1|0) */
- buf[5] = 0x49;
- } else if (op->bandwidth == BANDWIDTH_7_MHZ) {
- buf[4] = 0x64;
- buf[5] = 0x00;
- } else { /* 6MHz */
- buf[4] = 0x55;
- buf[5] = 0xb7;
- }
-
- buf[6] = 0x31; /* INPUT_FREQ_(1|0), 20.48MHz clock, 36.166667MHz IF */
- buf[7] = 0x05; /* see MT352 Design Manual page 32 for details */
-
- buf[8] = I2C_TUNER_ADDR;
-
- /**
- * All the following settings are tuner module dependent,
- * check the datasheet...
- */
- {
- /* here we assume 1/6MHz == 166.66kHz stepsize */
- #define IF_FREQUENCYx6 217 /* 6 * 36.16666666667MHz */
- uint16_t tmp = 6 * freq + IF_FREQUENCYx6;
- buf[9] = msb(tmp); /* CHAN_START_(1|0) */
- buf[10] = lsb(tmp);
- }
+ buf[3] = 0x50; /* ACQ_CTL, fully automatic parameter search */
+
+ /**
+ * these settings assume 20.48MHz f_ADC, for other tuners you might
+ * need other values. See p. 33 in the MT352 Design Manual.
+ */
+ if (op->bandwidth == BANDWIDTH_8_MHZ) {
+ buf[4] = 0x72; /* TRL_NOMINAL_RATE_(1|0) */
+ buf[5] = 0x49;
+ } else if (op->bandwidth == BANDWIDTH_7_MHZ) {
+ buf[4] = 0x64;
+ buf[5] = 0x00;
+ } else { /* 6MHz */
+ buf[4] = 0x55;
+ buf[5] = 0xb7;
+ }
+
+ buf[6] = 0x31; /* INPUT_FREQ_(1|0), 20.48MHz clock, 36.166667MHz IF */
+ buf[7] = 0x05; /* see MT352 Design Manual page 32 for details */
+
+ buf[8] = I2C_TUNER_ADDR;
+
+ /**
+ * All the following settings are tuner module dependent,
+ * check the datasheet...
+ */
+ {
+ /* here we assume 1/6MHz == 166.66kHz stepsize */
+ #define IF_FREQUENCYx6 217 /* 6 * 36.16666666667MHz */
+ uint16_t tmp = (6 * freq) / 1000 + IF_FREQUENCYx6;
+ buf[9] = msb(tmp); /* CHAN_START_(1|0) */
+ buf[10] = lsb(tmp);
+ }
printk (KERN_WARNING "buf9,10: %02x %02x\n", buf[9], buf[10]);
- if (freq < 542)
- buf[11] = 0xbe; /* CONT_1, charge pump byte */
- else if (freq < 830)
- buf[11] = 0xf6;
- else
- buf[11] = 0xfe;
+ if (freq < 542000)
+ buf[11] = 0xbe; /* CONT_1, charge pump byte */
+ else if (freq < 830000)
+ buf[11] = 0xf6;
+ else
+ buf[11] = 0xfe;
- if (freq < 250) /* VHF, freq < 250MHz */
- buf[12] = 0x01; /* CONT_0, bandswitch byte */
- else
- buf[12] = 0x08;
+ if (freq < 250000) /* VHF, freq < 250MHz */
+ buf[12] = 0x01; /* CONT_0, bandswitch byte */
+ else
+ buf[12] = 0x08;
- buf[13] = 0x01; /* TUNER_GO!! */
+ buf[13] = 0x01; /* TUNER_GO!! */
mt352_write(buf, sizeof(buf));
return 0;
}
+
static u8 mt352_read_register (struct dvb_i2c_bus *i2c, u8 reg)
{
int ret;
- u8 b0 [] = { reg };
- u8 b1 [] = { 0 };
- struct i2c_msg msg [] = { { .addr = I2C_MT352_ADDR, .flags = I2C_M_NOSTART, .buf = b0, .len = 1 },
- { .addr = I2C_MT352_ADDR, .flags = I2C_M_RD, .buf = b1, .len = 1 } };
-
- ret = i2c->xfer (i2c, msg, 2);
-
- if (ret != 2)
- printk(KERN_WARNING "%s: readreg error (ret == %i)\n", __FUNCTION__, ret);
-
- return b1[0];
+ u8 b0 [] = { reg };
+ u8 b1 [] = { 0 };
+ struct i2c_msg msg [] = { { .addr = I2C_MT352_ADDR,
+ .flags = I2C_M_NOSTART,
+ .buf = b0, .len = 1 },
+ { .addr = I2C_MT352_ADDR,
+ .flags = I2C_M_RD,
+ .buf = b1, .len = 1 } };
+
+ ret = i2c->xfer (i2c, msg, 2);
+
+ if (ret != 2)
+ printk(KERN_WARNING
+ "%s: readreg error (ret == %i)\n", __FUNCTION__, ret);
+
+ return b1[0];
}
+
static int mt352_dump (struct dvb_i2c_bus *i2c) {
int i;
for (i=0x50; i<=0x7f; i++)
- printk ("mt352[%03x]: %02x\n", i, mt352_read_register (i2c, i));
+ printk("mt352[%03x]: %02x\n", i, mt352_read_register (i2c, i));
return 0;
}
+
static int mt352_ioctl (struct dvb_frontend *fe, unsigned int cmd, void *arg)
{
struct dvb_i2c_bus *i2c = fe->i2c;
int i;
- switch (cmd) {
- case FE_GET_INFO:
+ switch (cmd) {
+ case FE_GET_INFO:
memcpy (arg, &mt352_info, sizeof(struct dvb_frontend_info));
break;
- case FE_READ_STATUS:
+ case FE_READ_STATUS:
{
u8 r;
fe_status_t *status = arg;
@@ -312,24 +326,24 @@ static int mt352_ioctl (struct dvb_frontend *fe, unsigned int cmd, void *arg)
break;
}
- case FE_READ_BER:
+ case FE_READ_BER:
{
u32 *ber = (u32 *) arg;
*ber = (mt352_read_register (i2c, 0xA) << 16) |
- (mt352_read_register (i2c, 0xB) << 8) |
+ (mt352_read_register (i2c, 0xB) << 8) |
(mt352_read_register (i2c, 0xC));
break;
}
- case FE_READ_SIGNAL_STRENGTH:
+ case FE_READ_SIGNAL_STRENGTH:
{
u16 signal = (mt352_read_register (i2c, 0x12) << 8) |
- (mt352_read_register (i2c, 0x13));
+ (mt352_read_register (i2c, 0x13));
*((u16*) arg) = ~signal;
break;
}
- case FE_READ_SNR:
+ case FE_READ_SNR:
{
u8 snr = mt352_read_register (i2c, 0x9);
*(u16*) arg = (snr << 8) | snr;
@@ -338,34 +352,37 @@ static int mt352_ioctl (struct dvb_frontend *fe, unsigned int cmd, void *arg)
case FE_READ_UNCORRECTED_BLOCKS:
*(u32*) arg = (mt352_read_register (i2c, 0x10) << 8) |
- (mt352_read_register (i2c, 0x11));
+ (mt352_read_register (i2c, 0x11));
break;
- case FE_SET_FRONTEND:
- i = mt352_set_parameters (i2c, (struct dvb_frontend_parameters *) arg);
+ case FE_SET_FRONTEND:
+ i = mt352_set_parameters (i2c,
+ (struct dvb_frontend_parameters *) arg);
mt352_dump(i2c);
return i;
case FE_GET_FRONTEND:
break;
- case FE_SLEEP:
+ case FE_SLEEP:
return 0;
- case FE_INIT:
+ case FE_INIT:
return mt352_init(i2c);
default:
return -EOPNOTSUPP;
- }
- return 0;
+ }
+
+ return 0;
}
static int mt352_attach (struct dvb_i2c_bus *i2c, void **data)
{
- if (mt352_read_register (i2c, 0x7f) == 0x13)
- return dvb_register_frontend (mt352_ioctl, i2c, NULL, &mt352_info);
+ if (mt352_read_register(i2c, 0x7f) == 0x13)
+ return dvb_register_frontend(mt352_ioctl, i2c, NULL,
+ &mt352_info);
return -ENODEV;
}
@@ -373,21 +390,19 @@ static int mt352_attach (struct dvb_i2c_bus *i2c, void **data)
static void mt352_detach (struct dvb_i2c_bus *i2c, void *data)
{
- dvb_unregister_frontend (mt352_ioctl, i2c);
+ dvb_unregister_frontend(mt352_ioctl, i2c);
}
static int __init init_mt352 (void)
{
- return dvb_register_i2c_device (NULL,
- mt352_attach,
- mt352_detach);
+ return dvb_register_i2c_device(NULL, mt352_attach, mt352_detach);
}
static void __exit exit_mt352 (void)
{
- dvb_unregister_i2c_device (mt352_attach);
+ dvb_unregister_i2c_device(mt352_attach);
}
@@ -396,5 +411,6 @@ module_exit(exit_mt352);
MODULE_DESCRIPTION("DVB-T MT352 Zarlink");
-MODULE_AUTHOR("Holniel");
+MODULE_AUTHOR("Holger Waechtler, Daniel Mack");
MODULE_LICENSE("GPL");
+