Received: by 2002:a05:6a10:9e8c:0:0:0:0 with SMTP id y12csp908823pxx; Thu, 29 Oct 2020 18:20:36 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyLfWG+NOAPCEIZS8DD3+NgzZzaVsF07LzHxGqeMGTtW1mvFEbSjkrwIHvcmtHX7nB0MU2W X-Received: by 2002:a05:6402:19ae:: with SMTP id o14mr6830403edz.67.1604020836058; Thu, 29 Oct 2020 18:20:36 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1604020836; cv=none; d=google.com; s=arc-20160816; b=BSqNMNs5mOzSCOHiXM9BgmewU18F3X4fQDO7hiT628muSSBhPFQh2o1wmqrDMLOk0F TQeyxvxWj4uJj0Y4gTcLrg6uEgJQgsCxnju6zaMT0YCPjDJ0kkxgpGnuLEpB/HuzSCMa x3dU6U6ZJXIl9fKCUB1ofKK1znN+8nP797df4N5fE01uhfOKu9JdqGRXL5WlIB32YT99 nJgTmMS2Ao58yYJWfY9B9vFLrThLpwgDef7XFtcLxGA/FQkHJxstDQOfyob7LhgUjKwr C67W8OK8Ra3mFV9OE7Bj5eFMeN+GXzkfBfJ/8hArjxLOoupBO2uxC4hg/sP+oKvu56Nu xQYA== 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:cc:to:from :dkim-signature; bh=Ha6d4m9hNhg8mJNd9NxPkdoxY0rDbWj+549lDc0BZvA=; b=wWY0c7Btyd48PsQ0Nvi1W41AhvqhToGm4kvWzANAaIIau03XIT53jbAj6beXpvV2EX kRVUEG/5wVQwOiABEEIhaldpHeETM3CCfwn5RQu1UAJN7oFpHhRGwdwhF9fiSgd4xiOE iexCQSpaT5hw+CHA6CETBFFTZVPPUUQp7hcfBpxADTZKRwdTubkP4Yc2xEKcKGiCQ4Cn G+GY7nOR1o3Vw2NDQXusqevp38aQkF3FS15jGAPxOjp9nlcdMr0lEi9MHq4lAA+vPXuZ A8mOm+tq7OzPXaLzR0491/Z1UCMpaMd5pupBobRkFq7CM8RB/rTyzqwTg9JvYuj8UHw/ fw6g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=Ut+GsZyC; 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=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id g23si2914419ejr.397.2020.10.29.18.20.13; Thu, 29 Oct 2020 18:20:36 -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; dkim=pass header.i=@chromium.org header.s=google header.b=Ut+GsZyC; 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=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726149AbgJ3BRr (ORCPT + 99 others); Thu, 29 Oct 2020 21:17:47 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53212 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725379AbgJ3BRq (ORCPT ); Thu, 29 Oct 2020 21:17:46 -0400 Received: from mail-pl1-x641.google.com (mail-pl1-x641.google.com [IPv6:2607:f8b0:4864:20::641]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 16AA4C0613CF for ; Thu, 29 Oct 2020 18:17:45 -0700 (PDT) Received: by mail-pl1-x641.google.com with SMTP id 1so2178968ple.2 for ; Thu, 29 Oct 2020 18:17:45 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=Ha6d4m9hNhg8mJNd9NxPkdoxY0rDbWj+549lDc0BZvA=; b=Ut+GsZyCxsILcxGwO7EaUgN3ZFz36AhbzS7p6bMWyVXxYXeRaWfDLmMPEdSLGl8Odu tM5YV8rp0fXRZo4/F+E1vpbZh3UguCR74BN+HnNDJEd7Dret+Fbjjjl6LbbUVVLW5cad 0bdPIb3Zf0Tu5xlOsuHrN33BGerd3aYHC05S8= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=Ha6d4m9hNhg8mJNd9NxPkdoxY0rDbWj+549lDc0BZvA=; b=nW3sP8V4mObYILZwjxZzP0/gWEF3/es7CwBL2zfB1W50NN9twpgbOlzL2tKBS/q1lh lTnLsK0ziKzpTpR18+fn0LsY82KILpGf8yQRu3JjtPU8vp9REhI5ksfntHTdJ+JJ09Ip Xz14qRyofSJY5DLaCiOU+Hp+MBC/Q+jUSpNy2rsijD/K9NC7qvJvCaN6D0YFRGMtMZVw hoOgjCSTMY7G/M5T+bUeo8R6QimyVjPB7vSi1IEdfmhtHpJAyAVscBWCSjHS65sD6LfY a2ZN9/6wjnQ3XfZiSYYhq+QF9xi0BL9+VeVv2HYmmSRf9VkklYnIWsjYea51M60Zz4hv wFag== X-Gm-Message-State: AOAM530hTx+zQfBprDhpDlTcy4u4exw5FEaxpRLnxcoOHfP883bYnsv8 ZlQW6uFI93EH94yIqMpG+2giNQ== X-Received: by 2002:a17:902:9890:b029:d2:2f2a:584e with SMTP id s16-20020a1709029890b02900d22f2a584emr6729708plp.29.1604020664675; Thu, 29 Oct 2020 18:17:44 -0700 (PDT) Received: from smtp.gmail.com ([2620:15c:202:201:3e52:82ff:fe6c:83ab]) by smtp.gmail.com with ESMTPSA id z26sm4477854pfq.131.2020.10.29.18.17.43 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 29 Oct 2020 18:17:44 -0700 (PDT) From: Stephen Boyd To: Andrzej Hajda , Neil Armstrong Cc: linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, Douglas Anderson , Laurent Pinchart , Jonas Karlman , Jernej Skrabec , Sean Paul Subject: [PATCH v2 3/4] drm/bridge: ti-sn65dsi86: Read EDID blob over DDC Date: Thu, 29 Oct 2020 18:17:37 -0700 Message-Id: <20201030011738.2028313-4-swboyd@chromium.org> X-Mailer: git-send-email 2.29.1.341.ge80a0c044ae-goog In-Reply-To: <20201030011738.2028313-1-swboyd@chromium.org> References: <20201030011738.2028313-1-swboyd@chromium.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Use the DDC connection to read the EDID from the eDP panel instead of relying on the panel to tell us the modes. Reviewed-by: Douglas Anderson Cc: Laurent Pinchart Cc: Jonas Karlman Cc: Jernej Skrabec Cc: Sean Paul Signed-off-by: Stephen Boyd --- drivers/gpu/drm/bridge/ti-sn65dsi86.c | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/drivers/gpu/drm/bridge/ti-sn65dsi86.c b/drivers/gpu/drm/bridge/ti-sn65dsi86.c index c77f46a21aae..f86934fd6cc8 100644 --- a/drivers/gpu/drm/bridge/ti-sn65dsi86.c +++ b/drivers/gpu/drm/bridge/ti-sn65dsi86.c @@ -119,6 +119,7 @@ * @debugfs: Used for managing our debugfs. * @host_node: Remote DSI node. * @dsi: Our MIPI DSI source. + * @edid: Detected EDID of eDP panel. * @refclk: Our reference clock. * @panel: Our panel. * @enable_gpio: The GPIO we toggle to enable the bridge. @@ -144,6 +145,7 @@ struct ti_sn_bridge { struct drm_bridge bridge; struct drm_connector connector; struct dentry *debugfs; + struct edid *edid; struct device_node *host_node; struct mipi_dsi_device *dsi; struct clk *refclk; @@ -265,6 +267,23 @@ connector_to_ti_sn_bridge(struct drm_connector *connector) static int ti_sn_bridge_connector_get_modes(struct drm_connector *connector) { struct ti_sn_bridge *pdata = connector_to_ti_sn_bridge(connector); + struct edid *edid = pdata->edid; + int num, ret; + + if (!edid) { + pm_runtime_get_sync(pdata->dev); + edid = pdata->edid = drm_get_edid(connector, &pdata->aux.ddc); + pm_runtime_put(pdata->dev); + } + + if (edid && drm_edid_is_valid(edid)) { + ret = drm_connector_update_edid_property(connector, edid); + if (!ret) { + num = drm_add_edid_modes(connector, edid); + if (num) + return num; + } + } return drm_panel_get_modes(pdata->panel, connector); } @@ -1245,6 +1264,7 @@ static int ti_sn_bridge_remove(struct i2c_client *client) if (!pdata) return -EINVAL; + kfree(pdata->edid); ti_sn_debugfs_remove(pdata); of_node_put(pdata->host_node); -- Sent by a computer, using git, on the internet