Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp344089iog; Wed, 15 Jun 2022 03:30:23 -0700 (PDT) X-Google-Smtp-Source: AGRyM1tzDdoX8AOwt4poF88nucoYJKoUuqpoujMvxCbprTk/Fgva0wCe7OylT0FgnwwVoEfJhC7N X-Received: by 2002:a17:902:9f96:b0:163:dc33:6b72 with SMTP id g22-20020a1709029f9600b00163dc336b72mr8419963plq.34.1655289022793; Wed, 15 Jun 2022 03:30:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1655289022; cv=none; d=google.com; s=arc-20160816; b=C+Nn6gvaZuyNdu8m4A8VmdTOqJYtp4L7HU02tR7oh9M5P7cTES9O++7HufTB93lqU4 YsS8YVRxZOvIqgGhwnG+bov8ejko1HubS2UGa6jn1b9oUwqkh2Ag6VXRc7HB7Tdwo4ZG kPYGXtCFaiboHQZn9D/EIXiyxU/y8sW4KivVqlLaSR3ue2/JuqJkwwyV+0vdpkhhEDcW jCjvqKnvIiqLVxOPkm6fdl96i8dycKBPFsu2sLF0zl8BSQqoCNzXagEoWohKSN6Hk48R DekmTtXZh8MunITwVjSjDuTKN6chkLX9yRCWb7+kz8iS+z6jqdrg+N1EERXU3KsgfDTj 7mdg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject; bh=HcTfnooYwh7iH4ZyFOxDWe/+Srm4/ogI5k00t+Gte4Y=; b=AbO+JSQcrDnqJrUusYm6V35C/MNCUNkx3tqvt4cPkS5X+n/pG7kVIFSjiFDa0sq9e/ uJ+daCLMCuOldfSpIC/wOf/EucPRgrwyqy/TTLmOMotakJ8j2xaV0PlcDJm/FB/BWQ4s lEnUZ/LrcI5WHJjHGxm5TKDAC+0AvAvlRvJYo1h5rE3FNGbJ0bPVi0/O1kBh8iubXYlR aXe1mw0YP3/fNoveZ74kacGlxH+gj+yIqFjxDhN8sRiyohIWp26lF9jZrUb9k4/irFo/ gw2Xi8AnHowW4pKKoBrfBpA7JlsrGfQ3zwshdywcEz35UISSxLzTcf5LZjkuQVvXIP5R V7/g== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id jg1-20020a17090326c100b0016198140119si14671007plb.606.2022.06.15.03.30.09; Wed, 15 Jun 2022 03:30:22 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1346811AbiFOJn4 (ORCPT + 99 others); Wed, 15 Jun 2022 05:43:56 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:55386 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1346900AbiFOJn1 (ORCPT ); Wed, 15 Jun 2022 05:43:27 -0400 Received: from loongson.cn (mail.loongson.cn [114.242.206.163]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 3113A4348C for ; Wed, 15 Jun 2022 02:43:25 -0700 (PDT) Received: from [10.20.42.13] (unknown [10.20.42.13]) by mail.loongson.cn (Coremail) with SMTP id AQAAf9Dxj96zqaliPYFDAA--.6230S3; Wed, 15 Jun 2022 17:43:16 +0800 (CST) Subject: Re: [PATCH V12 01/10] APCI: irq: Add support for multiple GSI domains To: Marc Zyngier Cc: Thomas Gleixner , linux-kernel@vger.kernel.org, Hanjun Guo , Lorenzo Pieralisi , Jiaxun Yang , Huacai Chen References: <1655273250-23495-1-git-send-email-lvjianmin@loongson.cn> <1655273250-23495-2-git-send-email-lvjianmin@loongson.cn> <87k09ipfe2.wl-maz@kernel.org> From: Jianmin Lv Message-ID: <5ca8542e-060e-bdd5-ee5b-f5a9ca6bbb3a@loongson.cn> Date: Wed, 15 Jun 2022 17:43:15 +0800 User-Agent: Mozilla/5.0 (X11; Linux loongarch64; rv:68.0) Gecko/20100101 Thunderbird/68.7.0 MIME-Version: 1.0 In-Reply-To: <87k09ipfe2.wl-maz@kernel.org> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit X-CM-TRANSID: AQAAf9Dxj96zqaliPYFDAA--.6230S3 X-Coremail-Antispam: 1UD129KBjvJXoWxZry8XFyDJF1kCw1xWF47XFb_yoW5AF15pF WfG3Wa9r4jqr1xWa13K34Y9Fyakas5t3y8Xr4fJ3srAr1DuF9akF10gFyFkFyDZFy3Gr42 vF1UtF4kuF1qyFJanT9S1TB71UUUUUUqnTZGkaVYY2UrUUUUjbIjqfuFe4nvWSU5nxnvy2 9KBjDU0xBIdaVrnRJUUUvEb7Iv0xC_Kw4lb4IE77IF4wAFc2x0x2IEx4CE42xK8VAvwI8I cIk0rVWrJVCq3wAFIxvE14AKwVWUJVWUGwA2ocxC64kIII0Yj41l84x0c7CEw4AK67xGY2 AK021l84ACjcxK6xIIjxv20xvE14v26ryj6F1UM28EF7xvwVC0I7IYx2IY6xkF7I0E14v2 6F4j6r4UJwA2z4x0Y4vEx4A2jsIE14v26rxl6s0DM28EF7xvwVC2z280aVCY1x0267AKxV W0oVCq3wAS0I0E0xvYzxvE52x082IY62kv0487Mc02F40EFcxC0VAKzVAqx4xG6I80ewAv 7VC0I7IYx2IY67AKxVWUJVWUGwAv7VC2z280aVAFwI0_Jr0_Gr1lOx8S6xCaFVCjc4AY6r 1j6r4UM4x0Y48IcVAKI48JMxk0xIA0c2IEe2xFo4CEbIxvr21lc2xSY4AK6svPMxAIw28I cxkI7VAKI48JMxAIw28IcVCjz48v1sIEY20_XrWUJr1UMxC20s026xCaFVCjc4AY6r1j6r 4UMI8I3I0E5I8CrVAFwI0_Jr0_Jr4lx2IqxVCjr7xvwVAFwI0_JrI_JrWlx4CE17CEb7AF 67AKxVWUAVWUtwCIc40Y0x0EwIxGrwCI42IY6xIIjxv20xvE14v26r1j6r1xMIIF0xvE2I x0cI8IcVCY1x0267AKxVWUJVW8JwCI42IY6xAIw20EY4v20xvaj40_Wr1j6rW3Jr1lIxAI cVC2z280aVAFwI0_Cr0_Gr1UMIIF0xvEx4A2jsIEc7CjxVAFwI0_Gr1j6F4UJbIYCTnIWI evJa73UjIFyTuYvjxUqEoXUUUUU X-CM-SenderInfo: 5oymxthqpl0qxorr0wxvrqhubq/ X-Spam-Status: No, score=-3.1 required=5.0 tests=BAYES_00,NICE_REPLY_A, SPF_HELO_PASS,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2022/6/15 下午3:14, Marc Zyngier wrote: > On Wed, 15 Jun 2022 07:07:21 +0100, > Jianmin Lv wrote: >> >> From: Marc Zyngier >> >> In an unfortunate departure from the ACPI spec, the LoongArch >> architecture split its GSI space across multiple interrupt >> controllers. >> >> In order to be able to reuse sthe core code and prevent >> architectures from reinventing an already square wheel, offer >> the arch code the ability to register a dispatcher function >> that will return the domain fwnode for a given GSI. >> >> The ARM GIC drivers are updated to support this (with a single >> domain, as intended). >> >> Co-developed-by: Jianmin Lv > > I don't think this tag is appropriate here. > Ok, I'll drop it. >> Signed-off-by: Marc Zyngier >> Cc: Hanjun Guo >> Cc: Lorenzo Pieralisi >> Signed-off-by: Jianmin Lv >> --- >> drivers/acpi/irq.c | 40 +++++++++++++++++++++++----------------- >> drivers/irqchip/irq-gic-v3.c | 18 ++++++++++++------ >> drivers/irqchip/irq-gic.c | 18 ++++++++++++------ >> include/linux/acpi.h | 2 +- >> 4 files changed, 48 insertions(+), 30 deletions(-) >> >> diff --git a/drivers/acpi/irq.c b/drivers/acpi/irq.c >> index c68e694..b7460ab 100644 >> --- a/drivers/acpi/irq.c >> +++ b/drivers/acpi/irq.c >> @@ -12,7 +12,7 @@ >> >> enum acpi_irq_model_id acpi_irq_model; >> >> -static struct fwnode_handle *acpi_gsi_domain_id; >> +static struct fwnode_handle *(*acpi_get_gsi_domain_id)(u32 gsi); >> >> /** >> * acpi_gsi_to_irq() - Retrieve the linux irq number for a given GSI >> @@ -26,10 +26,7 @@ >> */ >> int acpi_gsi_to_irq(u32 gsi, unsigned int *irq) >> { >> - struct irq_domain *d = irq_find_matching_fwnode(acpi_gsi_domain_id, >> - DOMAIN_BUS_ANY); >> - >> - *irq = irq_find_mapping(d, gsi); >> + *irq = acpi_register_gsi(NULL, gsi, -1, -1); > > What is this? > > - This wasn't part of my initial patch, and randomly changing patches > without mentioning it isn't acceptable > > - you *cannot* trigger a registration here, as this isn't what the API > advertises > > - what makes you think that passing random values (NULL, -1... )to > acpi_register_gsi() is an acceptable thing to do? > > The original patch had: > > @@ -26,8 +26,10 @@ static struct fwnode_handle *acpi_gsi_domain_id; > */ > int acpi_gsi_to_irq(u32 gsi, unsigned int *irq) > { > - struct irq_domain *d = irq_find_matching_fwnode(acpi_gsi_domain_id, > - DOMAIN_BUS_ANY); > + struct irq_domain *d; > + > + d = irq_find_matching_fwnode(acpi_get_gsi_domain_id(gsi), > + DOMAIN_BUS_ANY); > *irq = irq_find_mapping(d, gsi); > /* > > and I don't think it needs anything else. If something breaks, let's > discuss it, but don't abuse the API nor the fact that I usually don't > review my own patches to sneak things in... > > M. >