diff options
Diffstat (limited to 'fs/proc')
-rw-r--r-- | fs/proc/page.c | 17 |
1 files changed, 11 insertions, 6 deletions
diff --git a/fs/proc/page.c b/fs/proc/page.c index 38dd88b7ce84..e73e911b7d0c 100644 --- a/fs/proc/page.c +++ b/fs/proc/page.c | |||
@@ -12,6 +12,7 @@ | |||
12 | 12 | ||
13 | #define KPMSIZE sizeof(u64) | 13 | #define KPMSIZE sizeof(u64) |
14 | #define KPMMASK (KPMSIZE - 1) | 14 | #define KPMMASK (KPMSIZE - 1) |
15 | |||
15 | /* /proc/kpagecount - an array exposing page counts | 16 | /* /proc/kpagecount - an array exposing page counts |
16 | * | 17 | * |
17 | * Each entry is a u64 representing the corresponding | 18 | * Each entry is a u64 representing the corresponding |
@@ -33,20 +34,22 @@ static ssize_t kpagecount_read(struct file *file, char __user *buf, | |||
33 | return -EINVAL; | 34 | return -EINVAL; |
34 | 35 | ||
35 | while (count > 0) { | 36 | while (count > 0) { |
36 | ppage = NULL; | ||
37 | if (pfn_valid(pfn)) | 37 | if (pfn_valid(pfn)) |
38 | ppage = pfn_to_page(pfn); | 38 | ppage = pfn_to_page(pfn); |
39 | pfn++; | 39 | else |
40 | ppage = NULL; | ||
40 | if (!ppage) | 41 | if (!ppage) |
41 | pcount = 0; | 42 | pcount = 0; |
42 | else | 43 | else |
43 | pcount = page_mapcount(ppage); | 44 | pcount = page_mapcount(ppage); |
44 | 45 | ||
45 | if (put_user(pcount, out++)) { | 46 | if (put_user(pcount, out)) { |
46 | ret = -EFAULT; | 47 | ret = -EFAULT; |
47 | break; | 48 | break; |
48 | } | 49 | } |
49 | 50 | ||
51 | pfn++; | ||
52 | out++; | ||
50 | count -= KPMSIZE; | 53 | count -= KPMSIZE; |
51 | } | 54 | } |
52 | 55 | ||
@@ -99,10 +102,10 @@ static ssize_t kpageflags_read(struct file *file, char __user *buf, | |||
99 | return -EINVAL; | 102 | return -EINVAL; |
100 | 103 | ||
101 | while (count > 0) { | 104 | while (count > 0) { |
102 | ppage = NULL; | ||
103 | if (pfn_valid(pfn)) | 105 | if (pfn_valid(pfn)) |
104 | ppage = pfn_to_page(pfn); | 106 | ppage = pfn_to_page(pfn); |
105 | pfn++; | 107 | else |
108 | ppage = NULL; | ||
106 | if (!ppage) | 109 | if (!ppage) |
107 | kflags = 0; | 110 | kflags = 0; |
108 | else | 111 | else |
@@ -120,11 +123,13 @@ static ssize_t kpageflags_read(struct file *file, char __user *buf, | |||
120 | kpf_copy_bit(kflags, KPF_RECLAIM, PG_reclaim) | | 123 | kpf_copy_bit(kflags, KPF_RECLAIM, PG_reclaim) | |
121 | kpf_copy_bit(kflags, KPF_BUDDY, PG_buddy); | 124 | kpf_copy_bit(kflags, KPF_BUDDY, PG_buddy); |
122 | 125 | ||
123 | if (put_user(uflags, out++)) { | 126 | if (put_user(uflags, out)) { |
124 | ret = -EFAULT; | 127 | ret = -EFAULT; |
125 | break; | 128 | break; |
126 | } | 129 | } |
127 | 130 | ||
131 | pfn++; | ||
132 | out++; | ||
128 | count -= KPMSIZE; | 133 | count -= KPMSIZE; |
129 | } | 134 | } |
130 | 135 | ||