[media] vp7045-fe: convert set_fontend to use DVBv5 parameters
Instead of using dvb_frontend_parameters struct, that were designed for a subset of the supported standards, use the DVBv5 cache information. Also, fill the supported delivery systems at dvb_frontend_ops struct. Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
This commit is contained in:
parent
4fa102d5cc
commit
e4b40030bf
1 changed files with 16 additions and 17 deletions
|
@ -103,9 +103,9 @@ static int vp7045_fe_get_tune_settings(struct dvb_frontend* fe, struct dvb_front
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int vp7045_fe_set_frontend(struct dvb_frontend* fe,
|
static int vp7045_fe_set_frontend(struct dvb_frontend *fe)
|
||||||
struct dvb_frontend_parameters *fep)
|
|
||||||
{
|
{
|
||||||
|
struct dtv_frontend_properties *fep = &fe->dtv_property_cache;
|
||||||
struct vp7045_fe_state *state = fe->demodulator_priv;
|
struct vp7045_fe_state *state = fe->demodulator_priv;
|
||||||
u8 buf[5];
|
u8 buf[5];
|
||||||
u32 freq = fep->frequency / 1000;
|
u32 freq = fep->frequency / 1000;
|
||||||
|
@ -115,25 +115,24 @@ static int vp7045_fe_set_frontend(struct dvb_frontend* fe,
|
||||||
buf[2] = freq & 0xff;
|
buf[2] = freq & 0xff;
|
||||||
buf[3] = 0;
|
buf[3] = 0;
|
||||||
|
|
||||||
switch (fep->u.ofdm.bandwidth) {
|
switch (fep->bandwidth_hz) {
|
||||||
case BANDWIDTH_8_MHZ: buf[4] = 8; break;
|
case 8000000:
|
||||||
case BANDWIDTH_7_MHZ: buf[4] = 7; break;
|
buf[4] = 8;
|
||||||
case BANDWIDTH_6_MHZ: buf[4] = 6; break;
|
break;
|
||||||
case BANDWIDTH_AUTO: return -EOPNOTSUPP;
|
case 7000000:
|
||||||
default:
|
buf[4] = 7;
|
||||||
return -EINVAL;
|
break;
|
||||||
|
case 6000000:
|
||||||
|
buf[4] = 6;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
vp7045_usb_op(state->d,LOCK_TUNER_COMMAND,buf,5,NULL,0,200);
|
vp7045_usb_op(state->d,LOCK_TUNER_COMMAND,buf,5,NULL,0,200);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int vp7045_fe_get_frontend(struct dvb_frontend* fe,
|
|
||||||
struct dvb_frontend_parameters *fep)
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void vp7045_fe_release(struct dvb_frontend* fe)
|
static void vp7045_fe_release(struct dvb_frontend* fe)
|
||||||
{
|
{
|
||||||
struct vp7045_fe_state *state = fe->demodulator_priv;
|
struct vp7045_fe_state *state = fe->demodulator_priv;
|
||||||
|
@ -159,6 +158,7 @@ error:
|
||||||
|
|
||||||
|
|
||||||
static struct dvb_frontend_ops vp7045_fe_ops = {
|
static struct dvb_frontend_ops vp7045_fe_ops = {
|
||||||
|
.delsys = { SYS_DVBT },
|
||||||
.info = {
|
.info = {
|
||||||
.name = "Twinhan VP7045/46 USB DVB-T",
|
.name = "Twinhan VP7045/46 USB DVB-T",
|
||||||
.type = FE_OFDM,
|
.type = FE_OFDM,
|
||||||
|
@ -180,8 +180,7 @@ static struct dvb_frontend_ops vp7045_fe_ops = {
|
||||||
.init = vp7045_fe_init,
|
.init = vp7045_fe_init,
|
||||||
.sleep = vp7045_fe_sleep,
|
.sleep = vp7045_fe_sleep,
|
||||||
|
|
||||||
.set_frontend_legacy = vp7045_fe_set_frontend,
|
.set_frontend = vp7045_fe_set_frontend,
|
||||||
.get_frontend_legacy = vp7045_fe_get_frontend,
|
|
||||||
.get_tune_settings = vp7045_fe_get_tune_settings,
|
.get_tune_settings = vp7045_fe_get_tune_settings,
|
||||||
|
|
||||||
.read_status = vp7045_fe_read_status,
|
.read_status = vp7045_fe_read_status,
|
||||||
|
|
Loading…
Add table
Reference in a new issue