1  /*
2   * Copyright © 2016 Intel Corporation
3   *
4   * Permission is hereby granted, free of charge, to any person obtaining a
5   * copy of this software and associated documentation files (the "Software"),
6   * to deal in the Software without restriction, including without limitation
7   * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8   * and/or sell copies of the Software, and to permit persons to whom the
9   * Software is furnished to do so, subject to the following conditions:
10   *
11   * The above copyright notice and this permission notice (including the next
12   * paragraph) shall be included in all copies or substantial portions of the
13   * Software.
14   *
15   * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16   * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17   * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
18   * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19   * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20   * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
21   * DEALINGS IN THE SOFTWARE.
22   *
23   */
24  
25  #include "i9xx_plane_regs.h"
26  #include "intel_color.h"
27  #include "intel_color_regs.h"
28  #include "intel_de.h"
29  #include "intel_display_types.h"
30  #include "intel_dsb.h"
31  
32  struct intel_color_funcs {
33  	int (*color_check)(struct intel_atomic_state *state,
34  			   struct intel_crtc *crtc);
35  	/*
36  	 * Program non-arming double buffered color management registers
37  	 * before vblank evasion. The registers should then latch after
38  	 * the arming register is written (by color_commit_arm()) during
39  	 * the next vblank start, alongside any other double buffered
40  	 * registers involved with the same commit. This hook is optional.
41  	 */
42  	void (*color_commit_noarm)(const struct intel_crtc_state *crtc_state);
43  	/*
44  	 * Program arming double buffered color management registers
45  	 * during vblank evasion. The registers (and whatever other registers
46  	 * they arm that were written by color_commit_noarm) should then latch
47  	 * during the next vblank start, alongside any other double buffered
48  	 * registers involved with the same commit.
49  	 */
50  	void (*color_commit_arm)(const struct intel_crtc_state *crtc_state);
51  	/*
52  	 * Perform any extra tasks needed after all the
53  	 * double buffered registers have been latched.
54  	 */
55  	void (*color_post_update)(const struct intel_crtc_state *crtc_state);
56  	/*
57  	 * Load LUTs (and other single buffered color management
58  	 * registers). Will (hopefully) be called during the vblank
59  	 * following the latching of any double buffered registers
60  	 * involved with the same commit.
61  	 */
62  	void (*load_luts)(const struct intel_crtc_state *crtc_state);
63  	/*
64  	 * Read out the LUTs from the hardware into the software state.
65  	 * Used by eg. the hardware state checker.
66  	 */
67  	void (*read_luts)(struct intel_crtc_state *crtc_state);
68  	/*
69  	 * Compare the LUTs
70  	 */
71  	bool (*lut_equal)(const struct intel_crtc_state *crtc_state,
72  			  const struct drm_property_blob *blob1,
73  			  const struct drm_property_blob *blob2,
74  			  bool is_pre_csc_lut);
75  	/*
76  	 * Read out the CSCs (if any) from the hardware into the
77  	 * software state. Used by eg. the hardware state checker.
78  	 */
79  	void (*read_csc)(struct intel_crtc_state *crtc_state);
80  	/*
81  	 * Read config other than LUTs and CSCs, before them. Optional.
82  	 */
83  	void (*get_config)(struct intel_crtc_state *crtc_state);
84  };
85  
86  #define CTM_COEFF_SIGN	(1ULL << 63)
87  
88  #define CTM_COEFF_1_0	(1ULL << 32)
89  #define CTM_COEFF_2_0	(CTM_COEFF_1_0 << 1)
90  #define CTM_COEFF_4_0	(CTM_COEFF_2_0 << 1)
91  #define CTM_COEFF_8_0	(CTM_COEFF_4_0 << 1)
92  #define CTM_COEFF_0_5	(CTM_COEFF_1_0 >> 1)
93  #define CTM_COEFF_0_25	(CTM_COEFF_0_5 >> 1)
94  #define CTM_COEFF_0_125	(CTM_COEFF_0_25 >> 1)
95  
96  #define CTM_COEFF_LIMITED_RANGE ((235ULL - 16ULL) * CTM_COEFF_1_0 / 255)
97  
98  #define CTM_COEFF_NEGATIVE(coeff)	(((coeff) & CTM_COEFF_SIGN) != 0)
99  #define CTM_COEFF_ABS(coeff)		((coeff) & (CTM_COEFF_SIGN - 1))
100  
101  #define LEGACY_LUT_LENGTH		256
102  
103  /*
104   * ILK+ csc matrix:
105   *
106   * |R/Cr|   | c0 c1 c2 |   ( |R/Cr|   |preoff0| )   |postoff0|
107   * |G/Y | = | c3 c4 c5 | x ( |G/Y | + |preoff1| ) + |postoff1|
108   * |B/Cb|   | c6 c7 c8 |   ( |B/Cb|   |preoff2| )   |postoff2|
109   *
110   * ILK/SNB don't have explicit post offsets, and instead
111   * CSC_MODE_YUV_TO_RGB and CSC_BLACK_SCREEN_OFFSET are used:
112   *  CSC_MODE_YUV_TO_RGB=0 + CSC_BLACK_SCREEN_OFFSET=0 -> 1/2, 0, 1/2
113   *  CSC_MODE_YUV_TO_RGB=0 + CSC_BLACK_SCREEN_OFFSET=1 -> 1/2, 1/16, 1/2
114   *  CSC_MODE_YUV_TO_RGB=1 + CSC_BLACK_SCREEN_OFFSET=0 -> 0, 0, 0
115   *  CSC_MODE_YUV_TO_RGB=1 + CSC_BLACK_SCREEN_OFFSET=1 -> 1/16, 1/16, 1/16
116   */
117  
118  /*
119   * Extract the CSC coefficient from a CTM coefficient (in U32.32 fixed point
120   * format). This macro takes the coefficient we want transformed and the
121   * number of fractional bits.
122   *
123   * We only have a 9 bits precision window which slides depending on the value
124   * of the CTM coefficient and we write the value from bit 3. We also round the
125   * value.
126   */
127  #define ILK_CSC_COEFF_FP(coeff, fbits)	\
128  	(clamp_val(((coeff) >> (32 - (fbits) - 3)) + 4, 0, 0xfff) & 0xff8)
129  
130  #define ILK_CSC_COEFF_1_0 0x7800
131  #define ILK_CSC_COEFF_LIMITED_RANGE ((235 - 16) << (12 - 8)) /* exponent 0 */
132  #define ILK_CSC_POSTOFF_LIMITED_RANGE (16 << (12 - 8))
133  
134  static const struct intel_csc_matrix ilk_csc_matrix_identity = {
135  	.preoff = {},
136  	.coeff = {
137  		ILK_CSC_COEFF_1_0, 0, 0,
138  		0, ILK_CSC_COEFF_1_0, 0,
139  		0, 0, ILK_CSC_COEFF_1_0,
140  	},
141  	.postoff = {},
142  };
143  
144  /* Full range RGB -> limited range RGB matrix */
145  static const struct intel_csc_matrix ilk_csc_matrix_limited_range = {
146  	.preoff = {},
147  	.coeff = {
148  		ILK_CSC_COEFF_LIMITED_RANGE, 0, 0,
149  		0, ILK_CSC_COEFF_LIMITED_RANGE, 0,
150  		0, 0, ILK_CSC_COEFF_LIMITED_RANGE,
151  	},
152  	.postoff = {
153  		ILK_CSC_POSTOFF_LIMITED_RANGE,
154  		ILK_CSC_POSTOFF_LIMITED_RANGE,
155  		ILK_CSC_POSTOFF_LIMITED_RANGE,
156  	},
157  };
158  
159  /* BT.709 full range RGB -> limited range YCbCr matrix */
160  static const struct intel_csc_matrix ilk_csc_matrix_rgb_to_ycbcr = {
161  	.preoff = {},
162  	.coeff = {
163  		0x1e08, 0x9cc0, 0xb528,
164  		0x2ba8, 0x09d8, 0x37e8,
165  		0xbce8, 0x9ad8, 0x1e08,
166  	},
167  	.postoff = {
168  		0x0800, 0x0100, 0x0800,
169  	},
170  };
171  
intel_csc_clear(struct intel_csc_matrix * csc)172  static void intel_csc_clear(struct intel_csc_matrix *csc)
173  {
174  	memset(csc, 0, sizeof(*csc));
175  }
176  
lut_is_legacy(const struct drm_property_blob * lut)177  static bool lut_is_legacy(const struct drm_property_blob *lut)
178  {
179  	return lut && drm_color_lut_size(lut) == LEGACY_LUT_LENGTH;
180  }
181  
182  /*
183   * When using limited range, multiply the matrix given by userspace by
184   * the matrix that we would use for the limited range.
185   */
ctm_mult_by_limited(u64 * result,const u64 * input)186  static u64 *ctm_mult_by_limited(u64 *result, const u64 *input)
187  {
188  	int i;
189  
190  	for (i = 0; i < 9; i++) {
191  		u64 user_coeff = input[i];
192  		u32 limited_coeff = CTM_COEFF_LIMITED_RANGE;
193  		u32 abs_coeff = clamp_val(CTM_COEFF_ABS(user_coeff), 0,
194  					  CTM_COEFF_4_0 - 1) >> 2;
195  
196  		/*
197  		 * By scaling every co-efficient with limited range (16-235)
198  		 * vs full range (0-255) the final o/p will be scaled down to
199  		 * fit in the limited range supported by the panel.
200  		 */
201  		result[i] = mul_u32_u32(limited_coeff, abs_coeff) >> 30;
202  		result[i] |= user_coeff & CTM_COEFF_SIGN;
203  	}
204  
205  	return result;
206  }
207  
ilk_update_pipe_csc(struct intel_crtc * crtc,const struct intel_csc_matrix * csc)208  static void ilk_update_pipe_csc(struct intel_crtc *crtc,
209  				const struct intel_csc_matrix *csc)
210  {
211  	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
212  	enum pipe pipe = crtc->pipe;
213  
214  	intel_de_write_fw(i915, PIPE_CSC_PREOFF_HI(pipe), csc->preoff[0]);
215  	intel_de_write_fw(i915, PIPE_CSC_PREOFF_ME(pipe), csc->preoff[1]);
216  	intel_de_write_fw(i915, PIPE_CSC_PREOFF_LO(pipe), csc->preoff[2]);
217  
218  	intel_de_write_fw(i915, PIPE_CSC_COEFF_RY_GY(pipe),
219  			  csc->coeff[0] << 16 | csc->coeff[1]);
220  	intel_de_write_fw(i915, PIPE_CSC_COEFF_BY(pipe),
221  			  csc->coeff[2] << 16);
222  
223  	intel_de_write_fw(i915, PIPE_CSC_COEFF_RU_GU(pipe),
224  			  csc->coeff[3] << 16 | csc->coeff[4]);
225  	intel_de_write_fw(i915, PIPE_CSC_COEFF_BU(pipe),
226  			  csc->coeff[5] << 16);
227  
228  	intel_de_write_fw(i915, PIPE_CSC_COEFF_RV_GV(pipe),
229  			  csc->coeff[6] << 16 | csc->coeff[7]);
230  	intel_de_write_fw(i915, PIPE_CSC_COEFF_BV(pipe),
231  			  csc->coeff[8] << 16);
232  
233  	if (DISPLAY_VER(i915) < 7)
234  		return;
235  
236  	intel_de_write_fw(i915, PIPE_CSC_POSTOFF_HI(pipe), csc->postoff[0]);
237  	intel_de_write_fw(i915, PIPE_CSC_POSTOFF_ME(pipe), csc->postoff[1]);
238  	intel_de_write_fw(i915, PIPE_CSC_POSTOFF_LO(pipe), csc->postoff[2]);
239  }
240  
ilk_read_pipe_csc(struct intel_crtc * crtc,struct intel_csc_matrix * csc)241  static void ilk_read_pipe_csc(struct intel_crtc *crtc,
242  			      struct intel_csc_matrix *csc)
243  {
244  	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
245  	enum pipe pipe = crtc->pipe;
246  	u32 tmp;
247  
248  	csc->preoff[0] = intel_de_read_fw(i915, PIPE_CSC_PREOFF_HI(pipe));
249  	csc->preoff[1] = intel_de_read_fw(i915, PIPE_CSC_PREOFF_ME(pipe));
250  	csc->preoff[2] = intel_de_read_fw(i915, PIPE_CSC_PREOFF_LO(pipe));
251  
252  	tmp = intel_de_read_fw(i915, PIPE_CSC_COEFF_RY_GY(pipe));
253  	csc->coeff[0] = tmp >> 16;
254  	csc->coeff[1] = tmp & 0xffff;
255  	tmp = intel_de_read_fw(i915, PIPE_CSC_COEFF_BY(pipe));
256  	csc->coeff[2] = tmp >> 16;
257  
258  	tmp = intel_de_read_fw(i915, PIPE_CSC_COEFF_RU_GU(pipe));
259  	csc->coeff[3] = tmp >> 16;
260  	csc->coeff[4] = tmp & 0xffff;
261  	tmp = intel_de_read_fw(i915, PIPE_CSC_COEFF_BU(pipe));
262  	csc->coeff[5] = tmp >> 16;
263  
264  	tmp = intel_de_read_fw(i915, PIPE_CSC_COEFF_RV_GV(pipe));
265  	csc->coeff[6] = tmp >> 16;
266  	csc->coeff[7] = tmp & 0xffff;
267  	tmp = intel_de_read_fw(i915, PIPE_CSC_COEFF_BV(pipe));
268  	csc->coeff[8] = tmp >> 16;
269  
270  	if (DISPLAY_VER(i915) < 7)
271  		return;
272  
273  	csc->postoff[0] = intel_de_read_fw(i915, PIPE_CSC_POSTOFF_HI(pipe));
274  	csc->postoff[1] = intel_de_read_fw(i915, PIPE_CSC_POSTOFF_ME(pipe));
275  	csc->postoff[2] = intel_de_read_fw(i915, PIPE_CSC_POSTOFF_LO(pipe));
276  }
277  
ilk_read_csc(struct intel_crtc_state * crtc_state)278  static void ilk_read_csc(struct intel_crtc_state *crtc_state)
279  {
280  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
281  
282  	if (crtc_state->csc_enable)
283  		ilk_read_pipe_csc(crtc, &crtc_state->csc);
284  }
285  
skl_read_csc(struct intel_crtc_state * crtc_state)286  static void skl_read_csc(struct intel_crtc_state *crtc_state)
287  {
288  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
289  
290  	/*
291  	 * Display WA #1184: skl,glk
292  	 * Wa_1406463849: icl
293  	 *
294  	 * Danger! On SKL-ICL *reads* from the CSC coeff/offset registers
295  	 * will disarm an already armed CSC double buffer update.
296  	 * So this must not be called while armed. Fortunately the state checker
297  	 * readout happens only after the update has been already been latched.
298  	 *
299  	 * On earlier and later platforms only writes to said registers will
300  	 * disarm the update. This is considered normal behavior and also
301  	 * happens with various other hardware units.
302  	 */
303  	if (crtc_state->csc_enable)
304  		ilk_read_pipe_csc(crtc, &crtc_state->csc);
305  }
306  
icl_update_output_csc(struct intel_crtc * crtc,const struct intel_csc_matrix * csc)307  static void icl_update_output_csc(struct intel_crtc *crtc,
308  				  const struct intel_csc_matrix *csc)
309  {
310  	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
311  	enum pipe pipe = crtc->pipe;
312  
313  	intel_de_write_fw(i915, PIPE_CSC_OUTPUT_PREOFF_HI(pipe), csc->preoff[0]);
314  	intel_de_write_fw(i915, PIPE_CSC_OUTPUT_PREOFF_ME(pipe), csc->preoff[1]);
315  	intel_de_write_fw(i915, PIPE_CSC_OUTPUT_PREOFF_LO(pipe), csc->preoff[2]);
316  
317  	intel_de_write_fw(i915, PIPE_CSC_OUTPUT_COEFF_RY_GY(pipe),
318  			  csc->coeff[0] << 16 | csc->coeff[1]);
319  	intel_de_write_fw(i915, PIPE_CSC_OUTPUT_COEFF_BY(pipe),
320  			  csc->coeff[2] << 16);
321  
322  	intel_de_write_fw(i915, PIPE_CSC_OUTPUT_COEFF_RU_GU(pipe),
323  			  csc->coeff[3] << 16 | csc->coeff[4]);
324  	intel_de_write_fw(i915, PIPE_CSC_OUTPUT_COEFF_BU(pipe),
325  			  csc->coeff[5] << 16);
326  
327  	intel_de_write_fw(i915, PIPE_CSC_OUTPUT_COEFF_RV_GV(pipe),
328  			  csc->coeff[6] << 16 | csc->coeff[7]);
329  	intel_de_write_fw(i915, PIPE_CSC_OUTPUT_COEFF_BV(pipe),
330  			  csc->coeff[8] << 16);
331  
332  	intel_de_write_fw(i915, PIPE_CSC_OUTPUT_POSTOFF_HI(pipe), csc->postoff[0]);
333  	intel_de_write_fw(i915, PIPE_CSC_OUTPUT_POSTOFF_ME(pipe), csc->postoff[1]);
334  	intel_de_write_fw(i915, PIPE_CSC_OUTPUT_POSTOFF_LO(pipe), csc->postoff[2]);
335  }
336  
icl_read_output_csc(struct intel_crtc * crtc,struct intel_csc_matrix * csc)337  static void icl_read_output_csc(struct intel_crtc *crtc,
338  				struct intel_csc_matrix *csc)
339  {
340  	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
341  	enum pipe pipe = crtc->pipe;
342  	u32 tmp;
343  
344  	csc->preoff[0] = intel_de_read_fw(i915, PIPE_CSC_OUTPUT_PREOFF_HI(pipe));
345  	csc->preoff[1] = intel_de_read_fw(i915, PIPE_CSC_OUTPUT_PREOFF_ME(pipe));
346  	csc->preoff[2] = intel_de_read_fw(i915, PIPE_CSC_OUTPUT_PREOFF_LO(pipe));
347  
348  	tmp = intel_de_read_fw(i915, PIPE_CSC_OUTPUT_COEFF_RY_GY(pipe));
349  	csc->coeff[0] = tmp >> 16;
350  	csc->coeff[1] = tmp & 0xffff;
351  	tmp = intel_de_read_fw(i915, PIPE_CSC_OUTPUT_COEFF_BY(pipe));
352  	csc->coeff[2] = tmp >> 16;
353  
354  	tmp = intel_de_read_fw(i915, PIPE_CSC_OUTPUT_COEFF_RU_GU(pipe));
355  	csc->coeff[3] = tmp >> 16;
356  	csc->coeff[4] = tmp & 0xffff;
357  	tmp = intel_de_read_fw(i915, PIPE_CSC_OUTPUT_COEFF_BU(pipe));
358  	csc->coeff[5] = tmp >> 16;
359  
360  	tmp = intel_de_read_fw(i915, PIPE_CSC_OUTPUT_COEFF_RV_GV(pipe));
361  	csc->coeff[6] = tmp >> 16;
362  	csc->coeff[7] = tmp & 0xffff;
363  	tmp = intel_de_read_fw(i915, PIPE_CSC_OUTPUT_COEFF_BV(pipe));
364  	csc->coeff[8] = tmp >> 16;
365  
366  	csc->postoff[0] = intel_de_read_fw(i915, PIPE_CSC_OUTPUT_POSTOFF_HI(pipe));
367  	csc->postoff[1] = intel_de_read_fw(i915, PIPE_CSC_OUTPUT_POSTOFF_ME(pipe));
368  	csc->postoff[2] = intel_de_read_fw(i915, PIPE_CSC_OUTPUT_POSTOFF_LO(pipe));
369  }
370  
icl_read_csc(struct intel_crtc_state * crtc_state)371  static void icl_read_csc(struct intel_crtc_state *crtc_state)
372  {
373  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
374  
375  	/*
376  	 * Wa_1406463849: icl
377  	 *
378  	 * See skl_read_csc()
379  	 */
380  	if (crtc_state->csc_mode & ICL_CSC_ENABLE)
381  		ilk_read_pipe_csc(crtc, &crtc_state->csc);
382  
383  	if (crtc_state->csc_mode & ICL_OUTPUT_CSC_ENABLE)
384  		icl_read_output_csc(crtc, &crtc_state->output_csc);
385  }
386  
ilk_limited_range(const struct intel_crtc_state * crtc_state)387  static bool ilk_limited_range(const struct intel_crtc_state *crtc_state)
388  {
389  	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
390  
391  	/* icl+ have dedicated output CSC */
392  	if (DISPLAY_VER(i915) >= 11)
393  		return false;
394  
395  	/* pre-hsw have TRANSCONF_COLOR_RANGE_SELECT */
396  	if (DISPLAY_VER(i915) < 7 || IS_IVYBRIDGE(i915))
397  		return false;
398  
399  	return crtc_state->limited_color_range;
400  }
401  
ilk_lut_limited_range(const struct intel_crtc_state * crtc_state)402  static bool ilk_lut_limited_range(const struct intel_crtc_state *crtc_state)
403  {
404  	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
405  
406  	if (!ilk_limited_range(crtc_state))
407  		return false;
408  
409  	if (crtc_state->c8_planes)
410  		return false;
411  
412  	if (DISPLAY_VER(i915) == 10)
413  		return crtc_state->hw.gamma_lut;
414  	else
415  		return crtc_state->hw.gamma_lut &&
416  			(crtc_state->hw.degamma_lut || crtc_state->hw.ctm);
417  }
418  
ilk_csc_limited_range(const struct intel_crtc_state * crtc_state)419  static bool ilk_csc_limited_range(const struct intel_crtc_state *crtc_state)
420  {
421  	if (!ilk_limited_range(crtc_state))
422  		return false;
423  
424  	return !ilk_lut_limited_range(crtc_state);
425  }
426  
ilk_csc_copy(struct drm_i915_private * i915,struct intel_csc_matrix * dst,const struct intel_csc_matrix * src)427  static void ilk_csc_copy(struct drm_i915_private *i915,
428  			 struct intel_csc_matrix *dst,
429  			 const struct intel_csc_matrix *src)
430  {
431  	*dst = *src;
432  
433  	if (DISPLAY_VER(i915) < 7)
434  		memset(dst->postoff, 0, sizeof(dst->postoff));
435  }
436  
ilk_csc_convert_ctm(const struct intel_crtc_state * crtc_state,struct intel_csc_matrix * csc,bool limited_color_range)437  static void ilk_csc_convert_ctm(const struct intel_crtc_state *crtc_state,
438  				struct intel_csc_matrix *csc,
439  				bool limited_color_range)
440  {
441  	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
442  	const struct drm_color_ctm *ctm = crtc_state->hw.ctm->data;
443  	const u64 *input;
444  	u64 temp[9];
445  	int i;
446  
447  	/* for preoff/postoff */
448  	if (limited_color_range)
449  		ilk_csc_copy(i915, csc, &ilk_csc_matrix_limited_range);
450  	else
451  		ilk_csc_copy(i915, csc, &ilk_csc_matrix_identity);
452  
453  	if (limited_color_range)
454  		input = ctm_mult_by_limited(temp, ctm->matrix);
455  	else
456  		input = ctm->matrix;
457  
458  	/*
459  	 * Convert fixed point S31.32 input to format supported by the
460  	 * hardware.
461  	 */
462  	for (i = 0; i < 9; i++) {
463  		u64 abs_coeff = ((1ULL << 63) - 1) & input[i];
464  
465  		/*
466  		 * Clamp input value to min/max supported by
467  		 * hardware.
468  		 */
469  		abs_coeff = clamp_val(abs_coeff, 0, CTM_COEFF_4_0 - 1);
470  
471  		csc->coeff[i] = 0;
472  
473  		/* sign bit */
474  		if (CTM_COEFF_NEGATIVE(input[i]))
475  			csc->coeff[i] |= 1 << 15;
476  
477  		if (abs_coeff < CTM_COEFF_0_125)
478  			csc->coeff[i] |= (3 << 12) |
479  				ILK_CSC_COEFF_FP(abs_coeff, 12);
480  		else if (abs_coeff < CTM_COEFF_0_25)
481  			csc->coeff[i] |= (2 << 12) |
482  				ILK_CSC_COEFF_FP(abs_coeff, 11);
483  		else if (abs_coeff < CTM_COEFF_0_5)
484  			csc->coeff[i] |= (1 << 12) |
485  				ILK_CSC_COEFF_FP(abs_coeff, 10);
486  		else if (abs_coeff < CTM_COEFF_1_0)
487  			csc->coeff[i] |= ILK_CSC_COEFF_FP(abs_coeff, 9);
488  		else if (abs_coeff < CTM_COEFF_2_0)
489  			csc->coeff[i] |= (7 << 12) |
490  				ILK_CSC_COEFF_FP(abs_coeff, 8);
491  		else
492  			csc->coeff[i] |= (6 << 12) |
493  				ILK_CSC_COEFF_FP(abs_coeff, 7);
494  	}
495  }
496  
ilk_assign_csc(struct intel_crtc_state * crtc_state)497  static void ilk_assign_csc(struct intel_crtc_state *crtc_state)
498  {
499  	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
500  	bool limited_color_range = ilk_csc_limited_range(crtc_state);
501  
502  	if (crtc_state->hw.ctm) {
503  		drm_WARN_ON(&i915->drm, !crtc_state->csc_enable);
504  
505  		ilk_csc_convert_ctm(crtc_state, &crtc_state->csc, limited_color_range);
506  	} else if (crtc_state->output_format != INTEL_OUTPUT_FORMAT_RGB) {
507  		drm_WARN_ON(&i915->drm, !crtc_state->csc_enable);
508  
509  		ilk_csc_copy(i915, &crtc_state->csc, &ilk_csc_matrix_rgb_to_ycbcr);
510  	} else if (limited_color_range) {
511  		drm_WARN_ON(&i915->drm, !crtc_state->csc_enable);
512  
513  		ilk_csc_copy(i915, &crtc_state->csc, &ilk_csc_matrix_limited_range);
514  	} else if (crtc_state->csc_enable) {
515  		/*
516  		 * On GLK both pipe CSC and degamma LUT are controlled
517  		 * by csc_enable. Hence for the cases where the degama
518  		 * LUT is needed but CSC is not we need to load an
519  		 * identity matrix.
520  		 */
521  		drm_WARN_ON(&i915->drm, !IS_GEMINILAKE(i915));
522  
523  		ilk_csc_copy(i915, &crtc_state->csc, &ilk_csc_matrix_identity);
524  	} else {
525  		intel_csc_clear(&crtc_state->csc);
526  	}
527  }
528  
ilk_load_csc_matrix(const struct intel_crtc_state * crtc_state)529  static void ilk_load_csc_matrix(const struct intel_crtc_state *crtc_state)
530  {
531  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
532  
533  	if (crtc_state->csc_enable)
534  		ilk_update_pipe_csc(crtc, &crtc_state->csc);
535  }
536  
icl_assign_csc(struct intel_crtc_state * crtc_state)537  static void icl_assign_csc(struct intel_crtc_state *crtc_state)
538  {
539  	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
540  
541  	if (crtc_state->hw.ctm) {
542  		drm_WARN_ON(&i915->drm, (crtc_state->csc_mode & ICL_CSC_ENABLE) == 0);
543  
544  		ilk_csc_convert_ctm(crtc_state, &crtc_state->csc, false);
545  	} else {
546  		drm_WARN_ON(&i915->drm, (crtc_state->csc_mode & ICL_CSC_ENABLE) != 0);
547  
548  		intel_csc_clear(&crtc_state->csc);
549  	}
550  
551  	if (crtc_state->output_format != INTEL_OUTPUT_FORMAT_RGB) {
552  		drm_WARN_ON(&i915->drm, (crtc_state->csc_mode & ICL_OUTPUT_CSC_ENABLE) == 0);
553  
554  		ilk_csc_copy(i915, &crtc_state->output_csc, &ilk_csc_matrix_rgb_to_ycbcr);
555  	} else if (crtc_state->limited_color_range) {
556  		drm_WARN_ON(&i915->drm, (crtc_state->csc_mode & ICL_OUTPUT_CSC_ENABLE) == 0);
557  
558  		ilk_csc_copy(i915, &crtc_state->output_csc, &ilk_csc_matrix_limited_range);
559  	} else {
560  		drm_WARN_ON(&i915->drm, (crtc_state->csc_mode & ICL_OUTPUT_CSC_ENABLE) != 0);
561  
562  		intel_csc_clear(&crtc_state->output_csc);
563  	}
564  }
565  
icl_load_csc_matrix(const struct intel_crtc_state * crtc_state)566  static void icl_load_csc_matrix(const struct intel_crtc_state *crtc_state)
567  {
568  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
569  
570  	if (crtc_state->csc_mode & ICL_CSC_ENABLE)
571  		ilk_update_pipe_csc(crtc, &crtc_state->csc);
572  
573  	if (crtc_state->csc_mode & ICL_OUTPUT_CSC_ENABLE)
574  		icl_update_output_csc(crtc, &crtc_state->output_csc);
575  }
576  
ctm_to_twos_complement(u64 coeff,int int_bits,int frac_bits)577  static u16 ctm_to_twos_complement(u64 coeff, int int_bits, int frac_bits)
578  {
579  	s64 c = CTM_COEFF_ABS(coeff);
580  
581  	/* leave an extra bit for rounding */
582  	c >>= 32 - frac_bits - 1;
583  
584  	/* round and drop the extra bit */
585  	c = (c + 1) >> 1;
586  
587  	if (CTM_COEFF_NEGATIVE(coeff))
588  		c = -c;
589  
590  	c = clamp(c, -(s64)BIT(int_bits + frac_bits - 1),
591  		  (s64)(BIT(int_bits + frac_bits - 1) - 1));
592  
593  	return c & (BIT(int_bits + frac_bits) - 1);
594  }
595  
596  /*
597   * VLV/CHV Wide Gamut Color Correction (WGC) CSC
598   * |r|   | c0 c1 c2 |   |r|
599   * |g| = | c3 c4 c5 | x |g|
600   * |b|   | c6 c7 c8 |   |b|
601   *
602   * Coefficients are two's complement s2.10.
603   */
vlv_wgc_csc_convert_ctm(const struct intel_crtc_state * crtc_state,struct intel_csc_matrix * csc)604  static void vlv_wgc_csc_convert_ctm(const struct intel_crtc_state *crtc_state,
605  				    struct intel_csc_matrix *csc)
606  {
607  	const struct drm_color_ctm *ctm = crtc_state->hw.ctm->data;
608  	int i;
609  
610  	for (i = 0; i < 9; i++)
611  		csc->coeff[i] = ctm_to_twos_complement(ctm->matrix[i], 2, 10);
612  }
613  
vlv_load_wgc_csc(struct intel_crtc * crtc,const struct intel_csc_matrix * csc)614  static void vlv_load_wgc_csc(struct intel_crtc *crtc,
615  			     const struct intel_csc_matrix *csc)
616  {
617  	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
618  	enum pipe pipe = crtc->pipe;
619  
620  	intel_de_write_fw(dev_priv, PIPE_WGC_C01_C00(dev_priv, pipe),
621  			  csc->coeff[1] << 16 | csc->coeff[0]);
622  	intel_de_write_fw(dev_priv, PIPE_WGC_C02(dev_priv, pipe),
623  			  csc->coeff[2]);
624  
625  	intel_de_write_fw(dev_priv, PIPE_WGC_C11_C10(dev_priv, pipe),
626  			  csc->coeff[4] << 16 | csc->coeff[3]);
627  	intel_de_write_fw(dev_priv, PIPE_WGC_C12(dev_priv, pipe),
628  			  csc->coeff[5]);
629  
630  	intel_de_write_fw(dev_priv, PIPE_WGC_C21_C20(dev_priv, pipe),
631  			  csc->coeff[7] << 16 | csc->coeff[6]);
632  	intel_de_write_fw(dev_priv, PIPE_WGC_C22(dev_priv, pipe),
633  			  csc->coeff[8]);
634  }
635  
vlv_read_wgc_csc(struct intel_crtc * crtc,struct intel_csc_matrix * csc)636  static void vlv_read_wgc_csc(struct intel_crtc *crtc,
637  			     struct intel_csc_matrix *csc)
638  {
639  	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
640  	enum pipe pipe = crtc->pipe;
641  	u32 tmp;
642  
643  	tmp = intel_de_read_fw(dev_priv, PIPE_WGC_C01_C00(dev_priv, pipe));
644  	csc->coeff[0] = tmp & 0xffff;
645  	csc->coeff[1] = tmp >> 16;
646  
647  	tmp = intel_de_read_fw(dev_priv, PIPE_WGC_C02(dev_priv, pipe));
648  	csc->coeff[2] = tmp & 0xffff;
649  
650  	tmp = intel_de_read_fw(dev_priv, PIPE_WGC_C11_C10(dev_priv, pipe));
651  	csc->coeff[3] = tmp & 0xffff;
652  	csc->coeff[4] = tmp >> 16;
653  
654  	tmp = intel_de_read_fw(dev_priv, PIPE_WGC_C12(dev_priv, pipe));
655  	csc->coeff[5] = tmp & 0xffff;
656  
657  	tmp = intel_de_read_fw(dev_priv, PIPE_WGC_C21_C20(dev_priv, pipe));
658  	csc->coeff[6] = tmp & 0xffff;
659  	csc->coeff[7] = tmp >> 16;
660  
661  	tmp = intel_de_read_fw(dev_priv, PIPE_WGC_C22(dev_priv, pipe));
662  	csc->coeff[8] = tmp & 0xffff;
663  }
664  
vlv_read_csc(struct intel_crtc_state * crtc_state)665  static void vlv_read_csc(struct intel_crtc_state *crtc_state)
666  {
667  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
668  
669  	if (crtc_state->wgc_enable)
670  		vlv_read_wgc_csc(crtc, &crtc_state->csc);
671  }
672  
vlv_assign_csc(struct intel_crtc_state * crtc_state)673  static void vlv_assign_csc(struct intel_crtc_state *crtc_state)
674  {
675  	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
676  
677  	if (crtc_state->hw.ctm) {
678  		drm_WARN_ON(&i915->drm, !crtc_state->wgc_enable);
679  
680  		vlv_wgc_csc_convert_ctm(crtc_state, &crtc_state->csc);
681  	} else {
682  		drm_WARN_ON(&i915->drm, crtc_state->wgc_enable);
683  
684  		intel_csc_clear(&crtc_state->csc);
685  	}
686  }
687  
688  /*
689   * CHV Color Gamut Mapping (CGM) CSC
690   * |r|   | c0 c1 c2 |   |r|
691   * |g| = | c3 c4 c5 | x |g|
692   * |b|   | c6 c7 c8 |   |b|
693   *
694   * Coefficients are two's complement s4.12.
695   */
chv_cgm_csc_convert_ctm(const struct intel_crtc_state * crtc_state,struct intel_csc_matrix * csc)696  static void chv_cgm_csc_convert_ctm(const struct intel_crtc_state *crtc_state,
697  				    struct intel_csc_matrix *csc)
698  {
699  	const struct drm_color_ctm *ctm = crtc_state->hw.ctm->data;
700  	int i;
701  
702  	for (i = 0; i < 9; i++)
703  		csc->coeff[i] = ctm_to_twos_complement(ctm->matrix[i], 4, 12);
704  }
705  
706  #define CHV_CGM_CSC_COEFF_1_0 (1 << 12)
707  
708  static const struct intel_csc_matrix chv_cgm_csc_matrix_identity = {
709  	.coeff = {
710  		CHV_CGM_CSC_COEFF_1_0, 0, 0,
711  		0, CHV_CGM_CSC_COEFF_1_0, 0,
712  		0, 0, CHV_CGM_CSC_COEFF_1_0,
713  	},
714  };
715  
chv_load_cgm_csc(struct intel_crtc * crtc,const struct intel_csc_matrix * csc)716  static void chv_load_cgm_csc(struct intel_crtc *crtc,
717  			     const struct intel_csc_matrix *csc)
718  {
719  	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
720  	enum pipe pipe = crtc->pipe;
721  
722  	intel_de_write_fw(i915, CGM_PIPE_CSC_COEFF01(pipe),
723  			  csc->coeff[1] << 16 | csc->coeff[0]);
724  	intel_de_write_fw(i915, CGM_PIPE_CSC_COEFF23(pipe),
725  			  csc->coeff[3] << 16 | csc->coeff[2]);
726  	intel_de_write_fw(i915, CGM_PIPE_CSC_COEFF45(pipe),
727  			  csc->coeff[5] << 16 | csc->coeff[4]);
728  	intel_de_write_fw(i915, CGM_PIPE_CSC_COEFF67(pipe),
729  			  csc->coeff[7] << 16 | csc->coeff[6]);
730  	intel_de_write_fw(i915, CGM_PIPE_CSC_COEFF8(pipe),
731  			  csc->coeff[8]);
732  }
733  
chv_read_cgm_csc(struct intel_crtc * crtc,struct intel_csc_matrix * csc)734  static void chv_read_cgm_csc(struct intel_crtc *crtc,
735  			     struct intel_csc_matrix *csc)
736  {
737  	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
738  	enum pipe pipe = crtc->pipe;
739  	u32 tmp;
740  
741  	tmp = intel_de_read_fw(i915, CGM_PIPE_CSC_COEFF01(pipe));
742  	csc->coeff[0] = tmp & 0xffff;
743  	csc->coeff[1] = tmp >> 16;
744  
745  	tmp = intel_de_read_fw(i915, CGM_PIPE_CSC_COEFF23(pipe));
746  	csc->coeff[2] = tmp & 0xffff;
747  	csc->coeff[3] = tmp >> 16;
748  
749  	tmp = intel_de_read_fw(i915, CGM_PIPE_CSC_COEFF45(pipe));
750  	csc->coeff[4] = tmp & 0xffff;
751  	csc->coeff[5] = tmp >> 16;
752  
753  	tmp = intel_de_read_fw(i915, CGM_PIPE_CSC_COEFF67(pipe));
754  	csc->coeff[6] = tmp & 0xffff;
755  	csc->coeff[7] = tmp >> 16;
756  
757  	tmp = intel_de_read_fw(i915, CGM_PIPE_CSC_COEFF8(pipe));
758  	csc->coeff[8] = tmp & 0xffff;
759  }
760  
chv_read_csc(struct intel_crtc_state * crtc_state)761  static void chv_read_csc(struct intel_crtc_state *crtc_state)
762  {
763  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
764  
765  	if (crtc_state->cgm_mode & CGM_PIPE_MODE_CSC)
766  		chv_read_cgm_csc(crtc, &crtc_state->csc);
767  }
768  
chv_assign_csc(struct intel_crtc_state * crtc_state)769  static void chv_assign_csc(struct intel_crtc_state *crtc_state)
770  {
771  	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
772  
773  	drm_WARN_ON(&i915->drm, crtc_state->wgc_enable);
774  
775  	if (crtc_state->hw.ctm) {
776  		drm_WARN_ON(&i915->drm, (crtc_state->cgm_mode & CGM_PIPE_MODE_CSC) == 0);
777  
778  		chv_cgm_csc_convert_ctm(crtc_state, &crtc_state->csc);
779  	} else {
780  		drm_WARN_ON(&i915->drm, (crtc_state->cgm_mode & CGM_PIPE_MODE_CSC) == 0);
781  
782  		crtc_state->csc = chv_cgm_csc_matrix_identity;
783  	}
784  }
785  
786  /* convert hw value with given bit_precision to lut property val */
intel_color_lut_pack(u32 val,int bit_precision)787  static u32 intel_color_lut_pack(u32 val, int bit_precision)
788  {
789  	if (bit_precision > 16)
790  		return DIV_ROUND_CLOSEST_ULL(mul_u32_u32(val, (1 << 16) - 1),
791  					     (1 << bit_precision) - 1);
792  	else
793  		return DIV_ROUND_CLOSEST(val * ((1 << 16) - 1),
794  					 (1 << bit_precision) - 1);
795  }
796  
i9xx_lut_8(const struct drm_color_lut * color)797  static u32 i9xx_lut_8(const struct drm_color_lut *color)
798  {
799  	return REG_FIELD_PREP(PALETTE_RED_MASK, drm_color_lut_extract(color->red, 8)) |
800  		REG_FIELD_PREP(PALETTE_GREEN_MASK, drm_color_lut_extract(color->green, 8)) |
801  		REG_FIELD_PREP(PALETTE_BLUE_MASK, drm_color_lut_extract(color->blue, 8));
802  }
803  
i9xx_lut_8_pack(struct drm_color_lut * entry,u32 val)804  static void i9xx_lut_8_pack(struct drm_color_lut *entry, u32 val)
805  {
806  	entry->red = intel_color_lut_pack(REG_FIELD_GET(PALETTE_RED_MASK, val), 8);
807  	entry->green = intel_color_lut_pack(REG_FIELD_GET(PALETTE_GREEN_MASK, val), 8);
808  	entry->blue = intel_color_lut_pack(REG_FIELD_GET(PALETTE_BLUE_MASK, val), 8);
809  }
810  
811  /* i8xx/i9xx+ 10bit slope format "even DW" (low 8 bits) */
_i9xx_lut_10_ldw(u16 a)812  static u32 _i9xx_lut_10_ldw(u16 a)
813  {
814  	return drm_color_lut_extract(a, 10) & 0xff;
815  }
816  
i9xx_lut_10_ldw(const struct drm_color_lut * color)817  static u32 i9xx_lut_10_ldw(const struct drm_color_lut *color)
818  {
819  	return REG_FIELD_PREP(PALETTE_RED_MASK, _i9xx_lut_10_ldw(color[0].red)) |
820  		REG_FIELD_PREP(PALETTE_GREEN_MASK, _i9xx_lut_10_ldw(color[0].green)) |
821  		REG_FIELD_PREP(PALETTE_BLUE_MASK, _i9xx_lut_10_ldw(color[0].blue));
822  }
823  
824  /* i8xx/i9xx+ 10bit slope format "odd DW" (high 2 bits + slope) */
_i9xx_lut_10_udw(u16 a,u16 b)825  static u32 _i9xx_lut_10_udw(u16 a, u16 b)
826  {
827  	unsigned int mantissa, exponent;
828  
829  	a = drm_color_lut_extract(a, 10);
830  	b = drm_color_lut_extract(b, 10);
831  
832  	/* b = a + 8 * m * 2 ^ -e */
833  	mantissa = clamp(b - a, 0, 0x7f);
834  	exponent = 3;
835  	while (mantissa > 0xf) {
836  		mantissa >>= 1;
837  		exponent--;
838  	}
839  
840  	return (exponent << 6) |
841  		(mantissa << 2) |
842  		(a >> 8);
843  }
844  
i9xx_lut_10_udw(const struct drm_color_lut * color)845  static u32 i9xx_lut_10_udw(const struct drm_color_lut *color)
846  {
847  	return REG_FIELD_PREP(PALETTE_RED_MASK, _i9xx_lut_10_udw(color[0].red, color[1].red)) |
848  		REG_FIELD_PREP(PALETTE_GREEN_MASK, _i9xx_lut_10_udw(color[0].green, color[1].green)) |
849  		REG_FIELD_PREP(PALETTE_BLUE_MASK, _i9xx_lut_10_udw(color[0].blue, color[1].blue));
850  }
851  
i9xx_lut_10_pack(struct drm_color_lut * color,u32 ldw,u32 udw)852  static void i9xx_lut_10_pack(struct drm_color_lut *color,
853  			     u32 ldw, u32 udw)
854  {
855  	u16 red = REG_FIELD_GET(PALETTE_10BIT_RED_LDW_MASK, ldw) |
856  		REG_FIELD_GET(PALETTE_10BIT_RED_UDW_MASK, udw) << 8;
857  	u16 green = REG_FIELD_GET(PALETTE_10BIT_GREEN_LDW_MASK, ldw) |
858  		REG_FIELD_GET(PALETTE_10BIT_GREEN_UDW_MASK, udw) << 8;
859  	u16 blue = REG_FIELD_GET(PALETTE_10BIT_BLUE_LDW_MASK, ldw) |
860  		REG_FIELD_GET(PALETTE_10BIT_BLUE_UDW_MASK, udw) << 8;
861  
862  	color->red = intel_color_lut_pack(red, 10);
863  	color->green = intel_color_lut_pack(green, 10);
864  	color->blue = intel_color_lut_pack(blue, 10);
865  }
866  
i9xx_lut_10_pack_slope(struct drm_color_lut * color,u32 ldw,u32 udw)867  static void i9xx_lut_10_pack_slope(struct drm_color_lut *color,
868  				   u32 ldw, u32 udw)
869  {
870  	int r_exp = REG_FIELD_GET(PALETTE_10BIT_RED_EXP_MASK, udw);
871  	int r_mant = REG_FIELD_GET(PALETTE_10BIT_RED_MANT_MASK, udw);
872  	int g_exp = REG_FIELD_GET(PALETTE_10BIT_GREEN_EXP_MASK, udw);
873  	int g_mant = REG_FIELD_GET(PALETTE_10BIT_GREEN_MANT_MASK, udw);
874  	int b_exp = REG_FIELD_GET(PALETTE_10BIT_BLUE_EXP_MASK, udw);
875  	int b_mant = REG_FIELD_GET(PALETTE_10BIT_BLUE_MANT_MASK, udw);
876  
877  	i9xx_lut_10_pack(color, ldw, udw);
878  
879  	color->red += r_mant << (3 - r_exp);
880  	color->green += g_mant << (3 - g_exp);
881  	color->blue += b_mant << (3 - b_exp);
882  }
883  
884  /* i965+ "10.6" bit interpolated format "even DW" (low 8 bits) */
i965_lut_10p6_ldw(const struct drm_color_lut * color)885  static u32 i965_lut_10p6_ldw(const struct drm_color_lut *color)
886  {
887  	return REG_FIELD_PREP(PALETTE_RED_MASK, color->red & 0xff) |
888  		REG_FIELD_PREP(PALETTE_GREEN_MASK, color->green & 0xff) |
889  		REG_FIELD_PREP(PALETTE_BLUE_MASK, color->blue & 0xff);
890  }
891  
892  /* i965+ "10.6" interpolated format "odd DW" (high 8 bits) */
i965_lut_10p6_udw(const struct drm_color_lut * color)893  static u32 i965_lut_10p6_udw(const struct drm_color_lut *color)
894  {
895  	return REG_FIELD_PREP(PALETTE_RED_MASK, color->red >> 8) |
896  		REG_FIELD_PREP(PALETTE_GREEN_MASK, color->green >> 8) |
897  		REG_FIELD_PREP(PALETTE_BLUE_MASK, color->blue >> 8);
898  }
899  
i965_lut_10p6_pack(struct drm_color_lut * entry,u32 ldw,u32 udw)900  static void i965_lut_10p6_pack(struct drm_color_lut *entry, u32 ldw, u32 udw)
901  {
902  	entry->red = REG_FIELD_GET(PALETTE_RED_MASK, udw) << 8 |
903  		REG_FIELD_GET(PALETTE_RED_MASK, ldw);
904  	entry->green = REG_FIELD_GET(PALETTE_GREEN_MASK, udw) << 8 |
905  		REG_FIELD_GET(PALETTE_GREEN_MASK, ldw);
906  	entry->blue = REG_FIELD_GET(PALETTE_BLUE_MASK, udw) << 8 |
907  		REG_FIELD_GET(PALETTE_BLUE_MASK, ldw);
908  }
909  
i965_lut_11p6_max_pack(u32 val)910  static u16 i965_lut_11p6_max_pack(u32 val)
911  {
912  	/* PIPEGCMAX is 11.6, clamp to 10.6 */
913  	return min(val, 0xffffu);
914  }
915  
ilk_lut_10(const struct drm_color_lut * color)916  static u32 ilk_lut_10(const struct drm_color_lut *color)
917  {
918  	return REG_FIELD_PREP(PREC_PALETTE_10_RED_MASK, drm_color_lut_extract(color->red, 10)) |
919  		REG_FIELD_PREP(PREC_PALETTE_10_GREEN_MASK, drm_color_lut_extract(color->green, 10)) |
920  		REG_FIELD_PREP(PREC_PALETTE_10_BLUE_MASK, drm_color_lut_extract(color->blue, 10));
921  }
922  
ilk_lut_10_pack(struct drm_color_lut * entry,u32 val)923  static void ilk_lut_10_pack(struct drm_color_lut *entry, u32 val)
924  {
925  	entry->red = intel_color_lut_pack(REG_FIELD_GET(PREC_PALETTE_10_RED_MASK, val), 10);
926  	entry->green = intel_color_lut_pack(REG_FIELD_GET(PREC_PALETTE_10_GREEN_MASK, val), 10);
927  	entry->blue = intel_color_lut_pack(REG_FIELD_GET(PREC_PALETTE_10_BLUE_MASK, val), 10);
928  }
929  
930  /* ilk+ "12.4" interpolated format (low 6 bits) */
ilk_lut_12p4_ldw(const struct drm_color_lut * color)931  static u32 ilk_lut_12p4_ldw(const struct drm_color_lut *color)
932  {
933  	return REG_FIELD_PREP(PREC_PALETTE_12P4_RED_LDW_MASK, color->red & 0x3f) |
934  		REG_FIELD_PREP(PREC_PALETTE_12P4_GREEN_LDW_MASK, color->green & 0x3f) |
935  		REG_FIELD_PREP(PREC_PALETTE_12P4_BLUE_LDW_MASK, color->blue & 0x3f);
936  }
937  
938  /* ilk+ "12.4" interpolated format (high 10 bits) */
ilk_lut_12p4_udw(const struct drm_color_lut * color)939  static u32 ilk_lut_12p4_udw(const struct drm_color_lut *color)
940  {
941  	return REG_FIELD_PREP(PREC_PALETTE_12P4_RED_UDW_MASK, color->red >> 6) |
942  		REG_FIELD_PREP(PREC_PALETTE_12P4_GREEN_UDW_MASK, color->green >> 6) |
943  		REG_FIELD_PREP(PREC_PALETTE_12P4_BLUE_UDW_MASK, color->blue >> 6);
944  }
945  
ilk_lut_12p4_pack(struct drm_color_lut * entry,u32 ldw,u32 udw)946  static void ilk_lut_12p4_pack(struct drm_color_lut *entry, u32 ldw, u32 udw)
947  {
948  	entry->red = REG_FIELD_GET(PREC_PALETTE_12P4_RED_UDW_MASK, udw) << 6 |
949  		REG_FIELD_GET(PREC_PALETTE_12P4_RED_LDW_MASK, ldw);
950  	entry->green = REG_FIELD_GET(PREC_PALETTE_12P4_GREEN_UDW_MASK, udw) << 6 |
951  		REG_FIELD_GET(PREC_PALETTE_12P4_GREEN_LDW_MASK, ldw);
952  	entry->blue = REG_FIELD_GET(PREC_PALETTE_12P4_BLUE_UDW_MASK, udw) << 6 |
953  		REG_FIELD_GET(PREC_PALETTE_12P4_BLUE_LDW_MASK, ldw);
954  }
955  
icl_color_commit_noarm(const struct intel_crtc_state * crtc_state)956  static void icl_color_commit_noarm(const struct intel_crtc_state *crtc_state)
957  {
958  	/*
959  	 * Despite Wa_1406463849, ICL no longer suffers from the SKL
960  	 * DC5/PSR CSC black screen issue (see skl_color_commit_noarm()).
961  	 * Possibly due to the extra sticky CSC arming
962  	 * (see icl_color_post_update()).
963  	 *
964  	 * On TGL+ all CSC arming issues have been properly fixed.
965  	 */
966  	icl_load_csc_matrix(crtc_state);
967  }
968  
skl_color_commit_noarm(const struct intel_crtc_state * crtc_state)969  static void skl_color_commit_noarm(const struct intel_crtc_state *crtc_state)
970  {
971  	/*
972  	 * Possibly related to display WA #1184, SKL CSC loses the latched
973  	 * CSC coeff/offset register values if the CSC registers are disarmed
974  	 * between DC5 exit and PSR exit. This will cause the plane(s) to
975  	 * output all black (until CSC_MODE is rearmed and properly latched).
976  	 * Once PSR exit (and proper register latching) has occurred the
977  	 * danger is over. Thus when PSR is enabled the CSC coeff/offset
978  	 * register programming will be peformed from skl_color_commit_arm()
979  	 * which is called after PSR exit.
980  	 */
981  	if (!crtc_state->has_psr)
982  		ilk_load_csc_matrix(crtc_state);
983  }
984  
ilk_color_commit_noarm(const struct intel_crtc_state * crtc_state)985  static void ilk_color_commit_noarm(const struct intel_crtc_state *crtc_state)
986  {
987  	ilk_load_csc_matrix(crtc_state);
988  }
989  
i9xx_color_commit_arm(const struct intel_crtc_state * crtc_state)990  static void i9xx_color_commit_arm(const struct intel_crtc_state *crtc_state)
991  {
992  	/* update TRANSCONF GAMMA_MODE */
993  	i9xx_set_pipeconf(crtc_state);
994  }
995  
ilk_color_commit_arm(const struct intel_crtc_state * crtc_state)996  static void ilk_color_commit_arm(const struct intel_crtc_state *crtc_state)
997  {
998  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
999  	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
1000  
1001  	/* update TRANSCONF GAMMA_MODE */
1002  	ilk_set_pipeconf(crtc_state);
1003  
1004  	intel_de_write_fw(i915, PIPE_CSC_MODE(crtc->pipe),
1005  			  crtc_state->csc_mode);
1006  }
1007  
hsw_color_commit_arm(const struct intel_crtc_state * crtc_state)1008  static void hsw_color_commit_arm(const struct intel_crtc_state *crtc_state)
1009  {
1010  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
1011  	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
1012  
1013  	intel_de_write(i915, GAMMA_MODE(crtc->pipe),
1014  		       crtc_state->gamma_mode);
1015  
1016  	intel_de_write_fw(i915, PIPE_CSC_MODE(crtc->pipe),
1017  			  crtc_state->csc_mode);
1018  }
1019  
hsw_read_gamma_mode(struct intel_crtc * crtc)1020  static u32 hsw_read_gamma_mode(struct intel_crtc *crtc)
1021  {
1022  	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
1023  
1024  	return intel_de_read(i915, GAMMA_MODE(crtc->pipe));
1025  }
1026  
ilk_read_csc_mode(struct intel_crtc * crtc)1027  static u32 ilk_read_csc_mode(struct intel_crtc *crtc)
1028  {
1029  	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
1030  
1031  	return intel_de_read(i915, PIPE_CSC_MODE(crtc->pipe));
1032  }
1033  
i9xx_get_config(struct intel_crtc_state * crtc_state)1034  static void i9xx_get_config(struct intel_crtc_state *crtc_state)
1035  {
1036  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
1037  	struct intel_plane *plane = to_intel_plane(crtc->base.primary);
1038  	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
1039  	enum i9xx_plane_id i9xx_plane = plane->i9xx_plane;
1040  	u32 tmp;
1041  
1042  	tmp = intel_de_read(dev_priv, DSPCNTR(dev_priv, i9xx_plane));
1043  
1044  	if (tmp & DISP_PIPE_GAMMA_ENABLE)
1045  		crtc_state->gamma_enable = true;
1046  
1047  	if (!HAS_GMCH(dev_priv) && tmp & DISP_PIPE_CSC_ENABLE)
1048  		crtc_state->csc_enable = true;
1049  }
1050  
hsw_get_config(struct intel_crtc_state * crtc_state)1051  static void hsw_get_config(struct intel_crtc_state *crtc_state)
1052  {
1053  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
1054  
1055  	crtc_state->gamma_mode = hsw_read_gamma_mode(crtc);
1056  	crtc_state->csc_mode = ilk_read_csc_mode(crtc);
1057  
1058  	i9xx_get_config(crtc_state);
1059  }
1060  
skl_get_config(struct intel_crtc_state * crtc_state)1061  static void skl_get_config(struct intel_crtc_state *crtc_state)
1062  {
1063  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
1064  	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
1065  	u32 tmp;
1066  
1067  	crtc_state->gamma_mode = hsw_read_gamma_mode(crtc);
1068  	crtc_state->csc_mode = ilk_read_csc_mode(crtc);
1069  
1070  	tmp = intel_de_read(i915, SKL_BOTTOM_COLOR(crtc->pipe));
1071  
1072  	if (tmp & SKL_BOTTOM_COLOR_GAMMA_ENABLE)
1073  		crtc_state->gamma_enable = true;
1074  
1075  	if (tmp & SKL_BOTTOM_COLOR_CSC_ENABLE)
1076  		crtc_state->csc_enable = true;
1077  }
1078  
skl_color_commit_arm(const struct intel_crtc_state * crtc_state)1079  static void skl_color_commit_arm(const struct intel_crtc_state *crtc_state)
1080  {
1081  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
1082  	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
1083  	enum pipe pipe = crtc->pipe;
1084  	u32 val = 0;
1085  
1086  	if (crtc_state->has_psr)
1087  		ilk_load_csc_matrix(crtc_state);
1088  
1089  	/*
1090  	 * We don't (yet) allow userspace to control the pipe background color,
1091  	 * so force it to black, but apply pipe gamma and CSC appropriately
1092  	 * so that its handling will match how we program our planes.
1093  	 */
1094  	if (crtc_state->gamma_enable)
1095  		val |= SKL_BOTTOM_COLOR_GAMMA_ENABLE;
1096  	if (crtc_state->csc_enable)
1097  		val |= SKL_BOTTOM_COLOR_CSC_ENABLE;
1098  	intel_de_write(i915, SKL_BOTTOM_COLOR(pipe), val);
1099  
1100  	intel_de_write(i915, GAMMA_MODE(crtc->pipe),
1101  		       crtc_state->gamma_mode);
1102  
1103  	intel_de_write_fw(i915, PIPE_CSC_MODE(crtc->pipe),
1104  			  crtc_state->csc_mode);
1105  }
1106  
icl_color_commit_arm(const struct intel_crtc_state * crtc_state)1107  static void icl_color_commit_arm(const struct intel_crtc_state *crtc_state)
1108  {
1109  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
1110  	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
1111  	enum pipe pipe = crtc->pipe;
1112  
1113  	/*
1114  	 * We don't (yet) allow userspace to control the pipe background color,
1115  	 * so force it to black.
1116  	 */
1117  	intel_de_write(i915, SKL_BOTTOM_COLOR(pipe), 0);
1118  
1119  	intel_de_write(i915, GAMMA_MODE(crtc->pipe),
1120  		       crtc_state->gamma_mode);
1121  
1122  	intel_de_write_fw(i915, PIPE_CSC_MODE(crtc->pipe),
1123  			  crtc_state->csc_mode);
1124  }
1125  
icl_color_post_update(const struct intel_crtc_state * crtc_state)1126  static void icl_color_post_update(const struct intel_crtc_state *crtc_state)
1127  {
1128  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
1129  	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
1130  
1131  	/*
1132  	 * Despite Wa_1406463849, ICL CSC is no longer disarmed by
1133  	 * coeff/offset register *writes*. Instead, once CSC_MODE
1134  	 * is armed it stays armed, even after it has been latched.
1135  	 * Afterwards the coeff/offset registers become effectively
1136  	 * self-arming. That self-arming must be disabled before the
1137  	 * next icl_color_commit_noarm() tries to write the next set
1138  	 * of coeff/offset registers. Fortunately register *reads*
1139  	 * do still disarm the CSC. Naturally this must not be done
1140  	 * until the previously written CSC registers have actually
1141  	 * been latched.
1142  	 *
1143  	 * TGL+ no longer need this workaround.
1144  	 */
1145  	intel_de_read_fw(i915, PIPE_CSC_PREOFF_HI(crtc->pipe));
1146  }
1147  
1148  static struct drm_property_blob *
create_linear_lut(struct drm_i915_private * i915,int lut_size)1149  create_linear_lut(struct drm_i915_private *i915, int lut_size)
1150  {
1151  	struct drm_property_blob *blob;
1152  	struct drm_color_lut *lut;
1153  	int i;
1154  
1155  	blob = drm_property_create_blob(&i915->drm,
1156  					sizeof(lut[0]) * lut_size,
1157  					NULL);
1158  	if (IS_ERR(blob))
1159  		return blob;
1160  
1161  	lut = blob->data;
1162  
1163  	for (i = 0; i < lut_size; i++) {
1164  		u16 val = 0xffff * i / (lut_size - 1);
1165  
1166  		lut[i].red = val;
1167  		lut[i].green = val;
1168  		lut[i].blue = val;
1169  	}
1170  
1171  	return blob;
1172  }
1173  
lut_limited_range(unsigned int value)1174  static u16 lut_limited_range(unsigned int value)
1175  {
1176  	unsigned int min = 16 << 8;
1177  	unsigned int max = 235 << 8;
1178  
1179  	return value * (max - min) / 0xffff + min;
1180  }
1181  
1182  static struct drm_property_blob *
create_resized_lut(struct drm_i915_private * i915,const struct drm_property_blob * blob_in,int lut_out_size,bool limited_color_range)1183  create_resized_lut(struct drm_i915_private *i915,
1184  		   const struct drm_property_blob *blob_in, int lut_out_size,
1185  		   bool limited_color_range)
1186  {
1187  	int i, lut_in_size = drm_color_lut_size(blob_in);
1188  	struct drm_property_blob *blob_out;
1189  	const struct drm_color_lut *lut_in;
1190  	struct drm_color_lut *lut_out;
1191  
1192  	blob_out = drm_property_create_blob(&i915->drm,
1193  					    sizeof(lut_out[0]) * lut_out_size,
1194  					    NULL);
1195  	if (IS_ERR(blob_out))
1196  		return blob_out;
1197  
1198  	lut_in = blob_in->data;
1199  	lut_out = blob_out->data;
1200  
1201  	for (i = 0; i < lut_out_size; i++) {
1202  		const struct drm_color_lut *entry =
1203  			&lut_in[i * (lut_in_size - 1) / (lut_out_size - 1)];
1204  
1205  		if (limited_color_range) {
1206  			lut_out[i].red = lut_limited_range(entry->red);
1207  			lut_out[i].green = lut_limited_range(entry->green);
1208  			lut_out[i].blue = lut_limited_range(entry->blue);
1209  		} else {
1210  			lut_out[i] = *entry;
1211  		}
1212  	}
1213  
1214  	return blob_out;
1215  }
1216  
i9xx_load_lut_8(struct intel_crtc * crtc,const struct drm_property_blob * blob)1217  static void i9xx_load_lut_8(struct intel_crtc *crtc,
1218  			    const struct drm_property_blob *blob)
1219  {
1220  	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
1221  	const struct drm_color_lut *lut;
1222  	enum pipe pipe = crtc->pipe;
1223  	int i;
1224  
1225  	if (!blob)
1226  		return;
1227  
1228  	lut = blob->data;
1229  
1230  	for (i = 0; i < 256; i++)
1231  		intel_de_write_fw(dev_priv, PALETTE(dev_priv, pipe, i),
1232  				  i9xx_lut_8(&lut[i]));
1233  }
1234  
i9xx_load_lut_10(struct intel_crtc * crtc,const struct drm_property_blob * blob)1235  static void i9xx_load_lut_10(struct intel_crtc *crtc,
1236  			     const struct drm_property_blob *blob)
1237  {
1238  	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
1239  	const struct drm_color_lut *lut = blob->data;
1240  	int i, lut_size = drm_color_lut_size(blob);
1241  	enum pipe pipe = crtc->pipe;
1242  
1243  	for (i = 0; i < lut_size - 1; i++) {
1244  		intel_de_write_fw(dev_priv,
1245  				  PALETTE(dev_priv, pipe, 2 * i + 0),
1246  				  i9xx_lut_10_ldw(&lut[i]));
1247  		intel_de_write_fw(dev_priv,
1248  				  PALETTE(dev_priv, pipe, 2 * i + 1),
1249  				  i9xx_lut_10_udw(&lut[i]));
1250  	}
1251  }
1252  
i9xx_load_luts(const struct intel_crtc_state * crtc_state)1253  static void i9xx_load_luts(const struct intel_crtc_state *crtc_state)
1254  {
1255  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
1256  	const struct drm_property_blob *post_csc_lut = crtc_state->post_csc_lut;
1257  
1258  	switch (crtc_state->gamma_mode) {
1259  	case GAMMA_MODE_MODE_8BIT:
1260  		i9xx_load_lut_8(crtc, post_csc_lut);
1261  		break;
1262  	case GAMMA_MODE_MODE_10BIT:
1263  		i9xx_load_lut_10(crtc, post_csc_lut);
1264  		break;
1265  	default:
1266  		MISSING_CASE(crtc_state->gamma_mode);
1267  		break;
1268  	}
1269  }
1270  
i965_load_lut_10p6(struct intel_crtc * crtc,const struct drm_property_blob * blob)1271  static void i965_load_lut_10p6(struct intel_crtc *crtc,
1272  			       const struct drm_property_blob *blob)
1273  {
1274  	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
1275  	const struct drm_color_lut *lut = blob->data;
1276  	int i, lut_size = drm_color_lut_size(blob);
1277  	enum pipe pipe = crtc->pipe;
1278  
1279  	for (i = 0; i < lut_size - 1; i++) {
1280  		intel_de_write_fw(dev_priv,
1281  				  PALETTE(dev_priv, pipe, 2 * i + 0),
1282  				  i965_lut_10p6_ldw(&lut[i]));
1283  		intel_de_write_fw(dev_priv,
1284  				  PALETTE(dev_priv, pipe, 2 * i + 1),
1285  				  i965_lut_10p6_udw(&lut[i]));
1286  	}
1287  
1288  	intel_de_write_fw(dev_priv, PIPEGCMAX(dev_priv, pipe, 0), lut[i].red);
1289  	intel_de_write_fw(dev_priv, PIPEGCMAX(dev_priv, pipe, 1), lut[i].green);
1290  	intel_de_write_fw(dev_priv, PIPEGCMAX(dev_priv, pipe, 2), lut[i].blue);
1291  }
1292  
i965_load_luts(const struct intel_crtc_state * crtc_state)1293  static void i965_load_luts(const struct intel_crtc_state *crtc_state)
1294  {
1295  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
1296  	const struct drm_property_blob *post_csc_lut = crtc_state->post_csc_lut;
1297  
1298  	switch (crtc_state->gamma_mode) {
1299  	case GAMMA_MODE_MODE_8BIT:
1300  		i9xx_load_lut_8(crtc, post_csc_lut);
1301  		break;
1302  	case GAMMA_MODE_MODE_10BIT:
1303  		i965_load_lut_10p6(crtc, post_csc_lut);
1304  		break;
1305  	default:
1306  		MISSING_CASE(crtc_state->gamma_mode);
1307  		break;
1308  	}
1309  }
1310  
ilk_lut_write(const struct intel_crtc_state * crtc_state,i915_reg_t reg,u32 val)1311  static void ilk_lut_write(const struct intel_crtc_state *crtc_state,
1312  			  i915_reg_t reg, u32 val)
1313  {
1314  	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
1315  
1316  	if (crtc_state->dsb_color_vblank)
1317  		intel_dsb_reg_write(crtc_state->dsb_color_vblank, reg, val);
1318  	else
1319  		intel_de_write_fw(i915, reg, val);
1320  }
1321  
ilk_load_lut_8(const struct intel_crtc_state * crtc_state,const struct drm_property_blob * blob)1322  static void ilk_load_lut_8(const struct intel_crtc_state *crtc_state,
1323  			   const struct drm_property_blob *blob)
1324  {
1325  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
1326  	const struct drm_color_lut *lut;
1327  	enum pipe pipe = crtc->pipe;
1328  	int i;
1329  
1330  	if (!blob)
1331  		return;
1332  
1333  	lut = blob->data;
1334  
1335  	/*
1336  	 * DSB fails to correctly load the legacy LUT
1337  	 * unless we either write each entry twice,
1338  	 * or use non-posted writes
1339  	 */
1340  	if (crtc_state->dsb_color_vblank)
1341  		intel_dsb_nonpost_start(crtc_state->dsb_color_vblank);
1342  
1343  	for (i = 0; i < 256; i++)
1344  		ilk_lut_write(crtc_state, LGC_PALETTE(pipe, i),
1345  			      i9xx_lut_8(&lut[i]));
1346  
1347  	if (crtc_state->dsb_color_vblank)
1348  		intel_dsb_nonpost_end(crtc_state->dsb_color_vblank);
1349  }
1350  
ilk_load_lut_10(const struct intel_crtc_state * crtc_state,const struct drm_property_blob * blob)1351  static void ilk_load_lut_10(const struct intel_crtc_state *crtc_state,
1352  			    const struct drm_property_blob *blob)
1353  {
1354  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
1355  	const struct drm_color_lut *lut = blob->data;
1356  	int i, lut_size = drm_color_lut_size(blob);
1357  	enum pipe pipe = crtc->pipe;
1358  
1359  	for (i = 0; i < lut_size; i++)
1360  		ilk_lut_write(crtc_state, PREC_PALETTE(pipe, i),
1361  			      ilk_lut_10(&lut[i]));
1362  }
1363  
ilk_load_luts(const struct intel_crtc_state * crtc_state)1364  static void ilk_load_luts(const struct intel_crtc_state *crtc_state)
1365  {
1366  	const struct drm_property_blob *post_csc_lut = crtc_state->post_csc_lut;
1367  	const struct drm_property_blob *pre_csc_lut = crtc_state->pre_csc_lut;
1368  	const struct drm_property_blob *blob = post_csc_lut ?: pre_csc_lut;
1369  
1370  	switch (crtc_state->gamma_mode) {
1371  	case GAMMA_MODE_MODE_8BIT:
1372  		ilk_load_lut_8(crtc_state, blob);
1373  		break;
1374  	case GAMMA_MODE_MODE_10BIT:
1375  		ilk_load_lut_10(crtc_state, blob);
1376  		break;
1377  	default:
1378  		MISSING_CASE(crtc_state->gamma_mode);
1379  		break;
1380  	}
1381  }
1382  
ivb_lut_10_size(u32 prec_index)1383  static int ivb_lut_10_size(u32 prec_index)
1384  {
1385  	if (prec_index & PAL_PREC_SPLIT_MODE)
1386  		return 512;
1387  	else
1388  		return 1024;
1389  }
1390  
1391  /*
1392   * IVB/HSW Bspec / PAL_PREC_INDEX:
1393   * "Restriction : Index auto increment mode is not
1394   *  supported and must not be enabled."
1395   */
ivb_load_lut_10(const struct intel_crtc_state * crtc_state,const struct drm_property_blob * blob,u32 prec_index)1396  static void ivb_load_lut_10(const struct intel_crtc_state *crtc_state,
1397  			    const struct drm_property_blob *blob,
1398  			    u32 prec_index)
1399  {
1400  	const struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
1401  	const struct drm_color_lut *lut = blob->data;
1402  	int i, lut_size = drm_color_lut_size(blob);
1403  	enum pipe pipe = crtc->pipe;
1404  
1405  	for (i = 0; i < lut_size; i++) {
1406  		ilk_lut_write(crtc_state, PREC_PAL_INDEX(pipe),
1407  			      prec_index + i);
1408  		ilk_lut_write(crtc_state, PREC_PAL_DATA(pipe),
1409  			      ilk_lut_10(&lut[i]));
1410  	}
1411  
1412  	/*
1413  	 * Reset the index, otherwise it prevents the legacy palette to be
1414  	 * written properly.
1415  	 */
1416  	ilk_lut_write(crtc_state, PREC_PAL_INDEX(pipe),
1417  		      PAL_PREC_INDEX_VALUE(0));
1418  }
1419  
1420  /* On BDW+ the index auto increment mode actually works */
bdw_load_lut_10(const struct intel_crtc_state * crtc_state,const struct drm_property_blob * blob,u32 prec_index)1421  static void bdw_load_lut_10(const struct intel_crtc_state *crtc_state,
1422  			    const struct drm_property_blob *blob,
1423  			    u32 prec_index)
1424  {
1425  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
1426  	const struct drm_color_lut *lut = blob->data;
1427  	int i, lut_size = drm_color_lut_size(blob);
1428  	enum pipe pipe = crtc->pipe;
1429  
1430  	ilk_lut_write(crtc_state, PREC_PAL_INDEX(pipe),
1431  		      prec_index);
1432  	ilk_lut_write(crtc_state, PREC_PAL_INDEX(pipe),
1433  		      PAL_PREC_AUTO_INCREMENT |
1434  		      prec_index);
1435  
1436  	for (i = 0; i < lut_size; i++)
1437  		ilk_lut_write(crtc_state, PREC_PAL_DATA(pipe),
1438  			      ilk_lut_10(&lut[i]));
1439  
1440  	/*
1441  	 * Reset the index, otherwise it prevents the legacy palette to be
1442  	 * written properly.
1443  	 */
1444  	ilk_lut_write(crtc_state, PREC_PAL_INDEX(pipe),
1445  		      PAL_PREC_INDEX_VALUE(0));
1446  }
1447  
ivb_load_lut_ext_max(const struct intel_crtc_state * crtc_state)1448  static void ivb_load_lut_ext_max(const struct intel_crtc_state *crtc_state)
1449  {
1450  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
1451  	enum pipe pipe = crtc->pipe;
1452  
1453  	/* Program the max register to clamp values > 1.0. */
1454  	ilk_lut_write(crtc_state, PREC_PAL_EXT_GC_MAX(pipe, 0), 1 << 16);
1455  	ilk_lut_write(crtc_state, PREC_PAL_EXT_GC_MAX(pipe, 1), 1 << 16);
1456  	ilk_lut_write(crtc_state, PREC_PAL_EXT_GC_MAX(pipe, 2), 1 << 16);
1457  }
1458  
glk_load_lut_ext2_max(const struct intel_crtc_state * crtc_state)1459  static void glk_load_lut_ext2_max(const struct intel_crtc_state *crtc_state)
1460  {
1461  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
1462  	enum pipe pipe = crtc->pipe;
1463  
1464  	/* Program the max register to clamp values > 1.0. */
1465  	ilk_lut_write(crtc_state, PREC_PAL_EXT2_GC_MAX(pipe, 0), 1 << 16);
1466  	ilk_lut_write(crtc_state, PREC_PAL_EXT2_GC_MAX(pipe, 1), 1 << 16);
1467  	ilk_lut_write(crtc_state, PREC_PAL_EXT2_GC_MAX(pipe, 2), 1 << 16);
1468  }
1469  
ivb_load_luts(const struct intel_crtc_state * crtc_state)1470  static void ivb_load_luts(const struct intel_crtc_state *crtc_state)
1471  {
1472  	const struct drm_property_blob *post_csc_lut = crtc_state->post_csc_lut;
1473  	const struct drm_property_blob *pre_csc_lut = crtc_state->pre_csc_lut;
1474  	const struct drm_property_blob *blob = post_csc_lut ?: pre_csc_lut;
1475  
1476  	switch (crtc_state->gamma_mode) {
1477  	case GAMMA_MODE_MODE_8BIT:
1478  		ilk_load_lut_8(crtc_state, blob);
1479  		break;
1480  	case GAMMA_MODE_MODE_SPLIT:
1481  		ivb_load_lut_10(crtc_state, pre_csc_lut, PAL_PREC_SPLIT_MODE |
1482  				PAL_PREC_INDEX_VALUE(0));
1483  		ivb_load_lut_ext_max(crtc_state);
1484  		ivb_load_lut_10(crtc_state, post_csc_lut, PAL_PREC_SPLIT_MODE |
1485  				PAL_PREC_INDEX_VALUE(512));
1486  		break;
1487  	case GAMMA_MODE_MODE_10BIT:
1488  		ivb_load_lut_10(crtc_state, blob,
1489  				PAL_PREC_INDEX_VALUE(0));
1490  		ivb_load_lut_ext_max(crtc_state);
1491  		break;
1492  	default:
1493  		MISSING_CASE(crtc_state->gamma_mode);
1494  		break;
1495  	}
1496  }
1497  
bdw_load_luts(const struct intel_crtc_state * crtc_state)1498  static void bdw_load_luts(const struct intel_crtc_state *crtc_state)
1499  {
1500  	const struct drm_property_blob *post_csc_lut = crtc_state->post_csc_lut;
1501  	const struct drm_property_blob *pre_csc_lut = crtc_state->pre_csc_lut;
1502  	const struct drm_property_blob *blob = post_csc_lut ?: pre_csc_lut;
1503  
1504  	switch (crtc_state->gamma_mode) {
1505  	case GAMMA_MODE_MODE_8BIT:
1506  		ilk_load_lut_8(crtc_state, blob);
1507  		break;
1508  	case GAMMA_MODE_MODE_SPLIT:
1509  		bdw_load_lut_10(crtc_state, pre_csc_lut, PAL_PREC_SPLIT_MODE |
1510  				PAL_PREC_INDEX_VALUE(0));
1511  		ivb_load_lut_ext_max(crtc_state);
1512  		bdw_load_lut_10(crtc_state, post_csc_lut, PAL_PREC_SPLIT_MODE |
1513  				PAL_PREC_INDEX_VALUE(512));
1514  		break;
1515  	case GAMMA_MODE_MODE_10BIT:
1516  		bdw_load_lut_10(crtc_state, blob,
1517  				PAL_PREC_INDEX_VALUE(0));
1518  		ivb_load_lut_ext_max(crtc_state);
1519  		break;
1520  	default:
1521  		MISSING_CASE(crtc_state->gamma_mode);
1522  		break;
1523  	}
1524  }
1525  
glk_degamma_lut_size(struct drm_i915_private * i915)1526  static int glk_degamma_lut_size(struct drm_i915_private *i915)
1527  {
1528  	if (DISPLAY_VER(i915) >= 13)
1529  		return 131;
1530  	else
1531  		return 35;
1532  }
1533  
glk_degamma_lut(const struct drm_color_lut * color)1534  static u32 glk_degamma_lut(const struct drm_color_lut *color)
1535  {
1536  	return color->green;
1537  }
1538  
glk_degamma_lut_pack(struct drm_color_lut * entry,u32 val)1539  static void glk_degamma_lut_pack(struct drm_color_lut *entry, u32 val)
1540  {
1541  	/* PRE_CSC_GAMC_DATA is 3.16, clamp to 0.16 */
1542  	entry->red = entry->green = entry->blue = min(val, 0xffffu);
1543  }
1544  
mtl_degamma_lut(const struct drm_color_lut * color)1545  static u32 mtl_degamma_lut(const struct drm_color_lut *color)
1546  {
1547  	return drm_color_lut_extract(color->green, 24);
1548  }
1549  
mtl_degamma_lut_pack(struct drm_color_lut * entry,u32 val)1550  static void mtl_degamma_lut_pack(struct drm_color_lut *entry, u32 val)
1551  {
1552  	/* PRE_CSC_GAMC_DATA is 3.24, clamp to 0.16 */
1553  	entry->red = entry->green = entry->blue =
1554  		intel_color_lut_pack(min(val, 0xffffffu), 24);
1555  }
1556  
glk_load_degamma_lut(const struct intel_crtc_state * crtc_state,const struct drm_property_blob * blob)1557  static void glk_load_degamma_lut(const struct intel_crtc_state *crtc_state,
1558  				 const struct drm_property_blob *blob)
1559  {
1560  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
1561  	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
1562  	const struct drm_color_lut *lut = blob->data;
1563  	int i, lut_size = drm_color_lut_size(blob);
1564  	enum pipe pipe = crtc->pipe;
1565  
1566  	/*
1567  	 * When setting the auto-increment bit, the hardware seems to
1568  	 * ignore the index bits, so we need to reset it to index 0
1569  	 * separately.
1570  	 */
1571  	ilk_lut_write(crtc_state, PRE_CSC_GAMC_INDEX(pipe),
1572  		      PRE_CSC_GAMC_INDEX_VALUE(0));
1573  	ilk_lut_write(crtc_state, PRE_CSC_GAMC_INDEX(pipe),
1574  		      PRE_CSC_GAMC_AUTO_INCREMENT |
1575  		      PRE_CSC_GAMC_INDEX_VALUE(0));
1576  
1577  	for (i = 0; i < lut_size; i++) {
1578  		/*
1579  		 * First lut_size entries represent range from 0 to 1.0
1580  		 * 3 additional lut entries will represent extended range
1581  		 * inputs 3.0 and 7.0 respectively, currently clamped
1582  		 * at 1.0. Since the precision is 16bit, the user
1583  		 * value can be directly filled to register.
1584  		 * The pipe degamma table in GLK+ onwards doesn't
1585  		 * support different values per channel, so this just
1586  		 * programs green value which will be equal to Red and
1587  		 * Blue into the lut registers.
1588  		 * ToDo: Extend to max 7.0. Enable 32 bit input value
1589  		 * as compared to just 16 to achieve this.
1590  		 */
1591  		ilk_lut_write(crtc_state, PRE_CSC_GAMC_DATA(pipe),
1592  			      DISPLAY_VER(i915) >= 14 ?
1593  			      mtl_degamma_lut(&lut[i]) : glk_degamma_lut(&lut[i]));
1594  	}
1595  
1596  	/* Clamp values > 1.0. */
1597  	while (i++ < glk_degamma_lut_size(i915))
1598  		ilk_lut_write(crtc_state, PRE_CSC_GAMC_DATA(pipe),
1599  			      DISPLAY_VER(i915) >= 14 ?
1600  			      1 << 24 : 1 << 16);
1601  
1602  	ilk_lut_write(crtc_state, PRE_CSC_GAMC_INDEX(pipe), 0);
1603  }
1604  
glk_load_luts(const struct intel_crtc_state * crtc_state)1605  static void glk_load_luts(const struct intel_crtc_state *crtc_state)
1606  {
1607  	const struct drm_property_blob *pre_csc_lut = crtc_state->pre_csc_lut;
1608  	const struct drm_property_blob *post_csc_lut = crtc_state->post_csc_lut;
1609  
1610  	if (pre_csc_lut)
1611  		glk_load_degamma_lut(crtc_state, pre_csc_lut);
1612  
1613  	switch (crtc_state->gamma_mode) {
1614  	case GAMMA_MODE_MODE_8BIT:
1615  		ilk_load_lut_8(crtc_state, post_csc_lut);
1616  		break;
1617  	case GAMMA_MODE_MODE_10BIT:
1618  		bdw_load_lut_10(crtc_state, post_csc_lut, PAL_PREC_INDEX_VALUE(0));
1619  		ivb_load_lut_ext_max(crtc_state);
1620  		glk_load_lut_ext2_max(crtc_state);
1621  		break;
1622  	default:
1623  		MISSING_CASE(crtc_state->gamma_mode);
1624  		break;
1625  	}
1626  }
1627  
1628  static void
ivb_load_lut_max(const struct intel_crtc_state * crtc_state,const struct drm_color_lut * color)1629  ivb_load_lut_max(const struct intel_crtc_state *crtc_state,
1630  		 const struct drm_color_lut *color)
1631  {
1632  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
1633  	enum pipe pipe = crtc->pipe;
1634  
1635  	/* FIXME LUT entries are 16 bit only, so we can prog 0xFFFF max */
1636  	ilk_lut_write(crtc_state, PREC_PAL_GC_MAX(pipe, 0), color->red);
1637  	ilk_lut_write(crtc_state, PREC_PAL_GC_MAX(pipe, 1), color->green);
1638  	ilk_lut_write(crtc_state, PREC_PAL_GC_MAX(pipe, 2), color->blue);
1639  }
1640  
1641  static void
icl_program_gamma_superfine_segment(const struct intel_crtc_state * crtc_state)1642  icl_program_gamma_superfine_segment(const struct intel_crtc_state *crtc_state)
1643  {
1644  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
1645  	const struct drm_property_blob *blob = crtc_state->post_csc_lut;
1646  	const struct drm_color_lut *lut = blob->data;
1647  	enum pipe pipe = crtc->pipe;
1648  	int i;
1649  
1650  	/*
1651  	 * Program Super Fine segment (let's call it seg1)...
1652  	 *
1653  	 * Super Fine segment's step is 1/(8 * 128 * 256) and it has
1654  	 * 9 entries, corresponding to values 0, 1/(8 * 128 * 256),
1655  	 * 2/(8 * 128 * 256) ... 8/(8 * 128 * 256).
1656  	 */
1657  	ilk_lut_write(crtc_state, PREC_PAL_MULTI_SEG_INDEX(pipe),
1658  		      PAL_PREC_MULTI_SEG_INDEX_VALUE(0));
1659  	ilk_lut_write(crtc_state, PREC_PAL_MULTI_SEG_INDEX(pipe),
1660  		      PAL_PREC_AUTO_INCREMENT |
1661  		      PAL_PREC_MULTI_SEG_INDEX_VALUE(0));
1662  
1663  	for (i = 0; i < 9; i++) {
1664  		const struct drm_color_lut *entry = &lut[i];
1665  
1666  		ilk_lut_write(crtc_state, PREC_PAL_MULTI_SEG_DATA(pipe),
1667  			      ilk_lut_12p4_ldw(entry));
1668  		ilk_lut_write(crtc_state, PREC_PAL_MULTI_SEG_DATA(pipe),
1669  			      ilk_lut_12p4_udw(entry));
1670  	}
1671  
1672  	ilk_lut_write(crtc_state, PREC_PAL_MULTI_SEG_INDEX(pipe),
1673  		      PAL_PREC_MULTI_SEG_INDEX_VALUE(0));
1674  }
1675  
1676  static void
icl_program_gamma_multi_segment(const struct intel_crtc_state * crtc_state)1677  icl_program_gamma_multi_segment(const struct intel_crtc_state *crtc_state)
1678  {
1679  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
1680  	const struct drm_property_blob *blob = crtc_state->post_csc_lut;
1681  	const struct drm_color_lut *lut = blob->data;
1682  	const struct drm_color_lut *entry;
1683  	enum pipe pipe = crtc->pipe;
1684  	int i;
1685  
1686  	/*
1687  	 * Program Fine segment (let's call it seg2)...
1688  	 *
1689  	 * Fine segment's step is 1/(128 * 256) i.e. 1/(128 * 256), 2/(128 * 256)
1690  	 * ... 256/(128 * 256). So in order to program fine segment of LUT we
1691  	 * need to pick every 8th entry in the LUT, and program 256 indexes.
1692  	 *
1693  	 * PAL_PREC_INDEX[0] and PAL_PREC_INDEX[1] map to seg2[1],
1694  	 * seg2[0] being unused by the hardware.
1695  	 */
1696  	ilk_lut_write(crtc_state, PREC_PAL_INDEX(pipe),
1697  		      PAL_PREC_INDEX_VALUE(0));
1698  	ilk_lut_write(crtc_state, PREC_PAL_INDEX(pipe),
1699  		      PAL_PREC_AUTO_INCREMENT |
1700  		      PAL_PREC_INDEX_VALUE(0));
1701  
1702  	for (i = 1; i < 257; i++) {
1703  		entry = &lut[i * 8];
1704  
1705  		ilk_lut_write(crtc_state, PREC_PAL_DATA(pipe),
1706  			      ilk_lut_12p4_ldw(entry));
1707  		ilk_lut_write(crtc_state, PREC_PAL_DATA(pipe),
1708  			      ilk_lut_12p4_udw(entry));
1709  	}
1710  
1711  	/*
1712  	 * Program Coarse segment (let's call it seg3)...
1713  	 *
1714  	 * Coarse segment starts from index 0 and it's step is 1/256 ie 0,
1715  	 * 1/256, 2/256 ... 256/256. As per the description of each entry in LUT
1716  	 * above, we need to pick every (8 * 128)th entry in LUT, and
1717  	 * program 256 of those.
1718  	 *
1719  	 * Spec is not very clear about if entries seg3[0] and seg3[1] are
1720  	 * being used or not, but we still need to program these to advance
1721  	 * the index.
1722  	 */
1723  	for (i = 0; i < 256; i++) {
1724  		entry = &lut[i * 8 * 128];
1725  
1726  		ilk_lut_write(crtc_state, PREC_PAL_DATA(pipe),
1727  			      ilk_lut_12p4_ldw(entry));
1728  		ilk_lut_write(crtc_state, PREC_PAL_DATA(pipe),
1729  			      ilk_lut_12p4_udw(entry));
1730  	}
1731  
1732  	ilk_lut_write(crtc_state, PREC_PAL_INDEX(pipe),
1733  		      PAL_PREC_INDEX_VALUE(0));
1734  
1735  	/* The last entry in the LUT is to be programmed in GCMAX */
1736  	entry = &lut[256 * 8 * 128];
1737  	ivb_load_lut_max(crtc_state, entry);
1738  }
1739  
icl_load_luts(const struct intel_crtc_state * crtc_state)1740  static void icl_load_luts(const struct intel_crtc_state *crtc_state)
1741  {
1742  	const struct drm_property_blob *pre_csc_lut = crtc_state->pre_csc_lut;
1743  	const struct drm_property_blob *post_csc_lut = crtc_state->post_csc_lut;
1744  
1745  	if (pre_csc_lut)
1746  		glk_load_degamma_lut(crtc_state, pre_csc_lut);
1747  
1748  	switch (crtc_state->gamma_mode & GAMMA_MODE_MODE_MASK) {
1749  	case GAMMA_MODE_MODE_8BIT:
1750  		ilk_load_lut_8(crtc_state, post_csc_lut);
1751  		break;
1752  	case GAMMA_MODE_MODE_12BIT_MULTI_SEG:
1753  		icl_program_gamma_superfine_segment(crtc_state);
1754  		icl_program_gamma_multi_segment(crtc_state);
1755  		ivb_load_lut_ext_max(crtc_state);
1756  		glk_load_lut_ext2_max(crtc_state);
1757  		break;
1758  	case GAMMA_MODE_MODE_10BIT:
1759  		bdw_load_lut_10(crtc_state, post_csc_lut, PAL_PREC_INDEX_VALUE(0));
1760  		ivb_load_lut_ext_max(crtc_state);
1761  		glk_load_lut_ext2_max(crtc_state);
1762  		break;
1763  	default:
1764  		MISSING_CASE(crtc_state->gamma_mode);
1765  		break;
1766  	}
1767  }
1768  
vlv_load_luts(const struct intel_crtc_state * crtc_state)1769  static void vlv_load_luts(const struct intel_crtc_state *crtc_state)
1770  {
1771  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
1772  
1773  	if (crtc_state->wgc_enable)
1774  		vlv_load_wgc_csc(crtc, &crtc_state->csc);
1775  
1776  	i965_load_luts(crtc_state);
1777  }
1778  
chv_cgm_degamma_ldw(const struct drm_color_lut * color)1779  static u32 chv_cgm_degamma_ldw(const struct drm_color_lut *color)
1780  {
1781  	return REG_FIELD_PREP(CGM_PIPE_DEGAMMA_GREEN_LDW_MASK, drm_color_lut_extract(color->green, 14)) |
1782  		REG_FIELD_PREP(CGM_PIPE_DEGAMMA_BLUE_LDW_MASK, drm_color_lut_extract(color->blue, 14));
1783  }
1784  
chv_cgm_degamma_udw(const struct drm_color_lut * color)1785  static u32 chv_cgm_degamma_udw(const struct drm_color_lut *color)
1786  {
1787  	return REG_FIELD_PREP(CGM_PIPE_DEGAMMA_RED_UDW_MASK, drm_color_lut_extract(color->red, 14));
1788  }
1789  
chv_cgm_degamma_pack(struct drm_color_lut * entry,u32 ldw,u32 udw)1790  static void chv_cgm_degamma_pack(struct drm_color_lut *entry, u32 ldw, u32 udw)
1791  {
1792  	entry->green = intel_color_lut_pack(REG_FIELD_GET(CGM_PIPE_DEGAMMA_GREEN_LDW_MASK, ldw), 14);
1793  	entry->blue = intel_color_lut_pack(REG_FIELD_GET(CGM_PIPE_DEGAMMA_BLUE_LDW_MASK, ldw), 14);
1794  	entry->red = intel_color_lut_pack(REG_FIELD_GET(CGM_PIPE_DEGAMMA_RED_UDW_MASK, udw), 14);
1795  }
1796  
chv_load_cgm_degamma(struct intel_crtc * crtc,const struct drm_property_blob * blob)1797  static void chv_load_cgm_degamma(struct intel_crtc *crtc,
1798  				 const struct drm_property_blob *blob)
1799  {
1800  	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
1801  	const struct drm_color_lut *lut = blob->data;
1802  	int i, lut_size = drm_color_lut_size(blob);
1803  	enum pipe pipe = crtc->pipe;
1804  
1805  	for (i = 0; i < lut_size; i++) {
1806  		intel_de_write_fw(i915, CGM_PIPE_DEGAMMA(pipe, i, 0),
1807  				  chv_cgm_degamma_ldw(&lut[i]));
1808  		intel_de_write_fw(i915, CGM_PIPE_DEGAMMA(pipe, i, 1),
1809  				  chv_cgm_degamma_udw(&lut[i]));
1810  	}
1811  }
1812  
chv_cgm_gamma_ldw(const struct drm_color_lut * color)1813  static u32 chv_cgm_gamma_ldw(const struct drm_color_lut *color)
1814  {
1815  	return REG_FIELD_PREP(CGM_PIPE_GAMMA_GREEN_LDW_MASK, drm_color_lut_extract(color->green, 10)) |
1816  		REG_FIELD_PREP(CGM_PIPE_GAMMA_BLUE_LDW_MASK, drm_color_lut_extract(color->blue, 10));
1817  }
1818  
chv_cgm_gamma_udw(const struct drm_color_lut * color)1819  static u32 chv_cgm_gamma_udw(const struct drm_color_lut *color)
1820  {
1821  	return REG_FIELD_PREP(CGM_PIPE_GAMMA_RED_UDW_MASK, drm_color_lut_extract(color->red, 10));
1822  }
1823  
chv_cgm_gamma_pack(struct drm_color_lut * entry,u32 ldw,u32 udw)1824  static void chv_cgm_gamma_pack(struct drm_color_lut *entry, u32 ldw, u32 udw)
1825  {
1826  	entry->green = intel_color_lut_pack(REG_FIELD_GET(CGM_PIPE_GAMMA_GREEN_LDW_MASK, ldw), 10);
1827  	entry->blue = intel_color_lut_pack(REG_FIELD_GET(CGM_PIPE_GAMMA_BLUE_LDW_MASK, ldw), 10);
1828  	entry->red = intel_color_lut_pack(REG_FIELD_GET(CGM_PIPE_GAMMA_RED_UDW_MASK, udw), 10);
1829  }
1830  
chv_load_cgm_gamma(struct intel_crtc * crtc,const struct drm_property_blob * blob)1831  static void chv_load_cgm_gamma(struct intel_crtc *crtc,
1832  			       const struct drm_property_blob *blob)
1833  {
1834  	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
1835  	const struct drm_color_lut *lut = blob->data;
1836  	int i, lut_size = drm_color_lut_size(blob);
1837  	enum pipe pipe = crtc->pipe;
1838  
1839  	for (i = 0; i < lut_size; i++) {
1840  		intel_de_write_fw(i915, CGM_PIPE_GAMMA(pipe, i, 0),
1841  				  chv_cgm_gamma_ldw(&lut[i]));
1842  		intel_de_write_fw(i915, CGM_PIPE_GAMMA(pipe, i, 1),
1843  				  chv_cgm_gamma_udw(&lut[i]));
1844  	}
1845  }
1846  
chv_load_luts(const struct intel_crtc_state * crtc_state)1847  static void chv_load_luts(const struct intel_crtc_state *crtc_state)
1848  {
1849  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
1850  	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
1851  	const struct drm_property_blob *pre_csc_lut = crtc_state->pre_csc_lut;
1852  	const struct drm_property_blob *post_csc_lut = crtc_state->post_csc_lut;
1853  
1854  	if (crtc_state->cgm_mode & CGM_PIPE_MODE_CSC)
1855  		chv_load_cgm_csc(crtc, &crtc_state->csc);
1856  
1857  	if (crtc_state->cgm_mode & CGM_PIPE_MODE_DEGAMMA)
1858  		chv_load_cgm_degamma(crtc, pre_csc_lut);
1859  
1860  	if (crtc_state->cgm_mode & CGM_PIPE_MODE_GAMMA)
1861  		chv_load_cgm_gamma(crtc, post_csc_lut);
1862  	else
1863  		i965_load_luts(crtc_state);
1864  
1865  	intel_de_write_fw(i915, CGM_PIPE_MODE(crtc->pipe),
1866  			  crtc_state->cgm_mode);
1867  }
1868  
intel_color_load_luts(const struct intel_crtc_state * crtc_state)1869  void intel_color_load_luts(const struct intel_crtc_state *crtc_state)
1870  {
1871  	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
1872  
1873  	if (crtc_state->dsb_color_vblank)
1874  		return;
1875  
1876  	i915->display.funcs.color->load_luts(crtc_state);
1877  }
1878  
intel_color_commit_noarm(const struct intel_crtc_state * crtc_state)1879  void intel_color_commit_noarm(const struct intel_crtc_state *crtc_state)
1880  {
1881  	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
1882  
1883  	if (i915->display.funcs.color->color_commit_noarm)
1884  		i915->display.funcs.color->color_commit_noarm(crtc_state);
1885  }
1886  
intel_color_commit_arm(const struct intel_crtc_state * crtc_state)1887  void intel_color_commit_arm(const struct intel_crtc_state *crtc_state)
1888  {
1889  	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
1890  
1891  	i915->display.funcs.color->color_commit_arm(crtc_state);
1892  
1893  	if (crtc_state->dsb_color_commit)
1894  		intel_dsb_commit(crtc_state->dsb_color_commit, false);
1895  }
1896  
intel_color_post_update(const struct intel_crtc_state * crtc_state)1897  void intel_color_post_update(const struct intel_crtc_state *crtc_state)
1898  {
1899  	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
1900  
1901  	if (i915->display.funcs.color->color_post_update)
1902  		i915->display.funcs.color->color_post_update(crtc_state);
1903  }
1904  
intel_color_prepare_commit(struct intel_atomic_state * state,struct intel_crtc * crtc)1905  void intel_color_prepare_commit(struct intel_atomic_state *state,
1906  				struct intel_crtc *crtc)
1907  {
1908  	struct drm_i915_private *i915 = to_i915(state->base.dev);
1909  	struct intel_crtc_state *crtc_state =
1910  		intel_atomic_get_new_crtc_state(state, crtc);
1911  
1912  	if (!crtc_state->hw.active ||
1913  	    intel_crtc_needs_modeset(crtc_state))
1914  		return;
1915  
1916  	if (!intel_crtc_needs_color_update(crtc_state))
1917  		return;
1918  
1919  	if (!crtc_state->pre_csc_lut && !crtc_state->post_csc_lut)
1920  		return;
1921  
1922  	crtc_state->dsb_color_vblank = intel_dsb_prepare(state, crtc, INTEL_DSB_1, 1024);
1923  	if (!crtc_state->dsb_color_vblank)
1924  		return;
1925  
1926  	i915->display.funcs.color->load_luts(crtc_state);
1927  
1928  	intel_dsb_finish(crtc_state->dsb_color_vblank);
1929  
1930  	crtc_state->dsb_color_commit = intel_dsb_prepare(state, crtc, INTEL_DSB_0, 16);
1931  	if (!crtc_state->dsb_color_commit) {
1932  		intel_dsb_cleanup(crtc_state->dsb_color_vblank);
1933  		crtc_state->dsb_color_vblank = NULL;
1934  		return;
1935  	}
1936  
1937  	intel_dsb_chain(state, crtc_state->dsb_color_commit,
1938  			crtc_state->dsb_color_vblank, true);
1939  
1940  	intel_dsb_finish(crtc_state->dsb_color_commit);
1941  }
1942  
intel_color_cleanup_commit(struct intel_crtc_state * crtc_state)1943  void intel_color_cleanup_commit(struct intel_crtc_state *crtc_state)
1944  {
1945  	if (crtc_state->dsb_color_commit) {
1946  		intel_dsb_cleanup(crtc_state->dsb_color_commit);
1947  		crtc_state->dsb_color_commit = NULL;
1948  	}
1949  
1950  	if (crtc_state->dsb_color_vblank) {
1951  		intel_dsb_cleanup(crtc_state->dsb_color_vblank);
1952  		crtc_state->dsb_color_vblank = NULL;
1953  	}
1954  }
1955  
intel_color_wait_commit(const struct intel_crtc_state * crtc_state)1956  void intel_color_wait_commit(const struct intel_crtc_state *crtc_state)
1957  {
1958  	if (crtc_state->dsb_color_commit)
1959  		intel_dsb_wait(crtc_state->dsb_color_commit);
1960  	if (crtc_state->dsb_color_vblank)
1961  		intel_dsb_wait(crtc_state->dsb_color_vblank);
1962  }
1963  
intel_color_uses_dsb(const struct intel_crtc_state * crtc_state)1964  bool intel_color_uses_dsb(const struct intel_crtc_state *crtc_state)
1965  {
1966  	return crtc_state->dsb_color_vblank;
1967  }
1968  
intel_can_preload_luts(struct intel_atomic_state * state,struct intel_crtc * crtc)1969  static bool intel_can_preload_luts(struct intel_atomic_state *state,
1970  				   struct intel_crtc *crtc)
1971  {
1972  	const struct intel_crtc_state *old_crtc_state =
1973  		intel_atomic_get_old_crtc_state(state, crtc);
1974  
1975  	return !old_crtc_state->post_csc_lut &&
1976  		!old_crtc_state->pre_csc_lut;
1977  }
1978  
vlv_can_preload_luts(struct intel_atomic_state * state,struct intel_crtc * crtc)1979  static bool vlv_can_preload_luts(struct intel_atomic_state *state,
1980  				 struct intel_crtc *crtc)
1981  {
1982  	const struct intel_crtc_state *old_crtc_state =
1983  		intel_atomic_get_old_crtc_state(state, crtc);
1984  
1985  	return !old_crtc_state->wgc_enable &&
1986  		!old_crtc_state->post_csc_lut;
1987  }
1988  
chv_can_preload_luts(struct intel_atomic_state * state,struct intel_crtc * crtc)1989  static bool chv_can_preload_luts(struct intel_atomic_state *state,
1990  				 struct intel_crtc *crtc)
1991  {
1992  	const struct intel_crtc_state *old_crtc_state =
1993  		intel_atomic_get_old_crtc_state(state, crtc);
1994  	const struct intel_crtc_state *new_crtc_state =
1995  		intel_atomic_get_new_crtc_state(state, crtc);
1996  
1997  	/*
1998  	 * CGM_PIPE_MODE is itself single buffered. We'd have to
1999  	 * somehow split it out from chv_load_luts() if we wanted
2000  	 * the ability to preload the CGM LUTs/CSC without tearing.
2001  	 */
2002  	if (old_crtc_state->cgm_mode || new_crtc_state->cgm_mode)
2003  		return false;
2004  
2005  	return vlv_can_preload_luts(state, crtc);
2006  }
2007  
intel_color_check(struct intel_atomic_state * state,struct intel_crtc * crtc)2008  int intel_color_check(struct intel_atomic_state *state,
2009  		      struct intel_crtc *crtc)
2010  {
2011  	struct drm_i915_private *i915 = to_i915(state->base.dev);
2012  	const struct intel_crtc_state *old_crtc_state =
2013  		intel_atomic_get_old_crtc_state(state, crtc);
2014  	struct intel_crtc_state *new_crtc_state =
2015  		intel_atomic_get_new_crtc_state(state, crtc);
2016  
2017  	/*
2018  	 * May need to update pipe gamma enable bits
2019  	 * when C8 planes are getting enabled/disabled.
2020  	 */
2021  	if (!old_crtc_state->c8_planes != !new_crtc_state->c8_planes)
2022  		new_crtc_state->uapi.color_mgmt_changed = true;
2023  
2024  	if (!intel_crtc_needs_color_update(new_crtc_state))
2025  		return 0;
2026  
2027  	return i915->display.funcs.color->color_check(state, crtc);
2028  }
2029  
intel_color_get_config(struct intel_crtc_state * crtc_state)2030  void intel_color_get_config(struct intel_crtc_state *crtc_state)
2031  {
2032  	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
2033  
2034  	if (i915->display.funcs.color->get_config)
2035  		i915->display.funcs.color->get_config(crtc_state);
2036  
2037  	i915->display.funcs.color->read_luts(crtc_state);
2038  
2039  	if (i915->display.funcs.color->read_csc)
2040  		i915->display.funcs.color->read_csc(crtc_state);
2041  }
2042  
intel_color_lut_equal(const struct intel_crtc_state * crtc_state,const struct drm_property_blob * blob1,const struct drm_property_blob * blob2,bool is_pre_csc_lut)2043  bool intel_color_lut_equal(const struct intel_crtc_state *crtc_state,
2044  			   const struct drm_property_blob *blob1,
2045  			   const struct drm_property_blob *blob2,
2046  			   bool is_pre_csc_lut)
2047  {
2048  	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
2049  
2050  	/*
2051  	 * FIXME c8_planes readout missing thus
2052  	 * .read_luts() doesn't read out post_csc_lut.
2053  	 */
2054  	if (!is_pre_csc_lut && crtc_state->c8_planes)
2055  		return true;
2056  
2057  	return i915->display.funcs.color->lut_equal(crtc_state, blob1, blob2,
2058  						    is_pre_csc_lut);
2059  }
2060  
need_plane_update(struct intel_plane * plane,const struct intel_crtc_state * crtc_state)2061  static bool need_plane_update(struct intel_plane *plane,
2062  			      const struct intel_crtc_state *crtc_state)
2063  {
2064  	struct drm_i915_private *i915 = to_i915(plane->base.dev);
2065  
2066  	/*
2067  	 * On pre-SKL the pipe gamma enable and pipe csc enable for
2068  	 * the pipe bottom color are configured via the primary plane.
2069  	 * We have to reconfigure that even if the plane is inactive.
2070  	 */
2071  	return crtc_state->active_planes & BIT(plane->id) ||
2072  		(DISPLAY_VER(i915) < 9 &&
2073  		 plane->id == PLANE_PRIMARY);
2074  }
2075  
2076  static int
intel_color_add_affected_planes(struct intel_atomic_state * state,struct intel_crtc * crtc)2077  intel_color_add_affected_planes(struct intel_atomic_state *state,
2078  				struct intel_crtc *crtc)
2079  {
2080  	struct drm_i915_private *i915 = to_i915(state->base.dev);
2081  	const struct intel_crtc_state *old_crtc_state =
2082  		intel_atomic_get_old_crtc_state(state, crtc);
2083  	struct intel_crtc_state *new_crtc_state =
2084  		intel_atomic_get_new_crtc_state(state, crtc);
2085  	struct intel_plane *plane;
2086  
2087  	if (!new_crtc_state->hw.active ||
2088  	    intel_crtc_needs_modeset(new_crtc_state))
2089  		return 0;
2090  
2091  	if (new_crtc_state->gamma_enable == old_crtc_state->gamma_enable &&
2092  	    new_crtc_state->csc_enable == old_crtc_state->csc_enable)
2093  		return 0;
2094  
2095  	for_each_intel_plane_on_crtc(&i915->drm, crtc, plane) {
2096  		struct intel_plane_state *plane_state;
2097  
2098  		if (!need_plane_update(plane, new_crtc_state))
2099  			continue;
2100  
2101  		plane_state = intel_atomic_get_plane_state(state, plane);
2102  		if (IS_ERR(plane_state))
2103  			return PTR_ERR(plane_state);
2104  
2105  		new_crtc_state->update_planes |= BIT(plane->id);
2106  		new_crtc_state->async_flip_planes = 0;
2107  		new_crtc_state->do_async_flip = false;
2108  
2109  		/* plane control register changes blocked by CxSR */
2110  		if (HAS_GMCH(i915))
2111  			new_crtc_state->disable_cxsr = true;
2112  	}
2113  
2114  	return 0;
2115  }
2116  
intel_gamma_lut_tests(const struct intel_crtc_state * crtc_state)2117  static u32 intel_gamma_lut_tests(const struct intel_crtc_state *crtc_state)
2118  {
2119  	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
2120  	const struct drm_property_blob *gamma_lut = crtc_state->hw.gamma_lut;
2121  
2122  	if (lut_is_legacy(gamma_lut))
2123  		return 0;
2124  
2125  	return DISPLAY_INFO(i915)->color.gamma_lut_tests;
2126  }
2127  
intel_degamma_lut_tests(const struct intel_crtc_state * crtc_state)2128  static u32 intel_degamma_lut_tests(const struct intel_crtc_state *crtc_state)
2129  {
2130  	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
2131  
2132  	return DISPLAY_INFO(i915)->color.degamma_lut_tests;
2133  }
2134  
intel_gamma_lut_size(const struct intel_crtc_state * crtc_state)2135  static int intel_gamma_lut_size(const struct intel_crtc_state *crtc_state)
2136  {
2137  	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
2138  	const struct drm_property_blob *gamma_lut = crtc_state->hw.gamma_lut;
2139  
2140  	if (lut_is_legacy(gamma_lut))
2141  		return LEGACY_LUT_LENGTH;
2142  
2143  	return DISPLAY_INFO(i915)->color.gamma_lut_size;
2144  }
2145  
intel_degamma_lut_size(const struct intel_crtc_state * crtc_state)2146  static u32 intel_degamma_lut_size(const struct intel_crtc_state *crtc_state)
2147  {
2148  	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
2149  
2150  	return DISPLAY_INFO(i915)->color.degamma_lut_size;
2151  }
2152  
check_lut_size(struct drm_i915_private * i915,const struct drm_property_blob * lut,int expected)2153  static int check_lut_size(struct drm_i915_private *i915,
2154  			  const struct drm_property_blob *lut, int expected)
2155  {
2156  	int len;
2157  
2158  	if (!lut)
2159  		return 0;
2160  
2161  	len = drm_color_lut_size(lut);
2162  	if (len != expected) {
2163  		drm_dbg_kms(&i915->drm, "Invalid LUT size; got %d, expected %d\n",
2164  			    len, expected);
2165  		return -EINVAL;
2166  	}
2167  
2168  	return 0;
2169  }
2170  
_check_luts(const struct intel_crtc_state * crtc_state,u32 degamma_tests,u32 gamma_tests)2171  static int _check_luts(const struct intel_crtc_state *crtc_state,
2172  		       u32 degamma_tests, u32 gamma_tests)
2173  {
2174  	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
2175  	const struct drm_property_blob *gamma_lut = crtc_state->hw.gamma_lut;
2176  	const struct drm_property_blob *degamma_lut = crtc_state->hw.degamma_lut;
2177  	int gamma_length, degamma_length;
2178  
2179  	/* C8 relies on its palette being stored in the legacy LUT */
2180  	if (crtc_state->c8_planes && !lut_is_legacy(crtc_state->hw.gamma_lut)) {
2181  		drm_dbg_kms(&i915->drm,
2182  			    "C8 pixelformat requires the legacy LUT\n");
2183  		return -EINVAL;
2184  	}
2185  
2186  	degamma_length = intel_degamma_lut_size(crtc_state);
2187  	gamma_length = intel_gamma_lut_size(crtc_state);
2188  
2189  	if (check_lut_size(i915, degamma_lut, degamma_length) ||
2190  	    check_lut_size(i915, gamma_lut, gamma_length))
2191  		return -EINVAL;
2192  
2193  	if (drm_color_lut_check(degamma_lut, degamma_tests) ||
2194  	    drm_color_lut_check(gamma_lut, gamma_tests))
2195  		return -EINVAL;
2196  
2197  	return 0;
2198  }
2199  
check_luts(const struct intel_crtc_state * crtc_state)2200  static int check_luts(const struct intel_crtc_state *crtc_state)
2201  {
2202  	return _check_luts(crtc_state,
2203  			   intel_degamma_lut_tests(crtc_state),
2204  			   intel_gamma_lut_tests(crtc_state));
2205  }
2206  
i9xx_gamma_mode(struct intel_crtc_state * crtc_state)2207  static u32 i9xx_gamma_mode(struct intel_crtc_state *crtc_state)
2208  {
2209  	if (!crtc_state->gamma_enable ||
2210  	    lut_is_legacy(crtc_state->hw.gamma_lut))
2211  		return GAMMA_MODE_MODE_8BIT;
2212  	else
2213  		return GAMMA_MODE_MODE_10BIT;
2214  }
2215  
i9xx_lut_10_diff(u16 a,u16 b)2216  static int i9xx_lut_10_diff(u16 a, u16 b)
2217  {
2218  	return drm_color_lut_extract(a, 10) -
2219  		drm_color_lut_extract(b, 10);
2220  }
2221  
i9xx_check_lut_10(struct drm_i915_private * dev_priv,const struct drm_property_blob * blob)2222  static int i9xx_check_lut_10(struct drm_i915_private *dev_priv,
2223  			     const struct drm_property_blob *blob)
2224  {
2225  	const struct drm_color_lut *lut = blob->data;
2226  	int lut_size = drm_color_lut_size(blob);
2227  	const struct drm_color_lut *a = &lut[lut_size - 2];
2228  	const struct drm_color_lut *b = &lut[lut_size - 1];
2229  
2230  	if (i9xx_lut_10_diff(b->red, a->red) > 0x7f ||
2231  	    i9xx_lut_10_diff(b->green, a->green) > 0x7f ||
2232  	    i9xx_lut_10_diff(b->blue, a->blue) > 0x7f) {
2233  		drm_dbg_kms(&dev_priv->drm, "Last gamma LUT entry exceeds max slope\n");
2234  		return -EINVAL;
2235  	}
2236  
2237  	return 0;
2238  }
2239  
intel_color_assert_luts(const struct intel_crtc_state * crtc_state)2240  void intel_color_assert_luts(const struct intel_crtc_state *crtc_state)
2241  {
2242  	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
2243  
2244  	/* make sure {pre,post}_csc_lut were correctly assigned */
2245  	if (DISPLAY_VER(i915) >= 11 || HAS_GMCH(i915)) {
2246  		drm_WARN_ON(&i915->drm,
2247  			    crtc_state->pre_csc_lut != crtc_state->hw.degamma_lut);
2248  		drm_WARN_ON(&i915->drm,
2249  			    crtc_state->post_csc_lut != crtc_state->hw.gamma_lut);
2250  	} else if (DISPLAY_VER(i915) == 10) {
2251  		drm_WARN_ON(&i915->drm,
2252  			    crtc_state->post_csc_lut == crtc_state->hw.gamma_lut &&
2253  			    crtc_state->pre_csc_lut != crtc_state->hw.degamma_lut &&
2254  			    crtc_state->pre_csc_lut != i915->display.color.glk_linear_degamma_lut);
2255  		drm_WARN_ON(&i915->drm,
2256  			    !ilk_lut_limited_range(crtc_state) &&
2257  			    crtc_state->post_csc_lut != NULL &&
2258  			    crtc_state->post_csc_lut != crtc_state->hw.gamma_lut);
2259  	} else if (crtc_state->gamma_mode != GAMMA_MODE_MODE_SPLIT) {
2260  		drm_WARN_ON(&i915->drm,
2261  			    crtc_state->pre_csc_lut != crtc_state->hw.degamma_lut &&
2262  			    crtc_state->pre_csc_lut != crtc_state->hw.gamma_lut);
2263  		drm_WARN_ON(&i915->drm,
2264  			    !ilk_lut_limited_range(crtc_state) &&
2265  			    crtc_state->post_csc_lut != crtc_state->hw.degamma_lut &&
2266  			    crtc_state->post_csc_lut != crtc_state->hw.gamma_lut);
2267  	}
2268  }
2269  
intel_assign_luts(struct intel_crtc_state * crtc_state)2270  static void intel_assign_luts(struct intel_crtc_state *crtc_state)
2271  {
2272  	drm_property_replace_blob(&crtc_state->pre_csc_lut,
2273  				  crtc_state->hw.degamma_lut);
2274  	drm_property_replace_blob(&crtc_state->post_csc_lut,
2275  				  crtc_state->hw.gamma_lut);
2276  }
2277  
i9xx_color_check(struct intel_atomic_state * state,struct intel_crtc * crtc)2278  static int i9xx_color_check(struct intel_atomic_state *state,
2279  			    struct intel_crtc *crtc)
2280  {
2281  	struct drm_i915_private *i915 = to_i915(state->base.dev);
2282  	struct intel_crtc_state *crtc_state =
2283  		intel_atomic_get_new_crtc_state(state, crtc);
2284  	int ret;
2285  
2286  	ret = check_luts(crtc_state);
2287  	if (ret)
2288  		return ret;
2289  
2290  	crtc_state->gamma_enable =
2291  		crtc_state->hw.gamma_lut &&
2292  		!crtc_state->c8_planes;
2293  
2294  	crtc_state->gamma_mode = i9xx_gamma_mode(crtc_state);
2295  
2296  	if (DISPLAY_VER(i915) < 4 &&
2297  	    crtc_state->gamma_mode == GAMMA_MODE_MODE_10BIT) {
2298  		ret = i9xx_check_lut_10(i915, crtc_state->hw.gamma_lut);
2299  		if (ret)
2300  			return ret;
2301  	}
2302  
2303  	ret = intel_color_add_affected_planes(state, crtc);
2304  	if (ret)
2305  		return ret;
2306  
2307  	intel_assign_luts(crtc_state);
2308  
2309  	crtc_state->preload_luts = intel_can_preload_luts(state, crtc);
2310  
2311  	return 0;
2312  }
2313  
2314  /*
2315   * VLV color pipeline:
2316   * u0.10 -> WGC csc -> u0.10 -> pipe gamma -> u0.10
2317   */
vlv_color_check(struct intel_atomic_state * state,struct intel_crtc * crtc)2318  static int vlv_color_check(struct intel_atomic_state *state,
2319  			   struct intel_crtc *crtc)
2320  {
2321  	struct intel_crtc_state *crtc_state =
2322  		intel_atomic_get_new_crtc_state(state, crtc);
2323  	int ret;
2324  
2325  	ret = check_luts(crtc_state);
2326  	if (ret)
2327  		return ret;
2328  
2329  	crtc_state->gamma_enable =
2330  		crtc_state->hw.gamma_lut &&
2331  		!crtc_state->c8_planes;
2332  
2333  	crtc_state->gamma_mode = i9xx_gamma_mode(crtc_state);
2334  
2335  	crtc_state->wgc_enable = crtc_state->hw.ctm;
2336  
2337  	ret = intel_color_add_affected_planes(state, crtc);
2338  	if (ret)
2339  		return ret;
2340  
2341  	intel_assign_luts(crtc_state);
2342  
2343  	vlv_assign_csc(crtc_state);
2344  
2345  	crtc_state->preload_luts = vlv_can_preload_luts(state, crtc);
2346  
2347  	return 0;
2348  }
2349  
chv_cgm_mode(const struct intel_crtc_state * crtc_state)2350  static u32 chv_cgm_mode(const struct intel_crtc_state *crtc_state)
2351  {
2352  	u32 cgm_mode = 0;
2353  
2354  	if (crtc_state->hw.degamma_lut)
2355  		cgm_mode |= CGM_PIPE_MODE_DEGAMMA;
2356  	if (crtc_state->hw.ctm)
2357  		cgm_mode |= CGM_PIPE_MODE_CSC;
2358  	if (crtc_state->hw.gamma_lut &&
2359  	    !lut_is_legacy(crtc_state->hw.gamma_lut))
2360  		cgm_mode |= CGM_PIPE_MODE_GAMMA;
2361  
2362  	/*
2363  	 * Toggling the CGM CSC on/off outside of the tiny window
2364  	 * between start of vblank and frame start causes underruns.
2365  	 * Always enable the CGM CSC as a workaround.
2366  	 */
2367  	cgm_mode |= CGM_PIPE_MODE_CSC;
2368  
2369  	return cgm_mode;
2370  }
2371  
2372  /*
2373   * CHV color pipeline:
2374   * u0.10 -> CGM degamma -> u0.14 -> CGM csc -> u0.14 -> CGM gamma ->
2375   * u0.10 -> WGC csc -> u0.10 -> pipe gamma -> u0.10
2376   *
2377   * We always bypass the WGC csc and use the CGM csc
2378   * instead since it has degamma and better precision.
2379   */
chv_color_check(struct intel_atomic_state * state,struct intel_crtc * crtc)2380  static int chv_color_check(struct intel_atomic_state *state,
2381  			   struct intel_crtc *crtc)
2382  {
2383  	struct intel_crtc_state *crtc_state =
2384  		intel_atomic_get_new_crtc_state(state, crtc);
2385  	int ret;
2386  
2387  	ret = check_luts(crtc_state);
2388  	if (ret)
2389  		return ret;
2390  
2391  	/*
2392  	 * Pipe gamma will be used only for the legacy LUT.
2393  	 * Otherwise we bypass it and use the CGM gamma instead.
2394  	 */
2395  	crtc_state->gamma_enable =
2396  		lut_is_legacy(crtc_state->hw.gamma_lut) &&
2397  		!crtc_state->c8_planes;
2398  
2399  	crtc_state->gamma_mode = GAMMA_MODE_MODE_8BIT;
2400  
2401  	crtc_state->cgm_mode = chv_cgm_mode(crtc_state);
2402  
2403  	/*
2404  	 * We always bypass the WGC CSC and use the CGM CSC
2405  	 * instead since it has degamma and better precision.
2406  	 */
2407  	crtc_state->wgc_enable = false;
2408  
2409  	ret = intel_color_add_affected_planes(state, crtc);
2410  	if (ret)
2411  		return ret;
2412  
2413  	intel_assign_luts(crtc_state);
2414  
2415  	chv_assign_csc(crtc_state);
2416  
2417  	crtc_state->preload_luts = chv_can_preload_luts(state, crtc);
2418  
2419  	return 0;
2420  }
2421  
ilk_gamma_enable(const struct intel_crtc_state * crtc_state)2422  static bool ilk_gamma_enable(const struct intel_crtc_state *crtc_state)
2423  {
2424  	return (crtc_state->hw.gamma_lut ||
2425  		crtc_state->hw.degamma_lut) &&
2426  		!crtc_state->c8_planes;
2427  }
2428  
ilk_csc_enable(const struct intel_crtc_state * crtc_state)2429  static bool ilk_csc_enable(const struct intel_crtc_state *crtc_state)
2430  {
2431  	return crtc_state->output_format != INTEL_OUTPUT_FORMAT_RGB ||
2432  		ilk_csc_limited_range(crtc_state) ||
2433  		crtc_state->hw.ctm;
2434  }
2435  
ilk_gamma_mode(const struct intel_crtc_state * crtc_state)2436  static u32 ilk_gamma_mode(const struct intel_crtc_state *crtc_state)
2437  {
2438  	if (!crtc_state->gamma_enable ||
2439  	    lut_is_legacy(crtc_state->hw.gamma_lut))
2440  		return GAMMA_MODE_MODE_8BIT;
2441  	else
2442  		return GAMMA_MODE_MODE_10BIT;
2443  }
2444  
ilk_csc_mode(const struct intel_crtc_state * crtc_state)2445  static u32 ilk_csc_mode(const struct intel_crtc_state *crtc_state)
2446  {
2447  	/*
2448  	 * CSC comes after the LUT in RGB->YCbCr mode.
2449  	 * RGB->YCbCr needs the limited range offsets added to
2450  	 * the output. RGB limited range output is handled by
2451  	 * the hw automagically elsewhere.
2452  	 */
2453  	if (crtc_state->output_format != INTEL_OUTPUT_FORMAT_RGB)
2454  		return CSC_BLACK_SCREEN_OFFSET;
2455  
2456  	if (crtc_state->hw.degamma_lut)
2457  		return CSC_MODE_YUV_TO_RGB;
2458  
2459  	return CSC_MODE_YUV_TO_RGB |
2460  		CSC_POSITION_BEFORE_GAMMA;
2461  }
2462  
ilk_assign_luts(struct intel_crtc_state * crtc_state)2463  static int ilk_assign_luts(struct intel_crtc_state *crtc_state)
2464  {
2465  	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
2466  
2467  	if (ilk_lut_limited_range(crtc_state)) {
2468  		struct drm_property_blob *gamma_lut;
2469  
2470  		gamma_lut = create_resized_lut(i915, crtc_state->hw.gamma_lut,
2471  					       drm_color_lut_size(crtc_state->hw.gamma_lut),
2472  					       true);
2473  		if (IS_ERR(gamma_lut))
2474  			return PTR_ERR(gamma_lut);
2475  
2476  		drm_property_replace_blob(&crtc_state->post_csc_lut, gamma_lut);
2477  
2478  		drm_property_blob_put(gamma_lut);
2479  
2480  		drm_property_replace_blob(&crtc_state->pre_csc_lut, crtc_state->hw.degamma_lut);
2481  
2482  		return 0;
2483  	}
2484  
2485  	if (crtc_state->hw.degamma_lut ||
2486  	    crtc_state->csc_mode & CSC_POSITION_BEFORE_GAMMA) {
2487  		drm_property_replace_blob(&crtc_state->pre_csc_lut,
2488  					  crtc_state->hw.degamma_lut);
2489  		drm_property_replace_blob(&crtc_state->post_csc_lut,
2490  					  crtc_state->hw.gamma_lut);
2491  	} else {
2492  		drm_property_replace_blob(&crtc_state->pre_csc_lut,
2493  					  crtc_state->hw.gamma_lut);
2494  		drm_property_replace_blob(&crtc_state->post_csc_lut,
2495  					  NULL);
2496  	}
2497  
2498  	return 0;
2499  }
2500  
ilk_color_check(struct intel_atomic_state * state,struct intel_crtc * crtc)2501  static int ilk_color_check(struct intel_atomic_state *state,
2502  			   struct intel_crtc *crtc)
2503  {
2504  	struct drm_i915_private *i915 = to_i915(state->base.dev);
2505  	struct intel_crtc_state *crtc_state =
2506  		intel_atomic_get_new_crtc_state(state, crtc);
2507  	int ret;
2508  
2509  	ret = check_luts(crtc_state);
2510  	if (ret)
2511  		return ret;
2512  
2513  	if (crtc_state->hw.degamma_lut && crtc_state->hw.gamma_lut) {
2514  		drm_dbg_kms(&i915->drm,
2515  			    "Degamma and gamma together are not possible\n");
2516  		return -EINVAL;
2517  	}
2518  
2519  	if (crtc_state->output_format != INTEL_OUTPUT_FORMAT_RGB &&
2520  	    crtc_state->hw.ctm) {
2521  		drm_dbg_kms(&i915->drm,
2522  			    "YCbCr and CTM together are not possible\n");
2523  		return -EINVAL;
2524  	}
2525  
2526  	crtc_state->gamma_enable = ilk_gamma_enable(crtc_state);
2527  
2528  	crtc_state->csc_enable = ilk_csc_enable(crtc_state);
2529  
2530  	crtc_state->gamma_mode = ilk_gamma_mode(crtc_state);
2531  
2532  	crtc_state->csc_mode = ilk_csc_mode(crtc_state);
2533  
2534  	ret = intel_color_add_affected_planes(state, crtc);
2535  	if (ret)
2536  		return ret;
2537  
2538  	ret = ilk_assign_luts(crtc_state);
2539  	if (ret)
2540  		return ret;
2541  
2542  	ilk_assign_csc(crtc_state);
2543  
2544  	crtc_state->preload_luts = intel_can_preload_luts(state, crtc);
2545  
2546  	return 0;
2547  }
2548  
ivb_gamma_mode(const struct intel_crtc_state * crtc_state)2549  static u32 ivb_gamma_mode(const struct intel_crtc_state *crtc_state)
2550  {
2551  	if (crtc_state->hw.degamma_lut && crtc_state->hw.gamma_lut)
2552  		return GAMMA_MODE_MODE_SPLIT;
2553  
2554  	return ilk_gamma_mode(crtc_state);
2555  }
2556  
ivb_csc_mode(const struct intel_crtc_state * crtc_state)2557  static u32 ivb_csc_mode(const struct intel_crtc_state *crtc_state)
2558  {
2559  	bool limited_color_range = ilk_csc_limited_range(crtc_state);
2560  
2561  	/*
2562  	 * CSC comes after the LUT in degamma, RGB->YCbCr,
2563  	 * and RGB full->limited range mode.
2564  	 */
2565  	if (crtc_state->hw.degamma_lut ||
2566  	    crtc_state->output_format != INTEL_OUTPUT_FORMAT_RGB ||
2567  	    limited_color_range)
2568  		return 0;
2569  
2570  	return CSC_POSITION_BEFORE_GAMMA;
2571  }
2572  
ivb_assign_luts(struct intel_crtc_state * crtc_state)2573  static int ivb_assign_luts(struct intel_crtc_state *crtc_state)
2574  {
2575  	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
2576  	struct drm_property_blob *degamma_lut, *gamma_lut;
2577  
2578  	if (crtc_state->gamma_mode != GAMMA_MODE_MODE_SPLIT)
2579  		return ilk_assign_luts(crtc_state);
2580  
2581  	drm_WARN_ON(&i915->drm, drm_color_lut_size(crtc_state->hw.degamma_lut) != 1024);
2582  	drm_WARN_ON(&i915->drm, drm_color_lut_size(crtc_state->hw.gamma_lut) != 1024);
2583  
2584  	degamma_lut = create_resized_lut(i915, crtc_state->hw.degamma_lut, 512,
2585  					 false);
2586  	if (IS_ERR(degamma_lut))
2587  		return PTR_ERR(degamma_lut);
2588  
2589  	gamma_lut = create_resized_lut(i915, crtc_state->hw.gamma_lut, 512,
2590  				       ilk_lut_limited_range(crtc_state));
2591  	if (IS_ERR(gamma_lut)) {
2592  		drm_property_blob_put(degamma_lut);
2593  		return PTR_ERR(gamma_lut);
2594  	}
2595  
2596  	drm_property_replace_blob(&crtc_state->pre_csc_lut, degamma_lut);
2597  	drm_property_replace_blob(&crtc_state->post_csc_lut, gamma_lut);
2598  
2599  	drm_property_blob_put(degamma_lut);
2600  	drm_property_blob_put(gamma_lut);
2601  
2602  	return 0;
2603  }
2604  
ivb_color_check(struct intel_atomic_state * state,struct intel_crtc * crtc)2605  static int ivb_color_check(struct intel_atomic_state *state,
2606  			   struct intel_crtc *crtc)
2607  {
2608  	struct drm_i915_private *i915 = to_i915(state->base.dev);
2609  	struct intel_crtc_state *crtc_state =
2610  		intel_atomic_get_new_crtc_state(state, crtc);
2611  	int ret;
2612  
2613  	ret = check_luts(crtc_state);
2614  	if (ret)
2615  		return ret;
2616  
2617  	if (crtc_state->c8_planes && crtc_state->hw.degamma_lut) {
2618  		drm_dbg_kms(&i915->drm,
2619  			    "C8 pixelformat and degamma together are not possible\n");
2620  		return -EINVAL;
2621  	}
2622  
2623  	if (crtc_state->output_format != INTEL_OUTPUT_FORMAT_RGB &&
2624  	    crtc_state->hw.ctm) {
2625  		drm_dbg_kms(&i915->drm,
2626  			    "YCbCr and CTM together are not possible\n");
2627  		return -EINVAL;
2628  	}
2629  
2630  	if (crtc_state->output_format != INTEL_OUTPUT_FORMAT_RGB &&
2631  	    crtc_state->hw.degamma_lut && crtc_state->hw.gamma_lut) {
2632  		drm_dbg_kms(&i915->drm,
2633  			    "YCbCr and degamma+gamma together are not possible\n");
2634  		return -EINVAL;
2635  	}
2636  
2637  	crtc_state->gamma_enable = ilk_gamma_enable(crtc_state);
2638  
2639  	crtc_state->csc_enable = ilk_csc_enable(crtc_state);
2640  
2641  	crtc_state->gamma_mode = ivb_gamma_mode(crtc_state);
2642  
2643  	crtc_state->csc_mode = ivb_csc_mode(crtc_state);
2644  
2645  	ret = intel_color_add_affected_planes(state, crtc);
2646  	if (ret)
2647  		return ret;
2648  
2649  	ret = ivb_assign_luts(crtc_state);
2650  	if (ret)
2651  		return ret;
2652  
2653  	ilk_assign_csc(crtc_state);
2654  
2655  	crtc_state->preload_luts = intel_can_preload_luts(state, crtc);
2656  
2657  	return 0;
2658  }
2659  
glk_gamma_mode(const struct intel_crtc_state * crtc_state)2660  static u32 glk_gamma_mode(const struct intel_crtc_state *crtc_state)
2661  {
2662  	if (!crtc_state->gamma_enable ||
2663  	    lut_is_legacy(crtc_state->hw.gamma_lut))
2664  		return GAMMA_MODE_MODE_8BIT;
2665  	else
2666  		return GAMMA_MODE_MODE_10BIT;
2667  }
2668  
glk_use_pre_csc_lut_for_gamma(const struct intel_crtc_state * crtc_state)2669  static bool glk_use_pre_csc_lut_for_gamma(const struct intel_crtc_state *crtc_state)
2670  {
2671  	return crtc_state->hw.gamma_lut &&
2672  		!crtc_state->c8_planes &&
2673  		crtc_state->output_format != INTEL_OUTPUT_FORMAT_RGB;
2674  }
2675  
glk_assign_luts(struct intel_crtc_state * crtc_state)2676  static int glk_assign_luts(struct intel_crtc_state *crtc_state)
2677  {
2678  	struct drm_i915_private *i915 = to_i915(crtc_state->uapi.crtc->dev);
2679  
2680  	if (glk_use_pre_csc_lut_for_gamma(crtc_state)) {
2681  		struct drm_property_blob *gamma_lut;
2682  
2683  		gamma_lut = create_resized_lut(i915, crtc_state->hw.gamma_lut,
2684  					       DISPLAY_INFO(i915)->color.degamma_lut_size,
2685  					       false);
2686  		if (IS_ERR(gamma_lut))
2687  			return PTR_ERR(gamma_lut);
2688  
2689  		drm_property_replace_blob(&crtc_state->pre_csc_lut, gamma_lut);
2690  		drm_property_replace_blob(&crtc_state->post_csc_lut, NULL);
2691  
2692  		drm_property_blob_put(gamma_lut);
2693  
2694  		return 0;
2695  	}
2696  
2697  	if (ilk_lut_limited_range(crtc_state)) {
2698  		struct drm_property_blob *gamma_lut;
2699  
2700  		gamma_lut = create_resized_lut(i915, crtc_state->hw.gamma_lut,
2701  					       drm_color_lut_size(crtc_state->hw.gamma_lut),
2702  					       true);
2703  		if (IS_ERR(gamma_lut))
2704  			return PTR_ERR(gamma_lut);
2705  
2706  		drm_property_replace_blob(&crtc_state->post_csc_lut, gamma_lut);
2707  
2708  		drm_property_blob_put(gamma_lut);
2709  	} else {
2710  		drm_property_replace_blob(&crtc_state->post_csc_lut, crtc_state->hw.gamma_lut);
2711  	}
2712  
2713  	drm_property_replace_blob(&crtc_state->pre_csc_lut, crtc_state->hw.degamma_lut);
2714  
2715  	/*
2716  	 * On GLK+ both pipe CSC and degamma LUT are controlled
2717  	 * by csc_enable. Hence for the cases where the CSC is
2718  	 * needed but degamma LUT is not we need to load a
2719  	 * linear degamma LUT.
2720  	 */
2721  	if (crtc_state->csc_enable && !crtc_state->pre_csc_lut)
2722  		drm_property_replace_blob(&crtc_state->pre_csc_lut,
2723  					  i915->display.color.glk_linear_degamma_lut);
2724  
2725  	return 0;
2726  }
2727  
glk_check_luts(const struct intel_crtc_state * crtc_state)2728  static int glk_check_luts(const struct intel_crtc_state *crtc_state)
2729  {
2730  	u32 degamma_tests = intel_degamma_lut_tests(crtc_state);
2731  	u32 gamma_tests = intel_gamma_lut_tests(crtc_state);
2732  
2733  	if (glk_use_pre_csc_lut_for_gamma(crtc_state))
2734  		gamma_tests |= degamma_tests;
2735  
2736  	return _check_luts(crtc_state, degamma_tests, gamma_tests);
2737  }
2738  
glk_color_check(struct intel_atomic_state * state,struct intel_crtc * crtc)2739  static int glk_color_check(struct intel_atomic_state *state,
2740  			   struct intel_crtc *crtc)
2741  {
2742  	struct drm_i915_private *i915 = to_i915(state->base.dev);
2743  	struct intel_crtc_state *crtc_state =
2744  		intel_atomic_get_new_crtc_state(state, crtc);
2745  	int ret;
2746  
2747  	ret = glk_check_luts(crtc_state);
2748  	if (ret)
2749  		return ret;
2750  
2751  	if (crtc_state->output_format != INTEL_OUTPUT_FORMAT_RGB &&
2752  	    crtc_state->hw.ctm) {
2753  		drm_dbg_kms(&i915->drm,
2754  			    "YCbCr and CTM together are not possible\n");
2755  		return -EINVAL;
2756  	}
2757  
2758  	if (crtc_state->output_format != INTEL_OUTPUT_FORMAT_RGB &&
2759  	    crtc_state->hw.degamma_lut && crtc_state->hw.gamma_lut) {
2760  		drm_dbg_kms(&i915->drm,
2761  			    "YCbCr and degamma+gamma together are not possible\n");
2762  		return -EINVAL;
2763  	}
2764  
2765  	crtc_state->gamma_enable =
2766  		!glk_use_pre_csc_lut_for_gamma(crtc_state) &&
2767  		crtc_state->hw.gamma_lut &&
2768  		!crtc_state->c8_planes;
2769  
2770  	/* On GLK+ degamma LUT is controlled by csc_enable */
2771  	crtc_state->csc_enable =
2772  		glk_use_pre_csc_lut_for_gamma(crtc_state) ||
2773  		crtc_state->hw.degamma_lut ||
2774  		crtc_state->output_format != INTEL_OUTPUT_FORMAT_RGB ||
2775  		crtc_state->hw.ctm || ilk_csc_limited_range(crtc_state);
2776  
2777  	crtc_state->gamma_mode = glk_gamma_mode(crtc_state);
2778  
2779  	crtc_state->csc_mode = 0;
2780  
2781  	ret = intel_color_add_affected_planes(state, crtc);
2782  	if (ret)
2783  		return ret;
2784  
2785  	ret = glk_assign_luts(crtc_state);
2786  	if (ret)
2787  		return ret;
2788  
2789  	ilk_assign_csc(crtc_state);
2790  
2791  	crtc_state->preload_luts = intel_can_preload_luts(state, crtc);
2792  
2793  	return 0;
2794  }
2795  
icl_gamma_mode(const struct intel_crtc_state * crtc_state)2796  static u32 icl_gamma_mode(const struct intel_crtc_state *crtc_state)
2797  {
2798  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
2799  	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
2800  	u32 gamma_mode = 0;
2801  
2802  	if (crtc_state->hw.degamma_lut)
2803  		gamma_mode |= PRE_CSC_GAMMA_ENABLE;
2804  
2805  	if (crtc_state->hw.gamma_lut &&
2806  	    !crtc_state->c8_planes)
2807  		gamma_mode |= POST_CSC_GAMMA_ENABLE;
2808  
2809  	if (!crtc_state->hw.gamma_lut ||
2810  	    lut_is_legacy(crtc_state->hw.gamma_lut))
2811  		gamma_mode |= GAMMA_MODE_MODE_8BIT;
2812  	/*
2813  	 * Enable 10bit gamma for D13
2814  	 * ToDo: Extend to Logarithmic Gamma once the new UAPI
2815  	 * is accepted and implemented by a userspace consumer
2816  	 */
2817  	else if (DISPLAY_VER(i915) >= 13)
2818  		gamma_mode |= GAMMA_MODE_MODE_10BIT;
2819  	else
2820  		gamma_mode |= GAMMA_MODE_MODE_12BIT_MULTI_SEG;
2821  
2822  	return gamma_mode;
2823  }
2824  
icl_csc_mode(const struct intel_crtc_state * crtc_state)2825  static u32 icl_csc_mode(const struct intel_crtc_state *crtc_state)
2826  {
2827  	u32 csc_mode = 0;
2828  
2829  	if (crtc_state->hw.ctm)
2830  		csc_mode |= ICL_CSC_ENABLE;
2831  
2832  	if (crtc_state->output_format != INTEL_OUTPUT_FORMAT_RGB ||
2833  	    crtc_state->limited_color_range)
2834  		csc_mode |= ICL_OUTPUT_CSC_ENABLE;
2835  
2836  	return csc_mode;
2837  }
2838  
icl_color_check(struct intel_atomic_state * state,struct intel_crtc * crtc)2839  static int icl_color_check(struct intel_atomic_state *state,
2840  			   struct intel_crtc *crtc)
2841  {
2842  	struct intel_crtc_state *crtc_state =
2843  		intel_atomic_get_new_crtc_state(state, crtc);
2844  	int ret;
2845  
2846  	ret = check_luts(crtc_state);
2847  	if (ret)
2848  		return ret;
2849  
2850  	crtc_state->gamma_mode = icl_gamma_mode(crtc_state);
2851  
2852  	crtc_state->csc_mode = icl_csc_mode(crtc_state);
2853  
2854  	intel_assign_luts(crtc_state);
2855  
2856  	icl_assign_csc(crtc_state);
2857  
2858  	crtc_state->preload_luts = intel_can_preload_luts(state, crtc);
2859  
2860  	return 0;
2861  }
2862  
i9xx_post_csc_lut_precision(const struct intel_crtc_state * crtc_state)2863  static int i9xx_post_csc_lut_precision(const struct intel_crtc_state *crtc_state)
2864  {
2865  	if (!crtc_state->gamma_enable && !crtc_state->c8_planes)
2866  		return 0;
2867  
2868  	switch (crtc_state->gamma_mode) {
2869  	case GAMMA_MODE_MODE_8BIT:
2870  		return 8;
2871  	case GAMMA_MODE_MODE_10BIT:
2872  		return 10;
2873  	default:
2874  		MISSING_CASE(crtc_state->gamma_mode);
2875  		return 0;
2876  	}
2877  }
2878  
i9xx_pre_csc_lut_precision(const struct intel_crtc_state * crtc_state)2879  static int i9xx_pre_csc_lut_precision(const struct intel_crtc_state *crtc_state)
2880  {
2881  	return 0;
2882  }
2883  
i965_post_csc_lut_precision(const struct intel_crtc_state * crtc_state)2884  static int i965_post_csc_lut_precision(const struct intel_crtc_state *crtc_state)
2885  {
2886  	if (!crtc_state->gamma_enable && !crtc_state->c8_planes)
2887  		return 0;
2888  
2889  	switch (crtc_state->gamma_mode) {
2890  	case GAMMA_MODE_MODE_8BIT:
2891  		return 8;
2892  	case GAMMA_MODE_MODE_10BIT:
2893  		return 16;
2894  	default:
2895  		MISSING_CASE(crtc_state->gamma_mode);
2896  		return 0;
2897  	}
2898  }
2899  
ilk_gamma_mode_precision(u32 gamma_mode)2900  static int ilk_gamma_mode_precision(u32 gamma_mode)
2901  {
2902  	switch (gamma_mode) {
2903  	case GAMMA_MODE_MODE_8BIT:
2904  		return 8;
2905  	case GAMMA_MODE_MODE_10BIT:
2906  		return 10;
2907  	default:
2908  		MISSING_CASE(gamma_mode);
2909  		return 0;
2910  	}
2911  }
2912  
ilk_has_post_csc_lut(const struct intel_crtc_state * crtc_state)2913  static bool ilk_has_post_csc_lut(const struct intel_crtc_state *crtc_state)
2914  {
2915  	if (crtc_state->c8_planes)
2916  		return true;
2917  
2918  	return crtc_state->gamma_enable &&
2919  		(crtc_state->csc_mode & CSC_POSITION_BEFORE_GAMMA) != 0;
2920  }
2921  
ilk_has_pre_csc_lut(const struct intel_crtc_state * crtc_state)2922  static bool ilk_has_pre_csc_lut(const struct intel_crtc_state *crtc_state)
2923  {
2924  	return crtc_state->gamma_enable &&
2925  		(crtc_state->csc_mode & CSC_POSITION_BEFORE_GAMMA) == 0;
2926  }
2927  
ilk_post_csc_lut_precision(const struct intel_crtc_state * crtc_state)2928  static int ilk_post_csc_lut_precision(const struct intel_crtc_state *crtc_state)
2929  {
2930  	if (!ilk_has_post_csc_lut(crtc_state))
2931  		return 0;
2932  
2933  	return ilk_gamma_mode_precision(crtc_state->gamma_mode);
2934  }
2935  
ilk_pre_csc_lut_precision(const struct intel_crtc_state * crtc_state)2936  static int ilk_pre_csc_lut_precision(const struct intel_crtc_state *crtc_state)
2937  {
2938  	if (!ilk_has_pre_csc_lut(crtc_state))
2939  		return 0;
2940  
2941  	return ilk_gamma_mode_precision(crtc_state->gamma_mode);
2942  }
2943  
ivb_post_csc_lut_precision(const struct intel_crtc_state * crtc_state)2944  static int ivb_post_csc_lut_precision(const struct intel_crtc_state *crtc_state)
2945  {
2946  	if (crtc_state->gamma_enable &&
2947  	    crtc_state->gamma_mode == GAMMA_MODE_MODE_SPLIT)
2948  		return 10;
2949  
2950  	return ilk_post_csc_lut_precision(crtc_state);
2951  }
2952  
ivb_pre_csc_lut_precision(const struct intel_crtc_state * crtc_state)2953  static int ivb_pre_csc_lut_precision(const struct intel_crtc_state *crtc_state)
2954  {
2955  	if (crtc_state->gamma_enable &&
2956  	    crtc_state->gamma_mode == GAMMA_MODE_MODE_SPLIT)
2957  		return 10;
2958  
2959  	return ilk_pre_csc_lut_precision(crtc_state);
2960  }
2961  
chv_post_csc_lut_precision(const struct intel_crtc_state * crtc_state)2962  static int chv_post_csc_lut_precision(const struct intel_crtc_state *crtc_state)
2963  {
2964  	if (crtc_state->cgm_mode & CGM_PIPE_MODE_GAMMA)
2965  		return 10;
2966  
2967  	return i965_post_csc_lut_precision(crtc_state);
2968  }
2969  
chv_pre_csc_lut_precision(const struct intel_crtc_state * crtc_state)2970  static int chv_pre_csc_lut_precision(const struct intel_crtc_state *crtc_state)
2971  {
2972  	if (crtc_state->cgm_mode & CGM_PIPE_MODE_DEGAMMA)
2973  		return 14;
2974  
2975  	return 0;
2976  }
2977  
glk_post_csc_lut_precision(const struct intel_crtc_state * crtc_state)2978  static int glk_post_csc_lut_precision(const struct intel_crtc_state *crtc_state)
2979  {
2980  	if (!crtc_state->gamma_enable && !crtc_state->c8_planes)
2981  		return 0;
2982  
2983  	return ilk_gamma_mode_precision(crtc_state->gamma_mode);
2984  }
2985  
glk_pre_csc_lut_precision(const struct intel_crtc_state * crtc_state)2986  static int glk_pre_csc_lut_precision(const struct intel_crtc_state *crtc_state)
2987  {
2988  	if (!crtc_state->csc_enable)
2989  		return 0;
2990  
2991  	return 16;
2992  }
2993  
icl_has_post_csc_lut(const struct intel_crtc_state * crtc_state)2994  static bool icl_has_post_csc_lut(const struct intel_crtc_state *crtc_state)
2995  {
2996  	if (crtc_state->c8_planes)
2997  		return true;
2998  
2999  	return crtc_state->gamma_mode & POST_CSC_GAMMA_ENABLE;
3000  }
3001  
icl_has_pre_csc_lut(const struct intel_crtc_state * crtc_state)3002  static bool icl_has_pre_csc_lut(const struct intel_crtc_state *crtc_state)
3003  {
3004  	return crtc_state->gamma_mode & PRE_CSC_GAMMA_ENABLE;
3005  }
3006  
icl_post_csc_lut_precision(const struct intel_crtc_state * crtc_state)3007  static int icl_post_csc_lut_precision(const struct intel_crtc_state *crtc_state)
3008  {
3009  	if (!icl_has_post_csc_lut(crtc_state))
3010  		return 0;
3011  
3012  	switch (crtc_state->gamma_mode & GAMMA_MODE_MODE_MASK) {
3013  	case GAMMA_MODE_MODE_8BIT:
3014  		return 8;
3015  	case GAMMA_MODE_MODE_10BIT:
3016  		return 10;
3017  	case GAMMA_MODE_MODE_12BIT_MULTI_SEG:
3018  		return 16;
3019  	default:
3020  		MISSING_CASE(crtc_state->gamma_mode);
3021  		return 0;
3022  	}
3023  }
3024  
icl_pre_csc_lut_precision(const struct intel_crtc_state * crtc_state)3025  static int icl_pre_csc_lut_precision(const struct intel_crtc_state *crtc_state)
3026  {
3027  	if (!icl_has_pre_csc_lut(crtc_state))
3028  		return 0;
3029  
3030  	return 16;
3031  }
3032  
err_check(const struct drm_color_lut * lut1,const struct drm_color_lut * lut2,u32 err)3033  static bool err_check(const struct drm_color_lut *lut1,
3034  		      const struct drm_color_lut *lut2, u32 err)
3035  {
3036  	return ((abs((long)lut2->red - lut1->red)) <= err) &&
3037  		((abs((long)lut2->blue - lut1->blue)) <= err) &&
3038  		((abs((long)lut2->green - lut1->green)) <= err);
3039  }
3040  
intel_lut_entries_equal(const struct drm_color_lut * lut1,const struct drm_color_lut * lut2,int lut_size,u32 err)3041  static bool intel_lut_entries_equal(const struct drm_color_lut *lut1,
3042  				    const struct drm_color_lut *lut2,
3043  				    int lut_size, u32 err)
3044  {
3045  	int i;
3046  
3047  	for (i = 0; i < lut_size; i++) {
3048  		if (!err_check(&lut1[i], &lut2[i], err))
3049  			return false;
3050  	}
3051  
3052  	return true;
3053  }
3054  
intel_lut_equal(const struct drm_property_blob * blob1,const struct drm_property_blob * blob2,int check_size,int precision)3055  static bool intel_lut_equal(const struct drm_property_blob *blob1,
3056  			    const struct drm_property_blob *blob2,
3057  			    int check_size, int precision)
3058  {
3059  	const struct drm_color_lut *lut1, *lut2;
3060  	int lut_size1, lut_size2;
3061  	u32 err;
3062  
3063  	if (!blob1 != !blob2)
3064  		return false;
3065  
3066  	if (!blob1 != !precision)
3067  		return false;
3068  
3069  	if (!blob1)
3070  		return true;
3071  
3072  	lut_size1 = drm_color_lut_size(blob1);
3073  	lut_size2 = drm_color_lut_size(blob2);
3074  
3075  	if (lut_size1 != lut_size2)
3076  		return false;
3077  
3078  	if (check_size > lut_size1)
3079  		return false;
3080  
3081  	lut1 = blob1->data;
3082  	lut2 = blob2->data;
3083  
3084  	err = 0xffff >> precision;
3085  
3086  	if (!check_size)
3087  		check_size = lut_size1;
3088  
3089  	return intel_lut_entries_equal(lut1, lut2, check_size, err);
3090  }
3091  
i9xx_lut_equal(const struct intel_crtc_state * crtc_state,const struct drm_property_blob * blob1,const struct drm_property_blob * blob2,bool is_pre_csc_lut)3092  static bool i9xx_lut_equal(const struct intel_crtc_state *crtc_state,
3093  			   const struct drm_property_blob *blob1,
3094  			   const struct drm_property_blob *blob2,
3095  			   bool is_pre_csc_lut)
3096  {
3097  	int check_size = 0;
3098  
3099  	if (is_pre_csc_lut)
3100  		return intel_lut_equal(blob1, blob2, 0,
3101  				       i9xx_pre_csc_lut_precision(crtc_state));
3102  
3103  	/* 10bit mode last entry is implicit, just skip it */
3104  	if (crtc_state->gamma_mode == GAMMA_MODE_MODE_10BIT)
3105  		check_size = 128;
3106  
3107  	return intel_lut_equal(blob1, blob2, check_size,
3108  			       i9xx_post_csc_lut_precision(crtc_state));
3109  }
3110  
i965_lut_equal(const struct intel_crtc_state * crtc_state,const struct drm_property_blob * blob1,const struct drm_property_blob * blob2,bool is_pre_csc_lut)3111  static bool i965_lut_equal(const struct intel_crtc_state *crtc_state,
3112  			   const struct drm_property_blob *blob1,
3113  			   const struct drm_property_blob *blob2,
3114  			   bool is_pre_csc_lut)
3115  {
3116  	if (is_pre_csc_lut)
3117  		return intel_lut_equal(blob1, blob2, 0,
3118  				       i9xx_pre_csc_lut_precision(crtc_state));
3119  	else
3120  		return intel_lut_equal(blob1, blob2, 0,
3121  				       i965_post_csc_lut_precision(crtc_state));
3122  }
3123  
chv_lut_equal(const struct intel_crtc_state * crtc_state,const struct drm_property_blob * blob1,const struct drm_property_blob * blob2,bool is_pre_csc_lut)3124  static bool chv_lut_equal(const struct intel_crtc_state *crtc_state,
3125  			  const struct drm_property_blob *blob1,
3126  			  const struct drm_property_blob *blob2,
3127  			  bool is_pre_csc_lut)
3128  {
3129  	if (is_pre_csc_lut)
3130  		return intel_lut_equal(blob1, blob2, 0,
3131  				       chv_pre_csc_lut_precision(crtc_state));
3132  	else
3133  		return intel_lut_equal(blob1, blob2, 0,
3134  				       chv_post_csc_lut_precision(crtc_state));
3135  }
3136  
ilk_lut_equal(const struct intel_crtc_state * crtc_state,const struct drm_property_blob * blob1,const struct drm_property_blob * blob2,bool is_pre_csc_lut)3137  static bool ilk_lut_equal(const struct intel_crtc_state *crtc_state,
3138  			  const struct drm_property_blob *blob1,
3139  			  const struct drm_property_blob *blob2,
3140  			  bool is_pre_csc_lut)
3141  {
3142  	if (is_pre_csc_lut)
3143  		return intel_lut_equal(blob1, blob2, 0,
3144  				       ilk_pre_csc_lut_precision(crtc_state));
3145  	else
3146  		return intel_lut_equal(blob1, blob2, 0,
3147  				       ilk_post_csc_lut_precision(crtc_state));
3148  }
3149  
ivb_lut_equal(const struct intel_crtc_state * crtc_state,const struct drm_property_blob * blob1,const struct drm_property_blob * blob2,bool is_pre_csc_lut)3150  static bool ivb_lut_equal(const struct intel_crtc_state *crtc_state,
3151  			  const struct drm_property_blob *blob1,
3152  			  const struct drm_property_blob *blob2,
3153  			  bool is_pre_csc_lut)
3154  {
3155  	if (is_pre_csc_lut)
3156  		return intel_lut_equal(blob1, blob2, 0,
3157  				       ivb_pre_csc_lut_precision(crtc_state));
3158  	else
3159  		return intel_lut_equal(blob1, blob2, 0,
3160  				       ivb_post_csc_lut_precision(crtc_state));
3161  }
3162  
glk_lut_equal(const struct intel_crtc_state * crtc_state,const struct drm_property_blob * blob1,const struct drm_property_blob * blob2,bool is_pre_csc_lut)3163  static bool glk_lut_equal(const struct intel_crtc_state *crtc_state,
3164  			  const struct drm_property_blob *blob1,
3165  			  const struct drm_property_blob *blob2,
3166  			  bool is_pre_csc_lut)
3167  {
3168  	if (is_pre_csc_lut)
3169  		return intel_lut_equal(blob1, blob2, 0,
3170  				       glk_pre_csc_lut_precision(crtc_state));
3171  	else
3172  		return intel_lut_equal(blob1, blob2, 0,
3173  				       glk_post_csc_lut_precision(crtc_state));
3174  }
3175  
icl_lut_equal(const struct intel_crtc_state * crtc_state,const struct drm_property_blob * blob1,const struct drm_property_blob * blob2,bool is_pre_csc_lut)3176  static bool icl_lut_equal(const struct intel_crtc_state *crtc_state,
3177  			  const struct drm_property_blob *blob1,
3178  			  const struct drm_property_blob *blob2,
3179  			  bool is_pre_csc_lut)
3180  {
3181  	int check_size = 0;
3182  
3183  	if (is_pre_csc_lut)
3184  		return intel_lut_equal(blob1, blob2, 0,
3185  				       icl_pre_csc_lut_precision(crtc_state));
3186  
3187  	/* hw readout broken except for the super fine segment :( */
3188  	if ((crtc_state->gamma_mode & GAMMA_MODE_MODE_MASK) ==
3189  	    GAMMA_MODE_MODE_12BIT_MULTI_SEG)
3190  		check_size = 9;
3191  
3192  	return intel_lut_equal(blob1, blob2, check_size,
3193  			       icl_post_csc_lut_precision(crtc_state));
3194  }
3195  
i9xx_read_lut_8(struct intel_crtc * crtc)3196  static struct drm_property_blob *i9xx_read_lut_8(struct intel_crtc *crtc)
3197  {
3198  	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
3199  	enum pipe pipe = crtc->pipe;
3200  	struct drm_property_blob *blob;
3201  	struct drm_color_lut *lut;
3202  	int i;
3203  
3204  	blob = drm_property_create_blob(&dev_priv->drm,
3205  					sizeof(lut[0]) * LEGACY_LUT_LENGTH,
3206  					NULL);
3207  	if (IS_ERR(blob))
3208  		return NULL;
3209  
3210  	lut = blob->data;
3211  
3212  	for (i = 0; i < LEGACY_LUT_LENGTH; i++) {
3213  		u32 val = intel_de_read_fw(dev_priv,
3214  					   PALETTE(dev_priv, pipe, i));
3215  
3216  		i9xx_lut_8_pack(&lut[i], val);
3217  	}
3218  
3219  	return blob;
3220  }
3221  
i9xx_read_lut_10(struct intel_crtc * crtc)3222  static struct drm_property_blob *i9xx_read_lut_10(struct intel_crtc *crtc)
3223  {
3224  	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
3225  	u32 lut_size = DISPLAY_INFO(dev_priv)->color.gamma_lut_size;
3226  	enum pipe pipe = crtc->pipe;
3227  	struct drm_property_blob *blob;
3228  	struct drm_color_lut *lut;
3229  	u32 ldw, udw;
3230  	int i;
3231  
3232  	blob = drm_property_create_blob(&dev_priv->drm,
3233  					lut_size * sizeof(lut[0]), NULL);
3234  	if (IS_ERR(blob))
3235  		return NULL;
3236  
3237  	lut = blob->data;
3238  
3239  	for (i = 0; i < lut_size - 1; i++) {
3240  		ldw = intel_de_read_fw(dev_priv,
3241  				       PALETTE(dev_priv, pipe, 2 * i + 0));
3242  		udw = intel_de_read_fw(dev_priv,
3243  				       PALETTE(dev_priv, pipe, 2 * i + 1));
3244  
3245  		i9xx_lut_10_pack(&lut[i], ldw, udw);
3246  	}
3247  
3248  	i9xx_lut_10_pack_slope(&lut[i], ldw, udw);
3249  
3250  	return blob;
3251  }
3252  
i9xx_read_luts(struct intel_crtc_state * crtc_state)3253  static void i9xx_read_luts(struct intel_crtc_state *crtc_state)
3254  {
3255  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
3256  
3257  	if (!crtc_state->gamma_enable && !crtc_state->c8_planes)
3258  		return;
3259  
3260  	switch (crtc_state->gamma_mode) {
3261  	case GAMMA_MODE_MODE_8BIT:
3262  		crtc_state->post_csc_lut = i9xx_read_lut_8(crtc);
3263  		break;
3264  	case GAMMA_MODE_MODE_10BIT:
3265  		crtc_state->post_csc_lut = i9xx_read_lut_10(crtc);
3266  		break;
3267  	default:
3268  		MISSING_CASE(crtc_state->gamma_mode);
3269  		break;
3270  	}
3271  }
3272  
i965_read_lut_10p6(struct intel_crtc * crtc)3273  static struct drm_property_blob *i965_read_lut_10p6(struct intel_crtc *crtc)
3274  {
3275  	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
3276  	int i, lut_size = DISPLAY_INFO(dev_priv)->color.gamma_lut_size;
3277  	enum pipe pipe = crtc->pipe;
3278  	struct drm_property_blob *blob;
3279  	struct drm_color_lut *lut;
3280  
3281  	blob = drm_property_create_blob(&dev_priv->drm,
3282  					sizeof(lut[0]) * lut_size,
3283  					NULL);
3284  	if (IS_ERR(blob))
3285  		return NULL;
3286  
3287  	lut = blob->data;
3288  
3289  	for (i = 0; i < lut_size - 1; i++) {
3290  		u32 ldw = intel_de_read_fw(dev_priv,
3291  					   PALETTE(dev_priv, pipe, 2 * i + 0));
3292  		u32 udw = intel_de_read_fw(dev_priv,
3293  					   PALETTE(dev_priv, pipe, 2 * i + 1));
3294  
3295  		i965_lut_10p6_pack(&lut[i], ldw, udw);
3296  	}
3297  
3298  	lut[i].red = i965_lut_11p6_max_pack(intel_de_read_fw(dev_priv, PIPEGCMAX(dev_priv, pipe, 0)));
3299  	lut[i].green = i965_lut_11p6_max_pack(intel_de_read_fw(dev_priv, PIPEGCMAX(dev_priv, pipe, 1)));
3300  	lut[i].blue = i965_lut_11p6_max_pack(intel_de_read_fw(dev_priv, PIPEGCMAX(dev_priv, pipe, 2)));
3301  
3302  	return blob;
3303  }
3304  
i965_read_luts(struct intel_crtc_state * crtc_state)3305  static void i965_read_luts(struct intel_crtc_state *crtc_state)
3306  {
3307  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
3308  
3309  	if (!crtc_state->gamma_enable && !crtc_state->c8_planes)
3310  		return;
3311  
3312  	switch (crtc_state->gamma_mode) {
3313  	case GAMMA_MODE_MODE_8BIT:
3314  		crtc_state->post_csc_lut = i9xx_read_lut_8(crtc);
3315  		break;
3316  	case GAMMA_MODE_MODE_10BIT:
3317  		crtc_state->post_csc_lut = i965_read_lut_10p6(crtc);
3318  		break;
3319  	default:
3320  		MISSING_CASE(crtc_state->gamma_mode);
3321  		break;
3322  	}
3323  }
3324  
chv_read_cgm_degamma(struct intel_crtc * crtc)3325  static struct drm_property_blob *chv_read_cgm_degamma(struct intel_crtc *crtc)
3326  {
3327  	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
3328  	int i, lut_size = DISPLAY_INFO(dev_priv)->color.degamma_lut_size;
3329  	enum pipe pipe = crtc->pipe;
3330  	struct drm_property_blob *blob;
3331  	struct drm_color_lut *lut;
3332  
3333  	blob = drm_property_create_blob(&dev_priv->drm,
3334  					sizeof(lut[0]) * lut_size,
3335  					NULL);
3336  	if (IS_ERR(blob))
3337  		return NULL;
3338  
3339  	lut = blob->data;
3340  
3341  	for (i = 0; i < lut_size; i++) {
3342  		u32 ldw = intel_de_read_fw(dev_priv, CGM_PIPE_DEGAMMA(pipe, i, 0));
3343  		u32 udw = intel_de_read_fw(dev_priv, CGM_PIPE_DEGAMMA(pipe, i, 1));
3344  
3345  		chv_cgm_degamma_pack(&lut[i], ldw, udw);
3346  	}
3347  
3348  	return blob;
3349  }
3350  
chv_read_cgm_gamma(struct intel_crtc * crtc)3351  static struct drm_property_blob *chv_read_cgm_gamma(struct intel_crtc *crtc)
3352  {
3353  	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
3354  	int i, lut_size = DISPLAY_INFO(i915)->color.gamma_lut_size;
3355  	enum pipe pipe = crtc->pipe;
3356  	struct drm_property_blob *blob;
3357  	struct drm_color_lut *lut;
3358  
3359  	blob = drm_property_create_blob(&i915->drm,
3360  					sizeof(lut[0]) * lut_size,
3361  					NULL);
3362  	if (IS_ERR(blob))
3363  		return NULL;
3364  
3365  	lut = blob->data;
3366  
3367  	for (i = 0; i < lut_size; i++) {
3368  		u32 ldw = intel_de_read_fw(i915, CGM_PIPE_GAMMA(pipe, i, 0));
3369  		u32 udw = intel_de_read_fw(i915, CGM_PIPE_GAMMA(pipe, i, 1));
3370  
3371  		chv_cgm_gamma_pack(&lut[i], ldw, udw);
3372  	}
3373  
3374  	return blob;
3375  }
3376  
chv_get_config(struct intel_crtc_state * crtc_state)3377  static void chv_get_config(struct intel_crtc_state *crtc_state)
3378  {
3379  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
3380  	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
3381  
3382  	crtc_state->cgm_mode = intel_de_read(i915, CGM_PIPE_MODE(crtc->pipe));
3383  
3384  	i9xx_get_config(crtc_state);
3385  }
3386  
chv_read_luts(struct intel_crtc_state * crtc_state)3387  static void chv_read_luts(struct intel_crtc_state *crtc_state)
3388  {
3389  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
3390  
3391  	if (crtc_state->cgm_mode & CGM_PIPE_MODE_DEGAMMA)
3392  		crtc_state->pre_csc_lut = chv_read_cgm_degamma(crtc);
3393  
3394  	if (crtc_state->cgm_mode & CGM_PIPE_MODE_GAMMA)
3395  		crtc_state->post_csc_lut = chv_read_cgm_gamma(crtc);
3396  	else
3397  		i965_read_luts(crtc_state);
3398  }
3399  
ilk_read_lut_8(struct intel_crtc * crtc)3400  static struct drm_property_blob *ilk_read_lut_8(struct intel_crtc *crtc)
3401  {
3402  	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
3403  	enum pipe pipe = crtc->pipe;
3404  	struct drm_property_blob *blob;
3405  	struct drm_color_lut *lut;
3406  	int i;
3407  
3408  	blob = drm_property_create_blob(&i915->drm,
3409  					sizeof(lut[0]) * LEGACY_LUT_LENGTH,
3410  					NULL);
3411  	if (IS_ERR(blob))
3412  		return NULL;
3413  
3414  	lut = blob->data;
3415  
3416  	for (i = 0; i < LEGACY_LUT_LENGTH; i++) {
3417  		u32 val = intel_de_read_fw(i915, LGC_PALETTE(pipe, i));
3418  
3419  		i9xx_lut_8_pack(&lut[i], val);
3420  	}
3421  
3422  	return blob;
3423  }
3424  
ilk_read_lut_10(struct intel_crtc * crtc)3425  static struct drm_property_blob *ilk_read_lut_10(struct intel_crtc *crtc)
3426  {
3427  	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
3428  	int i, lut_size = DISPLAY_INFO(i915)->color.gamma_lut_size;
3429  	enum pipe pipe = crtc->pipe;
3430  	struct drm_property_blob *blob;
3431  	struct drm_color_lut *lut;
3432  
3433  	blob = drm_property_create_blob(&i915->drm,
3434  					sizeof(lut[0]) * lut_size,
3435  					NULL);
3436  	if (IS_ERR(blob))
3437  		return NULL;
3438  
3439  	lut = blob->data;
3440  
3441  	for (i = 0; i < lut_size; i++) {
3442  		u32 val = intel_de_read_fw(i915, PREC_PALETTE(pipe, i));
3443  
3444  		ilk_lut_10_pack(&lut[i], val);
3445  	}
3446  
3447  	return blob;
3448  }
3449  
ilk_get_config(struct intel_crtc_state * crtc_state)3450  static void ilk_get_config(struct intel_crtc_state *crtc_state)
3451  {
3452  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
3453  
3454  	crtc_state->csc_mode = ilk_read_csc_mode(crtc);
3455  
3456  	i9xx_get_config(crtc_state);
3457  }
3458  
ilk_read_luts(struct intel_crtc_state * crtc_state)3459  static void ilk_read_luts(struct intel_crtc_state *crtc_state)
3460  {
3461  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
3462  	struct drm_property_blob **blob =
3463  		ilk_has_post_csc_lut(crtc_state) ?
3464  		&crtc_state->post_csc_lut : &crtc_state->pre_csc_lut;
3465  
3466  	if (!crtc_state->gamma_enable && !crtc_state->c8_planes)
3467  		return;
3468  
3469  	switch (crtc_state->gamma_mode) {
3470  	case GAMMA_MODE_MODE_8BIT:
3471  		*blob = ilk_read_lut_8(crtc);
3472  		break;
3473  	case GAMMA_MODE_MODE_10BIT:
3474  		*blob = ilk_read_lut_10(crtc);
3475  		break;
3476  	default:
3477  		MISSING_CASE(crtc_state->gamma_mode);
3478  		break;
3479  	}
3480  }
3481  
3482  /*
3483   * IVB/HSW Bspec / PAL_PREC_INDEX:
3484   * "Restriction : Index auto increment mode is not
3485   *  supported and must not be enabled."
3486   */
ivb_read_lut_10(struct intel_crtc * crtc,u32 prec_index)3487  static struct drm_property_blob *ivb_read_lut_10(struct intel_crtc *crtc,
3488  						 u32 prec_index)
3489  {
3490  	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
3491  	int i, lut_size = ivb_lut_10_size(prec_index);
3492  	enum pipe pipe = crtc->pipe;
3493  	struct drm_property_blob *blob;
3494  	struct drm_color_lut *lut;
3495  
3496  	blob = drm_property_create_blob(&dev_priv->drm,
3497  					sizeof(lut[0]) * lut_size,
3498  					NULL);
3499  	if (IS_ERR(blob))
3500  		return NULL;
3501  
3502  	lut = blob->data;
3503  
3504  	for (i = 0; i < lut_size; i++) {
3505  		u32 val;
3506  
3507  		intel_de_write_fw(dev_priv, PREC_PAL_INDEX(pipe),
3508  				  prec_index + i);
3509  		val = intel_de_read_fw(dev_priv, PREC_PAL_DATA(pipe));
3510  
3511  		ilk_lut_10_pack(&lut[i], val);
3512  	}
3513  
3514  	intel_de_write_fw(dev_priv, PREC_PAL_INDEX(pipe),
3515  			  PAL_PREC_INDEX_VALUE(0));
3516  
3517  	return blob;
3518  }
3519  
ivb_read_luts(struct intel_crtc_state * crtc_state)3520  static void ivb_read_luts(struct intel_crtc_state *crtc_state)
3521  {
3522  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
3523  	struct drm_property_blob **blob =
3524  		ilk_has_post_csc_lut(crtc_state) ?
3525  		&crtc_state->post_csc_lut : &crtc_state->pre_csc_lut;
3526  
3527  	if (!crtc_state->gamma_enable && !crtc_state->c8_planes)
3528  		return;
3529  
3530  	switch (crtc_state->gamma_mode) {
3531  	case GAMMA_MODE_MODE_8BIT:
3532  		*blob = ilk_read_lut_8(crtc);
3533  		break;
3534  	case GAMMA_MODE_MODE_SPLIT:
3535  		crtc_state->pre_csc_lut =
3536  			ivb_read_lut_10(crtc, PAL_PREC_SPLIT_MODE |
3537  					PAL_PREC_INDEX_VALUE(0));
3538  		crtc_state->post_csc_lut =
3539  			ivb_read_lut_10(crtc, PAL_PREC_SPLIT_MODE |
3540  					PAL_PREC_INDEX_VALUE(512));
3541  		break;
3542  	case GAMMA_MODE_MODE_10BIT:
3543  		*blob = ivb_read_lut_10(crtc, PAL_PREC_INDEX_VALUE(0));
3544  		break;
3545  	default:
3546  		MISSING_CASE(crtc_state->gamma_mode);
3547  		break;
3548  	}
3549  }
3550  
3551  /* On BDW+ the index auto increment mode actually works */
bdw_read_lut_10(struct intel_crtc * crtc,u32 prec_index)3552  static struct drm_property_blob *bdw_read_lut_10(struct intel_crtc *crtc,
3553  						 u32 prec_index)
3554  {
3555  	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
3556  	int i, lut_size = ivb_lut_10_size(prec_index);
3557  	enum pipe pipe = crtc->pipe;
3558  	struct drm_property_blob *blob;
3559  	struct drm_color_lut *lut;
3560  
3561  	blob = drm_property_create_blob(&i915->drm,
3562  					sizeof(lut[0]) * lut_size,
3563  					NULL);
3564  	if (IS_ERR(blob))
3565  		return NULL;
3566  
3567  	lut = blob->data;
3568  
3569  	intel_de_write_fw(i915, PREC_PAL_INDEX(pipe),
3570  			  prec_index);
3571  	intel_de_write_fw(i915, PREC_PAL_INDEX(pipe),
3572  			  PAL_PREC_AUTO_INCREMENT |
3573  			  prec_index);
3574  
3575  	for (i = 0; i < lut_size; i++) {
3576  		u32 val = intel_de_read_fw(i915, PREC_PAL_DATA(pipe));
3577  
3578  		ilk_lut_10_pack(&lut[i], val);
3579  	}
3580  
3581  	intel_de_write_fw(i915, PREC_PAL_INDEX(pipe),
3582  			  PAL_PREC_INDEX_VALUE(0));
3583  
3584  	return blob;
3585  }
3586  
bdw_read_luts(struct intel_crtc_state * crtc_state)3587  static void bdw_read_luts(struct intel_crtc_state *crtc_state)
3588  {
3589  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
3590  	struct drm_property_blob **blob =
3591  		ilk_has_post_csc_lut(crtc_state) ?
3592  		&crtc_state->post_csc_lut : &crtc_state->pre_csc_lut;
3593  
3594  	if (!crtc_state->gamma_enable && !crtc_state->c8_planes)
3595  		return;
3596  
3597  	switch (crtc_state->gamma_mode) {
3598  	case GAMMA_MODE_MODE_8BIT:
3599  		*blob = ilk_read_lut_8(crtc);
3600  		break;
3601  	case GAMMA_MODE_MODE_SPLIT:
3602  		crtc_state->pre_csc_lut =
3603  			bdw_read_lut_10(crtc, PAL_PREC_SPLIT_MODE |
3604  					PAL_PREC_INDEX_VALUE(0));
3605  		crtc_state->post_csc_lut =
3606  			bdw_read_lut_10(crtc, PAL_PREC_SPLIT_MODE |
3607  					PAL_PREC_INDEX_VALUE(512));
3608  		break;
3609  	case GAMMA_MODE_MODE_10BIT:
3610  		*blob = bdw_read_lut_10(crtc, PAL_PREC_INDEX_VALUE(0));
3611  		break;
3612  	default:
3613  		MISSING_CASE(crtc_state->gamma_mode);
3614  		break;
3615  	}
3616  }
3617  
glk_read_degamma_lut(struct intel_crtc * crtc)3618  static struct drm_property_blob *glk_read_degamma_lut(struct intel_crtc *crtc)
3619  {
3620  	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
3621  	int i, lut_size = DISPLAY_INFO(dev_priv)->color.degamma_lut_size;
3622  	enum pipe pipe = crtc->pipe;
3623  	struct drm_property_blob *blob;
3624  	struct drm_color_lut *lut;
3625  
3626  	blob = drm_property_create_blob(&dev_priv->drm,
3627  					sizeof(lut[0]) * lut_size,
3628  					NULL);
3629  	if (IS_ERR(blob))
3630  		return NULL;
3631  
3632  	lut = blob->data;
3633  
3634  	/*
3635  	 * When setting the auto-increment bit, the hardware seems to
3636  	 * ignore the index bits, so we need to reset it to index 0
3637  	 * separately.
3638  	 */
3639  	intel_de_write_fw(dev_priv, PRE_CSC_GAMC_INDEX(pipe),
3640  			  PRE_CSC_GAMC_INDEX_VALUE(0));
3641  	intel_de_write_fw(dev_priv, PRE_CSC_GAMC_INDEX(pipe),
3642  			  PRE_CSC_GAMC_AUTO_INCREMENT |
3643  			  PRE_CSC_GAMC_INDEX_VALUE(0));
3644  
3645  	for (i = 0; i < lut_size; i++) {
3646  		u32 val = intel_de_read_fw(dev_priv, PRE_CSC_GAMC_DATA(pipe));
3647  
3648  		if (DISPLAY_VER(dev_priv) >= 14)
3649  			mtl_degamma_lut_pack(&lut[i], val);
3650  		else
3651  			glk_degamma_lut_pack(&lut[i], val);
3652  	}
3653  
3654  	intel_de_write_fw(dev_priv, PRE_CSC_GAMC_INDEX(pipe),
3655  			  PRE_CSC_GAMC_INDEX_VALUE(0));
3656  
3657  	return blob;
3658  }
3659  
glk_read_luts(struct intel_crtc_state * crtc_state)3660  static void glk_read_luts(struct intel_crtc_state *crtc_state)
3661  {
3662  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
3663  
3664  	if (crtc_state->csc_enable)
3665  		crtc_state->pre_csc_lut = glk_read_degamma_lut(crtc);
3666  
3667  	if (!crtc_state->gamma_enable && !crtc_state->c8_planes)
3668  		return;
3669  
3670  	switch (crtc_state->gamma_mode) {
3671  	case GAMMA_MODE_MODE_8BIT:
3672  		crtc_state->post_csc_lut = ilk_read_lut_8(crtc);
3673  		break;
3674  	case GAMMA_MODE_MODE_10BIT:
3675  		crtc_state->post_csc_lut = bdw_read_lut_10(crtc, PAL_PREC_INDEX_VALUE(0));
3676  		break;
3677  	default:
3678  		MISSING_CASE(crtc_state->gamma_mode);
3679  		break;
3680  	}
3681  }
3682  
3683  static struct drm_property_blob *
icl_read_lut_multi_segment(struct intel_crtc * crtc)3684  icl_read_lut_multi_segment(struct intel_crtc *crtc)
3685  {
3686  	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
3687  	int i, lut_size = DISPLAY_INFO(i915)->color.gamma_lut_size;
3688  	enum pipe pipe = crtc->pipe;
3689  	struct drm_property_blob *blob;
3690  	struct drm_color_lut *lut;
3691  
3692  	blob = drm_property_create_blob(&i915->drm,
3693  					sizeof(lut[0]) * lut_size,
3694  					NULL);
3695  	if (IS_ERR(blob))
3696  		return NULL;
3697  
3698  	lut = blob->data;
3699  
3700  	intel_de_write_fw(i915, PREC_PAL_MULTI_SEG_INDEX(pipe),
3701  			  PAL_PREC_MULTI_SEG_INDEX_VALUE(0));
3702  	intel_de_write_fw(i915, PREC_PAL_MULTI_SEG_INDEX(pipe),
3703  			  PAL_PREC_MULTI_SEG_AUTO_INCREMENT |
3704  			  PAL_PREC_MULTI_SEG_INDEX_VALUE(0));
3705  
3706  	for (i = 0; i < 9; i++) {
3707  		u32 ldw = intel_de_read_fw(i915, PREC_PAL_MULTI_SEG_DATA(pipe));
3708  		u32 udw = intel_de_read_fw(i915, PREC_PAL_MULTI_SEG_DATA(pipe));
3709  
3710  		ilk_lut_12p4_pack(&lut[i], ldw, udw);
3711  	}
3712  
3713  	intel_de_write_fw(i915, PREC_PAL_MULTI_SEG_INDEX(pipe),
3714  			  PAL_PREC_MULTI_SEG_INDEX_VALUE(0));
3715  
3716  	/*
3717  	 * FIXME readouts from PAL_PREC_DATA register aren't giving
3718  	 * correct values in the case of fine and coarse segments.
3719  	 * Restricting readouts only for super fine segment as of now.
3720  	 */
3721  
3722  	return blob;
3723  }
3724  
icl_read_luts(struct intel_crtc_state * crtc_state)3725  static void icl_read_luts(struct intel_crtc_state *crtc_state)
3726  {
3727  	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
3728  
3729  	if (icl_has_pre_csc_lut(crtc_state))
3730  		crtc_state->pre_csc_lut = glk_read_degamma_lut(crtc);
3731  
3732  	if (!icl_has_post_csc_lut(crtc_state))
3733  		return;
3734  
3735  	switch (crtc_state->gamma_mode & GAMMA_MODE_MODE_MASK) {
3736  	case GAMMA_MODE_MODE_8BIT:
3737  		crtc_state->post_csc_lut = ilk_read_lut_8(crtc);
3738  		break;
3739  	case GAMMA_MODE_MODE_10BIT:
3740  		crtc_state->post_csc_lut = bdw_read_lut_10(crtc, PAL_PREC_INDEX_VALUE(0));
3741  		break;
3742  	case GAMMA_MODE_MODE_12BIT_MULTI_SEG:
3743  		crtc_state->post_csc_lut = icl_read_lut_multi_segment(crtc);
3744  		break;
3745  	default:
3746  		MISSING_CASE(crtc_state->gamma_mode);
3747  		break;
3748  	}
3749  }
3750  
3751  static const struct intel_color_funcs chv_color_funcs = {
3752  	.color_check = chv_color_check,
3753  	.color_commit_arm = i9xx_color_commit_arm,
3754  	.load_luts = chv_load_luts,
3755  	.read_luts = chv_read_luts,
3756  	.lut_equal = chv_lut_equal,
3757  	.read_csc = chv_read_csc,
3758  	.get_config = chv_get_config,
3759  };
3760  
3761  static const struct intel_color_funcs vlv_color_funcs = {
3762  	.color_check = vlv_color_check,
3763  	.color_commit_arm = i9xx_color_commit_arm,
3764  	.load_luts = vlv_load_luts,
3765  	.read_luts = i965_read_luts,
3766  	.lut_equal = i965_lut_equal,
3767  	.read_csc = vlv_read_csc,
3768  	.get_config = i9xx_get_config,
3769  };
3770  
3771  static const struct intel_color_funcs i965_color_funcs = {
3772  	.color_check = i9xx_color_check,
3773  	.color_commit_arm = i9xx_color_commit_arm,
3774  	.load_luts = i965_load_luts,
3775  	.read_luts = i965_read_luts,
3776  	.lut_equal = i965_lut_equal,
3777  	.get_config = i9xx_get_config,
3778  };
3779  
3780  static const struct intel_color_funcs i9xx_color_funcs = {
3781  	.color_check = i9xx_color_check,
3782  	.color_commit_arm = i9xx_color_commit_arm,
3783  	.load_luts = i9xx_load_luts,
3784  	.read_luts = i9xx_read_luts,
3785  	.lut_equal = i9xx_lut_equal,
3786  	.get_config = i9xx_get_config,
3787  };
3788  
3789  static const struct intel_color_funcs tgl_color_funcs = {
3790  	.color_check = icl_color_check,
3791  	.color_commit_noarm = icl_color_commit_noarm,
3792  	.color_commit_arm = icl_color_commit_arm,
3793  	.load_luts = icl_load_luts,
3794  	.read_luts = icl_read_luts,
3795  	.lut_equal = icl_lut_equal,
3796  	.read_csc = icl_read_csc,
3797  	.get_config = skl_get_config,
3798  };
3799  
3800  static const struct intel_color_funcs icl_color_funcs = {
3801  	.color_check = icl_color_check,
3802  	.color_commit_noarm = icl_color_commit_noarm,
3803  	.color_commit_arm = icl_color_commit_arm,
3804  	.color_post_update = icl_color_post_update,
3805  	.load_luts = icl_load_luts,
3806  	.read_luts = icl_read_luts,
3807  	.lut_equal = icl_lut_equal,
3808  	.read_csc = icl_read_csc,
3809  	.get_config = skl_get_config,
3810  };
3811  
3812  static const struct intel_color_funcs glk_color_funcs = {
3813  	.color_check = glk_color_check,
3814  	.color_commit_noarm = skl_color_commit_noarm,
3815  	.color_commit_arm = skl_color_commit_arm,
3816  	.load_luts = glk_load_luts,
3817  	.read_luts = glk_read_luts,
3818  	.lut_equal = glk_lut_equal,
3819  	.read_csc = skl_read_csc,
3820  	.get_config = skl_get_config,
3821  };
3822  
3823  static const struct intel_color_funcs skl_color_funcs = {
3824  	.color_check = ivb_color_check,
3825  	.color_commit_noarm = skl_color_commit_noarm,
3826  	.color_commit_arm = skl_color_commit_arm,
3827  	.load_luts = bdw_load_luts,
3828  	.read_luts = bdw_read_luts,
3829  	.lut_equal = ivb_lut_equal,
3830  	.read_csc = skl_read_csc,
3831  	.get_config = skl_get_config,
3832  };
3833  
3834  static const struct intel_color_funcs bdw_color_funcs = {
3835  	.color_check = ivb_color_check,
3836  	.color_commit_noarm = ilk_color_commit_noarm,
3837  	.color_commit_arm = hsw_color_commit_arm,
3838  	.load_luts = bdw_load_luts,
3839  	.read_luts = bdw_read_luts,
3840  	.lut_equal = ivb_lut_equal,
3841  	.read_csc = ilk_read_csc,
3842  	.get_config = hsw_get_config,
3843  };
3844  
3845  static const struct intel_color_funcs hsw_color_funcs = {
3846  	.color_check = ivb_color_check,
3847  	.color_commit_noarm = ilk_color_commit_noarm,
3848  	.color_commit_arm = hsw_color_commit_arm,
3849  	.load_luts = ivb_load_luts,
3850  	.read_luts = ivb_read_luts,
3851  	.lut_equal = ivb_lut_equal,
3852  	.read_csc = ilk_read_csc,
3853  	.get_config = hsw_get_config,
3854  };
3855  
3856  static const struct intel_color_funcs ivb_color_funcs = {
3857  	.color_check = ivb_color_check,
3858  	.color_commit_noarm = ilk_color_commit_noarm,
3859  	.color_commit_arm = ilk_color_commit_arm,
3860  	.load_luts = ivb_load_luts,
3861  	.read_luts = ivb_read_luts,
3862  	.lut_equal = ivb_lut_equal,
3863  	.read_csc = ilk_read_csc,
3864  	.get_config = ilk_get_config,
3865  };
3866  
3867  static const struct intel_color_funcs ilk_color_funcs = {
3868  	.color_check = ilk_color_check,
3869  	.color_commit_noarm = ilk_color_commit_noarm,
3870  	.color_commit_arm = ilk_color_commit_arm,
3871  	.load_luts = ilk_load_luts,
3872  	.read_luts = ilk_read_luts,
3873  	.lut_equal = ilk_lut_equal,
3874  	.read_csc = ilk_read_csc,
3875  	.get_config = ilk_get_config,
3876  };
3877  
intel_color_crtc_init(struct intel_crtc * crtc)3878  void intel_color_crtc_init(struct intel_crtc *crtc)
3879  {
3880  	struct drm_i915_private *i915 = to_i915(crtc->base.dev);
3881  	int degamma_lut_size, gamma_lut_size;
3882  	bool has_ctm;
3883  
3884  	drm_mode_crtc_set_gamma_size(&crtc->base, 256);
3885  
3886  	gamma_lut_size = DISPLAY_INFO(i915)->color.gamma_lut_size;
3887  	degamma_lut_size = DISPLAY_INFO(i915)->color.degamma_lut_size;
3888  	has_ctm = DISPLAY_VER(i915) >= 5;
3889  
3890  	/*
3891  	 * "DPALETTE_A: NOTE: The 8-bit (non-10-bit) mode is the
3892  	 *  only mode supported by Alviso and Grantsdale."
3893  	 *
3894  	 * Actually looks like this affects all of gen3.
3895  	 * Confirmed on alv,cst,pnv. Mobile gen2 parts (alm,mgm)
3896  	 * are confirmed not to suffer from this restriction.
3897  	 */
3898  	if (DISPLAY_VER(i915) == 3 && crtc->pipe == PIPE_A)
3899  		gamma_lut_size = 256;
3900  
3901  	drm_crtc_enable_color_mgmt(&crtc->base, degamma_lut_size,
3902  				   has_ctm, gamma_lut_size);
3903  }
3904  
intel_color_init(struct drm_i915_private * i915)3905  int intel_color_init(struct drm_i915_private *i915)
3906  {
3907  	struct drm_property_blob *blob;
3908  
3909  	if (DISPLAY_VER(i915) != 10)
3910  		return 0;
3911  
3912  	blob = create_linear_lut(i915,
3913  				 DISPLAY_INFO(i915)->color.degamma_lut_size);
3914  	if (IS_ERR(blob))
3915  		return PTR_ERR(blob);
3916  
3917  	i915->display.color.glk_linear_degamma_lut = blob;
3918  
3919  	return 0;
3920  }
3921  
intel_color_init_hooks(struct drm_i915_private * i915)3922  void intel_color_init_hooks(struct drm_i915_private *i915)
3923  {
3924  	if (HAS_GMCH(i915)) {
3925  		if (IS_CHERRYVIEW(i915))
3926  			i915->display.funcs.color = &chv_color_funcs;
3927  		else if (IS_VALLEYVIEW(i915))
3928  			i915->display.funcs.color = &vlv_color_funcs;
3929  		else if (DISPLAY_VER(i915) >= 4)
3930  			i915->display.funcs.color = &i965_color_funcs;
3931  		else
3932  			i915->display.funcs.color = &i9xx_color_funcs;
3933  	} else {
3934  		if (DISPLAY_VER(i915) >= 12)
3935  			i915->display.funcs.color = &tgl_color_funcs;
3936  		else if (DISPLAY_VER(i915) == 11)
3937  			i915->display.funcs.color = &icl_color_funcs;
3938  		else if (DISPLAY_VER(i915) == 10)
3939  			i915->display.funcs.color = &glk_color_funcs;
3940  		else if (DISPLAY_VER(i915) == 9)
3941  			i915->display.funcs.color = &skl_color_funcs;
3942  		else if (DISPLAY_VER(i915) == 8)
3943  			i915->display.funcs.color = &bdw_color_funcs;
3944  		else if (IS_HASWELL(i915))
3945  			i915->display.funcs.color = &hsw_color_funcs;
3946  		else if (DISPLAY_VER(i915) == 7)
3947  			i915->display.funcs.color = &ivb_color_funcs;
3948  		else
3949  			i915->display.funcs.color = &ilk_color_funcs;
3950  	}
3951  }
3952