Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 90d5234f authored by Paulo Zanoni's avatar Paulo Zanoni
Browse files

drm/i915: fix the CFB size check



In function find_compression_threshold() we try to over-allocate CFB
space in order to reduce reallocations and fragmentation, and we're
not considering that at the CFB size check. Consider it.

There is also a longer-term plan to kill
dev_priv->fbc.uncompressed_size, but this will come later.

v2: Use drm_mm_node_allocated() (Chris).

Reviewed-by: default avatarChris Wilson <chris@chris-wilson.co.uk>
Signed-off-by: default avatarPaulo Zanoni <paulo.r.zanoni@intel.com>
Link: http://patchwork.freedesktop.org/patch/msgid/
parent bffce907
Loading
Loading
Loading
Loading
+2 −1
Original line number Original line Diff line number Diff line
@@ -720,7 +720,8 @@ static int intel_fbc_setup_cfb(struct intel_crtc *crtc)
	size = intel_fbc_calculate_cfb_size(crtc);
	size = intel_fbc_calculate_cfb_size(crtc);
	cpp = drm_format_plane_cpp(fb->pixel_format, 0);
	cpp = drm_format_plane_cpp(fb->pixel_format, 0);


	if (size <= dev_priv->fbc.uncompressed_size)
	if (drm_mm_node_allocated(&dev_priv->fbc.compressed_fb) &&
	    size <= dev_priv->fbc.compressed_fb.size * dev_priv->fbc.threshold)
		return 0;
		return 0;


	/* Release any current block */
	/* Release any current block */