On 6/23/25 2:13 PM, Rodrigo Siqueira wrote: > On 06/23, Werner Sembach wrote: >> gentle bump >> >> Am 09.04.25 um 18:27 schrieb Werner Sembach: >>> The display backlight on TUXEDO Polaris AMD Gen2 and Gen3 with panels >>> BOE 2420 and BOE 2423 must be forced to pwn controlled to be able to >>> control the brightness. >>> >>> This could already be archived via a module parameter, but this patch adds >>> a quirk to apply this by default on the mentioned device + panel >>> combinations. >>> >>> Signed-off-by: Werner Sembach <w...@tuxedocomputers.com> >>> Cc: sta...@vger.kernel.org >>> --- >>> .../gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c | 32 ++++++++++++++++++- >>> 1 file changed, 31 insertions(+), 1 deletion(-) >>> >>> 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 39df45f652b32..2bad6274ad8ff 100644 >>> --- a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c >>> +++ b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c >>> @@ -1625,11 +1625,13 @@ static bool dm_should_disable_stutter(struct >>> pci_dev *pdev) >>> struct amdgpu_dm_quirks { >>> bool aux_hpd_discon; >>> bool support_edp0_on_dp1; >>> + bool boe_2420_2423_bl_force_pwm; >>> }; >>> static struct amdgpu_dm_quirks quirk_entries = { >>> .aux_hpd_discon = false, >>> - .support_edp0_on_dp1 = false >>> + .support_edp0_on_dp1 = false, >>> + .boe_2420_2423_bl_force_pwm = false >>> }; >>> static int edp0_on_dp1_callback(const struct dmi_system_id *id) >>> @@ -1644,6 +1646,12 @@ static int aux_hpd_discon_callback(const struct >>> dmi_system_id *id) >>> return 0; >>> } >>> +static int boe_2420_2423_bl_force_pwm_callback(const struct dmi_system_id >>> *id) >>> +{ >>> + quirk_entries.boe_2420_2423_bl_force_pwm = true; >>> + return 0; >>> +} >>> + >>> static const struct dmi_system_id dmi_quirk_table[] = { >>> { >>> .callback = aux_hpd_discon_callback, >>> @@ -1722,6 +1730,20 @@ static const struct dmi_system_id dmi_quirk_table[] >>> = { >>> DMI_MATCH(DMI_PRODUCT_NAME, "HP EliteBook 665 16 inch >>> G11 Notebook PC"), >>> }, >>> }, >>> + { >>> + // TUXEDO Polaris AMD Gen2 >>> + .callback = boe_2420_2423_bl_force_pwm_callback, >>> + .matches = { >>> + DMI_MATCH(DMI_BOARD_NAME, "GMxNGxx"), >>> + }, >>> + }, >>> + { >>> + // TUXEDO Polaris AMD Gen3 >>> + .callback = boe_2420_2423_bl_force_pwm_callback, >>> + .matches = { >>> + DMI_MATCH(DMI_BOARD_NAME, "GMxZGxx"), >>> + }, >>> + }, >>> {} >>> /* TODO: refactor this from a fixed table to a dynamic option */ >>> }; >>> @@ -3586,6 +3608,7 @@ static void update_connector_ext_caps(struct >>> amdgpu_dm_connector *aconnector) >>> struct amdgpu_device *adev; >>> struct drm_luminance_range_info *luminance_range; >>> int min_input_signal_override; >>> + u32 panel; >>> if (aconnector->bl_idx == -1 || >>> aconnector->dc_link->connector_signal != SIGNAL_TYPE_EDP) >>> @@ -3610,6 +3633,13 @@ static void update_connector_ext_caps(struct >>> amdgpu_dm_connector *aconnector) >>> caps->aux_support = false; >>> else if (amdgpu_backlight == 1) >>> caps->aux_support = true; >>> + else if (amdgpu_backlight == -1 && >>> + quirk_entries.boe_2420_2423_bl_force_pwm) { >>> + panel = drm_edid_get_panel_id(aconnector->drm_edid); >>> + if (panel == drm_edid_encode_panel_id('B', 'O', 'E', 0x0974) || >>> + panel == drm_edid_encode_panel_id('B', 'O', 'E', 0x0977)) >>> + caps->aux_support = false; >>> + } > > It lgtm, > > Additionally, I believe this is safe to merge since it only affects a > specific device. Perhaps display folks would like to include this as > part of this week's promotion? Anyway, Cc other devs from the display. > > Reviewed-by: Rodrigo Siqueira <sique...@igalia.com>
That's a bit odd that aux based B/L control wouldn't work. Are these both OLED panels? What debugging have you done thus far with them? What kernel base? Could you repro on 6.16-rc3? > >>> if (caps->aux_support) >>> aconnector->dc_link->backlight_control_type = >>> BACKLIGHT_CONTROL_AMD_AUX; >