diff options
| author | Thomas Gleixner <tglx@linutronix.de> | 2018-06-22 21:20:35 +0200 | 
|---|---|---|
| committer | Thomas Gleixner <tglx@linutronix.de> | 2018-06-22 21:20:35 +0200 | 
| commit | 7731b8bc94e599c9a79e428f3359ff2c34b7576a (patch) | |
| tree | 879f18ccbe274122f2d4f095b43cbc7f953e0ada /drivers/android/binder_alloc.c | |
| parent | 48e315618dc4dc8904182cd221e3d395d5d97005 (diff) | |
| parent | 9ffc59d57228d74809700be6f7ecb1db10292f05 (diff) | |
Merge branch 'linus' into x86/urgent
Required to queue a dependent fix.
Diffstat (limited to 'drivers/android/binder_alloc.c')
| -rw-r--r-- | drivers/android/binder_alloc.c | 10 | 
1 files changed, 5 insertions, 5 deletions
diff --git a/drivers/android/binder_alloc.c b/drivers/android/binder_alloc.c index 5a426c877dfb..2628806c64a2 100644 --- a/drivers/android/binder_alloc.c +++ b/drivers/android/binder_alloc.c @@ -219,7 +219,7 @@ static int binder_update_page_range(struct binder_alloc *alloc, int allocate,  		mm = alloc->vma_vm_mm;  	if (mm) { -		down_write(&mm->mmap_sem); +		down_read(&mm->mmap_sem);  		vma = alloc->vma;  	} @@ -288,7 +288,7 @@ static int binder_update_page_range(struct binder_alloc *alloc, int allocate,  		/* vm_insert_page does not seem to increment the refcount */  	}  	if (mm) { -		up_write(&mm->mmap_sem); +		up_read(&mm->mmap_sem);  		mmput(mm);  	}  	return 0; @@ -321,7 +321,7 @@ err_page_ptr_cleared:  	}  err_no_vma:  	if (mm) { -		up_write(&mm->mmap_sem); +		up_read(&mm->mmap_sem);  		mmput(mm);  	}  	return vma ? -ENOMEM : -ESRCH; @@ -692,8 +692,8 @@ int binder_alloc_mmap_handler(struct binder_alloc *alloc,  		}  	}  #endif -	alloc->pages = kzalloc(sizeof(alloc->pages[0]) * -				   ((vma->vm_end - vma->vm_start) / PAGE_SIZE), +	alloc->pages = kcalloc((vma->vm_end - vma->vm_start) / PAGE_SIZE, +			       sizeof(alloc->pages[0]),  			       GFP_KERNEL);  	if (alloc->pages == NULL) {  		ret = -ENOMEM;  | 
