intel_fbc.c 44.8 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
/*
 * Copyright © 2014 Intel Corporation
 *
 * Permission is hereby granted, free of charge, to any person obtaining a
 * copy of this software and associated documentation files (the "Software"),
 * to deal in the Software without restriction, including without limitation
 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
 * and/or sell copies of the Software, and to permit persons to whom the
 * Software is furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice (including the next
 * paragraph) shall be included in all copies or substantial portions of the
 * Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
 * DEALINGS IN THE SOFTWARE.
 */

R
Rodrigo Vivi 已提交
24 25 26 27 28 29
/**
 * DOC: Frame Buffer Compression (FBC)
 *
 * FBC tries to save memory bandwidth (and so power consumption) by
 * compressing the amount of memory used by the display. It is total
 * transparent to user space and completely handled in the kernel.
30 31
 *
 * The benefits of FBC are mostly visible with solid backgrounds and
R
Rodrigo Vivi 已提交
32 33
 * variation-less patterns. It comes from keeping the memory footprint small
 * and having fewer memory pages opened and accessed for refreshing the display.
34
 *
R
Rodrigo Vivi 已提交
35 36 37 38
 * i915 is responsible to reserve stolen memory for FBC and configure its
 * offset on proper registers. The hardware takes care of all
 * compress/decompress. However there are many known cases where we have to
 * forcibly disable it to allow proper screen updates.
39 40
 */

41 42
#include <drm/drm_fourcc.h>

R
Rodrigo Vivi 已提交
43
#include "i915_drv.h"
44
#include "i915_trace.h"
45
#include "i915_vgpu.h"
46
#include "intel_de.h"
47
#include "intel_display_types.h"
48
#include "intel_fbc.h"
49
#include "intel_frontbuffer.h"
R
Rodrigo Vivi 已提交
50

51 52 53 54 55
/*
 * For SKL+, the plane source size used by the hardware is based on the value we
 * write to the PLANE_SIZE register. For BDW-, the hardware looks at the value
 * we wrote to PIPESRC.
 */
56
static void intel_fbc_get_plane_source_size(const struct intel_fbc_state_cache *cache,
57 58 59
					    int *width, int *height)
{
	if (width)
60
		*width = cache->plane.src_w;
61
	if (height)
62
		*height = cache->plane.src_h;
63 64
}

65 66
/* plane stride in pixels */
static unsigned int intel_fbc_plane_stride(const struct intel_plane_state *plane_state)
67
{
68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86
	const struct drm_framebuffer *fb = plane_state->hw.fb;
	unsigned int stride;

	stride = plane_state->view.color_plane[0].stride;
	if (!drm_rotation_90_or_270(plane_state->hw.rotation))
		stride /= fb->format->cpp[0];

	return stride;
}

/* plane stride based cfb stride in bytes, assuming 1:1 compression limit */
static unsigned int _intel_fbc_cfb_stride(const struct intel_fbc_state_cache *cache)
{
	unsigned int cpp = 4; /* FBC always 4 bytes per pixel */

	return cache->fb.stride * cpp;
}

/* minimum acceptable cfb stride in bytes, assuming 1:1 compression limit */
87 88
static unsigned int skl_fbc_min_cfb_stride(struct drm_i915_private *i915,
					   const struct intel_fbc_state_cache *cache)
89 90 91 92 93 94 95 96 97
{
	unsigned int limit = 4; /* 1:4 compression limit is the worst case */
	unsigned int cpp = 4; /* FBC always 4 bytes per pixel */
	unsigned int height = 4; /* FBC segment is 4 lines */
	unsigned int stride;

	/* minimum segment stride we can use */
	stride = cache->plane.src_w * cpp * height / limit;

98 99 100 101 102 103 104
	/*
	 * Wa_16011863758: icl+
	 * Avoid some hardware segment address miscalculation.
	 */
	if (DISPLAY_VER(i915) >= 11)
		stride += 64;

105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125
	/*
	 * At least some of the platforms require each 4 line segment to
	 * be 512 byte aligned. Just do it always for simplicity.
	 */
	stride = ALIGN(stride, 512);

	/* convert back to single line equivalent with 1:1 compression limit */
	return stride * limit / height;
}

/* properly aligned cfb stride in bytes, assuming 1:1 compression limit */
static unsigned int intel_fbc_cfb_stride(struct drm_i915_private *i915,
					 const struct intel_fbc_state_cache *cache)
{
	unsigned int stride = _intel_fbc_cfb_stride(cache);

	/*
	 * At least some of the platforms require each 4 line segment to
	 * be 512 byte aligned. Aligning each line to 512 bytes guarantees
	 * that regardless of the compression limit we choose later.
	 */
126
	if (DISPLAY_VER(i915) >= 9)
127
		return max(ALIGN(stride, 512), skl_fbc_min_cfb_stride(i915, cache));
128 129 130 131 132 133 134 135
	else
		return stride;
}

static unsigned int intel_fbc_cfb_size(struct drm_i915_private *dev_priv,
				       const struct intel_fbc_state_cache *cache)
{
	int lines = cache->plane.src_h;
136

137
	if (DISPLAY_VER(dev_priv) == 7)
138
		lines = min(lines, 2048);
139
	else if (DISPLAY_VER(dev_priv) >= 8)
140
		lines = min(lines, 2560);
141

142
	return lines * intel_fbc_cfb_stride(dev_priv, cache);
143 144
}

145
static void i8xx_fbc_deactivate(struct drm_i915_private *dev_priv)
146 147 148 149
{
	u32 fbc_ctl;

	/* Disable compression */
150
	fbc_ctl = intel_de_read(dev_priv, FBC_CONTROL);
151 152 153 154
	if ((fbc_ctl & FBC_CTL_EN) == 0)
		return;

	fbc_ctl &= ~FBC_CTL_EN;
155
	intel_de_write(dev_priv, FBC_CONTROL, fbc_ctl);
156 157

	/* Wait for compressing bit to clear */
158 159
	if (intel_de_wait_for_clear(dev_priv, FBC_STATUS,
				    FBC_STAT_COMPRESSING, 10)) {
160
		drm_dbg_kms(&dev_priv->drm, "FBC idle timed out\n");
161 162 163 164
		return;
	}
}

165
static void i8xx_fbc_activate(struct drm_i915_private *dev_priv)
166
{
167 168
	struct intel_fbc *fbc = &dev_priv->fbc;
	const struct intel_fbc_reg_params *params = &fbc->params;
169 170 171 172
	int cfb_pitch;
	int i;
	u32 fbc_ctl;

173
	cfb_pitch = params->cfb_stride / fbc->limit;
174 175

	/* FBC_CTL wants 32B or 64B units */
176
	if (DISPLAY_VER(dev_priv) == 2)
177 178 179 180 181 182
		cfb_pitch = (cfb_pitch / 32) - 1;
	else
		cfb_pitch = (cfb_pitch / 64) - 1;

	/* Clear old tags */
	for (i = 0; i < (FBC_LL_SIZE / 32) + 1; i++)
183
		intel_de_write(dev_priv, FBC_TAG(i), 0);
184

185
	if (DISPLAY_VER(dev_priv) == 4) {
186 187 188
		u32 fbc_ctl2;

		/* Set it up... */
189
		fbc_ctl2 = FBC_CTL_FENCE_DBL | FBC_CTL_IDLE_IMM;
190
		fbc_ctl2 |= FBC_CTL_PLANE(params->crtc.i9xx_plane);
191 192
		if (params->fence_id >= 0)
			fbc_ctl2 |= FBC_CTL_CPU_FENCE;
193 194
		intel_de_write(dev_priv, FBC_CONTROL2, fbc_ctl2);
		intel_de_write(dev_priv, FBC_FENCE_OFF,
195
			       params->fence_y_offset);
196 197 198
	}

	/* enable it... */
199
	fbc_ctl = FBC_CTL_INTERVAL(params->interval);
200
	fbc_ctl |= FBC_CTL_EN | FBC_CTL_PERIODIC;
201
	if (IS_I945GM(dev_priv))
202
		fbc_ctl |= FBC_CTL_C3_IDLE; /* 945 needs special SR handling */
203
	fbc_ctl |= FBC_CTL_STRIDE(cfb_pitch & 0xff);
204
	if (params->fence_id >= 0)
205
		fbc_ctl |= FBC_CTL_FENCENO(params->fence_id);
206
	intel_de_write(dev_priv, FBC_CONTROL, fbc_ctl);
207 208
}

209
static bool i8xx_fbc_is_active(struct drm_i915_private *dev_priv)
210
{
211
	return intel_de_read(dev_priv, FBC_CONTROL) & FBC_CTL_EN;
212 213
}

214 215
static u32 g4x_dpfc_ctl_limit(struct drm_i915_private *i915)
{
216
	switch (i915->fbc.limit) {
217
	default:
218
		MISSING_CASE(i915->fbc.limit);
219 220 221 222 223 224 225 226 227 228
		fallthrough;
	case 1:
		return DPFC_CTL_LIMIT_1X;
	case 2:
		return DPFC_CTL_LIMIT_2X;
	case 4:
		return DPFC_CTL_LIMIT_4X;
	}
}

229
static void g4x_fbc_activate(struct drm_i915_private *dev_priv)
230
{
231
	struct intel_fbc_reg_params *params = &dev_priv->fbc.params;
232 233
	u32 dpfc_ctl;

234
	dpfc_ctl = DPFC_CTL_PLANE(params->crtc.i9xx_plane) | DPFC_SR_EN;
235 236

	dpfc_ctl |= g4x_dpfc_ctl_limit(dev_priv);
237

238 239
	if (params->fence_id >= 0) {
		dpfc_ctl |= DPFC_CTL_FENCE_EN | params->fence_id;
240
		intel_de_write(dev_priv, DPFC_FENCE_YOFF,
241
			       params->fence_y_offset);
242
	} else {
243
		intel_de_write(dev_priv, DPFC_FENCE_YOFF, 0);
244
	}
245 246

	/* enable it... */
247
	intel_de_write(dev_priv, DPFC_CONTROL, dpfc_ctl | DPFC_CTL_EN);
248 249
}

250
static void g4x_fbc_deactivate(struct drm_i915_private *dev_priv)
251 252 253 254
{
	u32 dpfc_ctl;

	/* Disable compression */
255
	dpfc_ctl = intel_de_read(dev_priv, DPFC_CONTROL);
256 257
	if (dpfc_ctl & DPFC_CTL_EN) {
		dpfc_ctl &= ~DPFC_CTL_EN;
258
		intel_de_write(dev_priv, DPFC_CONTROL, dpfc_ctl);
259 260 261
	}
}

262
static bool g4x_fbc_is_active(struct drm_i915_private *dev_priv)
263
{
264
	return intel_de_read(dev_priv, DPFC_CONTROL) & DPFC_CTL_EN;
265 266
}

267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288
static void i8xx_fbc_recompress(struct drm_i915_private *dev_priv)
{
	struct intel_fbc_reg_params *params = &dev_priv->fbc.params;
	enum i9xx_plane_id i9xx_plane = params->crtc.i9xx_plane;

	spin_lock_irq(&dev_priv->uncore.lock);
	intel_de_write_fw(dev_priv, DSPADDR(i9xx_plane),
			  intel_de_read_fw(dev_priv, DSPADDR(i9xx_plane)));
	spin_unlock_irq(&dev_priv->uncore.lock);
}

static void i965_fbc_recompress(struct drm_i915_private *dev_priv)
{
	struct intel_fbc_reg_params *params = &dev_priv->fbc.params;
	enum i9xx_plane_id i9xx_plane = params->crtc.i9xx_plane;

	spin_lock_irq(&dev_priv->uncore.lock);
	intel_de_write_fw(dev_priv, DSPSURF(i9xx_plane),
			  intel_de_read_fw(dev_priv, DSPSURF(i9xx_plane)));
	spin_unlock_irq(&dev_priv->uncore.lock);
}

289
/* This function forces a CFB recompression through the nuke operation. */
290
static void snb_fbc_recompress(struct drm_i915_private *dev_priv)
291
{
292 293
	intel_de_write(dev_priv, MSG_FBC_REND_STATE, FBC_REND_NUKE);
	intel_de_posting_read(dev_priv, MSG_FBC_REND_STATE);
294 295
}

296 297
static void intel_fbc_recompress(struct drm_i915_private *dev_priv)
{
298 299 300 301
	struct intel_fbc *fbc = &dev_priv->fbc;

	trace_intel_fbc_nuke(fbc->crtc);

302
	if (DISPLAY_VER(dev_priv) >= 6)
303
		snb_fbc_recompress(dev_priv);
304
	else if (DISPLAY_VER(dev_priv) >= 4)
305 306 307 308 309
		i965_fbc_recompress(dev_priv);
	else
		i8xx_fbc_recompress(dev_priv);
}

310
static void ilk_fbc_activate(struct drm_i915_private *dev_priv)
311
{
312
	struct intel_fbc_reg_params *params = &dev_priv->fbc.params;
313 314
	u32 dpfc_ctl;

315
	dpfc_ctl = DPFC_CTL_PLANE(params->crtc.i9xx_plane);
316

317
	dpfc_ctl |= g4x_dpfc_ctl_limit(dev_priv);
318

319
	if (params->fence_id >= 0) {
320
		dpfc_ctl |= DPFC_CTL_FENCE_EN;
321
		if (IS_IRONLAKE(dev_priv))
322
			dpfc_ctl |= params->fence_id;
323
		if (IS_SANDYBRIDGE(dev_priv)) {
324 325 326
			intel_de_write(dev_priv, SNB_DPFC_CTL_SA,
				       SNB_CPU_FENCE_ENABLE | params->fence_id);
			intel_de_write(dev_priv, DPFC_CPU_FENCE_OFFSET,
327
				       params->fence_y_offset);
328 329
		}
	} else {
330
		if (IS_SANDYBRIDGE(dev_priv)) {
331 332
			intel_de_write(dev_priv, SNB_DPFC_CTL_SA, 0);
			intel_de_write(dev_priv, DPFC_CPU_FENCE_OFFSET, 0);
333 334
		}
	}
335

336
	intel_de_write(dev_priv, ILK_DPFC_FENCE_YOFF,
337
		       params->fence_y_offset);
338
	/* enable it... */
339
	intel_de_write(dev_priv, ILK_DPFC_CONTROL, dpfc_ctl | DPFC_CTL_EN);
340 341
}

342
static void ilk_fbc_deactivate(struct drm_i915_private *dev_priv)
343 344 345 346
{
	u32 dpfc_ctl;

	/* Disable compression */
347
	dpfc_ctl = intel_de_read(dev_priv, ILK_DPFC_CONTROL);
348 349
	if (dpfc_ctl & DPFC_CTL_EN) {
		dpfc_ctl &= ~DPFC_CTL_EN;
350
		intel_de_write(dev_priv, ILK_DPFC_CONTROL, dpfc_ctl);
351 352 353
	}
}

354
static bool ilk_fbc_is_active(struct drm_i915_private *dev_priv)
355
{
356
	return intel_de_read(dev_priv, ILK_DPFC_CONTROL) & DPFC_CTL_EN;
357 358
}

359
static void gen7_fbc_activate(struct drm_i915_private *dev_priv)
360
{
361 362
	struct intel_fbc *fbc = &dev_priv->fbc;
	const struct intel_fbc_reg_params *params = &fbc->params;
363 364
	u32 dpfc_ctl;

365
	if (DISPLAY_VER(dev_priv) >= 10) {
366
		u32 val = 0;
367

368 369 370 371 372 373 374 375 376
		if (params->override_cfb_stride)
			val |= FBC_STRIDE_OVERRIDE |
				FBC_STRIDE(params->override_cfb_stride / fbc->limit);

		intel_de_write(dev_priv, GLK_FBC_STRIDE, val);
	} else if (DISPLAY_VER(dev_priv) == 9) {
		u32 val = 0;

		/* Display WA #0529: skl, kbl, bxt. */
377 378
		if (params->override_cfb_stride)
			val |= CHICKEN_FBC_STRIDE_OVERRIDE |
379
				CHICKEN_FBC_STRIDE(params->override_cfb_stride / fbc->limit);
380

381 382 383
		intel_de_rmw(dev_priv, CHICKEN_MISC_4,
			     CHICKEN_FBC_STRIDE_OVERRIDE |
			     CHICKEN_FBC_STRIDE_MASK, val);
384 385
	}

386
	dpfc_ctl = 0;
387
	if (IS_IVYBRIDGE(dev_priv))
388
		dpfc_ctl |= IVB_DPFC_CTL_PLANE(params->crtc.i9xx_plane);
389

390
	dpfc_ctl |= g4x_dpfc_ctl_limit(dev_priv);
391

392
	if (params->fence_id >= 0) {
393
		dpfc_ctl |= IVB_DPFC_CTL_FENCE_EN;
394 395 396
		intel_de_write(dev_priv, SNB_DPFC_CTL_SA,
			       SNB_CPU_FENCE_ENABLE | params->fence_id);
		intel_de_write(dev_priv, DPFC_CPU_FENCE_OFFSET,
397
			       params->fence_y_offset);
398
	} else if (dev_priv->ggtt.num_fences) {
399 400
		intel_de_write(dev_priv, SNB_DPFC_CTL_SA, 0);
		intel_de_write(dev_priv, DPFC_CPU_FENCE_OFFSET, 0);
401
	}
402 403 404 405

	if (dev_priv->fbc.false_color)
		dpfc_ctl |= FBC_CTL_FALSE_COLOR;

406
	intel_de_write(dev_priv, ILK_DPFC_CONTROL, dpfc_ctl | DPFC_CTL_EN);
407 408
}

409 410
static bool intel_fbc_hw_is_active(struct drm_i915_private *dev_priv)
{
411
	if (DISPLAY_VER(dev_priv) >= 5)
412 413 414 415 416 417 418 419 420
		return ilk_fbc_is_active(dev_priv);
	else if (IS_GM45(dev_priv))
		return g4x_fbc_is_active(dev_priv);
	else
		return i8xx_fbc_is_active(dev_priv);
}

static void intel_fbc_hw_activate(struct drm_i915_private *dev_priv)
{
421 422
	struct intel_fbc *fbc = &dev_priv->fbc;

423 424
	trace_intel_fbc_activate(fbc->crtc);

425
	fbc->active = true;
426
	fbc->activated = true;
427

428
	if (DISPLAY_VER(dev_priv) >= 7)
429
		gen7_fbc_activate(dev_priv);
430
	else if (DISPLAY_VER(dev_priv) >= 5)
431 432 433 434 435 436 437 438 439
		ilk_fbc_activate(dev_priv);
	else if (IS_GM45(dev_priv))
		g4x_fbc_activate(dev_priv);
	else
		i8xx_fbc_activate(dev_priv);
}

static void intel_fbc_hw_deactivate(struct drm_i915_private *dev_priv)
{
440 441
	struct intel_fbc *fbc = &dev_priv->fbc;

442 443
	trace_intel_fbc_deactivate(fbc->crtc);

444 445
	fbc->active = false;

446
	if (DISPLAY_VER(dev_priv) >= 5)
447 448 449 450 451 452 453
		ilk_fbc_deactivate(dev_priv);
	else if (IS_GM45(dev_priv))
		g4x_fbc_deactivate(dev_priv);
	else
		i8xx_fbc_deactivate(dev_priv);
}

R
Rodrigo Vivi 已提交
454
/**
455
 * intel_fbc_is_active - Is FBC active?
456
 * @dev_priv: i915 device instance
R
Rodrigo Vivi 已提交
457 458
 *
 * This function is used to verify the current state of FBC.
D
Daniel Vetter 已提交
459
 *
R
Rodrigo Vivi 已提交
460
 * FIXME: This should be tracked in the plane config eventually
D
Daniel Vetter 已提交
461
 * instead of queried at runtime for most callers.
R
Rodrigo Vivi 已提交
462
 */
463
bool intel_fbc_is_active(struct drm_i915_private *dev_priv)
464
{
465
	return dev_priv->fbc.active;
466 467
}

468 469 470 471 472 473
static void intel_fbc_activate(struct drm_i915_private *dev_priv)
{
	intel_fbc_hw_activate(dev_priv);
	intel_fbc_recompress(dev_priv);
}

474 475
static void intel_fbc_deactivate(struct drm_i915_private *dev_priv,
				 const char *reason)
P
Paulo Zanoni 已提交
476
{
477 478
	struct intel_fbc *fbc = &dev_priv->fbc;

479
	drm_WARN_ON(&dev_priv->drm, !mutex_is_locked(&fbc->lock));
P
Paulo Zanoni 已提交
480

481
	if (fbc->active)
482
		intel_fbc_hw_deactivate(dev_priv);
483 484

	fbc->no_fbc_reason = reason;
485 486
}

487 488
static u64 intel_fbc_cfb_base_max(struct drm_i915_private *i915)
{
489
	if (DISPLAY_VER(i915) >= 5 || IS_G4X(i915))
490 491 492 493 494
		return BIT_ULL(28);
	else
		return BIT_ULL(32);
}

495
static u64 intel_fbc_stolen_end(struct drm_i915_private *dev_priv)
496
{
497 498 499 500 501 502
	u64 end;

	/* The FBC hardware for BDW/SKL doesn't have access to the stolen
	 * reserved range size, so it always assumes the maximum (8mb) is used.
	 * If we enable FBC using a CFB on that memory range we'll get FIFO
	 * underruns, even if that range is not reserved by the BIOS. */
503
	if (IS_BROADWELL(dev_priv) || (DISPLAY_VER(dev_priv) == 9 &&
504
				       !IS_BROXTON(dev_priv)))
505
		end = resource_size(&dev_priv->dsm) - 8 * 1024 * 1024;
506
	else
507
		end = U64_MAX;
508

509 510 511
	return min(end, intel_fbc_cfb_base_max(dev_priv));
}

512 513 514 515 516 517
static int intel_fbc_min_limit(int fb_cpp)
{
	return fb_cpp == 2 ? 2 : 1;
}

static int intel_fbc_max_limit(struct drm_i915_private *dev_priv)
518 519 520 521 522
{
	/* WaFbcOnly1to1Ratio:ctg */
	if (IS_G4X(dev_priv))
		return 1;

523 524 525 526
	/*
	 * FBC2 can only do 1:1, 1:2, 1:4, we limit
	 * FBC1 to the same out of convenience.
	 */
527
	return 4;
528 529
}

530
static int find_compression_limit(struct drm_i915_private *dev_priv,
531
				  unsigned int size, int min_limit)
532 533 534
{
	struct intel_fbc *fbc = &dev_priv->fbc;
	u64 end = intel_fbc_stolen_end(dev_priv);
535 536 537
	int ret, limit = min_limit;

	size /= limit;
538 539

	/* Try to over-allocate to reduce reallocations and fragmentation. */
540 541
	ret = i915_gem_stolen_insert_node_in_range(dev_priv, &fbc->compressed_fb,
						   size <<= 1, 4096, 0, end);
542
	if (ret == 0)
543
		return limit;
544

545
	for (; limit <= intel_fbc_max_limit(dev_priv); limit <<= 1) {
546 547 548 549
		ret = i915_gem_stolen_insert_node_in_range(dev_priv, &fbc->compressed_fb,
							   size >>= 1, 4096, 0, end);
		if (ret == 0)
			return limit;
550
	}
551 552

	return 0;
553 554
}

555
static int intel_fbc_alloc_cfb(struct drm_i915_private *dev_priv,
556
			       unsigned int size, int min_limit)
557
{
558
	struct intel_fbc *fbc = &dev_priv->fbc;
559
	int ret;
560

561 562
	drm_WARN_ON(&dev_priv->drm,
		    drm_mm_node_allocated(&fbc->compressed_fb));
563 564
	drm_WARN_ON(&dev_priv->drm,
		    drm_mm_node_allocated(&fbc->compressed_llb));
565

566 567 568 569 570 571 572
	if (DISPLAY_VER(dev_priv) < 5 && !IS_G4X(dev_priv)) {
		ret = i915_gem_stolen_insert_node(dev_priv, &fbc->compressed_llb,
						  4096, 4096);
		if (ret)
			goto err;
	}

573
	ret = find_compression_limit(dev_priv, size, min_limit);
574 575
	if (!ret)
		goto err_llb;
576
	else if (ret > min_limit)
577 578
		drm_info_once(&dev_priv->drm,
			      "Reducing the compressed framebuffer size. This may lead to less power savings than a non-reduced-size. Try to increase stolen memory size if available in BIOS.\n");
579

580
	fbc->limit = ret;
581

582
	drm_dbg_kms(&dev_priv->drm,
583 584
		    "reserved %llu bytes of contiguous stolen space for FBC, limit: %d\n",
		    fbc->compressed_fb.size, fbc->limit);
585 586 587 588

	return 0;

err_llb:
589 590
	if (drm_mm_node_allocated(&fbc->compressed_llb))
		i915_gem_stolen_remove_node(dev_priv, &fbc->compressed_llb);
591
err:
592
	if (drm_mm_initialized(&dev_priv->mm.stolen))
593
		drm_info_once(&dev_priv->drm, "not enough stolen space for compressed buffer (need %d more bytes), disabling. Hint: you may be able to increase stolen memory size in the BIOS to avoid this.\n", size);
594 595 596
	return -ENOSPC;
}

597 598 599 600 601 602 603 604 605 606 607 608 609 610 611
static void intel_fbc_program_cfb(struct drm_i915_private *dev_priv)
{
	struct intel_fbc *fbc = &dev_priv->fbc;

	if (DISPLAY_VER(dev_priv) >= 5) {
		intel_de_write(dev_priv, ILK_DPFC_CB_BASE,
			       fbc->compressed_fb.start);
	} else if (IS_GM45(dev_priv)) {
		intel_de_write(dev_priv, DPFC_CB_BASE,
			       fbc->compressed_fb.start);
	} else {
		GEM_BUG_ON(range_overflows_end_t(u64, dev_priv->dsm.start,
						 fbc->compressed_fb.start,
						 U32_MAX));
		GEM_BUG_ON(range_overflows_end_t(u64, dev_priv->dsm.start,
612
						 fbc->compressed_llb.start,
613 614 615 616 617
						 U32_MAX));

		intel_de_write(dev_priv, FBC_CFB_BASE,
			       dev_priv->dsm.start + fbc->compressed_fb.start);
		intel_de_write(dev_priv, FBC_LL_BASE,
618
			       dev_priv->dsm.start + fbc->compressed_llb.start);
619 620 621
	}
}

622
static void __intel_fbc_cleanup_cfb(struct drm_i915_private *dev_priv)
623
{
624 625
	struct intel_fbc *fbc = &dev_priv->fbc;

626 627 628
	if (WARN_ON(intel_fbc_hw_is_active(dev_priv)))
		return;

629 630 631 632
	if (drm_mm_node_allocated(&fbc->compressed_llb))
		i915_gem_stolen_remove_node(dev_priv, &fbc->compressed_llb);
	if (drm_mm_node_allocated(&fbc->compressed_fb))
		i915_gem_stolen_remove_node(dev_priv, &fbc->compressed_fb);
633 634
}

635
void intel_fbc_cleanup_cfb(struct drm_i915_private *dev_priv)
P
Paulo Zanoni 已提交
636
{
637 638
	struct intel_fbc *fbc = &dev_priv->fbc;

639
	if (!HAS_FBC(dev_priv))
640 641
		return;

642
	mutex_lock(&fbc->lock);
643
	__intel_fbc_cleanup_cfb(dev_priv);
644
	mutex_unlock(&fbc->lock);
P
Paulo Zanoni 已提交
645 646
}

647
static bool stride_is_valid(struct drm_i915_private *dev_priv,
648
			    u64 modifier, unsigned int stride)
649
{
650
	/* This should have been caught earlier. */
651
	if (drm_WARN_ON_ONCE(&dev_priv->drm, (stride & (64 - 1)) != 0))
652
		return false;
653 654

	/* Below are the additional FBC restrictions. */
655 656
	if (stride < 512)
		return false;
657

658
	if (DISPLAY_VER(dev_priv) == 2 || DISPLAY_VER(dev_priv) == 3)
659 660
		return stride == 4096 || stride == 8192;

661
	if (DISPLAY_VER(dev_priv) == 4 && !IS_G4X(dev_priv) && stride < 2048)
662 663
		return false;

664
	/* Display WA #1105: skl,bxt,kbl,cfl,glk */
665
	if ((DISPLAY_VER(dev_priv) == 9 || IS_GEMINILAKE(dev_priv)) &&
666 667 668
	    modifier == DRM_FORMAT_MOD_LINEAR && stride & 511)
		return false;

669 670 671 672 673 674
	if (stride > 16384)
		return false;

	return true;
}

675
static bool pixel_format_is_valid(struct drm_i915_private *dev_priv,
676
				  u32 pixel_format)
677
{
678
	switch (pixel_format) {
679 680 681 682 683 684
	case DRM_FORMAT_XRGB8888:
	case DRM_FORMAT_XBGR8888:
		return true;
	case DRM_FORMAT_XRGB1555:
	case DRM_FORMAT_RGB565:
		/* 16bpp not supported on gen2 */
685
		if (DISPLAY_VER(dev_priv) == 2)
686 687 688 689 690 691 692 693 694 695
			return false;
		/* WaFbcOnly1to1Ratio:ctg */
		if (IS_G4X(dev_priv))
			return false;
		return true;
	default:
		return false;
	}
}

696 697 698
static bool rotation_is_valid(struct drm_i915_private *dev_priv,
			      u32 pixel_format, unsigned int rotation)
{
699
	if (DISPLAY_VER(dev_priv) >= 9 && pixel_format == DRM_FORMAT_RGB565 &&
700 701
	    drm_rotation_90_or_270(rotation))
		return false;
702
	else if (DISPLAY_VER(dev_priv) <= 4 && !IS_G4X(dev_priv) &&
703 704 705 706 707 708
		 rotation != DRM_MODE_ROTATE_0)
		return false;

	return true;
}

709 710 711
/*
 * For some reason, the hardware tracking starts looking at whatever we
 * programmed as the display plane base address register. It does not look at
712 713
 * the X and Y offset registers. That's why we include the src x/y offsets
 * instead of just looking at the plane size.
714 715
 */
static bool intel_fbc_hw_tracking_covers_screen(struct intel_crtc *crtc)
716
{
717
	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
718
	struct intel_fbc *fbc = &dev_priv->fbc;
719
	unsigned int effective_w, effective_h, max_w, max_h;
720

721
	if (DISPLAY_VER(dev_priv) >= 10) {
722 723
		max_w = 5120;
		max_h = 4096;
724
	} else if (DISPLAY_VER(dev_priv) >= 8 || IS_HASWELL(dev_priv)) {
725 726
		max_w = 4096;
		max_h = 4096;
727
	} else if (IS_G4X(dev_priv) || DISPLAY_VER(dev_priv) >= 5) {
728 729 730 731 732 733 734
		max_w = 4096;
		max_h = 2048;
	} else {
		max_w = 2048;
		max_h = 1536;
	}

735 736
	intel_fbc_get_plane_source_size(&fbc->state_cache, &effective_w,
					&effective_h);
737 738
	effective_w += fbc->state_cache.plane.adjusted_x;
	effective_h += fbc->state_cache.plane.adjusted_y;
739 740

	return effective_w <= max_w && effective_h <= max_h;
741 742
}

743
static bool tiling_is_valid(struct drm_i915_private *dev_priv,
744
			    u64 modifier)
745 746 747 748
{
	switch (modifier) {
	case DRM_FORMAT_MOD_LINEAR:
	case I915_FORMAT_MOD_Y_TILED:
749
	case I915_FORMAT_MOD_Yf_TILED:
750 751
		return DISPLAY_VER(dev_priv) >= 9;
	case I915_FORMAT_MOD_X_TILED:
752 753 754 755 756 757
		return true;
	default:
		return false;
	}
}

758
static void intel_fbc_update_state_cache(struct intel_crtc *crtc,
759 760
					 const struct intel_crtc_state *crtc_state,
					 const struct intel_plane_state *plane_state)
761
{
762
	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
763
	struct intel_fbc *fbc = &dev_priv->fbc;
764
	struct intel_fbc_state_cache *cache = &fbc->state_cache;
765
	struct drm_framebuffer *fb = plane_state->hw.fb;
766

767 768 769
	cache->plane.visible = plane_state->uapi.visible;
	if (!cache->plane.visible)
		return;
770

771
	cache->crtc.mode_flags = crtc_state->hw.adjusted_mode.flags;
772
	if (IS_HASWELL(dev_priv) || IS_BROADWELL(dev_priv))
773
		cache->crtc.hsw_bdw_pixel_rate = crtc_state->pixel_rate;
774

775
	cache->plane.rotation = plane_state->hw.rotation;
776 777 778 779 780
	/*
	 * Src coordinates are already rotated by 270 degrees for
	 * the 90/270 degree plane rotation cases (to match the
	 * GTT mapping), hence no need to account for rotation here.
	 */
781 782
	cache->plane.src_w = drm_rect_width(&plane_state->uapi.src) >> 16;
	cache->plane.src_h = drm_rect_height(&plane_state->uapi.src) >> 16;
783 784
	cache->plane.adjusted_x = plane_state->view.color_plane[0].x;
	cache->plane.adjusted_y = plane_state->view.color_plane[0].y;
785

786
	cache->plane.pixel_blend_mode = plane_state->hw.pixel_blend_mode;
787

788
	cache->fb.format = fb->format;
789
	cache->fb.modifier = fb->modifier;
790
	cache->fb.stride = intel_fbc_plane_stride(plane_state);
791

792 793
	/* FBC1 compression interval: arbitrary choice of 1 second */
	cache->interval = drm_mode_vrefresh(&crtc_state->hw.adjusted_mode);
794

795 796
	cache->fence_y_offset = intel_plane_fence_y_offset(plane_state);

797
	drm_WARN_ON(&dev_priv->drm, plane_state->flags & PLANE_HAS_FENCE &&
798
		    !plane_state->ggtt_vma->fence);
799 800

	if (plane_state->flags & PLANE_HAS_FENCE &&
801 802
	    plane_state->ggtt_vma->fence)
		cache->fence_id = plane_state->ggtt_vma->fence->id;
803 804
	else
		cache->fence_id = -1;
805 806

	cache->psr2_active = crtc_state->has_psr2;
807 808
}

809 810 811 812
static bool intel_fbc_cfb_size_changed(struct drm_i915_private *dev_priv)
{
	struct intel_fbc *fbc = &dev_priv->fbc;

813
	return intel_fbc_cfb_size(dev_priv, &fbc->state_cache) >
814
		fbc->compressed_fb.size * fbc->limit;
815 816
}

817 818
static u16 intel_fbc_override_cfb_stride(struct drm_i915_private *dev_priv,
					 const struct intel_fbc_state_cache *cache)
819
{
820 821
	unsigned int stride = _intel_fbc_cfb_stride(cache);
	unsigned int stride_aligned = intel_fbc_cfb_stride(dev_priv, cache);
822

823 824 825 826 827 828 829 830 831 832 833
	/*
	 * Override stride in 64 byte units per 4 line segment.
	 *
	 * Gen9 hw miscalculates cfb stride for linear as
	 * PLANE_STRIDE*512 instead of PLANE_STRIDE*64, so
	 * we always need to use the override there.
	 */
	if (stride != stride_aligned ||
	    (DISPLAY_VER(dev_priv) == 9 &&
	     cache->fb.modifier == DRM_FORMAT_MOD_LINEAR))
		return stride_aligned * 4 / 64;
834

835
	return 0;
836 837
}

838 839 840 841 842 843 844 845 846
static bool intel_fbc_can_enable(struct drm_i915_private *dev_priv)
{
	struct intel_fbc *fbc = &dev_priv->fbc;

	if (intel_vgpu_active(dev_priv)) {
		fbc->no_fbc_reason = "VGPU is active";
		return false;
	}

847
	if (!dev_priv->params.enable_fbc) {
848 849 850 851 852 853 854 855 856 857 858 859
		fbc->no_fbc_reason = "disabled per module param or by default";
		return false;
	}

	if (fbc->underrun_detected) {
		fbc->no_fbc_reason = "underrun detected";
		return false;
	}

	return true;
}

860 861
static bool intel_fbc_can_activate(struct intel_crtc *crtc)
{
862
	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
863 864 865
	struct intel_fbc *fbc = &dev_priv->fbc;
	struct intel_fbc_state_cache *cache = &fbc->state_cache;

866 867 868
	if (!intel_fbc_can_enable(dev_priv))
		return false;

869 870 871 872 873
	if (!cache->plane.visible) {
		fbc->no_fbc_reason = "primary plane not visible";
		return false;
	}

874 875 876 877 878 879 880 881
	/* We don't need to use a state cache here since this information is
	 * global for all CRTC.
	 */
	if (fbc->underrun_detected) {
		fbc->no_fbc_reason = "underrun detected";
		return false;
	}

882
	if (cache->crtc.mode_flags & DRM_MODE_FLAG_INTERLACE) {
883
		fbc->no_fbc_reason = "incompatible mode";
884
		return false;
885 886
	}

887
	if (!intel_fbc_hw_tracking_covers_screen(crtc)) {
888
		fbc->no_fbc_reason = "mode too large for compression";
889
		return false;
890
	}
891

892 893 894 895 896 897
	/* The use of a CPU fence is one of two ways to detect writes by the
	 * CPU to the scanout and trigger updates to the FBC.
	 *
	 * The other method is by software tracking (see
	 * intel_fbc_invalidate/flush()), it will manually notify FBC and nuke
	 * the current compressed buffer and recompress it.
898 899
	 *
	 * Note that is possible for a tiled surface to be unmappable (and
900
	 * so have no fence associated with it) due to aperture constraints
901
	 * at the time of pinning.
902 903 904 905
	 *
	 * FIXME with 90/270 degree rotation we should use the fence on
	 * the normal GTT view (the rotated view doesn't even have a
	 * fence). Would need changes to the FBC fence Y offset as well.
906
	 * For now this will effectively disable FBC with 90/270 degree
907
	 * rotation.
908
	 */
909
	if (DISPLAY_VER(dev_priv) < 9 && cache->fence_id < 0) {
910 911
		fbc->no_fbc_reason = "framebuffer not tiled or fenced";
		return false;
912
	}
913

914 915 916 917 918
	if (!pixel_format_is_valid(dev_priv, cache->fb.format->format)) {
		fbc->no_fbc_reason = "pixel format is invalid";
		return false;
	}

919 920
	if (!rotation_is_valid(dev_priv, cache->fb.format->format,
			       cache->plane.rotation)) {
921
		fbc->no_fbc_reason = "rotation unsupported";
922
		return false;
923 924
	}

925 926 927 928 929
	if (!tiling_is_valid(dev_priv, cache->fb.modifier)) {
		fbc->no_fbc_reason = "tiling unsupported";
		return false;
	}

930 931
	if (!stride_is_valid(dev_priv, cache->fb.modifier,
			     cache->fb.stride * cache->fb.format->cpp[0])) {
932
		fbc->no_fbc_reason = "framebuffer stride not supported";
933
		return false;
934 935
	}

936 937 938 939 940 941
	if (cache->plane.pixel_blend_mode != DRM_MODE_BLEND_PIXEL_NONE &&
	    cache->fb.format->has_alpha) {
		fbc->no_fbc_reason = "per-pixel alpha blending is incompatible with FBC";
		return false;
	}

942 943
	/* WaFbcExceedCdClockThreshold:hsw,bdw */
	if ((IS_HASWELL(dev_priv) || IS_BROADWELL(dev_priv)) &&
944
	    cache->crtc.hsw_bdw_pixel_rate >= dev_priv->cdclk.hw.cdclk * 95 / 100) {
945
		fbc->no_fbc_reason = "pixel rate is too big";
946
		return false;
947 948
	}

949 950 951 952 953 954 955 956 957 958
	/* It is possible for the required CFB size change without a
	 * crtc->disable + crtc->enable since it is possible to change the
	 * stride without triggering a full modeset. Since we try to
	 * over-allocate the CFB, there's a chance we may keep FBC enabled even
	 * if this happens, but if we exceed the current CFB size we'll have to
	 * disable FBC. Notice that it would be possible to disable FBC, wait
	 * for a frame, free the stolen node, then try to reenable FBC in case
	 * we didn't get any invalidate/deactivate calls, but this would require
	 * a lot of tracking just for a specific case. If we conclude it's an
	 * important case, we can implement it later. */
959
	if (intel_fbc_cfb_size_changed(dev_priv)) {
960
		fbc->no_fbc_reason = "CFB requirements changed";
961 962 963
		return false;
	}

964 965 966 967 968
	/*
	 * Work around a problem on GEN9+ HW, where enabling FBC on a plane
	 * having a Y offset that isn't divisible by 4 causes FIFO underrun
	 * and screen flicker.
	 */
969
	if (DISPLAY_VER(dev_priv) >= 9 &&
970 971 972 973 974
	    (fbc->state_cache.plane.adjusted_y & 3)) {
		fbc->no_fbc_reason = "plane Y offset is misaligned";
		return false;
	}

975
	/* Wa_22010751166: icl, ehl, tgl, dg1, rkl */
976
	if (DISPLAY_VER(dev_priv) >= 11 &&
977 978 979 980 981
	    (cache->plane.src_h + cache->plane.adjusted_y) % 4) {
		fbc->no_fbc_reason = "plane height + offset is non-modulo of 4";
		return false;
	}

982
	/*
983
	 * Display 12+ is not supporting FBC with PSR2.
984 985 986
	 * Recommendation is to keep this combination disabled
	 * Bspec: 50422 HSD: 14010260002
	 */
987
	if (fbc->state_cache.psr2_active && DISPLAY_VER(dev_priv) >= 12) {
988 989 990 991
		fbc->no_fbc_reason = "not supported with PSR2";
		return false;
	}

992 993 994
	return true;
}

995 996 997
static void intel_fbc_get_reg_params(struct intel_crtc *crtc,
				     struct intel_fbc_reg_params *params)
{
998
	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
999 1000
	struct intel_fbc *fbc = &dev_priv->fbc;
	struct intel_fbc_state_cache *cache = &fbc->state_cache;
1001 1002 1003 1004 1005 1006

	/* Since all our fields are integer types, use memset here so the
	 * comparison function can rely on memcmp because the padding will be
	 * zero. */
	memset(params, 0, sizeof(*params));

1007
	params->fence_id = cache->fence_id;
1008
	params->fence_y_offset = cache->fence_y_offset;
1009

1010 1011
	params->interval = cache->interval;

1012
	params->crtc.pipe = crtc->pipe;
V
Ville Syrjälä 已提交
1013
	params->crtc.i9xx_plane = to_intel_plane(crtc->base.primary)->i9xx_plane;
1014

1015
	params->fb.format = cache->fb.format;
1016
	params->fb.modifier = cache->fb.modifier;
1017
	params->fb.stride = cache->fb.stride;
1018

1019 1020 1021
	params->cfb_stride = intel_fbc_cfb_stride(dev_priv, cache);
	params->cfb_size = intel_fbc_cfb_size(dev_priv, cache);
	params->override_cfb_stride = intel_fbc_override_cfb_stride(dev_priv, cache);
1022 1023

	params->plane_visible = cache->plane.visible;
1024 1025
}

1026 1027 1028 1029 1030 1031 1032 1033 1034 1035 1036 1037 1038 1039 1040 1041 1042 1043 1044 1045
static bool intel_fbc_can_flip_nuke(const struct intel_crtc_state *crtc_state)
{
	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
	const struct intel_fbc *fbc = &dev_priv->fbc;
	const struct intel_fbc_state_cache *cache = &fbc->state_cache;
	const struct intel_fbc_reg_params *params = &fbc->params;

	if (drm_atomic_crtc_needs_modeset(&crtc_state->uapi))
		return false;

	if (!params->plane_visible)
		return false;

	if (!intel_fbc_can_activate(crtc))
		return false;

	if (params->fb.format != cache->fb.format)
		return false;

1046 1047 1048
	if (params->fb.modifier != cache->fb.modifier)
		return false;

1049 1050 1051
	if (params->fb.stride != cache->fb.stride)
		return false;

1052
	if (params->cfb_stride != intel_fbc_cfb_stride(dev_priv, cache))
1053 1054
		return false;

1055 1056 1057 1058
	if (params->cfb_size != intel_fbc_cfb_size(dev_priv, cache))
		return false;

	if (params->override_cfb_stride != intel_fbc_override_cfb_stride(dev_priv, cache))
1059 1060 1061 1062 1063
		return false;

	return true;
}

1064 1065
bool intel_fbc_pre_update(struct intel_atomic_state *state,
			  struct intel_crtc *crtc)
1066
{
1067 1068 1069 1070 1071
	struct intel_plane *plane = to_intel_plane(crtc->base.primary);
	const struct intel_crtc_state *crtc_state =
		intel_atomic_get_new_crtc_state(state, crtc);
	const struct intel_plane_state *plane_state =
		intel_atomic_get_new_plane_state(state, plane);
1072
	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
1073
	struct intel_fbc *fbc = &dev_priv->fbc;
1074
	const char *reason = "update pending";
1075
	bool need_vblank_wait = false;
1076

1077
	if (!plane->has_fbc || !plane_state)
1078 1079
		return need_vblank_wait;

1080
	mutex_lock(&fbc->lock);
1081

V
Ville Syrjälä 已提交
1082
	if (fbc->crtc != crtc)
1083
		goto unlock;
1084

1085
	intel_fbc_update_state_cache(crtc, crtc_state, plane_state);
1086
	fbc->flip_pending = true;
1087

1088
	if (!intel_fbc_can_flip_nuke(crtc_state)) {
1089
		intel_fbc_deactivate(dev_priv, reason);
1090 1091 1092 1093 1094 1095 1096 1097 1098 1099 1100 1101 1102 1103 1104

		/*
		 * Display WA #1198: glk+
		 * Need an extra vblank wait between FBC disable and most plane
		 * updates. Bspec says this is only needed for plane disable, but
		 * that is not true. Touching most plane registers will cause the
		 * corruption to appear. Also SKL/derivatives do not seem to be
		 * affected.
		 *
		 * TODO: could optimize this a bit by sampling the frame
		 * counter when we disable FBC (if it was already done earlier)
		 * and skipping the extra vblank wait before the plane update
		 * if at least one frame has already passed.
		 */
		if (fbc->activated &&
1105
		    DISPLAY_VER(dev_priv) >= 10)
1106 1107 1108
			need_vblank_wait = true;
		fbc->activated = false;
	}
1109 1110
unlock:
	mutex_unlock(&fbc->lock);
1111 1112

	return need_vblank_wait;
1113 1114
}

1115 1116 1117 1118 1119 1120 1121 1122 1123 1124 1125 1126
/**
 * __intel_fbc_disable - disable FBC
 * @dev_priv: i915 device instance
 *
 * This is the low level function that actually disables FBC. Callers should
 * grab the FBC lock.
 */
static void __intel_fbc_disable(struct drm_i915_private *dev_priv)
{
	struct intel_fbc *fbc = &dev_priv->fbc;
	struct intel_crtc *crtc = fbc->crtc;

1127 1128 1129
	drm_WARN_ON(&dev_priv->drm, !mutex_is_locked(&fbc->lock));
	drm_WARN_ON(&dev_priv->drm, !fbc->crtc);
	drm_WARN_ON(&dev_priv->drm, fbc->active);
1130

1131 1132
	drm_dbg_kms(&dev_priv->drm, "Disabling FBC on pipe %c\n",
		    pipe_name(crtc->pipe));
1133 1134 1135 1136 1137 1138

	__intel_fbc_cleanup_cfb(dev_priv);

	fbc->crtc = NULL;
}

1139
static void __intel_fbc_post_update(struct intel_crtc *crtc)
1140
{
1141
	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
1142 1143
	struct intel_fbc *fbc = &dev_priv->fbc;

1144
	drm_WARN_ON(&dev_priv->drm, !mutex_is_locked(&fbc->lock));
1145

V
Ville Syrjälä 已提交
1146
	if (fbc->crtc != crtc)
1147 1148
		return;

1149 1150
	fbc->flip_pending = false;

1151
	if (!dev_priv->params.enable_fbc) {
1152 1153 1154 1155 1156 1157
		intel_fbc_deactivate(dev_priv, "disabled at runtime per module param");
		__intel_fbc_disable(dev_priv);

		return;
	}

1158
	intel_fbc_get_reg_params(crtc, &fbc->params);
1159

1160
	if (!intel_fbc_can_activate(crtc))
1161 1162
		return;

1163
	if (!fbc->busy_bits)
1164
		intel_fbc_activate(dev_priv);
1165
	else
1166
		intel_fbc_deactivate(dev_priv, "frontbuffer write");
P
Paulo Zanoni 已提交
1167 1168
}

1169 1170
void intel_fbc_post_update(struct intel_atomic_state *state,
			   struct intel_crtc *crtc)
P
Paulo Zanoni 已提交
1171
{
1172
	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
1173 1174 1175
	struct intel_plane *plane = to_intel_plane(crtc->base.primary);
	const struct intel_plane_state *plane_state =
		intel_atomic_get_new_plane_state(state, plane);
1176
	struct intel_fbc *fbc = &dev_priv->fbc;
1177

1178
	if (!plane->has_fbc || !plane_state)
1179 1180
		return;

1181
	mutex_lock(&fbc->lock);
1182
	__intel_fbc_post_update(crtc);
1183
	mutex_unlock(&fbc->lock);
1184 1185
}

1186 1187
static unsigned int intel_fbc_get_frontbuffer_bit(struct intel_fbc *fbc)
{
V
Ville Syrjälä 已提交
1188
	if (fbc->crtc)
1189 1190 1191 1192 1193
		return to_intel_plane(fbc->crtc->base.primary)->frontbuffer_bit;
	else
		return fbc->possible_framebuffer_bits;
}

1194 1195 1196 1197
void intel_fbc_invalidate(struct drm_i915_private *dev_priv,
			  unsigned int frontbuffer_bits,
			  enum fb_op_origin origin)
{
1198
	struct intel_fbc *fbc = &dev_priv->fbc;
1199

1200
	if (!HAS_FBC(dev_priv))
1201 1202
		return;

1203
	if (origin == ORIGIN_FLIP)
1204 1205
		return;

1206
	mutex_lock(&fbc->lock);
P
Paulo Zanoni 已提交
1207

1208
	fbc->busy_bits |= intel_fbc_get_frontbuffer_bit(fbc) & frontbuffer_bits;
1209

V
Ville Syrjälä 已提交
1210
	if (fbc->crtc && fbc->busy_bits)
1211
		intel_fbc_deactivate(dev_priv, "frontbuffer write");
P
Paulo Zanoni 已提交
1212

1213
	mutex_unlock(&fbc->lock);
1214 1215 1216
}

void intel_fbc_flush(struct drm_i915_private *dev_priv,
1217
		     unsigned int frontbuffer_bits, enum fb_op_origin origin)
1218
{
1219 1220
	struct intel_fbc *fbc = &dev_priv->fbc;

1221
	if (!HAS_FBC(dev_priv))
1222 1223
		return;

1224
	mutex_lock(&fbc->lock);
1225

1226
	fbc->busy_bits &= ~frontbuffer_bits;
1227

1228
	if (origin == ORIGIN_FLIP)
1229 1230
		goto out;

V
Ville Syrjälä 已提交
1231
	if (!fbc->busy_bits && fbc->crtc &&
1232
	    (frontbuffer_bits & intel_fbc_get_frontbuffer_bit(fbc))) {
1233
		if (fbc->active)
1234
			intel_fbc_recompress(dev_priv);
1235
		else if (!fbc->flip_pending)
1236
			__intel_fbc_post_update(fbc->crtc);
1237
	}
P
Paulo Zanoni 已提交
1238

1239
out:
1240
	mutex_unlock(&fbc->lock);
1241 1242
}

1243 1244 1245 1246 1247 1248 1249 1250 1251 1252 1253 1254 1255
/**
 * intel_fbc_choose_crtc - select a CRTC to enable FBC on
 * @dev_priv: i915 device instance
 * @state: the atomic state structure
 *
 * This function looks at the proposed state for CRTCs and planes, then chooses
 * which pipe is going to have FBC by setting intel_crtc_state->enable_fbc to
 * true.
 *
 * Later, intel_fbc_enable is going to look for state->enable_fbc and then maybe
 * enable FBC for the chosen CRTC. If it does, it will set dev_priv->fbc.crtc.
 */
void intel_fbc_choose_crtc(struct drm_i915_private *dev_priv,
1256
			   struct intel_atomic_state *state)
1257 1258
{
	struct intel_fbc *fbc = &dev_priv->fbc;
1259 1260
	struct intel_plane *plane;
	struct intel_plane_state *plane_state;
1261
	bool crtc_chosen = false;
1262
	int i;
1263 1264 1265

	mutex_lock(&fbc->lock);

1266 1267
	/* Does this atomic commit involve the CRTC currently tied to FBC? */
	if (fbc->crtc &&
1268
	    !intel_atomic_get_new_crtc_state(state, fbc->crtc))
1269 1270
		goto out;

1271 1272 1273
	if (!intel_fbc_can_enable(dev_priv))
		goto out;

1274 1275 1276 1277
	/* Simply choose the first CRTC that is compatible and has a visible
	 * plane. We could go for fancier schemes such as checking the plane
	 * size, but this would just affect the few platforms that don't tie FBC
	 * to pipe or plane A. */
1278 1279
	for_each_new_intel_plane_in_state(state, plane, plane_state, i) {
		struct intel_crtc_state *crtc_state;
1280
		struct intel_crtc *crtc = to_intel_crtc(plane_state->hw.crtc);
1281

1282
		if (!plane->has_fbc)
1283 1284
			continue;

1285
		if (!plane_state->uapi.visible)
1286 1287
			continue;

1288
		crtc_state = intel_atomic_get_new_crtc_state(state, crtc);
1289

1290
		crtc_state->enable_fbc = true;
1291
		crtc_chosen = true;
1292
		break;
1293 1294
	}

1295 1296 1297
	if (!crtc_chosen)
		fbc->no_fbc_reason = "no suitable CRTC for FBC";

1298 1299 1300 1301
out:
	mutex_unlock(&fbc->lock);
}

1302 1303 1304
/**
 * intel_fbc_enable: tries to enable FBC on the CRTC
 * @crtc: the CRTC
1305
 * @state: corresponding &drm_crtc_state for @crtc
1306
 *
1307
 * This function checks if the given CRTC was chosen for FBC, then enables it if
1308 1309 1310
 * possible. Notice that it doesn't activate FBC. It is valid to call
 * intel_fbc_enable multiple times for the same pipe without an
 * intel_fbc_disable in the middle, as long as it is deactivated.
1311
 */
1312 1313
static void intel_fbc_enable(struct intel_atomic_state *state,
			     struct intel_crtc *crtc)
1314
{
1315
	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
1316 1317 1318 1319 1320
	struct intel_plane *plane = to_intel_plane(crtc->base.primary);
	const struct intel_crtc_state *crtc_state =
		intel_atomic_get_new_crtc_state(state, crtc);
	const struct intel_plane_state *plane_state =
		intel_atomic_get_new_plane_state(state, plane);
1321
	struct intel_fbc *fbc = &dev_priv->fbc;
1322
	struct intel_fbc_state_cache *cache = &fbc->state_cache;
1323
	int min_limit;
1324

1325
	if (!plane->has_fbc || !plane_state)
1326 1327
		return;

1328 1329 1330
	min_limit = intel_fbc_min_limit(plane_state->hw.fb ?
					plane_state->hw.fb->format->cpp[0] : 0);

1331
	mutex_lock(&fbc->lock);
1332

V
Ville Syrjälä 已提交
1333
	if (fbc->crtc) {
1334 1335 1336 1337 1338
		if (fbc->crtc != crtc)
			goto out;

		if (fbc->limit >= min_limit &&
		    !intel_fbc_cfb_size_changed(dev_priv))
1339
			goto out;
1340

1341 1342
		__intel_fbc_disable(dev_priv);
	}
1343

1344
	drm_WARN_ON(&dev_priv->drm, fbc->active);
1345

1346
	intel_fbc_update_state_cache(crtc, crtc_state, plane_state);
1347 1348 1349 1350 1351 1352

	/* FIXME crtc_state->enable_fbc lies :( */
	if (!cache->plane.visible)
		goto out;

	if (intel_fbc_alloc_cfb(dev_priv,
1353
				intel_fbc_cfb_size(dev_priv, cache), min_limit)) {
1354
		cache->plane.visible = false;
1355
		fbc->no_fbc_reason = "not enough stolen memory";
1356 1357 1358
		goto out;
	}

1359 1360
	drm_dbg_kms(&dev_priv->drm, "Enabling FBC on pipe %c\n",
		    pipe_name(crtc->pipe));
1361
	fbc->no_fbc_reason = "FBC enabled but not active yet\n";
1362

1363
	fbc->crtc = crtc;
1364 1365

	intel_fbc_program_cfb(dev_priv);
1366
out:
1367
	mutex_unlock(&fbc->lock);
1368 1369 1370
}

/**
1371
 * intel_fbc_disable - disable FBC if it's associated with crtc
1372 1373 1374 1375
 * @crtc: the CRTC
 *
 * This function disables FBC if it's associated with the provided CRTC.
 */
1376
void intel_fbc_disable(struct intel_crtc *crtc)
1377
{
1378
	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
1379
	struct intel_plane *plane = to_intel_plane(crtc->base.primary);
1380
	struct intel_fbc *fbc = &dev_priv->fbc;
1381

1382
	if (!plane->has_fbc)
1383 1384
		return;

1385
	mutex_lock(&fbc->lock);
1386
	if (fbc->crtc == crtc)
1387
		__intel_fbc_disable(dev_priv);
1388
	mutex_unlock(&fbc->lock);
1389 1390
}

1391 1392 1393 1394 1395 1396 1397 1398 1399 1400 1401 1402 1403 1404 1405 1406 1407 1408 1409 1410 1411 1412
/**
 * intel_fbc_update: enable/disable FBC on the CRTC
 * @state: atomic state
 * @crtc: the CRTC
 *
 * This function checks if the given CRTC was chosen for FBC, then enables it if
 * possible. Notice that it doesn't activate FBC. It is valid to call
 * intel_fbc_update multiple times for the same pipe without an
 * intel_fbc_disable in the middle.
 */
void intel_fbc_update(struct intel_atomic_state *state,
		      struct intel_crtc *crtc)
{
	const struct intel_crtc_state *crtc_state =
		intel_atomic_get_new_crtc_state(state, crtc);

	if (crtc_state->update_pipe && !crtc_state->enable_fbc)
		intel_fbc_disable(crtc);
	else
		intel_fbc_enable(state, crtc);
}

1413
/**
1414
 * intel_fbc_global_disable - globally disable FBC
1415 1416 1417 1418
 * @dev_priv: i915 device instance
 *
 * This function disables FBC regardless of which CRTC is associated with it.
 */
1419
void intel_fbc_global_disable(struct drm_i915_private *dev_priv)
1420
{
1421 1422
	struct intel_fbc *fbc = &dev_priv->fbc;

1423
	if (!HAS_FBC(dev_priv))
1424 1425
		return;

1426
	mutex_lock(&fbc->lock);
V
Ville Syrjälä 已提交
1427
	if (fbc->crtc) {
1428
		drm_WARN_ON(&dev_priv->drm, fbc->crtc->active);
1429
		__intel_fbc_disable(dev_priv);
1430
	}
1431
	mutex_unlock(&fbc->lock);
1432 1433
}

1434 1435 1436 1437 1438 1439 1440 1441 1442
static void intel_fbc_underrun_work_fn(struct work_struct *work)
{
	struct drm_i915_private *dev_priv =
		container_of(work, struct drm_i915_private, fbc.underrun_work);
	struct intel_fbc *fbc = &dev_priv->fbc;

	mutex_lock(&fbc->lock);

	/* Maybe we were scheduled twice. */
V
Ville Syrjälä 已提交
1443
	if (fbc->underrun_detected || !fbc->crtc)
1444 1445
		goto out;

1446
	drm_dbg_kms(&dev_priv->drm, "Disabling FBC due to FIFO underrun.\n");
1447 1448
	fbc->underrun_detected = true;

1449
	intel_fbc_deactivate(dev_priv, "FIFO underrun");
1450 1451 1452 1453
out:
	mutex_unlock(&fbc->lock);
}

1454 1455 1456 1457 1458 1459 1460 1461 1462 1463 1464 1465 1466 1467 1468 1469 1470 1471
/*
 * intel_fbc_reset_underrun - reset FBC fifo underrun status.
 * @dev_priv: i915 device instance
 *
 * See intel_fbc_handle_fifo_underrun_irq(). For automated testing we
 * want to re-enable FBC after an underrun to increase test coverage.
 */
int intel_fbc_reset_underrun(struct drm_i915_private *dev_priv)
{
	int ret;

	cancel_work_sync(&dev_priv->fbc.underrun_work);

	ret = mutex_lock_interruptible(&dev_priv->fbc.lock);
	if (ret)
		return ret;

	if (dev_priv->fbc.underrun_detected) {
1472 1473
		drm_dbg_kms(&dev_priv->drm,
			    "Re-allowing FBC after fifo underrun\n");
1474 1475 1476 1477 1478 1479 1480 1481 1482
		dev_priv->fbc.no_fbc_reason = "FIFO underrun cleared";
	}

	dev_priv->fbc.underrun_detected = false;
	mutex_unlock(&dev_priv->fbc.lock);

	return 0;
}

1483 1484 1485 1486 1487 1488 1489 1490 1491 1492 1493 1494 1495 1496 1497 1498 1499 1500
/**
 * intel_fbc_handle_fifo_underrun_irq - disable FBC when we get a FIFO underrun
 * @dev_priv: i915 device instance
 *
 * Without FBC, most underruns are harmless and don't really cause too many
 * problems, except for an annoying message on dmesg. With FBC, underruns can
 * become black screens or even worse, especially when paired with bad
 * watermarks. So in order for us to be on the safe side, completely disable FBC
 * in case we ever detect a FIFO underrun on any pipe. An underrun on any pipe
 * already suggests that watermarks may be bad, so try to be as safe as
 * possible.
 *
 * This function is called from the IRQ handler.
 */
void intel_fbc_handle_fifo_underrun_irq(struct drm_i915_private *dev_priv)
{
	struct intel_fbc *fbc = &dev_priv->fbc;

1501
	if (!HAS_FBC(dev_priv))
1502 1503 1504 1505 1506 1507 1508 1509 1510 1511 1512 1513 1514 1515
		return;

	/* There's no guarantee that underrun_detected won't be set to true
	 * right after this check and before the work is scheduled, but that's
	 * not a problem since we'll check it again under the work function
	 * while FBC is locked. This check here is just to prevent us from
	 * unnecessarily scheduling the work, and it relies on the fact that we
	 * never switch underrun_detect back to false after it's true. */
	if (READ_ONCE(fbc->underrun_detected))
		return;

	schedule_work(&fbc->underrun_work);
}

1516 1517 1518 1519 1520 1521 1522 1523 1524 1525 1526
/*
 * The DDX driver changes its behavior depending on the value it reads from
 * i915.enable_fbc, so sanitize it by translating the default value into either
 * 0 or 1 in order to allow it to know what's going on.
 *
 * Notice that this is done at driver initialization and we still allow user
 * space to change the value during runtime without sanitizing it again. IGT
 * relies on being able to change i915.enable_fbc at runtime.
 */
static int intel_sanitize_fbc_option(struct drm_i915_private *dev_priv)
{
1527 1528
	if (dev_priv->params.enable_fbc >= 0)
		return !!dev_priv->params.enable_fbc;
1529

1530 1531 1532
	if (!HAS_FBC(dev_priv))
		return 0;

1533
	if (IS_BROADWELL(dev_priv) || DISPLAY_VER(dev_priv) >= 9)
1534 1535 1536 1537 1538
		return 1;

	return 0;
}

1539 1540 1541
static bool need_fbc_vtd_wa(struct drm_i915_private *dev_priv)
{
	/* WaFbcTurnOffFbcWhenHyperVisorIsUsed:skl,bxt */
1542
	if (intel_vtd_active() &&
1543
	    (IS_SKYLAKE(dev_priv) || IS_BROXTON(dev_priv))) {
1544 1545
		drm_info(&dev_priv->drm,
			 "Disabling framebuffer compression (FBC) to prevent screen flicker with VT-d enabled\n");
1546 1547 1548 1549 1550 1551
		return true;
	}

	return false;
}

R
Rodrigo Vivi 已提交
1552 1553 1554 1555 1556 1557
/**
 * intel_fbc_init - Initialize FBC
 * @dev_priv: the i915 device
 *
 * This function might be called during PM init process.
 */
1558 1559
void intel_fbc_init(struct drm_i915_private *dev_priv)
{
1560
	struct intel_fbc *fbc = &dev_priv->fbc;
1561

1562
	INIT_WORK(&fbc->underrun_work, intel_fbc_underrun_work_fn);
1563 1564
	mutex_init(&fbc->lock);
	fbc->active = false;
P
Paulo Zanoni 已提交
1565

1566 1567 1568
	if (!drm_mm_initialized(&dev_priv->mm.stolen))
		mkwrite_device_info(dev_priv)->display.has_fbc = false;

1569
	if (need_fbc_vtd_wa(dev_priv))
1570
		mkwrite_device_info(dev_priv)->display.has_fbc = false;
1571

1572
	dev_priv->params.enable_fbc = intel_sanitize_fbc_option(dev_priv);
1573
	drm_dbg_kms(&dev_priv->drm, "Sanitized enable_fbc value: %d\n",
1574
		    dev_priv->params.enable_fbc);
1575

1576
	if (!HAS_FBC(dev_priv)) {
1577
		fbc->no_fbc_reason = "unsupported by this chipset";
1578 1579 1580
		return;
	}

1581
	/* We still don't have any sort of hardware state readout for FBC, so
1582 1583
	 * deactivate it in case the BIOS activated it to make sure software
	 * matches the hardware state. */
1584 1585
	if (intel_fbc_hw_is_active(dev_priv))
		intel_fbc_hw_deactivate(dev_priv);
1586
}