* @trans:     transaction object
  * @ca:                device to allocate from
  * @watermark: how important is this allocation?
+ * @data_type: BCH_DATA_journal, btree, user...
  * @cl:                if not NULL, closure to be used to wait if buckets not available
  * @usage:     for secondarily also returning the current device usage
  *
 static struct open_bucket *bch2_bucket_alloc_trans(struct btree_trans *trans,
                                      struct bch_dev *ca,
                                      enum bch_watermark watermark,
+                                     enum bch_data_type data_type,
                                      struct closure *cl,
                                      struct bch_dev_usage *usage)
 {
        if (!ob)
                ob = ERR_PTR(-BCH_ERR_no_buckets_found);
 
+       if (!IS_ERR(ob))
+               ob->data_type = data_type;
+
        if (!IS_ERR(ob))
                trace_and_count(c, bucket_alloc, ca,
                                bch2_watermarks[watermark],
 
 struct open_bucket *bch2_bucket_alloc(struct bch_fs *c, struct bch_dev *ca,
                                      enum bch_watermark watermark,
+                                     enum bch_data_type data_type,
                                      struct closure *cl)
 {
        struct bch_dev_usage usage;
 
        bch2_trans_do(c, NULL, NULL, 0,
                      PTR_ERR_OR_ZERO(ob = bch2_bucket_alloc_trans(trans, ca, watermark,
-                                                       cl, &usage)));
+                                                       data_type, cl, &usage)));
        return ob;
 }
 
                        continue;
                }
 
-               ob = bch2_bucket_alloc_trans(trans, ca, watermark, cl, &usage);
+               ob = bch2_bucket_alloc_trans(trans, ca, watermark, data_type, cl, &usage);
                if (!IS_ERR(ob))
                        bch2_dev_stripe_increment_inlined(ca, stripe, &usage);
                percpu_ref_put(&ca->ref);
                        continue;
                }
 
-               ob->data_type = data_type;
-
                if (add_new_bucket(c, ptrs, devs_may_alloc,
                                   nr_replicas, nr_effective,
                                   have_cache, flags, ob)) {