Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp707546pxb; Wed, 27 Jan 2021 20:08:25 -0800 (PST) X-Google-Smtp-Source: ABdhPJx94uBffkLDIw+vU3vUMBe8o1t1S2kJ1AmNtXbniYZVEVCcCNRAiRoZrr4tkrVhQ+o+KSrQ X-Received: by 2002:a17:906:3b92:: with SMTP id u18mr9482059ejf.7.1611806905221; Wed, 27 Jan 2021 20:08:25 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1611806905; cv=none; d=google.com; s=arc-20160816; b=hpIhZOMGc+PoAvfIIn9nyFBf9LeUL+MrRdQkjk5ADwN+Cb5ppJ1YRDy/01kjdKzfxt osRIE3QNSMPCw3k8B0n5Ai78mDE/tYe6L2qRwHm9NxiHfZnAVBRhSYYAXjf2OLJN8Wd9 5issU+VMsY1OjSi3b/oZ4byMViHla26fX5cl+orycQ0HXGaGllPNUbY0P8S4U0ZrKZT0 Eq/rAuySvEuclK8+jfVIALo2oJ6PnlNL6SrZFiTsDJSKpy/rPxxhd9co6KgbACq2AKBz gMVzmVUjGfApBEKX72inRxUcZdANhBaFRuUiQgo/NLiNwdwpmaq+bH28wtbcnzQourS6 J6Ww== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature:dkim-filter; bh=x8bTPYoZTArVtYOE+RjShhf6PW9777v9BqcbpoXpseI=; b=s2htYzUnBubeBu5Wi7hohHTdSiBY2duETwj2r4u0gQCAE3lXdFl5MCJuzrE2TwkDl+ bS52OMxANboYMvUfKlyGpaQtIZhWlGH/pVwgL1bculaimlWfqvygCmetFdpRWqSH3lDM ONflnTuRhBX8ilVwgwsBlOK9FJUqfovNAXr6HnNQ5G9deD0OJJHK3ryOZX6xRxRv1zFs jPtZp5T8kq/FQkIHEhVZ93BsqdmoHI8UJjMOV0iovxx5G5Ux44zdGD/4r1ckYmP1KMTZ 7WusGg+LiGu4SHcTBYfVpsj71c4yAzw3PVHdvx7hSQj9gL0VF7QJdNOWfFKiscloEuUo cAZQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@nifty.com header.s=dec2015msa header.b=HRKIE2h+; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y13si2226274edv.304.2021.01.27.20.08.01; Wed, 27 Jan 2021 20:08:25 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@nifty.com header.s=dec2015msa header.b=HRKIE2h+; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231248AbhA1EEn (ORCPT + 99 others); Wed, 27 Jan 2021 23:04:43 -0500 Received: from conssluserg-03.nifty.com ([210.131.2.82]:19487 "EHLO conssluserg-03.nifty.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231158AbhA1EDX (ORCPT ); Wed, 27 Jan 2021 23:03:23 -0500 Received: from mail-pj1-f47.google.com (mail-pj1-f47.google.com [209.85.216.47]) (authenticated) by conssluserg-03.nifty.com with ESMTP id 10S41wtt010837 for ; Thu, 28 Jan 2021 13:01:58 +0900 DKIM-Filter: OpenDKIM Filter v2.10.3 conssluserg-03.nifty.com 10S41wtt010837 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nifty.com; s=dec2015msa; t=1611806519; bh=x8bTPYoZTArVtYOE+RjShhf6PW9777v9BqcbpoXpseI=; h=References:In-Reply-To:From:Date:Subject:To:Cc:From; b=HRKIE2h+HrfIHkTL3Axc9nR1kyoqWfEn4c/RkmBDnNQ7B4APqEhDbhdazulFNCZXA 8QnMT0jwOEuP3u6kzgq6tNPDFPQDiQukUKZUwJc4+IlvgM6KQRV6+bmWJlqeaqIaAL +/MTwQhgj3q60f5b+OZ4CoMOYcIIN5oWiFehHyAYU03W4sJXAtlG8AlyHbmwVIk/LQ klU33h2Z5TjCkETxzl6mykRoMHu+nycotTtBbJ4+FN5KbpetyoVbSQhm+tEDuHPQfj VMVb4H2NS64sp8CrUcBe1HtZI9iuQNQK1KjLSUcbgIhgB1FakZAJqsKUhlc2iKJ8XM InPtTE/mtATTw== X-Nifty-SrcIP: [209.85.216.47] Received: by mail-pj1-f47.google.com with SMTP id lw17so4083114pjb.0 for ; Wed, 27 Jan 2021 20:01:58 -0800 (PST) X-Gm-Message-State: AOAM531dPg88B2LkWLWlZWUAPQWW0tWFrAQlWr/r002sksmIjSGDLGzi DCwOey4PF7T8FdXPK7eYOZVISue9BWkU869bOBg= X-Received: by 2002:a17:902:bb87:b029:e1:d1f:2736 with SMTP id m7-20020a170902bb87b02900e10d1f2736mr3579128pls.1.1611806517852; Wed, 27 Jan 2021 20:01:57 -0800 (PST) MIME-Version: 1.0 References: <20201223171142.707053-1-masahiroy@kernel.org> In-Reply-To: <20201223171142.707053-1-masahiroy@kernel.org> From: Masahiro Yamada Date: Thu, 28 Jan 2021 13:01:19 +0900 X-Gmail-Original-Message-ID: Message-ID: Subject: Re: [PATCH 1/2] powerpc/vdso: fix unnecessary rebuilds of vgettimeofday.o To: Michael Ellerman , Benjamin Herrenschmidt , Paul Mackerras , linuxppc-dev Cc: Ard Biesheuvel , Christophe Leroy , Daniel Axtens , Greentime Hu , Michal Suchanek , Nicholas Piggin , "Oliver O'Halloran" , Ravi Bangoria , Linux Kernel Mailing List Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Dec 24, 2020 at 2:12 AM Masahiro Yamada wrote: > > vgettimeofday.o is unnecessarily rebuilt. Adding it to 'targets' is not > enough to fix the issue. Kbuild is correctly rebuilding it because the > command line is changed. > > PowerPC builds each vdso directory twice; first in vdso_prepare to > generate vdso{32,64}-offsets.h, second as part of the ordinary build > process to embed vdso{32,64}.so.dbg into the kernel. > > The problem shows up when CONFIG_PPC_WERROR=y due to the following line > in arch/powerpc/Kbuild: > > subdir-ccflags-$(CONFIG_PPC_WERROR) := -Werror > > In the preparation stage, Kbuild directly visits the vdso directories, > hence it does not inherit subdir-ccflags-y. In the second descend, > Kbuild adds -Werror, which results in the command line flipping > with/without -Werror. > > It implies a potential danger; if a more critical flag that would impact > the resulted vdso, the offsets recorded in the headers might be different > from real offsets in the embedded vdso images. > > Removing the unneeded second descend solves the problem. > > Link: https://lore.kernel.org/linuxppc-dev/87tuslxhry.fsf@mpe.ellerman.id.au/ > Reported-by: Michael Ellerman > Signed-off-by: Masahiro Yamada > --- Michael, please take a look at this. The unneeded rebuild problem is still remaining. > > arch/powerpc/kernel/Makefile | 4 ++-- > arch/powerpc/kernel/vdso32/Makefile | 5 +---- > arch/powerpc/kernel/{vdso32 => }/vdso32_wrapper.S | 0 > arch/powerpc/kernel/vdso64/Makefile | 6 +----- > arch/powerpc/kernel/{vdso64 => }/vdso64_wrapper.S | 0 > 5 files changed, 4 insertions(+), 11 deletions(-) > rename arch/powerpc/kernel/{vdso32 => }/vdso32_wrapper.S (100%) > rename arch/powerpc/kernel/{vdso64 => }/vdso64_wrapper.S (100%) > > diff --git a/arch/powerpc/kernel/Makefile b/arch/powerpc/kernel/Makefile > index fe2ef598e2ea..79ee7750937d 100644 > --- a/arch/powerpc/kernel/Makefile > +++ b/arch/powerpc/kernel/Makefile > @@ -51,7 +51,7 @@ obj-y += ptrace/ > obj-$(CONFIG_PPC64) += setup_64.o \ > paca.o nvram_64.o note.o syscall_64.o > obj-$(CONFIG_COMPAT) += sys_ppc32.o signal_32.o > -obj-$(CONFIG_VDSO32) += vdso32/ > +obj-$(CONFIG_VDSO32) += vdso32_wrapper.o > obj-$(CONFIG_PPC_WATCHDOG) += watchdog.o > obj-$(CONFIG_HAVE_HW_BREAKPOINT) += hw_breakpoint.o > obj-$(CONFIG_PPC_DAWR) += dawr.o > @@ -60,7 +60,7 @@ obj-$(CONFIG_PPC_BOOK3S_64) += cpu_setup_power.o > obj-$(CONFIG_PPC_BOOK3S_64) += mce.o mce_power.o > obj-$(CONFIG_PPC_BOOK3E_64) += exceptions-64e.o idle_book3e.o > obj-$(CONFIG_PPC_BARRIER_NOSPEC) += security.o > -obj-$(CONFIG_PPC64) += vdso64/ > +obj-$(CONFIG_PPC64) += vdso64_wrapper.o > obj-$(CONFIG_ALTIVEC) += vecemu.o > obj-$(CONFIG_PPC_BOOK3S_IDLE) += idle_book3s.o > procfs-y := proc_powerpc.o > diff --git a/arch/powerpc/kernel/vdso32/Makefile b/arch/powerpc/kernel/vdso32/Makefile > index 59aa2944ecae..42fc3de89b39 100644 > --- a/arch/powerpc/kernel/vdso32/Makefile > +++ b/arch/powerpc/kernel/vdso32/Makefile > @@ -30,7 +30,7 @@ CC32FLAGS += -m32 > KBUILD_CFLAGS := $(filter-out -mcmodel=medium,$(KBUILD_CFLAGS)) > endif > > -targets := $(obj-vdso32) vdso32.so.dbg > +targets := $(obj-vdso32) vdso32.so.dbg vgettimeofday.o > obj-vdso32 := $(addprefix $(obj)/, $(obj-vdso32)) > > GCOV_PROFILE := n > @@ -46,9 +46,6 @@ obj-y += vdso32_wrapper.o > targets += vdso32.lds > CPPFLAGS_vdso32.lds += -P -C -Upowerpc > > -# Force dependency (incbin is bad) > -$(obj)/vdso32_wrapper.o : $(obj)/vdso32.so.dbg > - > # link rule for the .so file, .lds has to be first > $(obj)/vdso32.so.dbg: $(src)/vdso32.lds $(obj-vdso32) $(obj)/vgettimeofday.o FORCE > $(call if_changed,vdso32ld_and_check) > diff --git a/arch/powerpc/kernel/vdso32/vdso32_wrapper.S b/arch/powerpc/kernel/vdso32_wrapper.S > similarity index 100% > rename from arch/powerpc/kernel/vdso32/vdso32_wrapper.S > rename to arch/powerpc/kernel/vdso32_wrapper.S > diff --git a/arch/powerpc/kernel/vdso64/Makefile b/arch/powerpc/kernel/vdso64/Makefile > index d365810a689a..b50b39fedf74 100644 > --- a/arch/powerpc/kernel/vdso64/Makefile > +++ b/arch/powerpc/kernel/vdso64/Makefile > @@ -17,7 +17,7 @@ endif > > # Build rules > > -targets := $(obj-vdso64) vdso64.so.dbg > +targets := $(obj-vdso64) vdso64.so.dbg vgettimeofday.o > obj-vdso64 := $(addprefix $(obj)/, $(obj-vdso64)) > > GCOV_PROFILE := n > @@ -29,15 +29,11 @@ ccflags-y := -shared -fno-common -fno-builtin -nostdlib \ > -Wl,-soname=linux-vdso64.so.1 -Wl,--hash-style=both > asflags-y := -D__VDSO64__ -s > > -obj-y += vdso64_wrapper.o > targets += vdso64.lds > CPPFLAGS_vdso64.lds += -P -C -U$(ARCH) > > $(obj)/vgettimeofday.o: %.o: %.c FORCE > > -# Force dependency (incbin is bad) > -$(obj)/vdso64_wrapper.o : $(obj)/vdso64.so.dbg > - > # link rule for the .so file, .lds has to be first > $(obj)/vdso64.so.dbg: $(src)/vdso64.lds $(obj-vdso64) $(obj)/vgettimeofday.o FORCE > $(call if_changed,vdso64ld_and_check) > diff --git a/arch/powerpc/kernel/vdso64/vdso64_wrapper.S b/arch/powerpc/kernel/vdso64_wrapper.S > similarity index 100% > rename from arch/powerpc/kernel/vdso64/vdso64_wrapper.S > rename to arch/powerpc/kernel/vdso64_wrapper.S > -- > 2.27.0 > -- Best Regards Masahiro Yamada