Received: by 10.192.165.148 with SMTP id m20csp4233773imm; Tue, 8 May 2018 05:21:13 -0700 (PDT) X-Google-Smtp-Source: AB8JxZrwDUdHTDy0hEgJ2Rc/yGAPbtSsvXOlRfBaCLYoB+pt+8rq2EGVx3cGgWOwU5OJ4zsXzUBX X-Received: by 2002:a63:744a:: with SMTP id e10-v6mr28496777pgn.275.1525782073668; Tue, 08 May 2018 05:21:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1525782073; cv=none; d=google.com; s=arc-20160816; b=pKBzzX9Fz9IQmPZCsoycU8/oZ4Ilw/2cXhSf4Xhr89OXSOFj3rsmqfOlXKAm1iUoph vrh7Pw8tNG2kj5et7ryPpJSTtCsc/lr6dxRjqZ7lQiL8xaUe7v7ItfBfus90XTRgRpCy 5nYhvTRxMgsgVrv5gqNId253P+ETu7gKOGcQoY59s+HUl3lzegeRZg1FH4AtscPwQoyo +qaUnoB/yKueIN7aCQ6yLO1PePzUEdrQxm2irnM1RIeArc2LqDQKO/uFMLMZcnAb1A/+ MavypPnpdvUSVVMe8X1rIATjYH1bwB4nHSQFrC6dGT8TIVf+9vOr7wt4EgySBH/qnDyy kEdA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:arc-authentication-results; bh=fvId38t9GCwSpcquFmfdLsh2VJzXa1qTlk/0Zke24Pg=; b=e0m2VEWPEZIXsAo+ukqZfY5RW2nlwXoX7iLOlLOSNkf84BYoibM4kPbUWb0AtJM4XU t/dxGP1KUDApgaYphciZTDgSbOtFrZe7UD5rspe/eseOI0Y4f06kq+A0W4/KLRCGDvU/ u6YfJ02mqrTFAWJTSlJ41GfbnIUIKMxhzFOye9bvaEo5FN7LiCtzHVnG+SsqUwHbnctd IpZJLWeGvneYGUxlEy9fVcdyd5HeXF1nuHjit/Cx/p8ir5em9NXp59YeAMIJn/w1DABH jnhIGin4OnkoWvfz8qfkZz3YVf2hRGPdR6x720QWmM1Clm28/KlRREaQuRuGMOpIbQ6l 0ang== ARC-Authentication-Results: i=1; mx.google.com; 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 i14-v6si15539413pgp.558.2018.05.08.05.20.59; Tue, 08 May 2018 05:21:13 -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; 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 S1754946AbeEHMTg (ORCPT + 99 others); Tue, 8 May 2018 08:19:36 -0400 Received: from usa-sjc-mx-foss1.foss.arm.com ([217.140.101.70]:57640 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754760AbeEHMTf (ORCPT ); Tue, 8 May 2018 08:19:35 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id F0D471529; Tue, 8 May 2018 05:19:34 -0700 (PDT) Received: from [10.1.210.88] (e110467-lin.cambridge.arm.com [10.1.210.88]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id C48AE3F592; Tue, 8 May 2018 05:19:32 -0700 (PDT) Subject: Re: [RESEND PATCH v2] bus: arm-cci: use asm unreachable To: Stefan Agner , arm@kernel.org, arnd@arndb.de Cc: linux@armlinux.org.uk, ard.biesheuvel@linaro.org, nicolas.pitre@linaro.org, marc.zyngier@arm.com, behanw@converseincode.com, keescook@chromium.org, Bernhard.Rosenkranzer@linaro.org, mka@chromium.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org References: <20180508113211.7026-1-stefan@agner.ch> From: Robin Murphy Message-ID: <9925be9a-2e24-7ab4-4d7e-cb8f62c422e7@arm.com> Date: Tue, 8 May 2018 13:19:30 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.7.0 MIME-Version: 1.0 In-Reply-To: <20180508113211.7026-1-stefan@agner.ch> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-GB Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 08/05/18 12:32, Stefan Agner wrote: > Mixing asm and C code is not recommended in a naked function by > gcc and leads to an error when using clang: > drivers/bus/arm-cci.c:2107:2: error: non-ASM statement in naked > function is not supported > unreachable(); > ^ > > While the function is marked __naked it actually properly return > in asm. There is no need for the unreachable() call. The commit title is a bit out-of-date now (I guess it could just be something like "remove unnecessary unreachable()" now), but the rest looks OK to me - even GCC clearly doesn't expect anything beyond the asm to be reachable anyway since the lack of epilogue includes the lack of any compiler-generated return. I've checked that GCC 7.2 generates identical object files before and after, other than (for obvious reasons) the line numbers generated by WANT_WARN_ON_SLOWPATH for all the WARN()s appearing later in the file. Reviewed-by: Robin Murphy > Suggested-by: Russell King > Signed-off-by: Stefan Agner > Acked-by: Nicolas Pitre > --- > drivers/bus/arm-cci.c | 2 -- > 1 file changed, 2 deletions(-) > > diff --git a/drivers/bus/arm-cci.c b/drivers/bus/arm-cci.c > index 443e4c3fd357..b8184a903583 100644 > --- a/drivers/bus/arm-cci.c > +++ b/drivers/bus/arm-cci.c > @@ -371,8 +371,6 @@ asmlinkage void __naked cci_enable_port_for_self(void) > [sizeof_struct_cpu_port] "i" (sizeof(struct cpu_port)), > [sizeof_struct_ace_port] "i" (sizeof(struct cci_ace_port)), > [offsetof_port_phys] "i" (offsetof(struct cci_ace_port, phys)) ); > - > - unreachable(); > } > > /** >