]>
Commit | Line | Data |
---|---|---|
1da177e4 LT |
1 | /* highmem.c: arch-specific highmem stuff |
2 | * | |
3 | * Copyright (C) 2004 Red Hat, Inc. All Rights Reserved. | |
4 | * Written by David Howells ([email protected]) | |
5 | * | |
6 | * This program is free software; you can redistribute it and/or | |
7 | * modify it under the terms of the GNU General Public License | |
8 | * as published by the Free Software Foundation; either version | |
9 | * 2 of the License, or (at your option) any later version. | |
10 | */ | |
11 | #include <linux/highmem.h> | |
40234401 | 12 | #include <linux/module.h> |
1da177e4 LT |
13 | |
14 | void *kmap(struct page *page) | |
15 | { | |
16 | might_sleep(); | |
17 | if (!PageHighMem(page)) | |
18 | return page_address(page); | |
19 | return kmap_high(page); | |
20 | } | |
21 | ||
40234401 DH |
22 | EXPORT_SYMBOL(kmap); |
23 | ||
1da177e4 LT |
24 | void kunmap(struct page *page) |
25 | { | |
26 | if (in_interrupt()) | |
27 | BUG(); | |
28 | if (!PageHighMem(page)) | |
29 | return; | |
30 | kunmap_high(page); | |
31 | } | |
32 | ||
40234401 DH |
33 | EXPORT_SYMBOL(kunmap); |
34 | ||
1da177e4 LT |
35 | struct page *kmap_atomic_to_page(void *ptr) |
36 | { | |
37 | return virt_to_page(ptr); | |
38 | } | |
3e4d3af5 | 39 | |
a24401bc | 40 | void *kmap_atomic(struct page *page) |
3e4d3af5 PZ |
41 | { |
42 | unsigned long paddr; | |
43 | int type; | |
44 | ||
2cb7c9cb | 45 | preempt_disable(); |
3e4d3af5 PZ |
46 | pagefault_disable(); |
47 | type = kmap_atomic_idx_push(); | |
48 | paddr = page_to_phys(page); | |
49 | ||
50 | switch (type) { | |
51 | /* | |
52 | * The first 4 primary maps are reserved for architecture code | |
53 | */ | |
144cf864 CW |
54 | case 0: return __kmap_atomic_primary(0, paddr, 6); |
55 | case 1: return __kmap_atomic_primary(0, paddr, 7); | |
56 | case 2: return __kmap_atomic_primary(0, paddr, 8); | |
57 | case 3: return __kmap_atomic_primary(0, paddr, 9); | |
58 | case 4: return __kmap_atomic_primary(0, paddr, 10); | |
3e4d3af5 PZ |
59 | |
60 | case 5 ... 5 + NR_TLB_LINES - 1: | |
61 | return __kmap_atomic_secondary(type - 5, paddr); | |
62 | ||
63 | default: | |
64 | BUG(); | |
65 | return NULL; | |
66 | } | |
67 | } | |
a24401bc | 68 | EXPORT_SYMBOL(kmap_atomic); |
3e4d3af5 PZ |
69 | |
70 | void __kunmap_atomic(void *kvaddr) | |
71 | { | |
20273941 | 72 | int type = kmap_atomic_idx(); |
3e4d3af5 | 73 | switch (type) { |
144cf864 CW |
74 | case 0: __kunmap_atomic_primary(0, 6); break; |
75 | case 1: __kunmap_atomic_primary(0, 7); break; | |
76 | case 2: __kunmap_atomic_primary(0, 8); break; | |
77 | case 3: __kunmap_atomic_primary(0, 9); break; | |
78 | case 4: __kunmap_atomic_primary(0, 10); break; | |
3e4d3af5 PZ |
79 | |
80 | case 5 ... 5 + NR_TLB_LINES - 1: | |
81 | __kunmap_atomic_secondary(type - 5, kvaddr); | |
82 | break; | |
83 | ||
84 | default: | |
85 | BUG(); | |
86 | } | |
20273941 | 87 | kmap_atomic_idx_pop(); |
3e4d3af5 | 88 | pagefault_enable(); |
2cb7c9cb | 89 | preempt_enable(); |
3e4d3af5 PZ |
90 | } |
91 | EXPORT_SYMBOL(__kunmap_atomic); |