提交 ad2cde16 编写于 作者: I Ingo Molnar

x86, pat: cleanups

clean up recently added code to be more consistent with other x86 code.
Signed-off-by: NIngo Molnar <mingo@elte.hu>
上级 28dd033f
...@@ -7,24 +7,24 @@ ...@@ -7,24 +7,24 @@
* Loosely based on earlier PAT patchset from Eric Biederman and Andi Kleen. * Loosely based on earlier PAT patchset from Eric Biederman and Andi Kleen.
*/ */
#include <linux/mm.h> #include <linux/seq_file.h>
#include <linux/bootmem.h>
#include <linux/debugfs.h>
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/gfp.h> #include <linux/gfp.h>
#include <linux/mm.h>
#include <linux/fs.h> #include <linux/fs.h>
#include <linux/bootmem.h>
#include <linux/debugfs.h>
#include <linux/seq_file.h>
#include <asm/msr.h> #include <asm/cacheflush.h>
#include <asm/tlbflush.h>
#include <asm/processor.h> #include <asm/processor.h>
#include <asm/page.h> #include <asm/tlbflush.h>
#include <asm/pgtable.h> #include <asm/pgtable.h>
#include <asm/pat.h>
#include <asm/e820.h>
#include <asm/cacheflush.h>
#include <asm/fcntl.h> #include <asm/fcntl.h>
#include <asm/e820.h>
#include <asm/mtrr.h> #include <asm/mtrr.h>
#include <asm/page.h>
#include <asm/msr.h>
#include <asm/pat.h>
#include <asm/io.h> #include <asm/io.h>
#ifdef CONFIG_X86_PAT #ifdef CONFIG_X86_PAT
...@@ -46,6 +46,7 @@ early_param("nopat", nopat); ...@@ -46,6 +46,7 @@ early_param("nopat", nopat);
static int debug_enable; static int debug_enable;
static int __init pat_debug_setup(char *str) static int __init pat_debug_setup(char *str)
{ {
debug_enable = 1; debug_enable = 1;
...@@ -145,14 +146,14 @@ static char *cattr_name(unsigned long flags) ...@@ -145,14 +146,14 @@ static char *cattr_name(unsigned long flags)
*/ */
struct memtype { struct memtype {
u64 start; u64 start;
u64 end; u64 end;
unsigned long type; unsigned long type;
struct list_head nd; struct list_head nd;
}; };
static LIST_HEAD(memtype_list); static LIST_HEAD(memtype_list);
static DEFINE_SPINLOCK(memtype_lock); /* protects memtype list */ static DEFINE_SPINLOCK(memtype_lock); /* protects memtype list */
/* /*
* Does intersection of PAT memory type and MTRR memory type and returns * Does intersection of PAT memory type and MTRR memory type and returns
...@@ -180,8 +181,8 @@ static unsigned long pat_x_mtrr_type(u64 start, u64 end, unsigned long req_type) ...@@ -180,8 +181,8 @@ static unsigned long pat_x_mtrr_type(u64 start, u64 end, unsigned long req_type)
return req_type; return req_type;
} }
static int chk_conflict(struct memtype *new, struct memtype *entry, static int
unsigned long *type) chk_conflict(struct memtype *new, struct memtype *entry, unsigned long *type)
{ {
if (new->type != entry->type) { if (new->type != entry->type) {
if (type) { if (type) {
...@@ -210,15 +211,6 @@ static int chk_conflict(struct memtype *new, struct memtype *entry, ...@@ -210,15 +211,6 @@ static int chk_conflict(struct memtype *new, struct memtype *entry,
static struct memtype *cached_entry; static struct memtype *cached_entry;
static u64 cached_start; static u64 cached_start;
/*
* RED-PEN: TODO: Add PageReserved() check as well here,
* once we add SetPageReserved() to all the drivers using
* set_memory_* or set_pages_*.
*
* This will help prevent accidentally freeing pages
* before setting the attribute back to WB.
*/
/* /*
* For RAM pages, mark the pages as non WB memory type using * For RAM pages, mark the pages as non WB memory type using
* PageNonWB (PG_arch_1). We allow only one set_memory_uc() or * PageNonWB (PG_arch_1). We allow only one set_memory_uc() or
...@@ -232,7 +224,7 @@ static u64 cached_start; ...@@ -232,7 +224,7 @@ static u64 cached_start;
* UC and WC mapping. * UC and WC mapping.
*/ */
static int reserve_ram_pages_type(u64 start, u64 end, unsigned long req_type, static int reserve_ram_pages_type(u64 start, u64 end, unsigned long req_type,
unsigned long *new_type) unsigned long *new_type)
{ {
struct page *page; struct page *page;
u64 pfn, end_pfn; u64 pfn, end_pfn;
...@@ -295,15 +287,15 @@ static int free_ram_pages_type(u64 start, u64 end) ...@@ -295,15 +287,15 @@ static int free_ram_pages_type(u64 start, u64 end)
* it will return a negative return value. * it will return a negative return value.
*/ */
int reserve_memtype(u64 start, u64 end, unsigned long req_type, int reserve_memtype(u64 start, u64 end, unsigned long req_type,
unsigned long *new_type) unsigned long *new_type)
{ {
struct memtype *new, *entry; struct memtype *new, *entry;
unsigned long actual_type; unsigned long actual_type;
struct list_head *where; struct list_head *where;
int err = 0;
int is_range_ram; int is_range_ram;
int err = 0;
BUG_ON(start >= end); /* end is exclusive */ BUG_ON(start >= end); /* end is exclusive */
if (!pat_enabled) { if (!pat_enabled) {
/* This is identical to page table setting without PAT */ /* This is identical to page table setting without PAT */
...@@ -336,9 +328,10 @@ int reserve_memtype(u64 start, u64 end, unsigned long req_type, ...@@ -336,9 +328,10 @@ int reserve_memtype(u64 start, u64 end, unsigned long req_type,
actual_type = _PAGE_CACHE_WB; actual_type = _PAGE_CACHE_WB;
else else
actual_type = _PAGE_CACHE_UC_MINUS; actual_type = _PAGE_CACHE_UC_MINUS;
} else } else {
actual_type = pat_x_mtrr_type(start, end, actual_type = pat_x_mtrr_type(start, end,
req_type & _PAGE_CACHE_MASK); req_type & _PAGE_CACHE_MASK);
}
is_range_ram = pagerange_is_ram(start, end); is_range_ram = pagerange_is_ram(start, end);
if (is_range_ram == 1) if (is_range_ram == 1)
...@@ -350,9 +343,9 @@ int reserve_memtype(u64 start, u64 end, unsigned long req_type, ...@@ -350,9 +343,9 @@ int reserve_memtype(u64 start, u64 end, unsigned long req_type,
if (!new) if (!new)
return -ENOMEM; return -ENOMEM;
new->start = start; new->start = start;
new->end = end; new->end = end;
new->type = actual_type; new->type = actual_type;
if (new_type) if (new_type)
*new_type = actual_type; *new_type = actual_type;
...@@ -411,6 +404,7 @@ int reserve_memtype(u64 start, u64 end, unsigned long req_type, ...@@ -411,6 +404,7 @@ int reserve_memtype(u64 start, u64 end, unsigned long req_type,
start, end, cattr_name(new->type), cattr_name(req_type)); start, end, cattr_name(new->type), cattr_name(req_type));
kfree(new); kfree(new);
spin_unlock(&memtype_lock); spin_unlock(&memtype_lock);
return err; return err;
} }
...@@ -469,6 +463,7 @@ int free_memtype(u64 start, u64 end) ...@@ -469,6 +463,7 @@ int free_memtype(u64 start, u64 end)
} }
dprintk("free_memtype request 0x%Lx-0x%Lx\n", start, end); dprintk("free_memtype request 0x%Lx-0x%Lx\n", start, end);
return err; return err;
} }
...@@ -575,9 +570,9 @@ int phys_mem_access_prot_allowed(struct file *file, unsigned long pfn, ...@@ -575,9 +570,9 @@ int phys_mem_access_prot_allowed(struct file *file, unsigned long pfn,
void map_devmem(unsigned long pfn, unsigned long size, pgprot_t vma_prot) void map_devmem(unsigned long pfn, unsigned long size, pgprot_t vma_prot)
{ {
unsigned long want_flags = (pgprot_val(vma_prot) & _PAGE_CACHE_MASK);
u64 addr = (u64)pfn << PAGE_SHIFT; u64 addr = (u64)pfn << PAGE_SHIFT;
unsigned long flags; unsigned long flags;
unsigned long want_flags = (pgprot_val(vma_prot) & _PAGE_CACHE_MASK);
reserve_memtype(addr, addr + size, want_flags, &flags); reserve_memtype(addr, addr + size, want_flags, &flags);
if (flags != want_flags) { if (flags != want_flags) {
...@@ -620,6 +615,7 @@ static struct memtype *memtype_get_idx(loff_t pos) ...@@ -620,6 +615,7 @@ static struct memtype *memtype_get_idx(loff_t pos)
} }
spin_unlock(&memtype_lock); spin_unlock(&memtype_lock);
kfree(print_entry); kfree(print_entry);
return NULL; return NULL;
} }
...@@ -650,6 +646,7 @@ static int memtype_seq_show(struct seq_file *seq, void *v) ...@@ -650,6 +646,7 @@ static int memtype_seq_show(struct seq_file *seq, void *v)
seq_printf(seq, "%s @ 0x%Lx-0x%Lx\n", cattr_name(print_entry->type), seq_printf(seq, "%s @ 0x%Lx-0x%Lx\n", cattr_name(print_entry->type),
print_entry->start, print_entry->end); print_entry->start, print_entry->end);
kfree(print_entry); kfree(print_entry);
return 0; return 0;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册