Received: by 2002:a05:6a10:6d10:0:0:0:0 with SMTP id gq16csp872733pxb; Fri, 22 Apr 2022 13:07:56 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwxXclYleGHTYRamSSb4cMaZbn4juYFPAjzFW/WIf6sAGAYQgoXpHYjRKEsO1XuyCNNxyKW X-Received: by 2002:a17:902:e00c:b0:15a:3b4a:3e42 with SMTP id o12-20020a170902e00c00b0015a3b4a3e42mr6194304plo.10.1650658076682; Fri, 22 Apr 2022 13:07:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1650658076; cv=none; d=google.com; s=arc-20160816; b=eb2n+vDkOl8zN3wBIdhg1Xhieb1iVif5Gn3XIGwSBzmfiBJgvHeG0tb6RUYq9Uw7Qq 7d5plxrUMFDAzthaNvvXU3XFHkEwcaKTzzJ8iYA+r2hcOFn3f2uhVV1baZFcA7Ct1bNm JNE0b12szyA1KpbmP4ypQ7ZXcYcDk2hXHMVSCiuHNN91q5s7eFrCi2h5Ax+oGhZuSx9A V0dMnUjKl2DdElGLiSFtOkPy296oHrJICG5mQ9SLGQ84a52oaFAQxZ0WlNWRfRDcIUgQ IKGaE2l/r5RheO65OGf4z+LeMyf6PsvD6DUg5nGhR7gaZDYMGjh3MJzc1BozxCIqvE2Z 7sJA== 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 :message-id:date:subject:cc:to:from:dkim-signature; bh=gdbvXFvPlODxwWrm89MVekUAyc4cmb0QzNZ5AG9eFow=; b=vmRYeg3o57q4S+LqVXd5xl+0Pdg+n5diLRCcP/BgWcPudcmWjBLsCGn5HFxSBedSTT QkpKaFefhsbJ3jAGt1UdlkoAZQnHAijbgU61xRi3mv6atYrZpZTZFuzScE07EGMe9kO6 iZiGQjOCkE8L9N4hx+QvL6iowQpsB2HbvPrtkOa+b3zg2hDIyThlwPtWP9uqTP6lgYTe Itf4mplJMwRo6OvEqYGJJJvGV9lG7FFUitAVHteeIJTjLJ25ma6h5HYlafDvlvc00Ppr JnSddcHfeAlt9k4u4XO5mhEUNKTdRwMGzLsNdUNWmmHae8DqER1+bbe0dyrcpoPe9Slv lCiw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=EIrQ4znQ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id h22-20020a635316000000b00399149a5d14si9419566pgb.205.2022.04.22.13.07.56 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 22 Apr 2022 13:07:56 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=EIrQ4znQ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 92849249B49; Fri, 22 Apr 2022 12:04:33 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1383124AbiDTXNV (ORCPT + 99 others); Wed, 20 Apr 2022 19:13:21 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:54506 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231873AbiDTXNO (ORCPT ); Wed, 20 Apr 2022 19:13:14 -0400 Received: from mail-oa1-x2f.google.com (mail-oa1-x2f.google.com [IPv6:2001:4860:4864:20::2f]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id EEA6211142 for ; Wed, 20 Apr 2022 16:10:26 -0700 (PDT) Received: by mail-oa1-x2f.google.com with SMTP id 586e51a60fabf-e2afb80550so3648230fac.1 for ; Wed, 20 Apr 2022 16:10:26 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=gdbvXFvPlODxwWrm89MVekUAyc4cmb0QzNZ5AG9eFow=; b=EIrQ4znQvoRLhPbawBtJopfbUloIV6vDLCxZk3sov+7xSyIliKoQDb839QzGpgLDQo BqTL/gRHVYKJUjuwrZF1D6PtoXmLKXvsRJO1UHFgfHiVFKnSv78BKD7wqpvuI4zk7rpK /wAa+6cjF2x6WZP1ngaHFOc/f8kYLqo8M2iRnVtLUi5aRnqn1CTrkdZTSAeD6f+SrhvT x3MXw+mHXXSpB1yrW41SLawFwtsbScYebG6PLX+FWsmWTa+YjK6fbGyJtotp60dO+ONS ZbIYLcuwIb+/SBJwyMH7zP3BWTZyNagbxjIrWCWNTkKbFKALjUXE9ecA78YzFVOsTo1g Xbvg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=gdbvXFvPlODxwWrm89MVekUAyc4cmb0QzNZ5AG9eFow=; b=E0rT1deSNV0reZ40yq3bQMkSokX1h0xIzAqmlnnmhyqIazJbhrRdYGIeodk9Fg/NZQ 7V329vp8WnmEfgBtfT75KysrP2Q8Lm+DecnW6W/D6/8TNn/Z39yrmLZgQU4IYQ7+A08W 4ylK6mmDUWEvf7RPW/erXDGdfOzmPp8jedNwRo3J0tymitE23az3DzXuScqeg0YdqBYv Hr5iSjYQ9HIjGBXeU+Fww4p/CO0AX9jaufu+IQkvK7sG5b6+2LyA5Okz3chEhoGjxcUd wAyE6iyvdTSg1r7dYqi32cpVeuUMG2ep97E1LYriSMTn0a96s0+DsH3zYdaVlaqNRPm4 NxMQ== X-Gm-Message-State: AOAM532mAZWgCO2P+hlUbi82FtyQ+u39125AL9Exw3hvUV7dVya3rKRn HM/hTsC8vI4WlzHjU+ZsBNllHQ== X-Received: by 2002:a05:6870:d1c9:b0:e5:9f16:c94f with SMTP id b9-20020a056870d1c900b000e59f16c94fmr2629205oac.273.1650496225618; Wed, 20 Apr 2022 16:10:25 -0700 (PDT) Received: from ripper.. ([2600:1700:a0:3dc8:205:1bff:fec0:b9b3]) by smtp.gmail.com with ESMTPSA id a17-20020a4ae931000000b0032933be7230sm7424481ooe.4.2022.04.20.16.10.24 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 20 Apr 2022 16:10:25 -0700 (PDT) From: Bjorn Andersson To: Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Daniel Vetter , Thierry Reding , Paul Kocialkowski , Rob Clark Cc: dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org Subject: [PATCH 1/2] Revert "drm: of: Properly try all possible cases for bridge/panel detection" Date: Wed, 20 Apr 2022 16:12:29 -0700 Message-Id: <20220420231230.58499-1-bjorn.andersson@linaro.org> X-Mailer: git-send-email 2.35.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.0 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RDNS_NONE,SPF_HELO_NONE autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Commit '80253168dbfd ("drm: of: Lookup if child node has panel or bridge")' introduced the ability to describe a panel under a display controller without having to use a graph to connect the controller to its single child panel (or bridge). The implementation of this would find the first non-graph node and attempt to acquire the related panel or bridge. This prevents cases where any other child node, such as a aux bus for a DisplayPort controller, or an opp-table to find the referenced panel. Commit '67bae5f28c89 ("drm: of: Properly try all possible cases for bridge/panel detection")' attempted to solve this problem by not bypassing the graph reference lookup before attempting to find the panel or bridge. While this does solve the case where a proper graph reference is present, it does not allow the caller to distinguish between a yet-to-be-probed panel or bridge and the absence of a reference to a panel. One such case is a DisplayPort controller that on some boards have an explicitly described reference to a panel, but on others have a discoverable DisplayPort display attached (which doesn't need to be expressed in DeviceTree). This reverts commit '67bae5f28c89 ("drm: of: Properly try all possible cases for bridge/panel detection")', as a step towards reverting commit '80253168dbfd ("drm: of: Lookup if child node has panel or bridge")'. Signed-off-by: Bjorn Andersson --- drivers/gpu/drm/drm_of.c | 99 ++++++++++++++++++++-------------------- 1 file changed, 49 insertions(+), 50 deletions(-) diff --git a/drivers/gpu/drm/drm_of.c b/drivers/gpu/drm/drm_of.c index f4df344509a8..026e4e29a0f3 100644 --- a/drivers/gpu/drm/drm_of.c +++ b/drivers/gpu/drm/drm_of.c @@ -214,29 +214,6 @@ int drm_of_encoder_active_endpoint(struct device_node *node, } EXPORT_SYMBOL_GPL(drm_of_encoder_active_endpoint); -static int find_panel_or_bridge(struct device_node *node, - struct drm_panel **panel, - struct drm_bridge **bridge) -{ - if (panel) { - *panel = of_drm_find_panel(node); - if (!IS_ERR(*panel)) - return 0; - - /* Clear the panel pointer in case of error. */ - *panel = NULL; - } - - /* No panel found yet, check for a bridge next. */ - if (bridge) { - *bridge = of_drm_find_bridge(node); - if (*bridge) - return 0; - } - - return -EPROBE_DEFER; -} - /** * drm_of_find_panel_or_bridge - return connected panel or bridge device * @np: device tree node containing encoder output ports @@ -259,44 +236,66 @@ int drm_of_find_panel_or_bridge(const struct device_node *np, struct drm_panel **panel, struct drm_bridge **bridge) { - struct device_node *node; - int ret; + int ret = -EPROBE_DEFER; + struct device_node *remote; if (!panel && !bridge) return -EINVAL; - if (panel) *panel = NULL; - if (bridge) - *bridge = NULL; - - /* Check for a graph on the device node first. */ - if (of_graph_is_present(np)) { - node = of_graph_get_remote_node(np, port, endpoint); - if (node) { - ret = find_panel_or_bridge(node, panel, bridge); - of_node_put(node); - - if (!ret) - return 0; - } - } - /* Otherwise check for any child node other than port/ports. */ - for_each_available_child_of_node(np, node) { - if (of_node_name_eq(node, "port") || - of_node_name_eq(node, "ports")) + /** + * Devices can also be child nodes when we also control that device + * through the upstream device (ie, MIPI-DCS for a MIPI-DSI device). + * + * Lookup for a child node of the given parent that isn't either port + * or ports. + */ + for_each_available_child_of_node(np, remote) { + if (of_node_name_eq(remote, "port") || + of_node_name_eq(remote, "ports")) continue; - ret = find_panel_or_bridge(node, panel, bridge); - of_node_put(node); + goto of_find_panel_or_bridge; + } + + /* + * of_graph_get_remote_node() produces a noisy error message if port + * node isn't found and the absence of the port is a legit case here, + * so at first we silently check whether graph presents in the + * device-tree node. + */ + if (!of_graph_is_present(np)) + return -ENODEV; + + remote = of_graph_get_remote_node(np, port, endpoint); + +of_find_panel_or_bridge: + if (!remote) + return -ENODEV; + + if (panel) { + *panel = of_drm_find_panel(remote); + if (!IS_ERR(*panel)) + ret = 0; + else + *panel = NULL; + } + + /* No panel found yet, check for a bridge next. */ + if (bridge) { + if (ret) { + *bridge = of_drm_find_bridge(remote); + if (*bridge) + ret = 0; + } else { + *bridge = NULL; + } - /* Stop at the first found occurrence. */ - if (!ret) - return 0; } - return -EPROBE_DEFER; + of_node_put(remote); + return ret; } EXPORT_SYMBOL_GPL(drm_of_find_panel_or_bridge); -- 2.35.1