Received: by 2002:a05:6602:2086:0:0:0:0 with SMTP id a6csp4083571ioa; Tue, 26 Apr 2022 16:51:16 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzTJpUYN2Wvxa27kSi3HQHkL1fgBHc3dtExy3cKp4ynWXlvxlmoz7Asi/w8e3S1bG2n6X35 X-Received: by 2002:a65:5a8e:0:b0:365:3b6:47fb with SMTP id c14-20020a655a8e000000b0036503b647fbmr21747706pgt.147.1651017076544; Tue, 26 Apr 2022 16:51:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1651017076; cv=none; d=google.com; s=arc-20160816; b=CbKg+3gp8OZRB7HJpecfZl0Fa7tEA8veOusbjP8wSFHdiP1I6ZCjsWVK4yBNCv9gNZ 742JcpWa9WSW2yKxPAQ+0OKp1T3Y/rkEjUEa7coV0QtOqKaah5JyZUlgtpBZzgea+VSd Xuab2BqF7rRaeHASPPWH0gal++JAdHIIGrGz3iKJPUo3ShFY8bp1d/B84W1WUlNg8afV jOOhHI2GMiAgBKnv0gVcU2sgQeTSERAzR7klClj/afSR9i7kdcwECFHqDUh7rIlsmWN+ hx9PNmW2kx9+tgcWNHLrgX3zUbhEcZqNea4RwpTidHFy1qM/q/s1aPwhzB6sdcT1E6aU dGBA== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=FHkc/KMM4MIFnqT4k+x68ZoEqV/W91Mh5VuDllL9NMM=; b=lpQTYR7NgYQVLhZQ9sBu9BL/YAQNmDjfe7SXumUC6df3yKregl3FhxYaWJ9MMZs6nk ZCSrUJe5BK4zsib6dyv9bzem6OYb9o0KF8OqRTYmWhL6pS7ieSGg6FR0tguBM6yrVYhD I4MaV8OZmKlqLrYxkGhYyrOn/CEFW7Qy4T4+2IydVYyvV7pdIK7b5Y3omFUgWbXUvzSo JTk7lYGsP61qI7//Hj5LsBtjaBQ/VB4+7JEvVSqEJF+J+iIYy99jCCcer6nZFfHA8Qp+ +noBLu5R9Y7uSG9ymUOBce7aSnKyUP/e9hs8cymtKezSwxo1hev1hfAi7snzAzCoZimu Ac1Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=mhEO8JDD; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id s37-20020a635265000000b003aa1ecf8d44si11857496pgl.123.2022.04.26.16.51.00; Tue, 26 Apr 2022 16:51:16 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=mhEO8JDD; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S240753AbiDZJGf (ORCPT + 99 others); Tue, 26 Apr 2022 05:06:35 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56242 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1346535AbiDZIpH (ORCPT ); Tue, 26 Apr 2022 04:45:07 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [IPv6:2604:1380:4641:c500::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id DA0BB16B196; Tue, 26 Apr 2022 01:34:56 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 2C5196185D; Tue, 26 Apr 2022 08:34:56 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 3C510C385A4; Tue, 26 Apr 2022 08:34:55 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1650962095; bh=WEBbgczWrpbCXYwFl07E9jqszZ2qufQtN0yZY/YVjpg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=mhEO8JDD2TW3OHeN1DIDnu0dNZPwbUjiVFG/h+bsafaZDoCbsDDBhTbKvASt2QNQ8 CrxNWPj652F/O2Zt+VK4Z1oYGzv27EO4kaetuFfAxdo03KQmQbaoZ2WxCDvcR1hOV5 EMU01ZYcxCwoqx965Qdn+HLi20mGhDH07dmoPlDs= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Dave Stevenson , Stefan Wahren , Maxime Ripard , Sasha Levin Subject: [PATCH 5.10 69/86] drm/panel/raspberrypi-touchscreen: Initialise the bridge in prepare Date: Tue, 26 Apr 2022 10:21:37 +0200 Message-Id: <20220426081743.198823808@linuxfoundation.org> X-Mailer: git-send-email 2.36.0 In-Reply-To: <20220426081741.202366502@linuxfoundation.org> References: <20220426081741.202366502@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-7.7 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS autolearn=ham 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 From: Dave Stevenson [ Upstream commit 5f18c0782b99e26121efa93d20b76c19e17aa1dd ] The panel has a prepare call which is before video starts, and an enable call which is after. The Toshiba bridge should be configured before video, so move the relevant power and initialisation calls to prepare. Fixes: 2f733d6194bd ("drm/panel: Add support for the Raspberry Pi 7" Touchscreen.") Signed-off-by: Dave Stevenson Signed-off-by: Stefan Wahren Signed-off-by: Maxime Ripard Link: https://patchwork.freedesktop.org/patch/msgid/20220415162513.42190-3-stefan.wahren@i2se.com Signed-off-by: Sasha Levin --- drivers/gpu/drm/panel/panel-raspberrypi-touchscreen.c | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/drivers/gpu/drm/panel/panel-raspberrypi-touchscreen.c b/drivers/gpu/drm/panel/panel-raspberrypi-touchscreen.c index 90487df62480..4b92c6341490 100644 --- a/drivers/gpu/drm/panel/panel-raspberrypi-touchscreen.c +++ b/drivers/gpu/drm/panel/panel-raspberrypi-touchscreen.c @@ -265,7 +265,7 @@ static int rpi_touchscreen_noop(struct drm_panel *panel) return 0; } -static int rpi_touchscreen_enable(struct drm_panel *panel) +static int rpi_touchscreen_prepare(struct drm_panel *panel) { struct rpi_touchscreen *ts = panel_to_ts(panel); int i; @@ -295,6 +295,13 @@ static int rpi_touchscreen_enable(struct drm_panel *panel) rpi_touchscreen_write(ts, DSI_STARTDSI, 0x01); msleep(100); + return 0; +} + +static int rpi_touchscreen_enable(struct drm_panel *panel) +{ + struct rpi_touchscreen *ts = panel_to_ts(panel); + /* Turn on the backlight. */ rpi_touchscreen_i2c_write(ts, REG_PWM, 255); @@ -349,7 +356,7 @@ static int rpi_touchscreen_get_modes(struct drm_panel *panel, static const struct drm_panel_funcs rpi_touchscreen_funcs = { .disable = rpi_touchscreen_disable, .unprepare = rpi_touchscreen_noop, - .prepare = rpi_touchscreen_noop, + .prepare = rpi_touchscreen_prepare, .enable = rpi_touchscreen_enable, .get_modes = rpi_touchscreen_get_modes, }; -- 2.35.1