- Linus: more PageDirty / swapcache handling
[davej-history.git] / include / linux / highmem.h
blobeb5405d336deca7a6bbdb9d7c9a3ef1b9a356bde
1 #ifndef _LINUX_HIGHMEM_H
2 #define _LINUX_HIGHMEM_H
4 #include <linux/config.h>
5 #include <asm/pgalloc.h>
7 #ifdef CONFIG_HIGHMEM
9 extern struct page *highmem_start_page;
11 #include <asm/highmem.h>
13 /* declarations for linux/mm/highmem.c */
14 FASTCALL(unsigned int nr_free_highpages(void));
16 extern struct buffer_head * create_bounce(int rw, struct buffer_head * bh_orig);
19 static inline char *bh_kmap(struct buffer_head *bh)
21 return kmap(bh->b_page) + bh_offset(bh);
24 static inline void bh_kunmap(struct buffer_head *bh)
26 kunmap(bh->b_page);
29 #else /* CONFIG_HIGHMEM */
31 static inline unsigned int nr_free_highpages(void) { return 0; }
33 static inline void *kmap(struct page *page) { return page_address(page); }
35 #define kunmap(page) do { } while (0)
37 #define kmap_atomic(page,idx) kmap(page)
38 #define kunmap_atomic(page,idx) kunmap(page)
40 #define bh_kmap(bh) ((bh)->b_data)
41 #define bh_kunmap(bh) do { } while (0);
43 #endif /* CONFIG_HIGHMEM */
45 /* when CONFIG_HIGHMEM is not set these will be plain clear/copy_page */
46 static inline void clear_user_highpage(struct page *page, unsigned long vaddr)
48 clear_user_page(kmap(page), vaddr);
49 kunmap(page);
52 static inline void clear_highpage(struct page *page)
54 clear_page(kmap(page));
55 kunmap(page);
58 static inline void memclear_highpage(struct page *page, unsigned int offset, unsigned int size)
60 char *kaddr;
62 if (offset + size > PAGE_SIZE)
63 BUG();
64 kaddr = kmap(page);
65 memset(kaddr + offset, 0, size);
66 kunmap(page);
70 * Same but also flushes aliased cache contents to RAM.
72 static inline void memclear_highpage_flush(struct page *page, unsigned int offset, unsigned int size)
74 char *kaddr;
76 if (offset + size > PAGE_SIZE)
77 BUG();
78 kaddr = kmap(page);
79 memset(kaddr + offset, 0, size);
80 flush_page_to_ram(page);
81 kunmap(page);
84 static inline void copy_user_highpage(struct page *to, struct page *from, unsigned long vaddr)
86 char *vfrom, *vto;
88 vfrom = kmap(from);
89 vto = kmap(to);
90 copy_user_page(vto, vfrom, vaddr);
91 kunmap(from);
92 kunmap(to);
95 static inline void copy_highpage(struct page *to, struct page *from)
97 char *vfrom, *vto;
99 vfrom = kmap(from);
100 vto = kmap(to);
101 copy_page(vto, vfrom);
102 kunmap(from);
103 kunmap(to);
106 #endif /* _LINUX_HIGHMEM_H */