2019-05-20 15:19:02 +08:00
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
2009-12-03 08:57:10 +08:00
|
|
|
/*
|
|
|
|
Mantis VP-3030 driver
|
|
|
|
|
2009-12-15 20:13:49 +08:00
|
|
|
Copyright (C) Manu Abraham (abraham.manu@gmail.com)
|
2009-12-03 08:57:10 +08:00
|
|
|
|
|
|
|
*/
|
|
|
|
|
2009-12-04 16:41:11 +08:00
|
|
|
#include <linux/signal.h>
|
|
|
|
#include <linux/sched.h>
|
|
|
|
#include <linux/interrupt.h>
|
|
|
|
|
2017-12-29 02:03:51 +08:00
|
|
|
#include <media/dmxdev.h>
|
|
|
|
#include <media/dvbdev.h>
|
|
|
|
#include <media/dvb_demux.h>
|
|
|
|
#include <media/dvb_frontend.h>
|
|
|
|
#include <media/dvb_net.h>
|
2009-12-04 16:41:11 +08:00
|
|
|
|
|
|
|
#include "zl10353.h"
|
2009-12-04 16:56:35 +08:00
|
|
|
#include "tda665x.h"
|
2009-12-03 08:57:10 +08:00
|
|
|
#include "mantis_common.h"
|
2009-12-04 16:56:35 +08:00
|
|
|
#include "mantis_ioc.h"
|
|
|
|
#include "mantis_dvb.h"
|
2009-12-03 08:57:10 +08:00
|
|
|
#include "mantis_vp3030.h"
|
|
|
|
|
2014-08-21 05:26:40 +08:00
|
|
|
static struct zl10353_config mantis_vp3030_config = {
|
2009-12-04 16:56:35 +08:00
|
|
|
.demod_address = 0x0f,
|
|
|
|
};
|
|
|
|
|
2014-08-21 05:26:40 +08:00
|
|
|
static struct tda665x_config env57h12d5_config = {
|
2009-12-04 16:56:35 +08:00
|
|
|
.name = "ENV57H12D5 (ET-50DT)",
|
|
|
|
.addr = 0x60,
|
2018-07-06 06:59:36 +08:00
|
|
|
.frequency_min = 47 * MHz,
|
|
|
|
.frequency_max = 862 * MHz,
|
2009-12-04 16:56:35 +08:00
|
|
|
.frequency_offst = 3616667,
|
|
|
|
.ref_multiplier = 6, /* 1/6 MHz */
|
|
|
|
.ref_divider = 100000, /* 1/6 MHz */
|
2009-12-03 09:07:24 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
#define MANTIS_MODEL_NAME "VP-3030"
|
|
|
|
#define MANTIS_DEV_TYPE "DVB-T"
|
|
|
|
|
2009-12-04 16:41:11 +08:00
|
|
|
|
|
|
|
static int vp3030_frontend_init(struct mantis_pci *mantis, struct dvb_frontend *fe)
|
|
|
|
{
|
|
|
|
struct i2c_adapter *adapter = &mantis->adapter;
|
2009-12-04 16:56:35 +08:00
|
|
|
struct mantis_hwconfig *config = mantis->hwconfig;
|
|
|
|
int err = 0;
|
|
|
|
|
2010-11-15 01:56:00 +08:00
|
|
|
mantis_gpio_set_bits(mantis, config->reset, 0);
|
2009-12-04 16:56:35 +08:00
|
|
|
msleep(100);
|
|
|
|
err = mantis_frontend_power(mantis, POWER_ON);
|
|
|
|
msleep(100);
|
2010-11-15 01:56:00 +08:00
|
|
|
mantis_gpio_set_bits(mantis, config->reset, 1);
|
2009-12-04 16:41:11 +08:00
|
|
|
|
2009-12-04 16:57:28 +08:00
|
|
|
if (err == 0) {
|
|
|
|
msleep(250);
|
|
|
|
dprintk(MANTIS_ERROR, 1, "Probing for 10353 (DVB-T)");
|
2010-11-15 01:24:36 +08:00
|
|
|
fe = dvb_attach(zl10353_attach, &mantis_vp3030_config, adapter);
|
2009-12-04 16:41:11 +08:00
|
|
|
|
2009-12-04 16:57:28 +08:00
|
|
|
if (!fe)
|
|
|
|
return -1;
|
2009-12-04 16:41:11 +08:00
|
|
|
|
2010-11-15 01:24:36 +08:00
|
|
|
dvb_attach(tda665x_attach, fe, &env57h12d5_config, adapter);
|
2009-12-04 16:57:28 +08:00
|
|
|
} else {
|
|
|
|
dprintk(MANTIS_ERROR, 1, "Frontend on <%s> POWER ON failed! <%d>",
|
|
|
|
adapter->name,
|
|
|
|
err);
|
|
|
|
|
|
|
|
return -EIO;
|
|
|
|
|
|
|
|
}
|
2009-12-04 16:41:11 +08:00
|
|
|
mantis->fe = fe;
|
|
|
|
dprintk(MANTIS_ERROR, 1, "Done!");
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
struct mantis_hwconfig vp3030_config = {
|
|
|
|
.model_name = MANTIS_MODEL_NAME,
|
|
|
|
.dev_type = MANTIS_DEV_TYPE,
|
|
|
|
.ts_size = MANTIS_TS_188,
|
|
|
|
|
|
|
|
.baud_rate = MANTIS_BAUD_9600,
|
|
|
|
.parity = MANTIS_PARITY_NONE,
|
|
|
|
.bytes = 0,
|
|
|
|
|
|
|
|
.frontend_init = vp3030_frontend_init,
|
2009-12-04 16:56:35 +08:00
|
|
|
.power = GPIF_A12,
|
|
|
|
.reset = GPIF_A13,
|
2009-12-04 16:57:28 +08:00
|
|
|
|
|
|
|
.i2c_mode = MANTIS_BYTE_MODE
|
2009-12-04 16:41:11 +08:00
|
|
|
};
|