From: Kent Overstreet Date: Sun, 17 Dec 2023 08:05:30 +0000 (-0500) Subject: bcachefs: bch2_dirent_lookup() -> lockrestart_do() X-Git-Tag: v6.8-rc1~137^2~94 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=c8ef2dc2fc87369a949c3e379ebfe50fe540fa36;p=users%2Fhch%2Fmisc.git bcachefs: bch2_dirent_lookup() -> lockrestart_do() Signed-off-by: Kent Overstreet --- diff --git a/fs/bcachefs/dirent.c b/fs/bcachefs/dirent.c index 78ce9634d05c..51fe04f45690 100644 --- a/fs/bcachefs/dirent.c +++ b/fs/bcachefs/dirent.c @@ -471,17 +471,11 @@ u64 bch2_dirent_lookup(struct bch_fs *c, subvol_inum dir, const struct qstr *name, subvol_inum *inum) { struct btree_trans *trans = bch2_trans_get(c); - struct btree_iter iter; - int ret; -retry: - bch2_trans_begin(trans); + struct btree_iter iter = { NULL }; - ret = __bch2_dirent_lookup_trans(trans, &iter, dir, hash_info, - name, inum, 0); - if (bch2_err_matches(ret, BCH_ERR_transaction_restart)) - goto retry; - if (!ret) - bch2_trans_iter_exit(trans, &iter); + int ret = lockrestart_do(trans, + __bch2_dirent_lookup_trans(trans, &iter, dir, hash_info, name, inum, 0)); + bch2_trans_iter_exit(trans, &iter); bch2_trans_put(trans); return ret; }