Lines Matching full:insert
85 * If this extent tree is supported by an extent map, insert
592 * Tree depth may change during truncate, or insert. If we're in ocfs2_reinit_path()
661 * Insert an extent block at given index.
673 * safely removed if we ever need to insert extent block in ocfs2_path_insert_eb()
2031 * - When our insert into the right path leaf is at the leftmost edge
2358 * - In the case that the rotation requires a post-insert update,
2433 "Owner %llu: error during insert of %u " in ocfs2_rotate_tree_right()
2453 * before the record insert is that an error in ocfs2_rotate_tree_right()
2491 * instead of a real insert, then we have to in ocfs2_rotate_tree_right()
3700 * Since the leftright insert always covers the entire in ocfs2_try_to_merge_extent()
3701 * extent, this call will delete the insert record in ocfs2_try_to_merge_extent()
3863 struct ocfs2_insert_type *insert) in ocfs2_insert_at_leaf() argument
3865 int i = insert->ins_contig_index; in ocfs2_insert_at_leaf()
3871 if (insert->ins_split != SPLIT_NONE) { in ocfs2_insert_at_leaf()
3876 insert->ins_split, rec, in ocfs2_insert_at_leaf()
3882 * Contiguous insert - either left or right. in ocfs2_insert_at_leaf()
3884 if (insert->ins_contig != CONTIG_NONE) { in ocfs2_insert_at_leaf()
3886 if (insert->ins_contig == CONTIG_LEFT) { in ocfs2_insert_at_leaf()
3896 * Handle insert into an empty leaf. in ocfs2_insert_at_leaf()
3907 * Appending insert. in ocfs2_insert_at_leaf()
3909 if (insert->ins_appending == APPEND_TAIL) { in ocfs2_insert_at_leaf()
3920 "insert.cpos %u, insert.clusters %u\n", in ocfs2_insert_at_leaf()
4005 * If our appending insert is at the leftmost edge of a leaf, in ocfs2_append_rec_to_path()
4098 * do the later insert there. in ocfs2_split_record()
4102 * it back for a post-insert update. in ocfs2_split_record()
4110 * can just do the insert there. in ocfs2_split_record()
4117 * leaf. The insert will be into the in ocfs2_split_record()
4134 * Left path is easy - we can just allow the insert to in ocfs2_split_record()
4153 * right_path is the path we want to do the actual insert
4155 * portion of the tree after an edge insert.
4162 struct ocfs2_insert_type *insert) in ocfs2_insert_path() argument
4197 if (insert->ins_split != SPLIT_NONE) { in ocfs2_insert_path()
4204 insert_rec, insert->ins_split); in ocfs2_insert_path()
4208 * have a guarantee that the later edge insert will in ocfs2_insert_path()
4216 insert); in ocfs2_insert_path()
4223 * up portions of the tree after the insert. in ocfs2_insert_path()
4295 * left_path to account for an edge insert. in ocfs2_do_insert_extent()
4297 * XXX: When modifying this code, keep in mind that an insert in ocfs2_do_insert_extent()
4479 struct ocfs2_insert_type *insert, in ocfs2_figure_contig_type() argument
4492 insert->ins_contig_index = i; in ocfs2_figure_contig_type()
4496 insert->ins_contig = contig_type; in ocfs2_figure_contig_type()
4498 if (insert->ins_contig != CONTIG_NONE) { in ocfs2_figure_contig_type()
4500 &el->l_recs[insert->ins_contig_index]; in ocfs2_figure_contig_type()
4510 insert->ins_contig = CONTIG_NONE; in ocfs2_figure_contig_type()
4518 * insert at the tail of the rightmost leaf.
4524 static void ocfs2_figure_appending_type(struct ocfs2_insert_type *insert, in ocfs2_figure_appending_type() argument
4532 insert->ins_appending = APPEND_NONE; in ocfs2_figure_appending_type()
4555 insert->ins_appending = APPEND_TAIL; in ocfs2_figure_appending_type()
4559 * Helper function called at the beginning of an insert.
4565 * - Whether the insert is an appending one.
4575 struct ocfs2_insert_type *insert) in ocfs2_figure_insert_type() argument
4583 insert->ins_split = SPLIT_NONE; in ocfs2_figure_insert_type()
4586 insert->ins_tree_depth = le16_to_cpu(el->l_tree_depth); in ocfs2_figure_insert_type()
4607 * Unless we have a contiguous insert, we'll need to know if in ocfs2_figure_insert_type()
4617 if (!insert->ins_tree_depth) { in ocfs2_figure_insert_type()
4618 ocfs2_figure_contig_type(et, insert, el, insert_rec); in ocfs2_figure_insert_type()
4619 ocfs2_figure_appending_type(insert, el, insert_rec); in ocfs2_figure_insert_type()
4652 ocfs2_figure_contig_type(et, insert, el, insert_rec); in ocfs2_figure_insert_type()
4655 * The insert code isn't quite ready to deal with all cases of in ocfs2_figure_insert_type()
4656 * left contiguousness. Specifically, if it's an insert into in ocfs2_figure_insert_type()
4663 if (insert->ins_contig == CONTIG_LEFT && in ocfs2_figure_insert_type()
4664 insert->ins_contig_index == 0) in ocfs2_figure_insert_type()
4665 insert->ins_contig = CONTIG_NONE; in ocfs2_figure_insert_type()
4677 * tree path. This might be an appending insert. There are in ocfs2_figure_insert_type()
4683 ocfs2_figure_appending_type(insert, el, insert_rec); in ocfs2_figure_insert_type()
4697 * Insert an extent into a btree.
4712 struct ocfs2_insert_type insert = {0, }; in ocfs2_insert_extent() local
4731 &free_records, &insert); in ocfs2_insert_extent()
4737 trace_ocfs2_insert_extent(insert.ins_appending, insert.ins_contig, in ocfs2_insert_extent()
4738 insert.ins_contig_index, free_records, in ocfs2_insert_extent()
4739 insert.ins_tree_depth); in ocfs2_insert_extent()
4741 if (insert.ins_contig == CONTIG_NONE && free_records == 0) { in ocfs2_insert_extent()
4743 &insert.ins_tree_depth, &last_eb_bh, in ocfs2_insert_extent()
4752 status = ocfs2_do_insert_extent(handle, et, &rec, &insert); in ocfs2_insert_extent()
4917 struct ocfs2_insert_type insert; in ocfs2_split_and_insert() local
4946 memset(&insert, 0, sizeof(struct ocfs2_insert_type)); in ocfs2_split_and_insert()
4947 insert.ins_appending = APPEND_NONE; in ocfs2_split_and_insert()
4948 insert.ins_contig = CONTIG_NONE; in ocfs2_split_and_insert()
4949 insert.ins_tree_depth = depth; in ocfs2_split_and_insert()
4957 insert.ins_split = SPLIT_LEFT; in ocfs2_split_and_insert()
4959 insert.ins_split = SPLIT_RIGHT; in ocfs2_split_and_insert()
4965 insert.ins_split = SPLIT_RIGHT; in ocfs2_split_and_insert()
4976 ret = ocfs2_do_insert_extent(handle, et, &split_rec, &insert); in ocfs2_split_and_insert()
5258 * XXX: This should be fixed up so that we just re-insert the in ocfs2_mark_extent_written()
5284 struct ocfs2_insert_type insert; in ocfs2_split_tree() local
5327 memset(&insert, 0, sizeof(struct ocfs2_insert_type)); in ocfs2_split_tree()
5328 insert.ins_appending = APPEND_NONE; in ocfs2_split_tree()
5329 insert.ins_contig = CONTIG_NONE; in ocfs2_split_tree()
5330 insert.ins_split = SPLIT_RIGHT; in ocfs2_split_tree()
5331 insert.ins_tree_depth = depth; in ocfs2_split_tree()
5333 ret = ocfs2_do_insert_extent(handle, et, &split_rec, &insert); in ocfs2_split_tree()
7117 * Save two copies, one for insert, and one that can in ocfs2_convert_inline_data_to_extents()