Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp3089803imm; Mon, 10 Sep 2018 10:51:16 -0700 (PDT) X-Google-Smtp-Source: ANB0Vda+eemkoCmohoYr/RdQZQPKeQ/iXvq1wsUUJxbrdWvPEMM8ftHBfSYMEXh/xDy491RcG1gV X-Received: by 2002:a63:e40d:: with SMTP id a13-v6mr23974346pgi.289.1536601876719; Mon, 10 Sep 2018 10:51:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1536601876; cv=none; d=google.com; s=arc-20160816; b=OJAO61dRHn0PcQmHgpfbEzrXg0L5gN7676q9z6vQVQU8p5xyETG7IGY4wN0Mtm4P3b bxvZiWOgT+vIBIZLcELB8zwvyQyqC11kui7scFpgVfYCRd6j3Ls+U5Kjqp8HVCLpPEIb oahmdxJMkDpHbD+/K1UJzmIWXPUAK8eEg9Y6bD4ljcIavnwYul70OE6ll4SjFUhDhsGG iKFL3LvHYB0a5/Xyiuy9pCwOZ1gSLl2JyzR4Pg1mRZZPOo0YnjdddzFl8081V20B+uhu /MY08o0T46jzKet8Zb5q3N5uYOB0nrGLGLgllVUqdyt7PjugX1kHUiRmPU++lCJdeF7N 9UBg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:message-id:references :in-reply-to:subject:cc:to:from:date:content-transfer-encoding :mime-version:dkim-signature; bh=MEqyCQBeGFMuM69LrkARWUdBfgxnLdJ+yuLUFggzxuY=; b=dBPifih6XakwUHIq+/+QKY8nFl/RcA+LAtUeBcQfRXgtbniwifkSIGZeUj/j4wpsqN nblw+FK0uoKJTaQxdWRBen+S/FTqAaIOHNTvYf6J0Cy3F1z44ebI75aV06NoYZ+1z1tz 6YeHFCPokDC1KyO99voWEcNPCz85fr2UWW8/oQB7hT9boE/mzGrbdKxBL4JzFEq2LQiz CRSdHLmBLw0Sb7VI42+UXgvruCpwP76ySy8mBdc9Rk3pjIcVOpUeAJnV4mFfGiPhOG/L wJSTlTZSNRZCZdDBUhLUwLhv4far72bVJsar9R+QvvwrlbX50B0ua/aHj6jzSU0/wkwr /Z/w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@agner.ch header.s=dkim header.b=DPTaHtfg; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id b11-v6si17043020pgt.44.2018.09.10.10.50.54; Mon, 10 Sep 2018 10:51:16 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@agner.ch header.s=dkim header.b=DPTaHtfg; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728175AbeIJWp5 (ORCPT + 99 others); Mon, 10 Sep 2018 18:45:57 -0400 Received: from mail.kmu-office.ch ([178.209.48.109]:54536 "EHLO mail.kmu-office.ch" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726603AbeIJWp5 (ORCPT ); Mon, 10 Sep 2018 18:45:57 -0400 Received: from webmail.kmu-office.ch (unknown [IPv6:2a02:418:6a02::a3]) by mail.kmu-office.ch (Postfix) with ESMTPSA id E13435C19B2; Mon, 10 Sep 2018 19:50:40 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=agner.ch; s=dkim; t=1536601840; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=MEqyCQBeGFMuM69LrkARWUdBfgxnLdJ+yuLUFggzxuY=; b=DPTaHtfgkHsVlnHRG913TfUw92pZnmasvyJs82fMyFjbDJWpEJe73DZcWM3YSA4mLxp4oy 9z3soxUofy27lOjWHWZ28V+EXKFb49Kv+0A0iO3rDu5Oixezh79twcokhdKovWo9VIBAgI x8hC4yw/RBt0LCPd0cqUamMoMONsqzo= MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Date: Mon, 10 Sep 2018 10:50:40 -0700 From: Stefan Agner To: Miguel Ojeda Cc: Linus Torvalds , linux-kernel@vger.kernel.org, Rasmus Villemoes , Luc Van Oostenryck , Eli Friedman , Christopher Li , Kees Cook , Ingo Molnar , Geert Uytterhoeven , Greg Kroah-Hartman , Masahiro Yamada , Joe Perches , Dominique Martinet , Nick Desaulniers , linux-sparse@vger.kernel.org, linux-kernel-owner@vger.kernel.org Subject: Re: [PATCH v4 06/13] Compiler Attributes: naked can be shared In-Reply-To: <20180908212459.19736-7-miguel.ojeda.sandonis@gmail.com> References: <20180908212459.19736-1-miguel.ojeda.sandonis@gmail.com> <20180908212459.19736-7-miguel.ojeda.sandonis@gmail.com> Message-ID: <9daffa34182b7163c2bfdbbe5b688189@agner.ch> X-Sender: stefan@agner.ch User-Agent: Roundcube Webmail/1.3.4 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 08.09.2018 14:24, Miguel Ojeda wrote: > The naked attribute is supported by at least gcc >= 4.6 (for ARM, > which is the only current user), gcc >= 8 (for x86), clang >= 3.1 > and icc >= 13. See https://godbolt.org/z/350Dyc > > Therefore, move it out of compiler-gcc.h so that the definition > is shared by all compilers. > This actually fixes Clang support for ARM32, it fixes: 815f0ddb346c ("include/linux/compiler*.h: make compiler-*.h mutually exclusive"). So this should go in v4.19. Is this patch set (patches 5/6 in particular) planned for v4.19? If not, we probably have to split out this fix... -- Stefan > Cc: Rasmus Villemoes > Cc: Luc Van Oostenryck > Cc: Eli Friedman > Cc: Christopher Li > Cc: Kees Cook > Cc: Ingo Molnar > Cc: Geert Uytterhoeven > Cc: Greg Kroah-Hartman > Cc: Masahiro Yamada > Cc: Joe Perches > Cc: Dominique Martinet > Cc: Nick Desaulniers > Cc: Linus Torvalds > Cc: linux-sparse@vger.kernel.org > Suggested-by: Arnd Bergmann > Signed-off-by: Miguel Ojeda > --- > include/linux/compiler-gcc.h | 8 -------- > include/linux/compiler_types.h | 8 ++++++++ > 2 files changed, 8 insertions(+), 8 deletions(-) > > diff --git a/include/linux/compiler-gcc.h b/include/linux/compiler-gcc.h > index 4cd5e9264bce..3b32bbfa5a49 100644 > --- a/include/linux/compiler-gcc.h > +++ b/include/linux/compiler-gcc.h > @@ -72,14 +72,6 @@ > #define __noretpoline __attribute__((__indirect_branch__("keep"))) > #endif > > -/* > - * it doesn't make sense on ARM (currently the only user of __naked) > - * to trace naked functions because then mcount is called without > - * stack and frame pointer being set up and there is no chance to > - * restore the lr register to the value before mcount was called. > - */ > -#define __naked __attribute__((__naked__)) notrace > - > #define __UNIQUE_ID(prefix) __PASTE(__PASTE(__UNIQUE_ID_, prefix), __COUNTER__) > > #define __compiletime_object_size(obj) __builtin_object_size(obj, 0) > diff --git a/include/linux/compiler_types.h b/include/linux/compiler_types.h > index 83475515bc39..5ff9cda893f4 100644 > --- a/include/linux/compiler_types.h > +++ b/include/linux/compiler_types.h > @@ -224,6 +224,14 @@ struct ftrace_likely_data { > #define notrace __attribute__((__no_instrument_function__)) > #endif > > +/* > + * it doesn't make sense on ARM (currently the only user of __naked) > + * to trace naked functions because then mcount is called without > + * stack and frame pointer being set up and there is no chance to > + * restore the lr register to the value before mcount was called. > + */ > +#define __naked __attribute__((__naked__)) notrace > + > #define __compiler_offsetof(a, b) __builtin_offsetof(a, b) > > /*