OSDN Git Service

Revert "intel: Add some defense against buffer allocation failure for subimage blits"
authorChris Wilson <chris@chris-wilson.co.uk>
Wed, 30 Mar 2011 09:54:31 +0000 (10:54 +0100)
committerChris Wilson <chris@chris-wilson.co.uk>
Wed, 30 Mar 2011 10:01:42 +0000 (11:01 +0100)
This reverts commit de7678ef521f4fb34459e407a66ab8bf8be733e1.

The conversion from using drm_intel_bo_alloc_tiled to a plain
drm_intel_bo_alloc forgot that the tiled variant adjusts the
allocation height even for TILING_NONE.

Reported-by: Dave Airlie <airlied@redhat.com>
Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=35786
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
src/mesa/drivers/dri/intel/intel_tex_subimage.c

index d0f8294..6b7f13f 100644 (file)
@@ -90,19 +90,19 @@ intelTexSubimage(struct gl_context * ctx,
          intel->gen < 6 && target == GL_TEXTURE_2D &&
          drm_intel_bo_busy(dst_bo))
       {
-        dstRowStride = width * intelImage->mt->cpp;
-         temp_bo = drm_intel_bo_alloc(intel->bufmgr, "subimage blit bo",
-                                      dstRowStride * height, 0);
-         if (!temp_bo)
-            return;
-
-        if (drm_intel_gem_bo_map_gtt(temp_bo)) {
-            drm_intel_bo_unreference(temp_bo);
-            return;
-         }
-
+        unsigned long pitch;
+        uint32_t tiling_mode = I915_TILING_NONE;
+        temp_bo = drm_intel_bo_alloc_tiled(intel->bufmgr,
+                                           "subimage blit bo",
+                                           width, height,
+                                           intelImage->mt->cpp,
+                                           &tiling_mode,
+                                           &pitch,
+                                           0);
+        drm_intel_gem_bo_map_gtt(temp_bo);
         texImage->Data = temp_bo->virtual;
         texImage->ImageOffsets[0] = 0;
+        dstRowStride = pitch;
 
         intel_miptree_get_image_offset(intelImage->mt, level,
                                        intelImage->face, 0,