summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHeiko Carstens <heiko.carstens@de.ibm.com>2013-10-08 09:29:09 +0200
committerMartin Schwidefsky <schwidefsky@de.ibm.com>2013-10-24 17:17:01 +0200
commiteb0bf929d5228ca0eb2758585f2e4e25aa20427e (patch)
tree68b30c431a0418d31feaca8046a9deab86172b7e
parent01997bbc924d63e6c4837c5d8dc190245bc473ec (diff)
downloadlwn-eb0bf929d5228ca0eb2758585f2e4e25aa20427e.tar.gz
lwn-eb0bf929d5228ca0eb2758585f2e4e25aa20427e.zip
s390/gup: handle zero nr_pages case correctly
If [__]get_user_pages_fast() gets called with nr_pages == 0, the current code would walk the page tables and pin as many pages until the first invalid pte (or the kernel crashed while writing struct page pointers to the pages array). So let's handle at least the nr_pages == 0 case correctly and exit early. Signed-off-by: Heiko Carstens <heiko.carstens@de.ibm.com> Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
-rw-r--r--arch/s390/mm/gup.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/arch/s390/mm/gup.c b/arch/s390/mm/gup.c
index d3a2b819fa0b..639fce464008 100644
--- a/arch/s390/mm/gup.c
+++ b/arch/s390/mm/gup.c
@@ -180,7 +180,7 @@ int __get_user_pages_fast(unsigned long start, int nr_pages, int write,
addr = start;
len = (unsigned long) nr_pages << PAGE_SHIFT;
end = start + len;
- if ((end < start) || (end > TASK_SIZE))
+ if ((end <= start) || (end > TASK_SIZE))
return 0;
/*
* local_irq_save() doesn't prevent pagetable teardown, but does