]> www.infradead.org Git - users/griffoul/linux.git/commitdiff
drm/i915: Fix memory leaks in scatterlist
authorMatt Atwood <matthew.s.atwood@intel.com>
Wed, 1 Feb 2023 23:28:01 +0000 (15:28 -0800)
committerJani Nikula <jani.nikula@intel.com>
Wed, 15 Feb 2023 15:33:07 +0000 (17:33 +0200)
This patch fixes memory leaks on error escapes in i915_scatterlist.c

Fixes: c3bfba9a2225 ("drm/i915: Check for integer truncation on scatterlist creation")
Cc: Chris Wilson <chris@chris-wilson.co.uk>
Signed-off-by: Matt Atwood <matthew.s.atwood@intel.com>
Reviewed-by: Harish Chegondi <harish.chegondi@intel.com>
Signed-off-by: Matt Roper <matthew.d.roper@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20230201232801.123684-1-matthew.s.atwood@intel.com
(cherry picked from commit 389b9d91dd57fd2d4428bd0c19ed1cacf2fe918d)
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
drivers/gpu/drm/i915/i915_scatterlist.c

index 756289e43dff6e1be6572e48699ed2a127cfac76..7c7a86921b1c7a08c95f29942f027cec46f79441 100644 (file)
@@ -98,8 +98,10 @@ struct i915_refct_sgt *i915_rsgt_from_mm_node(const struct drm_mm_node *node,
        st = &rsgt->table;
        /* restricted by sg_alloc_table */
        if (WARN_ON(overflows_type(DIV_ROUND_UP_ULL(node->size, segment_pages),
-                                  unsigned int)))
+                                  unsigned int))) {
+               i915_refct_sgt_put(rsgt);
                return ERR_PTR(-E2BIG);
+       }
 
        if (sg_alloc_table(st, DIV_ROUND_UP_ULL(node->size, segment_pages),
                           GFP_KERNEL)) {
@@ -183,8 +185,10 @@ struct i915_refct_sgt *i915_rsgt_from_buddy_resource(struct ttm_resource *res,
        i915_refct_sgt_init(rsgt, size);
        st = &rsgt->table;
        /* restricted by sg_alloc_table */
-       if (WARN_ON(overflows_type(PFN_UP(res->size), unsigned int)))
+       if (WARN_ON(overflows_type(PFN_UP(res->size), unsigned int))) {
+               i915_refct_sgt_put(rsgt);
                return ERR_PTR(-E2BIG);
+       }
 
        if (sg_alloc_table(st, PFN_UP(res->size), GFP_KERNEL)) {
                i915_refct_sgt_put(rsgt);