aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2015-10-31 19:16:51 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2015-10-31 19:16:51 -0400
commitd59ebbf19b29f4964b24f38c3ad876c33cdd7368 (patch)
tree4b1d76e577989f429e4706db76ce5c600e277b72
parent523e13455ec9ec4457a5a1d24ff7132949742b70 (diff)
parent8731b269f01e16193390c7276e70530366b8d626 (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.c4
-rw-r--r--drivers/gpu/drm/radeon/atombios_encoders.c19
-rw-r--r--drivers/gpu/drm/radeon/radeon_encoders.c1
-rw-r--r--drivers/gpu/drm/radeon/radeon_legacy_encoders.c1
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