]> git.sesse.net Git - bcachefs-tools-debian/commitdiff
Update bcachefs sources to dab31ca168 bcachefs: Add some logging for btree node rewri...
authorKent Overstreet <kent.overstreet@linux.dev>
Fri, 10 Feb 2023 20:49:12 +0000 (15:49 -0500)
committerKent Overstreet <kent.overstreet@linux.dev>
Fri, 10 Feb 2023 20:49:12 +0000 (15:49 -0500)
.bcachefs_revision
libbcachefs/btree_io.c
libbcachefs/btree_update_interior.c
libbcachefs/btree_update_leaf.c

index 3ca1265b4cf436de5e94c02a787f5968be51d9e1..b5ff7667b0402a79e7d8b10f8f1727bc4b38a62b 100644 (file)
@@ -1 +1 @@
-ea93c26e98081d8e1a5fc138e6334b3631983d77
+dab31ca168df1c7a492a0a2a626ba6cd983b2a7a
index 0145746c277b948b82de7b34513576dcc450b80e..19565b94cdefcdbf094baa8f2abcfa4274c19156 100644 (file)
@@ -1246,8 +1246,18 @@ start:
        bio_put(&rb->bio);
        printbuf_exit(&buf);
 
-       if (saw_error && !btree_node_read_error(b))
+       if (!btree_node_read_error(b) &&
+           (saw_error ||
+            btree_node_need_rewrite(b))) {
+               struct printbuf buf = PRINTBUF;
+
+               bch2_bpos_to_text(&buf, b->key.k.p);
+               bch_info(c, "%s: rewriting btree node at btree=%s level=%u %s due to error",
+                        __func__, bch2_btree_ids[b->c.btree_id], b->c.level, buf.buf);
+               printbuf_exit(&buf);
+
                bch2_btree_node_rewrite_async(c, b);
+       }
 
        clear_btree_node_read_in_flight(b);
        wake_up_bit(&b->flags, BTREE_NODE_read_in_flight);
index 09aeee06a137a4d1bc28e70af9bc70386dde405b..a40a0f5ca4bdb5d632eb1841fc3d17016042f685 100644 (file)
@@ -161,6 +161,7 @@ static void __btree_node_free(struct bch_fs *c, struct btree *b)
 {
        trace_and_count(c, btree_node_free, c, b);
 
+       BUG_ON(btree_node_write_blocked(b));
        BUG_ON(btree_node_dirty(b));
        BUG_ON(btree_node_need_write(b));
        BUG_ON(b == btree_node_root(c, b));
@@ -806,6 +807,7 @@ static void btree_update_updated_node(struct btree_update *as, struct btree *b)
 
        BUG_ON(as->mode != BTREE_INTERIOR_NO_UPDATE);
        BUG_ON(!btree_node_dirty(b));
+       BUG_ON(!b->c.level);
 
        as->mode        = BTREE_INTERIOR_UPDATING_NODE;
        as->b           = b;
@@ -975,6 +977,7 @@ static void bch2_btree_interior_update_will_free_node(struct btree_update *as,
 
        clear_btree_node_dirty_acct(c, b);
        clear_btree_node_need_write(b);
+       clear_btree_node_write_blocked(b);
 
        /*
         * Does this node have unwritten data that has a pin on the journal?
@@ -2003,6 +2006,7 @@ struct async_btree_rewrite {
 static int async_btree_node_rewrite_trans(struct btree_trans *trans,
                                          struct async_btree_rewrite *a)
 {
+       struct bch_fs *c = trans->c;
        struct btree_iter iter;
        struct btree *b;
        int ret;
@@ -2014,8 +2018,18 @@ static int async_btree_node_rewrite_trans(struct btree_trans *trans,
        if (ret)
                goto out;
 
-       if (!b || b->data->keys.seq != a->seq)
+       if (!b || b->data->keys.seq != a->seq) {
+               struct printbuf buf = PRINTBUF;
+
+               if (b)
+                       bch2_bkey_val_to_text(&buf, c, bkey_i_to_s_c(&b->key));
+               else
+                       prt_str(&buf, "(null");
+               bch_info(c, "%s: node to rewrite not found:, searching for seq %llu, got\n%s",
+                        __func__, a->seq, buf.buf);
+               printbuf_exit(&buf);
                goto out;
+       }
 
        ret = bch2_btree_node_rewrite(trans, &iter, b, 0);
 out:
@@ -2029,9 +2043,12 @@ void async_btree_node_rewrite_work(struct work_struct *work)
        struct async_btree_rewrite *a =
                container_of(work, struct async_btree_rewrite, work);
        struct bch_fs *c = a->c;
+       int ret;
 
-       bch2_trans_do(c, NULL, NULL, 0,
+       ret = bch2_trans_do(c, NULL, NULL, 0,
                      async_btree_node_rewrite_trans(&trans, a));
+       if (ret)
+               bch_err(c, "%s: error %s", __func__, bch2_err_str(ret));
        bch2_write_ref_put(c, BCH_WRITE_REF_node_rewrite);
        kfree(a);
 }
@@ -2040,12 +2057,15 @@ void bch2_btree_node_rewrite_async(struct bch_fs *c, struct btree *b)
 {
        struct async_btree_rewrite *a;
 
-       if (!bch2_write_ref_tryget(c, BCH_WRITE_REF_node_rewrite))
+       if (!bch2_write_ref_tryget(c, BCH_WRITE_REF_node_rewrite)) {
+               bch_err(c, "%s: error getting c->writes ref", __func__);
                return;
+       }
 
        a = kmalloc(sizeof(*a), GFP_NOFS);
        if (!a) {
                bch2_write_ref_put(c, BCH_WRITE_REF_node_rewrite);
+               bch_err(c, "%s: error allocating memory", __func__);
                return;
        }
 
index f01a2e90a4ec361eccb9a7a8bf386e9b885020e3..6cbc0e5e1fe819a703625fc7563823ee88201c6c 100644 (file)
@@ -307,7 +307,7 @@ static inline void btree_insert_entry_checks(struct btree_trans *trans,
 }
 
 static noinline int
-bch2_trans_journal_preres_get_cold(struct btree_trans *trans, unsigned u64s,
+bch2_trans_journal_preres_get_cold(struct btree_trans *trans, unsigned flags,
                                   unsigned long trace_ip)
 {
        struct bch_fs *c = trans->c;
@@ -316,7 +316,9 @@ bch2_trans_journal_preres_get_cold(struct btree_trans *trans, unsigned u64s,
        bch2_trans_unlock(trans);
 
        ret = bch2_journal_preres_get(&c->journal,
-                       &trans->journal_preres, u64s, 0);
+                       &trans->journal_preres,
+                       trans->journal_preres_u64s,
+                       (flags & JOURNAL_WATERMARK_MASK));
        if (ret)
                return ret;
 
@@ -857,8 +859,7 @@ static inline int do_bch2_trans_commit(struct btree_trans *trans, unsigned flags
                        &trans->journal_preres, trans->journal_preres_u64s,
                        (flags & JOURNAL_WATERMARK_MASK)|JOURNAL_RES_GET_NONBLOCK);
        if (unlikely(ret == -BCH_ERR_journal_preres_get_blocked))
-               ret = bch2_trans_journal_preres_get_cold(trans,
-                                               trans->journal_preres_u64s, trace_ip);
+               ret = bch2_trans_journal_preres_get_cold(trans, flags, trace_ip);
        if (unlikely(ret))
                return ret;
 
@@ -937,7 +938,9 @@ int bch2_trans_commit_error(struct btree_trans *trans, unsigned flags,
                        break;
                }
 
-               ret = bch2_trans_journal_res_get(trans, JOURNAL_RES_GET_CHECK);
+               ret = bch2_trans_journal_res_get(trans,
+                                       (flags & JOURNAL_WATERMARK_MASK)|
+                                       JOURNAL_RES_GET_CHECK);
                if (ret)
                        break;