Received: by 2002:a05:6a10:9e8c:0:0:0:0 with SMTP id y12csp535125pxx; Mon, 26 Oct 2020 14:32:45 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwvHz4H6SMpbpKhsTkHWv6rDW/Ep1X7xCETBQCtcnm++qfRARM9DXNv05dxux/kkzMxJeGT X-Received: by 2002:a05:6402:3045:: with SMTP id bu5mr18197090edb.232.1603747965679; Mon, 26 Oct 2020 14:32:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1603747965; cv=none; d=google.com; s=arc-20160816; b=fvVrFzhfewH/IHyKQ4GGuNulZ9n1uZgASVZkMmZMh2pHYjPqm642XSVIW/sob+PN+L sVA1FW0ZxVAif94KtAxwyP7nD+FNJsKnC37XPNgPIAGBbGU35Zwg6MiVXjfY9c/OpJLf KmJTDYMETi+xntLbdcxOAp9YEe4Ef7h19hsqA0iSMl/51OdyNasnw+LtFewwcooqAnZL CNzLszJ3imefLTzilth/wvQa4P1cKwFItvJ0pJF21KvW4WtH8kHK5o53pTe7DgsyBQ12 MWkkj22E3YvPYmdAHTtjXgU0KbXuAoWNQ/L+QgwZ5Y4cC6NY6hKRh5t1x/tKv1yfzJEH T1aQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date; bh=N8BnyWeTYlHlAyGkblFNygtP5uAW+O5en19WfEevrPY=; b=fmER+81WBSX4LFFCFTB/5KElm0jzkL3ptUAorgLu95NxFtJtPFDXyng7ThymM7Hfv0 yTi5d1GWq6wwGcnaOBGM2XPL5ZRC39KB9rucplChf0jCnx/5+q+M56wc1N4Lz94kF56m fm2x3EO84Q/L/Zeu3or11VGOeYjSNAhRnhOC8IC5brZTllEOeHaFy5BeYBsekAdP72xt VWjKbQzPVj4nZKQWN0tEqVjFZVTPXt+A21GcBanKsegC3VkdbHV25L7FiBAU6VN75F5B 57JRS0nYpmSPsYVvxRUKmiRGFxeWuZNOrhD7hzqJb/sdlUREPiUzQby8gnbzZDymvac2 oYDQ== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id i10si7893761ejz.433.2020.10.26.14.32.23; Mon, 26 Oct 2020 14:32:45 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1785761AbgJZQXY (ORCPT + 99 others); Mon, 26 Oct 2020 12:23:24 -0400 Received: from foss.arm.com ([217.140.110.172]:44070 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1775605AbgJZQXX (ORCPT ); Mon, 26 Oct 2020 12:23:23 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 920E81042; Mon, 26 Oct 2020 09:23:22 -0700 (PDT) Received: from C02TD0UTHF1T.local (unknown [10.57.56.187]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 257703F719; Mon, 26 Oct 2020 09:23:20 -0700 (PDT) Date: Mon, 26 Oct 2020 16:23:14 +0000 From: Mark Rutland To: Arnd Bergmann Cc: Catalin Marinas , Will Deacon , Arnd Bergmann , Christoffer Dall , Marc Zyngier , Peter Maydell , Will Deacon , Dave Martin , Mark Brown , Dmitry Safonov <0x7f454c46@gmail.com>, James Morse , Amit Daniel Kachhap , Gavin Shan , linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH 4/4] arm64: traps: fix -Woverride-init warnings Message-ID: <20201026162314.GA42396@C02TD0UTHF1T.local> References: <20201026160342.3705327-1-arnd@kernel.org> <20201026160342.3705327-4-arnd@kernel.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20201026160342.3705327-4-arnd@kernel.org> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Arnd, On Mon, Oct 26, 2020 at 05:03:31PM +0100, Arnd Bergmann wrote: > From: Arnd Bergmann > > There are many warnings in this file when we re-enable the > Woverride-init flag: > > arch/arm64/kernel/traps.c:704:26: warning: initialized field overwritten [-Woverride-init] > 704 | [ESR_ELx_EC_UNKNOWN] = "Unknown/Uncategorized", > | ^~~~~~~~~~~~~~~~~~~~~~~ > arch/arm64/kernel/traps.c:704:26: note: (near initialization for 'esr_class_str[0]') > arch/arm64/kernel/traps.c:705:22: warning: initialized field overwritten [-Woverride-init] > 705 | [ESR_ELx_EC_WFx] = "WFI/WFE", > | ^~~~~~~~~ > > This is harmless since they are only informational strings, > but it's easy to change the code to ignore missing initialization > and instead warn about possible duplicate initializers. This has come up before, and IMO the warning is more hindrance than helpful, given the prevalance of spurious warnings, and the (again IMO) the rework needed to avoid those making the code harder to reason about. We use this pattern all througout the kernel (e.g. in the syscall wrappers), so unless the plan is to avoid this everywhere, I don't think that we should alter individual cases. I also don't think that the Fixes tag is appropriate given the code is correct. Could we instead convince the compiler folk to give us better tools to deal with this? For example, if we could annotate assignmments as overridable or being an override, it'd be possible to distinguish the benign cases from bad ones, without forcing us to have dynamic checks. Thanks, Mark. > > Fixes: 60a1f02c9e91 ("arm64: decode ESR_ELx.EC when reporting exceptions") > Signed-off-by: Arnd Bergmann > --- > arch/arm64/kernel/traps.c | 3 +-- > 1 file changed, 1 insertion(+), 2 deletions(-) > > diff --git a/arch/arm64/kernel/traps.c b/arch/arm64/kernel/traps.c > index 8af4e0e85736..d21cb25f9e1f 100644 > --- a/arch/arm64/kernel/traps.c > +++ b/arch/arm64/kernel/traps.c > @@ -700,7 +700,6 @@ void do_sysinstr(unsigned int esr, struct pt_regs *regs) > NOKPROBE_SYMBOL(do_sysinstr); > > static const char *esr_class_str[] = { > - [0 ... ESR_ELx_EC_MAX] = "UNRECOGNIZED EC", > [ESR_ELx_EC_UNKNOWN] = "Unknown/Uncategorized", > [ESR_ELx_EC_WFx] = "WFI/WFE", > [ESR_ELx_EC_CP15_32] = "CP15 MCR/MRC", > @@ -746,7 +745,7 @@ static const char *esr_class_str[] = { > > const char *esr_get_class_string(u32 esr) > { > - return esr_class_str[ESR_ELx_EC(esr)]; > + return esr_class_str[ESR_ELx_EC(esr)] ?: "UNRECOGNIZED EC"; > } > > /* > -- > 2.27.0 >