Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp586088ybz; Wed, 15 Apr 2020 14:35:13 -0700 (PDT) X-Google-Smtp-Source: APiQypKly8fDMmifcXmuXzOyvWca7gZAMz55ufPx4NxQ75t/pzf+FoaUnPqmn9t95qXLbZCg3u9p X-Received: by 2002:aa7:cac6:: with SMTP id l6mr27225801edt.265.1586986513148; Wed, 15 Apr 2020 14:35:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586986513; cv=none; d=google.com; s=arc-20160816; b=GhRa1nAmsQOg103eoumIrHTG7TLXY/EPw92GggIXQMDpZngKYKiO0VxSPlf1iCEj3N 9WyPqZsL/PiU4xAI3WsqME8gTBRifdF+kTbdoa5IXWgamrPpuB6VzUpSy/2CjcdfScb3 iqkQf3HJEcE5+32h/vO9XUbtTqW89UVw1hITOwRJISKAwd2YqPLBZDlvL9oHkjeVxFlP UreKUFBvmWOkQE9zVEzEQP5rlw2YkZp9Kb+FupFPJxRzGQUuwR9u7tRtU5RydEChHzrF 10Y52Jdlg2H9NuE9gwvuOfqc9gvELv7/86YCSgtwd/2iZgm7wxlcYiXCqwxyc/bv3WTT AWTw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from; bh=DP3Q7Tr/rJkpmjw+RuCPmusjhL6RiD6DaPY1EtGZqBg=; b=DMi3H40T7aZQVzwDnNAl/KjRMYfagVuoPyCUsfinTtZF7jw+3Yz+pAM0LjoWI4oOog HPcx6ROcPL4vAW0wPNWHxON8z5r8bCD9b0hd6Yj4A4tmWQAEDzi3o4YZHVAuUpgH4OYX ybg9B04YjX+ltdn91umz6jb00ZRGb+v9MlBZ+90B60j6L49VI5Gyklm2GdVvJpFrlstv l9CmJ67NSQJ4SIO7MdRlrmxPGRkvZ23CwnHeaaAqnKAmtOkcyq2jEs5ja8rus2OczS4m ffl3ev7ybNGEXaduUiRmW5L3BH8Cwk8mUGMUBlMTjU1CJk9E+NFGlkEyQEnVTyIlE0Ks KuWw== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=8bytes.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y25si11159872edr.60.2020.04.15.14.34.49; Wed, 15 Apr 2020 14:35:13 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=8bytes.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2387511AbgDNNaW (ORCPT + 99 others); Tue, 14 Apr 2020 09:30:22 -0400 Received: from 8bytes.org ([81.169.241.247]:34728 "EHLO theia.8bytes.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2502860AbgDNNP6 (ORCPT ); Tue, 14 Apr 2020 09:15:58 -0400 Received: by theia.8bytes.org (Postfix, from userid 1000) id 6821A2B0; Tue, 14 Apr 2020 15:15:51 +0200 (CEST) From: Joerg Roedel To: Joerg Roedel , Will Deacon , Robin Murphy , Marek Szyprowski , Kukjin Kim , Krzysztof Kozlowski , David Woodhouse , Lu Baolu , Andy Gross , Bjorn Andersson , Matthias Brugger , Rob Clark , Heiko Stuebner , Gerald Schaefer , Thierry Reding , Jonathan Hunter , Jean-Philippe Brucker Cc: iommu@lists.linux-foundation.org, linux-kernel@vger.kernel.org, linux-samsung-soc@vger.kernel.org, linux-arm-msm@vger.kernel.org, linux-mediatek@lists.infradead.org, linux-rockchip@lists.infradead.org, linux-s390@vger.kernel.org, linux-tegra@vger.kernel.org, virtualization@lists.linux-foundation.org Subject: [PATCH v2 00/33] iommu: Move iommu_group setup to IOMMU core code Date: Tue, 14 Apr 2020 15:15:09 +0200 Message-Id: <20200414131542.25608-1-joro@8bytes.org> X-Mailer: git-send-email 2.17.1 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, here is the second version of this patch-set. The first version with some more introductory text can be found here: https://lore.kernel.org/lkml/20200407183742.4344-1-joro@8bytes.org/ Changes v1->v2: * Rebased to v5.7-rc1 * Re-wrote the arm-smmu changes as suggested by Robin Murphy * Re-worked the Exynos patches to hopefully not break the driver anymore * Fixed a missing mutex_unlock() reported by Marek Szyprowski, thanks for that. There is also a git-branch available with these patches applied: https://git.kernel.org/pub/scm/linux/kernel/git/joro/linux.git/log/?h=iommu-probe-device-v2 Please review. Thanks, Joerg Joerg Roedel (32): iommu: Move default domain allocation to separate function iommu/amd: Implement iommu_ops->def_domain_type call-back iommu/vt-d: Wire up iommu_ops->def_domain_type iommu/amd: Remove dma_mask check from check_device() iommu/amd: Return -ENODEV in add_device when device is not handled by IOMMU iommu: Add probe_device() and remove_device() call-backs iommu: Move default domain allocation to iommu_probe_device() iommu: Keep a list of allocated groups in __iommu_probe_device() iommu: Move new probe_device path to separate function iommu: Split off default domain allocation from group assignment iommu: Move iommu_group_create_direct_mappings() out of iommu_group_add_device() iommu: Export bus_iommu_probe() and make is safe for re-probing iommu/amd: Remove dev_data->passthrough iommu/amd: Convert to probe/release_device() call-backs iommu/vt-d: Convert to probe/release_device() call-backs iommu/arm-smmu: Convert to probe/release_device() call-backs iommu/pamu: Convert to probe/release_device() call-backs iommu/s390: Convert to probe/release_device() call-backs iommu/virtio: Convert to probe/release_device() call-backs iommu/msm: Convert to probe/release_device() call-backs iommu/mediatek: Convert to probe/release_device() call-backs iommu/mediatek-v1 Convert to probe/release_device() call-backs iommu/qcom: Convert to probe/release_device() call-backs iommu/rockchip: Convert to probe/release_device() call-backs iommu/tegra: Convert to probe/release_device() call-backs iommu/renesas: Convert to probe/release_device() call-backs iommu/omap: Remove orphan_dev tracking iommu/omap: Convert to probe/release_device() call-backs iommu/exynos: Use first SYSMMU in controllers list for IOMMU core iommu/exynos: Convert to probe/release_device() call-backs iommu: Remove add_device()/remove_device() code-paths iommu: Unexport iommu_group_get_for_dev() Sai Praneeth Prakhya (1): iommu: Add def_domain_type() callback in iommu_ops drivers/iommu/amd_iommu.c | 97 ++++---- drivers/iommu/amd_iommu_types.h | 1 - drivers/iommu/arm-smmu-v3.c | 38 +-- drivers/iommu/arm-smmu.c | 39 ++-- drivers/iommu/exynos-iommu.c | 24 +- drivers/iommu/fsl_pamu_domain.c | 22 +- drivers/iommu/intel-iommu.c | 68 +----- drivers/iommu/iommu.c | 393 +++++++++++++++++++++++++------- drivers/iommu/ipmmu-vmsa.c | 60 ++--- drivers/iommu/msm_iommu.c | 34 +-- drivers/iommu/mtk_iommu.c | 24 +- drivers/iommu/mtk_iommu_v1.c | 50 ++-- drivers/iommu/omap-iommu.c | 99 ++------ drivers/iommu/qcom_iommu.c | 24 +- drivers/iommu/rockchip-iommu.c | 26 +-- drivers/iommu/s390-iommu.c | 22 +- drivers/iommu/tegra-gart.c | 24 +- drivers/iommu/tegra-smmu.c | 31 +-- drivers/iommu/virtio-iommu.c | 41 +--- include/linux/iommu.h | 21 +- 20 files changed, 533 insertions(+), 605 deletions(-) -- 2.17.1