dm thin: use refcount_t for thin_c reference counting
authorJohn Pittman <jpittman@redhat.com>
Thu, 23 Aug 2018 17:35:55 +0000 (13:35 -0400)
committerMike Snitzer <snitzer@redhat.com>
Tue, 16 Oct 2018 18:27:03 +0000 (14:27 -0400)
The API surrounding refcount_t should be used in place of atomic_t
when variables are being used as reference counters.  It can
potentially prevent reference counter overflows and use-after-free
conditions.  In the dm thin layer, one such example is tc->refcount.
Change this from the atomic_t API to the refcount_t API to prevent
mentioned conditions.

Signed-off-by: John Pittman <jpittman@redhat.com>
Signed-off-by: Mike Snitzer <snitzer@redhat.com>
drivers/md/dm-thin.c

index aaf1ad481ee88e59b90273133b7a7bd90c69d3fb..0bd8d498b3b90dc8fdc173adcda33640ca73c04c 100644 (file)
@@ -325,7 +325,7 @@ struct thin_c {
         * Ensures the thin is not destroyed until the worker has finished
         * iterating the active_thins list.
         */
-       atomic_t refcount;
+       refcount_t refcount;
        struct completion can_destroy;
 };
 
@@ -4044,12 +4044,12 @@ static struct target_type pool_target = {
  *--------------------------------------------------------------*/
 static void thin_get(struct thin_c *tc)
 {
-       atomic_inc(&tc->refcount);
+       refcount_inc(&tc->refcount);
 }
 
 static void thin_put(struct thin_c *tc)
 {
-       if (atomic_dec_and_test(&tc->refcount))
+       if (refcount_dec_and_test(&tc->refcount))
                complete(&tc->can_destroy);
 }
 
@@ -4193,7 +4193,7 @@ static int thin_ctr(struct dm_target *ti, unsigned argc, char **argv)
                r = -EINVAL;
                goto bad;
        }
-       atomic_set(&tc->refcount, 1);
+       refcount_set(&tc->refcount, 1);
        init_completion(&tc->can_destroy);
        list_add_tail_rcu(&tc->list, &tc->pool->active_thins);
        spin_unlock_irqrestore(&tc->pool->lock, flags);