*                                    ->add_extent_mapping(0, 16K)
  *                                    -> #handle -EEXIST
  */
-static int test_case_1(struct btrfs_fs_info *fs_info,
-               struct extent_map_tree *em_tree)
+static int test_case_1(struct btrfs_fs_info *fs_info, struct btrfs_inode *inode)
 {
+       struct extent_map_tree *em_tree = &inode->extent_tree;
        struct extent_map *em;
        u64 start = 0;
        u64 len = SZ_8K;
        em->block_start = 0;
        em->block_len = SZ_16K;
        write_lock(&em_tree->lock);
-       ret = btrfs_add_extent_mapping(fs_info, em_tree, &em, em->start, em->len);
+       ret = btrfs_add_extent_mapping(inode, &em, em->start, em->len);
        write_unlock(&em_tree->lock);
        if (ret < 0) {
                test_err("cannot add extent range [0, 16K)");
        em->block_start = SZ_32K; /* avoid merging */
        em->block_len = SZ_4K;
        write_lock(&em_tree->lock);
-       ret = btrfs_add_extent_mapping(fs_info, em_tree, &em, em->start, em->len);
+       ret = btrfs_add_extent_mapping(inode, &em, em->start, em->len);
        write_unlock(&em_tree->lock);
        if (ret < 0) {
                test_err("cannot add extent range [16K, 20K)");
        em->block_start = start;
        em->block_len = len;
        write_lock(&em_tree->lock);
-       ret = btrfs_add_extent_mapping(fs_info, em_tree, &em, em->start, em->len);
+       ret = btrfs_add_extent_mapping(inode, &em, em->start, em->len);
        write_unlock(&em_tree->lock);
        if (ret) {
                test_err("case1 [%llu %llu]: ret %d", start, start + len, ret);
  * Reading the inline ending up with EEXIST, ie. read an inline
  * extent and discard page cache and read it again.
  */
-static int test_case_2(struct btrfs_fs_info *fs_info,
-               struct extent_map_tree *em_tree)
+static int test_case_2(struct btrfs_fs_info *fs_info, struct btrfs_inode *inode)
 {
+       struct extent_map_tree *em_tree = &inode->extent_tree;
        struct extent_map *em;
        int ret;
 
        em->block_start = EXTENT_MAP_INLINE;
        em->block_len = (u64)-1;
        write_lock(&em_tree->lock);
-       ret = btrfs_add_extent_mapping(fs_info, em_tree, &em, em->start, em->len);
+       ret = btrfs_add_extent_mapping(inode, &em, em->start, em->len);
        write_unlock(&em_tree->lock);
        if (ret < 0) {
                test_err("cannot add extent range [0, 1K)");
        em->block_start = SZ_4K;
        em->block_len = SZ_4K;
        write_lock(&em_tree->lock);
-       ret = btrfs_add_extent_mapping(fs_info, em_tree, &em, em->start, em->len);
+       ret = btrfs_add_extent_mapping(inode, &em, em->start, em->len);
        write_unlock(&em_tree->lock);
        if (ret < 0) {
                test_err("cannot add extent range [4K, 8K)");
        em->block_start = EXTENT_MAP_INLINE;
        em->block_len = (u64)-1;
        write_lock(&em_tree->lock);
-       ret = btrfs_add_extent_mapping(fs_info, em_tree, &em, em->start, em->len);
+       ret = btrfs_add_extent_mapping(inode, &em, em->start, em->len);
        write_unlock(&em_tree->lock);
        if (ret) {
                test_err("case2 [0 1K]: ret %d", ret);
 }
 
 static int __test_case_3(struct btrfs_fs_info *fs_info,
-               struct extent_map_tree *em_tree, u64 start)
+                        struct btrfs_inode *inode, u64 start)
 {
+       struct extent_map_tree *em_tree = &inode->extent_tree;
        struct extent_map *em;
        u64 len = SZ_4K;
        int ret;
        em->block_start = SZ_4K;
        em->block_len = SZ_4K;
        write_lock(&em_tree->lock);
-       ret = btrfs_add_extent_mapping(fs_info, em_tree, &em, em->start, em->len);
+       ret = btrfs_add_extent_mapping(inode, &em, em->start, em->len);
        write_unlock(&em_tree->lock);
        if (ret < 0) {
                test_err("cannot add extent range [4K, 8K)");
        em->block_start = 0;
        em->block_len = SZ_16K;
        write_lock(&em_tree->lock);
-       ret = btrfs_add_extent_mapping(fs_info, em_tree, &em, start, len);
+       ret = btrfs_add_extent_mapping(inode, &em, start, len);
        write_unlock(&em_tree->lock);
        if (ret) {
                test_err("case3 [%llu %llu): ret %d",
  *   -> add_extent_mapping()
  *                            -> add_extent_mapping()
  */
-static int test_case_3(struct btrfs_fs_info *fs_info,
-               struct extent_map_tree *em_tree)
+static int test_case_3(struct btrfs_fs_info *fs_info, struct btrfs_inode *inode)
 {
        int ret;
 
-       ret = __test_case_3(fs_info, em_tree, 0);
+       ret = __test_case_3(fs_info, inode, 0);
        if (ret)
                return ret;
-       ret = __test_case_3(fs_info, em_tree, SZ_8K);
+       ret = __test_case_3(fs_info, inode, SZ_8K);
        if (ret)
                return ret;
-       ret = __test_case_3(fs_info, em_tree, (12 * SZ_1K));
+       ret = __test_case_3(fs_info, inode, (12 * SZ_1K));
 
        return ret;
 }
 
 static int __test_case_4(struct btrfs_fs_info *fs_info,
-               struct extent_map_tree *em_tree, u64 start)
+                        struct btrfs_inode *inode, u64 start)
 {
+       struct extent_map_tree *em_tree = &inode->extent_tree;
        struct extent_map *em;
        u64 len = SZ_4K;
        int ret;
        em->block_start = 0;
        em->block_len = SZ_8K;
        write_lock(&em_tree->lock);
-       ret = btrfs_add_extent_mapping(fs_info, em_tree, &em, em->start, em->len);
+       ret = btrfs_add_extent_mapping(inode, &em, em->start, em->len);
        write_unlock(&em_tree->lock);
        if (ret < 0) {
                test_err("cannot add extent range [0, 8K)");
        em->block_start = SZ_16K; /* avoid merging */
        em->block_len = 24 * SZ_1K;
        write_lock(&em_tree->lock);
-       ret = btrfs_add_extent_mapping(fs_info, em_tree, &em, em->start, em->len);
+       ret = btrfs_add_extent_mapping(inode, &em, em->start, em->len);
        write_unlock(&em_tree->lock);
        if (ret < 0) {
                test_err("cannot add extent range [8K, 32K)");
        em->block_start = 0;
        em->block_len = SZ_32K;
        write_lock(&em_tree->lock);
-       ret = btrfs_add_extent_mapping(fs_info, em_tree, &em, start, len);
+       ret = btrfs_add_extent_mapping(inode, &em, start, len);
        write_unlock(&em_tree->lock);
        if (ret) {
                test_err("case4 [%llu %llu): ret %d",
  *                                             # handle -EEXIST when adding
  *                                             # [0, 32K)
  */
-static int test_case_4(struct btrfs_fs_info *fs_info,
-               struct extent_map_tree *em_tree)
+static int test_case_4(struct btrfs_fs_info *fs_info, struct btrfs_inode *inode)
 {
        int ret;
 
-       ret = __test_case_4(fs_info, em_tree, 0);
+       ret = __test_case_4(fs_info, inode, 0);
        if (ret)
                return ret;
-       ret = __test_case_4(fs_info, em_tree, SZ_4K);
+       ret = __test_case_4(fs_info, inode, SZ_4K);
 
        return ret;
 }
 
-static int add_compressed_extent(struct btrfs_fs_info *fs_info,
-                                struct extent_map_tree *em_tree,
+static int add_compressed_extent(struct btrfs_inode *inode,
                                 u64 start, u64 len, u64 block_start)
 {
+       struct extent_map_tree *em_tree = &inode->extent_tree;
        struct extent_map *em;
        int ret;
 
        em->block_len = SZ_4K;
        em->flags |= EXTENT_FLAG_COMPRESS_ZLIB;
        write_lock(&em_tree->lock);
-       ret = btrfs_add_extent_mapping(fs_info, em_tree, &em, em->start, em->len);
+       ret = btrfs_add_extent_mapping(inode, &em, em->start, em->len);
        write_unlock(&em_tree->lock);
        free_extent_map(em);
        if (ret < 0) {
  * They'll have the EXTENT_FLAG_COMPRESSED flag set to keep the em tree from
  * merging the em's.
  */
-static int test_case_5(struct btrfs_fs_info *fs_info)
+static int test_case_5(struct btrfs_fs_info *fs_info, struct btrfs_inode *inode)
 {
-       struct extent_map_tree *em_tree;
-       struct inode *inode;
        u64 start, end;
        int ret;
 
        test_msg("Running btrfs_drop_extent_map_range tests");
 
-       inode = btrfs_new_test_inode();
-       if (!inode) {
-               test_std_err(TEST_ALLOC_INODE);
-               return -ENOMEM;
-       }
-
-       em_tree = &BTRFS_I(inode)->extent_tree;
-
        /* [0, 12k) */
-       ret = add_compressed_extent(fs_info, em_tree, 0, SZ_4K * 3, 0);
+       ret = add_compressed_extent(inode, 0, SZ_4K * 3, 0);
        if (ret) {
                test_err("cannot add extent range [0, 12K)");
                goto out;
        }
 
        /* [12k, 24k) */
-       ret = add_compressed_extent(fs_info, em_tree, SZ_4K * 3, SZ_4K * 3, SZ_4K);
+       ret = add_compressed_extent(inode, SZ_4K * 3, SZ_4K * 3, SZ_4K);
        if (ret) {
                test_err("cannot add extent range [12k, 24k)");
                goto out;
        }
 
        /* [24k, 36k) */
-       ret = add_compressed_extent(fs_info, em_tree, SZ_4K * 6, SZ_4K * 3, SZ_8K);
+       ret = add_compressed_extent(inode, SZ_4K * 6, SZ_4K * 3, SZ_8K);
        if (ret) {
                test_err("cannot add extent range [12k, 24k)");
                goto out;
        }
 
        /* [36k, 40k) */
-       ret = add_compressed_extent(fs_info, em_tree, SZ_32K + SZ_4K, SZ_4K, SZ_4K * 3);
+       ret = add_compressed_extent(inode, SZ_32K + SZ_4K, SZ_4K, SZ_4K * 3);
        if (ret) {
                test_err("cannot add extent range [12k, 24k)");
                goto out;
        }
 
        /* [40k, 64k) */
-       ret = add_compressed_extent(fs_info, em_tree, SZ_4K * 10, SZ_4K * 6, SZ_16K);
+       ret = add_compressed_extent(inode, SZ_4K * 10, SZ_4K * 6, SZ_16K);
        if (ret) {
                test_err("cannot add extent range [12k, 24k)");
                goto out;
        /* Drop [8k, 12k) */
        start = SZ_8K;
        end = (3 * SZ_4K) - 1;
-       btrfs_drop_extent_map_range(BTRFS_I(inode), start, end, false);
-       ret = validate_range(&BTRFS_I(inode)->extent_tree, 0);
+       btrfs_drop_extent_map_range(inode, start, end, false);
+       ret = validate_range(&inode->extent_tree, 0);
        if (ret)
                goto out;
 
        /* Drop [12k, 20k) */
        start = SZ_4K * 3;
        end = SZ_16K + SZ_4K - 1;
-       btrfs_drop_extent_map_range(BTRFS_I(inode), start, end, false);
-       ret = validate_range(&BTRFS_I(inode)->extent_tree, 1);
+       btrfs_drop_extent_map_range(inode, start, end, false);
+       ret = validate_range(&inode->extent_tree, 1);
        if (ret)
                goto out;
 
        /* Drop [28k, 32k) */
        start = SZ_32K - SZ_4K;
        end = SZ_32K - 1;
-       btrfs_drop_extent_map_range(BTRFS_I(inode), start, end, false);
-       ret = validate_range(&BTRFS_I(inode)->extent_tree, 2);
+       btrfs_drop_extent_map_range(inode, start, end, false);
+       ret = validate_range(&inode->extent_tree, 2);
        if (ret)
                goto out;
 
        /* Drop [32k, 64k) */
        start = SZ_32K;
        end = SZ_64K - 1;
-       btrfs_drop_extent_map_range(BTRFS_I(inode), start, end, false);
-       ret = validate_range(&BTRFS_I(inode)->extent_tree, 3);
+       btrfs_drop_extent_map_range(inode, start, end, false);
+       ret = validate_range(&inode->extent_tree, 3);
        if (ret)
                goto out;
 out:
-       iput(inode);
+       free_extent_map_tree(&inode->extent_tree);
        return ret;
 }
 
  * for areas between two existing ems.  Validate it doesn't do this when there
  * are two unmerged em's side by side.
  */
-static int test_case_6(struct btrfs_fs_info *fs_info, struct extent_map_tree *em_tree)
+static int test_case_6(struct btrfs_fs_info *fs_info, struct btrfs_inode *inode)
 {
+       struct extent_map_tree *em_tree = &inode->extent_tree;
        struct extent_map *em = NULL;
        int ret;
 
-       ret = add_compressed_extent(fs_info, em_tree, 0, SZ_4K, 0);
+       ret = add_compressed_extent(inode, 0, SZ_4K, 0);
        if (ret)
                goto out;
 
-       ret = add_compressed_extent(fs_info, em_tree, SZ_4K, SZ_4K, 0);
+       ret = add_compressed_extent(inode, SZ_4K, SZ_4K, 0);
        if (ret)
                goto out;
 
        em = alloc_extent_map();
        if (!em) {
                test_std_err(TEST_ALLOC_EXTENT_MAP);
-               return -ENOMEM;
+               ret = -ENOMEM;
+               goto out;
        }
 
        em->start = SZ_4K;
        em->block_start = SZ_16K;
        em->block_len = SZ_16K;
        write_lock(&em_tree->lock);
-       ret = btrfs_add_extent_mapping(fs_info, em_tree, &em, 0, SZ_8K);
+       ret = btrfs_add_extent_mapping(inode, &em, 0, SZ_8K);
        write_unlock(&em_tree->lock);
 
        if (ret != 0) {
  * true would mess up the start/end calculations and subsequent splits would be
  * incorrect.
  */
-static int test_case_7(struct btrfs_fs_info *fs_info)
+static int test_case_7(struct btrfs_fs_info *fs_info, struct btrfs_inode *inode)
 {
-       struct extent_map_tree *em_tree;
+       struct extent_map_tree *em_tree = &inode->extent_tree;
        struct extent_map *em;
-       struct inode *inode;
        int ret;
+       int ret2;
 
        test_msg("Running btrfs_drop_extent_cache with pinned");
 
-       inode = btrfs_new_test_inode();
-       if (!inode) {
-               test_std_err(TEST_ALLOC_INODE);
-               return -ENOMEM;
-       }
-
-       em_tree = &BTRFS_I(inode)->extent_tree;
-
        em = alloc_extent_map();
        if (!em) {
                test_std_err(TEST_ALLOC_EXTENT_MAP);
-               ret = -ENOMEM;
-               goto out;
+               return -ENOMEM;
        }
 
        /* [0, 16K), pinned */
        em->block_len = SZ_4K;
        em->flags |= EXTENT_FLAG_PINNED;
        write_lock(&em_tree->lock);
-       ret = btrfs_add_extent_mapping(fs_info, em_tree, &em, em->start, em->len);
+       ret = btrfs_add_extent_mapping(inode, &em, em->start, em->len);
        write_unlock(&em_tree->lock);
        if (ret < 0) {
                test_err("couldn't add extent map");
        em->block_start = SZ_32K;
        em->block_len = SZ_16K;
        write_lock(&em_tree->lock);
-       ret = btrfs_add_extent_mapping(fs_info, em_tree, &em, em->start, em->len);
+       ret = btrfs_add_extent_mapping(inode, &em, em->start, em->len);
        write_unlock(&em_tree->lock);
        if (ret < 0) {
                test_err("couldn't add extent map");
         * Drop [0, 36K) This should skip the [0, 4K) extent and then split the
         * [32K, 48K) extent.
         */
-       btrfs_drop_extent_map_range(BTRFS_I(inode), 0, (36 * SZ_1K) - 1, true);
+       btrfs_drop_extent_map_range(inode, 0, (36 * SZ_1K) - 1, true);
 
        /* Make sure our extent maps look sane. */
        ret = -EINVAL;
        ret = 0;
 out:
        free_extent_map(em);
-       iput(inode);
+       /* Unpin our extent to prevent warning when removing it below. */
+       ret2 = unpin_extent_cache(inode, 0, SZ_16K, 0);
+       if (ret == 0)
+               ret = ret2;
+       free_extent_map_tree(em_tree);
        return ret;
 }
 
 int btrfs_test_extent_map(void)
 {
        struct btrfs_fs_info *fs_info = NULL;
-       struct extent_map_tree *em_tree;
+       struct inode *inode;
+       struct btrfs_root *root = NULL;
        int ret = 0, i;
        struct rmap_test_vector rmap_tests[] = {
                {
                return -ENOMEM;
        }
 
-       em_tree = kzalloc(sizeof(*em_tree), GFP_KERNEL);
-       if (!em_tree) {
+       inode = btrfs_new_test_inode();
+       if (!inode) {
+               test_std_err(TEST_ALLOC_INODE);
                ret = -ENOMEM;
                goto out;
        }
 
-       extent_map_tree_init(em_tree);
+       root = btrfs_alloc_dummy_root(fs_info);
+       if (IS_ERR(root)) {
+               test_std_err(TEST_ALLOC_ROOT);
+               ret = PTR_ERR(root);
+               root = NULL;
+               goto out;
+       }
 
-       ret = test_case_1(fs_info, em_tree);
+       BTRFS_I(inode)->root = root;
+
+       ret = test_case_1(fs_info, BTRFS_I(inode));
        if (ret)
                goto out;
-       ret = test_case_2(fs_info, em_tree);
+       ret = test_case_2(fs_info, BTRFS_I(inode));
        if (ret)
                goto out;
-       ret = test_case_3(fs_info, em_tree);
+       ret = test_case_3(fs_info, BTRFS_I(inode));
        if (ret)
                goto out;
-       ret = test_case_4(fs_info, em_tree);
+       ret = test_case_4(fs_info, BTRFS_I(inode));
        if (ret)
                goto out;
-       ret = test_case_5(fs_info);
+       ret = test_case_5(fs_info, BTRFS_I(inode));
        if (ret)
                goto out;
-       ret = test_case_6(fs_info, em_tree);
+       ret = test_case_6(fs_info, BTRFS_I(inode));
        if (ret)
                goto out;
-       ret = test_case_7(fs_info);
+       ret = test_case_7(fs_info, BTRFS_I(inode));
        if (ret)
                goto out;
 
        }
 
 out:
-       kfree(em_tree);
+       iput(inode);
+       btrfs_free_dummy_root(root);
        btrfs_free_dummy_fs_info(fs_info);
 
        return ret;