Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp544375pxf; Wed, 24 Mar 2021 10:05:04 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzvPdTAdW1vZ0LSm8oSVqHIOViYL69OqiVnkf4zvUvBnRZ0L5UlooWXjNTj/kOTzhXnQZj1 X-Received: by 2002:a17:906:dfce:: with SMTP id jt14mr4853931ejc.83.1616605504362; Wed, 24 Mar 2021 10:05:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1616605504; cv=none; d=google.com; s=arc-20160816; b=nr2Z1RY/FKf2ZVmBxcCllldY/dPiLNEcQG4DtyxB/dXA5riD3K/Vrehh9wmeCYt4eg oaAd8IV80cdHfY+6yjGY+gIaY9ONQ2ftJ9uFKIp84naRAi5n7B5qYXV3EXd6tribNqfA l8J9tcEP++Dtgb8a4oU5jBleDmRNmbjQNnWyrJVU91RZPMDkDRcOfDRe8OLlFpruByJG 4RcywrqcwfUjpX54hF7x86VOeHsYrtRnPRizMQm09Ah2Tyrgm00bidCemW3+HjCMFqk+ 1k6iArqRkXayMLPEbgcGAexNWA3xTA2hT9qTPDki6tFJtrQQcQsZIX6EDNqNiIKCKuUd Vp8A== 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-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature; bh=DrcwUB7p5vEN6pYQKsc9fxS4Cb4HuHuMDZ74CEf+lbo=; b=mkhMGmlGedrKlLWJQ2T1glSdf2mAr2vEZD0OLwhr+ww3HwMkzaa+v9e8cdm0wJ+NKa DCkoadYodgZsoY2z2vFo8pBUShhQzzGRWkNg8qhm9AAtr2V+0Wj1N2g6NnG4ZWwLNqP6 3yZyBaFUf88syAs2Or5mvGWtazv3CBpzgcgnAsZVmgrsEMSrXLPrkubLcPkGXOcfA+mb bAYNlqU+XF+o22Vddkt07JW+5Eo1vBNriDWplkULFzi7+ElxV8G7n9VC5mWeVNQjbInQ mOE4n29P1DPcYFHGxxkcJbJC1gNSWJZbn/ic1ydV0evbXd1rvz1mHhGc7jzZzh8zSP9d B1pQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=LZtwson0; 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=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id z31si2322162ede.226.2021.03.24.10.04.41; Wed, 24 Mar 2021 10:05:04 -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; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=LZtwson0; 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=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236510AbhCXRDp (ORCPT + 99 others); Wed, 24 Mar 2021 13:03:45 -0400 Received: from mail.kernel.org ([198.145.29.99]:45882 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236672AbhCXRD2 (ORCPT ); Wed, 24 Mar 2021 13:03:28 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id AA96E61A0F; Wed, 24 Mar 2021 17:03:26 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1616605408; bh=SfTG1Fnwf+9jTJzJLstp+/FdSqRD7VVDKqeIumMB8NU=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=LZtwson02LCx+HQ0D44CArLEAC2s2VIm6bZS2szlk6VKkT0ack9ZjVWAEUYwVO1UV PHnee5CdFoQe0LE6xIoxfh1xER6SCoyMXKxEnXrRoa0VhDHtELOdtgQqCMKuPm5rU/ UmyEkxYSOIAYCZb+f5N5bh1n/ZAPAcLl3CdNpL9xEotR8sDVnUKOKwgxEIbwfRjmL7 4sedWzEOMl4IeIKKjYpJhgpC/uT9Y28fADcYiknSDSCEpoeUDdLUXgZo8t0UByHRXD IaLKy8E6jssTz5zz/6EJTux/uaOmQFy6W4zBpWBc/NyFYlE8CZNRXNiB5Gptlr6ao6 wo+1Hcz/b3APQ== Date: Wed, 24 Mar 2021 17:03:23 +0000 From: Will Deacon To: Mark Rutland Cc: linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, catalin.marinas@arm.com, james.morse@arm.com, marcan@marcan.st, maz@kernel.org, tglx@linutronix.de Subject: Re: [PATCHv3 6/6] arm64: irq: allow FIQs to be handled Message-ID: <20210324170323.GE13030@willie-the-truck> References: <20210315115629.57191-1-mark.rutland@arm.com> <20210315115629.57191-7-mark.rutland@arm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20210315115629.57191-7-mark.rutland@arm.com> User-Agent: Mutt/1.10.1 (2018-07-13) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Mar 15, 2021 at 11:56:29AM +0000, Mark Rutland wrote: > On contemporary platforms we don't use FIQ, and treat any stray FIQ as a > fatal event. However, some platforms have an interrupt controller wired > to FIQ, and need to handle FIQ as part of regular operation. > > So that we can support both cases dynamically, this patch updates the > FIQ exception handling code to operate the same way as the IRQ handling > code, with its own handle_arch_fiq handler. Where a root FIQ handler is > not registered, an unexpected FIQ exception will trigger the default FIQ > handler, which will panic() as today. Where a root FIQ handler is > registered, handling of the FIQ is deferred to that handler. > > As el0_fiq_invalid_compat is supplanted by el0_fiq, the former is > removed. For !CONFIG_COMPAT builds we never expect to take an exception > from AArch32 EL0, so we keep the common el0_fiq_invalid handler. > > Signed-off-by: Mark Rutland > Tested-by: Hector Martin > Cc: Catalin Marinas > Cc: James Morse > Cc: Marc Zyngier > Cc: Thomas Gleixner > Cc: Will Deacon > --- > arch/arm64/include/asm/irq.h | 1 + > arch/arm64/kernel/entry.S | 30 +++++++++++++++++++++--------- > arch/arm64/kernel/irq.c | 16 ++++++++++++++++ > 3 files changed, 38 insertions(+), 9 deletions(-) Acked-by: Will Deacon Will