Skip to content

Commit 04ccb89

Browse files
committed
Merge branch 'drm-fixes-4.3' of git://people.freedesktop.org/~agd5f/linux into drm-fixes
regression fix for backlight on old laptops. * 'drm-fixes-4.3' of git://people.freedesktop.org/~agd5f/linux: drm/radeon: fix dpms when driver backlight control is disabled drm/radeon: move bl encoder assignment into bl init
2 parents 8a28d67 + ae93580 commit 04ccb89

File tree

3 files changed

+16
-5
lines changed

3 files changed

+16
-5
lines changed

drivers/gpu/drm/radeon/atombios_encoders.c

Lines changed: 15 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -237,6 +237,7 @@ void radeon_atom_backlight_init(struct radeon_encoder *radeon_encoder,
237237
backlight_update_status(bd);
238238

239239
DRM_INFO("radeon atom DIG backlight initialized\n");
240+
rdev->mode_info.bl_encoder = radeon_encoder;
240241

241242
return;
242243

@@ -1624,9 +1625,14 @@ radeon_atom_encoder_dpms_avivo(struct drm_encoder *encoder, int mode)
16241625
} else
16251626
atom_execute_table(rdev->mode_info.atom_context, index, (uint32_t *)&args);
16261627
if (radeon_encoder->devices & (ATOM_DEVICE_LCD_SUPPORT)) {
1627-
struct radeon_encoder_atom_dig *dig = radeon_encoder->enc_priv;
1628+
if (rdev->mode_info.bl_encoder) {
1629+
struct radeon_encoder_atom_dig *dig = radeon_encoder->enc_priv;
16281630

1629-
atombios_set_backlight_level(radeon_encoder, dig->backlight_level);
1631+
atombios_set_backlight_level(radeon_encoder, dig->backlight_level);
1632+
} else {
1633+
args.ucAction = ATOM_LCD_BLON;
1634+
atom_execute_table(rdev->mode_info.atom_context, index, (uint32_t *)&args);
1635+
}
16301636
}
16311637
break;
16321638
case DRM_MODE_DPMS_STANDBY:
@@ -1706,8 +1712,13 @@ radeon_atom_encoder_dpms_dig(struct drm_encoder *encoder, int mode)
17061712
if (ASIC_IS_DCE4(rdev))
17071713
atombios_dig_encoder_setup(encoder, ATOM_ENCODER_CMD_DP_VIDEO_ON, 0);
17081714
}
1709-
if (radeon_encoder->devices & (ATOM_DEVICE_LCD_SUPPORT))
1710-
atombios_set_backlight_level(radeon_encoder, dig->backlight_level);
1715+
if (radeon_encoder->devices & (ATOM_DEVICE_LCD_SUPPORT)) {
1716+
if (rdev->mode_info.bl_encoder)
1717+
atombios_set_backlight_level(radeon_encoder, dig->backlight_level);
1718+
else
1719+
atombios_dig_transmitter_setup(encoder,
1720+
ATOM_TRANSMITTER_ACTION_LCD_BLON, 0, 0);
1721+
}
17111722
if (ext_encoder)
17121723
atombios_external_encoder_setup(encoder, ext_encoder, ATOM_ENABLE);
17131724
break;

drivers/gpu/drm/radeon/radeon_encoders.c

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -194,7 +194,6 @@ static void radeon_encoder_add_backlight(struct radeon_encoder *radeon_encoder,
194194
radeon_atom_backlight_init(radeon_encoder, connector);
195195
else
196196
radeon_legacy_backlight_init(radeon_encoder, connector);
197-
rdev->mode_info.bl_encoder = radeon_encoder;
198197
}
199198
}
200199

drivers/gpu/drm/radeon/radeon_legacy_encoders.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -441,6 +441,7 @@ void radeon_legacy_backlight_init(struct radeon_encoder *radeon_encoder,
441441
backlight_update_status(bd);
442442

443443
DRM_INFO("radeon legacy LVDS backlight initialized\n");
444+
rdev->mode_info.bl_encoder = radeon_encoder;
444445

445446
return;
446447

0 commit comments

Comments
 (0)