Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp2932371pxf; Sun, 21 Mar 2021 12:00:20 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx9dXAmaC6UpSloK5ANZT53XViC5dKXQUIVHmU/WwAiBb3mXt9D6abnXJJIE7bP15tRsvgz X-Received: by 2002:a05:6402:95b:: with SMTP id h27mr22119163edz.93.1616353220096; Sun, 21 Mar 2021 12:00:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1616353220; cv=none; d=google.com; s=arc-20160816; b=C8BBZUKe+XTys6XEkGzFIMhl/zzvtt3UKx8O29kREeUg2YNkk9yykr1gEZi2MrGfza MLuZCRWjceUCAkuywHKY+FFgTtMSr6eFQIyj0E5Vckci61EdNFtLn1I0ZIJWM5hMkxnF qKPMFk6OxfWmDSe/QTAU2JqPIt/+lObYNEWbBc5Uy+hQZClqSuuSEYMcDoGYcJ79FArc UOJKpU6piqRJAm1cRP4rawwd2Sc/vzFXwZAwlENdhdwTRh1OhgjdHxkI6KwiG9+DOBrx Hpcco5lArzMR+p8+ejiiZJkA+BC0GJQ0Z7SiCuH0O0V/vAA+6wv6+RQImm5Rdn+cMFlK b8mw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:to:from; bh=oqe3XQvc3WlxlX3cpcFR6mngV7SUh9gDWvFeb7sIkYI=; b=UIzf9yHOcP2VRGBKH1VPbAJ9IdUeP/ACR7JIP9w4Tozannxic64Ry1YSk9sWfiXSSd 3iEVoe04KicjO1GbJ6eFCbUNgJW/r6w8Gtvk/mNvTBEhYquJuzriMloQYNKyqDIMTE6n XBBPdc22c/F8mJwh0C5kGLoqtvoX+lT3KRlzdQkLXsgwFRqy3bPgbva+asCtec2Upidp jO/bOhODnV3dtMQTLW6Lx2k8XKOp3Y8ifc7ekf6K/2oASYFaqzGAy40EjzDopXq5yCDG NvxA6KJKeZcJr9nuS2JGb5/VlJRCV2Qw0hhYrEp4IbckFTD0q8tCcRn0Duv2fZ/00wfd ZuSw== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id qo24si9184718ejb.99.2021.03.21.11.59.55; Sun, 21 Mar 2021 12:00: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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230139AbhCUS6w convert rfc822-to-8bit (ORCPT + 99 others); Sun, 21 Mar 2021 14:58:52 -0400 Received: from gloria.sntech.de ([185.11.138.130]:43132 "EHLO gloria.sntech.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230060AbhCUS6W (ORCPT ); Sun, 21 Mar 2021 14:58:22 -0400 Received: from p508fc3a3.dip0.t-ipconnect.de ([80.143.195.163] helo=phil.localnet) by gloria.sntech.de with esmtpsa (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1lO3HC-0006z5-By; Sun, 21 Mar 2021 19:58:14 +0100 From: Heiko Stuebner To: Sandy Huang , David Airlie , Daniel Vetter , dri-devel@lists.freedesktop.org, linux-arm-kernel@lists.infradead.org, linux-rockchip@lists.infradead.org, linux-kernel@vger.kernel.org, Jonathan McDowell Subject: Re: [PATCH] drm/rockchip: Cope with endpoints that haven't been registered yet Date: Sun, 21 Mar 2021 19:58:13 +0100 Message-ID: <3104631.44csPzL39Z@phil> In-Reply-To: <20210316182753.GA25685@earth.li> References: <20210316182753.GA25685@earth.li> MIME-Version: 1.0 Content-Transfer-Encoding: 8BIT Content-Type: text/plain; charset="iso-8859-1" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Jonathan, Am Dienstag, 16. M?rz 2021, 19:27:53 CET schrieb Jonathan McDowell: > The Rockchip RGB CRTC output driver attempts to avoid probing Rockchip > subdrivers to see if they're a connected panel or bridge. However part > of its checks assumes that if no OF platform device is found then it > can't be a valid bridge or panel. This causes issues with I2C controlled > bridges that have not yet been registered to the point they can be > found. > > Change this to return EPROBE_DEFER instead of ENODEV and don't ignore > such devices. The subsequent call to drm_of_find_panel_or_bridge() will > return EPROBE_DEFER as well if there's actually a valid device we should > wait for. > > Signed-off-by: Jonathan McDowell > --- > drivers/gpu/drm/rockchip/rockchip_drm_drv.c | 8 ++++++-- > drivers/gpu/drm/rockchip/rockchip_rgb.c | 7 ++++--- > 2 files changed, 10 insertions(+), 5 deletions(-) > > diff --git a/drivers/gpu/drm/rockchip/rockchip_drm_drv.c b/drivers/gpu/drm/rockchip/rockchip_drm_drv.c > index 212bd87c0c4a..b0d63a566501 100644 > --- a/drivers/gpu/drm/rockchip/rockchip_drm_drv.c > +++ b/drivers/gpu/drm/rockchip/rockchip_drm_drv.c > @@ -270,11 +270,15 @@ int rockchip_drm_endpoint_is_subdriver(struct device_node *ep) > if (!node) > return -ENODEV; > > - /* status disabled will prevent creation of platform-devices */ > + /* > + * status disabled will prevent creation of platform-devices, > + * but equally we can't rely on the driver having been registered > + * yet (e.g. I2C bridges). > + */ > pdev = of_find_device_by_node(node); > of_node_put(node); > if (!pdev) > - return -ENODEV; > + return -EPROBE_DEFER; In general, how does that relate to i2c-bridge-drivers, as of_find_device_by_node supposedly only acts on platform-devices? Also if that points to a disabled bridge (hdmi, etc) that would likely make it probe-defer indefinitly, as that device will never become available? Maybe we could do something like of_device_is_available() which checks the status property of the node. So something like: pdev = of_find_device_by_node(node); if (!pdev) { bool avail = of_device_is_available(node); of_node_put(node); /* if disabled if (!avail) return -ENODEV; else return -EPROBE_DEFER; } of_node_put(node); Though I still do not understand how that should actually pick up on i2c devices at all. Heiko