media: dvb_frontend: cleanup some coding style errors
This is a core media file... it shoudn't have so many coding style issues! The last patch ended by being submitted with an error like that, very likely due to some cut and paste issue. Maybe it is time to clean it up. Do it with the auto fix logic: ./scripts/checkpatch.pl -f drivers/media/dvb-core/dvb_frontend.c --strict --fix-inplace Then manually fix the errors introduced by it. Signed-off-by: Mauro Carvalho Chehab <mchehab+samsung@kernel.org>
This commit is contained in:
parent
f17c403af9
commit
09c2cc98cd
@ -190,7 +190,7 @@ dtv_property_legacy_params_sync(struct dvb_frontend *fe,
|
|||||||
|
|
||||||
static bool has_get_frontend(struct dvb_frontend *fe)
|
static bool has_get_frontend(struct dvb_frontend *fe)
|
||||||
{
|
{
|
||||||
return fe->ops.get_frontend != NULL;
|
return fe->ops.get_frontend;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -272,7 +272,7 @@ static void dvb_frontend_add_event(struct dvb_frontend *fe,
|
|||||||
|
|
||||||
mutex_unlock(&events->mtx);
|
mutex_unlock(&events->mtx);
|
||||||
|
|
||||||
wake_up_interruptible (&events->wait_queue);
|
wake_up_interruptible(&events->wait_queue);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int dvb_frontend_test_event(struct dvb_frontend_private *fepriv,
|
static int dvb_frontend_test_event(struct dvb_frontend_private *fepriv,
|
||||||
@ -288,7 +288,7 @@ static int dvb_frontend_test_event(struct dvb_frontend_private *fepriv,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int dvb_frontend_get_event(struct dvb_frontend *fe,
|
static int dvb_frontend_get_event(struct dvb_frontend *fe,
|
||||||
struct dvb_frontend_event *event, int flags)
|
struct dvb_frontend_event *event, int flags)
|
||||||
{
|
{
|
||||||
struct dvb_frontend_private *fepriv = fe->frontend_priv;
|
struct dvb_frontend_private *fepriv = fe->frontend_priv;
|
||||||
struct dvb_fe_events *events = &fepriv->events;
|
struct dvb_fe_events *events = &fepriv->events;
|
||||||
@ -334,8 +334,8 @@ static void dvb_frontend_clear_events(struct dvb_frontend *fe)
|
|||||||
static void dvb_frontend_init(struct dvb_frontend *fe)
|
static void dvb_frontend_init(struct dvb_frontend *fe)
|
||||||
{
|
{
|
||||||
dev_dbg(fe->dvb->device,
|
dev_dbg(fe->dvb->device,
|
||||||
"%s: initialising adapter %i frontend %i (%s)...\n",
|
"%s: initialising adapter %i frontend %i (%s)...\n",
|
||||||
__func__, fe->dvb->num, fe->id, fe->ops.info.name);
|
__func__, fe->dvb->num, fe->id, fe->ops.info.name);
|
||||||
|
|
||||||
if (fe->ops.init)
|
if (fe->ops.init)
|
||||||
fe->ops.init(fe);
|
fe->ops.init(fe);
|
||||||
@ -365,14 +365,14 @@ static void dvb_frontend_swzigzag_update_delay(struct dvb_frontend_private *fepr
|
|||||||
dev_dbg(fe->dvb->device, "%s:\n", __func__);
|
dev_dbg(fe->dvb->device, "%s:\n", __func__);
|
||||||
|
|
||||||
if (locked)
|
if (locked)
|
||||||
(fepriv->quality) = (fepriv->quality * 220 + 36*256) / 256;
|
(fepriv->quality) = (fepriv->quality * 220 + 36 * 256) / 256;
|
||||||
else
|
else
|
||||||
(fepriv->quality) = (fepriv->quality * 220 + 0) / 256;
|
(fepriv->quality) = (fepriv->quality * 220 + 0) / 256;
|
||||||
|
|
||||||
q2 = fepriv->quality - 128;
|
q2 = fepriv->quality - 128;
|
||||||
q2 *= q2;
|
q2 *= q2;
|
||||||
|
|
||||||
fepriv->delay = fepriv->min_delay + q2 * HZ / (128*128);
|
fepriv->delay = fepriv->min_delay + q2 * HZ / (128 * 128);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -400,7 +400,7 @@ static int dvb_frontend_swzigzag_autotune(struct dvb_frontend *fe, int check_wra
|
|||||||
(c->inversion == INVERSION_AUTO));
|
(c->inversion == INVERSION_AUTO));
|
||||||
|
|
||||||
/* setup parameters correctly */
|
/* setup parameters correctly */
|
||||||
while(!ready) {
|
while (!ready) {
|
||||||
/* calculate the lnb_drift */
|
/* calculate the lnb_drift */
|
||||||
fepriv->lnb_drift = fepriv->auto_step * fepriv->step_size;
|
fepriv->lnb_drift = fepriv->auto_step * fepriv->step_size;
|
||||||
|
|
||||||
@ -412,7 +412,7 @@ static int dvb_frontend_swzigzag_autotune(struct dvb_frontend *fe, int check_wra
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* perform inversion and +/- zigzag */
|
/* perform inversion and +/- zigzag */
|
||||||
switch(fepriv->auto_sub_step) {
|
switch (fepriv->auto_sub_step) {
|
||||||
case 0:
|
case 0:
|
||||||
/* try with the current inversion and current drift setting */
|
/* try with the current inversion and current drift setting */
|
||||||
ready = 1;
|
ready = 1;
|
||||||
@ -457,11 +457,11 @@ static int dvb_frontend_swzigzag_autotune(struct dvb_frontend *fe, int check_wra
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
dev_dbg(fe->dvb->device, "%s: drift:%i inversion:%i auto_step:%i " \
|
dev_dbg(fe->dvb->device,
|
||||||
"auto_sub_step:%i started_auto_step:%i\n",
|
"%s: drift:%i inversion:%i auto_step:%i auto_sub_step:%i started_auto_step:%i\n",
|
||||||
__func__, fepriv->lnb_drift, fepriv->inversion,
|
__func__, fepriv->lnb_drift, fepriv->inversion,
|
||||||
fepriv->auto_step, fepriv->auto_sub_step,
|
fepriv->auto_step, fepriv->auto_sub_step,
|
||||||
fepriv->started_auto_step);
|
fepriv->started_auto_step);
|
||||||
|
|
||||||
/* set the frontend itself */
|
/* set the frontend itself */
|
||||||
c->frequency += fepriv->lnb_drift;
|
c->frequency += fepriv->lnb_drift;
|
||||||
@ -492,7 +492,7 @@ static void dvb_frontend_swzigzag(struct dvb_frontend *fe)
|
|||||||
|
|
||||||
/* if we've got no parameters, just keep idling */
|
/* if we've got no parameters, just keep idling */
|
||||||
if (fepriv->state & FESTATE_IDLE) {
|
if (fepriv->state & FESTATE_IDLE) {
|
||||||
fepriv->delay = 3*HZ;
|
fepriv->delay = 3 * HZ;
|
||||||
fepriv->quality = 0;
|
fepriv->quality = 0;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -509,7 +509,7 @@ static void dvb_frontend_swzigzag(struct dvb_frontend *fe)
|
|||||||
else
|
else
|
||||||
fepriv->state = FESTATE_TUNED;
|
fepriv->state = FESTATE_TUNED;
|
||||||
}
|
}
|
||||||
fepriv->delay = 3*HZ;
|
fepriv->delay = 3 * HZ;
|
||||||
fepriv->quality = 0;
|
fepriv->quality = 0;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -598,7 +598,7 @@ static void dvb_frontend_swzigzag(struct dvb_frontend *fe)
|
|||||||
}
|
}
|
||||||
fepriv->check_wrapped = 1;
|
fepriv->check_wrapped = 1;
|
||||||
|
|
||||||
/* if we've just retuned, enter the ZIGZAG_FAST state.
|
/* if we've just re-tuned, enter the ZIGZAG_FAST state.
|
||||||
* This ensures we cannot return from an
|
* This ensures we cannot return from an
|
||||||
* FE_SET_FRONTEND ioctl before the first frontend tune
|
* FE_SET_FRONTEND ioctl before the first frontend tune
|
||||||
* occurs */
|
* occurs */
|
||||||
@ -665,7 +665,7 @@ static int dvb_frontend_thread(void *data)
|
|||||||
|
|
||||||
fepriv->check_wrapped = 0;
|
fepriv->check_wrapped = 0;
|
||||||
fepriv->quality = 0;
|
fepriv->quality = 0;
|
||||||
fepriv->delay = 3*HZ;
|
fepriv->delay = 3 * HZ;
|
||||||
fepriv->status = 0;
|
fepriv->status = 0;
|
||||||
fepriv->wakeup = 0;
|
fepriv->wakeup = 0;
|
||||||
fepriv->reinitialise = 0;
|
fepriv->reinitialise = 0;
|
||||||
@ -677,8 +677,9 @@ static int dvb_frontend_thread(void *data)
|
|||||||
up(&fepriv->sem); /* is locked when we enter the thread... */
|
up(&fepriv->sem); /* is locked when we enter the thread... */
|
||||||
restart:
|
restart:
|
||||||
wait_event_interruptible_timeout(fepriv->wait_queue,
|
wait_event_interruptible_timeout(fepriv->wait_queue,
|
||||||
dvb_frontend_should_wakeup(fe) || kthread_should_stop()
|
dvb_frontend_should_wakeup(fe) ||
|
||||||
|| freezing(current),
|
kthread_should_stop() ||
|
||||||
|
freezing(current),
|
||||||
fepriv->delay);
|
fepriv->delay);
|
||||||
|
|
||||||
if (kthread_should_stop() || dvb_frontend_is_exiting(fe)) {
|
if (kthread_should_stop() || dvb_frontend_is_exiting(fe)) {
|
||||||
@ -827,8 +828,8 @@ static void dvb_frontend_stop(struct dvb_frontend *fe)
|
|||||||
/* paranoia check in case a signal arrived */
|
/* paranoia check in case a signal arrived */
|
||||||
if (fepriv->thread)
|
if (fepriv->thread)
|
||||||
dev_warn(fe->dvb->device,
|
dev_warn(fe->dvb->device,
|
||||||
"dvb_frontend_stop: warning: thread %p won't exit\n",
|
"dvb_frontend_stop: warning: thread %p won't exit\n",
|
||||||
fepriv->thread);
|
fepriv->thread);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -865,12 +866,12 @@ static int dvb_frontend_start(struct dvb_frontend *fe)
|
|||||||
if (fe->exit == DVB_FE_NO_EXIT)
|
if (fe->exit == DVB_FE_NO_EXIT)
|
||||||
return 0;
|
return 0;
|
||||||
else
|
else
|
||||||
dvb_frontend_stop (fe);
|
dvb_frontend_stop(fe);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (signal_pending(current))
|
if (signal_pending(current))
|
||||||
return -EINTR;
|
return -EINTR;
|
||||||
if (down_interruptible (&fepriv->sem))
|
if (down_interruptible(&fepriv->sem))
|
||||||
return -EINTR;
|
return -EINTR;
|
||||||
|
|
||||||
fepriv->state = FESTATE_IDLE;
|
fepriv->state = FESTATE_IDLE;
|
||||||
@ -879,12 +880,12 @@ static int dvb_frontend_start(struct dvb_frontend *fe)
|
|||||||
mb();
|
mb();
|
||||||
|
|
||||||
fe_thread = kthread_run(dvb_frontend_thread, fe,
|
fe_thread = kthread_run(dvb_frontend_thread, fe,
|
||||||
"kdvb-ad-%i-fe-%i", fe->dvb->num,fe->id);
|
"kdvb-ad-%i-fe-%i", fe->dvb->num, fe->id);
|
||||||
if (IS_ERR(fe_thread)) {
|
if (IS_ERR(fe_thread)) {
|
||||||
ret = PTR_ERR(fe_thread);
|
ret = PTR_ERR(fe_thread);
|
||||||
dev_warn(fe->dvb->device,
|
dev_warn(fe->dvb->device,
|
||||||
"dvb_frontend_start: failed to start kthread (%d)\n",
|
"dvb_frontend_start: failed to start kthread (%d)\n",
|
||||||
ret);
|
ret);
|
||||||
up(&fepriv->sem);
|
up(&fepriv->sem);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
@ -893,7 +894,7 @@ static int dvb_frontend_start(struct dvb_frontend *fe)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void dvb_frontend_get_frequency_limits(struct dvb_frontend *fe,
|
static void dvb_frontend_get_frequency_limits(struct dvb_frontend *fe,
|
||||||
u32 *freq_min, u32 *freq_max)
|
u32 *freq_min, u32 *freq_max)
|
||||||
{
|
{
|
||||||
*freq_min = max(fe->ops.info.frequency_min, fe->ops.tuner_ops.info.frequency_min);
|
*freq_min = max(fe->ops.info.frequency_min, fe->ops.tuner_ops.info.frequency_min);
|
||||||
|
|
||||||
@ -905,8 +906,9 @@ static void dvb_frontend_get_frequency_limits(struct dvb_frontend *fe,
|
|||||||
*freq_max = min(fe->ops.info.frequency_max, fe->ops.tuner_ops.info.frequency_max);
|
*freq_max = min(fe->ops.info.frequency_max, fe->ops.tuner_ops.info.frequency_max);
|
||||||
|
|
||||||
if (*freq_min == 0 || *freq_max == 0)
|
if (*freq_min == 0 || *freq_max == 0)
|
||||||
dev_warn(fe->dvb->device, "DVB: adapter %i frontend %u frequency limits undefined - fix the driver\n",
|
dev_warn(fe->dvb->device,
|
||||||
fe->dvb->num, fe->id);
|
"DVB: adapter %i frontend %u frequency limits undefined - fix the driver\n",
|
||||||
|
fe->dvb->num, fe->id);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int dvb_frontend_check_parameters(struct dvb_frontend *fe)
|
static int dvb_frontend_check_parameters(struct dvb_frontend *fe)
|
||||||
@ -920,8 +922,8 @@ static int dvb_frontend_check_parameters(struct dvb_frontend *fe)
|
|||||||
if ((freq_min && c->frequency < freq_min) ||
|
if ((freq_min && c->frequency < freq_min) ||
|
||||||
(freq_max && c->frequency > freq_max)) {
|
(freq_max && c->frequency > freq_max)) {
|
||||||
dev_warn(fe->dvb->device, "DVB: adapter %i frontend %i frequency %u out of range (%u..%u)\n",
|
dev_warn(fe->dvb->device, "DVB: adapter %i frontend %i frequency %u out of range (%u..%u)\n",
|
||||||
fe->dvb->num, fe->id, c->frequency,
|
fe->dvb->num, fe->id, c->frequency,
|
||||||
freq_min, freq_max);
|
freq_min, freq_max);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -937,9 +939,9 @@ static int dvb_frontend_check_parameters(struct dvb_frontend *fe)
|
|||||||
(fe->ops.info.symbol_rate_max &&
|
(fe->ops.info.symbol_rate_max &&
|
||||||
c->symbol_rate > fe->ops.info.symbol_rate_max)) {
|
c->symbol_rate > fe->ops.info.symbol_rate_max)) {
|
||||||
dev_warn(fe->dvb->device, "DVB: adapter %i frontend %i symbol rate %u out of range (%u..%u)\n",
|
dev_warn(fe->dvb->device, "DVB: adapter %i frontend %i symbol rate %u out of range (%u..%u)\n",
|
||||||
fe->dvb->num, fe->id, c->symbol_rate,
|
fe->dvb->num, fe->id, c->symbol_rate,
|
||||||
fe->ops.info.symbol_rate_min,
|
fe->ops.info.symbol_rate_min,
|
||||||
fe->ops.info.symbol_rate_max);
|
fe->ops.info.symbol_rate_max);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
@ -960,7 +962,7 @@ static int dvb_frontend_clear_cache(struct dvb_frontend *fe)
|
|||||||
c->delivery_system = delsys;
|
c->delivery_system = delsys;
|
||||||
|
|
||||||
dev_dbg(fe->dvb->device, "%s: Clearing cache for delivery system %d\n",
|
dev_dbg(fe->dvb->device, "%s: Clearing cache for delivery system %d\n",
|
||||||
__func__, c->delivery_system);
|
__func__, c->delivery_system);
|
||||||
|
|
||||||
c->transmission_mode = TRANSMISSION_MODE_AUTO;
|
c->transmission_mode = TRANSMISSION_MODE_AUTO;
|
||||||
c->bandwidth_hz = 0; /* AUTO */
|
c->bandwidth_hz = 0; /* AUTO */
|
||||||
@ -1185,8 +1187,8 @@ static int dtv_property_cache_sync(struct dvb_frontend *fe,
|
|||||||
break;
|
break;
|
||||||
case DVBV3_UNKNOWN:
|
case DVBV3_UNKNOWN:
|
||||||
dev_err(fe->dvb->device,
|
dev_err(fe->dvb->device,
|
||||||
"%s: doesn't know how to handle a DVBv3 call to delivery system %i\n",
|
"%s: doesn't know how to handle a DVBv3 call to delivery system %i\n",
|
||||||
__func__, c->delivery_system);
|
__func__, c->delivery_system);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1207,8 +1209,8 @@ dtv_property_legacy_params_sync(struct dvb_frontend *fe,
|
|||||||
switch (dvbv3_type(c->delivery_system)) {
|
switch (dvbv3_type(c->delivery_system)) {
|
||||||
case DVBV3_UNKNOWN:
|
case DVBV3_UNKNOWN:
|
||||||
dev_err(fe->dvb->device,
|
dev_err(fe->dvb->device,
|
||||||
"%s: doesn't know how to handle a DVBv3 call to delivery system %i\n",
|
"%s: doesn't know how to handle a DVBv3 call to delivery system %i\n",
|
||||||
__func__, c->delivery_system);
|
__func__, c->delivery_system);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
case DVBV3_QPSK:
|
case DVBV3_QPSK:
|
||||||
dev_dbg(fe->dvb->device, "%s: Preparing QPSK req\n", __func__);
|
dev_dbg(fe->dvb->device, "%s: Preparing QPSK req\n", __func__);
|
||||||
@ -1300,7 +1302,7 @@ static int dtv_property_process_get(struct dvb_frontend *fe,
|
|||||||
{
|
{
|
||||||
int ncaps;
|
int ncaps;
|
||||||
|
|
||||||
switch(tvp->cmd) {
|
switch (tvp->cmd) {
|
||||||
case DTV_ENUM_DELSYS:
|
case DTV_ENUM_DELSYS:
|
||||||
ncaps = 0;
|
ncaps = 0;
|
||||||
while (ncaps < MAX_DELSYS && fe->ops.delsys[ncaps]) {
|
while (ncaps < MAX_DELSYS && fe->ops.delsys[ncaps]) {
|
||||||
@ -1629,8 +1631,8 @@ static int dvbv5_set_delivery_system(struct dvb_frontend *fe,
|
|||||||
if (fe->ops.delsys[ncaps] == desired_system) {
|
if (fe->ops.delsys[ncaps] == desired_system) {
|
||||||
c->delivery_system = desired_system;
|
c->delivery_system = desired_system;
|
||||||
dev_dbg(fe->dvb->device,
|
dev_dbg(fe->dvb->device,
|
||||||
"%s: Changing delivery system to %d\n",
|
"%s: Changing delivery system to %d\n",
|
||||||
__func__, desired_system);
|
__func__, desired_system);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
ncaps++;
|
ncaps++;
|
||||||
@ -1722,8 +1724,8 @@ static int dvbv3_set_delivery_system(struct dvb_frontend *fe)
|
|||||||
*/
|
*/
|
||||||
if (is_dvbv3_delsys(c->delivery_system)) {
|
if (is_dvbv3_delsys(c->delivery_system)) {
|
||||||
dev_dbg(fe->dvb->device,
|
dev_dbg(fe->dvb->device,
|
||||||
"%s: Using delivery system to %d\n",
|
"%s: Using delivery system to %d\n",
|
||||||
__func__, c->delivery_system);
|
__func__, c->delivery_system);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1763,8 +1765,8 @@ static int dvbv3_set_delivery_system(struct dvb_frontend *fe)
|
|||||||
* Zero on success, negative errno on failure.
|
* Zero on success, negative errno on failure.
|
||||||
*/
|
*/
|
||||||
static int dtv_property_process_set(struct dvb_frontend *fe,
|
static int dtv_property_process_set(struct dvb_frontend *fe,
|
||||||
struct file *file,
|
struct file *file,
|
||||||
u32 cmd, u32 data)
|
u32 cmd, u32 data)
|
||||||
{
|
{
|
||||||
int r = 0;
|
int r = 0;
|
||||||
struct dtv_frontend_properties *c = &fe->dtv_property_cache;
|
struct dtv_frontend_properties *c = &fe->dtv_property_cache;
|
||||||
@ -1772,11 +1774,11 @@ static int dtv_property_process_set(struct dvb_frontend *fe,
|
|||||||
/** Dump DTV command name and value*/
|
/** Dump DTV command name and value*/
|
||||||
if (!cmd || cmd > DTV_MAX_COMMAND)
|
if (!cmd || cmd > DTV_MAX_COMMAND)
|
||||||
dev_warn(fe->dvb->device, "%s: SET cmd 0x%08x undefined\n",
|
dev_warn(fe->dvb->device, "%s: SET cmd 0x%08x undefined\n",
|
||||||
__func__, cmd);
|
__func__, cmd);
|
||||||
else
|
else
|
||||||
dev_dbg(fe->dvb->device,
|
dev_dbg(fe->dvb->device,
|
||||||
"%s: SET cmd 0x%08x (%s) to 0x%08x\n",
|
"%s: SET cmd 0x%08x (%s) to 0x%08x\n",
|
||||||
__func__, cmd, dtv_cmds[cmd].name, data);
|
__func__, cmd, dtv_cmds[cmd].name, data);
|
||||||
switch (cmd) {
|
switch (cmd) {
|
||||||
case DTV_CLEAR:
|
case DTV_CLEAR:
|
||||||
/*
|
/*
|
||||||
@ -1826,12 +1828,12 @@ static int dtv_property_process_set(struct dvb_frontend *fe,
|
|||||||
case DTV_VOLTAGE:
|
case DTV_VOLTAGE:
|
||||||
c->voltage = data;
|
c->voltage = data;
|
||||||
r = dvb_frontend_handle_ioctl(file, FE_SET_VOLTAGE,
|
r = dvb_frontend_handle_ioctl(file, FE_SET_VOLTAGE,
|
||||||
(void *)c->voltage);
|
(void *)c->voltage);
|
||||||
break;
|
break;
|
||||||
case DTV_TONE:
|
case DTV_TONE:
|
||||||
c->sectone = data;
|
c->sectone = data;
|
||||||
r = dvb_frontend_handle_ioctl(file, FE_SET_TONE,
|
r = dvb_frontend_handle_ioctl(file, FE_SET_TONE,
|
||||||
(void *)c->sectone);
|
(void *)c->sectone);
|
||||||
break;
|
break;
|
||||||
case DTV_CODE_RATE_HP:
|
case DTV_CODE_RATE_HP:
|
||||||
c->code_rate_HP = data;
|
c->code_rate_HP = data;
|
||||||
@ -2052,8 +2054,8 @@ static int dvb_frontend_handle_compat_ioctl(struct file *file, unsigned int cmd,
|
|||||||
|
|
||||||
for (i = 0; i < tvps->num; i++) {
|
for (i = 0; i < tvps->num; i++) {
|
||||||
err = dtv_property_process_set(fe, file,
|
err = dtv_property_process_set(fe, file,
|
||||||
(tvp + i)->cmd,
|
(tvp + i)->cmd,
|
||||||
(tvp + i)->u.data);
|
(tvp + i)->u.data);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
kfree(tvp);
|
kfree(tvp);
|
||||||
return err;
|
return err;
|
||||||
@ -2272,7 +2274,6 @@ static int dtv_set_frontend(struct dvb_frontend *fe)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static int dvb_frontend_handle_ioctl(struct file *file,
|
static int dvb_frontend_handle_ioctl(struct file *file,
|
||||||
unsigned int cmd, void *parg)
|
unsigned int cmd, void *parg)
|
||||||
{
|
{
|
||||||
@ -2307,8 +2308,8 @@ static int dvb_frontend_handle_ioctl(struct file *file,
|
|||||||
|
|
||||||
for (i = 0; i < tvps->num; i++) {
|
for (i = 0; i < tvps->num; i++) {
|
||||||
err = dtv_property_process_set(fe, file,
|
err = dtv_property_process_set(fe, file,
|
||||||
(tvp + i)->cmd,
|
(tvp + i)->cmd,
|
||||||
(tvp + i)->u.data);
|
(tvp + i)->u.data);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
kfree(tvp);
|
kfree(tvp);
|
||||||
return err;
|
return err;
|
||||||
@ -2372,7 +2373,7 @@ static int dvb_frontend_handle_ioctl(struct file *file,
|
|||||||
}
|
}
|
||||||
|
|
||||||
case FE_GET_INFO: {
|
case FE_GET_INFO: {
|
||||||
struct dvb_frontend_info* info = parg;
|
struct dvb_frontend_info *info = parg;
|
||||||
|
|
||||||
memcpy(info, &fe->ops.info, sizeof(struct dvb_frontend_info));
|
memcpy(info, &fe->ops.info, sizeof(struct dvb_frontend_info));
|
||||||
dvb_frontend_get_frequency_limits(fe, &info->frequency_min, &info->frequency_max);
|
dvb_frontend_get_frequency_limits(fe, &info->frequency_min, &info->frequency_max);
|
||||||
@ -2403,12 +2404,12 @@ static int dvb_frontend_handle_ioctl(struct file *file,
|
|||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
dev_err(fe->dvb->device,
|
dev_err(fe->dvb->device,
|
||||||
"%s: doesn't know how to handle a DVBv3 call to delivery system %i\n",
|
"%s: doesn't know how to handle a DVBv3 call to delivery system %i\n",
|
||||||
__func__, c->delivery_system);
|
__func__, c->delivery_system);
|
||||||
fe->ops.info.type = FE_OFDM;
|
fe->ops.info.type = FE_OFDM;
|
||||||
}
|
}
|
||||||
dev_dbg(fe->dvb->device, "%s: current delivery system on cache: %d, V3 type: %d\n",
|
dev_dbg(fe->dvb->device, "%s: current delivery system on cache: %d, V3 type: %d\n",
|
||||||
__func__, c->delivery_system, fe->ops.info.type);
|
__func__, c->delivery_system, fe->ops.info.type);
|
||||||
|
|
||||||
/* Set CAN_INVERSION_AUTO bit on in other than oneshot mode */
|
/* Set CAN_INVERSION_AUTO bit on in other than oneshot mode */
|
||||||
if (!(fepriv->tune_mode_flags & FE_TUNE_MODE_ONESHOT))
|
if (!(fepriv->tune_mode_flags & FE_TUNE_MODE_ONESHOT))
|
||||||
@ -2424,7 +2425,7 @@ static int dvb_frontend_handle_ioctl(struct file *file,
|
|||||||
* that user get signal state from previous tuning */
|
* that user get signal state from previous tuning */
|
||||||
if (fepriv->state == FESTATE_RETUNE ||
|
if (fepriv->state == FESTATE_RETUNE ||
|
||||||
fepriv->state == FESTATE_ERROR) {
|
fepriv->state == FESTATE_ERROR) {
|
||||||
err=0;
|
err = 0;
|
||||||
*status = 0;
|
*status = 0;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -2492,11 +2493,11 @@ static int dvb_frontend_handle_ioctl(struct file *file,
|
|||||||
|
|
||||||
case FE_ENABLE_HIGH_LNB_VOLTAGE:
|
case FE_ENABLE_HIGH_LNB_VOLTAGE:
|
||||||
if (fe->ops.enable_high_lnb_voltage)
|
if (fe->ops.enable_high_lnb_voltage)
|
||||||
err = fe->ops.enable_high_lnb_voltage(fe, (long) parg);
|
err = fe->ops.enable_high_lnb_voltage(fe, (long)parg);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case FE_SET_FRONTEND_TUNE_MODE:
|
case FE_SET_FRONTEND_TUNE_MODE:
|
||||||
fepriv->tune_mode_flags = (unsigned long) parg;
|
fepriv->tune_mode_flags = (unsigned long)parg;
|
||||||
err = 0;
|
err = 0;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -2525,11 +2526,12 @@ static int dvb_frontend_handle_ioctl(struct file *file,
|
|||||||
* initialization, so parg is 8 bits and does not
|
* initialization, so parg is 8 bits and does not
|
||||||
* include the initialization or start bit
|
* include the initialization or start bit
|
||||||
*/
|
*/
|
||||||
unsigned long swcmd = ((unsigned long) parg) << 1;
|
unsigned long swcmd = ((unsigned long)parg) << 1;
|
||||||
ktime_t nexttime;
|
ktime_t nexttime;
|
||||||
ktime_t tv[10];
|
ktime_t tv[10];
|
||||||
int i;
|
int i;
|
||||||
u8 last = 1;
|
u8 last = 1;
|
||||||
|
|
||||||
if (dvb_frontend_debug)
|
if (dvb_frontend_debug)
|
||||||
dprintk("%s switch command: 0x%04lx\n",
|
dprintk("%s switch command: 0x%04lx\n",
|
||||||
__func__, swcmd);
|
__func__, swcmd);
|
||||||
@ -2544,7 +2546,7 @@ static int dvb_frontend_handle_ioctl(struct file *file,
|
|||||||
|
|
||||||
for (i = 0; i < 9; i++) {
|
for (i = 0; i < 9; i++) {
|
||||||
if (dvb_frontend_debug)
|
if (dvb_frontend_debug)
|
||||||
tv[i+1] = ktime_get_boottime();
|
tv[i + 1] = ktime_get_boottime();
|
||||||
if ((swcmd & 0x01) != last) {
|
if ((swcmd & 0x01) != last) {
|
||||||
/* set voltage to (last ? 13V : 18V) */
|
/* set voltage to (last ? 13V : 18V) */
|
||||||
fe->ops.set_voltage(fe, (last) ? SEC_VOLTAGE_13 : SEC_VOLTAGE_18);
|
fe->ops.set_voltage(fe, (last) ? SEC_VOLTAGE_13 : SEC_VOLTAGE_18);
|
||||||
@ -2559,7 +2561,7 @@ static int dvb_frontend_handle_ioctl(struct file *file,
|
|||||||
__func__, fe->dvb->num);
|
__func__, fe->dvb->num);
|
||||||
for (i = 1; i < 10; i++)
|
for (i = 1; i < 10; i++)
|
||||||
pr_info("%d: %d\n", i,
|
pr_info("%d: %d\n", i,
|
||||||
(int) ktime_us_delta(tv[i], tv[i-1]));
|
(int)ktime_us_delta(tv[i], tv[i - 1]));
|
||||||
}
|
}
|
||||||
err = 0;
|
err = 0;
|
||||||
fepriv->state = FESTATE_DISEQC;
|
fepriv->state = FESTATE_DISEQC;
|
||||||
@ -2618,7 +2620,7 @@ static int dvb_frontend_handle_ioctl(struct file *file,
|
|||||||
err = dtv_set_frontend(fe);
|
err = dtv_set_frontend(fe);
|
||||||
break;
|
break;
|
||||||
case FE_GET_EVENT:
|
case FE_GET_EVENT:
|
||||||
err = dvb_frontend_get_event (fe, parg, file->f_flags);
|
err = dvb_frontend_get_event(fe, parg, file->f_flags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case FE_GET_FRONTEND: {
|
case FE_GET_FRONTEND: {
|
||||||
@ -2641,7 +2643,6 @@ static int dvb_frontend_handle_ioctl(struct file *file,
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static __poll_t dvb_frontend_poll(struct file *file, struct poll_table_struct *wait)
|
static __poll_t dvb_frontend_poll(struct file *file, struct poll_table_struct *wait)
|
||||||
{
|
{
|
||||||
struct dvb_device *dvbdev = file->private_data;
|
struct dvb_device *dvbdev = file->private_data;
|
||||||
@ -2650,7 +2651,7 @@ static __poll_t dvb_frontend_poll(struct file *file, struct poll_table_struct *w
|
|||||||
|
|
||||||
dev_dbg_ratelimited(fe->dvb->device, "%s:\n", __func__);
|
dev_dbg_ratelimited(fe->dvb->device, "%s:\n", __func__);
|
||||||
|
|
||||||
poll_wait (file, &fepriv->events.wait_queue, wait);
|
poll_wait(file, &fepriv->events.wait_queue, wait);
|
||||||
|
|
||||||
if (fepriv->events.eventw != fepriv->events.eventr)
|
if (fepriv->events.eventw != fepriv->events.eventr)
|
||||||
return (EPOLLIN | EPOLLRDNORM | EPOLLPRI);
|
return (EPOLLIN | EPOLLRDNORM | EPOLLPRI);
|
||||||
@ -2671,9 +2672,9 @@ static int dvb_frontend_open(struct inode *inode, struct file *file)
|
|||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
|
||||||
if (adapter->mfe_shared) {
|
if (adapter->mfe_shared) {
|
||||||
mutex_lock (&adapter->mfe_lock);
|
mutex_lock(&adapter->mfe_lock);
|
||||||
|
|
||||||
if (adapter->mfe_dvbdev == NULL)
|
if (!adapter->mfe_dvbdev)
|
||||||
adapter->mfe_dvbdev = dvbdev;
|
adapter->mfe_dvbdev = dvbdev;
|
||||||
|
|
||||||
else if (adapter->mfe_dvbdev != dvbdev) {
|
else if (adapter->mfe_dvbdev != dvbdev) {
|
||||||
@ -2685,23 +2686,23 @@ static int dvb_frontend_open(struct inode *inode, struct file *file)
|
|||||||
*mfepriv = mfe->frontend_priv;
|
*mfepriv = mfe->frontend_priv;
|
||||||
int mferetry = (dvb_mfe_wait_time << 1);
|
int mferetry = (dvb_mfe_wait_time << 1);
|
||||||
|
|
||||||
mutex_unlock (&adapter->mfe_lock);
|
mutex_unlock(&adapter->mfe_lock);
|
||||||
while (mferetry-- && (mfedev->users != -1 ||
|
while (mferetry-- && (mfedev->users != -1 ||
|
||||||
mfepriv->thread != NULL)) {
|
mfepriv->thread)) {
|
||||||
if(msleep_interruptible(500)) {
|
if (msleep_interruptible(500)) {
|
||||||
if(signal_pending(current))
|
if (signal_pending(current))
|
||||||
return -EINTR;
|
return -EINTR;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
mutex_lock (&adapter->mfe_lock);
|
mutex_lock(&adapter->mfe_lock);
|
||||||
if(adapter->mfe_dvbdev != dvbdev) {
|
if (adapter->mfe_dvbdev != dvbdev) {
|
||||||
mfedev = adapter->mfe_dvbdev;
|
mfedev = adapter->mfe_dvbdev;
|
||||||
mfe = mfedev->priv;
|
mfe = mfedev->priv;
|
||||||
mfepriv = mfe->frontend_priv;
|
mfepriv = mfe->frontend_priv;
|
||||||
if (mfedev->users != -1 ||
|
if (mfedev->users != -1 ||
|
||||||
mfepriv->thread != NULL) {
|
mfepriv->thread) {
|
||||||
mutex_unlock (&adapter->mfe_lock);
|
mutex_unlock(&adapter->mfe_lock);
|
||||||
return -EBUSY;
|
return -EBUSY;
|
||||||
}
|
}
|
||||||
adapter->mfe_dvbdev = dvbdev;
|
adapter->mfe_dvbdev = dvbdev;
|
||||||
@ -2722,7 +2723,7 @@ static int dvb_frontend_open(struct inode *inode, struct file *file)
|
|||||||
fepriv->reinitialise = 1;
|
fepriv->reinitialise = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((ret = dvb_generic_open (inode, file)) < 0)
|
if ((ret = dvb_generic_open(inode, file)) < 0)
|
||||||
goto err1;
|
goto err1;
|
||||||
|
|
||||||
if ((file->f_flags & O_ACCMODE) != O_RDONLY) {
|
if ((file->f_flags & O_ACCMODE) != O_RDONLY) {
|
||||||
@ -2749,7 +2750,7 @@ static int dvb_frontend_open(struct inode *inode, struct file *file)
|
|||||||
}
|
}
|
||||||
mutex_unlock(&fe->dvb->mdev_lock);
|
mutex_unlock(&fe->dvb->mdev_lock);
|
||||||
#endif
|
#endif
|
||||||
ret = dvb_frontend_start (fe);
|
ret = dvb_frontend_start(fe);
|
||||||
if (ret)
|
if (ret)
|
||||||
goto err3;
|
goto err3;
|
||||||
|
|
||||||
@ -2760,7 +2761,7 @@ static int dvb_frontend_open(struct inode *inode, struct file *file)
|
|||||||
dvb_frontend_get(fe);
|
dvb_frontend_get(fe);
|
||||||
|
|
||||||
if (adapter->mfe_shared)
|
if (adapter->mfe_shared)
|
||||||
mutex_unlock (&adapter->mfe_lock);
|
mutex_unlock(&adapter->mfe_lock);
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
err3:
|
err3:
|
||||||
@ -2781,7 +2782,7 @@ err1:
|
|||||||
fe->ops.ts_bus_ctrl(fe, 0);
|
fe->ops.ts_bus_ctrl(fe, 0);
|
||||||
err0:
|
err0:
|
||||||
if (adapter->mfe_shared)
|
if (adapter->mfe_shared)
|
||||||
mutex_unlock (&adapter->mfe_lock);
|
mutex_unlock(&adapter->mfe_lock);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2799,7 +2800,7 @@ static int dvb_frontend_release(struct inode *inode, struct file *file)
|
|||||||
mb();
|
mb();
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = dvb_generic_release (inode, file);
|
ret = dvb_generic_release(inode, file);
|
||||||
|
|
||||||
if (dvbdev->users == -1) {
|
if (dvbdev->users == -1) {
|
||||||
wake_up(&fepriv->wait_queue);
|
wake_up(&fepriv->wait_queue);
|
||||||
@ -2841,7 +2842,7 @@ int dvb_frontend_suspend(struct dvb_frontend *fe)
|
|||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
dev_dbg(fe->dvb->device, "%s: adap=%d fe=%d\n", __func__, fe->dvb->num,
|
dev_dbg(fe->dvb->device, "%s: adap=%d fe=%d\n", __func__, fe->dvb->num,
|
||||||
fe->id);
|
fe->id);
|
||||||
|
|
||||||
if (fe->ops.tuner_ops.suspend)
|
if (fe->ops.tuner_ops.suspend)
|
||||||
ret = fe->ops.tuner_ops.suspend(fe);
|
ret = fe->ops.tuner_ops.suspend(fe);
|
||||||
@ -2861,7 +2862,7 @@ int dvb_frontend_resume(struct dvb_frontend *fe)
|
|||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
dev_dbg(fe->dvb->device, "%s: adap=%d fe=%d\n", __func__, fe->dvb->num,
|
dev_dbg(fe->dvb->device, "%s: adap=%d fe=%d\n", __func__, fe->dvb->num,
|
||||||
fe->id);
|
fe->id);
|
||||||
|
|
||||||
fe->exit = DVB_FE_DEVICE_RESUME;
|
fe->exit = DVB_FE_DEVICE_RESUME;
|
||||||
if (fe->ops.init)
|
if (fe->ops.init)
|
||||||
@ -2885,14 +2886,14 @@ int dvb_frontend_resume(struct dvb_frontend *fe)
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL(dvb_frontend_resume);
|
EXPORT_SYMBOL(dvb_frontend_resume);
|
||||||
|
|
||||||
int dvb_register_frontend(struct dvb_adapter* dvb,
|
int dvb_register_frontend(struct dvb_adapter *dvb,
|
||||||
struct dvb_frontend* fe)
|
struct dvb_frontend *fe)
|
||||||
{
|
{
|
||||||
struct dvb_frontend_private *fepriv;
|
struct dvb_frontend_private *fepriv;
|
||||||
const struct dvb_device dvbdev_template = {
|
const struct dvb_device dvbdev_template = {
|
||||||
.users = ~0,
|
.users = ~0,
|
||||||
.writers = 1,
|
.writers = 1,
|
||||||
.readers = (~0)-1,
|
.readers = (~0) - 1,
|
||||||
.fops = &dvb_frontend_fops,
|
.fops = &dvb_frontend_fops,
|
||||||
#if defined(CONFIG_MEDIA_CONTROLLER_DVB)
|
#if defined(CONFIG_MEDIA_CONTROLLER_DVB)
|
||||||
.name = fe->ops.info.name,
|
.name = fe->ops.info.name,
|
||||||
@ -2905,7 +2906,7 @@ int dvb_register_frontend(struct dvb_adapter* dvb,
|
|||||||
return -ERESTARTSYS;
|
return -ERESTARTSYS;
|
||||||
|
|
||||||
fe->frontend_priv = kzalloc(sizeof(struct dvb_frontend_private), GFP_KERNEL);
|
fe->frontend_priv = kzalloc(sizeof(struct dvb_frontend_private), GFP_KERNEL);
|
||||||
if (fe->frontend_priv == NULL) {
|
if (!fe->frontend_priv) {
|
||||||
mutex_unlock(&frontend_mutex);
|
mutex_unlock(&frontend_mutex);
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
}
|
}
|
||||||
@ -2921,18 +2922,18 @@ int dvb_register_frontend(struct dvb_adapter* dvb,
|
|||||||
dvb_frontend_get(fe);
|
dvb_frontend_get(fe);
|
||||||
|
|
||||||
sema_init(&fepriv->sem, 1);
|
sema_init(&fepriv->sem, 1);
|
||||||
init_waitqueue_head (&fepriv->wait_queue);
|
init_waitqueue_head(&fepriv->wait_queue);
|
||||||
init_waitqueue_head (&fepriv->events.wait_queue);
|
init_waitqueue_head(&fepriv->events.wait_queue);
|
||||||
mutex_init(&fepriv->events.mtx);
|
mutex_init(&fepriv->events.mtx);
|
||||||
fe->dvb = dvb;
|
fe->dvb = dvb;
|
||||||
fepriv->inversion = INVERSION_OFF;
|
fepriv->inversion = INVERSION_OFF;
|
||||||
|
|
||||||
dev_info(fe->dvb->device,
|
dev_info(fe->dvb->device,
|
||||||
"DVB: registering adapter %i frontend %i (%s)...\n",
|
"DVB: registering adapter %i frontend %i (%s)...\n",
|
||||||
fe->dvb->num, fe->id, fe->ops.info.name);
|
fe->dvb->num, fe->id, fe->ops.info.name);
|
||||||
|
|
||||||
dvb_register_device (fe->dvb, &fepriv->dvbdev, &dvbdev_template,
|
dvb_register_device(fe->dvb, &fepriv->dvbdev, &dvbdev_template,
|
||||||
fe, DVB_DEVICE_FRONTEND, 0);
|
fe, DVB_DEVICE_FRONTEND, 0);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Initialize the cache to the proper values according with the
|
* Initialize the cache to the proper values according with the
|
||||||
@ -2947,9 +2948,10 @@ int dvb_register_frontend(struct dvb_adapter* dvb,
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL(dvb_register_frontend);
|
EXPORT_SYMBOL(dvb_register_frontend);
|
||||||
|
|
||||||
int dvb_unregister_frontend(struct dvb_frontend* fe)
|
int dvb_unregister_frontend(struct dvb_frontend *fe)
|
||||||
{
|
{
|
||||||
struct dvb_frontend_private *fepriv = fe->frontend_priv;
|
struct dvb_frontend_private *fepriv = fe->frontend_priv;
|
||||||
|
|
||||||
dev_dbg(fe->dvb->device, "%s:\n", __func__);
|
dev_dbg(fe->dvb->device, "%s:\n", __func__);
|
||||||
|
|
||||||
mutex_lock(&frontend_mutex);
|
mutex_lock(&frontend_mutex);
|
||||||
@ -2974,7 +2976,7 @@ static void dvb_frontend_invoke_release(struct dvb_frontend *fe,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void dvb_frontend_detach(struct dvb_frontend* fe)
|
void dvb_frontend_detach(struct dvb_frontend *fe)
|
||||||
{
|
{
|
||||||
dvb_frontend_invoke_release(fe, fe->ops.release_sec);
|
dvb_frontend_invoke_release(fe, fe->ops.release_sec);
|
||||||
dvb_frontend_invoke_release(fe, fe->ops.tuner_ops.release);
|
dvb_frontend_invoke_release(fe, fe->ops.tuner_ops.release);
|
||||||
|
Loading…
Reference in New Issue
Block a user