From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753232AbbC0VxS (ORCPT ); Fri, 27 Mar 2015 17:53:18 -0400 Received: from mga09.intel.com ([134.134.136.24]:62182 "EHLO mga09.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753167AbbC0VxM (ORCPT ); Fri, 27 Mar 2015 17:53:12 -0400 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.11,481,1422950400"; d="scan'208";a="705290886" Subject: [PATCH 10/17] x86: make __VIRTUAL_MASK safe to use on 32 bit To: linux-kernel@vger.kernel.org Cc: x86@kernel.org, tglx@linutronix.de, Dave Hansen , dave.hansen@linux.intel.com From: Dave Hansen Date: Fri, 27 Mar 2015 14:53:08 -0700 References: <20150327215253.8583D538@viggo.jf.intel.com> In-Reply-To: <20150327215253.8583D538@viggo.jf.intel.com> Message-Id: <20150327215308.85354CFD@viggo.jf.intel.com> Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Dave Hansen We are going to do some calculations in a moment that are based on the size of the virtual address space. __VIRTUAL_MASK is currently unsafe to use on 32-bit since it overflows an unsigned long with its shift. The current version will emit a warning if used at all on 32-bit kernels. Add a version which is safe on 32-bit and consequently does not spit out a warning. Signed-off-by: Dave Hansen --- b/arch/x86/include/asm/page_types.h | 8 ++++++++ 1 file changed, 8 insertions(+) diff -puN arch/x86/include/asm/page_types.h~x86-make-__VIRTUAL_MASK-safe-to-use-on-32-bit arch/x86/include/asm/page_types.h --- a/arch/x86/include/asm/page_types.h~x86-make-__VIRTUAL_MASK-safe-to-use-on-32-bit 2015-03-27 14:35:07.648891831 -0700 +++ b/arch/x86/include/asm/page_types.h 2015-03-27 14:35:07.652892012 -0700 @@ -10,7 +10,15 @@ #define PAGE_MASK (~(PAGE_SIZE-1)) #define __PHYSICAL_MASK ((phys_addr_t)((1ULL << __PHYSICAL_MASK_SHIFT) - 1)) +#ifdef CONFIG_X86_64 +/* + * This version doesn't work on 32-bit because __VIRTUAL_MASK_SHIFT=32 + * overflows the unsigned long we're trying to shift. + */ #define __VIRTUAL_MASK ((1UL << __VIRTUAL_MASK_SHIFT) - 1) +#else +#define __VIRTUAL_MASK (~0UL) +#endif /* Cast PAGE_MASK to a signed type so that it is sign-extended if virtual addresses are 32-bits but physical addresses are larger _