Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754544AbbG3HQc (ORCPT ); Thu, 30 Jul 2015 03:16:32 -0400 Received: from foss.arm.com ([217.140.101.70]:39113 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752109AbbG3HQb (ORCPT ); Thu, 30 Jul 2015 03:16:31 -0400 Date: Thu, 30 Jul 2015 08:19:34 +0100 From: Marc Zyngier To: Thomas Gleixner Cc: Jon Hunter , Russell King , "nicolas.pitre@linaro.org" , Jason Cooper , LKML , LAK Subject: Re: [PATCH] irqchip: gic: Add a cpu map for each GIC instance Message-ID: <20150730081934.02a6aa99@why.wild-wind.fr.eu.org> In-Reply-To: References: <1438180984-18219-1-git-send-email-jonathanh@nvidia.com> Organization: ARM Ltd X-Mailer: Claws Mail 3.11.1 (GTK+ 2.24.25; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1894 Lines: 48 On Wed, 29 Jul 2015 17:10:45 +0100 Thomas Gleixner wrote: > On Wed, 29 Jul 2015, Jon Hunter wrote: > > Cc'ing Marc ... Thanks for looping me in. > > > The gic_init_bases() function initialises an array that stores the mapping > > between the GIC and CPUs. This array is a global array that is > > unconditionally initialised on every call to gic_init_bases(). Although, > > it is not common for there to be more than one GIC instance, there are > > some devices that do support nested GIC controllers and gic_init_bases() > > can be called more than once. > > > > A 2nd call to gic_init_bases() will clear the previous CPU mapping and > > will only setup the mapping again for CPU0. This is because for child GIC > > controllers there is most likely only one recipient of the interrupt. > > > > Fix this by moving the CPU mapping array to the GIC chip data structure > > so that it is initialised for each GIC instance separately. It is assumed > > that the bL switcher code is only interested in the root or primary GIC > > instance. This feels very odd. If you have a secondary GIC, it is cascaded into the primary one, and I don't see why you would need to manage the affinity of the interrupt for the secondary GIC. The only thing that matters is the affinity of interrupts in the primary one, and this is what the bl switcher is dealing with. To me, it looks like the bug is to even try to compute an affinity for a GIC that is not the primary one, and keeping it around doesn't seem to make much sense. Or am I overlooking something? Thanks, M. -- Without deviation from the norm, progress is not possible. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/