diff options
Diffstat (limited to 'arch/x86/kernel/cpu/mtrr/generic.c')
| -rw-r--r-- | arch/x86/kernel/cpu/mtrr/generic.c | 23 | 
1 files changed, 12 insertions, 11 deletions
| diff --git a/arch/x86/kernel/cpu/mtrr/generic.c b/arch/x86/kernel/cpu/mtrr/generic.c index fa72a39e5d46..d4cdfa67509e 100644 --- a/arch/x86/kernel/cpu/mtrr/generic.c +++ b/arch/x86/kernel/cpu/mtrr/generic.c @@ -510,8 +510,9 @@ generic_get_free_region(unsigned long base, unsigned long size, int replace_reg)  static void generic_get_mtrr(unsigned int reg, unsigned long *base,  			     unsigned long *size, mtrr_type *type)  { -	unsigned int mask_lo, mask_hi, base_lo, base_hi; -	unsigned int tmp, hi; +	u32 mask_lo, mask_hi, base_lo, base_hi; +	unsigned int hi; +	u64 tmp, mask;  	/*  	 * get_mtrr doesn't need to update mtrr_state, also it could be called @@ -532,18 +533,18 @@ static void generic_get_mtrr(unsigned int reg, unsigned long *base,  	rdmsr(MTRRphysBase_MSR(reg), base_lo, base_hi);  	/* Work out the shifted address mask: */ -	tmp = mask_hi << (32 - PAGE_SHIFT) | mask_lo >> PAGE_SHIFT; -	mask_lo = size_or_mask | tmp; +	tmp = (u64)mask_hi << (32 - PAGE_SHIFT) | mask_lo >> PAGE_SHIFT; +	mask = size_or_mask | tmp;  	/* Expand tmp with high bits to all 1s: */ -	hi = fls(tmp); +	hi = fls64(tmp);  	if (hi > 0) { -		tmp |= ~((1<<(hi - 1)) - 1); +		tmp |= ~((1ULL<<(hi - 1)) - 1); -		if (tmp != mask_lo) { +		if (tmp != mask) {  			printk(KERN_WARNING "mtrr: your BIOS has configured an incorrect mask, fixing it.\n");  			add_taint(TAINT_FIRMWARE_WORKAROUND, LOCKDEP_STILL_OK); -			mask_lo = tmp; +			mask = tmp;  		}  	} @@ -551,8 +552,8 @@ static void generic_get_mtrr(unsigned int reg, unsigned long *base,  	 * This works correctly if size is a power of two, i.e. a  	 * contiguous range:  	 */ -	*size = -mask_lo; -	*base = base_hi << (32 - PAGE_SHIFT) | base_lo >> PAGE_SHIFT; +	*size = -mask; +	*base = (u64)base_hi << (32 - PAGE_SHIFT) | base_lo >> PAGE_SHIFT;  	*type = base_lo & 0xff;  out_put_cpu: @@ -701,7 +702,7 @@ static void post_set(void) __releases(set_atomicity_lock)  	mtrr_wrmsr(MSR_MTRRdefType, deftype_lo, deftype_hi);  	/* Enable caches */ -	write_cr0(read_cr0() & 0xbfffffff); +	write_cr0(read_cr0() & ~X86_CR0_CD);  	/* Restore value of CR4 */  	if (cpu_has_pge) |