|
@@ -198,6 +198,23 @@ static long v4l2_unlocked_ioctl(struct file *filp,
|
|
|
return vdev->fops->unlocked_ioctl(filp, cmd, arg);
|
|
|
}
|
|
|
|
|
|
+#ifdef CONFIG_MMU
|
|
|
+#define v4l2_get_unmapped_area NULL
|
|
|
+#else
|
|
|
+static unsigned long v4l2_get_unmapped_area(struct file *filp,
|
|
|
+ unsigned long addr, unsigned long len, unsigned long pgoff,
|
|
|
+ unsigned long flags)
|
|
|
+{
|
|
|
+ struct video_device *vdev = video_devdata(filp);
|
|
|
+
|
|
|
+ if (!vdev->fops->get_unmapped_area)
|
|
|
+ return -ENOSYS;
|
|
|
+ if (video_is_unregistered(vdev))
|
|
|
+ return -ENODEV;
|
|
|
+ return vdev->fops->get_unmapped_area(filp, addr, len, pgoff, flags);
|
|
|
+}
|
|
|
+#endif
|
|
|
+
|
|
|
static int v4l2_mmap(struct file *filp, struct vm_area_struct *vm)
|
|
|
{
|
|
|
struct video_device *vdev = video_devdata(filp);
|
|
@@ -250,6 +267,7 @@ static const struct file_operations v4l2_unlocked_fops = {
|
|
|
.read = v4l2_read,
|
|
|
.write = v4l2_write,
|
|
|
.open = v4l2_open,
|
|
|
+ .get_unmapped_area = v4l2_get_unmapped_area,
|
|
|
.mmap = v4l2_mmap,
|
|
|
.unlocked_ioctl = v4l2_unlocked_ioctl,
|
|
|
#ifdef CONFIG_COMPAT
|
|
@@ -265,6 +283,7 @@ static const struct file_operations v4l2_fops = {
|
|
|
.read = v4l2_read,
|
|
|
.write = v4l2_write,
|
|
|
.open = v4l2_open,
|
|
|
+ .get_unmapped_area = v4l2_get_unmapped_area,
|
|
|
.mmap = v4l2_mmap,
|
|
|
.ioctl = v4l2_ioctl,
|
|
|
#ifdef CONFIG_COMPAT
|