Lines Matching refs:bbl
55 struct backed_block *backed_block_iter_new(struct backed_block_list *bbl) in backed_block_iter_new() argument
57 return bbl->data_blocks; in backed_block_iter_new()
130 void backed_block_list_destroy(struct backed_block_list *bbl) in backed_block_list_destroy() argument
132 if (bbl->data_blocks) { in backed_block_list_destroy()
133 struct backed_block *bb = bbl->data_blocks; in backed_block_list_destroy()
141 free(bbl); in backed_block_list_destroy()
191 static int merge_bb(struct backed_block_list *bbl, in merge_bb() argument
209 block_len = a->len / bbl->block_size; /* rounds down */ in merge_bb()
248 static int queue_bb(struct backed_block_list *bbl, struct backed_block *new_bb) in queue_bb() argument
252 if (bbl->data_blocks == NULL) { in queue_bb()
253 bbl->data_blocks = new_bb; in queue_bb()
257 if (bbl->data_blocks->block > new_bb->block) { in queue_bb()
258 new_bb->next = bbl->data_blocks; in queue_bb()
259 bbl->data_blocks = new_bb; in queue_bb()
266 if (bbl->last_used && new_bb->block > bbl->last_used->block) in queue_bb()
267 bb = bbl->last_used; in queue_bb()
269 bb = bbl->data_blocks; in queue_bb()
270 bbl->last_used = new_bb; in queue_bb()
282 merge_bb(bbl, new_bb, new_bb->next); in queue_bb()
283 if (!merge_bb(bbl, bb, new_bb)) { in queue_bb()
285 bbl->last_used = bb; in queue_bb()
292 int backed_block_add_fill(struct backed_block_list *bbl, unsigned int fill_val, in backed_block_add_fill() argument
306 return queue_bb(bbl, bb); in backed_block_add_fill()
310 int backed_block_add_data(struct backed_block_list *bbl, void *data, in backed_block_add_data() argument
324 return queue_bb(bbl, bb); in backed_block_add_data()
328 int backed_block_add_file(struct backed_block_list *bbl, const char *filename, in backed_block_add_file() argument
343 return queue_bb(bbl, bb); in backed_block_add_file()
347 int backed_block_add_fd(struct backed_block_list *bbl, int fd, int64_t offset, in backed_block_add_fd() argument
362 return queue_bb(bbl, bb); in backed_block_add_fd()
365 int backed_block_split(struct backed_block_list *bbl, struct backed_block *bb, in backed_block_split() argument
370 max_len = ALIGN_DOWN(max_len, bbl->block_size); in backed_block_split()
384 new_bb->block = bb->block + max_len / bbl->block_size; in backed_block_split()