Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 357177
b: refs/heads/master
c: 6ae2322
h: refs/heads/master
i:
  357175: 833673e
v: v3
  • Loading branch information
Juergen Lock authored and Mauro Carvalho Chehab committed Dec 27, 2012
1 parent 31cac87 commit c378807
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 6 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: a75831f3600c479054fc3f70cd11257ab07886e2
refs/heads/master: 6ae23224557d797439d02f6ce5d10a82ab544b21
19 changes: 14 additions & 5 deletions trunk/drivers/media/dvb-core/dvb_frontend.c
Original file line number Diff line number Diff line change
Expand Up @@ -603,6 +603,7 @@ static int dvb_frontend_thread(void *data)
enum dvbfe_algo algo;

bool re_tune = false;
bool semheld = false;

dev_dbg(fe->dvb->device, "%s:\n", __func__);

Expand All @@ -626,6 +627,8 @@ static int dvb_frontend_thread(void *data)

if (kthread_should_stop() || dvb_frontend_is_exiting(fe)) {
/* got signal or quitting */
if (!down_interruptible(&fepriv->sem))
semheld = true;
fepriv->exit = DVB_FE_NORMAL_EXIT;
break;
}
Expand Down Expand Up @@ -741,6 +744,8 @@ static int dvb_frontend_thread(void *data)
fepriv->exit = DVB_FE_NO_EXIT;
mb();

if (semheld)
up(&fepriv->sem);
dvb_frontend_wakeup(fe);
return 0;
}
Expand Down Expand Up @@ -1823,16 +1828,20 @@ static int dvb_frontend_ioctl(struct file *file,
int err = -ENOTTY;

dev_dbg(fe->dvb->device, "%s: (%d)\n", __func__, _IOC_NR(cmd));
if (fepriv->exit != DVB_FE_NO_EXIT)
if (down_interruptible(&fepriv->sem))
return -ERESTARTSYS;

if (fepriv->exit != DVB_FE_NO_EXIT) {
up(&fepriv->sem);
return -ENODEV;
}

if ((file->f_flags & O_ACCMODE) == O_RDONLY &&
(_IOC_DIR(cmd) != _IOC_READ || cmd == FE_GET_EVENT ||
cmd == FE_DISEQC_RECV_SLAVE_REPLY))
cmd == FE_DISEQC_RECV_SLAVE_REPLY)) {
up(&fepriv->sem);
return -EPERM;

if (down_interruptible (&fepriv->sem))
return -ERESTARTSYS;
}

if ((cmd == FE_SET_PROPERTY) || (cmd == FE_GET_PROPERTY))
err = dvb_frontend_ioctl_properties(file, cmd, parg);
Expand Down

0 comments on commit c378807

Please sign in to comment.