Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp1759240ybz; Sat, 18 Apr 2020 07:55:15 -0700 (PDT) X-Google-Smtp-Source: APiQypKwIjPbl/+4TYJPOzK37F7CFkfI3Z3o4YUTuZmVocyiqQLeMfYhOV5PVxnR/p0dl+DSFi4U X-Received: by 2002:a17:906:8549:: with SMTP id h9mr7803510ejy.145.1587221715719; Sat, 18 Apr 2020 07:55:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587221715; cv=none; d=google.com; s=arc-20160816; b=v/lj7ZhBYDD4amdXPrjoumDtN5zMQcgrY4JrFNZ+OUt163jajlOEXSPVYOp/YLR0JV p8/DIQL5bZ1kZC3UMho93icW4Kn6XzghHF+MfY9hyd6r7MDHh7pkOVqvPBh0u1dzpFo1 9fptXuWKK45+ceD0gWJ0nyjrHexwqEt5WelZMyrxjqcf5aAjdVc5sPvCuSZwPm8Yp+yI E52ArbSmcQ8Ube2YBJJuQU4ZYJ/YAi1bJIV8097L62JoAf/X7naIG1lbRg7w822iEij+ owRh4KkVELqGzEIUtnybBztQBG1t0LeBoaxW4ywsCIam1IZZd00DJLK2zPdsinzcPfAb PDYQ== 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=s0Qr1hFca83b7SNl/93ojGBK7Ram0hdHNq4bwvuX0G4=; b=QuHIpesImsk5ctgBII+o1i5oc4Dx7vE0FsAPrGrsz9y/YMkq/FBIkLZd9B5fhI1yzV Ha0tnetwirDpjgojPf+mYSrKglL93Iv136nrbtw5sN2VYWng2KrDIpZvKhXnrW3rMwLH TyJT2gs0VHUEoEwgz549P9bb2CgwCI6TnQq161lsVSk+xFchbV6KvK/HWOfvbzCGdUiC ehx71XxCmdd/uGxplNEy5ppELYXcJFEl45HNSEIZnmKl4w1E/HZURt3beWJD/W59uGnF bUY3HbWF7b83+bOfbN1SuY1iMp8HYR8kqT/CkRS6sBG7f6qahOP4iIPoQHWHRZHYaIsS VhGQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=pD5m0saz; 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 p3si2514088edm.574.2020.04.18.07.54.53; Sat, 18 Apr 2020 07:55:15 -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=pD5m0saz; 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 S1729095AbgDROwz (ORCPT + 99 others); Sat, 18 Apr 2020 10:52:55 -0400 Received: from mail.kernel.org ([198.145.29.99]:51914 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728250AbgDROmH (ORCPT ); Sat, 18 Apr 2020 10:42:07 -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 3A95222244; Sat, 18 Apr 2020 14:42:06 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1587220927; bh=5rg1mbDvVPgqk2qdN1TJwA1lpQ8pvGe+EL4GcEoRhmI=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=pD5m0sazOQZ2VF9jw75mDsKVphLY9+j2GaPBmYyywrRntcPkgdqZ2XSaimgSbMlXl 9mANJnGPolv7PkFM3An+iJ+QauBkpl5Rmn1Xe0V+FvyE/qbSca0PjHeQGuYT7LqbMv OkYF0mbs7CJCq4vfrXumXWBbxu8h58I98Z6D9UTs= 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 5.4 64/78] drm/amd/display: Not doing optimize bandwidth if flip pending. Date: Sat, 18 Apr 2020 10:40:33 -0400 Message-Id: <20200418144047.9013-64-sashal@kernel.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200418144047.9013-1-sashal@kernel.org> References: <20200418144047.9013-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 71c574d1e8be2..2028dc017f7a0 100644 --- a/drivers/gpu/drm/amd/display/dc/core/dc.c +++ b/drivers/gpu/drm/amd/display/dc/core/dc.c @@ -1182,6 +1182,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; @@ -1192,6 +1212,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