Received: by 2002:a05:6a11:4021:0:0:0:0 with SMTP id ky33csp839203pxb; Wed, 29 Sep 2021 10:43:20 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxP3lRi8r2yuqKEJQ1XqdJDnUL5COz+9H0OWUheu/dpF2KmD/A6IQb1vaxyb6CXNeG6I15m X-Received: by 2002:a05:6402:411:: with SMTP id q17mr1380403edv.35.1632937400414; Wed, 29 Sep 2021 10:43:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1632937400; cv=none; d=google.com; s=arc-20160816; b=D3zkBnghBfS3ljwlF++9mykdViIz1SLBFgIEqId7AJPfbSU7grQkoMMmTuICd+nDwk 0EbxbHaySBF6+b17pTzWJqD+REZsH2UQIpOyU12b89zxSYrG7Z3dwKDC+5+m1q34I7Lt WnXVcUVDAHBjUP3EfWqf1RX0qlO1lavn5l+1cNXjLcWllZsG02njNBSzMMegwMBlc/mr QBPWnl+aN2xYuGUY8k5DgcltL4OilQ/zIN9RV5yOxBUHvWYPZ0dkpvAM2onxGbvtImMp wRNIC2igBeKfW9TQZZsMyrJDLus6lCr+xxaWfOA6kcThCiI5pU0hrsPQysLpGK9J5yft ZpqA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject; bh=fDu3OdB4vNM4qqWEP9c+zLPC44eqkx6JKx9mofBBqls=; b=N0/kCr67ZUzXckzBtrX5kFk8PzfcTA7R2MV0fCwrclJXn+Z3Sas0ojC5V5DShaC33f nLLwCW1IIMTi4ad1HRLArf4arhkN1VpNfIVmh+WS+witNiOaaiajAOWb6RtiPXHEFnWp OOanamMsbpB1fY3amag5pvHYIm60Z8RlEefQNiCwVBNajrPk5x7HmRxDgC3tYZxwD94e 7VP0gFAiNGqfyfbH+qvwoBGqGbBkm7vcDLh74XIGQ38HdgJQ4z7hXrpc+y3CIU2/gWvv +lkVC3D+OrRd9N3QvKA4U4oSJh4a1r2XRiaHiW73o+ZGul7pnC24PLTHQG876u/CFmQt SiUQ== 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=collabora.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id 6si476576ejc.751.2021.09.29.10.42.48; Wed, 29 Sep 2021 10:43:20 -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=collabora.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1345544AbhI2Qew (ORCPT + 99 others); Wed, 29 Sep 2021 12:34:52 -0400 Received: from bhuna.collabora.co.uk ([46.235.227.227]:51880 "EHLO bhuna.collabora.co.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S244930AbhI2Qev (ORCPT ); Wed, 29 Sep 2021 12:34:51 -0400 Received: from [IPv6:2a02:810a:880:f54:fd5c:7cb1:aaa8:78b1] (unknown [IPv6:2a02:810a:880:f54:fd5c:7cb1:aaa8:78b1]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: dafna) by bhuna.collabora.co.uk (Postfix) with ESMTPSA id 3A3C31F4473B; Wed, 29 Sep 2021 17:33:08 +0100 (BST) Subject: Re: [PATCH v8 03/12] iommu/mediatek: Add probe_defer for smi-larb To: Yong Wu , Matthias Brugger , Joerg Roedel , Rob Herring , Krzysztof Kozlowski , David Airlie , Mauro Carvalho Chehab Cc: Evan Green , Robin Murphy , Tomasz Figa , Will Deacon , linux-mediatek@lists.infradead.org, srv_heupstream@mediatek.com, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, iommu@lists.linux-foundation.org, youlin.pei@mediatek.com, Matthias Kaehlcke , anan.sun@mediatek.com, yi.kuo@mediatek.com, acourbot@chromium.org, linux-media@vger.kernel.org, dri-devel@lists.freedesktop.org, Daniel Vetter , Chun-Kuang Hu , Philipp Zabel , Tiffany Lin , Hsin-Yi Wang , Eizan Miyamoto , anthony.huang@mediatek.com, Frank Wunderlich References: <20210929013719.25120-1-yong.wu@mediatek.com> <20210929013719.25120-4-yong.wu@mediatek.com> From: Dafna Hirschfeld Message-ID: <33a8b313-ad1b-d307-7e8c-2fdebdc6f1a7@collabora.com> Date: Wed, 29 Sep 2021 18:33:05 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.13.0 MIME-Version: 1.0 In-Reply-To: <20210929013719.25120-4-yong.wu@mediatek.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 29.09.21 03:37, Yong Wu wrote: > Prepare for adding device_link. > > The iommu consumer should use device_link to connect with the > smi-larb(supplier). then the smi-larb should run before the iommu > consumer. Here we delay the iommu driver until the smi driver is ready, > then all the iommu consumers always are after the smi driver. > > When there is no this patch, if some consumer drivers run before > smi-larb, the supplier link_status is DL_DEV_NO_DRIVER(0) in the > device_link_add, then device_links_driver_bound will use WARN_ON > to complain that the link_status of supplier is not right. > > device_is_bound may be more elegant here. but it is not allowed to > EXPORT from https://lore.kernel.org/patchwork/patch/1334670/. > > Signed-off-by: Yong Wu > Tested-by: Frank Wunderlich # BPI-R2/MT7623 > --- > drivers/iommu/mtk_iommu.c | 2 +- > drivers/iommu/mtk_iommu_v1.c | 2 +- > 2 files changed, 2 insertions(+), 2 deletions(-) > > diff --git a/drivers/iommu/mtk_iommu.c b/drivers/iommu/mtk_iommu.c > index d837adfd1da5..d5848f78a677 100644 > --- a/drivers/iommu/mtk_iommu.c > +++ b/drivers/iommu/mtk_iommu.c > @@ -844,7 +844,7 @@ static int mtk_iommu_probe(struct platform_device *pdev) > id = i; > > plarbdev = of_find_device_by_node(larbnode); > - if (!plarbdev) { > + if (!plarbdev || !plarbdev->dev.driver) { > of_node_put(larbnode); > return -EPROBE_DEFER; if plarbdev is null doesn't that mean that the device does not exist? so we should return -ENODEV in that case? thanks, Dafna > } > diff --git a/drivers/iommu/mtk_iommu_v1.c b/drivers/iommu/mtk_iommu_v1.c > index 1467ba1e4417..4d7809432239 100644 > --- a/drivers/iommu/mtk_iommu_v1.c > +++ b/drivers/iommu/mtk_iommu_v1.c > @@ -602,7 +602,7 @@ static int mtk_iommu_probe(struct platform_device *pdev) > } > > plarbdev = of_find_device_by_node(larbnode); > - if (!plarbdev) { > + if (!plarbdev || !plarbdev->dev.driver) { > of_node_put(larbnode); > return -EPROBE_DEFER; > } >