goto err;
        }
 
-       bch2_trans_update(trans, iter, &new->k_i, 0);
+       bch2_trans_update(trans, BTREE_INSERT_ENTRY(iter, &new->k_i));
        *new_acl = acl;
        acl = NULL;
 err:
 
 
 /* new transactional interface: */
 
-void bch2_trans_update(struct btree_trans *, struct btree_iter *,
-                            struct bkey_i *, unsigned);
+static inline void
+bch2_trans_update(struct btree_trans *trans,
+                 struct btree_insert_entry entry)
+{
+       BUG_ON(trans->nr_updates >= ARRAY_SIZE(trans->updates));
+
+       trans->updates[trans->nr_updates++] = entry;
+}
+
 int bch2_trans_commit(struct btree_trans *,
                      struct disk_reservation *,
                      struct extent_insert_hook *,
 
        goto out;
 }
 
-void bch2_trans_update(struct btree_trans *trans,
-                      struct btree_iter *iter,
-                      struct bkey_i *k,
-                      unsigned extra_journal_res)
-{
-       struct btree_insert_entry *i;
-
-       BUG_ON(trans->nr_updates >= ARRAY_SIZE(trans->updates));
-
-       i = &trans->updates[trans->nr_updates++];
-
-       *i = (struct btree_insert_entry) {
-               .iter   = iter,
-               .k              = k,
-               .extra_res      = extra_journal_res,
-       };
-
-       btree_insert_entry_checks(trans->c, i);
-}
-
 int bch2_trans_commit(struct btree_trans *trans,
                      struct disk_reservation *disk_res,
                      struct extent_insert_hook *hook,
 
                                 * new_dst at the src position:
                                 */
                                new_dst->k.p = src_iter->pos;
-                               bch2_trans_update(trans, src_iter, &new_dst->k_i, 0);
+                               bch2_trans_update(trans,
+                                       BTREE_INSERT_ENTRY(src_iter,
+                                                          &new_dst->k_i));
                                return 0;
                        } else {
                                /* If we're overwriting, we can't insert new_dst
                }
        }
 
-       bch2_trans_update(trans, src_iter, &new_src->k_i, 0);
-       bch2_trans_update(trans, dst_iter, &new_dst->k_i, 0);
+       bch2_trans_update(trans, BTREE_INSERT_ENTRY(src_iter, &new_src->k_i));
+       bch2_trans_update(trans, BTREE_INSERT_ENTRY(dst_iter, &new_dst->k_i));
        return 0;
 }
 
 
                return PTR_ERR(inode_p);
 
        bch2_inode_pack(inode_p, inode_u);
-       bch2_trans_update(trans, iter, &inode_p->inode.k_i, 0);
+       bch2_trans_update(trans, BTREE_INSERT_ENTRY(iter, &inode_p->inode.k_i));
        return 0;
 }
 
 
                        inode_u->bi_generation  = bkey_generation(k);
 
                        bch2_inode_pack(inode_p, inode_u);
-                       bch2_trans_update(trans, iter, &inode_p->inode.k_i, 0);
+                       bch2_trans_update(trans,
+                               BTREE_INSERT_ENTRY(iter, &inode_p->inode.k_i));
                        return 0;
                }
        }
 
                return -ENOENT;
 
        insert->k.p = slot->pos;
-       bch2_trans_update(trans, slot, insert, 0);
+       bch2_trans_update(trans, BTREE_INSERT_ENTRY(slot, insert));
        return 0;
 found:
        if (flags & BCH_HASH_SET_MUST_CREATE)
                return -EEXIST;
 
        insert->k.p = iter->pos;
-       bch2_trans_update(trans, iter, insert, 0);
+       bch2_trans_update(trans, BTREE_INSERT_ENTRY(iter, insert));
        return 0;
 }
 
        delete->k.p = iter->pos;
        delete->k.type = ret ? desc.whiteout_type : KEY_TYPE_DELETED;
 
-       bch2_trans_update(trans, iter, delete, 0);
+       bch2_trans_update(trans, BTREE_INSERT_ENTRY(iter, delete));
        return 0;
 }