Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit ad2cde16 authored by Ingo Molnar's avatar Ingo Molnar
Browse files

x86, pat: cleanups



clean up recently added code to be more consistent with other x86 code.

Signed-off-by: default avatarIngo Molnar <mingo@elte.hu>
parent 28dd033f
Loading
Loading
Loading
Loading
+32 −35
Original line number Diff line number Diff line
@@ -7,24 +7,24 @@
 * 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/gfp.h>
#include <linux/mm.h>
#include <linux/fs.h>
#include <linux/bootmem.h>
#include <linux/debugfs.h>
#include <linux/seq_file.h>

#include <asm/msr.h>
#include <asm/tlbflush.h>
#include <asm/cacheflush.h>
#include <asm/processor.h>
#include <asm/page.h>
#include <asm/tlbflush.h>
#include <asm/pgtable.h>
#include <asm/pat.h>
#include <asm/e820.h>
#include <asm/cacheflush.h>
#include <asm/fcntl.h>
#include <asm/e820.h>
#include <asm/mtrr.h>
#include <asm/page.h>
#include <asm/msr.h>
#include <asm/pat.h>
#include <asm/io.h>

#ifdef CONFIG_X86_PAT
@@ -46,6 +46,7 @@ early_param("nopat", nopat);


static int debug_enable;

static int __init pat_debug_setup(char *str)
{
	debug_enable = 1;
@@ -180,8 +181,8 @@ static unsigned long pat_x_mtrr_type(u64 start, u64 end, unsigned long req_type)
	return req_type;
}

static int chk_conflict(struct memtype *new, struct memtype *entry,
			unsigned long *type)
static int
chk_conflict(struct memtype *new, struct memtype *entry, unsigned long *type)
{
	if (new->type != entry->type) {
		if (type) {
@@ -210,15 +211,6 @@ static int chk_conflict(struct memtype *new, struct memtype *entry,
static struct memtype *cached_entry;
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
 * PageNonWB (PG_arch_1). We allow only one set_memory_uc() or
@@ -300,8 +292,8 @@ int reserve_memtype(u64 start, u64 end, unsigned long req_type,
	struct memtype *new, *entry;
	unsigned long actual_type;
	struct list_head *where;
	int err = 0;
	int is_range_ram;
	int err = 0;

	BUG_ON(start >= end); /* end is exclusive */

@@ -336,9 +328,10 @@ int reserve_memtype(u64 start, u64 end, unsigned long req_type,
			actual_type = _PAGE_CACHE_WB;
		else
			actual_type = _PAGE_CACHE_UC_MINUS;
	} else
	} else {
		actual_type = pat_x_mtrr_type(start, end,
					      req_type & _PAGE_CACHE_MASK);
	}

	is_range_ram = pagerange_is_ram(start, end);
	if (is_range_ram == 1)
@@ -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));
		kfree(new);
		spin_unlock(&memtype_lock);

		return err;
	}

@@ -469,6 +463,7 @@ int free_memtype(u64 start, u64 end)
	}

	dprintk("free_memtype request 0x%Lx-0x%Lx\n", start, end);

	return err;
}

@@ -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)
{
	unsigned long want_flags = (pgprot_val(vma_prot) & _PAGE_CACHE_MASK);
	u64 addr = (u64)pfn << PAGE_SHIFT;
	unsigned long flags;
	unsigned long want_flags = (pgprot_val(vma_prot) & _PAGE_CACHE_MASK);

	reserve_memtype(addr, addr + size, want_flags, &flags);
	if (flags != want_flags) {
@@ -620,6 +615,7 @@ static struct memtype *memtype_get_idx(loff_t pos)
	}
	spin_unlock(&memtype_lock);
	kfree(print_entry);

	return NULL;
}

@@ -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),
			print_entry->start, print_entry->end);
	kfree(print_entry);

	return 0;
}