From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mail-pg0-f69.google.com (mail-pg0-f69.google.com [74.125.83.69]) by kanga.kvack.org (Postfix) with ESMTP id C519A6B0038 for ; Mon, 27 Feb 2017 14:35:32 -0500 (EST) Received: by mail-pg0-f69.google.com with SMTP id t184so192706732pgt.1 for ; Mon, 27 Feb 2017 11:35:32 -0800 (PST) Received: from mga02.intel.com (mga02.intel.com. [134.134.136.20]) by mx.google.com with ESMTPS id s23si15936320plk.205.2017.02.27.11.35.31 for (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 27 Feb 2017 11:35:31 -0800 (PST) Subject: Re: [PATCH] mm,x86: fix SMP x86 32bit build for native_pud_clear() References: <078cfd81-12d4-285e-d80d-7afd0f2e7e6d@redhat.com> <1488223776-10326-1-git-send-email-boris.ostrovsky@oracle.com> From: Dave Jiang Message-ID: Date: Mon, 27 Feb 2017 12:35:30 -0700 MIME-Version: 1.0 In-Reply-To: <1488223776-10326-1-git-send-email-boris.ostrovsky@oracle.com> Content-Type: text/plain; charset=windows-1252 Content-Transfer-Encoding: 7bit Sender: owner-linux-mm@kvack.org List-ID: To: Boris Ostrovsky , labbott@redhat.com Cc: linux-mm@kvack.org, linux-kernel@vger.kernel.org On 02/27/2017 12:29 PM, Boris Ostrovsky wrote: >> On 02/15/2017 12:31 PM, Dave Jiang wrote: >>> The fix introduced by e4decc90 to fix the UP case for 32bit x86, however >>> that broke the SMP case that was working previously. Add ifdef so the dummy >>> function only show up for 32bit UP case only. >>> >>> Fix: e4decc90 mm,x86: native_pud_clear missing on i386 build >>> >>> Reported-by: Alexander Kapshuk >>> Signed-off-by: Dave Jiang >>> --- >>> arch/x86/include/asm/pgtable-3level.h | 2 ++ >>> 1 file changed, 2 insertions(+) >>> >>> diff --git a/arch/x86/include/asm/pgtable-3level.h b/arch/x86/include/asm/pgtable-3level.h >>> index 50d35e3..8f50fb3 100644 >>> --- a/arch/x86/include/asm/pgtable-3level.h >>> +++ b/arch/x86/include/asm/pgtable-3level.h >>> @@ -121,9 +121,11 @@ static inline void native_pmd_clear(pmd_t *pmd) >>> *(tmp + 1) = 0; >>> } >>> >>> +#ifndef CONFIG_SMP >>> static inline void native_pud_clear(pud_t *pudp) >>> { >>> } >>> +#endif >>> >>> static inline void pud_clear(pud_t *pudp) >>> { >>> > >> >> This breaks one of the Fedora configurations as of >> e5d56efc97f8240d0b5d66c03949382b6d7e5570 >> >> In file included from ./include/linux/mm.h:68:0, >> from ./include/linux/highmem.h:7, >> from ./include/linux/bio.h:21, >> from ./include/linux/writeback.h:205, >> from ./include/linux/memcontrol.h:30, >> from ./include/linux/swap.h:8, >> from ./include/linux/suspend.h:4, >> from arch/x86/kernel/asm-offsets.c:12: >> ./arch/x86/include/asm/pgtable.h: In function 'native_local_pudp_get_and_clear': >> ./arch/x86/include/asm/pgtable.h:888:2: error: implicit declaration of function 'native_pud_clear';did you mean 'native_pmd_clear'? [-Werror=implicit-function-declaration] >> native_pud_clear(pudp); >> ^~~~~~~~~~~~~~~~ >> >> Kernel configuration attached. I'm probably just going to revert >> this part unless someone sends me a better fix. > > > This breakage happens when CONFIG_HIGHMEM64G (i.e. CONFIG_X86_PAE) and CONFIG_PARAVIRT. Thanks for the additional breakage configs report. I think I need to extend that ifdef to additional configs. I'll send out a fix as soon as I test the various different combination of configs. > > -boris > -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@kvack.org. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: email@kvack.org