diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2015-10-31 19:16:51 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2015-10-31 19:16:51 -0400 |
commit | d59ebbf19b29f4964b24f38c3ad876c33cdd7368 (patch) | |
tree | 4b1d76e577989f429e4706db76ce5c600e277b72 | |
parent | 523e13455ec9ec4457a5a1d24ff7132949742b70 (diff) | |
parent | 8731b269f01e16193390c7276e70530366b8d626 (diff) |
Merge branch 'drm-fixes' of git://people.freedesktop.org/~airlied/linux
Pull drm fixes from Dave Airlie:
"Two drm atomic core fixes.
And two radeon patches needed to fix a backlight regression on some
older hardware"
* 'drm-fixes' of git://people.freedesktop.org/~airlied/linux:
drm: Correct arguments to list_tail_add in create blob ioctl
drm: crtc: integer overflow in drm_property_create_blob()
drm/radeon: fix dpms when driver backlight control is disabled
drm/radeon: move bl encoder assignment into bl init
-rw-r--r-- | drivers/gpu/drm/drm_crtc.c | 4 | ||||
-rw-r--r-- | drivers/gpu/drm/radeon/atombios_encoders.c | 19 | ||||
-rw-r--r-- | drivers/gpu/drm/radeon/radeon_encoders.c | 1 | ||||
-rw-r--r-- | drivers/gpu/drm/radeon/radeon_legacy_encoders.c | 1 |
4 files changed, 18 insertions, 7 deletions
diff --git a/drivers/gpu/drm/drm_crtc.c b/drivers/gpu/drm/drm_crtc.c index 33d877c65ced..8328e7059205 100644 --- a/drivers/gpu/drm/drm_crtc.c +++ b/drivers/gpu/drm/drm_crtc.c | |||
@@ -4105,7 +4105,7 @@ drm_property_create_blob(struct drm_device *dev, size_t length, | |||
4105 | struct drm_property_blob *blob; | 4105 | struct drm_property_blob *blob; |
4106 | int ret; | 4106 | int ret; |
4107 | 4107 | ||
4108 | if (!length) | 4108 | if (!length || length > ULONG_MAX - sizeof(struct drm_property_blob)) |
4109 | return ERR_PTR(-EINVAL); | 4109 | return ERR_PTR(-EINVAL); |
4110 | 4110 | ||
4111 | blob = kzalloc(sizeof(struct drm_property_blob)+length, GFP_KERNEL); | 4111 | blob = kzalloc(sizeof(struct drm_property_blob)+length, GFP_KERNEL); |
@@ -4454,7 +4454,7 @@ int drm_mode_createblob_ioctl(struct drm_device *dev, | |||
4454 | * not associated with any file_priv. */ | 4454 | * not associated with any file_priv. */ |
4455 | mutex_lock(&dev->mode_config.blob_lock); | 4455 | mutex_lock(&dev->mode_config.blob_lock); |
4456 | out_resp->blob_id = blob->base.id; | 4456 | out_resp->blob_id = blob->base.id; |
4457 | list_add_tail(&file_priv->blobs, &blob->head_file); | 4457 | list_add_tail(&blob->head_file, &file_priv->blobs); |
4458 | mutex_unlock(&dev->mode_config.blob_lock); | 4458 | mutex_unlock(&dev->mode_config.blob_lock); |
4459 | 4459 | ||
4460 | return 0; | 4460 | return 0; |
diff --git a/drivers/gpu/drm/radeon/atombios_encoders.c b/drivers/gpu/drm/radeon/atombios_encoders.c index 65adb9c72377..bb292143997e 100644 --- a/drivers/gpu/drm/radeon/atombios_encoders.c +++ b/drivers/gpu/drm/radeon/atombios_encoders.c | |||
@@ -237,6 +237,7 @@ void radeon_atom_backlight_init(struct radeon_encoder *radeon_encoder, | |||
237 | backlight_update_status(bd); | 237 | backlight_update_status(bd); |
238 | 238 | ||
239 | DRM_INFO("radeon atom DIG backlight initialized\n"); | 239 | DRM_INFO("radeon atom DIG backlight initialized\n"); |
240 | rdev->mode_info.bl_encoder = radeon_encoder; | ||
240 | 241 | ||
241 | return; | 242 | return; |
242 | 243 | ||
@@ -1624,9 +1625,14 @@ radeon_atom_encoder_dpms_avivo(struct drm_encoder *encoder, int mode) | |||
1624 | } else | 1625 | } else |
1625 | atom_execute_table(rdev->mode_info.atom_context, index, (uint32_t *)&args); | 1626 | atom_execute_table(rdev->mode_info.atom_context, index, (uint32_t *)&args); |
1626 | if (radeon_encoder->devices & (ATOM_DEVICE_LCD_SUPPORT)) { | 1627 | 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; | ||
1628 | 1630 | ||
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 | } | ||
1630 | } | 1636 | } |
1631 | break; | 1637 | break; |
1632 | case DRM_MODE_DPMS_STANDBY: | 1638 | case DRM_MODE_DPMS_STANDBY: |
@@ -1706,8 +1712,13 @@ radeon_atom_encoder_dpms_dig(struct drm_encoder *encoder, int mode) | |||
1706 | if (ASIC_IS_DCE4(rdev)) | 1712 | if (ASIC_IS_DCE4(rdev)) |
1707 | atombios_dig_encoder_setup(encoder, ATOM_ENCODER_CMD_DP_VIDEO_ON, 0); | 1713 | atombios_dig_encoder_setup(encoder, ATOM_ENCODER_CMD_DP_VIDEO_ON, 0); |
1708 | } | 1714 | } |
1709 | if (radeon_encoder->devices & (ATOM_DEVICE_LCD_SUPPORT)) | 1715 | if (radeon_encoder->devices & (ATOM_DEVICE_LCD_SUPPORT)) { |
1710 | atombios_set_backlight_level(radeon_encoder, dig->backlight_level); | 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 | } | ||
1711 | if (ext_encoder) | 1722 | if (ext_encoder) |
1712 | atombios_external_encoder_setup(encoder, ext_encoder, ATOM_ENABLE); | 1723 | atombios_external_encoder_setup(encoder, ext_encoder, ATOM_ENABLE); |
1713 | break; | 1724 | break; |
diff --git a/drivers/gpu/drm/radeon/radeon_encoders.c b/drivers/gpu/drm/radeon/radeon_encoders.c index ef99917f000d..c6ee80216cf4 100644 --- a/drivers/gpu/drm/radeon/radeon_encoders.c +++ b/drivers/gpu/drm/radeon/radeon_encoders.c | |||
@@ -194,7 +194,6 @@ static void radeon_encoder_add_backlight(struct radeon_encoder *radeon_encoder, | |||
194 | radeon_atom_backlight_init(radeon_encoder, connector); | 194 | radeon_atom_backlight_init(radeon_encoder, connector); |
195 | else | 195 | else |
196 | radeon_legacy_backlight_init(radeon_encoder, connector); | 196 | radeon_legacy_backlight_init(radeon_encoder, connector); |
197 | rdev->mode_info.bl_encoder = radeon_encoder; | ||
198 | } | 197 | } |
199 | } | 198 | } |
200 | 199 | ||
diff --git a/drivers/gpu/drm/radeon/radeon_legacy_encoders.c b/drivers/gpu/drm/radeon/radeon_legacy_encoders.c index 45715307db71..30de43366eae 100644 --- a/drivers/gpu/drm/radeon/radeon_legacy_encoders.c +++ b/drivers/gpu/drm/radeon/radeon_legacy_encoders.c | |||
@@ -441,6 +441,7 @@ void radeon_legacy_backlight_init(struct radeon_encoder *radeon_encoder, | |||
441 | backlight_update_status(bd); | 441 | backlight_update_status(bd); |
442 | 442 | ||
443 | DRM_INFO("radeon legacy LVDS backlight initialized\n"); | 443 | DRM_INFO("radeon legacy LVDS backlight initialized\n"); |
444 | rdev->mode_info.bl_encoder = radeon_encoder; | ||
444 | 445 | ||
445 | return; | 446 | return; |
446 | 447 | ||