f3e374efbf
Now that we have the logged operations btree, we can make finsert/fcollapse atomic w.r.t. unclean shutdown as well. This adds bch_logged_op_finsert to represent the state of an finsert or fcollapse, which is a bit more complicated than truncate since we need to track our position in the "shift extents" operation. Signed-off-by: Kent Overstreet <kent.overstreet@linux.dev>
35 lines
1.2 KiB
C
35 lines
1.2 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#ifndef _BCACHEFS_IO_MISC_H
|
|
#define _BCACHEFS_IO_MISC_H
|
|
|
|
int bch2_extent_fallocate(struct btree_trans *, subvol_inum, struct btree_iter *,
|
|
unsigned, struct bch_io_opts, s64 *,
|
|
struct write_point_specifier);
|
|
int bch2_fpunch_at(struct btree_trans *, struct btree_iter *,
|
|
subvol_inum, u64, s64 *);
|
|
int bch2_fpunch(struct bch_fs *c, subvol_inum, u64, u64, s64 *);
|
|
|
|
void bch2_logged_op_truncate_to_text(struct printbuf *, struct bch_fs *, struct bkey_s_c);
|
|
|
|
#define bch2_bkey_ops_logged_op_truncate ((struct bkey_ops) { \
|
|
.val_to_text = bch2_logged_op_truncate_to_text, \
|
|
.min_val_size = 24, \
|
|
})
|
|
|
|
int bch2_resume_logged_op_truncate(struct btree_trans *, struct bkey_i *);
|
|
|
|
int bch2_truncate(struct bch_fs *, subvol_inum, u64, u64 *);
|
|
|
|
void bch2_logged_op_finsert_to_text(struct printbuf *, struct bch_fs *, struct bkey_s_c);
|
|
|
|
#define bch2_bkey_ops_logged_op_finsert ((struct bkey_ops) { \
|
|
.val_to_text = bch2_logged_op_finsert_to_text, \
|
|
.min_val_size = 24, \
|
|
})
|
|
|
|
int bch2_resume_logged_op_finsert(struct btree_trans *, struct bkey_i *);
|
|
|
|
int bch2_fcollapse_finsert(struct bch_fs *, subvol_inum, u64, u64, bool, s64 *);
|
|
|
|
#endif /* _BCACHEFS_IO_MISC_H */
|