diff options
Diffstat (limited to 'arch/x86/mm/pageattr-test.c')
| -rw-r--r-- | arch/x86/mm/pageattr-test.c | 13 | 
1 files changed, 5 insertions, 8 deletions
diff --git a/arch/x86/mm/pageattr-test.c b/arch/x86/mm/pageattr-test.c index e1d10690921..6629f397b46 100644 --- a/arch/x86/mm/pageattr-test.c +++ b/arch/x86/mm/pageattr-test.c @@ -8,7 +8,6 @@  #include <linux/kthread.h>  #include <linux/random.h>  #include <linux/kernel.h> -#include <linux/init.h>  #include <linux/mm.h>  #include <asm/cacheflush.h> @@ -36,7 +35,7 @@ enum {  static int pte_testbit(pte_t pte)  { -	return pte_flags(pte) & _PAGE_UNUSED1; +	return pte_flags(pte) & _PAGE_SOFTW1;  }  struct split_state { @@ -68,7 +67,7 @@ static int print_split(struct split_state *s)  			s->gpg++;  			i += GPS/PAGE_SIZE;  		} else if (level == PG_LEVEL_2M) { -			if (!(pte_val(*pte) & _PAGE_PSE)) { +			if ((pte_val(*pte) & _PAGE_PRESENT) && !(pte_val(*pte) & _PAGE_PSE)) {  				printk(KERN_ERR  					"%lx level %d but not PSE %Lx\n",  					addr, level, (u64)pte_val(*pte)); @@ -123,21 +122,19 @@ static int pageattr_test(void)  	if (print)  		printk(KERN_INFO "CPA self-test:\n"); -	bm = vmalloc((max_pfn_mapped + 7) / 8); +	bm = vzalloc((max_pfn_mapped + 7) / 8);  	if (!bm) {  		printk(KERN_ERR "CPA Cannot vmalloc bitmap\n");  		return -ENOMEM;  	} -	memset(bm, 0, (max_pfn_mapped + 7) / 8);  	failed += print_split(&sa); -	srandom32(100);  	for (i = 0; i < NTEST; i++) { -		unsigned long pfn = random32() % max_pfn_mapped; +		unsigned long pfn = prandom_u32() % max_pfn_mapped;  		addr[i] = (unsigned long)__va(pfn << PAGE_SHIFT); -		len[i] = random32() % 100; +		len[i] = prandom_u32() % 100;  		len[i] = min_t(unsigned long, len[i], max_pfn_mapped - pfn - 1);  		if (len[i] == 0)  | 
