Received: by 2002:a05:6358:45e:b0:b5:b6eb:e1f9 with SMTP id 30csp2434693rwe; Sun, 28 Aug 2022 11:19:44 -0700 (PDT) X-Google-Smtp-Source: AA6agR5XfXEycA2Dkgf2QI/XsQ1TcYWGVYeoA18uByewudUoU/1hGzJEeNpu6uw6Wko1TI524vRZ X-Received: by 2002:a50:fd07:0:b0:447:ea4f:c1fb with SMTP id i7-20020a50fd07000000b00447ea4fc1fbmr9263221eds.310.1661710783931; Sun, 28 Aug 2022 11:19:43 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1661710783; cv=none; d=google.com; s=arc-20160816; b=K1dk7iAsigPVw4e68V5hZnVqV4tX0gLCjpRbjUy3l9IklHsR0GIJxwLrfsBVnJqQjv t//ADQAqvuSAzd9cL3NFdxVvgd6Y+ycwFdYFNMkszOH9nDquLrxbi623eP0RgFGcatka SBcy/EdsI88o4KD6BFM77iFqOQLrKciZ64OxkQm6j5yNXsm0ssakGvE/pBBN5pomA5ZS YvtEI0ocO3N7AlGw9mJKQ7mBC8rozeitaTQh9LcMi+aEHscciQ/QZj8ysP4pB0TrS3l4 Oi5CVNOzaxLnP5kz4DGyHprFya0sRn2oT1mJUWSaP6dIpNy2X4ERiXnCt2htnmwcf7dZ kH3w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:in-reply-to:content-transfer-encoding :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=LUJb+6uafBLTSDJkBJrOnlm54DsA1SDQzCReZgnFoqI=; b=tZOrw5nYsJ91BxM06RoClvx2ce3+bFHKU6Qk+1gy+QJMXA5XGgjf3A7i+NB/W6uy7j eJku0HhddPjJhUK5X54SprTuMDjsjppY6GBp55sYxcRy37iEQFudeqDUsesjyY8B5FQ6 oGaQCuCGnxUslvpOXAegA54khqXWtX8os7Takh2EO9asTU4Kyd/5SPOuNwWLxKnjdsHG 9bFm5hlpZiMnK2AEsLfiOOejzaE+cyvoy8fvmLMinh8mWD+s7gwe57dQHykN+owh9Hvx XymmkVwK2X5158oZvZDHhwU+zDHgXCp62aXrbPwtb60UyfDkpp9htSahoOj+UQgdrTGF izdw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=VXZAU+Wy; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id hb12-20020a170907160c00b0073d847631d2si5582365ejc.158.2022.08.28.11.19.10; Sun, 28 Aug 2022 11:19:43 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=VXZAU+Wy; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 S230211AbiH1Rlo (ORCPT + 99 others); Sun, 28 Aug 2022 13:41:44 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33866 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229543AbiH1Rlm (ORCPT ); Sun, 28 Aug 2022 13:41:42 -0400 Received: from ams.source.kernel.org (ams.source.kernel.org [IPv6:2604:1380:4601:e00::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7C17BDFE9 for ; Sun, 28 Aug 2022 10:41:41 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ams.source.kernel.org (Postfix) with ESMTPS id 279ABB80B84 for ; Sun, 28 Aug 2022 17:41:40 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 98891C433C1; Sun, 28 Aug 2022 17:41:38 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1661708498; bh=oWbacq76FiLZIfuBUsffJq7HQY/+kQwKoxWKLOvIweY=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=VXZAU+Wy9SFqAjZJxRg6k8LSAoVRE3YdgjF/vMFnCwkXO12n80gFY5mjZKWKPVCVA zRwslSfMZr8BsoDOEtOrdYNhyHqML7MIgo0SNRCBsjBCV9NUgWOdMhMyh0sU2j7gbA SXVAhkKvHDYSxuen3IgJA0CZXCcL+vTDD41q63f1wo0OLUTFJO0xSeXsY8P8DBDIEO r8oeaHv5y9E6p/SgQMD9p5lILG3Y3RrDZfi6JMstUAnSZVkkpaiatOvYKSe49N9Um1 WyuIzrNjTGJ82sUCoVfMhfRNeAWczzY3wZVA7e/xl5oksAvX3TxsOkZX0t27Ckg6gf UgVHabu3abC8Q== Received: by pali.im (Postfix) id BDF7C7B3; Sun, 28 Aug 2022 19:41:35 +0200 (CEST) Date: Sun, 28 Aug 2022 19:41:35 +0200 From: Pali =?utf-8?B?Um9ow6Fy?= To: Christophe Leroy Cc: Michael Ellerman , Joel Stanley , Benjamin Herrenschmidt , Paul Mackerras , "linuxppc-dev@lists.ozlabs.org" , "linux-kernel@vger.kernel.org" Subject: Re: [PATCH v3] powerpc/boot: Don't always pass -mcpu=powerpc when building 32-bit uImage Message-ID: <20220828174135.rcql4uiunqbnn5gh@pali> References: <20220820105200.30425-1-pali@kernel.org> <20220828095659.4061-1-pali@kernel.org> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: User-Agent: NeoMutt/20180716 X-Spam-Status: No, score=-7.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sunday 28 August 2022 17:39:25 Christophe Leroy wrote: > Le 28/08/2022 à 19:33, Christophe Leroy a écrit : > > > > > > Le 28/08/2022 à 11:56, Pali Rohár a écrit : > >> When CONFIG_TARGET_CPU is specified then pass its value to the compiler > >> -mcpu option. This fixes following build error when building kernel with > >> powerpc e500 SPE capable cross compilers: > >> > >>      BOOTAS  arch/powerpc/boot/crt0.o > >>    powerpc-linux-gnuspe-gcc: error: unrecognized argument in option > >> ‘-mcpu=powerpc’ > >>    powerpc-linux-gnuspe-gcc: note: valid arguments to ‘-mcpu=’ are: > >> 8540 8548 native > >>    make[1]: *** [arch/powerpc/boot/Makefile:231: > >> arch/powerpc/boot/crt0.o] Error 1 > > > > corenet64_smp_defconfig : > > > >   BOOTAS  arch/powerpc/boot/crt0.o > > powerpc64-linux-gcc: error: missing argument to '-mcpu=' > > make[1]: *** [arch/powerpc/boot/Makefile:237 : arch/powerpc/boot/crt0.o] > > Erreur 1 > > make: *** [arch/powerpc/Makefile:253 : uImage] Erreur 2 > > > > > > Seems like in fact, E5500_CPU and E6500_CPU are not taken into account > in CONFIG_TARGET_CPU, and get special treatment directly in > arch/powerpc/Makefile. > > This goes unnoticed because of CFLAGS-$(CONFIG_TARGET_CPU_BOOL) += > $(call cc-option,-mcpu=$(CONFIG_TARGET_CPU)) > > I think we need to fix that prior to your patch. It looks like that CONFIG_TARGET_CPU is broken. $ make ARCH=powerpc corenet64_smp_defconfig CROSS_COMPILE=powerpc64-linux-gnu- ... # configuration written to .config $ grep CONFIG_TARGET_CPU .config CONFIG_TARGET_CPU_BOOL=y CONFIG_TARGET_CPU_BOOL is set but CONFIG_TARGET_CPU not! > > Christophe > > > > > >> > >> Similar change was already introduced for the main powerpc Makefile in > >> commit 446cda1b21d9 ("powerpc/32: Don't always pass -mcpu=powerpc to the > >> compiler"). > >> > >> Fixes: 40a75584e526 ("powerpc/boot: Build wrapper for an appropriate > >> CPU") > >> Cc: stable@vger.kernel.org # 446cda1b21d9 ("powerpc/32: Don't always > >> pass -mcpu=powerpc to the compiler") > >> Signed-off-by: Pali Rohár > >> --- > >>   arch/powerpc/boot/Makefile | 14 ++++++++++---- > >>   1 file changed, 10 insertions(+), 4 deletions(-) > >> > >> diff --git a/arch/powerpc/boot/Makefile b/arch/powerpc/boot/Makefile > >> index a9cd2ea4a861..1957a3de7a1c 100644 > >> --- a/arch/powerpc/boot/Makefile > >> +++ b/arch/powerpc/boot/Makefile > >> @@ -38,13 +38,19 @@ BOOTCFLAGS    := -Wall -Wundef -Wstrict-prototypes > >> -Wno-trigraphs \ > >>            $(LINUXINCLUDE) > >>   ifdef CONFIG_PPC64_BOOT_WRAPPER > >> -ifdef CONFIG_CPU_LITTLE_ENDIAN > >> -BOOTCFLAGS    += -m64 -mcpu=powerpc64le > >> +BOOTCFLAGS    += -m64 > >>   else > >> -BOOTCFLAGS    += -m64 -mcpu=powerpc64 > >> +BOOTCFLAGS    += -m32 > >>   endif > >> + > >> +ifdef CONFIG_TARGET_CPU_BOOL > >> +BOOTCFLAGS    += -mcpu=$(CONFIG_TARGET_CPU) > >> +else ifdef CONFIG_PPC64_BOOT_WRAPPER > >> +ifdef CONFIG_CPU_LITTLE_ENDIAN > >> +BOOTCFLAGS    += -mcpu=powerpc64le > >>   else > >> -BOOTCFLAGS    += -m32 -mcpu=powerpc > >> +BOOTCFLAGS    += -mcpu=powerpc64 > >> +endif > >>   endif > >>   BOOTCFLAGS    += -isystem $(shell $(BOOTCC) -print-file-name=include)