Loading drivers/md/dm-snap-persistent.c +3 −3 Original line number Diff line number Diff line Loading @@ -596,7 +596,7 @@ static void persistent_dtr(struct dm_exception_store *store) free_area(ps); /* Allocated in persistent_read_metadata */ vfree(ps->callbacks); kvfree(ps->callbacks); kfree(ps); } Loading @@ -621,8 +621,8 @@ static int persistent_read_metadata(struct dm_exception_store *store, */ ps->exceptions_per_area = (ps->store->chunk_size << SECTOR_SHIFT) / sizeof(struct disk_exception); ps->callbacks = dm_vcalloc(ps->exceptions_per_area, sizeof(*ps->callbacks)); ps->callbacks = kvcalloc(ps->exceptions_per_area, sizeof(*ps->callbacks), GFP_KERNEL); if (!ps->callbacks) return -ENOMEM; Loading drivers/md/dm-snap.c +3 −2 Original line number Diff line number Diff line Loading @@ -663,7 +663,8 @@ static int dm_exception_table_init(struct dm_exception_table *et, et->hash_shift = hash_shift; et->hash_mask = size - 1; et->table = dm_vcalloc(size, sizeof(struct hlist_bl_head)); et->table = kvmalloc_array(size, sizeof(struct hlist_bl_head), GFP_KERNEL); if (!et->table) return -ENOMEM; Loading @@ -689,7 +690,7 @@ static void dm_exception_table_exit(struct dm_exception_table *et, kmem_cache_free(mem, ex); } vfree(et->table); kvfree(et->table); } static uint32_t exception_hash(struct dm_exception_table *et, chunk_t chunk) Loading drivers/md/dm-table.c +6 −24 Original line number Diff line number Diff line Loading @@ -94,24 +94,6 @@ static int setup_btree_index(unsigned int l, struct dm_table *t) return 0; } void *dm_vcalloc(unsigned long nmemb, unsigned long elem_size) { unsigned long size; void *addr; /* * Check that we're not going to overflow. */ if (nmemb > (ULONG_MAX / elem_size)) return NULL; size = nmemb * elem_size; addr = vzalloc(size); return addr; } EXPORT_SYMBOL(dm_vcalloc); /* * highs, and targets are managed as dynamic arrays during a * table load. Loading @@ -124,15 +106,15 @@ static int alloc_targets(struct dm_table *t, unsigned int num) /* * Allocate both the target array and offset array at once. */ n_highs = (sector_t *) dm_vcalloc(num, sizeof(struct dm_target) + sizeof(sector_t)); n_highs = kvcalloc(num, sizeof(struct dm_target) + sizeof(sector_t), GFP_KERNEL); if (!n_highs) return -ENOMEM; n_targets = (struct dm_target *) (n_highs + num); memset(n_highs, -1, sizeof(*n_highs) * num); vfree(t->highs); kvfree(t->highs); t->num_allocated = num; t->highs = n_highs; Loading Loading @@ -198,7 +180,7 @@ void dm_table_destroy(struct dm_table *t) /* free the indexes */ if (t->depth >= 2) vfree(t->index[t->depth - 2]); kvfree(t->index[t->depth - 2]); /* free the targets */ for (i = 0; i < t->num_targets; i++) { Loading @@ -210,7 +192,7 @@ void dm_table_destroy(struct dm_table *t) dm_put_target_type(tgt->type); } vfree(t->highs); kvfree(t->highs); /* free the device list */ free_devices(&t->devices, t->md); Loading Loading @@ -1077,7 +1059,7 @@ static int setup_indexes(struct dm_table *t) total += t->counts[i]; } indexes = (sector_t *) dm_vcalloc(total, (unsigned long) NODE_SIZE); indexes = kvcalloc(total, NODE_SIZE, GFP_KERNEL); if (!indexes) return -ENOMEM; Loading include/linux/device-mapper.h +0 −5 Original line number Diff line number Diff line Loading @@ -574,11 +574,6 @@ struct dm_table *dm_swap_table(struct mapped_device *md, */ void dm_destroy_keyslot_manager(struct blk_keyslot_manager *ksm); /* * A wrapper around vmalloc. */ void *dm_vcalloc(unsigned long nmemb, unsigned long elem_size); /*----------------------------------------------------------------- * Macros. *---------------------------------------------------------------*/ Loading Loading
drivers/md/dm-snap-persistent.c +3 −3 Original line number Diff line number Diff line Loading @@ -596,7 +596,7 @@ static void persistent_dtr(struct dm_exception_store *store) free_area(ps); /* Allocated in persistent_read_metadata */ vfree(ps->callbacks); kvfree(ps->callbacks); kfree(ps); } Loading @@ -621,8 +621,8 @@ static int persistent_read_metadata(struct dm_exception_store *store, */ ps->exceptions_per_area = (ps->store->chunk_size << SECTOR_SHIFT) / sizeof(struct disk_exception); ps->callbacks = dm_vcalloc(ps->exceptions_per_area, sizeof(*ps->callbacks)); ps->callbacks = kvcalloc(ps->exceptions_per_area, sizeof(*ps->callbacks), GFP_KERNEL); if (!ps->callbacks) return -ENOMEM; Loading
drivers/md/dm-snap.c +3 −2 Original line number Diff line number Diff line Loading @@ -663,7 +663,8 @@ static int dm_exception_table_init(struct dm_exception_table *et, et->hash_shift = hash_shift; et->hash_mask = size - 1; et->table = dm_vcalloc(size, sizeof(struct hlist_bl_head)); et->table = kvmalloc_array(size, sizeof(struct hlist_bl_head), GFP_KERNEL); if (!et->table) return -ENOMEM; Loading @@ -689,7 +690,7 @@ static void dm_exception_table_exit(struct dm_exception_table *et, kmem_cache_free(mem, ex); } vfree(et->table); kvfree(et->table); } static uint32_t exception_hash(struct dm_exception_table *et, chunk_t chunk) Loading
drivers/md/dm-table.c +6 −24 Original line number Diff line number Diff line Loading @@ -94,24 +94,6 @@ static int setup_btree_index(unsigned int l, struct dm_table *t) return 0; } void *dm_vcalloc(unsigned long nmemb, unsigned long elem_size) { unsigned long size; void *addr; /* * Check that we're not going to overflow. */ if (nmemb > (ULONG_MAX / elem_size)) return NULL; size = nmemb * elem_size; addr = vzalloc(size); return addr; } EXPORT_SYMBOL(dm_vcalloc); /* * highs, and targets are managed as dynamic arrays during a * table load. Loading @@ -124,15 +106,15 @@ static int alloc_targets(struct dm_table *t, unsigned int num) /* * Allocate both the target array and offset array at once. */ n_highs = (sector_t *) dm_vcalloc(num, sizeof(struct dm_target) + sizeof(sector_t)); n_highs = kvcalloc(num, sizeof(struct dm_target) + sizeof(sector_t), GFP_KERNEL); if (!n_highs) return -ENOMEM; n_targets = (struct dm_target *) (n_highs + num); memset(n_highs, -1, sizeof(*n_highs) * num); vfree(t->highs); kvfree(t->highs); t->num_allocated = num; t->highs = n_highs; Loading Loading @@ -198,7 +180,7 @@ void dm_table_destroy(struct dm_table *t) /* free the indexes */ if (t->depth >= 2) vfree(t->index[t->depth - 2]); kvfree(t->index[t->depth - 2]); /* free the targets */ for (i = 0; i < t->num_targets; i++) { Loading @@ -210,7 +192,7 @@ void dm_table_destroy(struct dm_table *t) dm_put_target_type(tgt->type); } vfree(t->highs); kvfree(t->highs); /* free the device list */ free_devices(&t->devices, t->md); Loading Loading @@ -1077,7 +1059,7 @@ static int setup_indexes(struct dm_table *t) total += t->counts[i]; } indexes = (sector_t *) dm_vcalloc(total, (unsigned long) NODE_SIZE); indexes = kvcalloc(total, NODE_SIZE, GFP_KERNEL); if (!indexes) return -ENOMEM; Loading
include/linux/device-mapper.h +0 −5 Original line number Diff line number Diff line Loading @@ -574,11 +574,6 @@ struct dm_table *dm_swap_table(struct mapped_device *md, */ void dm_destroy_keyslot_manager(struct blk_keyslot_manager *ksm); /* * A wrapper around vmalloc. */ void *dm_vcalloc(unsigned long nmemb, unsigned long elem_size); /*----------------------------------------------------------------- * Macros. *---------------------------------------------------------------*/ Loading