Received: by 2002:ac0:a594:0:0:0:0:0 with SMTP id m20-v6csp3321701imm; Fri, 25 May 2018 03:48:57 -0700 (PDT) X-Google-Smtp-Source: AB8JxZpzBc55+d2oz4ZQzXzi4sJefaNqCD+bGfpzlcdOldkC9VZ9rTlOlHo5fyH5hnSFVcTIugwU X-Received: by 2002:a62:4a88:: with SMTP id c8-v6mr2014851pfj.23.1527245337777; Fri, 25 May 2018 03:48:57 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1527245337; cv=none; d=google.com; s=arc-20160816; b=AaXWS9fdGB29ZaM3Q9VTG/F3wvmp/Nx6hK6JuK+j6kTL8exQWJVtgd+OnCQnOtVwPw oqKsAJUASRpndwdqWpDAQbLUSw2z/8ik0yBI8jZGTPCc5QTm4iv+TqQkZAMZhO1YDqlN 63l+m3dhfZEHhtndPcMGFHF8LvEC1upeisI7nsmGCytuXvBOWOJcOCAgL9ZnWecKZlu4 CdlQXyGf6w4t0Lgy+7cqMB6ojIJN8ZQy1GA2RQtrK5zr3hBBO0+Y+N24E7TVacjKmJ1/ hYqYO/DOfVsfRr027N5+BetYY9RhbxDDfDCXjQGofjPPd1cFXEyrv8CkUgB8pr6wFwN/ dGyw== 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=wYNbX57eH44w3pQ3XprTNAz9Evy7fwdj3e+LbUAqdW0=; b=zJM6HJEUxi9zk4cIfzG2EOAf5odDOunW3FnK2sk0IMjK+/6daDzEHtT+zgLY8iiAhy bmRy4vQsjvZdq88lhLFp4W9/bIM2BmDWh+rWd6Rth7buqB5nXFpNBdGfuYiSykoIyNUj 0LooicxgOZ9leAD666iYHPK1K1edoRqod2YBa0c2JJrQcDy96N3j88zpZUXqiIJcbTsd IFT8MFtARLbQHyGYvMnRXCVzsYXQ0S4CHccXooRJIAV3fMf2sv6dD8RrhrdbpvFSpnaq BNeDXlSMCnqHd6mpTQ4Ie2os1dzWSp2p4MZtpddEhECvWIL+nEJuMRPLDCa18R3UhzZ4 pzWA== 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 x10-v6si22789616plv.1.2018.05.25.03.48.42; Fri, 25 May 2018 03:48:57 -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 S966069AbeEYKsR (ORCPT + 99 others); Fri, 25 May 2018 06:48:17 -0400 Received: from usa-sjc-mx-foss1.foss.arm.com ([217.140.101.70]:59408 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S965255AbeEYKsO (ORCPT ); Fri, 25 May 2018 06:48:14 -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 3C4321596; Fri, 25 May 2018 03:48:14 -0700 (PDT) Received: from [10.1.206.24] (e112298-lin.cambridge.arm.com [10.1.206.24]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 5DF403F24A; Fri, 25 May 2018 03:48:12 -0700 (PDT) Subject: Re: [PATCH v4 02/26] arm64: cpufeature: Add cpufeature for IRQ priority masking To: Suzuki K Poulose , linux-arm-kernel@lists.infradead.org Cc: linux-kernel@vger.kernel.org, daniel.thompson@linaro.org, joel@joelfernandes.org, marc.zyngier@arm.com, mark.rutland@arm.com, christoffer.dall@arm.com, james.morse@arm.com, catalin.marinas@arm.com, will.deacon@arm.com References: <1527241772-48007-1-git-send-email-julien.thierry@arm.com> <1527241772-48007-3-git-send-email-julien.thierry@arm.com> <54ff6127-928d-99a3-a6e9-59799628ca87@arm.com> <3f0afa54-8e98-798e-68dc-bbbc74bd9e19@arm.com> From: Julien Thierry Message-ID: Date: Fri, 25 May 2018 11:48:10 +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: <3f0afa54-8e98-798e-68dc-bbbc74bd9e19@arm.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 25/05/18 11:41, Suzuki K Poulose wrote: > On 25/05/18 11:39, Julien Thierry wrote: >> >> >> On 25/05/18 11:36, Suzuki K Poulose wrote: >>> On 25/05/18 11:17, Julien Thierry wrote: >>>> >>>> >>>> On 25/05/18 11:04, Suzuki K Poulose wrote: >>>>> On 25/05/18 10:49, Julien Thierry wrote: >>>>>> Add a cpufeature indicating whether a cpu supports masking interrupts >>>>>> by priority. >>>>> >>>>> How is this different from the SYSREG_GIC_CPUIF cap ? Is it just >>>>> the description ? >>>> >>>> More or less. >>>> >>>> It is just to have an easier condition in the rest of the series. >>>> Basically the PRIO masking feature is enabled if we have a GICv3 >>>> CPUIF working *and* the option was selected at build time. Before >>>> this meant that I was checking for the GIC_CPUIF cap inside #ifdefs >>>> (and putting alternatives depending on that inside #ifdefs as well). >>>> >>>> Having this as a separate feature feels easier to manage in the >>>> code. It also makes it clearer at boot time that the kernel will be >>>> using irq priorities (although I admit it was not the initial >>>> intention): >>>> >>>> [    0.000000] CPU features: detected: IRQ priority masking >>>> >>>> >>>> But yes that new feature will be detected only if SYSREG_GIC_CPUIF >>>> gets detected as well. >>> >>> Well, you could always wrap the check like : >>> >>> static inline bool system_has_irq_priority_masking(void) >>> { >>>      return (IS_ENABLED(CONFIG_YOUR_CONFIG) && >>> cpus_have_const_cap(HWCAP_SYSREG_GIC_CPUIF)); >>> } >>> >>> and use it everywhere. >>> >> >> Yes, but I can't use that in the asm parts that use alternatives and >> would need to surround them in #ifdef... :\ > > I thought there is _ALTERNATIVE_CFG() to base the alternative depend on > a CONFIG_xxx ? > Doesn't that solve the problem ? Right, I didn't see that one. It should work yes. I'll try that when working on the next version. Thanks, -- Julien Thierry