mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-17 12:36:51 +07:00
dm persistent data: eliminate unnecessary return values
dm_bm_unlock and dm_tm_unlock return an integer value but the returned value is always 0. The calling code sometimes checks the return value and sometimes doesn't. Eliminate these unnecessary return values and also the checks for them. Signed-off-by: Mikulas Patocka <mpatocka@redhat.com> Signed-off-by: Mike Snitzer <snitzer@redhat.com>
This commit is contained in:
parent
dbba42d8a9
commit
4c7da06f5a
@ -260,7 +260,9 @@ static int __superblock_all_zeroes(struct dm_block_manager *bm, bool *result)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return dm_bm_unlock(b);
|
dm_bm_unlock(b);
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void __setup_mapping_info(struct dm_cache_metadata *cmd)
|
static void __setup_mapping_info(struct dm_cache_metadata *cmd)
|
||||||
@ -465,7 +467,9 @@ static int __open_metadata(struct dm_cache_metadata *cmd)
|
|||||||
dm_disk_bitset_init(cmd->tm, &cmd->discard_info);
|
dm_disk_bitset_init(cmd->tm, &cmd->discard_info);
|
||||||
sb_flags = le32_to_cpu(disk_super->flags);
|
sb_flags = le32_to_cpu(disk_super->flags);
|
||||||
cmd->clean_when_opened = test_bit(CLEAN_SHUTDOWN, &sb_flags);
|
cmd->clean_when_opened = test_bit(CLEAN_SHUTDOWN, &sb_flags);
|
||||||
return dm_bm_unlock(sblock);
|
dm_bm_unlock(sblock);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
|
||||||
bad:
|
bad:
|
||||||
dm_bm_unlock(sblock);
|
dm_bm_unlock(sblock);
|
||||||
|
@ -343,7 +343,9 @@ static int superblock_all_zeroes(struct dm_block_manager *bm, bool *result)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return dm_bm_unlock(b);
|
dm_bm_unlock(b);
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*----------------------------------------------------------------*/
|
/*----------------------------------------------------------------*/
|
||||||
@ -582,7 +584,9 @@ static int open_metadata(struct era_metadata *md)
|
|||||||
md->metadata_snap = le64_to_cpu(disk->metadata_snap);
|
md->metadata_snap = le64_to_cpu(disk->metadata_snap);
|
||||||
md->archived_writesets = true;
|
md->archived_writesets = true;
|
||||||
|
|
||||||
return dm_bm_unlock(sblock);
|
dm_bm_unlock(sblock);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
|
||||||
bad:
|
bad:
|
||||||
dm_bm_unlock(sblock);
|
dm_bm_unlock(sblock);
|
||||||
@ -1046,12 +1050,7 @@ static int metadata_take_snap(struct era_metadata *md)
|
|||||||
|
|
||||||
md->metadata_snap = dm_block_location(clone);
|
md->metadata_snap = dm_block_location(clone);
|
||||||
|
|
||||||
r = dm_tm_unlock(md->tm, clone);
|
dm_tm_unlock(md->tm, clone);
|
||||||
if (r) {
|
|
||||||
DMERR("%s: couldn't unlock clone", __func__);
|
|
||||||
md->metadata_snap = SUPERBLOCK_LOCATION;
|
|
||||||
return r;
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -396,7 +396,9 @@ static int __superblock_all_zeroes(struct dm_block_manager *bm, int *result)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return dm_bm_unlock(b);
|
dm_bm_unlock(b);
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void __setup_btree_details(struct dm_pool_metadata *pmd)
|
static void __setup_btree_details(struct dm_pool_metadata *pmd)
|
||||||
@ -650,7 +652,9 @@ static int __open_metadata(struct dm_pool_metadata *pmd)
|
|||||||
}
|
}
|
||||||
|
|
||||||
__setup_btree_details(pmd);
|
__setup_btree_details(pmd);
|
||||||
return dm_bm_unlock(sblock);
|
dm_bm_unlock(sblock);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
|
||||||
bad_cleanup_data_sm:
|
bad_cleanup_data_sm:
|
||||||
dm_sm_destroy(pmd->data_sm);
|
dm_sm_destroy(pmd->data_sm);
|
||||||
@ -1297,7 +1301,9 @@ static int __release_metadata_snap(struct dm_pool_metadata *pmd)
|
|||||||
dm_btree_del(&pmd->details_info, le64_to_cpu(disk_super->device_details_root));
|
dm_btree_del(&pmd->details_info, le64_to_cpu(disk_super->device_details_root));
|
||||||
dm_sm_dec_block(pmd->metadata_sm, held_root);
|
dm_sm_dec_block(pmd->metadata_sm, held_root);
|
||||||
|
|
||||||
return dm_tm_unlock(pmd->tm, copy);
|
dm_tm_unlock(pmd->tm, copy);
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int dm_pool_release_metadata_snap(struct dm_pool_metadata *pmd)
|
int dm_pool_release_metadata_snap(struct dm_pool_metadata *pmd)
|
||||||
@ -1327,7 +1333,9 @@ static int __get_metadata_snap(struct dm_pool_metadata *pmd,
|
|||||||
disk_super = dm_block_data(sblock);
|
disk_super = dm_block_data(sblock);
|
||||||
*result = le64_to_cpu(disk_super->held_root);
|
*result = le64_to_cpu(disk_super->held_root);
|
||||||
|
|
||||||
return dm_bm_unlock(sblock);
|
dm_bm_unlock(sblock);
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int dm_pool_get_metadata_snap(struct dm_pool_metadata *pmd,
|
int dm_pool_get_metadata_snap(struct dm_pool_metadata *pmd,
|
||||||
|
@ -233,9 +233,9 @@ static int get_ablock(struct dm_array_info *info, dm_block_t b,
|
|||||||
/*
|
/*
|
||||||
* Unlocks an array block.
|
* Unlocks an array block.
|
||||||
*/
|
*/
|
||||||
static int unlock_ablock(struct dm_array_info *info, struct dm_block *block)
|
static void unlock_ablock(struct dm_array_info *info, struct dm_block *block)
|
||||||
{
|
{
|
||||||
return dm_tm_unlock(info->btree_info.tm, block);
|
dm_tm_unlock(info->btree_info.tm, block);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*----------------------------------------------------------------*/
|
/*----------------------------------------------------------------*/
|
||||||
|
@ -578,7 +578,7 @@ int dm_bm_write_lock_zero(struct dm_block_manager *bm,
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(dm_bm_write_lock_zero);
|
EXPORT_SYMBOL_GPL(dm_bm_write_lock_zero);
|
||||||
|
|
||||||
int dm_bm_unlock(struct dm_block *b)
|
void dm_bm_unlock(struct dm_block *b)
|
||||||
{
|
{
|
||||||
struct buffer_aux *aux;
|
struct buffer_aux *aux;
|
||||||
aux = dm_bufio_get_aux_data(to_buffer(b));
|
aux = dm_bufio_get_aux_data(to_buffer(b));
|
||||||
@ -590,8 +590,6 @@ int dm_bm_unlock(struct dm_block *b)
|
|||||||
bl_up_read(&aux->lock);
|
bl_up_read(&aux->lock);
|
||||||
|
|
||||||
dm_bufio_release(to_buffer(b));
|
dm_bufio_release(to_buffer(b));
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(dm_bm_unlock);
|
EXPORT_SYMBOL_GPL(dm_bm_unlock);
|
||||||
|
|
||||||
|
@ -94,7 +94,7 @@ int dm_bm_write_lock_zero(struct dm_block_manager *bm, dm_block_t b,
|
|||||||
struct dm_block_validator *v,
|
struct dm_block_validator *v,
|
||||||
struct dm_block **result);
|
struct dm_block **result);
|
||||||
|
|
||||||
int dm_bm_unlock(struct dm_block *b);
|
void dm_bm_unlock(struct dm_block *b);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* It's a common idiom to have a superblock that should be committed last.
|
* It's a common idiom to have a superblock that should be committed last.
|
||||||
|
@ -52,7 +52,7 @@ void inc_children(struct dm_transaction_manager *tm, struct btree_node *n,
|
|||||||
struct dm_btree_value_type *vt);
|
struct dm_btree_value_type *vt);
|
||||||
|
|
||||||
int new_block(struct dm_btree_info *info, struct dm_block **result);
|
int new_block(struct dm_btree_info *info, struct dm_block **result);
|
||||||
int unlock_block(struct dm_btree_info *info, struct dm_block *b);
|
void unlock_block(struct dm_btree_info *info, struct dm_block *b);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Spines keep track of the rolling locks. There are 2 variants, read-only
|
* Spines keep track of the rolling locks. There are 2 variants, read-only
|
||||||
|
@ -165,9 +165,9 @@ static int init_child(struct dm_btree_info *info, struct dm_btree_value_type *vt
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int exit_child(struct dm_btree_info *info, struct child *c)
|
static void exit_child(struct dm_btree_info *info, struct child *c)
|
||||||
{
|
{
|
||||||
return dm_tm_unlock(info->tm, c->block);
|
dm_tm_unlock(info->tm, c->block);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void shift(struct btree_node *left, struct btree_node *right, int count)
|
static void shift(struct btree_node *left, struct btree_node *right, int count)
|
||||||
@ -249,13 +249,10 @@ static int rebalance2(struct shadow_spine *s, struct dm_btree_info *info,
|
|||||||
|
|
||||||
__rebalance2(info, parent, &left, &right);
|
__rebalance2(info, parent, &left, &right);
|
||||||
|
|
||||||
r = exit_child(info, &left);
|
exit_child(info, &left);
|
||||||
if (r) {
|
exit_child(info, &right);
|
||||||
exit_child(info, &right);
|
|
||||||
return r;
|
|
||||||
}
|
|
||||||
|
|
||||||
return exit_child(info, &right);
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -389,22 +386,9 @@ static int rebalance3(struct shadow_spine *s, struct dm_btree_info *info,
|
|||||||
|
|
||||||
__rebalance3(info, parent, &left, ¢er, &right);
|
__rebalance3(info, parent, &left, ¢er, &right);
|
||||||
|
|
||||||
r = exit_child(info, &left);
|
exit_child(info, &left);
|
||||||
if (r) {
|
exit_child(info, ¢er);
|
||||||
exit_child(info, ¢er);
|
exit_child(info, &right);
|
||||||
exit_child(info, &right);
|
|
||||||
return r;
|
|
||||||
}
|
|
||||||
|
|
||||||
r = exit_child(info, ¢er);
|
|
||||||
if (r) {
|
|
||||||
exit_child(info, &right);
|
|
||||||
return r;
|
|
||||||
}
|
|
||||||
|
|
||||||
r = exit_child(info, &right);
|
|
||||||
if (r)
|
|
||||||
return r;
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -428,9 +412,7 @@ static int rebalance_children(struct shadow_spine *s,
|
|||||||
|
|
||||||
memcpy(n, dm_block_data(child),
|
memcpy(n, dm_block_data(child),
|
||||||
dm_bm_block_size(dm_tm_get_bm(info->tm)));
|
dm_bm_block_size(dm_tm_get_bm(info->tm)));
|
||||||
r = dm_tm_unlock(info->tm, child);
|
dm_tm_unlock(info->tm, child);
|
||||||
if (r)
|
|
||||||
return r;
|
|
||||||
|
|
||||||
dm_tm_dec(info->tm, dm_block_location(child));
|
dm_tm_dec(info->tm, dm_block_location(child));
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -117,9 +117,9 @@ int new_block(struct dm_btree_info *info, struct dm_block **result)
|
|||||||
return dm_tm_new_block(info->tm, &btree_node_validator, result);
|
return dm_tm_new_block(info->tm, &btree_node_validator, result);
|
||||||
}
|
}
|
||||||
|
|
||||||
int unlock_block(struct dm_btree_info *info, struct dm_block *b)
|
void unlock_block(struct dm_btree_info *info, struct dm_block *b)
|
||||||
{
|
{
|
||||||
return dm_tm_unlock(info->tm, b);
|
dm_tm_unlock(info->tm, b);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*----------------------------------------------------------------*/
|
/*----------------------------------------------------------------*/
|
||||||
@ -137,9 +137,7 @@ int exit_ro_spine(struct ro_spine *s)
|
|||||||
int r = 0, i;
|
int r = 0, i;
|
||||||
|
|
||||||
for (i = 0; i < s->count; i++) {
|
for (i = 0; i < s->count; i++) {
|
||||||
int r2 = unlock_block(s->info, s->nodes[i]);
|
unlock_block(s->info, s->nodes[i]);
|
||||||
if (r2 < 0)
|
|
||||||
r = r2;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return r;
|
return r;
|
||||||
@ -150,9 +148,7 @@ int ro_step(struct ro_spine *s, dm_block_t new_child)
|
|||||||
int r;
|
int r;
|
||||||
|
|
||||||
if (s->count == 2) {
|
if (s->count == 2) {
|
||||||
r = unlock_block(s->info, s->nodes[0]);
|
unlock_block(s->info, s->nodes[0]);
|
||||||
if (r < 0)
|
|
||||||
return r;
|
|
||||||
s->nodes[0] = s->nodes[1];
|
s->nodes[0] = s->nodes[1];
|
||||||
s->count--;
|
s->count--;
|
||||||
}
|
}
|
||||||
@ -194,9 +190,7 @@ int exit_shadow_spine(struct shadow_spine *s)
|
|||||||
int r = 0, i;
|
int r = 0, i;
|
||||||
|
|
||||||
for (i = 0; i < s->count; i++) {
|
for (i = 0; i < s->count; i++) {
|
||||||
int r2 = unlock_block(s->info, s->nodes[i]);
|
unlock_block(s->info, s->nodes[i]);
|
||||||
if (r2 < 0)
|
|
||||||
r = r2;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return r;
|
return r;
|
||||||
@ -208,9 +202,7 @@ int shadow_step(struct shadow_spine *s, dm_block_t b,
|
|||||||
int r;
|
int r;
|
||||||
|
|
||||||
if (s->count == 2) {
|
if (s->count == 2) {
|
||||||
r = unlock_block(s->info, s->nodes[0]);
|
unlock_block(s->info, s->nodes[0]);
|
||||||
if (r < 0)
|
|
||||||
return r;
|
|
||||||
s->nodes[0] = s->nodes[1];
|
s->nodes[0] = s->nodes[1];
|
||||||
s->count--;
|
s->count--;
|
||||||
}
|
}
|
||||||
|
@ -141,7 +141,9 @@ int dm_btree_empty(struct dm_btree_info *info, dm_block_t *root)
|
|||||||
n->header.value_size = cpu_to_le32(info->value_type.size);
|
n->header.value_size = cpu_to_le32(info->value_type.size);
|
||||||
|
|
||||||
*root = dm_block_location(b);
|
*root = dm_block_location(b);
|
||||||
return unlock_block(info, b);
|
unlock_block(info, b);
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(dm_btree_empty);
|
EXPORT_SYMBOL_GPL(dm_btree_empty);
|
||||||
|
|
||||||
|
@ -259,9 +259,7 @@ int sm_ll_extend(struct ll_disk *ll, dm_block_t extra_blocks)
|
|||||||
|
|
||||||
idx.blocknr = cpu_to_le64(dm_block_location(b));
|
idx.blocknr = cpu_to_le64(dm_block_location(b));
|
||||||
|
|
||||||
r = dm_tm_unlock(ll->tm, b);
|
dm_tm_unlock(ll->tm, b);
|
||||||
if (r < 0)
|
|
||||||
return r;
|
|
||||||
|
|
||||||
idx.nr_free = cpu_to_le32(ll->entries_per_block);
|
idx.nr_free = cpu_to_le32(ll->entries_per_block);
|
||||||
idx.none_free_before = 0;
|
idx.none_free_before = 0;
|
||||||
@ -293,7 +291,9 @@ int sm_ll_lookup_bitmap(struct ll_disk *ll, dm_block_t b, uint32_t *result)
|
|||||||
|
|
||||||
*result = sm_lookup_bitmap(dm_bitmap_data(blk), b);
|
*result = sm_lookup_bitmap(dm_bitmap_data(blk), b);
|
||||||
|
|
||||||
return dm_tm_unlock(ll->tm, blk);
|
dm_tm_unlock(ll->tm, blk);
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int sm_ll_lookup_big_ref_count(struct ll_disk *ll, dm_block_t b,
|
static int sm_ll_lookup_big_ref_count(struct ll_disk *ll, dm_block_t b,
|
||||||
@ -373,9 +373,7 @@ int sm_ll_find_free_block(struct ll_disk *ll, dm_block_t begin,
|
|||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
r = dm_tm_unlock(ll->tm, blk);
|
dm_tm_unlock(ll->tm, blk);
|
||||||
if (r < 0)
|
|
||||||
return r;
|
|
||||||
|
|
||||||
*result = i * ll->entries_per_block + (dm_block_t) position;
|
*result = i * ll->entries_per_block + (dm_block_t) position;
|
||||||
return 0;
|
return 0;
|
||||||
@ -429,9 +427,7 @@ static int sm_ll_mutate(struct ll_disk *ll, dm_block_t b,
|
|||||||
if (ref_count <= 2) {
|
if (ref_count <= 2) {
|
||||||
sm_set_bitmap(bm_le, bit, ref_count);
|
sm_set_bitmap(bm_le, bit, ref_count);
|
||||||
|
|
||||||
r = dm_tm_unlock(ll->tm, nb);
|
dm_tm_unlock(ll->tm, nb);
|
||||||
if (r < 0)
|
|
||||||
return r;
|
|
||||||
|
|
||||||
if (old > 2) {
|
if (old > 2) {
|
||||||
r = dm_btree_remove(&ll->ref_count_info,
|
r = dm_btree_remove(&ll->ref_count_info,
|
||||||
@ -445,9 +441,7 @@ static int sm_ll_mutate(struct ll_disk *ll, dm_block_t b,
|
|||||||
__le32 le_rc = cpu_to_le32(ref_count);
|
__le32 le_rc = cpu_to_le32(ref_count);
|
||||||
|
|
||||||
sm_set_bitmap(bm_le, bit, 3);
|
sm_set_bitmap(bm_le, bit, 3);
|
||||||
r = dm_tm_unlock(ll->tm, nb);
|
dm_tm_unlock(ll->tm, nb);
|
||||||
if (r < 0)
|
|
||||||
return r;
|
|
||||||
|
|
||||||
__dm_bless_for_disk(&le_rc);
|
__dm_bless_for_disk(&le_rc);
|
||||||
r = dm_btree_insert(&ll->ref_count_info, ll->ref_count_root,
|
r = dm_btree_insert(&ll->ref_count_info, ll->ref_count_root,
|
||||||
@ -556,7 +550,9 @@ static int metadata_ll_init_index(struct ll_disk *ll)
|
|||||||
memcpy(dm_block_data(b), &ll->mi_le, sizeof(ll->mi_le));
|
memcpy(dm_block_data(b), &ll->mi_le, sizeof(ll->mi_le));
|
||||||
ll->bitmap_root = dm_block_location(b);
|
ll->bitmap_root = dm_block_location(b);
|
||||||
|
|
||||||
return dm_tm_unlock(ll->tm, b);
|
dm_tm_unlock(ll->tm, b);
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int metadata_ll_open(struct ll_disk *ll)
|
static int metadata_ll_open(struct ll_disk *ll)
|
||||||
@ -570,7 +566,9 @@ static int metadata_ll_open(struct ll_disk *ll)
|
|||||||
return r;
|
return r;
|
||||||
|
|
||||||
memcpy(&ll->mi_le, dm_block_data(block), sizeof(ll->mi_le));
|
memcpy(&ll->mi_le, dm_block_data(block), sizeof(ll->mi_le));
|
||||||
return dm_tm_unlock(ll->tm, block);
|
dm_tm_unlock(ll->tm, block);
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static dm_block_t metadata_ll_max_entries(struct ll_disk *ll)
|
static dm_block_t metadata_ll_max_entries(struct ll_disk *ll)
|
||||||
@ -590,7 +588,9 @@ static int metadata_ll_commit(struct ll_disk *ll)
|
|||||||
memcpy(dm_block_data(b), &ll->mi_le, sizeof(ll->mi_le));
|
memcpy(dm_block_data(b), &ll->mi_le, sizeof(ll->mi_le));
|
||||||
ll->bitmap_root = dm_block_location(b);
|
ll->bitmap_root = dm_block_location(b);
|
||||||
|
|
||||||
return dm_tm_unlock(ll->tm, b);
|
dm_tm_unlock(ll->tm, b);
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int sm_ll_new_metadata(struct ll_disk *ll, struct dm_transaction_manager *tm)
|
int sm_ll_new_metadata(struct ll_disk *ll, struct dm_transaction_manager *tm)
|
||||||
|
@ -342,9 +342,9 @@ int dm_tm_read_lock(struct dm_transaction_manager *tm, dm_block_t b,
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(dm_tm_read_lock);
|
EXPORT_SYMBOL_GPL(dm_tm_read_lock);
|
||||||
|
|
||||||
int dm_tm_unlock(struct dm_transaction_manager *tm, struct dm_block *b)
|
void dm_tm_unlock(struct dm_transaction_manager *tm, struct dm_block *b)
|
||||||
{
|
{
|
||||||
return dm_bm_unlock(b);
|
dm_bm_unlock(b);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(dm_tm_unlock);
|
EXPORT_SYMBOL_GPL(dm_tm_unlock);
|
||||||
|
|
||||||
|
@ -94,7 +94,7 @@ int dm_tm_read_lock(struct dm_transaction_manager *tm, dm_block_t b,
|
|||||||
struct dm_block_validator *v,
|
struct dm_block_validator *v,
|
||||||
struct dm_block **result);
|
struct dm_block **result);
|
||||||
|
|
||||||
int dm_tm_unlock(struct dm_transaction_manager *tm, struct dm_block *b);
|
void dm_tm_unlock(struct dm_transaction_manager *tm, struct dm_block *b);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Functions for altering the reference count of a block directly.
|
* Functions for altering the reference count of a block directly.
|
||||||
|
Loading…
Reference in New Issue
Block a user