Commit e4b40030 authored by Mauro Carvalho Chehab's avatar Mauro Carvalho Chehab

[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: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent 4fa102d5
...@@ -103,9 +103,9 @@ static int vp7045_fe_get_tune_settings(struct dvb_frontend* fe, struct dvb_front ...@@ -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, ...@@ -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 @@ struct dvb_frontend * vp7045_fe_attach(struct dvb_usb_device *d) ...@@ -159,6 +158,7 @@ struct dvb_frontend * vp7045_fe_attach(struct dvb_usb_device *d)
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 = { ...@@ -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,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment