summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorChris Wilson <chris@chris-wilson.co.uk>2010-11-14 19:47:00 +0000
committerChris Wilson <chris@chris-wilson.co.uk>2010-11-14 19:47:00 +0000
commitcc930a37612341a1f2457adb339523c215879d82 (patch)
tree14a8753a5eab49c0af3468a12e6cb86fb06771dd /src
parent3c5b1399e29ef577b8b91655b5e1c215d1b6dfbb (diff)
uxa: Relax fencing some more for gen3
Allow fenced allocations even for small pixmaps if the kernel supports relaxing fencing (where only the used pages are allocated). Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Diffstat (limited to 'src')
-rw-r--r--src/intel_uxa.c18
1 files changed, 11 insertions, 7 deletions
diff --git a/src/intel_uxa.c b/src/intel_uxa.c
index ee1247f4..8db0ef0d 100644
--- a/src/intel_uxa.c
+++ b/src/intel_uxa.c
@@ -146,18 +146,22 @@ intel_uxa_pixmap_compute_size(PixmapPtr pixmap,
pitch = ALIGN(pitch, 64);
size = pitch * ALIGN (h, 2);
if (INTEL_INFO(intel)->gen < 40) {
- /* Older hardware requires fences to be pot size
- * aligned with a minimum of 1 MiB, so causes
- * massive overallocation for small textures.
- */
- if (size < 1024*1024/2)
- *tiling = I915_TILING_NONE;
-
/* Gen 2/3 has a maximum stride for tiling of
* 8192 bytes.
*/
if (pitch > KB(8))
*tiling = I915_TILING_NONE;
+
+ /* Narrower than half a tile? */
+ if (pitch < 256)
+ *tiling = I915_TILING_NONE;
+
+ /* Older hardware requires fences to be pot size
+ * aligned with a minimum of 1 MiB, so causes
+ * massive overallocation for small textures.
+ */
+ if (size < 1024*1024/2 && !intel->has_relaxed_fencing)
+ *tiling = I915_TILING_NONE;
} else if (!(usage & INTEL_CREATE_PIXMAP_DRI2) && size <= 4096) {
/* Disable tiling beneath a page size, we will not see
* any benefit from reducing TLB misses and instead