Received: by 2002:a05:6358:111d:b0:dc:6189:e246 with SMTP id f29csp2569912rwi; Tue, 1 Nov 2022 09:08:57 -0700 (PDT) X-Google-Smtp-Source: AMsMyM6tXewZ/ajGRtR0reyWqgbdPguOzF5wtv/dzLY00fKyUFB9Oa1IIPy1o8j/+KThNoK9pLhw X-Received: by 2002:a17:906:9750:b0:798:9ccc:845d with SMTP id o16-20020a170906975000b007989ccc845dmr19351734ejy.760.1667318937660; Tue, 01 Nov 2022 09:08:57 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1667318937; cv=none; d=google.com; s=arc-20160816; b=T1AbIoVcWd8uLotog76W4o+7DdT3kHp2E6j9y2/trwGoWXRajroWPAC7K2cWcn2Whp xNSr1bTSCUegy2uB8wR+0kmVFbENaCV/qm8fUmKuv8mAy69+j+k93r/HXrYqpIsV7hcr bDAYsVdxfqJPXrFvyGWX7NgeGWXPOAqba7ec3bQtQJs4FwWkMwKsNVIMvX/LUdjUBFOy +zwIYHbA6LWEw0nV+zv4ERjlA4Y+APOMBoy2e+MlKjRL55UQqVqPkcOl3KfN2yOvKWb8 US+JB9QENHtsezjdBWxGBSYnT9s5ByABjZr/8aQB2ldg2YHPxdlYlWDMoQ3afuYtKUVl bsAQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-transfer-encoding :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=AhuhHf4zrmixzZAsBr9hEqobQ8VFY76RJTWzb1GkiwM=; b=YOLWq8ChCk5hNMmQ6MNcShrjZJqimTSA+P/0BW6frhjg+nLn2yjBN1Hvi8ttMl5pL/ K5cTIii3Z5sXuKVacVNcWp5UiAGKATyXc5kCJoxd9G8kbRmwixs7Mqj/AY419T1vjRZj 8wALrRqREvjLHnaWgZPSHSldXLmC7ABAR2mZNYXkSiDd5XctZ4tUFnKYX29jhqfMIi7O j243d+HMrTR+YWzjN6b5pVAZW2nL6TVvRNE9jb+jQz3w1a/MebKxsCtCSKvAfm8wvIO9 jpJYBw5Vd7ikovaBJot+tiF2VjVyYM3VggO1SxmhvlFUWS8CQBQr8A0+P/2S6aLVe8lW fJtw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@moc6.cz header.s=mail20201116 header.b=a8y3ZxAJ; 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=moc6.cz Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id s4-20020a17090699c400b0078d4cf8de04si12100218ejn.380.2022.11.01.09.08.33; Tue, 01 Nov 2022 09:08:57 -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=@moc6.cz header.s=mail20201116 header.b=a8y3ZxAJ; 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=moc6.cz Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230047AbiKAPdp (ORCPT + 96 others); Tue, 1 Nov 2022 11:33:45 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53378 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229783AbiKAPdo (ORCPT ); Tue, 1 Nov 2022 11:33:44 -0400 Received: from moc6.cz (hosting.moc6.cz [IPv6:2a02:c60:c70:8900::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id D5C1F9FF0 for ; Tue, 1 Nov 2022 08:33:41 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=moc6.cz; s=mail20201116; h=In-Reply-To:Message-ID:Subject:Cc:To:From:Date:Reply-To; bh=AhuhHf4zrmixzZAsBr9hEqobQ8VFY76RJTWzb1GkiwM=; b=a8y3ZxAJ34Cjdz4lY470TFaRM/ 5pGFbNZYNIt2/11DbUly3NPCXhb5IaujoU3Ssw2L8l9zsD+iWX99ABryWslyhfcGT3T7E5SbWE9Z3 wuFuuw366n13JWTRrZNMcM8TC8ShLYnAX/LldxdfImd54g8W8MeC/+Oy1JN7Qi+XxZlC/QiWtJKC6 o4WM2vCEsyXoxeanS77p3+avECxhDItMV18HXd/uqlCfXB16b6MYPtzOEXarMO/CjpuLluojPjZaJ Ms+uXYMTuIuoAjcY8G+bSUz/xQ60P4wzZZMSPAh8W7ZBcARrdDWwNSSwgrFFeAHSvBP5uH6QRYIjC LjnuUKXoaDdp+WCn4wqRvU93O8lz2EUTu++CIorfe/4geyuEiBs1tc66Zq+sA9JJ0+XqqxEsxyr6C eWoC4g/m9zIRNBwI8JaIKvnT+lYyZz0sUX//karmRyGvJG70g/hxxY5r1tSGigItr8IooEUJ9UtnC +xzGE1+sM4PwME18HXl6M/Yz0cJBcrbjq6bnunvCGsmbT/SBwM0XzFrbhT2hFLK+QrsQLbHvBpVDT hJSCGjPXFwDtBTRg+i458yEw3pQ3a9cbS62SczbYznE/6woBO/+VHHQx7giPmT84ZvO7bSGvvYiRo vY91Z4rMvmGtaiMew/Ggf2qeiDhr9f4999EepaRNQ=; Received: from Debian-exim by moc6.cz with local (Exim 4.94.2) (envelope-from ) authenticated: Debian-exim id 1optGc-00117m-QO; Tue, 01 Nov 2022 16:33:30 +0100 Date: Tue, 1 Nov 2022 16:33:30 +0100 From: Filip Moc To: Harry Wentland Cc: Leo Li , Rodrigo Siqueira , Alex Deucher , Christian =?iso-8859-1?Q?K=F6nig?= , "Pan, Xinhui" , David Airlie , Daniel Vetter , amd-gfx@lists.freedesktop.org, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] drm/amd/display: add parameter backlight_min Message-ID: References: <23cd28ea-59ed-7687-0912-506356b4b24d@amd.com> MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <23cd28ea-59ed-7687-0912-506356b4b24d@amd.com> X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,SPF_HELO_PASS,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 Hello Harry, thank you for your response. > amdgpu.backlight_min=2:-1 almost :-) Array elements in module parameters are separated by commas not colons. So for cmdline it should look like this: amdgpu.backlight_min=2,-1 Though you can just drop the ,-1 relying on kernel leaving the rest of array untouched. Which I would recommend as there is no point for user to follow AMDGPU_DM_MAX_NUM_EDP. Only when you need to override some other display than display 0 then you may need to use -1. E.g. backlight_min=-1,2 overrides display 1 to min backlight=2 while keeping display 0 with no override. When amdgpu is loaded as a kernel module, backlight_min can also be passed as a parameter to modprobe, e.g.: modprobe backlight_min=2 So in that case you probably want to add something like options amdgpu backlight_min=2 to /etc/modprobe.d/amdgpu.conf (and also run update-initramfs if amdgpu is loaded by initramfs). I'll add some examples to commit message in v2. Filip V?Mon, Oct 31, 2022 at 10:24:25AM -0400,?Harry Wentland napsal(a): > On 2022-10-29 15:13, Filip Moc wrote: > > There are some devices on which amdgpu won't allow user to set brightness > > to sufficiently low values even though the hardware would support it just > > fine. > > > > This usually happens in two cases when either configuration of brightness > > levels via ACPI/ATIF is not available and amdgpu falls back to defaults > > (currently 12 for minimum level) which may be too high for some devices or > > even the configuration via ATIF is available but the minimum brightness > > level provided by the manufacturer is set to unreasonably high value. > > > > In either case user can use this new module parameter to adjust the > > minimum allowed backlight brightness level. > > > > Thanks for this patch and covering all the bases. > > It might be useful to have an example in the commit description on > how to set the array property. I assume it looks like this if I > wanted to set the first device to a minimum of 2 and leave the default > for the 2nd one: > > amdgpu.backlight_min=2:-1 > > Either way, this patch is > Reviewed-by: Harry Wentland > > Harry > > > Link: https://bugzilla.kernel.org/show_bug.cgi?id=203439>> > > Signed-off-by: Filip Moc > > --- > > drivers/gpu/drm/amd/amdgpu/amdgpu.h | 3 +++ > > drivers/gpu/drm/amd/amdgpu/amdgpu_drv.c | 15 +++++++++++++++ > > drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c | 15 +++++++++++++++ > > 3 files changed, 33 insertions(+) > > > > diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu.h b/drivers/gpu/drm/amd/amdgpu/amdgpu.h > > index 0e6ddf05c23c..c5445402c49d 100644 > > --- a/drivers/gpu/drm/amd/amdgpu/amdgpu.h > > +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu.h > > @@ -200,6 +200,9 @@ extern uint amdgpu_dc_debug_mask; > > extern uint amdgpu_dc_visual_confirm; > > extern uint amdgpu_dm_abm_level; > > extern int amdgpu_backlight; > > +#ifdef CONFIG_DRM_AMD_DC > > +extern int amdgpu_backlight_override_min[]; > > +#endif > > extern struct amdgpu_mgpu_info mgpu_info; > > extern int amdgpu_ras_enable; > > extern uint amdgpu_ras_mask; > > diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_drv.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_drv.c > > index 16f6a313335e..f2fb549ac52f 100644 > > --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_drv.c > > +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_drv.c > > @@ -43,6 +43,7 @@ > > #include "amdgpu_irq.h" > > #include "amdgpu_dma_buf.h" > > #include "amdgpu_sched.h" > > +#include "amdgpu_dm.h" > > #include "amdgpu_fdinfo.h" > > #include "amdgpu_amdkfd.h" > > > > @@ -853,6 +854,20 @@ int amdgpu_backlight = -1; > > MODULE_PARM_DESC(backlight, "Backlight control (0 = pwm, 1 = aux, -1 auto (default))"); > > module_param_named(backlight, amdgpu_backlight, bint, 0444); > > > > +/** > > + * DOC: backlight_min (array of int) > > + * Override minimum allowed backlight brightness signal (per display). > > + * Must be less than the maximum brightness signal. > > + * Negative value means no override. > > + * > > + * Defaults to all -1 (no override on any display). > > + */ > > +#ifdef CONFIG_DRM_AMD_DC > > +int amdgpu_backlight_override_min[AMDGPU_DM_MAX_NUM_EDP] = {[0 ... (AMDGPU_DM_MAX_NUM_EDP-1)] = -1}; > > +MODULE_PARM_DESC(backlight_min, "Override minimum backlight brightness signal (0..max-1, -1 = no override (default))"); > > +module_param_array_named(backlight_min, amdgpu_backlight_override_min, int, NULL, 0444); > > +#endif > > + > > /** > > * DOC: tmz (int) > > * Trusted Memory Zone (TMZ) is a method to protect data being written > > 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 eb4ce7216104..e2c36ba93d05 100644 > > --- a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c > > +++ b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c > > @@ -3911,6 +3911,21 @@ static void amdgpu_dm_update_backlight_caps(struct amdgpu_display_manager *dm, > > dm->backlight_caps[bl_idx].min_input_signal = AMDGPU_DM_DEFAULT_MIN_BACKLIGHT; > > dm->backlight_caps[bl_idx].max_input_signal = AMDGPU_DM_DEFAULT_MAX_BACKLIGHT; > > #endif > > + > > + if (amdgpu_backlight_override_min[bl_idx] >= 0) { > > + if (amdgpu_backlight_override_min[bl_idx] < dm->backlight_caps[bl_idx].max_input_signal) { > > + DRM_INFO("amdgpu: backlight[%i]: overriding minimum brightness from %i to %i\n", > > + bl_idx, > > + dm->backlight_caps[bl_idx].min_input_signal, > > + amdgpu_backlight_override_min[bl_idx]); > > + dm->backlight_caps[bl_idx].min_input_signal = amdgpu_backlight_override_min[bl_idx]; > > + } else { > > + DRM_ERROR("amdgpu: backlight[%i]: minimum brightness override (%i) is not below maximum (%i)\n", > > + bl_idx, > > + amdgpu_backlight_override_min[bl_idx], > > + dm->backlight_caps[bl_idx].max_input_signal); > > + } > > + } > > } > > > > static int get_brightness_range(const struct amdgpu_dm_backlight_caps *caps, > > > > base-commit: d8c03bfe146fd5e081a252cd34f3f12ca0255357 >