aboutsummaryrefslogtreecommitdiffstats
path: root/mm
diff options
context:
space:
mode:
Diffstat (limited to 'mm')
-rw-r--r--mm/highmem.c12
-rw-r--r--mm/page_io.c3
-rw-r--r--mm/swap.c3
3 files changed, 15 insertions, 3 deletions
diff --git a/mm/highmem.c b/mm/highmem.c
index 57d82c6250c3..d517cd16a6eb 100644
--- a/mm/highmem.c
+++ b/mm/highmem.c
@@ -94,6 +94,18 @@ static DECLARE_WAIT_QUEUE_HEAD(pkmap_map_wait);
94 do { spin_unlock(&kmap_lock); (void)(flags); } while (0) 94 do { spin_unlock(&kmap_lock); (void)(flags); } while (0)
95#endif 95#endif
96 96
97struct page *kmap_to_page(void *vaddr)
98{
99 unsigned long addr = (unsigned long)vaddr;
100
101 if (addr >= PKMAP_ADDR(0) && addr <= PKMAP_ADDR(LAST_PKMAP)) {
102 int i = (addr - PKMAP_ADDR(0)) >> PAGE_SHIFT;
103 return pte_page(pkmap_page_table[i]);
104 }
105
106 return virt_to_page(addr);
107}
108
97static void flush_all_zero_pkmaps(void) 109static void flush_all_zero_pkmaps(void)
98{ 110{
99 int i; 111 int i;
diff --git a/mm/page_io.c b/mm/page_io.c
index 4a379629e31f..78eee32ee486 100644
--- a/mm/page_io.c
+++ b/mm/page_io.c
@@ -205,7 +205,7 @@ int swap_writepage(struct page *page, struct writeback_control *wbc)
205 struct file *swap_file = sis->swap_file; 205 struct file *swap_file = sis->swap_file;
206 struct address_space *mapping = swap_file->f_mapping; 206 struct address_space *mapping = swap_file->f_mapping;
207 struct iovec iov = { 207 struct iovec iov = {
208 .iov_base = page_address(page), 208 .iov_base = kmap(page),
209 .iov_len = PAGE_SIZE, 209 .iov_len = PAGE_SIZE,
210 }; 210 };
211 211
@@ -218,6 +218,7 @@ int swap_writepage(struct page *page, struct writeback_control *wbc)
218 ret = mapping->a_ops->direct_IO(KERNEL_WRITE, 218 ret = mapping->a_ops->direct_IO(KERNEL_WRITE,
219 &kiocb, &iov, 219 &kiocb, &iov,
220 kiocb.ki_pos, 1); 220 kiocb.ki_pos, 1);
221 kunmap(page);
221 if (ret == PAGE_SIZE) { 222 if (ret == PAGE_SIZE) {
222 count_vm_event(PSWPOUT); 223 count_vm_event(PSWPOUT);
223 ret = 0; 224 ret = 0;
diff --git a/mm/swap.c b/mm/swap.c
index 7d7f80c8044a..77825883298f 100644
--- a/mm/swap.c
+++ b/mm/swap.c
@@ -258,8 +258,7 @@ int get_kernel_pages(const struct kvec *kiov, int nr_segs, int write,
258 if (WARN_ON(kiov[seg].iov_len != PAGE_SIZE)) 258 if (WARN_ON(kiov[seg].iov_len != PAGE_SIZE))
259 return seg; 259 return seg;
260 260
261 /* virt_to_page sanity checks the PFN */ 261 pages[seg] = kmap_to_page(kiov[seg].iov_base);
262 pages[seg] = virt_to_page(kiov[seg].iov_base);
263 page_cache_get(pages[seg]); 262 page_cache_get(pages[seg]);
264 } 263 }
265 264