Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp7901pxk; Wed, 30 Sep 2020 16:07:53 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxzPF1Xclmbz9cx0TDyQNr6KismMgo6bwmYDS4K5vzOA/UyQTALP8UtO5kYm93TVw7+1CKK X-Received: by 2002:aa7:c648:: with SMTP id z8mr5294773edr.239.1601507273365; Wed, 30 Sep 2020 16:07:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1601507273; cv=none; d=google.com; s=arc-20160816; b=kwvdvViDq0F+RQaygHLOPNHLBtT9fcj+VPfa5/YAPfutRGKA3awwexGNsPRmvWyGiy XCQ/hXNn3rzSS2iHzG4zppIAW9T3itijJpEr4BIRohgu22LdZZvJWTYBsy/+Z6JKInR6 jmx2aGTSbFFwRHigWSIV0sJ0EvstVMk8bohBA7FohoZzkrDGGVYiJwlyMjUAtBLwZ33L wb5p8fb2d2Cl4s7F/zTS8vIilGHJh9RYRgC81Qpdy+9jP79XymMSXytPca6lmHkkO9dO wiBMbITq78NL4yOpidDnTsCBqBRjQstvUgZ2iyKRl3IE1I4z2HAM8ntjSWEVUmf1p5pN Gqzg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:date:cc:to:from:subject :message-id; bh=13DMw9whWeF1a3+ExlPkERKDUqNBt/PKNlRPnngwwF0=; b=JnEu+ouq9/9cY5gFHTKRfZeQNzuOR0XD49oslsZ5RZIeM8tjIpJ1CDk9KjEW7vpNkU E5i05nKHdF5w0bLf2JCf1l0d5DkkJ8BI3Nz2zTogwCNuA1nZ7DZ0cxnVmI7Y1yxH2D6Z vPxZY2Ulpktf2FS70dN77UHNs1AY9PZJYtR1hVC1qiDVR3don0BkA+RTBEOSsYAOGfVQ /F0axs1lSnDBrCzt6a0oGNfXbkHW0vL74Ujb/30yfceyNv8EeNXh8pnpa7e1jPfVQDIG 27xD57hoXnu6HKxPkSYuZ6NCcCEuYDdC8r9rkZH4E7wbQ1pNiGFuOYWqdecKaq4eJ5Ac 9YJg== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id 18si2814123edv.184.2020.09.30.16.07.31; Wed, 30 Sep 2020 16:07:53 -0700 (PDT) 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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731071AbgI3WG4 (ORCPT + 99 others); Wed, 30 Sep 2020 18:06:56 -0400 Received: from smtprelay0109.hostedemail.com ([216.40.44.109]:49994 "EHLO smtprelay.hostedemail.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1730269AbgI3WG4 (ORCPT ); Wed, 30 Sep 2020 18:06:56 -0400 Received: from filter.hostedemail.com (clb03-v110.bra.tucows.net [216.40.38.60]) by smtprelay01.hostedemail.com (Postfix) with ESMTP id B223A100E7B43; Wed, 30 Sep 2020 22:06:54 +0000 (UTC) X-Session-Marker: 6A6F6540706572636865732E636F6D X-Spam-Summary: 50,0,0,,d41d8cd98f00b204,joe@perches.com,,RULES_HIT:41:355:379:599:800:857:960:967:968:973:982:988:989:1260:1277:1311:1313:1314:1345:1359:1437:1515:1516:1518:1534:1542:1593:1594:1711:1730:1747:1777:1792:1981:2194:2198:2199:2200:2393:2525:2553:2560:2563:2682:2685:2828:2859:2902:2933:2937:2939:2942:2945:2947:2951:2954:3022:3138:3139:3140:3141:3142:3353:3622:3865:3866:3867:3868:3870:3871:3872:3873:3874:3934:3936:3938:3941:3944:3947:3950:3953:3956:3959:4321:4384:5007:6119:6120:6742:7875:7903:9010:9025:10004:10394:10400:10471:10848:11026:11232:11473:11658:11914:12043:12296:12297:12438:12555:12740:12760:12895:12986:13161:13172:13229:13255:13439:14096:14097:14181:14659:14721:21080:21433:21451:21627:21773:21789:21811:21939:30054:30070:30089:30090:30091,0,RBL:none,CacheIP:none,Bayesian:0.5,0.5,0.5,Netcheck:none,DomainCache:0,MSF:not bulk,SPF:,MSBL:0,DNSBL:none,Custom_rules:0:0:0,LFtime:1,LUA_SUMMARY:none X-HE-Tag: river77_3d14b8027196 X-Filterd-Recvd-Size: 4026 Received: from XPS-9350.home (unknown [47.151.133.149]) (Authenticated sender: joe@perches.com) by omf04.hostedemail.com (Postfix) with ESMTPA; Wed, 30 Sep 2020 22:06:52 +0000 (UTC) Message-ID: <417ffa3fd3fba5d4a481db6a0b0c9b48cbbb17c4.camel@perches.com> Subject: Re: [RFC PATCH next-20200930] treewide: Convert macro and uses of __section(foo) to __section("foo") From: Joe Perches To: Nick Desaulniers Cc: Sedat Dilek , "Paul E . McKenney" , Steven Rostedt , Mathieu Desnoyers , Lai Jiangshan , Josh Triplett , Kees Cook , LKML , rcu@vger.kernel.org, Clang-Built-Linux ML , Miguel Ojeda , Michael Ellerman Date: Wed, 30 Sep 2020 15:06:51 -0700 In-Reply-To: References: <20200929192549.501516-1-ndesaulniers@google.com> <133589afbe999347454dfcc46ae782897bf9e3a2.camel@perches.com> <46f69161e60b802488ba8c8f3f8bbf922aa3b49b.camel@perches.com> Content-Type: text/plain; charset="ISO-8859-1" User-Agent: Evolution 3.36.4-0ubuntu1 MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 2020-09-30 at 14:40 -0700, Nick Desaulniers wrote: > On Wed, Sep 30, 2020 at 12:16 PM Joe Perches wrote: > > Use a more generic form for __section that requires quotes to avoid > > complications with clang and gcc differences. > > > > Remove the quote operator # from compiler_attributes.h __section macro. > > > > Convert all unquoted __section(foo) uses to quoted __section("foo"). > > Also convert __attribute__((section("foo"))) uses to __section("foo") > > even if the __attribute__ has multiple list entry forms. > > > > Signed-off-by: Joe Perches > > --- > > > > This is the current output from the script against next-20200930 > > attached in this link: > > > > https://lore.kernel.org/lkml/0e582a7f5144a33f465978d97701f9b3dcc377f3.camel@perches.com/ > > > > It might be useful to run the script immediately before > > the next -rc1. > > $ ARCH=powerpc CROSS_COMPILE=powerpc64le-linux-gnu- make CC=clang -j71 > powernv_defconfig > $ ARCH=powerpc CROSS_COMPILE=powerpc64le-linux-gnu- make CC=clang -j71 > ... > arch/powerpc/boot/main.c:193:44: error: expected ';' after top level declarator > static char cmdline[BOOT_COMMAND_LINE_SIZE] The script does not convert files in scripts/ tools/ uapi/ and include/linux/compiler_attributes.h It otherwise assumes that any __attribute__((__section__ use should be converted to __section. If this ppc file is the only file outside of the listed exclusions, I can either exclude it directly or add compiler.h to it. You have a preference? Perhaps these are also possible files that need exclusions: ./arch/x86/boot/video.h:#define __videocard struct card_info __section(".videocards") __attribute__((used)) ./arch/x86/boot/compressed/pgtable_64.c:unsigned long *trampoline_32bit __section(".data"); ./arch/x86/boot/tty.c:static void __section(".inittext") serial_putchar(int ch) ./arch/x86/boot/tty.c:static void __section(".inittext") bios_putchar(int ch) ./arch/x86/boot/tty.c:void __section(".inittext") putchar(int ch) ./arch/x86/boot/tty.c:void __section(".inittext") puts(const char *str) ./arch/s390/boot/startup.c:static struct diag210 _diag210_tmp_dma __section(".dma.data"); ./arch/powerpc/boot/main.c: __section("__builtin_cmdline"); ./arch/powerpc/boot/ps3.c: __section("__builtin_cmdline");