Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp4933371pxj; Wed, 9 Jun 2021 05:36:09 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy7EH9ltrdTGcFgo+Y4pRmxBn1VoYECPzci+YLjuisCdoMITZmu8HSe3V045cnhR8ZeQS1y X-Received: by 2002:a17:907:7747:: with SMTP id kx7mr28473793ejc.400.1623242168820; Wed, 09 Jun 2021 05:36:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1623242168; cv=none; d=google.com; s=arc-20160816; b=bFpgZ+Bfm7g2xCaHyUhGNJBovJVBebNq/bb7/o5AuFwcneqaBlDve8ufNfZke4hQts e3hv+noIEZEGIdAsFHpdC6A9ZhnVQuwJA3MAI0kJhoaqn4jNUrk+Z6nl34qXmjTU0onQ SZSsbrKPCHiXCcvHuCpetD7FedYFETy11rqMZX5HvlsdEADVBsODL5oIdMwn0p9Mk7nw s04iNwqnuHP43vyrxe9LroE0VQ9pIDN8UvQ+gAei74uAunyiwoMpyZvXKx1XgmbvTMCA p1wcs1Wi75RX+KNK6QsAUxRRRXxCad84GWr1QodjUxhWhxbuQHPsNcY+D91oFtZqQlC8 Hymg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from:dkim-signature; bh=6zXMN5ll7TqYL0aplhePUX2gZ+E/gbqQqmdmCua20NM=; b=wqp+J5t3oQsB0cdHhjFUbB5eAnM727gPp35vgxptPFCnwq1x02Na43DSun8pJb9xr3 8tagOTmBS20YfnAU2MnVG5SzOUXwyy+9+9fZ/ysaozz3ZZ7c+EX00lImLAxDHOrTYPts fiwxshqP7Z8d2/BdI0BJL1Hz27fAIkHUHytCjwjWsYK2ye/HMPV/nCiw0n2KImbYQiyU Fc/ujcdg5Hm31la/w4s8Wmqfq6uvdiiaoBqk3Nu/p+dqvZUHGGxw233STuIpHGnsU8vH UdQioYIgtbXcdt/LWQCSZOpyZDDN+Cv1ZkecIkJGpExKcnZYie/7dYDgp41JAFfASG+X GNJQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=UZyWz51R; 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=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id dz12si2269428edb.23.2021.06.09.05.35.45; Wed, 09 Jun 2021 05:36:08 -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=@linaro.org header.s=google header.b=UZyWz51R; 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=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236487AbhFIDj1 (ORCPT + 99 others); Tue, 8 Jun 2021 23:39:27 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35534 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236476AbhFIDjY (ORCPT ); Tue, 8 Jun 2021 23:39:24 -0400 Received: from mail-pl1-x635.google.com (mail-pl1-x635.google.com [IPv6:2607:f8b0:4864:20::635]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 450A4C061756 for ; Tue, 8 Jun 2021 20:37:17 -0700 (PDT) Received: by mail-pl1-x635.google.com with SMTP id x19so4685729pln.2 for ; Tue, 08 Jun 2021 20:37:17 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=6zXMN5ll7TqYL0aplhePUX2gZ+E/gbqQqmdmCua20NM=; b=UZyWz51Rvms6N+ygB3kUxZtGt095CvNlartmipzWktYJkX6mhk2UUYkFSIt3/zA/54 rBtSPHOfB3zEgZpzeHHFpHUwQ6ymdsyMzMlXyDv9xJzwa4yTID9WTr1bj8wFcc9p2ujO MoCIEC28IQg1q/tLpq2rfmJTSBAhoka7P+hEEfLb0F00cegQaoxPsr2DWXE+YWYvs2R/ xNFZME+bxCcb3psEc3YuUpt12MNhcFxHOE0r2PG03NTBb0OA3QkcI7wgR/Ig8PeEaSJo Q7u7nNhSeWXckY3D8p/emX5k0sNEaGinWv+7i2bC3rkK2rc38wMCWbHQPZxFqEvSj7BX xopw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=6zXMN5ll7TqYL0aplhePUX2gZ+E/gbqQqmdmCua20NM=; b=b/UvWDlhksWusZRMU1diYr/mtQrWt3UMmLmG9yZwcj2nyZidcaufsJ6vfDN5/1ydd+ vUrNYsyQuDv++IxGoyXOP+rv3qVtP/nCvx/NHmTCJUHvxLpQeM4+hKYfT2hZmq1drzNB ePcpWH8N6eFhRSC0KLAV8vyCm7Sg3wN5QaqxYy5EUxCRtWfDaK0XL7DUOFO5Mal1ykKE z7aPSbqa+RNG+q/4w/KiD/7YBLg0E1IbXEqWl7zgZs8TWwbZbvkOiTV4T+UfmhLaoag8 H/3yll1EL2tE6m8rqIanLfEIl7B41N1OABCkNFq00Kd+coIfh9urJx9Duy69bNx//bIr EGOQ== X-Gm-Message-State: AOAM532XVL/gUWu6nFZnxv7HsAoJmxLPGTD1elOTw3x+ewO51u4RZ5fm vOjzzxGsgSf9YIt3zbfcI1CS5g== X-Received: by 2002:a17:902:9042:b029:10f:c864:6090 with SMTP id w2-20020a1709029042b029010fc8646090mr3393800plz.39.1623209836798; Tue, 08 Jun 2021 20:37:16 -0700 (PDT) Received: from localhost.localdomain ([45.135.186.135]) by smtp.gmail.com with ESMTPSA id t24sm3473904pji.56.2021.06.08.20.37.10 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Tue, 08 Jun 2021 20:37:16 -0700 (PDT) From: Zhangfei Gao To: Bjorn Helgaas , Greg Kroah-Hartman , Arnd Bergmann , jean-philippe , kenneth-lee-2012@foxmail.com, Wangzhou Cc: linux-pci@vger.kernel.org, linux-kernel@vger.kernel.org, Zhangfei Gao Subject: [PATCH v4 3/3] PCI: Set dma-can-stall for HiSilicon chips Date: Wed, 9 Jun 2021 11:36:41 +0800 Message-Id: <1623209801-1709-4-git-send-email-zhangfei.gao@linaro.org> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1623209801-1709-1-git-send-email-zhangfei.gao@linaro.org> References: <1623209801-1709-1-git-send-email-zhangfei.gao@linaro.org> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org HiSilicon KunPeng920 and KunPeng930 have devices appear as PCI but are actually on the AMBA bus. These fake PCI devices can support SVA via SMMU stall feature, by setting dma-can-stall for ACPI platforms. Property dma-can-stall depends on patchset https://lore.kernel.org/linux-iommu/162314710744.3707892.6632600736379822229.b4-ty@kernel.org/ Signed-off-by: Zhangfei Gao Signed-off-by: Jean-Philippe Brucker Signed-off-by: Zhou Wang --- drivers/pci/quirks.c | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/drivers/pci/quirks.c b/drivers/pci/quirks.c index 9331113..c1643ce 100644 --- a/drivers/pci/quirks.c +++ b/drivers/pci/quirks.c @@ -1822,10 +1822,23 @@ DECLARE_PCI_FIXUP_CLASS_FINAL(PCI_VENDOR_ID_HUAWEI, 0x1610, PCI_CLASS_BRIDGE_PCI static void quirk_huawei_pcie_sva(struct pci_dev *pdev) { + struct property_entry properties[] = { + PROPERTY_ENTRY_BOOL("dma-can-stall"), + {}, + }; + if (pdev->revision != 0x21 && pdev->revision != 0x30) return; pdev->pasid_no_tlp = 1; + + /* + * Set the dma-can-stall property on ACPI platforms. Device tree + * can set it directly. + */ + if (!pdev->dev.of_node && + device_add_properties(&pdev->dev, properties)) + pci_warn(pdev, "could not add stall property"); } DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_HUAWEI, 0xa250, quirk_huawei_pcie_sva); DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_HUAWEI, 0xa251, quirk_huawei_pcie_sva); -- 2.7.4