staging: comedi vmk80xx: lock held on error path
authorDan Carpenter <dan.carpenter@oracle.com>
Fri, 20 Apr 2012 11:46:27 +0000 (14:46 +0300)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 20 Apr 2012 15:32:45 +0000 (08:32 -0700)
If the user passes an invalid command, then we don't drop the lock
before returning.  The check for invalid commands doesn't need to be
done under lock so I moved it forward a couple lines.

Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/comedi/drivers/vmk80xx.c

index 10ac58d0cdddb9d93ae2a6551dcd8c30d8ac8c72..856d0ea6007f1c52dc86183fc5cf3ec0f95e7c59 100644 (file)
@@ -1020,12 +1020,12 @@ static int vmk80xx_cnt_cinsn(struct comedi_device *cdev,
        if (n)
                return n;
 
-       down(&dev->limit_sem);
-
        insn_cmd = data[0];
        if (insn_cmd != INSN_CONFIG_RESET && insn_cmd != GPCT_RESET)
                return -EINVAL;
 
+       down(&dev->limit_sem);
+
        chan = CR_CHAN(insn->chanspec);
 
        if (dev->board.model == VMK8055_MODEL) {