Received: by 2002:ac0:a679:0:0:0:0:0 with SMTP id p54csp693626imp; Wed, 20 Feb 2019 07:26:15 -0800 (PST) X-Google-Smtp-Source: AHgI3IYg794jA3+eGbt03f6nlRgtsgEi3rk59RSMSYROLSpm1nl4qoRrALqk2lT2M0DAGVIP2uj3 X-Received: by 2002:a17:902:104:: with SMTP id 4mr37070315plb.62.1550676375364; Wed, 20 Feb 2019 07:26:15 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1550676375; cv=none; d=google.com; s=arc-20160816; b=rX/+lYXzsYcuQ89hZPAxmkWFHp1U5WvxMJQ+Mp65nLUtFppfYW+fbzo2rnam04DeI3 fVkq791dePxq+uJOL3t0gEqgUI/unWLRf5pKV+SDFq3SduK02v5vbR1RO/TUUrHthtiX hydkdTUxp1APqzCbOrgnsFgAvO3+OC9stef6ujw4Yz5DUqyx+Yjusu9q7nHu1d/37o5c kHSXCworxxm/EJTNJ6qalHatkh04SnLjanm8tZ8/SPxVVAiIi9Aj9FLKdtQuFLB/f7WV ZkSu54E2Gkh2u3VialA7YasGzHL1CSEO6/BArX+Fkn8J1CPaXWhbf+vxZmwRNhBjbx5d 8nJg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=hCA7JZWrYLo6TnprwLPz5Xs3apnPjAjXOI/b49LK08w=; b=FiWc6YfgYPomUlNnye55cEmpwGA/weNR87bUN6mILtoaFFAu8ffxgXt3B3I2zJjt/q xQldwRn4yMleQinEJkHm3JkVvAizDL1Wt7T5KwQjkDhE9iOjPWUIzbCHi+RH3zplClx0 /LtZT9PagZ54AKhD6nkuKb/Evc25Z4lhhAqK2OPh9L7iVsyLYumGTT3RsV7br39yfFyh KeUSGc7vYludoDKyrB8TseQPlqxf6VL2J4lLJ+yK+4BILZMxbLhBYqcIFYgm5Y4iRuet fhEkEtjBSBioR7+8Wu7p3wLz9QovrMPD9r2HP0nwOJ00YgeJqwriDBPR2xJh1cpJvQEU 4U5g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=LXL8g+vH; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h22si15705726pgv.198.2019.02.20.07.25.59; Wed, 20 Feb 2019 07:26:15 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=LXL8g+vH; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727424AbfBTPZM (ORCPT + 99 others); Wed, 20 Feb 2019 10:25:12 -0500 Received: from perceval.ideasonboard.com ([213.167.242.64]:42076 "EHLO perceval.ideasonboard.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726019AbfBTPZL (ORCPT ); Wed, 20 Feb 2019 10:25:11 -0500 Received: from pendragon.ideasonboard.com (dfj612yhrgyx302h3jwwy-3.rev.dnainternet.fi [IPv6:2001:14ba:21f5:5b00:ce28:277f:58d7:3ca4]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id B792F2D1; Wed, 20 Feb 2019 16:25:09 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1550676309; bh=0TJgsLFgG2RQpD7sXwK5x2fdqgOVzse8WJ7zf1h5eF0=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=LXL8g+vHEKactp5pc2PjLcS1MJTnj8L9Eg32PMIFUUk4yjchPHAh4Iw79WM8mWiyO 0HgLxYorSd1/L1doPb04/445ISd2YYU//BJ77pOT9R38idaSB+lcYh3OjBEqBtEy2t yk0UZKZHFYC8XhdPbX5PC4ef+UgrYgoyjNtyJwps= Date: Wed, 20 Feb 2019 17:25:05 +0200 From: Laurent Pinchart To: Geert Uytterhoeven Cc: Joerg Roedel , Magnus Damm , Laurent Pinchart , iommu@lists.linux-foundation.org, linux-renesas-soc@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH 1/7] iommu/ipmmu-vmsa: Link IOMMUs and devices in sysfs Message-ID: <20190220152505.GD3516@pendragon.ideasonboard.com> References: <20190220150531.2462-1-geert+renesas@glider.be> <20190220150531.2462-2-geert+renesas@glider.be> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <20190220150531.2462-2-geert+renesas@glider.be> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Geert, Thank you for the patch. On Wed, Feb 20, 2019 at 04:05:25PM +0100, Geert Uytterhoeven wrote: > As of commit 7af9a5fdb9e0ca33 ("iommu/ipmmu-vmsa: Use > iommu_device_sysfs_add()/remove()"), IOMMU devices show up under > /sys/class/iommus/, but their "devices" subdirectories are empty. > Likewise, devices tied to an IOMMU do not have an "iommu" backlink. > > Make sure all links are created, on both arm32 and arm64. > > Signed-off-by: Geert Uytterhoeven Reviewed-by: Laurent Pinchart > --- > drivers/iommu/ipmmu-vmsa.c | 24 +++++++++++++++++------- > 1 file changed, 17 insertions(+), 7 deletions(-) > > diff --git a/drivers/iommu/ipmmu-vmsa.c b/drivers/iommu/ipmmu-vmsa.c > index 9a380c10655e182d..9f2b781e20a0eba6 100644 > --- a/drivers/iommu/ipmmu-vmsa.c > +++ b/drivers/iommu/ipmmu-vmsa.c > @@ -885,27 +885,37 @@ static int ipmmu_init_arm_mapping(struct device *dev) > > static int ipmmu_add_device(struct device *dev) > { > + struct ipmmu_vmsa_device *mmu = to_ipmmu(dev); > struct iommu_group *group; > + int ret; > > /* > * Only let through devices that have been verified in xlate() > */ > - if (!to_ipmmu(dev)) > + if (!mmu) > return -ENODEV; > > - if (IS_ENABLED(CONFIG_ARM) && !IS_ENABLED(CONFIG_IOMMU_DMA)) > - return ipmmu_init_arm_mapping(dev); > + if (IS_ENABLED(CONFIG_ARM) && !IS_ENABLED(CONFIG_IOMMU_DMA)) { > + ret = ipmmu_init_arm_mapping(dev); > + if (ret) > + return ret; > + } else { > + group = iommu_group_get_for_dev(dev); > + if (IS_ERR(group)) > + return PTR_ERR(group); > > - group = iommu_group_get_for_dev(dev); > - if (IS_ERR(group)) > - return PTR_ERR(group); > + iommu_group_put(group); > + } > > - iommu_group_put(group); > + iommu_device_link(&mmu->iommu, dev); > return 0; > } > > static void ipmmu_remove_device(struct device *dev) > { > + struct ipmmu_vmsa_device *mmu = to_ipmmu(dev); > + > + iommu_device_unlink(&mmu->iommu, dev); > arm_iommu_detach_device(dev); > iommu_group_remove_device(dev); > } -- Regards, Laurent Pinchart