Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp631400ybz; Wed, 29 Apr 2020 06:42:24 -0700 (PDT) X-Google-Smtp-Source: APiQypJG/u9yrgBRfeo1jkMf3ON20XysvPBd2p5cEBeiw1DpCkBtwX4jMiKRyGjKevZZpWIawwq/ X-Received: by 2002:a50:9f8f:: with SMTP id c15mr2316100edf.377.1588167744213; Wed, 29 Apr 2020 06:42:24 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588167744; cv=none; d=google.com; s=arc-20160816; b=xoqdloiTGGt0CizJ3HRebnEMPoyIdt+84RVJ9WBA13DRcRfetfENxRE6G961anoKDv fWMfAM44yjo5cZVw6tqmMbHIKAq+wsNS3yqSbYyMYaFJ5HjA4jPG4PlW46RSWrmelvOm AeC6IDJMBKosenJlonEB0F79+WJiISV7celzYPoZd/hJn7XAJIQfDAa34rI1ZVYEGOfz vtTc6+9nLb9i9BoHcqb7iS2nu509huyzO1YuScGbv+20yMna0Dq100ACduB2hOhFwx/b kxStB1unbe5YAWT2lLH4F7HdhIpeP/EoMkIPoJBTFFdjcnBxyqwB2DvE886LFnmHF5xX 6d2Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=9xyDFGBUG5iUXuZdKtqECT8162a/EZZr+Gs3UzGBLwg=; b=Bp+aKvtQIaffE1BeNGoMSfff/enL2r3/NHiEozgJO9R/9G4EobSYC3wQopo8qJxoGt g4N2a+mV5sdQT6iyfKXeP5dbdm6R7jrey4UBEpWciJR7X2WLahQ/kSC+pgZpB+QHQ+D7 BwDmo6DWZu++RR/uchtBpsvoaWN2YeQEAEV85qdPy+oIbV62vxpe5Ga+mUfU/y/r5C6X gji4u4RpJMwnvYUIjxUAXa9acG7bPo0q7m0BdFVtwCdqlf8FMQWT2kCpNRZSBJMb4Xpo cS6bs0NQaajBlndlwFHCv8vMyIICUcS8PeRCM34Q4chz4IzR7r7oUBUlq8ecR1WMUVbQ KxRw== 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 h23si3838580ejq.206.2020.04.29.06.42.01; Wed, 29 Apr 2020 06:42:24 -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 S1727976AbgD2Nhs (ORCPT + 99 others); Wed, 29 Apr 2020 09:37:48 -0400 Received: from 8bytes.org ([81.169.241.247]:39788 "EHLO theia.8bytes.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727917AbgD2Nhp (ORCPT ); Wed, 29 Apr 2020 09:37:45 -0400 Received: by theia.8bytes.org (Postfix, from userid 1000) id ED118BAD; Wed, 29 Apr 2020 15:37:36 +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: Daniel Drake , jonathan.derrick@intel.com, 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, Joerg Roedel Subject: [PATCH v3 09/34] iommu: Keep a list of allocated groups in __iommu_probe_device() Date: Wed, 29 Apr 2020 15:36:47 +0200 Message-Id: <20200429133712.31431-10-joro@8bytes.org> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20200429133712.31431-1-joro@8bytes.org> References: <20200429133712.31431-1-joro@8bytes.org> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Joerg Roedel This is needed to defer default_domain allocation for new IOMMU groups until all devices have been added to the group. Tested-by: Marek Szyprowski Acked-by: Marek Szyprowski Signed-off-by: Joerg Roedel --- drivers/iommu/iommu.c | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/drivers/iommu/iommu.c b/drivers/iommu/iommu.c index 7a385c18e1a5..18eb3623bd00 100644 --- a/drivers/iommu/iommu.c +++ b/drivers/iommu/iommu.c @@ -44,6 +44,7 @@ struct iommu_group { int id; struct iommu_domain *default_domain; struct iommu_domain *domain; + struct list_head entry; }; struct group_device { @@ -184,7 +185,7 @@ static void dev_iommu_free(struct device *dev) dev->iommu = NULL; } -static int __iommu_probe_device(struct device *dev) +static int __iommu_probe_device(struct device *dev, struct list_head *group_list) { const struct iommu_ops *ops = dev->bus->iommu_ops; struct iommu_device *iommu_dev; @@ -204,6 +205,9 @@ static int __iommu_probe_device(struct device *dev) } iommu_group_put(group); + if (group_list && !group->default_domain && list_empty(&group->entry)) + list_add_tail(&group->entry, group_list); + iommu_device_link(iommu_dev, dev); return 0; @@ -234,7 +238,7 @@ int iommu_probe_device(struct device *dev) if (ops->probe_device) { struct iommu_group *group; - ret = __iommu_probe_device(dev); + ret = __iommu_probe_device(dev, NULL); /* * Try to allocate a default domain - needs support from the @@ -567,6 +571,7 @@ struct iommu_group *iommu_group_alloc(void) group->kobj.kset = iommu_group_kset; mutex_init(&group->mutex); INIT_LIST_HEAD(&group->devices); + INIT_LIST_HEAD(&group->entry); BLOCKING_INIT_NOTIFIER_HEAD(&group->notifier); ret = ida_simple_get(&iommu_group_ida, 0, 0, GFP_KERNEL); -- 2.17.1