All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] drm/i915: Set legacy properties when using legacy gamma set IOCTL.
@ 2016-04-08 16:26 Bob Paauwe
  2016-04-08 17:10 ` ✗ Fi.CI.BAT: failure for " Patchwork
                   ` (4 more replies)
  0 siblings, 5 replies; 20+ messages in thread
From: Bob Paauwe @ 2016-04-08 16:26 UTC (permalink / raw)
  To: intel-gfx

The i915 driver is now using atomic properties and atomic commit
to handle the legacy set gamma IOCTL. However, if the driver is
configured without atomic (nuclear_pageflip = false), it won't
update the legacy properties for degamma_lut, gamma_lut and ctm
leaving them out of sync with the atomic version of the properties.

Until the driver is full atomic, make sure we update the non-atomic
version of the properties.

igt-testcase: kms_pipe_color / legacy-gamma-reset-pipeX
Signed-off-by: Bob Paauwe <bob.j.paauwe@intel.com>
---
 drivers/gpu/drm/i915/intel_display.c | 38 +++++++++++++++++++++++++++++++++++-
 1 file changed, 37 insertions(+), 1 deletion(-)

diff --git a/drivers/gpu/drm/i915/intel_display.c b/drivers/gpu/drm/i915/intel_display.c
index 5155efb6..ff09a18 100644
--- a/drivers/gpu/drm/i915/intel_display.c
+++ b/drivers/gpu/drm/i915/intel_display.c
@@ -13885,8 +13885,44 @@ out:
 
 #undef for_each_intel_crtc_masked
 
+/*
+ * TODO: Remove this once we have full atomic implmented.
+ */
+static void intel_atomic_legacy_gamma_set(struct drm_crtc *crtc,
+					  u16 *red, u16 *green, u16 *blue,
+					  uint32_t start, uint32_t size)
+{
+	struct drm_device *dev = crtc->dev;
+	struct drm_mode_config *config = &dev->mode_config;
+	struct drm_crtc_state *state;
+
+	drm_atomic_helper_legacy_gamma_set(crtc, red, green, blue, start, size);
+
+	/*
+	 * Make sure we update the legacy properties so this works when
+	 * atomic is not enabled.
+	 */
+
+	state = crtc->state;
+
+	drm_object_property_set_value(&crtc->base,
+				      config->degamma_lut_property,
+				      (state->degamma_lut) ?
+				      state->degamma_lut->base.id : 0);
+
+	drm_object_property_set_value(&crtc->base,
+				      config->ctm_property,
+				      (state->ctm) ?
+				      state->ctm->base.id : 0);
+
+	drm_object_property_set_value(&crtc->base,
+				      config->gamma_lut_property,
+				      (state->gamma_lut) ?
+				      state->gamma_lut->base.id : 0);
+}
+
 static const struct drm_crtc_funcs intel_crtc_funcs = {
-	.gamma_set = drm_atomic_helper_legacy_gamma_set,
+	.gamma_set = intel_atomic_legacy_gamma_set,
 	.set_config = drm_atomic_helper_set_config,
 	.set_property = drm_atomic_helper_crtc_set_property,
 	.destroy = intel_crtc_destroy,
-- 
2.5.5

_______________________________________________
Intel-gfx mailing list
Intel-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/intel-gfx

^ permalink raw reply related	[flat|nested] 20+ messages in thread
* [PATCH] Nightly color management fixes
@ 2016-07-15 10:59 Lionel Landwerlin
  2016-07-15 13:59 ` [PATCH] drm/i915: Set legacy properties when using legacy gamma set IOCTL. (v2) Lionel Landwerlin
  0 siblings, 1 reply; 20+ messages in thread
From: Lionel Landwerlin @ 2016-07-15 10:59 UTC (permalink / raw)
  To: intel-gfx

Nightly has gone through some atomic reverts, we just need a single
patch to fix the remaining color management issues.

Cheers,

Lionel

Bob Paauwe (1):
  drm/i915: Set legacy properties when using legacy gamma set IOCTL.

 drivers/gpu/drm/i915/intel_display.c | 39 +++++++++++++++++++++++++++++++++++-
 1 file changed, 38 insertions(+), 1 deletion(-)

--
2.8.1
_______________________________________________
Intel-gfx mailing list
Intel-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/intel-gfx

^ permalink raw reply	[flat|nested] 20+ messages in thread

end of thread, other threads:[~2016-07-18 14:27 UTC | newest]

Thread overview: 20+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2016-04-08 16:26 [PATCH] drm/i915: Set legacy properties when using legacy gamma set IOCTL Bob Paauwe
2016-04-08 17:10 ` ✗ Fi.CI.BAT: failure for " Patchwork
2016-04-08 17:21 ` [PATCH] " Lionel Landwerlin
2016-04-08 17:58   ` Bob Paauwe
2016-04-08 17:21 ` Lionel Landwerlin
2016-04-18 16:47 ` [PATCH] drm/i915: Set legacy properties when using legacy gamma set IOCTL. (v2) Bob Paauwe
2016-04-19  6:02   ` Maarten Lankhorst
2016-04-19 10:13     ` Lionel Landwerlin
2016-04-20  7:00       ` Maarten Lankhorst
2016-04-20 12:38         ` Daniel Vetter
2016-05-04 13:49           ` Lionel Landwerlin
2016-05-09  6:52             ` Daniel Vetter
2016-04-19  6:05   ` Maarten Lankhorst
2016-04-19 16:20     ` Bob Paauwe
2016-04-20  6:57       ` Maarten Lankhorst
2016-04-27 15:03 ` ✗ Fi.CI.BAT: failure for drm/i915: Set legacy properties when using legacy gamma set IOCTL. (rev2) Patchwork
2016-07-15 10:59 [PATCH] Nightly color management fixes Lionel Landwerlin
2016-07-15 13:59 ` [PATCH] drm/i915: Set legacy properties when using legacy gamma set IOCTL. (v2) Lionel Landwerlin
2016-07-15 16:13   ` Bob Paauwe
2016-07-18 14:27     ` Maarten Lankhorst
2016-07-18  7:50   ` Maarten Lankhorst

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.