diff options
author | venkatesh.pallipadi@intel.com <venkatesh.pallipadi@intel.com> | 2008-03-18 20:00:24 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-04-17 11:41:20 -0400 |
commit | b310f381d220b2c6e3fab16e8c6e4ca13eea75b2 (patch) | |
tree | dd25df964cd1280ee4f908002726b5ab921da807 | |
parent | ef354af4629e5cc76a3f64fc46d452f2b56d5a59 (diff) |
x86: PAT add ioremap_wc() interface
Introduce ioremap_wc for wc remap.
(generic wrapper is in a later patch)
Signed-off-by: Venkatesh Pallipadi <venkatesh.pallipadi@intel.com>
Signed-off-by: Suresh Siddha <suresh.b.siddha@intel.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
-rw-r--r-- | arch/x86/mm/ioremap.c | 30 | ||||
-rw-r--r-- | include/asm-x86/io.h | 3 | ||||
-rw-r--r-- | include/asm-x86/pgtable.h | 2 |
3 files changed, 35 insertions, 0 deletions
diff --git a/arch/x86/mm/ioremap.c b/arch/x86/mm/ioremap.c index 0cdb7f11ce49..51cd3956c564 100644 --- a/arch/x86/mm/ioremap.c +++ b/arch/x86/mm/ioremap.c | |||
@@ -97,6 +97,9 @@ int ioremap_change_attr(unsigned long vaddr, unsigned long size, | |||
97 | default: | 97 | default: |
98 | err = _set_memory_uc(vaddr, nrpages); | 98 | err = _set_memory_uc(vaddr, nrpages); |
99 | break; | 99 | break; |
100 | case _PAGE_CACHE_WC: | ||
101 | err = _set_memory_wc(vaddr, nrpages); | ||
102 | break; | ||
100 | case _PAGE_CACHE_WB: | 103 | case _PAGE_CACHE_WB: |
101 | err = _set_memory_wb(vaddr, nrpages); | 104 | err = _set_memory_wb(vaddr, nrpages); |
102 | break; | 105 | break; |
@@ -166,8 +169,13 @@ static void __iomem *__ioremap(resource_size_t phys_addr, unsigned long size, | |||
166 | * Do not fallback to certain memory types with certain | 169 | * Do not fallback to certain memory types with certain |
167 | * requested type: | 170 | * requested type: |
168 | * - request is uncached, return cannot be write-back | 171 | * - request is uncached, return cannot be write-back |
172 | * - request is uncached, return cannot be write-combine | ||
173 | * - request is write-combine, return cannot be write-back | ||
169 | */ | 174 | */ |
170 | if ((prot_val == _PAGE_CACHE_UC && | 175 | if ((prot_val == _PAGE_CACHE_UC && |
176 | (new_prot_val == _PAGE_CACHE_WB || | ||
177 | new_prot_val == _PAGE_CACHE_WC)) || | ||
178 | (prot_val == _PAGE_CACHE_WC && | ||
171 | new_prot_val == _PAGE_CACHE_WB)) { | 179 | new_prot_val == _PAGE_CACHE_WB)) { |
172 | free_memtype(phys_addr, phys_addr + size); | 180 | free_memtype(phys_addr, phys_addr + size); |
173 | return NULL; | 181 | return NULL; |
@@ -180,6 +188,9 @@ static void __iomem *__ioremap(resource_size_t phys_addr, unsigned long size, | |||
180 | default: | 188 | default: |
181 | prot = PAGE_KERNEL_NOCACHE; | 189 | prot = PAGE_KERNEL_NOCACHE; |
182 | break; | 190 | break; |
191 | case _PAGE_CACHE_WC: | ||
192 | prot = PAGE_KERNEL_WC; | ||
193 | break; | ||
183 | case _PAGE_CACHE_WB: | 194 | case _PAGE_CACHE_WB: |
184 | prot = PAGE_KERNEL; | 195 | prot = PAGE_KERNEL; |
185 | break; | 196 | break; |
@@ -235,6 +246,25 @@ void __iomem *ioremap_nocache(resource_size_t phys_addr, unsigned long size) | |||
235 | } | 246 | } |
236 | EXPORT_SYMBOL(ioremap_nocache); | 247 | EXPORT_SYMBOL(ioremap_nocache); |
237 | 248 | ||
249 | /** | ||
250 | * ioremap_wc - map memory into CPU space write combined | ||
251 | * @offset: bus address of the memory | ||
252 | * @size: size of the resource to map | ||
253 | * | ||
254 | * This version of ioremap ensures that the memory is marked write combining. | ||
255 | * Write combining allows faster writes to some hardware devices. | ||
256 | * | ||
257 | * Must be freed with iounmap. | ||
258 | */ | ||
259 | void __iomem *ioremap_wc(unsigned long phys_addr, unsigned long size) | ||
260 | { | ||
261 | if (pat_wc_enabled) | ||
262 | return __ioremap(phys_addr, size, _PAGE_CACHE_WC); | ||
263 | else | ||
264 | return ioremap_nocache(phys_addr, size); | ||
265 | } | ||
266 | EXPORT_SYMBOL(ioremap_wc); | ||
267 | |||
238 | void __iomem *ioremap_cache(resource_size_t phys_addr, unsigned long size) | 268 | void __iomem *ioremap_cache(resource_size_t phys_addr, unsigned long size) |
239 | { | 269 | { |
240 | return __ioremap(phys_addr, size, _PAGE_CACHE_WB); | 270 | return __ioremap(phys_addr, size, _PAGE_CACHE_WB); |
diff --git a/include/asm-x86/io.h b/include/asm-x86/io.h index 6fa150fa68fa..599cad3505c1 100644 --- a/include/asm-x86/io.h +++ b/include/asm-x86/io.h | |||
@@ -1,3 +1,5 @@ | |||
1 | #define ARCH_HAS_IOREMAP_WC | ||
2 | |||
1 | #ifdef CONFIG_X86_32 | 3 | #ifdef CONFIG_X86_32 |
2 | # include "io_32.h" | 4 | # include "io_32.h" |
3 | #else | 5 | #else |
@@ -5,4 +7,5 @@ | |||
5 | #endif | 7 | #endif |
6 | extern int ioremap_change_attr(unsigned long vaddr, unsigned long size, | 8 | extern int ioremap_change_attr(unsigned long vaddr, unsigned long size, |
7 | unsigned long prot_val); | 9 | unsigned long prot_val); |
10 | extern void __iomem * ioremap_wc(unsigned long offset, unsigned long size); | ||
8 | 11 | ||
diff --git a/include/asm-x86/pgtable.h b/include/asm-x86/pgtable.h index ca6deb3de7c0..e814cfe96af2 100644 --- a/include/asm-x86/pgtable.h +++ b/include/asm-x86/pgtable.h | |||
@@ -90,6 +90,7 @@ extern pteval_t __PAGE_KERNEL, __PAGE_KERNEL_EXEC; | |||
90 | #define __PAGE_KERNEL_RO (__PAGE_KERNEL & ~_PAGE_RW) | 90 | #define __PAGE_KERNEL_RO (__PAGE_KERNEL & ~_PAGE_RW) |
91 | #define __PAGE_KERNEL_RX (__PAGE_KERNEL_EXEC & ~_PAGE_RW) | 91 | #define __PAGE_KERNEL_RX (__PAGE_KERNEL_EXEC & ~_PAGE_RW) |
92 | #define __PAGE_KERNEL_EXEC_NOCACHE (__PAGE_KERNEL_EXEC | _PAGE_PCD | _PAGE_PWT) | 92 | #define __PAGE_KERNEL_EXEC_NOCACHE (__PAGE_KERNEL_EXEC | _PAGE_PCD | _PAGE_PWT) |
93 | #define __PAGE_KERNEL_WC (__PAGE_KERNEL | _PAGE_CACHE_WC) | ||
93 | #define __PAGE_KERNEL_NOCACHE (__PAGE_KERNEL | _PAGE_PCD | _PAGE_PWT) | 94 | #define __PAGE_KERNEL_NOCACHE (__PAGE_KERNEL | _PAGE_PCD | _PAGE_PWT) |
94 | #define __PAGE_KERNEL_UC_MINUS (__PAGE_KERNEL | _PAGE_PCD) | 95 | #define __PAGE_KERNEL_UC_MINUS (__PAGE_KERNEL | _PAGE_PCD) |
95 | #define __PAGE_KERNEL_VSYSCALL (__PAGE_KERNEL_RX | _PAGE_USER) | 96 | #define __PAGE_KERNEL_VSYSCALL (__PAGE_KERNEL_RX | _PAGE_USER) |
@@ -107,6 +108,7 @@ extern pteval_t __PAGE_KERNEL, __PAGE_KERNEL_EXEC; | |||
107 | #define PAGE_KERNEL_RO MAKE_GLOBAL(__PAGE_KERNEL_RO) | 108 | #define PAGE_KERNEL_RO MAKE_GLOBAL(__PAGE_KERNEL_RO) |
108 | #define PAGE_KERNEL_EXEC MAKE_GLOBAL(__PAGE_KERNEL_EXEC) | 109 | #define PAGE_KERNEL_EXEC MAKE_GLOBAL(__PAGE_KERNEL_EXEC) |
109 | #define PAGE_KERNEL_RX MAKE_GLOBAL(__PAGE_KERNEL_RX) | 110 | #define PAGE_KERNEL_RX MAKE_GLOBAL(__PAGE_KERNEL_RX) |
111 | #define PAGE_KERNEL_WC MAKE_GLOBAL(__PAGE_KERNEL_WC) | ||
110 | #define PAGE_KERNEL_NOCACHE MAKE_GLOBAL(__PAGE_KERNEL_NOCACHE) | 112 | #define PAGE_KERNEL_NOCACHE MAKE_GLOBAL(__PAGE_KERNEL_NOCACHE) |
111 | #define PAGE_KERNEL_UC_MINUS MAKE_GLOBAL(__PAGE_KERNEL_UC_MINUS) | 113 | #define PAGE_KERNEL_UC_MINUS MAKE_GLOBAL(__PAGE_KERNEL_UC_MINUS) |
112 | #define PAGE_KERNEL_EXEC_NOCACHE MAKE_GLOBAL(__PAGE_KERNEL_EXEC_NOCACHE) | 114 | #define PAGE_KERNEL_EXEC_NOCACHE MAKE_GLOBAL(__PAGE_KERNEL_EXEC_NOCACHE) |