Received: by 2002:a05:6a10:c7c6:0:0:0:0 with SMTP id h6csp3133882pxy; Wed, 4 Aug 2021 03:14:22 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwO00CB9LelMYKoDBMtSD41hI6V+6fCH7gGyGZAYypYwH9wyz6eu92VTsrSPK/KD0deBo03 X-Received: by 2002:a50:85c2:: with SMTP id q2mr9668808edh.157.1628072062728; Wed, 04 Aug 2021 03:14:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1628072062; cv=none; d=google.com; s=arc-20160816; b=ZqA2mz8+3koBN80DH/VV/nJ8MzPaXqrWhhZbBbdSk0Smwe/eirIcwm09KcO8U6u+Z0 N/GdnXBveRX29GutJRy7SK+zejKHg1k1x5hCuLKdPmkU5BKW+3Dbg55An6A4IR0YAJjB DWjRf9X502cjrVd6w0+L1zrN5drRmx+G1HlhJl3nA8O+JK7w8R8nq7rFy9OGD2m6b18p mte5RgcJlCvP41Y1y/v8hvvQEhbfsMyvCa58NBXG45cFya8OyagniUbqJ/2M5IwZYBMT Alo6t9Y0Pwsx5OuvE9u8nwevxtl1oOHCpB5MD+E/w/hxbDdMbE2VwguWViElLRi4yeo7 owSA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:message-id:date:subject:cc:to:from; bh=gNpwFfSX2t5War4nSh/qkqJSxPfhpjGjg5YhuPlu9P4=; b=kS3p1wmmxNBvNxX7D7iYcna8KCOVleSOWmWBtbp1a2MBgOykd0Ga1WtqSJr2Djhkb5 S4XINrN9bQFqvRiJT3vLNBgCx7gi2KCc89kjpUdgglBeiM/a9dWPN7nrSee8R1kjdyMX w/fGDVBlfcRZtvR79CIUHabdCx2E0DTGrY/lXKkpPgjsfnd2zhmaGx0S+qMmhlXxASiH zB8mipY+4ri5BbtWkp4vfUkmZLYs5iY+M+11YkduHser0RC0rbJQEyexe80ikfRkrWii R5Qfyt1azke9S1/M7Ik92LS6OZGFAjasZISbcOIDRKgOsoLdqbKM0JyCJO3ysgREmOWX /bOQ== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id w7si1694887eds.182.2021.08.04.03.13.59; Wed, 04 Aug 2021 03:14:22 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236534AbhHDJlX (ORCPT + 99 others); Wed, 4 Aug 2021 05:41:23 -0400 Received: from alexa-out.qualcomm.com ([129.46.98.28]:10843 "EHLO alexa-out.qualcomm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236511AbhHDJlW (ORCPT ); Wed, 4 Aug 2021 05:41:22 -0400 Received: from ironmsg07-lv.qualcomm.com ([10.47.202.151]) by alexa-out.qualcomm.com with ESMTP; 04 Aug 2021 02:41:10 -0700 X-QCInternal: smtphost Received: from ironmsg02-blr.qualcomm.com ([10.86.208.131]) by ironmsg07-lv.qualcomm.com with ESMTP/TLS/AES256-SHA; 04 Aug 2021 02:41:08 -0700 X-QCInternal: smtphost Received: from kalyant-linux.qualcomm.com ([10.204.66.210]) by ironmsg02-blr.qualcomm.com with ESMTP; 04 Aug 2021 15:10:31 +0530 Received: by kalyant-linux.qualcomm.com (Postfix, from userid 94428) id 244B54C65; Wed, 4 Aug 2021 02:40:30 -0700 (PDT) From: Kalyan Thota To: dri-devel@lists.freedesktop.org, linux-arm-msm@vger.kernel.org, freedreno@lists.freedesktop.org, devicetree@vger.kernel.org Cc: Kalyan Thota , linux-kernel@vger.kernel.org, robdclark@gmail.com, dianders@chromium.org, mkrishn@codeaurora.org, saiprakash.ranjan@codeaurora.org, rnayak@codeaurora.org, stable@vger.kernel.org Subject: [Resend v3] drm/msm/disp/dpu1: add safe lut config in dpu driver Date: Wed, 4 Aug 2021 02:40:28 -0700 Message-Id: <1628070028-2616-1-git-send-email-kalyan_t@codeaurora.org> X-Mailer: git-send-email 2.7.4 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Add safe lut configuration for all the targets in dpu driver as per QOS recommendation. Issue reported on SC7280: With wait-for-safe feature in smmu enabled, RT client buffer levels are checked to be safe before smmu invalidation. Since display was always set to unsafe it was delaying the invalidaiton process thus impacting the performance on NRT clients such as eMMC and NVMe. Validated this change on SC7280, With this change eMMC performance has improved significantly. Changes in v2: - Add fixes tag (Sai) - CC stable kernel (Dimtry) Changes in v3: - Correct fixes tag with appropriate hash (stephen) - Resend patch adding reviewed by tag - Resend patch adding correct format for pushing into stable tree (Greg) Fixes: 591e34a091d1 ("drm/msm/disp/dpu1: add support for display for SC7280 target") Cc: stable@vger.kernel.org Signed-off-by: Kalyan Thota Reviewed-by: Dmitry Baryshkov Tested-by: Sai Prakash Ranjan (sc7280, sc7180) --- drivers/gpu/drm/msm/disp/dpu1/dpu_hw_catalog.c | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/drivers/gpu/drm/msm/disp/dpu1/dpu_hw_catalog.c b/drivers/gpu/drm/msm/disp/dpu1/dpu_hw_catalog.c index d01c4c9..2e482cd 100644 --- a/drivers/gpu/drm/msm/disp/dpu1/dpu_hw_catalog.c +++ b/drivers/gpu/drm/msm/disp/dpu1/dpu_hw_catalog.c @@ -974,6 +974,7 @@ static const struct dpu_perf_cfg sdm845_perf_data = { .amortizable_threshold = 25, .min_prefill_lines = 24, .danger_lut_tbl = {0xf, 0xffff, 0x0}, + .safe_lut_tbl = {0xfff0, 0xf000, 0xffff}, .qos_lut_tbl = { {.nentry = ARRAY_SIZE(sdm845_qos_linear), .entries = sdm845_qos_linear @@ -1001,6 +1002,7 @@ static const struct dpu_perf_cfg sc7180_perf_data = { .min_dram_ib = 1600000, .min_prefill_lines = 24, .danger_lut_tbl = {0xff, 0xffff, 0x0}, + .safe_lut_tbl = {0xfff0, 0xff00, 0xffff}, .qos_lut_tbl = { {.nentry = ARRAY_SIZE(sc7180_qos_linear), .entries = sc7180_qos_linear @@ -1028,6 +1030,7 @@ static const struct dpu_perf_cfg sm8150_perf_data = { .min_dram_ib = 800000, .min_prefill_lines = 24, .danger_lut_tbl = {0xf, 0xffff, 0x0}, + .safe_lut_tbl = {0xfff8, 0xf000, 0xffff}, .qos_lut_tbl = { {.nentry = ARRAY_SIZE(sm8150_qos_linear), .entries = sm8150_qos_linear @@ -1056,6 +1059,7 @@ static const struct dpu_perf_cfg sm8250_perf_data = { .min_dram_ib = 800000, .min_prefill_lines = 35, .danger_lut_tbl = {0xf, 0xffff, 0x0}, + .safe_lut_tbl = {0xfff0, 0xff00, 0xffff}, .qos_lut_tbl = { {.nentry = ARRAY_SIZE(sc7180_qos_linear), .entries = sc7180_qos_linear @@ -1084,6 +1088,7 @@ static const struct dpu_perf_cfg sc7280_perf_data = { .min_dram_ib = 1600000, .min_prefill_lines = 24, .danger_lut_tbl = {0xffff, 0xffff, 0x0}, + .safe_lut_tbl = {0xff00, 0xff00, 0xffff}, .qos_lut_tbl = { {.nentry = ARRAY_SIZE(sc7180_qos_macrotile), .entries = sc7180_qos_macrotile -- 2.7.4