From patchwork Wed Oct 10 12:07:18 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Laurentiu Tudor X-Patchwork-Id: 10634443 Return-Path: Received: from mail.wl.linuxfoundation.org (pdx-wl-mail.web.codeaurora.org [172.30.200.125]) by pdx-korg-patchwork-2.web.codeaurora.org (Postfix) with ESMTP id BC47B14DB for ; Wed, 10 Oct 2018 12:12:37 +0000 (UTC) Received: from mail.wl.linuxfoundation.org (localhost [127.0.0.1]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id 9B8C029E16 for ; Wed, 10 Oct 2018 12:12:36 +0000 (UTC) Received: by mail.wl.linuxfoundation.org (Postfix, from userid 486) id 8F53429E73; Wed, 10 Oct 2018 12:12:36 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on pdx-wl-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.9 required=2.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,MAILING_LIST_MULTI,RCVD_IN_DNSWL_NONE autolearn=ham version=3.3.1 Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.wl.linuxfoundation.org (Postfix) with ESMTPS id 0B17429E16 for ; Wed, 10 Oct 2018 12:12:36 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20170209; h=Sender: Content-Transfer-Encoding:Content-Type:MIME-Version:Cc:List-Subscribe: List-Help:List-Post:List-Archive:List-Unsubscribe:List-Id:Message-Id:Date: Subject:To:From:Reply-To:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:In-Reply-To: References:List-Owner; bh=AuNFR2IiicT8oG4v7ZY8Af/NLmSp7BxE8vAeJOyKaQM=; b=QoC Jhd7EiSWFxtllO3WGZdWw+6RK6oQS2zS3152dpOuoQFl99kFwR18s65loS8gz9QZXt5Wksw4Is9ur 41UafA2HGZ69gzNIuaHflMEEKoZkzPx3jN9B3DkXB3gWWpuLJ6UUTDch+t6BRBq8elUR4bLGOFGB/ qzCMBxjmpeQvL92tFeV41qYXs6PVMsg1+xXnn5+O1ZkRzcHyMgKSg/oY7q+w22cg38wRrKMmP7siR DR3tVvudM7mLAB7qSvDZapR6+n35RytDsd+drKvjVpZO5PEx3gq36LXEardcsOxRYgloswqzpfwf0 vWHpobX8a987pZaLNkzEQzlLirUy3Yw==; Received: from localhost ([127.0.0.1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.90_1 #2 (Red Hat Linux)) id 1gADLq-0001hg-Kg; Wed, 10 Oct 2018 12:12:30 +0000 Received: from inva020.nxp.com ([92.121.34.13]) by bombadil.infradead.org with esmtps (Exim 4.90_1 #2 (Red Hat Linux)) id 1gADHW-0006uF-4B for linux-arm-kernel@lists.infradead.org; Wed, 10 Oct 2018 12:08:07 +0000 Received: from inva020.nxp.com (localhost [127.0.0.1]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id 7D5401A013B; Wed, 10 Oct 2018 14:07:48 +0200 (CEST) Received: from inva024.eu-rdc02.nxp.com (inva024.eu-rdc02.nxp.com [134.27.226.22]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id 7A03B1A017F; Wed, 10 Oct 2018 14:07:48 +0200 (CEST) Received: from fsr-ub1864-101.ea.freescale.net (fsr-ub1864-101.ea.freescale.net [10.171.82.46]) by inva024.eu-rdc02.nxp.com (Postfix) with ESMTP id C0C3620619; Wed, 10 Oct 2018 14:07:47 +0200 (CEST) From: laurentiu.tudor@nxp.com To: devicetree@vger.kernel.org, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, arm@kernel.org Subject: [PATCH v3 00/22] SMMU enablement for NXP LS1043A and LS1046A Date: Wed, 10 Oct 2018 15:07:18 +0300 Message-Id: <20181010120737.30300-1-laurentiu.tudor@nxp.com> X-Mailer: git-send-email 2.17.1 X-Virus-Scanned: ClamAV using ClamSMTP X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20181010_050802_844761_6DBC0681 X-CRM114-Status: GOOD ( 10.69 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.21 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: arnd@arndb.de, bharat.bhushan@nxp.com, madalin.bucur@nxp.com, shawnguo@kernel.org, roy.pledge@nxp.com, leoyang.li@nxp.com, robin.murphy@arm.com, davem@davemloft.net, Laurentiu Tudor MIME-Version: 1.0 Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+patchwork-linux-arm=patchwork.kernel.org@lists.infradead.org X-Virus-Scanned: ClamAV using ClamSMTP From: Laurentiu Tudor This patch series adds SMMU support for NXP LS1043A and LS1046A chips and consists mostly in important driver fixes and the required device tree updates. It touches several subsystems and consists of three main parts: - changes in soc/drivers/fsl/qbman drivers adding iommu mapping of reserved memory areas, fixes and defered probe support - changes in drivers/net/ethernet/freescale/dpaa_eth drivers consisting in misc dma mapping related fixes and probe ordering - addition of the actual arm smmu device tree node together with various adjustments to the device trees Performance impact Running iperf benchmarks in a back-to-back setup (both sides having smmu enabled) on a 10GBps port show an important networking performance degradation of around 40% (9.48Gbps linerate vs 5.45Gbps) and around 30%-35% with iommu.strict=1. If you need performance but without SMMU support you can use "iommu.passthrough=1" to disable SMMU. The patch set is based on net-next so, if generally agreed, I'd suggest to get the patches through the netdev tree after getting all the Acks. Changes in v3: - redesigned the badly broken logic behind qbman portal probe checking APIs. Updated commit message with details - dropped few patches that were picked through arm-soc tree [2] - added Madalin's Ack [1] for fsl/fman and dpaa_eth [1] https://lkml.org/lkml/2018/9/27/831 [2] [PATCH 05/23] soc/fsl/qbman: add APIs to retrieve the probing status [PATCH 06/23] soc/fsl/qman_portals: defer probe after qman's probe [PATCH 07/23] soc/fsl/bman_portals: defer probe after bman's probe Changes in v2: - dropped confusing comments in smmu interrupt property (Robin) - add an intermediate usb simple-bus to fix dma size issue (Robin) - use defines instead of numbers in smmu interrupt definition - drop double iommu_get_domain_for_dev() call in few qbman patches Laurentiu Tudor (22): soc/fsl/qman: fixup liodns only on ppc targets soc/fsl/bman: map FBPR area in the iommu soc/fsl/qman: map FQD and PFDR areas in the iommu soc/fsl/qman-portal: map CENA area in the iommu soc/fsl/qbman: add APIs to retrieve the probing status soc/fsl/qman_portals: defer probe after qman's probe soc/fsl/bman_portals: defer probe after bman's probe soc/fsl/qbman_portals: add APIs to retrieve the probing status fsl/fman: backup and restore ICID registers fsl/fman: add API to get the device behind a fman port dpaa_eth: defer probing after qbman dpaa_eth: base dma mappings on the fman rx port dpaa_eth: fix iova handling for contiguous frames dpaa_eth: fix iova handling for sg frames dpaa_eth: fix SG frame cleanup arm64: dts: ls1046a: add smmu node arm64: dts: ls1043a: add smmu node arm64: dts: ls104xa: set mask to drop TBU ID from StreamID arm64: dts: ls104x: add missing dma ranges property arm64: dts: ls104x: add iommu-map to pci controllers arm64: dts: ls104x: make dma-coherent global to the SoC arm64: dts: ls104x: use a pseudo-bus to constrain usb dma size .../arm64/boot/dts/freescale/fsl-ls1043a.dtsi | 106 ++++++++++---- .../arm64/boot/dts/freescale/fsl-ls1046a.dtsi | 102 ++++++++++--- .../net/ethernet/freescale/dpaa/dpaa_eth.c | 136 ++++++++++++------ drivers/net/ethernet/freescale/fman/fman.c | 35 ++++- drivers/net/ethernet/freescale/fman/fman.h | 4 + .../net/ethernet/freescale/fman/fman_port.c | 14 ++ .../net/ethernet/freescale/fman/fman_port.h | 2 + drivers/soc/fsl/qbman/bman_ccsr.c | 22 +++ drivers/soc/fsl/qbman/bman_portal.c | 32 ++++- drivers/soc/fsl/qbman/qman_ccsr.c | 28 ++++ drivers/soc/fsl/qbman/qman_portal.c | 48 ++++++- include/soc/fsl/bman.h | 16 +++ include/soc/fsl/qman.h | 17 +++ 13 files changed, 455 insertions(+), 107 deletions(-)