summarylogtreecommitdiffstats
diff options
context:
space:
mode:
authorMike Yuan2020-08-06 23:51:49 +0800
committerMike Yuan2020-08-23 11:03:08 +0800
commit7312bf172a646c5d4f5d6dcf8b749bef5cab6af6 (patch)
treec7ee8e360954fec6bdabbddf133002cbbf6b2b8b
parent4f630e7af9137edb318a0d7e8c854d315f96547c (diff)
downloadaur-7312bf172a646c5d4f5d6dcf8b749bef5cab6af6.tar.gz
Add patch for AMDGPU backlight
-rw-r--r--PKGBUILD4
-rw-r--r--amdgpu-backlight.patch191
2 files changed, 194 insertions, 1 deletions
diff --git a/PKGBUILD b/PKGBUILD
index b847c13e62fc..1284c7617efd 100644
--- a/PKGBUILD
+++ b/PKGBUILD
@@ -3,7 +3,7 @@
pkgbase=linux-zen-g14
_pkgbase=linux-zen
pkgver=5.8.zen1
-pkgrel=2
+pkgrel=3
pkgdesc='Linux ZEN with patch for Zephyrus G14 (GA401IV)'
_srctag=v${pkgver%.*}-${pkgver##*.}
url="https://github.com/zen-kernel/zen-kernel/commits/$_srctag"
@@ -22,6 +22,7 @@ source=(
i8042.patch
asus-nb-wmi.patch
asus-n-key-keyboard.patch
+ amdgpu-backlight.patch
"https://github.com/dolohow/uksm/raw/master/v5.x/uksm-5.8.patch"
)
validpgpkeys=(
@@ -34,6 +35,7 @@ sha256sums=('SKIP'
'2273fae30f712aa554dd10294a072b4934265b56e6146493a07c22c7df4af61d'
'ac8d8a0d54ad79e44f25b255bfecc80d190502e1173df18b091f53e9882d4ac8'
'fdea6ab1672ea4758359e9c6e743aba56f33224c5d759852817a01af5974fd4b'
+ '7573ea16b7a54aba6b7b160051c1efa4fc3471c341a27bcfcc60e0ba832e409d'
'0389c65d8357f8b22f65aceaf9ceda5a3c76e60ca34f713ff9a09ec379f51dc7')
export KBUILD_BUILD_HOST=archlinux
diff --git a/amdgpu-backlight.patch b/amdgpu-backlight.patch
new file mode 100644
index 000000000000..6de8bf118240
--- /dev/null
+++ b/amdgpu-backlight.patch
@@ -0,0 +1,191 @@
+From mboxrd@z Thu Jan 1 00:00:00 1970
+Return-Path: <SRS0=pusq=BO=vger.kernel.org=linux-kernel-owner@kernel.org>
+X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on
+ aws-us-west-2-korg-lkml-1.web.codeaurora.org
+X-Spam-Level:
+X-Spam-Status: No, score=-13.0 required=3.0 tests=BAYES_00,
+ HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH,MAILING_LIST_MULTI,SIGNED_OFF_BY,
+ SPF_HELO_NONE,SPF_PASS,URIBL_BLOCKED,USER_AGENT_GIT autolearn=ham
+ autolearn_force=no version=3.4.0
+Received: from mail.kernel.org (mail.kernel.org [198.145.29.99])
+ by smtp.lore.kernel.org (Postfix) with ESMTP id C1463C433E0
+ for <linux-kernel@archiver.kernel.org>; Tue, 4 Aug 2020 20:13:34 +0000 (UTC)
+Received: from vger.kernel.org (vger.kernel.org [23.128.96.18])
+ by mail.kernel.org (Postfix) with ESMTP id AE9E6207FC
+ for <linux-kernel@archiver.kernel.org>; Tue, 4 Aug 2020 20:13:34 +0000 (UTC)
+Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand
+ id S1726821AbgHDUNc (ORCPT
+ <rfc822;linux-kernel@archiver.kernel.org>);
+ Tue, 4 Aug 2020 16:13:32 -0400
+Received: from mail.ispras.ru ([83.149.199.84]:51862 "EHLO mail.ispras.ru"
+ rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP
+ id S1725981AbgHDUNc (ORCPT <rfc822;linux-kernel@vger.kernel.org>);
+ Tue, 4 Aug 2020 16:13:32 -0400
+Received: from localhost.localdomain (unknown [46.188.10.168])
+ by mail.ispras.ru (Postfix) with ESMTPSA id ADE5240A2071;
+ Tue, 4 Aug 2020 20:13:28 +0000 (UTC)
+From: Alexander Monakov <amonakov@ispras.ru>
+To: amd-gfx@lists.freedesktop.org
+Cc: linux-kernel@vger.kernel.org,
+ Alexander Monakov <amonakov@ispras.ru>,
+ Alex Deucher <alexander.deucher@amd.com>,
+ Nicholas Kazlauskas <nicholas.kazlauskas@amd.com>
+Subject: [PATCH v2] drm/amd/display: use correct scale for actual_brightness
+Date: Tue, 4 Aug 2020 23:13:13 +0300
+Message-Id: <20200804201313.6464-1-amonakov@ispras.ru>
+X-Mailer: git-send-email 2.26.2
+MIME-Version: 1.0
+Content-Transfer-Encoding: 8bit
+Sender: linux-kernel-owner@vger.kernel.org
+Precedence: bulk
+List-ID: <linux-kernel.vger.kernel.org>
+X-Mailing-List: linux-kernel@vger.kernel.org
+Archived-At: <https://lore.kernel.org/lkml/20200804201313.6464-1-amonakov@ispras.ru/>
+List-Archive: <https://lore.kernel.org/lkml/>
+List-Post: <mailto:linux-kernel@vger.kernel.org>
+
+Documentation for sysfs backlight level interface requires that
+values in both 'brightness' and 'actual_brightness' files are
+interpreted to be in range from 0 to the value given in the
+'max_brightness' file.
+
+With amdgpu, max_brightness gives 255, and values written by the user
+into 'brightness' are internally rescaled to a wider range. However,
+reading from 'actual_brightness' gives the raw register value without
+inverse rescaling. This causes issues for various userspace tools such
+as PowerTop and systemd that expect the value to be in the correct
+range.
+
+Introduce a helper to retrieve internal backlight range. Use it to
+reimplement 'convert_brightness' as 'convert_brightness_from_user' and
+introduce 'convert_brightness_to_user'.
+
+Bug: https://bugzilla.kernel.org/show_bug.cgi?id=203905
+Bug: https://gitlab.freedesktop.org/drm/amd/-/issues/1242
+Cc: Alex Deucher <alexander.deucher@amd.com>
+Cc: Nicholas Kazlauskas <nicholas.kazlauskas@amd.com>
+Signed-off-by: Alexander Monakov <amonakov@ispras.ru>
+---
+v2: split convert_brightness to &_from_user and &_to_user (Nicholas)
+
+ .../gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c | 81 +++++++++----------
+ 1 file changed, 40 insertions(+), 41 deletions(-)
+
+diff --git a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c
+index 710edc70e37e..b60a763f3f95 100644
+--- a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c
++++ b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c
+@@ -2881,51 +2881,50 @@ static int set_backlight_via_aux(struct dc_link *link, uint32_t brightness)
+ return rc ? 0 : 1;
+ }
+
+-static u32 convert_brightness(const struct amdgpu_dm_backlight_caps *caps,
+- const uint32_t user_brightness)
++static int get_brightness_range(const struct amdgpu_dm_backlight_caps *caps,
++ unsigned *min, unsigned *max)
+ {
+- u32 min, max, conversion_pace;
+- u32 brightness = user_brightness;
+-
+ if (!caps)
+- goto out;
++ return 0;
+
+- if (!caps->aux_support) {
+- max = caps->max_input_signal;
+- min = caps->min_input_signal;
+- /*
+- * The brightness input is in the range 0-255
+- * It needs to be rescaled to be between the
+- * requested min and max input signal
+- * It also needs to be scaled up by 0x101 to
+- * match the DC interface which has a range of
+- * 0 to 0xffff
+- */
+- conversion_pace = 0x101;
+- brightness =
+- user_brightness
+- * conversion_pace
+- * (max - min)
+- / AMDGPU_MAX_BL_LEVEL
+- + min * conversion_pace;
++ if (caps->aux_support) {
++ // Firmware limits are in nits, DC API wants millinits.
++ *max = 1000 * caps->aux_max_input_signal;
++ *min = 1000 * caps->aux_min_input_signal;
+ } else {
+- /* TODO
+- * We are doing a linear interpolation here, which is OK but
+- * does not provide the optimal result. We probably want
+- * something close to the Perceptual Quantizer (PQ) curve.
+- */
+- max = caps->aux_max_input_signal;
+- min = caps->aux_min_input_signal;
+-
+- brightness = (AMDGPU_MAX_BL_LEVEL - user_brightness) * min
+- + user_brightness * max;
+- // Multiple the value by 1000 since we use millinits
+- brightness *= 1000;
+- brightness = DIV_ROUND_CLOSEST(brightness, AMDGPU_MAX_BL_LEVEL);
++ // Firmware limits are 8-bit, PWM control is 16-bit.
++ *max = 0x101 * caps->max_input_signal;
++ *min = 0x101 * caps->min_input_signal;
+ }
++ return 1;
++}
+
+-out:
+- return brightness;
++static u32 convert_brightness_from_user(const struct amdgpu_dm_backlight_caps *caps,
++ uint32_t brightness)
++{
++ unsigned min, max;
++
++ if (!get_brightness_range(caps, &min, &max))
++ return brightness;
++
++ // Rescale 0..255 to min..max
++ return min + DIV_ROUND_CLOSEST((max - min) * brightness,
++ AMDGPU_MAX_BL_LEVEL);
++}
++
++static u32 convert_brightness_to_user(const struct amdgpu_dm_backlight_caps *caps,
++ uint32_t brightness)
++{
++ unsigned min, max;
++
++ if (!get_brightness_range(caps, &min, &max))
++ return brightness;
++
++ if (brightness < min)
++ return 0;
++ // Rescale min..max to 0..255
++ return DIV_ROUND_CLOSEST(AMDGPU_MAX_BL_LEVEL * (brightness - min),
++ max - min);
+ }
+
+ static int amdgpu_dm_backlight_update_status(struct backlight_device *bd)
+@@ -2941,7 +2940,7 @@ static int amdgpu_dm_backlight_update_status(struct backlight_device *bd)
+
+ link = (struct dc_link *)dm->backlight_link;
+
+- brightness = convert_brightness(&caps, bd->props.brightness);
++ brightness = convert_brightness_from_user(&caps, bd->props.brightness);
+ // Change brightness based on AUX property
+ if (caps.aux_support)
+ return set_backlight_via_aux(link, brightness);
+@@ -2958,7 +2957,7 @@ static int amdgpu_dm_backlight_get_brightness(struct backlight_device *bd)
+
+ if (ret == DC_ERROR_UNEXPECTED)
+ return bd->props.brightness;
+- return ret;
++ return convert_brightness_to_user(&dm->backlight_caps, ret);
+ }
+
+ static const struct backlight_ops amdgpu_dm_backlight_ops = {
+
+base-commit: bcf876870b95592b52519ed4aafcf9d95999bc9c
+--
+2.26.2
+
+