Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp1756915ybz; Sat, 18 Apr 2020 07:52:10 -0700 (PDT) X-Google-Smtp-Source: APiQypJq2lXKJhmD/ioLGNVDsyqF/ibYmpga/8d4/XvxowNWCC7qz34NNYkclHm5npZcEk5uGpwC X-Received: by 2002:a17:906:e210:: with SMTP id gf16mr8221590ejb.214.1587221530150; Sat, 18 Apr 2020 07:52:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587221530; cv=none; d=google.com; s=arc-20160816; b=KilxQIiLeP5zf6lobCww7zzPbdvG/g5xd3vpHN4kZ4HnoJr6xTahBmiOGBKsFjv/zp pJobQ7iloHA9//MVrpvau8p2NIk/RFmm1913kyqurtw+fwZ42LNrbrXeDdcsan+af6b8 envE7jvWioSUnLvcClpvx1WB1WItb4KtnCwBGQ2v03lNGk22VcElz13EiOsDcqFUqjtE iFkmP1irFgfCEcoeFoXOdyGeXWqJcibA+HPgrvS9MS/17U1IRESX3XTWVyFD/f6cLiav L8Y8tcw+BrP3fuIut5AmMe780zpCtf5G7NSndqdYxMMF0LWCZrzPQn9uGRQ5C0sUEDN0 87Fw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=sC9cGv9+kpTfKHbzDhrEuF9uzjMvgrty03F9qJ0I9lQ=; b=KVe6ghsnGCJvGOCeNHJse/mrDmKhwFEVhutlYUMS37roCFGsTbFRVTjYZ3tVndlnKS Q3J1Qb6Be5hjEYxKVm6tloks58JyRLhAx/1rFOBvgkM6mppxPYVzNNZwmvvsFUGwg69R lQxTMU7JXirQr+Lhju5+fWMRseRiH+ltS8RdYVaTejbSLBhO3BEN0gTKzdgJelhWkPRd v9u/ShGO1NpPPTWicZOLP3KzpCE2dHZXuOErzty/x1oUsSwlKWH1Zee/M2zZrt7Vso78 kV9etIos7m43i6HWs4qWlLSKE9drIG7xecn8Rv+yR247g+RBldDbEVEBvMebT/rjzTaG YAkg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=Bsfs9HqK; 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=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id k6si16587178ejv.507.2020.04.18.07.51.47; Sat, 18 Apr 2020 07:52:10 -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=@kernel.org header.s=default header.b=Bsfs9HqK; 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=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728584AbgDROn1 (ORCPT + 99 others); Sat, 18 Apr 2020 10:43:27 -0400 Received: from mail.kernel.org ([198.145.29.99]:54232 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728544AbgDROnS (ORCPT ); Sat, 18 Apr 2020 10:43:18 -0400 Received: from sasha-vm.mshome.net (c-73-47-72-35.hsd1.nh.comcast.net [73.47.72.35]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 1BEF222240; Sat, 18 Apr 2020 14:43:17 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1587220998; bh=Nc7RsPd8Y5ByX3ptQZ5fohyeTqewNhMV0zhtHF5N9OI=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Bsfs9HqKlO+WIobS/8KO0AoKauBJ4kCFOQNQYVFN+IKDJ16oirLZo5akWodQ8dXT/ 37gWBikKIaA0vvSwty2xeOdGWedCHtXRytndSxWtvyOvcP1AaSlwvUWzf9BmmvXTON 5y6AL51YY58Ifi4/uff7DPueXia5BNnDWXQTSO0w= From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Yongqiang Sun , Tony Cheng , Rodrigo Siqueira , Alex Deucher , Sasha Levin , amd-gfx@lists.freedesktop.org, dri-devel@lists.freedesktop.org Subject: [PATCH AUTOSEL 4.19 40/47] drm/amd/display: Not doing optimize bandwidth if flip pending. Date: Sat, 18 Apr 2020 10:42:20 -0400 Message-Id: <20200418144227.9802-40-sashal@kernel.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200418144227.9802-1-sashal@kernel.org> References: <20200418144227.9802-1-sashal@kernel.org> MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Yongqiang Sun [ Upstream commit 9941b8129030c9202aaf39114477a0e58c0d6ffc ] [Why] In some scenario like 1366x768 VSR enabled connected with a 4K monitor and playing 4K video in clone mode, underflow will be observed due to decrease dppclk when previouse surface scan isn't finished [How] In this use case, surface flip is switching between 4K and 1366x768, 1366x768 needs smaller dppclk, and when decrease the clk and previous surface scan is for 4K and scan isn't done, underflow will happen. Not doing optimize bandwidth in case of flip pending. Signed-off-by: Yongqiang Sun Reviewed-by: Tony Cheng Acked-by: Rodrigo Siqueira Signed-off-by: Alex Deucher Signed-off-by: Sasha Levin --- drivers/gpu/drm/amd/display/dc/core/dc.c | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) diff --git a/drivers/gpu/drm/amd/display/dc/core/dc.c b/drivers/gpu/drm/amd/display/dc/core/dc.c index 2b2efe443c36d..b64ad9e1f0c38 100644 --- a/drivers/gpu/drm/amd/display/dc/core/dc.c +++ b/drivers/gpu/drm/amd/display/dc/core/dc.c @@ -996,6 +996,26 @@ bool dc_commit_state(struct dc *dc, struct dc_state *context) return (result == DC_OK); } +static bool is_flip_pending_in_pipes(struct dc *dc, struct dc_state *context) +{ + int i; + struct pipe_ctx *pipe; + + for (i = 0; i < MAX_PIPES; i++) { + pipe = &context->res_ctx.pipe_ctx[i]; + + if (!pipe->plane_state) + continue; + + /* Must set to false to start with, due to OR in update function */ + pipe->plane_state->status.is_flip_pending = false; + dc->hwss.update_pending_status(pipe); + if (pipe->plane_state->status.is_flip_pending) + return true; + } + return false; +} + bool dc_post_update_surfaces_to_stream(struct dc *dc) { int i; @@ -1003,6 +1023,9 @@ bool dc_post_update_surfaces_to_stream(struct dc *dc) post_surface_trace(dc); + if (is_flip_pending_in_pipes(dc, context)) + return true; + for (i = 0; i < dc->res_pool->pipe_count; i++) if (context->res_ctx.pipe_ctx[i].stream == NULL || context->res_ctx.pipe_ctx[i].plane_state == NULL) { -- 2.20.1