diff options
| author | Thomas Gleixner <tglx@linutronix.de> | 2011-05-20 20:06:24 +0200 | 
|---|---|---|
| committer | Thomas Gleixner <tglx@linutronix.de> | 2011-05-20 20:08:05 +0200 | 
| commit | 250f972d85effad5b6e10da4bbd877e6a4b503b6 (patch) | |
| tree | 007393a6fc6439af7e0121dd99a6f9f9fb8405bc /drivers/xen/gntalloc.c | |
| parent | 7372b0b122af0f6675f3ab65bfd91c8a438e0480 (diff) | |
| parent | bbe7b8bef48c567f5ff3f6041c1fb011292e8f12 (diff) | |
| download | olio-linux-3.10-250f972d85effad5b6e10da4bbd877e6a4b503b6.tar.xz olio-linux-3.10-250f972d85effad5b6e10da4bbd877e6a4b503b6.zip  | |
Merge branch 'timers/urgent' into timers/core
Reason: Get upstream fixes and kfree_rcu which is necessary for a
follow up patch.
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'drivers/xen/gntalloc.c')
| -rw-r--r-- | drivers/xen/gntalloc.c | 14 | 
1 files changed, 12 insertions, 2 deletions
diff --git a/drivers/xen/gntalloc.c b/drivers/xen/gntalloc.c index a7ffdfe19fc..f6832f46aea 100644 --- a/drivers/xen/gntalloc.c +++ b/drivers/xen/gntalloc.c @@ -427,6 +427,17 @@ static long gntalloc_ioctl(struct file *filp, unsigned int cmd,  	return 0;  } +static void gntalloc_vma_open(struct vm_area_struct *vma) +{ +	struct gntalloc_gref *gref = vma->vm_private_data; +	if (!gref) +		return; + +	spin_lock(&gref_lock); +	gref->users++; +	spin_unlock(&gref_lock); +} +  static void gntalloc_vma_close(struct vm_area_struct *vma)  {  	struct gntalloc_gref *gref = vma->vm_private_data; @@ -441,6 +452,7 @@ static void gntalloc_vma_close(struct vm_area_struct *vma)  }  static struct vm_operations_struct gntalloc_vmops = { +	.open = gntalloc_vma_open,  	.close = gntalloc_vma_close,  }; @@ -471,8 +483,6 @@ static int gntalloc_mmap(struct file *filp, struct vm_area_struct *vma)  	vma->vm_private_data = gref;  	vma->vm_flags |= VM_RESERVED; -	vma->vm_flags |= VM_DONTCOPY; -	vma->vm_flags |= VM_PFNMAP | VM_PFN_AT_MMAP;  	vma->vm_ops = &gntalloc_vmops;  |