aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorvenkatesh.pallipadi@intel.com <venkatesh.pallipadi@intel.com>2008-03-18 20:00:24 -0400
committerIngo Molnar <mingo@elte.hu>2008-04-17 11:41:20 -0400
commitb310f381d220b2c6e3fab16e8c6e4ca13eea75b2 (patch)
treedd25df964cd1280ee4f908002726b5ab921da807
parentef354af4629e5cc76a3f64fc46d452f2b56d5a59 (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.c30
-rw-r--r--include/asm-x86/io.h3
-rw-r--r--include/asm-x86/pgtable.h2
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}
236EXPORT_SYMBOL(ioremap_nocache); 247EXPORT_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 */
259void __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}
266EXPORT_SYMBOL(ioremap_wc);
267
238void __iomem *ioremap_cache(resource_size_t phys_addr, unsigned long size) 268void __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
6extern int ioremap_change_attr(unsigned long vaddr, unsigned long size, 8extern int ioremap_change_attr(unsigned long vaddr, unsigned long size,
7 unsigned long prot_val); 9 unsigned long prot_val);
10extern 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)