diff options
-rw-r--r-- | linux/drivers/media/dvb/dvb-core/dvb_frontend.c | 27 |
1 files changed, 19 insertions, 8 deletions
diff --git a/linux/drivers/media/dvb/dvb-core/dvb_frontend.c b/linux/drivers/media/dvb/dvb-core/dvb_frontend.c index 39c167812..ba82c56eb 100644 --- a/linux/drivers/media/dvb/dvb-core/dvb_frontend.c +++ b/linux/drivers/media/dvb/dvb-core/dvb_frontend.c @@ -368,9 +368,13 @@ static int dvb_frontend_autotune(struct dvb_frontend_data *fe) // choose step size for zigzag scan switch(fe->info->type) { case FE_QPSK: - stepsize = fe->parameters.u.qpsk.symbol_rate / 16000; - maxdrift = fe->parameters.u.qpsk.symbol_rate / 2000; - if (maxdrift < 5000) maxdrift = 5000; + if (fe->parameters.u.qpsk.symbol_rate < 10000000) + stepsize = fe->parameters.u.qpsk.symbol_rate / 32000; + maxdrift = 5000; + else { + stepsize = fe->parameters.u.qpsk.symbol_rate / 16000; + maxdrift = fe->parameters.u.qpsk.symbol_rate / 2000; + } break; case FE_QAM: @@ -706,6 +710,7 @@ static int dvb_frontend_ioctl (struct inode *inode, struct file *file, struct dvb_device *dvbdev = file->private_data; struct dvb_frontend_data *fe = dvbdev->priv; int err = 0; + int delay_ms; dprintk ("%s\n", __FUNCTION__); @@ -731,11 +736,11 @@ static int dvb_frontend_ioctl (struct inode *inode, struct file *file, memcpy (&fe->parameters, parg, sizeof (struct dvb_frontend_parameters)); - fe->min_delay = dvb_frontend_internal_ioctl(&fe->frontend, FE_GETMINDELAY, &fe->parameters); - if (fe->min_delay <= 0) fe->min_delay = HZ/20; // default mindelay of 50ms - + delay_ms = dvb_frontend_internal_ioctl(&fe->frontend, FE_GETMINDELAY, &fe->parameters); + if (delay_ms >= 0) fe->min_delay = (delay_ms * HZ) / 1000; + else fe->min_delay = HZ/20; // default mindelay of 50ms + dvb_frontend_add_event (fe, 0); - wake_up_interruptible(&fe->wait_queue); break; case FE_GET_EVENT: @@ -762,7 +767,13 @@ static int dvb_frontend_ioctl (struct inode *inode, struct file *file, // This ensures the app doesn't start reading data too quickly, perhaps from the // previous lock, which is REALLY CONFUSING TO DEBUG! if ((cmd == FE_SET_FRONTEND) && (err == 0)) { - err = wait_event_interruptible(fe->wait_queue, fe->state == FESTATE_RETUNE); + // note: cannot use wait_event_interruptible_* here as that + // causes the thread not to wake until AFTER the call here returns. This is useless + // because the whole point is to have the thread wake first, and perform at least one tune + wake_up_interruptible(&fe->wait_queue); + while(fe->state & FESTATE_RETUNE) { + dvb_delay(10); + } } return err; |