diff options
author | Elena Reshetova <elena.reshetova@intel.com> | 2017-03-03 03:55:12 -0500 |
---|---|---|
committer | David Sterba <dsterba@suse.com> | 2017-04-18 08:07:23 -0400 |
commit | 490b54d6fb75f6ffd0471ec58bb38a992e2b40cd (patch) | |
tree | a7f431ea6a0f4369ba43be8736090efd54d6998b /fs/btrfs/tree-log.c | |
parent | 9b64f57ddf8673d29fafb3405d4aa1e93f5a4cd7 (diff) |
btrfs: convert extent_map.refs from atomic_t to refcount_t
refcount_t type and corresponding API should be
used instead of atomic_t when the variable is used as
a reference counter. This allows to avoid accidental
refcounter overflows that might lead to use-after-free
situations.
Signed-off-by: Elena Reshetova <elena.reshetova@intel.com>
Signed-off-by: Hans Liljestrand <ishkamiel@gmail.com>
Signed-off-by: Kees Cook <keescook@chromium.org>
Signed-off-by: David Windsor <dwindsor@gmail.com>
Signed-off-by: David Sterba <dsterba@suse.com>
Diffstat (limited to 'fs/btrfs/tree-log.c')
-rw-r--r-- | fs/btrfs/tree-log.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/fs/btrfs/tree-log.c b/fs/btrfs/tree-log.c index a59674c3e69e..ccfe9fe7754a 100644 --- a/fs/btrfs/tree-log.c +++ b/fs/btrfs/tree-log.c | |||
@@ -4196,7 +4196,7 @@ static int btrfs_log_changed_extents(struct btrfs_trans_handle *trans, | |||
4196 | if (em->generation <= test_gen) | 4196 | if (em->generation <= test_gen) |
4197 | continue; | 4197 | continue; |
4198 | /* Need a ref to keep it from getting evicted from cache */ | 4198 | /* Need a ref to keep it from getting evicted from cache */ |
4199 | atomic_inc(&em->refs); | 4199 | refcount_inc(&em->refs); |
4200 | set_bit(EXTENT_FLAG_LOGGING, &em->flags); | 4200 | set_bit(EXTENT_FLAG_LOGGING, &em->flags); |
4201 | list_add_tail(&em->list, &extents); | 4201 | list_add_tail(&em->list, &extents); |
4202 | num++; | 4202 | num++; |