Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp2519790rwd; Wed, 14 Jun 2023 04:11:18 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ6okb7Uzm57vazZ1VMU3dmUqbwNYdyEXFvDF5+qvp+OKJpAbm6edz91S1blmzOBWxR/QOXP X-Received: by 2002:a05:6a00:cc7:b0:663:6986:8aad with SMTP id b7-20020a056a000cc700b0066369868aadmr1648908pfv.13.1686741077670; Wed, 14 Jun 2023 04:11:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1686741077; cv=none; d=google.com; s=arc-20160816; b=Ma083rHcXjow0D+O9PMD6ZAUfrkD51Yo05CPBCavLH/o88qha73nrljY801bxtZcEL lzxVYNNyUf4Z5S0pbuMlYpdt8LJrrLoUh7ikP7f+R0Bl4HBfaziHG6zwHXu6eCsXqRjK 1QufFcNj9LbnJbmoJSxySiLT5fLsJT1OcIHZr73NyKSyAtbNSAWAN54caXXEI8Wyx9to tDxLIS4dH8iY2NEPu2cGaAb1tToGixQXA1FIWmdsXSoHS+txQ7NXnR47CHZhbrpakFxi yQbzglTItfUr2M77YaQUO8ZgY1p3aASZ533Tt4DE1DTd97BmBmv7j7k3Wbmy9vBtDzWz psUQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to :organization:from:content-language:references:cc:to:subject :user-agent:mime-version:date:message-id; bh=8yHql7sDMDdLPWrPc3UbNegsGZ9l/TkeI7j0uimotIQ=; b=g0LiSJGUsmEYqDNGrbLdiMKwxX+iBGIeGnOEyh3gai07RatHvglCY9pt+BOZ/vFqHu sIg1I7vhBDB0zGjRk+AmDbfSXJbdkERxwjoACHbMDloxupqmZLnR4+JntqJfdOHKoLbK dM1bDsnm6onmIpOfORHSkeiKE/cvs/6yurrjpuszPnhMnNY1MQOg0maU/sW/tSVpOguX Mw2qUiPZSZEIwcb+lE1Y8F7bB7wBwaN/9LhAn1I/xcruW1yawnG80+pp+Dh9KPaoBqCl f0pE4MCl/Uw873/KJEf74rPyIpeUVBHSJ1H3sP60ka54D4aQ6d+tZjRu5h3/8iwZaLXw MpEQ== 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 f16-20020a635110000000b005404f8dd0eesi10101066pgb.602.2023.06.14.04.11.02; Wed, 14 Jun 2023 04:11:17 -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 S234133AbjFNKul (ORCPT + 99 others); Wed, 14 Jun 2023 06:50:41 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56204 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229727AbjFNKuk (ORCPT ); Wed, 14 Jun 2023 06:50:40 -0400 Received: from mail.loongson.cn (mail.loongson.cn [114.242.206.163]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 1FE8E196; Wed, 14 Jun 2023 03:50:36 -0700 (PDT) Received: from loongson.cn (unknown [10.20.42.43]) by gateway (Coremail) with SMTP id _____8DxSup7m4lkUhgFAA--.10726S3; Wed, 14 Jun 2023 18:50:35 +0800 (CST) Received: from [10.20.42.43] (unknown [10.20.42.43]) by localhost.localdomain (Coremail) with SMTP id AQAAf8DxK8p6m4lkKIUaAA--.1634S3; Wed, 14 Jun 2023 18:50:34 +0800 (CST) Message-ID: Date: Wed, 14 Jun 2023 18:50:34 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.11.0 Subject: Re: [PATCH v7 2/8] PCI/VGA: Deal only with VGA class devices To: Sui Jingfeng <15330273260@189.cn>, Bjorn Helgaas Cc: amd-gfx@lists.freedesktop.org, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, intel-gfx@lists.freedesktop.org, nouveau@lists.freedesktop.org, linux-pci@vger.kernel.org, kvm@vger.kernel.org, linux-fbdev@vger.kernel.org References: <20230613030151.216625-1-15330273260@189.cn> <20230613030151.216625-3-15330273260@189.cn> Content-Language: en-US From: Sui Jingfeng Organization: Loongson In-Reply-To: <20230613030151.216625-3-15330273260@189.cn> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit X-CM-TRANSID: AQAAf8DxK8p6m4lkKIUaAA--.1634S3 X-CM-SenderInfo: xvxlyxpqjiv03j6o00pqjv00gofq/ X-Coremail-Antispam: 1Uk129KBj93XoWxXr43WFyxtr4ruFWDXr4xAFc_yoW5tr1xpF yrGa45KrW8Ga4xW3y2qF18ZFy5ZFZ0ka4rtr42k34FkFWqkw1qqF95GFyYq343JrWkJF1I qa1ayrnruanFgabCm3ZEXasCq-sJn29KB7ZKAUJUUUU5529EdanIXcx71UUUUU7KY7ZEXa sCq-sGcSsGvfJ3Ic02F40EFcxC0VAKzVAqx4xG6I80ebIjqfuFe4nvWSU5nxnvy29KBjDU 0xBIdaVrnRJUUU9ab4IE77IF4wAFF20E14v26r1j6r4UM7CY07I20VC2zVCF04k26cxKx2 IYs7xG6rWj6s0DM7CIcVAFz4kK6r1Y6r17M28lY4IEw2IIxxk0rwA2F7IY1VAKz4vEj48v e4kI8wA2z4x0Y4vE2Ix0cI8IcVAFwI0_Jr0_JF4l84ACjcxK6xIIjxv20xvEc7CjxVAFwI 0_Gr0_Cr1l84ACjcxK6I8E87Iv67AKxVWxJr0_GcWl84ACjcxK6I8E87Iv6xkF7I0E14v2 6rxl6s0DM2AIxVAIcxkEcVAq07x20xvEncxIr21l57IF6xkI12xvs2x26I8E6xACxx1l5I 8CrVACY4xI64kE6c02F40Ex7xfMcIj6xIIjxv20xvE14v26r1Y6r17McIj6I8E87Iv67AK xVWxJVW8Jr1lOx8S6xCaFVCjc4AY6r1j6r4UM4x0Y48IcVAKI48JMxk0xIA0c2IEe2xFo4 CEbIxvr21lc7CjxVAaw2AFwI0_JF0_Jw1l42xK82IYc2Ij64vIr41l4I8I3I0E4IkC6x0Y z7v_Jr0_Gr1lx2IqxVAqx4xG67AKxVWUJVWUGwC20s026x8GjcxK67AKxVWUGVWUWwC2zV AF1VAY17CE14v26r1q6r43MIIYrxkI7VAKI48JMIIF0xvE2Ix0cI8IcVAFwI0_Jr0_JF4l IxAIcVC0I7IYx2IY6xkF7I0E14v26r1j6r4UMIIF0xvE42xK8VAvwI8IcIk0rVWUJVWUCw CI42IY6I8E87Iv67AKxVWxJVW8Jr1lIxAIcVC2z280aVCY1x0267AKxVW8JVW8JrUvcSsG vfC2KfnxnUUI43ZEXa7IU88MaUUUUUU== X-Spam-Status: No, score=-2.0 required=5.0 tests=BAYES_00,NICE_REPLY_A, SPF_HELO_NONE,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 Hi, On 2023/6/13 11:01, Sui Jingfeng wrote: > From: Sui Jingfeng > > Deal only with the VGA devcie(pdev->class == 0x0300), so replace the > pci_get_subsys() function with pci_get_class(). Filter the non-PCI display > device(pdev->class != 0x0300) out. There no need to process the non-display > PCI device. > > Cc: Bjorn Helgaas > Signed-off-by: Sui Jingfeng > --- > drivers/pci/vgaarb.c | 22 ++++++++++++---------- > 1 file changed, 12 insertions(+), 10 deletions(-) > > diff --git a/drivers/pci/vgaarb.c b/drivers/pci/vgaarb.c > index c1bc6c983932..22a505e877dc 100644 > --- a/drivers/pci/vgaarb.c > +++ b/drivers/pci/vgaarb.c > @@ -754,10 +754,6 @@ static bool vga_arbiter_add_pci_device(struct pci_dev *pdev) > struct pci_dev *bridge; > u16 cmd; > > - /* Only deal with VGA class devices */ > - if ((pdev->class >> 8) != PCI_CLASS_DISPLAY_VGA) > - return false; > - Hi, here is probably a bug fixing. For an example, nvidia render only GPU typically has 0x0380. at its PCI class number, but  render only GPU should not participate in the arbitration. As it shouldn't snoop the legacy fixed VGA address. It(render only GPU) can not display anything. But 0x0380 >> 8 = 0x03, the filter  failed. > /* Allocate structure */ > vgadev = kzalloc(sizeof(struct vga_device), GFP_KERNEL); > if (vgadev == NULL) { > @@ -1500,7 +1496,9 @@ static int pci_notify(struct notifier_block *nb, unsigned long action, > struct pci_dev *pdev = to_pci_dev(dev); > bool notify = false; > > - vgaarb_dbg(dev, "%s\n", __func__); > + /* Only deal with VGA class devices */ > + if (pdev->class != PCI_CLASS_DISPLAY_VGA << 8) > + return 0; So here we only care 0x0300, my initial intent is to make an optimization, nowadays sane display graphic card should all has 0x0300 as its PCI class number, is this complete right? ``` #define PCI_BASE_CLASS_DISPLAY        0x03 #define PCI_CLASS_DISPLAY_VGA        0x0300 #define PCI_CLASS_DISPLAY_XGA        0x0301 #define PCI_CLASS_DISPLAY_3D        0x0302 #define PCI_CLASS_DISPLAY_OTHER        0x0380 ``` Any ideas ? > /* For now we're only intereted in devices added and removed. I didn't > * test this thing here, so someone needs to double check for the > @@ -1510,6 +1508,8 @@ static int pci_notify(struct notifier_block *nb, unsigned long action, > else if (action == BUS_NOTIFY_DEL_DEVICE) > notify = vga_arbiter_del_pci_device(pdev); > > + vgaarb_dbg(dev, "%s: action = %lu\n", __func__, action); > + > if (notify) > vga_arbiter_notify_clients(); > return 0; > @@ -1534,8 +1534,8 @@ static struct miscdevice vga_arb_device = { > > static int __init vga_arb_device_init(void) > { > + struct pci_dev *pdev = NULL; > int rc; > - struct pci_dev *pdev; > > rc = misc_register(&vga_arb_device); > if (rc < 0) > @@ -1545,11 +1545,13 @@ static int __init vga_arb_device_init(void) > > /* We add all PCI devices satisfying VGA class in the arbiter by > * default */ > - pdev = NULL; > - while ((pdev = > - pci_get_subsys(PCI_ANY_ID, PCI_ANY_ID, PCI_ANY_ID, > - PCI_ANY_ID, pdev)) != NULL) > + while (1) { > + pdev = pci_get_class(PCI_CLASS_DISPLAY_VGA << 8, pdev); > + if (!pdev) > + break; > + > vga_arbiter_add_pci_device(pdev); > + } > > pr_info("loaded\n"); > return rc; -- Jingfeng