|
@@ -1432,7 +1432,21 @@ static int do_cancel(struct comedi_device *dev, struct comedi_subdevice *s)
|
|
|
return ret;
|
|
|
}
|
|
|
|
|
|
-static void comedi_unmap(struct vm_area_struct *area)
|
|
|
+
|
|
|
+static void comedi_vm_open(struct vm_area_struct *area)
|
|
|
+{
|
|
|
+ struct comedi_async *async;
|
|
|
+ struct comedi_device *dev;
|
|
|
+
|
|
|
+ async = area->vm_private_data;
|
|
|
+ dev = async->subdevice->device;
|
|
|
+
|
|
|
+ mutex_lock(&dev->mutex);
|
|
|
+ async->mmap_count++;
|
|
|
+ mutex_unlock(&dev->mutex);
|
|
|
+}
|
|
|
+
|
|
|
+static void comedi_vm_close(struct vm_area_struct *area)
|
|
|
{
|
|
|
struct comedi_async *async;
|
|
|
struct comedi_device *dev;
|
|
@@ -1446,7 +1460,8 @@ static void comedi_unmap(struct vm_area_struct *area)
|
|
|
}
|
|
|
|
|
|
static struct vm_operations_struct comedi_vm_ops = {
|
|
|
- .close = comedi_unmap,
|
|
|
+ .open = comedi_vm_open,
|
|
|
+ .close = comedi_vm_close,
|
|
|
};
|
|
|
|
|
|
static int comedi_mmap(struct file *file, struct vm_area_struct *vma)
|