Commit bbe880b4 authored by Andreas Oberritter's avatar Andreas Oberritter Committed by Mauro Carvalho Chehab

[media] DVB: allow to read back of detected parameters through S2API

Signed-off-by: default avatarAndreas Oberritter <obi@linuxtv.org>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent a5959dbe
...@@ -1023,10 +1023,9 @@ static int is_legacy_delivery_system(fe_delivery_system_t s) ...@@ -1023,10 +1023,9 @@ static int is_legacy_delivery_system(fe_delivery_system_t s)
* it's being used for the legacy or new API, reducing code and complexity. * it's being used for the legacy or new API, reducing code and complexity.
*/ */
static void dtv_property_cache_sync(struct dvb_frontend *fe, static void dtv_property_cache_sync(struct dvb_frontend *fe,
struct dvb_frontend_parameters *p) struct dtv_frontend_properties *c,
const struct dvb_frontend_parameters *p)
{ {
struct dtv_frontend_properties *c = &fe->dtv_property_cache;
c->frequency = p->frequency; c->frequency = p->frequency;
c->inversion = p->inversion; c->inversion = p->inversion;
...@@ -1200,8 +1199,20 @@ static int dtv_property_process_get(struct dvb_frontend *fe, ...@@ -1200,8 +1199,20 @@ static int dtv_property_process_get(struct dvb_frontend *fe,
struct file *file) struct file *file)
{ {
const struct dtv_frontend_properties *c = &fe->dtv_property_cache; const struct dtv_frontend_properties *c = &fe->dtv_property_cache;
struct dvb_frontend_private *fepriv = fe->frontend_priv;
struct dtv_frontend_properties cdetected;
int r; int r;
/*
* If the driver implements a get_frontend function, then convert
* detected parameters to S2API properties.
*/
if (fe->ops.get_frontend) {
cdetected = *c;
dtv_property_cache_sync(fe, &cdetected, &fepriv->parameters_out);
c = &cdetected;
}
switch(tvp->cmd) { switch(tvp->cmd) {
case DTV_FREQUENCY: case DTV_FREQUENCY:
tvp->u.data = c->frequency; tvp->u.data = c->frequency;
...@@ -1812,7 +1823,7 @@ static int dvb_frontend_ioctl_legacy(struct file *file, ...@@ -1812,7 +1823,7 @@ static int dvb_frontend_ioctl_legacy(struct file *file,
memcpy (&fepriv->parameters_in, parg, memcpy (&fepriv->parameters_in, parg,
sizeof (struct dvb_frontend_parameters)); sizeof (struct dvb_frontend_parameters));
dtv_property_cache_sync(fe, &fepriv->parameters_in); dtv_property_cache_sync(fe, c, &fepriv->parameters_in);
} }
memset(&fetunesettings, 0, sizeof(struct dvb_frontend_tune_settings)); memset(&fetunesettings, 0, sizeof(struct dvb_frontend_tune_settings));
......
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