1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-19 14:04:17 +03:00

Merge branch '2018-06-04-data-structs'

This commit is contained in:
Joe Thornber 2018-06-08 14:21:07 +01:00
commit 7c4b19c335
109 changed files with 1116 additions and 1447 deletions

View File

@ -12,6 +12,8 @@
BASE_SOURCE=\ BASE_SOURCE=\
base/data-struct/radix-tree.c \ base/data-struct/radix-tree.c \
base/data-struct/hash.c \
base/data-struct/list.c
BASE_DEPENDS=$(addprefix $(top_builddir)/,$(subst .c,.d,$(BASE_SOURCE))) BASE_DEPENDS=$(addprefix $(top_builddir)/,$(subst .c,.d,$(BASE_SOURCE)))
BASE_OBJECTS=$(addprefix $(top_builddir)/,$(subst .c,.o,$(BASE_SOURCE))) BASE_OBJECTS=$(addprefix $(top_builddir)/,$(subst .c,.o,$(BASE_SOURCE)))

View File

@ -14,6 +14,8 @@
*/ */
#include "device_mapper/misc/dmlib.h" #include "device_mapper/misc/dmlib.h"
#include "base/memory/zalloc.h"
#include "hash.h"
struct dm_hash_node { struct dm_hash_node {
struct dm_hash_node *next; struct dm_hash_node *next;
@ -59,7 +61,7 @@ static unsigned char _nums[] = {
static struct dm_hash_node *_create_node(const char *str, unsigned len) static struct dm_hash_node *_create_node(const char *str, unsigned len)
{ {
struct dm_hash_node *n = dm_malloc(sizeof(*n) + len); struct dm_hash_node *n = malloc(sizeof(*n) + len);
if (n) { if (n) {
memcpy(n->key, str, len); memcpy(n->key, str, len);
@ -91,7 +93,7 @@ struct dm_hash_table *dm_hash_create(unsigned size_hint)
{ {
size_t len; size_t len;
unsigned new_size = 16u; unsigned new_size = 16u;
struct dm_hash_table *hc = dm_zalloc(sizeof(*hc)); struct dm_hash_table *hc = zalloc(sizeof(*hc));
if (!hc) if (!hc)
return_0; return_0;
@ -102,14 +104,14 @@ struct dm_hash_table *dm_hash_create(unsigned size_hint)
hc->num_slots = new_size; hc->num_slots = new_size;
len = sizeof(*(hc->slots)) * new_size; len = sizeof(*(hc->slots)) * new_size;
if (!(hc->slots = dm_zalloc(len))) if (!(hc->slots = zalloc(len)))
goto_bad; goto_bad;
return hc; return hc;
bad: bad:
dm_free(hc->slots); free(hc->slots);
dm_free(hc); free(hc);
return 0; return 0;
} }
@ -121,15 +123,15 @@ static void _free_nodes(struct dm_hash_table *t)
for (i = 0; i < t->num_slots; i++) for (i = 0; i < t->num_slots; i++)
for (c = t->slots[i]; c; c = n) { for (c = t->slots[i]; c; c = n) {
n = c->next; n = c->next;
dm_free(c); free(c);
} }
} }
void dm_hash_destroy(struct dm_hash_table *t) void dm_hash_destroy(struct dm_hash_table *t)
{ {
_free_nodes(t); _free_nodes(t);
dm_free(t->slots); free(t->slots);
dm_free(t); free(t);
} }
static struct dm_hash_node **_find(struct dm_hash_table *t, const void *key, static struct dm_hash_node **_find(struct dm_hash_table *t, const void *key,
@ -187,7 +189,7 @@ void dm_hash_remove_binary(struct dm_hash_table *t, const void *key,
if (*c) { if (*c) {
struct dm_hash_node *old = *c; struct dm_hash_node *old = *c;
*c = (*c)->next; *c = (*c)->next;
dm_free(old); free(old);
t->num_nodes--; t->num_nodes--;
} }
} }
@ -287,7 +289,7 @@ void dm_hash_remove_with_val(struct dm_hash_table *t, const char *key,
if (c && *c) { if (c && *c) {
struct dm_hash_node *old = *c; struct dm_hash_node *old = *c;
*c = (*c)->next; *c = (*c)->next;
dm_free(old); free(old);
t->num_nodes--; t->num_nodes--;
} }
} }

94
base/data-struct/hash.h Normal file
View File

@ -0,0 +1,94 @@
#ifndef BASE_DATA_STRUCT_HASH_H
#define BASE_DATA_STRUCT_HASH_H
#include <stdint.h>
//----------------------------------------------------------------
struct dm_hash_table;
struct dm_hash_node;
typedef void (*dm_hash_iterate_fn) (void *data);
struct dm_hash_table *dm_hash_create(unsigned size_hint)
__attribute__((__warn_unused_result__));
void dm_hash_destroy(struct dm_hash_table *t);
void dm_hash_wipe(struct dm_hash_table *t);
void *dm_hash_lookup(struct dm_hash_table *t, const char *key);
int dm_hash_insert(struct dm_hash_table *t, const char *key, void *data);
void dm_hash_remove(struct dm_hash_table *t, const char *key);
void *dm_hash_lookup_binary(struct dm_hash_table *t, const void *key, uint32_t len);
int dm_hash_insert_binary(struct dm_hash_table *t, const void *key, uint32_t len,
void *data);
void dm_hash_remove_binary(struct dm_hash_table *t, const void *key, uint32_t len);
unsigned dm_hash_get_num_entries(struct dm_hash_table *t);
void dm_hash_iter(struct dm_hash_table *t, dm_hash_iterate_fn f);
char *dm_hash_get_key(struct dm_hash_table *t, struct dm_hash_node *n);
void *dm_hash_get_data(struct dm_hash_table *t, struct dm_hash_node *n);
struct dm_hash_node *dm_hash_get_first(struct dm_hash_table *t);
struct dm_hash_node *dm_hash_get_next(struct dm_hash_table *t, struct dm_hash_node *n);
/*
* dm_hash_insert() replaces the value of an existing
* entry with a matching key if one exists. Otherwise
* it adds a new entry.
*
* dm_hash_insert_with_val() inserts a new entry if
* another entry with the same key already exists.
* val_len is the size of the data being inserted.
*
* If two entries with the same key exist,
* (added using dm_hash_insert_allow_multiple), then:
* . dm_hash_lookup() returns the first one it finds, and
* dm_hash_lookup_with_val() returns the one with a matching
* val_len/val.
* . dm_hash_remove() removes the first one it finds, and
* dm_hash_remove_with_val() removes the one with a matching
* val_len/val.
*
* If a single entry with a given key exists, and it has
* zero val_len, then:
* . dm_hash_lookup() returns it
* . dm_hash_lookup_with_val(val_len=0) returns it
* . dm_hash_remove() removes it
* . dm_hash_remove_with_val(val_len=0) removes it
*
* dm_hash_lookup_with_count() is a single call that will
* both lookup a key's value and check if there is more
* than one entry with the given key.
*
* (It is not meant to retrieve all the entries with the
* given key. In the common case where a single entry exists
* for the key, it is useful to have a single call that will
* both look up the value and indicate if multiple values
* exist for the key.)
*
* dm_hash_lookup_with_count:
* . If no entries exist, the function returns NULL, and
* the count is set to 0.
* . If only one entry exists, the value of that entry is
* returned and count is set to 1.
* . If N entries exists, the value of the first entry is
* returned and count is set to N.
*/
void *dm_hash_lookup_with_val(struct dm_hash_table *t, const char *key,
const void *val, uint32_t val_len);
void dm_hash_remove_with_val(struct dm_hash_table *t, const char *key,
const void *val, uint32_t val_len);
int dm_hash_insert_allow_multiple(struct dm_hash_table *t, const char *key,
const void *val, uint32_t val_len);
void *dm_hash_lookup_with_count(struct dm_hash_table *t, const char *key, int *count);
#define dm_hash_iterate(v, h) \
for (v = dm_hash_get_first((h)); v; \
v = dm_hash_get_next((h), v))
//----------------------------------------------------------------
#endif

View File

@ -13,8 +13,10 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "device_mapper/misc/dmlib.h" #include "list.h"
#include <assert.h> #include <assert.h>
#include <stdlib.h>
/* /*
* Initialise a list before use. * Initialise a list before use.

209
base/data-struct/list.h Normal file
View File

@ -0,0 +1,209 @@
#ifndef BASE_DATA_STRUCT_LIST_H
#define BASE_DATA_STRUCT_LIST_H
//----------------------------------------------------------------
/*
* A list consists of a list head plus elements.
* Each element has 'next' and 'previous' pointers.
* The list head's pointers point to the first and the last element.
*/
struct dm_list {
struct dm_list *n, *p;
};
/*
* String list.
*/
struct dm_str_list {
struct dm_list list;
const char *str;
};
/*
* Initialise a list before use.
* The list head's next and previous pointers point back to itself.
*/
#define DM_LIST_HEAD_INIT(name) { &(name), &(name) }
#define DM_LIST_INIT(name) struct dm_list name = DM_LIST_HEAD_INIT(name)
void dm_list_init(struct dm_list *head);
/*
* Insert an element before 'head'.
* If 'head' is the list head, this adds an element to the end of the list.
*/
void dm_list_add(struct dm_list *head, struct dm_list *elem);
/*
* Insert an element after 'head'.
* If 'head' is the list head, this adds an element to the front of the list.
*/
void dm_list_add_h(struct dm_list *head, struct dm_list *elem);
/*
* Delete an element from its list.
* Note that this doesn't change the element itself - it may still be safe
* to follow its pointers.
*/
void dm_list_del(struct dm_list *elem);
/*
* Remove an element from existing list and insert before 'head'.
*/
void dm_list_move(struct dm_list *head, struct dm_list *elem);
/*
* Join 'head1' to the end of 'head'.
*/
void dm_list_splice(struct dm_list *head, struct dm_list *head1);
/*
* Is the list empty?
*/
int dm_list_empty(const struct dm_list *head);
/*
* Is this the first element of the list?
*/
int dm_list_start(const struct dm_list *head, const struct dm_list *elem);
/*
* Is this the last element of the list?
*/
int dm_list_end(const struct dm_list *head, const struct dm_list *elem);
/*
* Return first element of the list or NULL if empty
*/
struct dm_list *dm_list_first(const struct dm_list *head);
/*
* Return last element of the list or NULL if empty
*/
struct dm_list *dm_list_last(const struct dm_list *head);
/*
* Return the previous element of the list, or NULL if we've reached the start.
*/
struct dm_list *dm_list_prev(const struct dm_list *head, const struct dm_list *elem);
/*
* Return the next element of the list, or NULL if we've reached the end.
*/
struct dm_list *dm_list_next(const struct dm_list *head, const struct dm_list *elem);
/*
* Given the address v of an instance of 'struct dm_list' called 'head'
* contained in a structure of type t, return the containing structure.
*/
#define dm_list_struct_base(v, t, head) \
((t *)((const char *)(v) - (const char *)&((t *) 0)->head))
/*
* Given the address v of an instance of 'struct dm_list list' contained in
* a structure of type t, return the containing structure.
*/
#define dm_list_item(v, t) dm_list_struct_base((v), t, list)
/*
* Given the address v of one known element e in a known structure of type t,
* return another element f.
*/
#define dm_struct_field(v, t, e, f) \
(((t *)((uintptr_t)(v) - (uintptr_t)&((t *) 0)->e))->f)
/*
* Given the address v of a known element e in a known structure of type t,
* return the list head 'list'
*/
#define dm_list_head(v, t, e) dm_struct_field(v, t, e, list)
/*
* Set v to each element of a list in turn.
*/
#define dm_list_iterate(v, head) \
for (v = (head)->n; v != head; v = v->n)
/*
* Set v to each element in a list in turn, starting from the element
* in front of 'start'.
* You can use this to 'unwind' a list_iterate and back out actions on
* already-processed elements.
* If 'start' is 'head' it walks the list backwards.
*/
#define dm_list_uniterate(v, head, start) \
for (v = (start)->p; v != head; v = v->p)
/*
* A safe way to walk a list and delete and free some elements along
* the way.
* t must be defined as a temporary variable of the same type as v.
*/
#define dm_list_iterate_safe(v, t, head) \
for (v = (head)->n, t = v->n; v != head; v = t, t = v->n)
/*
* Walk a list, setting 'v' in turn to the containing structure of each item.
* The containing structure should be the same type as 'v'.
* The 'struct dm_list' variable within the containing structure is 'field'.
*/
#define dm_list_iterate_items_gen(v, head, field) \
for (v = dm_list_struct_base((head)->n, __typeof__(*v), field); \
&v->field != (head); \
v = dm_list_struct_base(v->field.n, __typeof__(*v), field))
/*
* Walk a list, setting 'v' in turn to the containing structure of each item.
* The containing structure should be the same type as 'v'.
* The list should be 'struct dm_list list' within the containing structure.
*/
#define dm_list_iterate_items(v, head) dm_list_iterate_items_gen(v, (head), list)
/*
* Walk a list, setting 'v' in turn to the containing structure of each item.
* The containing structure should be the same type as 'v'.
* The 'struct dm_list' variable within the containing structure is 'field'.
* t must be defined as a temporary variable of the same type as v.
*/
#define dm_list_iterate_items_gen_safe(v, t, head, field) \
for (v = dm_list_struct_base((head)->n, __typeof__(*v), field), \
t = dm_list_struct_base(v->field.n, __typeof__(*v), field); \
&v->field != (head); \
v = t, t = dm_list_struct_base(v->field.n, __typeof__(*v), field))
/*
* Walk a list, setting 'v' in turn to the containing structure of each item.
* The containing structure should be the same type as 'v'.
* The list should be 'struct dm_list list' within the containing structure.
* t must be defined as a temporary variable of the same type as v.
*/
#define dm_list_iterate_items_safe(v, t, head) \
dm_list_iterate_items_gen_safe(v, t, (head), list)
/*
* Walk a list backwards, setting 'v' in turn to the containing structure
* of each item.
* The containing structure should be the same type as 'v'.
* The 'struct dm_list' variable within the containing structure is 'field'.
*/
#define dm_list_iterate_back_items_gen(v, head, field) \
for (v = dm_list_struct_base((head)->p, __typeof__(*v), field); \
&v->field != (head); \
v = dm_list_struct_base(v->field.p, __typeof__(*v), field))
/*
* Walk a list backwards, setting 'v' in turn to the containing structure
* of each item.
* The containing structure should be the same type as 'v'.
* The list should be 'struct dm_list list' within the containing structure.
*/
#define dm_list_iterate_back_items(v, head) dm_list_iterate_back_items_gen(v, (head), list)
/*
* Return the number of elements in a list by walking it.
*/
unsigned int dm_list_size(const struct dm_list *head);
//----------------------------------------------------------------
#endif

3
configure vendored
View File

@ -13611,7 +13611,7 @@ _ACEOF
################################################################################ ################################################################################
ac_config_files="$ac_config_files Makefile make.tmpl libdm/make.tmpl daemons/Makefile daemons/cmirrord/Makefile daemons/dmeventd/Makefile daemons/dmeventd/libdevmapper-event.pc daemons/dmeventd/plugins/Makefile daemons/dmeventd/plugins/lvm2/Makefile daemons/dmeventd/plugins/raid/Makefile daemons/dmeventd/plugins/mirror/Makefile daemons/dmeventd/plugins/snapshot/Makefile daemons/dmeventd/plugins/thin/Makefile daemons/dmfilemapd/Makefile daemons/lvmdbusd/Makefile daemons/lvmdbusd/lvmdbusd daemons/lvmdbusd/lvmdb.py daemons/lvmdbusd/lvm_shell_proxy.py daemons/lvmdbusd/path.py daemons/lvmetad/Makefile daemons/lvmpolld/Makefile daemons/lvmlockd/Makefile conf/Makefile conf/example.conf conf/lvmlocal.conf conf/command_profile_template.profile conf/metadata_profile_template.profile include/Makefile lib/Makefile include/lvm-version.h libdaemon/Makefile libdaemon/client/Makefile libdaemon/server/Makefile libdm/Makefile libdm/libdevmapper.pc man/Makefile po/Makefile python/Makefile python/setup.py scripts/blkdeactivate.sh scripts/blk_availability_init_red_hat scripts/blk_availability_systemd_red_hat.service scripts/cmirrord_init_red_hat scripts/com.redhat.lvmdbus1.service scripts/dm_event_systemd_red_hat.service scripts/dm_event_systemd_red_hat.socket scripts/lvm2_cmirrord_systemd_red_hat.service scripts/lvm2_lvmdbusd_systemd_red_hat.service scripts/lvm2_lvmetad_init_red_hat scripts/lvm2_lvmetad_systemd_red_hat.service scripts/lvm2_lvmetad_systemd_red_hat.socket scripts/lvm2_lvmpolld_init_red_hat scripts/lvm2_lvmpolld_systemd_red_hat.service scripts/lvm2_lvmpolld_systemd_red_hat.socket scripts/lvm2_lvmlockd_systemd_red_hat.service scripts/lvm2_lvmlocking_systemd_red_hat.service scripts/lvm2_monitoring_init_red_hat scripts/lvm2_monitoring_systemd_red_hat.service scripts/lvm2_pvscan_systemd_red_hat@.service scripts/lvm2_tmpfiles_red_hat.conf scripts/lvmdump.sh scripts/Makefile test/Makefile test/api/Makefile test/api/python_lvm_unit.py test/unit/Makefile tools/Makefile udev/Makefile" ac_config_files="$ac_config_files Makefile make.tmpl libdm/make.tmpl daemons/Makefile daemons/cmirrord/Makefile daemons/dmeventd/Makefile daemons/dmeventd/libdevmapper-event.pc daemons/dmeventd/plugins/Makefile daemons/dmeventd/plugins/lvm2/Makefile daemons/dmeventd/plugins/raid/Makefile daemons/dmeventd/plugins/mirror/Makefile daemons/dmeventd/plugins/snapshot/Makefile daemons/dmeventd/plugins/thin/Makefile daemons/dmfilemapd/Makefile daemons/lvmdbusd/Makefile daemons/lvmdbusd/lvmdbusd daemons/lvmdbusd/lvmdb.py daemons/lvmdbusd/lvm_shell_proxy.py daemons/lvmdbusd/path.py daemons/lvmetad/Makefile daemons/lvmpolld/Makefile daemons/lvmlockd/Makefile conf/Makefile conf/example.conf conf/lvmlocal.conf conf/command_profile_template.profile conf/metadata_profile_template.profile include/Makefile lib/Makefile include/lvm-version.h libdaemon/Makefile libdaemon/client/Makefile libdaemon/server/Makefile libdm/Makefile libdm/libdevmapper.pc man/Makefile po/Makefile python/Makefile python/setup.py scripts/blkdeactivate.sh scripts/blk_availability_init_red_hat scripts/blk_availability_systemd_red_hat.service scripts/cmirrord_init_red_hat scripts/com.redhat.lvmdbus1.service scripts/dm_event_systemd_red_hat.service scripts/dm_event_systemd_red_hat.socket scripts/lvm2_cmirrord_systemd_red_hat.service scripts/lvm2_lvmdbusd_systemd_red_hat.service scripts/lvm2_lvmetad_init_red_hat scripts/lvm2_lvmetad_systemd_red_hat.service scripts/lvm2_lvmetad_systemd_red_hat.socket scripts/lvm2_lvmpolld_init_red_hat scripts/lvm2_lvmpolld_systemd_red_hat.service scripts/lvm2_lvmpolld_systemd_red_hat.socket scripts/lvm2_lvmlockd_systemd_red_hat.service scripts/lvm2_lvmlocking_systemd_red_hat.service scripts/lvm2_monitoring_init_red_hat scripts/lvm2_monitoring_systemd_red_hat.service scripts/lvm2_pvscan_systemd_red_hat@.service scripts/lvm2_tmpfiles_red_hat.conf scripts/lvmdump.sh scripts/Makefile test/Makefile test/api/Makefile test/api/python_lvm_unit.py tools/Makefile udev/Makefile"
cat >confcache <<\_ACEOF cat >confcache <<\_ACEOF
# This file is a shell script that caches the results of configure # This file is a shell script that caches the results of configure
@ -14371,7 +14371,6 @@ do
"test/Makefile") CONFIG_FILES="$CONFIG_FILES test/Makefile" ;; "test/Makefile") CONFIG_FILES="$CONFIG_FILES test/Makefile" ;;
"test/api/Makefile") CONFIG_FILES="$CONFIG_FILES test/api/Makefile" ;; "test/api/Makefile") CONFIG_FILES="$CONFIG_FILES test/api/Makefile" ;;
"test/api/python_lvm_unit.py") CONFIG_FILES="$CONFIG_FILES test/api/python_lvm_unit.py" ;; "test/api/python_lvm_unit.py") CONFIG_FILES="$CONFIG_FILES test/api/python_lvm_unit.py" ;;
"test/unit/Makefile") CONFIG_FILES="$CONFIG_FILES test/unit/Makefile" ;;
"tools/Makefile") CONFIG_FILES="$CONFIG_FILES tools/Makefile" ;; "tools/Makefile") CONFIG_FILES="$CONFIG_FILES tools/Makefile" ;;
"udev/Makefile") CONFIG_FILES="$CONFIG_FILES udev/Makefile" ;; "udev/Makefile") CONFIG_FILES="$CONFIG_FILES udev/Makefile" ;;

View File

@ -1816,7 +1816,6 @@ scripts/Makefile
test/Makefile test/Makefile
test/api/Makefile test/api/Makefile
test/api/python_lvm_unit.py test/api/python_lvm_unit.py
test/unit/Makefile
tools/Makefile tools/Makefile
udev/Makefile udev/Makefile
]) ])

View File

@ -13,7 +13,7 @@
#define _LVM_CLOG_CLUSTER_H #define _LVM_CLOG_CLUSTER_H
#include "device_mapper/misc/dm-log-userspace.h" #include "device_mapper/misc/dm-log-userspace.h"
#include "device_mapper/libdevmapper.h" #include "device_mapper/all.h"
#define DM_ULOG_RESPONSE 0x1000U /* in last byte of 32-bit value */ #define DM_ULOG_RESPONSE 0x1000U /* in last byte of 32-bit value */
#define DM_ULOG_CHECKPOINT_READY 21 #define DM_ULOG_CHECKPOINT_READY 21

View File

@ -435,7 +435,7 @@ static int _clog_ctr(char *uuid, uint64_t luid,
block_on_error = 1; block_on_error = 1;
} }
lc = dm_zalloc(sizeof(*lc)); lc = zalloc(sizeof(*lc));
if (!lc) { if (!lc) {
LOG_ERROR("Unable to allocate cluster log context"); LOG_ERROR("Unable to allocate cluster log context");
r = -ENOMEM; r = -ENOMEM;
@ -532,9 +532,9 @@ fail:
LOG_ERROR("Close device error, %s: %s", LOG_ERROR("Close device error, %s: %s",
disk_path, strerror(errno)); disk_path, strerror(errno));
free(lc->disk_buffer); free(lc->disk_buffer);
dm_free(lc->sync_bits); free(lc->sync_bits);
dm_free(lc->clean_bits); free(lc->clean_bits);
dm_free(lc); free(lc);
} }
return r; return r;
} }
@ -659,9 +659,9 @@ static int clog_dtr(struct dm_ulog_request *rq)
strerror(errno)); strerror(errno));
if (lc->disk_buffer) if (lc->disk_buffer)
free(lc->disk_buffer); free(lc->disk_buffer);
dm_free(lc->clean_bits); free(lc->clean_bits);
dm_free(lc->sync_bits); free(lc->sync_bits);
dm_free(lc); free(lc);
return 0; return 0;
} }

View File

@ -16,6 +16,7 @@
* dmeventd - dm event daemon to monitor active mapped devices * dmeventd - dm event daemon to monitor active mapped devices
*/ */
#include "base/memory/zalloc.h"
#include "device_mapper/misc/dm-logging.h" #include "device_mapper/misc/dm-logging.h"
#include "daemons/dmeventd/libdevmapper-event.h" #include "daemons/dmeventd/libdevmapper-event.h"
@ -264,19 +265,19 @@ static pthread_cond_t _timeout_cond = PTHREAD_COND_INITIALIZER;
/* DSO data allocate/free. */ /* DSO data allocate/free. */
static void _free_dso_data(struct dso_data *data) static void _free_dso_data(struct dso_data *data)
{ {
dm_free(data->dso_name); free(data->dso_name);
dm_free(data); free(data);
} }
static struct dso_data *_alloc_dso_data(struct message_data *data) static struct dso_data *_alloc_dso_data(struct message_data *data)
{ {
struct dso_data *ret = (typeof(ret)) dm_zalloc(sizeof(*ret)); struct dso_data *ret = (typeof(ret)) zalloc(sizeof(*ret));
if (!ret) if (!ret)
return_NULL; return_NULL;
if (!(ret->dso_name = dm_strdup(data->dso_name))) { if (!(ret->dso_name = strdup(data->dso_name))) {
dm_free(ret); free(ret);
return_NULL; return_NULL;
} }
@ -397,9 +398,9 @@ static void _free_thread_status(struct thread_status *thread)
_lib_put(thread->dso_data); _lib_put(thread->dso_data);
if (thread->wait_task) if (thread->wait_task)
dm_task_destroy(thread->wait_task); dm_task_destroy(thread->wait_task);
dm_free(thread->device.uuid); free(thread->device.uuid);
dm_free(thread->device.name); free(thread->device.name);
dm_free(thread); free(thread);
} }
/* Note: events_field must not be 0, ensured by caller */ /* Note: events_field must not be 0, ensured by caller */
@ -408,7 +409,7 @@ static struct thread_status *_alloc_thread_status(const struct message_data *dat
{ {
struct thread_status *thread; struct thread_status *thread;
if (!(thread = dm_zalloc(sizeof(*thread)))) { if (!(thread = zalloc(sizeof(*thread)))) {
log_error("Cannot create new thread, out of memory."); log_error("Cannot create new thread, out of memory.");
return NULL; return NULL;
} }
@ -422,11 +423,11 @@ static struct thread_status *_alloc_thread_status(const struct message_data *dat
if (!dm_task_set_uuid(thread->wait_task, data->device_uuid)) if (!dm_task_set_uuid(thread->wait_task, data->device_uuid))
goto_out; goto_out;
if (!(thread->device.uuid = dm_strdup(data->device_uuid))) if (!(thread->device.uuid = strdup(data->device_uuid)))
goto_out; goto_out;
/* Until real name resolved, use UUID */ /* Until real name resolved, use UUID */
if (!(thread->device.name = dm_strdup(data->device_uuid))) if (!(thread->device.name = strdup(data->device_uuid)))
goto_out; goto_out;
/* runs ioctl and may register lvm2 pluging */ /* runs ioctl and may register lvm2 pluging */
@ -515,7 +516,7 @@ static int _fetch_string(char **ptr, char **src, const int delimiter)
if ((p = strchr(*src, delimiter))) { if ((p = strchr(*src, delimiter))) {
if (*src < p) { if (*src < p) {
*p = 0; /* Temporary exit with \0 */ *p = 0; /* Temporary exit with \0 */
if (!(*ptr = dm_strdup(*src))) { if (!(*ptr = strdup(*src))) {
log_error("Failed to fetch item %s.", *src); log_error("Failed to fetch item %s.", *src);
ret = 0; /* Allocation fail */ ret = 0; /* Allocation fail */
} }
@ -525,7 +526,7 @@ static int _fetch_string(char **ptr, char **src, const int delimiter)
(*src)++; /* Skip delmiter, next field */ (*src)++; /* Skip delmiter, next field */
} else if ((len = strlen(*src))) { } else if ((len = strlen(*src))) {
/* No delimiter, item ends with '\0' */ /* No delimiter, item ends with '\0' */
if (!(*ptr = dm_strdup(*src))) { if (!(*ptr = strdup(*src))) {
log_error("Failed to fetch last item %s.", *src); log_error("Failed to fetch last item %s.", *src);
ret = 0; /* Fail */ ret = 0; /* Fail */
} }
@ -538,11 +539,11 @@ out:
/* Free message memory. */ /* Free message memory. */
static void _free_message(struct message_data *message_data) static void _free_message(struct message_data *message_data)
{ {
dm_free(message_data->id); free(message_data->id);
dm_free(message_data->dso_name); free(message_data->dso_name);
dm_free(message_data->device_uuid); free(message_data->device_uuid);
dm_free(message_data->events_str); free(message_data->events_str);
dm_free(message_data->timeout_str); free(message_data->timeout_str);
} }
/* Parse a register message from the client. */ /* Parse a register message from the client. */
@ -574,7 +575,7 @@ static int _parse_message(struct message_data *message_data)
ret = 1; ret = 1;
} }
dm_free(msg->data); free(msg->data);
msg->data = NULL; msg->data = NULL;
return ret; return ret;
@ -608,8 +609,8 @@ static int _fill_device_data(struct thread_status *ts)
if (!dm_task_run(dmt)) if (!dm_task_run(dmt))
goto fail; goto fail;
dm_free(ts->device.name); free(ts->device.name);
if (!(ts->device.name = dm_strdup(dm_task_get_name(dmt)))) if (!(ts->device.name = strdup(dm_task_get_name(dmt))))
goto fail; goto fail;
if (!dm_task_get_info(dmt, &dmi)) if (!dm_task_get_info(dmt, &dmi))
@ -696,8 +697,8 @@ static int _get_status(struct message_data *message_data)
len = strlen(message_data->id); len = strlen(message_data->id);
msg->size = size + len + 1; msg->size = size + len + 1;
dm_free(msg->data); free(msg->data);
if (!(msg->data = dm_malloc(msg->size))) if (!(msg->data = malloc(msg->size)))
goto out; goto out;
memcpy(msg->data, message_data->id, len); memcpy(msg->data, message_data->id, len);
@ -712,7 +713,7 @@ static int _get_status(struct message_data *message_data)
ret = 0; ret = 0;
out: out:
for (j = 0; j < i; ++j) for (j = 0; j < i; ++j)
dm_free(buffers[j]); free(buffers[j]);
return ret; return ret;
} }
@ -721,7 +722,7 @@ static int _get_parameters(struct message_data *message_data) {
struct dm_event_daemon_message *msg = message_data->msg; struct dm_event_daemon_message *msg = message_data->msg;
int size; int size;
dm_free(msg->data); free(msg->data);
if ((size = dm_asprintf(&msg->data, "%s pid=%d daemon=%s exec_method=%s", if ((size = dm_asprintf(&msg->data, "%s pid=%d daemon=%s exec_method=%s",
message_data->id, getpid(), message_data->id, getpid(),
_foreground ? "no" : "yes", _foreground ? "no" : "yes",
@ -1225,7 +1226,7 @@ static int _registered_device(struct message_data *message_data,
int r; int r;
struct dm_event_daemon_message *msg = message_data->msg; struct dm_event_daemon_message *msg = message_data->msg;
dm_free(msg->data); free(msg->data);
if ((r = dm_asprintf(&(msg->data), "%s %s %s %u", if ((r = dm_asprintf(&(msg->data), "%s %s %s %u",
message_data->id, message_data->id,
@ -1365,7 +1366,7 @@ static int _get_timeout(struct message_data *message_data)
if (!thread) if (!thread)
return -ENODEV; return -ENODEV;
dm_free(msg->data); free(msg->data);
msg->size = dm_asprintf(&(msg->data), "%s %" PRIu32, msg->size = dm_asprintf(&(msg->data), "%s %" PRIu32,
message_data->id, thread->timeout); message_data->id, thread->timeout);
@ -1502,7 +1503,7 @@ static int _client_read(struct dm_event_fifos *fifos,
bytes = 0; bytes = 0;
if (!size) if (!size)
break; /* No data -> error */ break; /* No data -> error */
buf = msg->data = dm_malloc(msg->size); buf = msg->data = malloc(msg->size);
if (!buf) if (!buf)
break; /* No mem -> error */ break; /* No mem -> error */
header = 0; header = 0;
@ -1510,7 +1511,7 @@ static int _client_read(struct dm_event_fifos *fifos,
} }
if (bytes != size) { if (bytes != size) {
dm_free(msg->data); free(msg->data);
msg->data = NULL; msg->data = NULL;
return 0; return 0;
} }
@ -1530,7 +1531,7 @@ static int _client_write(struct dm_event_fifos *fifos,
fd_set fds; fd_set fds;
size_t size = 2 * sizeof(uint32_t) + ((msg->data) ? msg->size : 0); size_t size = 2 * sizeof(uint32_t) + ((msg->data) ? msg->size : 0);
uint32_t *header = dm_malloc(size); uint32_t *header = malloc(size);
char *buf = (char *)header; char *buf = (char *)header;
if (!header) { if (!header) {
@ -1560,7 +1561,7 @@ static int _client_write(struct dm_event_fifos *fifos,
} }
if (header != temp) if (header != temp)
dm_free(header); free(header);
return (bytes == size); return (bytes == size);
} }
@ -1622,7 +1623,7 @@ static int _do_process_request(struct dm_event_daemon_message *msg)
msg->size = dm_asprintf(&(msg->data), "%s %s %d", answer, msg->size = dm_asprintf(&(msg->data), "%s %s %d", answer,
(msg->cmd == DM_EVENT_CMD_DIE) ? "DYING" : "HELLO", (msg->cmd == DM_EVENT_CMD_DIE) ? "DYING" : "HELLO",
DM_EVENT_PROTOCOL_VERSION); DM_EVENT_PROTOCOL_VERSION);
dm_free(answer); free(answer);
} }
} else if (msg->cmd != DM_EVENT_CMD_ACTIVE && !_parse_message(&message_data)) { } else if (msg->cmd != DM_EVENT_CMD_ACTIVE && !_parse_message(&message_data)) {
stack; stack;
@ -1664,7 +1665,7 @@ static void _process_request(struct dm_event_fifos *fifos)
DEBUGLOG("<<< CMD:%s (0x%x) completed (result %d).", decode_cmd(cmd), cmd, msg.cmd); DEBUGLOG("<<< CMD:%s (0x%x) completed (result %d).", decode_cmd(cmd), cmd, msg.cmd);
dm_free(msg.data); free(msg.data);
if (cmd == DM_EVENT_CMD_DIE) { if (cmd == DM_EVENT_CMD_DIE) {
if (unlink(DMEVENTD_PIDFILE)) if (unlink(DMEVENTD_PIDFILE))
@ -1975,7 +1976,7 @@ static int _reinstate_registrations(struct dm_event_fifos *fifos)
int i, ret; int i, ret;
ret = daemon_talk(fifos, &msg, DM_EVENT_CMD_HELLO, NULL, NULL, 0, 0); ret = daemon_talk(fifos, &msg, DM_EVENT_CMD_HELLO, NULL, NULL, 0, 0);
dm_free(msg.data); free(msg.data);
msg.data = NULL; msg.data = NULL;
if (ret) { if (ret) {
@ -2061,13 +2062,13 @@ static void _restart_dmeventd(void)
++count; ++count;
} }
if (!(_initial_registrations = dm_malloc(sizeof(char*) * (count + 1)))) { if (!(_initial_registrations = malloc(sizeof(char*) * (count + 1)))) {
fprintf(stderr, "Memory allocation registration failed.\n"); fprintf(stderr, "Memory allocation registration failed.\n");
goto bad; goto bad;
} }
for (i = 0; i < count; ++i) { for (i = 0; i < count; ++i) {
if (!(_initial_registrations[i] = dm_strdup(message))) { if (!(_initial_registrations[i] = strdup(message))) {
fprintf(stderr, "Memory allocation for message failed.\n"); fprintf(stderr, "Memory allocation for message failed.\n");
goto bad; goto bad;
} }

View File

@ -12,6 +12,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "device_mapper/misc/dm-logging.h" #include "device_mapper/misc/dm-logging.h"
#include "device_mapper/misc/dmlib.h" #include "device_mapper/misc/dmlib.h"
#include "daemons/dmeventd/libdevmapper-event.h" #include "daemons/dmeventd/libdevmapper-event.h"
@ -49,8 +50,8 @@ struct dm_event_handler {
static void _dm_event_handler_clear_dev_info(struct dm_event_handler *dmevh) static void _dm_event_handler_clear_dev_info(struct dm_event_handler *dmevh)
{ {
dm_free(dmevh->dev_name); free(dmevh->dev_name);
dm_free(dmevh->uuid); free(dmevh->uuid);
dmevh->dev_name = dmevh->uuid = NULL; dmevh->dev_name = dmevh->uuid = NULL;
dmevh->major = dmevh->minor = 0; dmevh->major = dmevh->minor = 0;
} }
@ -59,7 +60,7 @@ struct dm_event_handler *dm_event_handler_create(void)
{ {
struct dm_event_handler *dmevh; struct dm_event_handler *dmevh;
if (!(dmevh = dm_zalloc(sizeof(*dmevh)))) { if (!(dmevh = zalloc(sizeof(*dmevh)))) {
log_error("Failed to allocate event handler."); log_error("Failed to allocate event handler.");
return NULL; return NULL;
} }
@ -70,9 +71,9 @@ struct dm_event_handler *dm_event_handler_create(void)
void dm_event_handler_destroy(struct dm_event_handler *dmevh) void dm_event_handler_destroy(struct dm_event_handler *dmevh)
{ {
_dm_event_handler_clear_dev_info(dmevh); _dm_event_handler_clear_dev_info(dmevh);
dm_free(dmevh->dso); free(dmevh->dso);
dm_free(dmevh->dmeventd_path); free(dmevh->dmeventd_path);
dm_free(dmevh); free(dmevh);
} }
int dm_event_handler_set_dmeventd_path(struct dm_event_handler *dmevh, const char *dmeventd_path) int dm_event_handler_set_dmeventd_path(struct dm_event_handler *dmevh, const char *dmeventd_path)
@ -80,9 +81,9 @@ int dm_event_handler_set_dmeventd_path(struct dm_event_handler *dmevh, const cha
if (!dmeventd_path) /* noop */ if (!dmeventd_path) /* noop */
return 0; return 0;
dm_free(dmevh->dmeventd_path); free(dmevh->dmeventd_path);
if (!(dmevh->dmeventd_path = dm_strdup(dmeventd_path))) if (!(dmevh->dmeventd_path = strdup(dmeventd_path)))
return -ENOMEM; return -ENOMEM;
return 0; return 0;
@ -93,9 +94,9 @@ int dm_event_handler_set_dso(struct dm_event_handler *dmevh, const char *path)
if (!path) /* noop */ if (!path) /* noop */
return 0; return 0;
dm_free(dmevh->dso); free(dmevh->dso);
if (!(dmevh->dso = dm_strdup(path))) if (!(dmevh->dso = strdup(path)))
return -ENOMEM; return -ENOMEM;
return 0; return 0;
@ -108,7 +109,7 @@ int dm_event_handler_set_dev_name(struct dm_event_handler *dmevh, const char *de
_dm_event_handler_clear_dev_info(dmevh); _dm_event_handler_clear_dev_info(dmevh);
if (!(dmevh->dev_name = dm_strdup(dev_name))) if (!(dmevh->dev_name = strdup(dev_name)))
return -ENOMEM; return -ENOMEM;
return 0; return 0;
@ -121,7 +122,7 @@ int dm_event_handler_set_uuid(struct dm_event_handler *dmevh, const char *uuid)
_dm_event_handler_clear_dev_info(dmevh); _dm_event_handler_clear_dev_info(dmevh);
if (!(dmevh->uuid = dm_strdup(uuid))) if (!(dmevh->uuid = strdup(uuid)))
return -ENOMEM; return -ENOMEM;
return 0; return 0;
@ -261,7 +262,7 @@ static int _daemon_read(struct dm_event_fifos *fifos,
if (header && (bytes == 2 * sizeof(uint32_t))) { if (header && (bytes == 2 * sizeof(uint32_t))) {
msg->cmd = ntohl(header[0]); msg->cmd = ntohl(header[0]);
msg->size = ntohl(header[1]); msg->size = ntohl(header[1]);
buf = msg->data = dm_malloc(msg->size); buf = msg->data = malloc(msg->size);
size = msg->size; size = msg->size;
bytes = 0; bytes = 0;
header = 0; header = 0;
@ -269,7 +270,7 @@ static int _daemon_read(struct dm_event_fifos *fifos,
} }
if (bytes != size) { if (bytes != size) {
dm_free(msg->data); free(msg->data);
msg->data = NULL; msg->data = NULL;
} }
return bytes == size; return bytes == size;
@ -372,13 +373,13 @@ int daemon_talk(struct dm_event_fifos *fifos,
*/ */
if (!_daemon_write(fifos, msg)) { if (!_daemon_write(fifos, msg)) {
stack; stack;
dm_free(msg->data); free(msg->data);
msg->data = NULL; msg->data = NULL;
return -EIO; return -EIO;
} }
do { do {
dm_free(msg->data); free(msg->data);
msg->data = NULL; msg->data = NULL;
if (!_daemon_read(fifos, msg)) { if (!_daemon_read(fifos, msg)) {
@ -621,7 +622,7 @@ static int _do_event(int cmd, char *dmeventd_path, struct dm_event_daemon_messag
ret = daemon_talk(&fifos, msg, DM_EVENT_CMD_HELLO, NULL, NULL, 0, 0); ret = daemon_talk(&fifos, msg, DM_EVENT_CMD_HELLO, NULL, NULL, 0, 0);
dm_free(msg->data); free(msg->data);
msg->data = 0; msg->data = 0;
if (!ret) if (!ret)
@ -661,7 +662,7 @@ int dm_event_register_handler(const struct dm_event_handler *dmevh)
ret = 0; ret = 0;
} }
dm_free(msg.data); free(msg.data);
dm_task_destroy(dmt); dm_task_destroy(dmt);
@ -688,7 +689,7 @@ int dm_event_unregister_handler(const struct dm_event_handler *dmevh)
ret = 0; ret = 0;
} }
dm_free(msg.data); free(msg.data);
dm_task_destroy(dmt); dm_task_destroy(dmt);
@ -704,7 +705,7 @@ static char *_fetch_string(char **src, const int delimiter)
if ((p = strchr(*src, delimiter))) if ((p = strchr(*src, delimiter)))
*p = 0; *p = 0;
if ((ret = dm_strdup(*src))) if ((ret = strdup(*src)))
*src += strlen(ret) + 1; *src += strlen(ret) + 1;
if (p) if (p)
@ -724,11 +725,11 @@ static int _parse_message(struct dm_event_daemon_message *msg, char **dso_name,
(*dso_name = _fetch_string(&p, ' ')) && (*dso_name = _fetch_string(&p, ' ')) &&
(*uuid = _fetch_string(&p, ' '))) { (*uuid = _fetch_string(&p, ' '))) {
*evmask = atoi(p); *evmask = atoi(p);
dm_free(id); free(id);
return 0; return 0;
} }
dm_free(id); free(id);
return -ENOMEM; return -ENOMEM;
} }
@ -770,7 +771,7 @@ int dm_event_get_registered_device(struct dm_event_handler *dmevh, int next)
dm_task_destroy(dmt); dm_task_destroy(dmt);
dmt = NULL; dmt = NULL;
dm_free(msg.data); free(msg.data);
msg.data = NULL; msg.data = NULL;
_dm_event_handler_clear_dev_info(dmevh); _dm_event_handler_clear_dev_info(dmevh);
@ -779,7 +780,7 @@ int dm_event_get_registered_device(struct dm_event_handler *dmevh, int next)
goto fail; goto fail;
} }
if (!(dmevh->uuid = dm_strdup(reply_uuid))) { if (!(dmevh->uuid = strdup(reply_uuid))) {
ret = -ENOMEM; ret = -ENOMEM;
goto fail; goto fail;
} }
@ -792,13 +793,13 @@ int dm_event_get_registered_device(struct dm_event_handler *dmevh, int next)
dm_event_handler_set_dso(dmevh, reply_dso); dm_event_handler_set_dso(dmevh, reply_dso);
dm_event_handler_set_event_mask(dmevh, reply_mask); dm_event_handler_set_event_mask(dmevh, reply_mask);
dm_free(reply_dso); free(reply_dso);
reply_dso = NULL; reply_dso = NULL;
dm_free(reply_uuid); free(reply_uuid);
reply_uuid = NULL; reply_uuid = NULL;
if (!(dmevh->dev_name = dm_strdup(dm_task_get_name(dmt)))) { if (!(dmevh->dev_name = strdup(dm_task_get_name(dmt)))) {
ret = -ENOMEM; ret = -ENOMEM;
goto fail; goto fail;
} }
@ -816,9 +817,9 @@ int dm_event_get_registered_device(struct dm_event_handler *dmevh, int next)
return ret; return ret;
fail: fail:
dm_free(msg.data); free(msg.data);
dm_free(reply_dso); free(reply_dso);
dm_free(reply_uuid); free(reply_uuid);
_dm_event_handler_clear_dev_info(dmevh); _dm_event_handler_clear_dev_info(dmevh);
if (dmt) if (dmt)
dm_task_destroy(dmt); dm_task_destroy(dmt);
@ -983,12 +984,12 @@ int dm_event_get_timeout(const char *device_path, uint32_t *timeout)
if (!p) { if (!p) {
log_error("Malformed reply from dmeventd '%s'.", log_error("Malformed reply from dmeventd '%s'.",
msg.data); msg.data);
dm_free(msg.data); free(msg.data);
return -EIO; return -EIO;
} }
*timeout = atoi(p); *timeout = atoi(p);
} }
dm_free(msg.data); free(msg.data);
return ret; return ret;
} }

View File

@ -311,7 +311,7 @@ static int _parse_args(int argc, char **argv, struct filemap_monitor *fm)
return 0; return 0;
} }
fm->path = dm_strdup(argv[0]); fm->path = strdup(argv[0]);
if (!fm->path) { if (!fm->path) {
_early_log("Could not allocate memory for path argument."); _early_log("Could not allocate memory for path argument.");
return 0; return 0;
@ -538,8 +538,8 @@ static void _filemap_monitor_destroy(struct filemap_monitor *fm)
_filemap_monitor_end_notify(fm); _filemap_monitor_end_notify(fm);
_filemap_monitor_close_fd(fm); _filemap_monitor_close_fd(fm);
} }
dm_free((void *) fm->program_id); free((void *) fm->program_id);
dm_free(fm->path); free(fm->path);
} }
static int _filemap_monitor_check_same_file(int fd1, int fd2) static int _filemap_monitor_check_same_file(int fd1, int fd2)
@ -699,7 +699,7 @@ static int _update_regions(struct dm_stats *dms, struct filemap_monitor *fm)
fm->group_id, regions[0]); fm->group_id, regions[0]);
fm->group_id = regions[0]; fm->group_id = regions[0];
} }
dm_free(regions); free(regions);
fm->nr_regions = nr_regions; fm->nr_regions = nr_regions;
return 1; return 1;
} }
@ -741,7 +741,7 @@ static int _dmfilemapd(struct filemap_monitor *fm)
*/ */
program_id = dm_stats_get_region_program_id(dms, fm->group_id); program_id = dm_stats_get_region_program_id(dms, fm->group_id);
if (program_id) if (program_id)
fm->program_id = dm_strdup(program_id); fm->program_id = strdup(program_id);
else else
fm->program_id = NULL; fm->program_id = NULL;
dm_stats_set_program_id(dms, 1, program_id); dm_stats_set_program_id(dms, 1, program_id);
@ -817,7 +817,7 @@ int main(int argc, char **argv)
memset(&fm, 0, sizeof(fm)); memset(&fm, 0, sizeof(fm));
if (!_parse_args(argc, argv, &fm)) { if (!_parse_args(argc, argv, &fm)) {
dm_free(fm.path); free(fm.path);
return 1; return 1;
} }
@ -828,7 +828,7 @@ int main(int argc, char **argv)
_mode_names[fm.mode], fm.path); _mode_names[fm.mode], fm.path);
if (!_foreground && !_daemonise(&fm)) { if (!_foreground && !_daemonise(&fm)) {
dm_free(fm.path); free(fm.path);
return 1; return 1;
} }

View File

@ -259,19 +259,19 @@ static void destroy_metadata_hashes(lvmetad_state *s)
dm_config_destroy(dm_hash_get_data(s->pvid_to_pvmeta, n)); dm_config_destroy(dm_hash_get_data(s->pvid_to_pvmeta, n));
dm_hash_iterate(n, s->vgid_to_vgname) dm_hash_iterate(n, s->vgid_to_vgname)
dm_free(dm_hash_get_data(s->vgid_to_vgname, n)); free(dm_hash_get_data(s->vgid_to_vgname, n));
dm_hash_iterate(n, s->vgname_to_vgid) dm_hash_iterate(n, s->vgname_to_vgid)
dm_free(dm_hash_get_data(s->vgname_to_vgid, n)); free(dm_hash_get_data(s->vgname_to_vgid, n));
dm_hash_iterate(n, s->vgid_to_info) dm_hash_iterate(n, s->vgid_to_info)
dm_free(dm_hash_get_data(s->vgid_to_info, n)); free(dm_hash_get_data(s->vgid_to_info, n));
dm_hash_iterate(n, s->device_to_pvid) dm_hash_iterate(n, s->device_to_pvid)
dm_free(dm_hash_get_data(s->device_to_pvid, n)); free(dm_hash_get_data(s->device_to_pvid, n));
dm_hash_iterate(n, s->pvid_to_vgid) dm_hash_iterate(n, s->pvid_to_vgid)
dm_free(dm_hash_get_data(s->pvid_to_vgid, n)); free(dm_hash_get_data(s->pvid_to_vgid, n));
dm_hash_destroy(s->pvid_to_pvmeta); dm_hash_destroy(s->pvid_to_pvmeta);
dm_hash_destroy(s->vgid_to_metadata); dm_hash_destroy(s->vgid_to_metadata);
@ -818,19 +818,19 @@ static int _update_pvid_to_vgid(lvmetad_state *s, struct dm_config_tree *vg,
if (mode == MARK_OUTDATED) if (mode == MARK_OUTDATED)
mark_outdated_pv(s, vgid, pvid); mark_outdated_pv(s, vgid, pvid);
if (!(vgid_dup = dm_strdup(vgid))) { if (!(vgid_dup = strdup(vgid))) {
ERROR(s, "update_pvid_to_vgid out of memory for vgid %s", vgid); ERROR(s, "update_pvid_to_vgid out of memory for vgid %s", vgid);
goto abort_daemon; goto abort_daemon;
} }
if (!dm_hash_insert(s->pvid_to_vgid, pvid, vgid_dup)) { if (!dm_hash_insert(s->pvid_to_vgid, pvid, vgid_dup)) {
ERROR(s, "update_pvid_to_vgid out of memory for hash insert vgid %s", vgid_dup); ERROR(s, "update_pvid_to_vgid out of memory for hash insert vgid %s", vgid_dup);
dm_free(vgid_dup); free(vgid_dup);
goto abort_daemon; goto abort_daemon;
} }
/* pvid_to_vgid no longer references vgid_old */ /* pvid_to_vgid no longer references vgid_old */
dm_free(vgid_old); free(vgid_old);
DEBUGLOG(s, "moving PV %s to VG %s", pvid, vgid); DEBUGLOG(s, "moving PV %s to VG %s", pvid, vgid);
} }
@ -889,9 +889,9 @@ static int remove_metadata(lvmetad_state *s, const char *vgid, int update_pvids)
dm_config_destroy(meta_lookup); dm_config_destroy(meta_lookup);
if (outdated_pvs_lookup) if (outdated_pvs_lookup)
dm_config_destroy(outdated_pvs_lookup); dm_config_destroy(outdated_pvs_lookup);
dm_free(info_lookup); free(info_lookup);
dm_free(name_lookup); free(name_lookup);
dm_free(vgid_lookup); free(vgid_lookup);
return 1; return 1;
} }
@ -950,7 +950,7 @@ static void _purge_metadata(lvmetad_state *s, const char *arg_name, const char *
if ((rem_vgid = dm_hash_lookup_with_val(s->vgname_to_vgid, arg_name, arg_vgid, strlen(arg_vgid) + 1))) { if ((rem_vgid = dm_hash_lookup_with_val(s->vgname_to_vgid, arg_name, arg_vgid, strlen(arg_vgid) + 1))) {
dm_hash_remove_with_val(s->vgname_to_vgid, arg_name, arg_vgid, strlen(arg_vgid) + 1); dm_hash_remove_with_val(s->vgname_to_vgid, arg_name, arg_vgid, strlen(arg_vgid) + 1);
dm_free(rem_vgid); free(rem_vgid);
} }
} }
@ -978,10 +978,10 @@ static int _update_metadata_new_vgid(lvmetad_state *s,
int abort_daemon = 0; int abort_daemon = 0;
int retval = 0; int retval = 0;
if (!(new_vgid_dup = dm_strdup(new_vgid))) if (!(new_vgid_dup = strdup(new_vgid)))
goto ret; goto ret;
if (!(arg_name_dup = dm_strdup(arg_name))) if (!(arg_name_dup = strdup(arg_name)))
goto ret; goto ret;
/* /*
@ -999,7 +999,7 @@ static int _update_metadata_new_vgid(lvmetad_state *s,
if ((rem_info = dm_hash_lookup(s->vgid_to_info, old_vgid))) { if ((rem_info = dm_hash_lookup(s->vgid_to_info, old_vgid))) {
dm_hash_remove(s->vgid_to_info, old_vgid); dm_hash_remove(s->vgid_to_info, old_vgid);
dm_free(rem_info); free(rem_info);
} }
if ((rem_outdated = dm_hash_lookup(s->vgid_to_outdated_pvs, old_vgid))) { if ((rem_outdated = dm_hash_lookup(s->vgid_to_outdated_pvs, old_vgid))) {
@ -1013,7 +1013,7 @@ static int _update_metadata_new_vgid(lvmetad_state *s,
dm_hash_remove_with_val(s->vgname_to_vgid, arg_name, old_vgid, strlen(old_vgid) + 1); dm_hash_remove_with_val(s->vgname_to_vgid, arg_name, old_vgid, strlen(old_vgid) + 1);
dm_hash_remove(s->vgid_to_vgname, old_vgid); dm_hash_remove(s->vgid_to_vgname, old_vgid);
dm_free((char *)old_vgid); free((char *)old_vgid);
old_vgid = NULL; old_vgid = NULL;
/* /*
@ -1085,10 +1085,10 @@ static int _update_metadata_new_name(lvmetad_state *s,
int abort_daemon = 0; int abort_daemon = 0;
int retval = 0; int retval = 0;
if (!(new_name_dup = dm_strdup(new_name))) if (!(new_name_dup = strdup(new_name)))
goto ret; goto ret;
if (!(arg_vgid_dup = dm_strdup(arg_vgid))) if (!(arg_vgid_dup = strdup(arg_vgid)))
goto ret; goto ret;
/* /*
@ -1106,7 +1106,7 @@ static int _update_metadata_new_name(lvmetad_state *s,
if ((rem_info = dm_hash_lookup(s->vgid_to_info, arg_vgid))) { if ((rem_info = dm_hash_lookup(s->vgid_to_info, arg_vgid))) {
dm_hash_remove(s->vgid_to_info, arg_vgid); dm_hash_remove(s->vgid_to_info, arg_vgid);
dm_free(rem_info); free(rem_info);
} }
if ((rem_outdated = dm_hash_lookup(s->vgid_to_outdated_pvs, arg_vgid))) { if ((rem_outdated = dm_hash_lookup(s->vgid_to_outdated_pvs, arg_vgid))) {
@ -1120,7 +1120,7 @@ static int _update_metadata_new_name(lvmetad_state *s,
dm_hash_remove(s->vgid_to_vgname, arg_vgid); dm_hash_remove(s->vgid_to_vgname, arg_vgid);
dm_hash_remove_with_val(s->vgname_to_vgid, old_name, arg_vgid, strlen(arg_vgid) + 1); dm_hash_remove_with_val(s->vgname_to_vgid, old_name, arg_vgid, strlen(arg_vgid) + 1);
dm_free((char *)old_name); free((char *)old_name);
old_name = NULL; old_name = NULL;
/* /*
@ -1183,10 +1183,10 @@ static int _update_metadata_add_new(lvmetad_state *s, const char *new_name, cons
DEBUGLOG(s, "update_metadata_add_new for %s %s", new_name, new_vgid); DEBUGLOG(s, "update_metadata_add_new for %s %s", new_name, new_vgid);
if (!(new_name_dup = dm_strdup(new_name))) if (!(new_name_dup = strdup(new_name)))
goto out_free; goto out_free;
if (!(new_vgid_dup = dm_strdup(new_vgid))) if (!(new_vgid_dup = strdup(new_vgid)))
goto out_free; goto out_free;
if (!dm_hash_insert(s->vgid_to_metadata, new_vgid, new_meta)) { if (!dm_hash_insert(s->vgid_to_metadata, new_vgid, new_meta)) {
@ -1218,8 +1218,8 @@ static int _update_metadata_add_new(lvmetad_state *s, const char *new_name, cons
out: out:
out_free: out_free:
if (!new_name_dup || !new_vgid_dup || abort_daemon) { if (!new_name_dup || !new_vgid_dup || abort_daemon) {
dm_free(new_name_dup); free(new_name_dup);
dm_free(new_vgid_dup); free(new_vgid_dup);
ERROR(s, "lvmetad could not be updated and is aborting."); ERROR(s, "lvmetad could not be updated and is aborting.");
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
@ -1799,17 +1799,17 @@ static response pv_gone(lvmetad_state *s, request r)
* mappings for this vg, which will free the "vgid" string that * mappings for this vg, which will free the "vgid" string that
* was returned above from the pvid_to_vgid lookup. * was returned above from the pvid_to_vgid lookup.
*/ */
if (!(vgid_dup = dm_strdup(vgid))) if (!(vgid_dup = strdup(vgid)))
return reply_fail("out of memory"); return reply_fail("out of memory");
vg_remove_if_missing(s, vgid_dup, 1); vg_remove_if_missing(s, vgid_dup, 1);
dm_free(vgid_dup); free(vgid_dup);
vgid_dup = NULL; vgid_dup = NULL;
vgid = NULL; vgid = NULL;
} }
dm_config_destroy(pvmeta); dm_config_destroy(pvmeta);
dm_free(old_pvid); free(old_pvid);
return daemon_reply_simple("OK", NULL ); return daemon_reply_simple("OK", NULL );
} }
@ -2082,7 +2082,7 @@ static response pv_found(lvmetad_state *s, request r)
DEBUGLOG(s, "pv_found new entry device_to_pvid %" PRIu64 " to %s", DEBUGLOG(s, "pv_found new entry device_to_pvid %" PRIu64 " to %s",
new_device, new_pvid); new_device, new_pvid);
if (!(new_pvid_dup = dm_strdup(new_pvid))) if (!(new_pvid_dup = strdup(new_pvid)))
goto nomem_free1; goto nomem_free1;
if (!dm_hash_insert_binary(s->device_to_pvid, &new_device, sizeof(new_device), new_pvid_dup)) if (!dm_hash_insert_binary(s->device_to_pvid, &new_device, sizeof(new_device), new_pvid_dup))
@ -2122,7 +2122,7 @@ static response pv_found(lvmetad_state *s, request r)
arg_device, arg_pvid); arg_device, arg_pvid);
dm_config_destroy(new_pvmeta); dm_config_destroy(new_pvmeta);
/* device_to_pvid no longer references prev_pvid_lookup */ /* device_to_pvid no longer references prev_pvid_lookup */
dm_free((void*)prev_pvid_on_dev); free((void*)prev_pvid_on_dev);
s->flags |= GLFL_DISABLE; s->flags |= GLFL_DISABLE;
s->flags |= GLFL_DISABLE_REASON_DUPLICATES; s->flags |= GLFL_DISABLE_REASON_DUPLICATES;
return reply_fail("Ignore duplicate PV"); return reply_fail("Ignore duplicate PV");
@ -2130,7 +2130,7 @@ static response pv_found(lvmetad_state *s, request r)
} }
if (!(new_pvid_dup = dm_strdup(new_pvid))) if (!(new_pvid_dup = strdup(new_pvid)))
goto nomem_free1; goto nomem_free1;
if (!dm_hash_insert_binary(s->device_to_pvid, &arg_device, sizeof(arg_device), new_pvid_dup)) if (!dm_hash_insert_binary(s->device_to_pvid, &arg_device, sizeof(arg_device), new_pvid_dup))
@ -2218,22 +2218,22 @@ static response pv_found(lvmetad_state *s, request r)
char *tmp_vgid; char *tmp_vgid;
if (!arg_vgid || strcmp(arg_vgid, prev_vgid_on_dev)) { if (!arg_vgid || strcmp(arg_vgid, prev_vgid_on_dev)) {
tmp_vgid = dm_strdup(prev_vgid_on_dev); tmp_vgid = strdup(prev_vgid_on_dev);
/* vg_remove_if_missing will clear and free /* vg_remove_if_missing will clear and free
the string pointed to by prev_vgid_on_dev. */ the string pointed to by prev_vgid_on_dev. */
vg_remove_if_missing(s, tmp_vgid, 1); vg_remove_if_missing(s, tmp_vgid, 1);
dm_free(tmp_vgid); free(tmp_vgid);
} }
/* vg_remove_if_missing may have remapped prev_pvid_on_dev to orphan */ /* vg_remove_if_missing may have remapped prev_pvid_on_dev to orphan */
if ((tmp_vgid = dm_hash_lookup(s->pvid_to_vgid, prev_pvid_on_dev))) { if ((tmp_vgid = dm_hash_lookup(s->pvid_to_vgid, prev_pvid_on_dev))) {
dm_hash_remove(s->pvid_to_vgid, prev_pvid_on_dev); dm_hash_remove(s->pvid_to_vgid, prev_pvid_on_dev);
dm_free(tmp_vgid); free(tmp_vgid);
} }
} }
/* This was unhashed from device_to_pvid above. */ /* This was unhashed from device_to_pvid above. */
dm_free((void *)prev_pvid_on_dev); free((void *)prev_pvid_on_dev);
return daemon_reply_simple("OK", return daemon_reply_simple("OK",
"status = %s", vg_status, "status = %s", vg_status,
@ -2245,7 +2245,7 @@ static response pv_found(lvmetad_state *s, request r)
NULL); NULL);
nomem_free2: nomem_free2:
dm_free(new_pvid_dup); free(new_pvid_dup);
nomem_free1: nomem_free1:
dm_config_destroy(new_pvmeta); dm_config_destroy(new_pvmeta);
nomem: nomem:
@ -2525,7 +2525,7 @@ inval:
info = dm_hash_lookup(s->vgid_to_info, uuid); info = dm_hash_lookup(s->vgid_to_info, uuid);
if (!info) { if (!info) {
if (!(info = dm_zalloc(sizeof(struct vg_info)))) if (!(info = zalloc(sizeof(struct vg_info))))
goto bad; goto bad;
if (!dm_hash_insert(s->vgid_to_info, uuid, (void*)info)) if (!dm_hash_insert(s->vgid_to_info, uuid, (void*)info))
goto bad; goto bad;
@ -2570,7 +2570,7 @@ static void _dump_pairs(struct buffer *buf, struct dm_hash_table *ht, const char
(void) dm_asprintf(&append, " %s = \"%s\"\n", key, val); (void) dm_asprintf(&append, " %s = \"%s\"\n", key, val);
if (append) if (append)
buffer_append(buf, append); buffer_append(buf, append);
dm_free(append); free(append);
} }
buffer_append(buf, "}\n"); buffer_append(buf, "}\n");
} }
@ -2590,7 +2590,7 @@ static void _dump_info_version(struct buffer *buf, struct dm_hash_table *ht, con
(void) dm_asprintf(&append, " %s = %lld\n", key, (long long)info->external_version); (void) dm_asprintf(&append, " %s = %lld\n", key, (long long)info->external_version);
if (append) if (append)
buffer_append(buf, append); buffer_append(buf, append);
dm_free(append); free(append);
n = dm_hash_get_next(ht, n); n = dm_hash_get_next(ht, n);
} }
buffer_append(buf, "}\n"); buffer_append(buf, "}\n");
@ -2611,7 +2611,7 @@ static void _dump_info_flags(struct buffer *buf, struct dm_hash_table *ht, const
(void) dm_asprintf(&append, " %s = %llx\n", key, (long long)info->flags); (void) dm_asprintf(&append, " %s = %llx\n", key, (long long)info->flags);
if (append) if (append)
buffer_append(buf, append); buffer_append(buf, append);
dm_free(append); free(append);
n = dm_hash_get_next(ht, n); n = dm_hash_get_next(ht, n);
} }
buffer_append(buf, "}\n"); buffer_append(buf, "}\n");

View File

@ -36,7 +36,7 @@ static int add_to_cmd_arr(const char ***cmdargv, const char *str, unsigned *ind)
const char **newargv; const char **newargv;
if (*ind && !(*ind % MIN_ARGV_SIZE)) { if (*ind && !(*ind % MIN_ARGV_SIZE)) {
newargv = dm_realloc(*cmdargv, (*ind / MIN_ARGV_SIZE + 1) * MIN_ARGV_SIZE * sizeof(char *)); newargv = realloc(*cmdargv, (*ind / MIN_ARGV_SIZE + 1) * MIN_ARGV_SIZE * sizeof(char *));
if (!newargv) if (!newargv)
return 0; return 0;
*cmdargv = newargv; *cmdargv = newargv;
@ -50,7 +50,7 @@ static int add_to_cmd_arr(const char ***cmdargv, const char *str, unsigned *ind)
const char **cmdargv_ctr(const struct lvmpolld_lv *pdlv, const char *lvm_binary, unsigned abort_polling, unsigned handle_missing_pvs) const char **cmdargv_ctr(const struct lvmpolld_lv *pdlv, const char *lvm_binary, unsigned abort_polling, unsigned handle_missing_pvs)
{ {
unsigned i = 0; unsigned i = 0;
const char **cmd_argv = dm_malloc(MIN_ARGV_SIZE * sizeof(char *)); const char **cmd_argv = malloc(MIN_ARGV_SIZE * sizeof(char *));
if (!cmd_argv) if (!cmd_argv)
return NULL; return NULL;
@ -98,7 +98,7 @@ const char **cmdargv_ctr(const struct lvmpolld_lv *pdlv, const char *lvm_binary,
return cmd_argv; return cmd_argv;
err: err:
dm_free(cmd_argv); free(cmd_argv);
return NULL; return NULL;
} }
@ -122,7 +122,7 @@ static int copy_env(const char ***cmd_envp, unsigned *i, const char *exclude)
const char **cmdenvp_ctr(const struct lvmpolld_lv *pdlv) const char **cmdenvp_ctr(const struct lvmpolld_lv *pdlv)
{ {
unsigned i = 0; unsigned i = 0;
const char **cmd_envp = dm_malloc(MIN_ARGV_SIZE * sizeof(char *)); const char **cmd_envp = malloc(MIN_ARGV_SIZE * sizeof(char *));
if (!cmd_envp) if (!cmd_envp)
return NULL; return NULL;
@ -141,6 +141,6 @@ const char **cmdenvp_ctr(const struct lvmpolld_lv *pdlv)
return cmd_envp; return cmd_envp;
err: err:
dm_free(cmd_envp); free(cmd_envp);
return NULL; return NULL;
} }

View File

@ -530,7 +530,7 @@ static response progress_info(client_handle h, struct lvmpolld_state *ls, reques
pdst_unlock(pdst); pdst_unlock(pdst);
dm_free(id); free(id);
if (pdlv) { if (pdlv) {
if (st.error) if (st.error)
@ -673,7 +673,7 @@ static response poll_init(client_handle h, struct lvmpolld_state *ls, request re
PD_LOG_PREFIX, "poll operation type mismatch on LV identified by", PD_LOG_PREFIX, "poll operation type mismatch on LV identified by",
id, id,
polling_op(pdlv_get_type(pdlv)), polling_op(type)); polling_op(pdlv_get_type(pdlv)), polling_op(type));
dm_free(id); free(id);
return reply(LVMPD_RESP_EINVAL, return reply(LVMPD_RESP_EINVAL,
REASON_DIFFERENT_OPERATION_IN_PROGRESS); REASON_DIFFERENT_OPERATION_IN_PROGRESS);
} }
@ -683,14 +683,14 @@ static response poll_init(client_handle h, struct lvmpolld_state *ls, request re
lvname, sysdir, type, abort_polling, 2 * uinterval); lvname, sysdir, type, abort_polling, 2 * uinterval);
if (!pdlv) { if (!pdlv) {
pdst_unlock(pdst); pdst_unlock(pdst);
dm_free(id); free(id);
return reply(LVMPD_RESP_FAILED, REASON_ENOMEM); return reply(LVMPD_RESP_FAILED, REASON_ENOMEM);
} }
if (!pdst_locked_insert(pdst, id, pdlv)) { if (!pdst_locked_insert(pdst, id, pdlv)) {
pdlv_destroy(pdlv); pdlv_destroy(pdlv);
pdst_unlock(pdst); pdst_unlock(pdst);
ERROR(ls, "%s: %s", PD_LOG_PREFIX, "couldn't store internal LV data structure"); ERROR(ls, "%s: %s", PD_LOG_PREFIX, "couldn't store internal LV data structure");
dm_free(id); free(id);
return reply(LVMPD_RESP_FAILED, REASON_ENOMEM); return reply(LVMPD_RESP_FAILED, REASON_ENOMEM);
} }
if (!spawn_detached_thread(pdlv)) { if (!spawn_detached_thread(pdlv)) {
@ -698,7 +698,7 @@ static response poll_init(client_handle h, struct lvmpolld_state *ls, request re
pdst_locked_remove(pdst, id); pdst_locked_remove(pdst, id);
pdlv_destroy(pdlv); pdlv_destroy(pdlv);
pdst_unlock(pdst); pdst_unlock(pdst);
dm_free(id); free(id);
return reply(LVMPD_RESP_FAILED, REASON_ENOMEM); return reply(LVMPD_RESP_FAILED, REASON_ENOMEM);
} }
@ -709,7 +709,7 @@ static response poll_init(client_handle h, struct lvmpolld_state *ls, request re
pdst_unlock(pdst); pdst_unlock(pdst);
dm_free(id); free(id);
return daemon_reply_simple(LVMPD_RESP_OK, NULL); return daemon_reply_simple(LVMPD_RESP_OK, NULL);
} }
@ -806,7 +806,7 @@ static int printout_raw_response(const char *prefix, const char *msg)
char *buf; char *buf;
char *pos; char *pos;
buf = dm_strdup(msg); buf = strdup(msg);
pos = buf; pos = buf;
if (!buf) if (!buf)
@ -819,7 +819,7 @@ static int printout_raw_response(const char *prefix, const char *msg)
_log_line(pos, &b); _log_line(pos, &b);
pos = next ? next + 1 : 0; pos = next ? next + 1 : 0;
} }
dm_free(buf); free(buf);
return 1; return 1;
} }

View File

@ -27,12 +27,12 @@ static char *_construct_full_lvname(const char *vgname, const char *lvname)
size_t l; size_t l;
l = strlen(vgname) + strlen(lvname) + 2; /* vg/lv and \0 */ l = strlen(vgname) + strlen(lvname) + 2; /* vg/lv and \0 */
name = (char *) dm_malloc(l * sizeof(char)); name = (char *) malloc(l * sizeof(char));
if (!name) if (!name)
return NULL; return NULL;
if (dm_snprintf(name, l, "%s/%s", vgname, lvname) < 0) { if (dm_snprintf(name, l, "%s/%s", vgname, lvname) < 0) {
dm_free(name); free(name);
name = NULL; name = NULL;
} }
@ -47,7 +47,7 @@ static char *_construct_lvm_system_dir_env(const char *sysdir)
* just single char to store NULL byte * just single char to store NULL byte
*/ */
size_t l = sysdir ? strlen(sysdir) + 16 : 1; size_t l = sysdir ? strlen(sysdir) + 16 : 1;
char *env = (char *) dm_malloc(l * sizeof(char)); char *env = (char *) malloc(l * sizeof(char));
if (!env) if (!env)
return NULL; return NULL;
@ -55,7 +55,7 @@ static char *_construct_lvm_system_dir_env(const char *sysdir)
*env = '\0'; *env = '\0';
if (sysdir && dm_snprintf(env, l, "%s%s", LVM_SYSTEM_DIR, sysdir) < 0) { if (sysdir && dm_snprintf(env, l, "%s%s", LVM_SYSTEM_DIR, sysdir) < 0) {
dm_free(env); free(env);
env = NULL; env = NULL;
} }
@ -74,7 +74,7 @@ char *construct_id(const char *sysdir, const char *uuid)
size_t l; size_t l;
l = strlen(uuid) + (sysdir ? strlen(sysdir) : 0) + 1; l = strlen(uuid) + (sysdir ? strlen(sysdir) : 0) + 1;
id = (char *) dm_malloc(l * sizeof(char)); id = (char *) malloc(l * sizeof(char));
if (!id) if (!id)
return NULL; return NULL;
@ -82,7 +82,7 @@ char *construct_id(const char *sysdir, const char *uuid)
dm_snprintf(id, l, "%s", uuid); dm_snprintf(id, l, "%s", uuid);
if (r < 0) { if (r < 0) {
dm_free(id); free(id);
id = NULL; id = NULL;
} }
@ -95,7 +95,7 @@ struct lvmpolld_lv *pdlv_create(struct lvmpolld_state *ls, const char *id,
const char *sinterval, unsigned pdtimeout, const char *sinterval, unsigned pdtimeout,
struct lvmpolld_store *pdst) struct lvmpolld_store *pdst)
{ {
char *lvmpolld_id = dm_strdup(id), /* copy */ char *lvmpolld_id = strdup(id), /* copy */
*full_lvname = _construct_full_lvname(vgname, lvname), /* copy */ *full_lvname = _construct_full_lvname(vgname, lvname), /* copy */
*lvm_system_dir_env = _construct_lvm_system_dir_env(sysdir); /* copy */ *lvm_system_dir_env = _construct_lvm_system_dir_env(sysdir); /* copy */
@ -106,12 +106,12 @@ struct lvmpolld_lv *pdlv_create(struct lvmpolld_state *ls, const char *id,
.lvid = _get_lvid(lvmpolld_id, sysdir), .lvid = _get_lvid(lvmpolld_id, sysdir),
.lvname = full_lvname, .lvname = full_lvname,
.lvm_system_dir_env = lvm_system_dir_env, .lvm_system_dir_env = lvm_system_dir_env,
.sinterval = dm_strdup(sinterval), /* copy */ .sinterval = strdup(sinterval), /* copy */
.pdtimeout = pdtimeout < MIN_POLLING_TIMEOUT ? MIN_POLLING_TIMEOUT : pdtimeout, .pdtimeout = pdtimeout < MIN_POLLING_TIMEOUT ? MIN_POLLING_TIMEOUT : pdtimeout,
.cmd_state = { .retcode = -1, .signal = 0 }, .cmd_state = { .retcode = -1, .signal = 0 },
.pdst = pdst, .pdst = pdst,
.init_rq_count = 1 .init_rq_count = 1
}, *pdlv = (struct lvmpolld_lv *) dm_malloc(sizeof(struct lvmpolld_lv)); }, *pdlv = (struct lvmpolld_lv *) malloc(sizeof(struct lvmpolld_lv));
if (!pdlv || !tmp.lvid || !tmp.lvname || !tmp.lvm_system_dir_env || !tmp.sinterval) if (!pdlv || !tmp.lvid || !tmp.lvname || !tmp.lvm_system_dir_env || !tmp.sinterval)
goto err; goto err;
@ -124,27 +124,27 @@ struct lvmpolld_lv *pdlv_create(struct lvmpolld_state *ls, const char *id,
return pdlv; return pdlv;
err: err:
dm_free((void *)full_lvname); free((void *)full_lvname);
dm_free((void *)lvmpolld_id); free((void *)lvmpolld_id);
dm_free((void *)lvm_system_dir_env); free((void *)lvm_system_dir_env);
dm_free((void *)tmp.sinterval); free((void *)tmp.sinterval);
dm_free((void *)pdlv); free((void *)pdlv);
return NULL; return NULL;
} }
void pdlv_destroy(struct lvmpolld_lv *pdlv) void pdlv_destroy(struct lvmpolld_lv *pdlv)
{ {
dm_free((void *)pdlv->lvmpolld_id); free((void *)pdlv->lvmpolld_id);
dm_free((void *)pdlv->lvname); free((void *)pdlv->lvname);
dm_free((void *)pdlv->sinterval); free((void *)pdlv->sinterval);
dm_free((void *)pdlv->lvm_system_dir_env); free((void *)pdlv->lvm_system_dir_env);
dm_free((void *)pdlv->cmdargv); free((void *)pdlv->cmdargv);
dm_free((void *)pdlv->cmdenvp); free((void *)pdlv->cmdenvp);
pthread_mutex_destroy(&pdlv->lock); pthread_mutex_destroy(&pdlv->lock);
dm_free((void *)pdlv); free((void *)pdlv);
} }
unsigned pdlv_get_polling_finished(struct lvmpolld_lv *pdlv) unsigned pdlv_get_polling_finished(struct lvmpolld_lv *pdlv)
@ -194,7 +194,7 @@ void pdlv_set_polling_finished(struct lvmpolld_lv *pdlv, unsigned finished)
struct lvmpolld_store *pdst_init(const char *name) struct lvmpolld_store *pdst_init(const char *name)
{ {
struct lvmpolld_store *pdst = (struct lvmpolld_store *) dm_malloc(sizeof(struct lvmpolld_store)); struct lvmpolld_store *pdst = (struct lvmpolld_store *) malloc(sizeof(struct lvmpolld_store));
if (!pdst) if (!pdst)
return NULL; return NULL;
@ -212,7 +212,7 @@ struct lvmpolld_store *pdst_init(const char *name)
err_mutex: err_mutex:
dm_hash_destroy(pdst->store); dm_hash_destroy(pdst->store);
err_hash: err_hash:
dm_free(pdst); free(pdst);
return NULL; return NULL;
} }
@ -223,7 +223,7 @@ void pdst_destroy(struct lvmpolld_store *pdst)
dm_hash_destroy(pdst->store); dm_hash_destroy(pdst->store);
pthread_mutex_destroy(&pdst->lock); pthread_mutex_destroy(&pdst->lock);
dm_free(pdst); free(pdst);
} }
void pdst_locked_lock_all_pdlvs(const struct lvmpolld_store *pdst) void pdst_locked_lock_all_pdlvs(const struct lvmpolld_store *pdst)
@ -321,7 +321,7 @@ void pdst_locked_destroy_all_pdlvs(const struct lvmpolld_store *pdst)
struct lvmpolld_thread_data *lvmpolld_thread_data_constructor(struct lvmpolld_lv *pdlv) struct lvmpolld_thread_data *lvmpolld_thread_data_constructor(struct lvmpolld_lv *pdlv)
{ {
struct lvmpolld_thread_data *data = (struct lvmpolld_thread_data *) dm_malloc(sizeof(struct lvmpolld_thread_data)); struct lvmpolld_thread_data *data = (struct lvmpolld_thread_data *) malloc(sizeof(struct lvmpolld_thread_data));
if (!data) if (!data)
return NULL; return NULL;
@ -368,7 +368,7 @@ void lvmpolld_thread_data_destroy(void *thread_private)
pdst_unlock(data->pdlv->pdst); pdst_unlock(data->pdlv->pdst);
} }
/* may get reallocated in getline(). dm_free must not be used */ /* may get reallocated in getline(). free must not be used */
free(data->line); free(data->line);
if (data->fout && !fclose(data->fout)) if (data->fout && !fclose(data->fout))
@ -389,5 +389,5 @@ void lvmpolld_thread_data_destroy(void *thread_private)
if (data->errpipe[1] >= 0) if (data->errpipe[1] >= 0)
(void) close(data->errpipe[1]); (void) close(data->errpipe[1]);
dm_free(data); free(data);
} }

View File

@ -12,8 +12,6 @@
DEVICE_MAPPER_SOURCE=\ DEVICE_MAPPER_SOURCE=\
device_mapper/datastruct/bitset.c \ device_mapper/datastruct/bitset.c \
device_mapper/datastruct/hash.c \
device_mapper/datastruct/list.c \
device_mapper/libdm-common.c \ device_mapper/libdm-common.c \
device_mapper/libdm-config.c \ device_mapper/libdm-config.c \
device_mapper/libdm-deptree.c \ device_mapper/libdm-deptree.c \
@ -23,7 +21,6 @@ DEVICE_MAPPER_SOURCE=\
device_mapper/libdm-string.c \ device_mapper/libdm-string.c \
device_mapper/libdm-targets.c \ device_mapper/libdm-targets.c \
device_mapper/libdm-timestamp.c \ device_mapper/libdm-timestamp.c \
device_mapper/mm/dbg_malloc.c \
device_mapper/mm/pool.c \ device_mapper/mm/pool.c \
device_mapper/regex/matcher.c \ device_mapper/regex/matcher.c \
device_mapper/regex/parse_rx.c \ device_mapper/regex/parse_rx.c \

View File

@ -31,6 +31,9 @@
#include <stdlib.h> #include <stdlib.h>
#include <stdio.h> #include <stdio.h>
#include "base/data-struct/list.h"
#include "base/data-struct/hash.h"
#ifndef __GNUC__ #ifndef __GNUC__
# define __typeof__ typeof # define __typeof__ typeof
#endif #endif
@ -41,10 +44,6 @@
#define DM_ARRAY_SIZE(a) (sizeof(a) / sizeof((a)[0])) #define DM_ARRAY_SIZE(a) (sizeof(a) / sizeof((a)[0]))
#ifdef __cplusplus
extern "C" {
#endif
/***************************************************************** /*****************************************************************
* The first section of this file provides direct access to the * The first section of this file provides direct access to the
* individual device-mapper ioctls. Since it is quite laborious to * individual device-mapper ioctls. Since it is quite laborious to
@ -822,7 +821,7 @@ int dm_stats_get_region_nr_histogram_bins(const struct dm_stats *dms,
* *
* On sucess a pointer to the struct dm_histogram representing the * On sucess a pointer to the struct dm_histogram representing the
* bounds values is returned, or NULL in the case of error. The returned * bounds values is returned, or NULL in the case of error. The returned
* pointer should be freed using dm_free() when no longer required. * pointer should be freed using free() when no longer required.
*/ */
struct dm_histogram *dm_histogram_bounds_from_string(const char *bounds_str); struct dm_histogram *dm_histogram_bounds_from_string(const char *bounds_str);
@ -1321,7 +1320,7 @@ int dm_stats_get_group_descriptor(const struct dm_stats *dms,
* On success the function returns a pointer to an array of uint64_t * On success the function returns a pointer to an array of uint64_t
* containing the IDs of the newly created regions. The region_id * containing the IDs of the newly created regions. The region_id
* array is terminated by the value DM_STATS_REGION_NOT_PRESENT and * array is terminated by the value DM_STATS_REGION_NOT_PRESENT and
* should be freed using dm_free() when no longer required. * should be freed using free() when no longer required.
* *
* On error NULL is returned. * On error NULL is returned.
* *
@ -1353,7 +1352,7 @@ uint64_t *dm_stats_create_regions_from_fd(struct dm_stats *dms, int fd,
* regions that were not modified by the call). * regions that were not modified by the call).
* *
* The region_id array is terminated by the special value * The region_id array is terminated by the special value
* DM_STATS_REGION_NOT_PRESENT and should be freed using dm_free() * DM_STATS_REGION_NOT_PRESENT and should be freed using free()
* when no longer required. * when no longer required.
* *
* On error NULL is returned. * On error NULL is returned.
@ -1474,7 +1473,7 @@ dm_string_mangling_t dm_get_name_mangling_mode(void);
/* /*
* Get mangled/unmangled form of the device-mapper name or uuid * Get mangled/unmangled form of the device-mapper name or uuid
* irrespective of the global setting (set by dm_set_name_mangling_mode). * irrespective of the global setting (set by dm_set_name_mangling_mode).
* The name or uuid returned needs to be freed after use by calling dm_free! * The name or uuid returned needs to be freed after use by calling free!
*/ */
char *dm_task_get_name_mangled(const struct dm_task *dmt); char *dm_task_get_name_mangled(const struct dm_task *dmt);
char *dm_task_get_name_unmangled(const struct dm_task *dmt); char *dm_task_get_name_unmangled(const struct dm_task *dmt);
@ -2066,35 +2065,7 @@ uint32_t dm_tree_get_cookie(struct dm_tree_node *node);
* Library functions * Library functions
*****************************************************************************/ *****************************************************************************/
/******************* #define malloc_aligned(s, a) malloc_aligned_wrapper((s), (a), __FILE__, __LINE__)
* Memory management
*******************/
/*
* Never use these functions directly - use the macros following instead.
*/
void *dm_malloc_wrapper(size_t s, const char *file, int line)
__attribute__((__malloc__)) __attribute__((__warn_unused_result__));
void *dm_malloc_aligned_wrapper(size_t s, size_t a, const char *file, int line)
__attribute__((__malloc__)) __attribute__((__warn_unused_result__));
void *dm_zalloc_wrapper(size_t s, const char *file, int line)
__attribute__((__malloc__)) __attribute__((__warn_unused_result__));
void *dm_realloc_wrapper(void *p, unsigned int s, const char *file, int line)
__attribute__((__warn_unused_result__));
void dm_free_wrapper(void *ptr);
char *dm_strdup_wrapper(const char *s, const char *file, int line)
__attribute__((__warn_unused_result__));
int dm_dump_memory_wrapper(void);
void dm_bounds_check_wrapper(void);
#define dm_malloc(s) dm_malloc_wrapper((s), __FILE__, __LINE__)
#define dm_malloc_aligned(s, a) dm_malloc_aligned_wrapper((s), (a), __FILE__, __LINE__)
#define dm_zalloc(s) dm_zalloc_wrapper((s), __FILE__, __LINE__)
#define dm_strdup(s) dm_strdup_wrapper((s), __FILE__, __LINE__)
#define dm_free(p) dm_free_wrapper(p)
#define dm_realloc(p, s) dm_realloc_wrapper((p), (s), __FILE__, __LINE__)
#define dm_dump_memory() dm_dump_memory_wrapper()
#define dm_bounds_check() dm_bounds_check_wrapper()
/* /*
* The pool allocator is useful when you are going to allocate * The pool allocator is useful when you are going to allocate
@ -2261,7 +2232,7 @@ int dm_bit_get_prev(dm_bitset_t bs, int last_bit);
* notation used is identical to the kernel bitmap parser (cpuset etc.) * notation used is identical to the kernel bitmap parser (cpuset etc.)
* and supports both lists ("1,2,3") and ranges ("1-2,5-8"). If the mem * and supports both lists ("1,2,3") and ranges ("1-2,5-8"). If the mem
* parameter is NULL memory for the bitset will be allocated using * parameter is NULL memory for the bitset will be allocated using
* dm_malloc(). Otherwise the bitset will be allocated using the supplied * malloc(). Otherwise the bitset will be allocated using the supplied
* dm_pool. * dm_pool.
*/ */
dm_bitset_t dm_bitset_parse_list(const char *str, struct dm_pool *mem, dm_bitset_t dm_bitset_parse_list(const char *str, struct dm_pool *mem,
@ -2278,299 +2249,6 @@ static inline unsigned hweight32(uint32_t i)
return (r & 0x0000FFFF) + ((r >> 16) & 0x0000FFFF); return (r & 0x0000FFFF) + ((r >> 16) & 0x0000FFFF);
} }
/****************
* hash functions
****************/
struct dm_hash_table;
struct dm_hash_node;
typedef void (*dm_hash_iterate_fn) (void *data);
struct dm_hash_table *dm_hash_create(unsigned size_hint)
__attribute__((__warn_unused_result__));
void dm_hash_destroy(struct dm_hash_table *t);
void dm_hash_wipe(struct dm_hash_table *t);
void *dm_hash_lookup(struct dm_hash_table *t, const char *key);
int dm_hash_insert(struct dm_hash_table *t, const char *key, void *data);
void dm_hash_remove(struct dm_hash_table *t, const char *key);
void *dm_hash_lookup_binary(struct dm_hash_table *t, const void *key, uint32_t len);
int dm_hash_insert_binary(struct dm_hash_table *t, const void *key, uint32_t len,
void *data);
void dm_hash_remove_binary(struct dm_hash_table *t, const void *key, uint32_t len);
unsigned dm_hash_get_num_entries(struct dm_hash_table *t);
void dm_hash_iter(struct dm_hash_table *t, dm_hash_iterate_fn f);
char *dm_hash_get_key(struct dm_hash_table *t, struct dm_hash_node *n);
void *dm_hash_get_data(struct dm_hash_table *t, struct dm_hash_node *n);
struct dm_hash_node *dm_hash_get_first(struct dm_hash_table *t);
struct dm_hash_node *dm_hash_get_next(struct dm_hash_table *t, struct dm_hash_node *n);
/*
* dm_hash_insert() replaces the value of an existing
* entry with a matching key if one exists. Otherwise
* it adds a new entry.
*
* dm_hash_insert_with_val() inserts a new entry if
* another entry with the same key already exists.
* val_len is the size of the data being inserted.
*
* If two entries with the same key exist,
* (added using dm_hash_insert_allow_multiple), then:
* . dm_hash_lookup() returns the first one it finds, and
* dm_hash_lookup_with_val() returns the one with a matching
* val_len/val.
* . dm_hash_remove() removes the first one it finds, and
* dm_hash_remove_with_val() removes the one with a matching
* val_len/val.
*
* If a single entry with a given key exists, and it has
* zero val_len, then:
* . dm_hash_lookup() returns it
* . dm_hash_lookup_with_val(val_len=0) returns it
* . dm_hash_remove() removes it
* . dm_hash_remove_with_val(val_len=0) removes it
*
* dm_hash_lookup_with_count() is a single call that will
* both lookup a key's value and check if there is more
* than one entry with the given key.
*
* (It is not meant to retrieve all the entries with the
* given key. In the common case where a single entry exists
* for the key, it is useful to have a single call that will
* both look up the value and indicate if multiple values
* exist for the key.)
*
* dm_hash_lookup_with_count:
* . If no entries exist, the function returns NULL, and
* the count is set to 0.
* . If only one entry exists, the value of that entry is
* returned and count is set to 1.
* . If N entries exists, the value of the first entry is
* returned and count is set to N.
*/
void *dm_hash_lookup_with_val(struct dm_hash_table *t, const char *key,
const void *val, uint32_t val_len);
void dm_hash_remove_with_val(struct dm_hash_table *t, const char *key,
const void *val, uint32_t val_len);
int dm_hash_insert_allow_multiple(struct dm_hash_table *t, const char *key,
const void *val, uint32_t val_len);
void *dm_hash_lookup_with_count(struct dm_hash_table *t, const char *key, int *count);
#define dm_hash_iterate(v, h) \
for (v = dm_hash_get_first((h)); v; \
v = dm_hash_get_next((h), v))
/****************
* list functions
****************/
/*
* A list consists of a list head plus elements.
* Each element has 'next' and 'previous' pointers.
* The list head's pointers point to the first and the last element.
*/
struct dm_list {
struct dm_list *n, *p;
};
/*
* String list.
*/
struct dm_str_list {
struct dm_list list;
const char *str;
};
/*
* Initialise a list before use.
* The list head's next and previous pointers point back to itself.
*/
#define DM_LIST_HEAD_INIT(name) { &(name), &(name) }
#define DM_LIST_INIT(name) struct dm_list name = DM_LIST_HEAD_INIT(name)
void dm_list_init(struct dm_list *head);
/*
* Insert an element before 'head'.
* If 'head' is the list head, this adds an element to the end of the list.
*/
void dm_list_add(struct dm_list *head, struct dm_list *elem);
/*
* Insert an element after 'head'.
* If 'head' is the list head, this adds an element to the front of the list.
*/
void dm_list_add_h(struct dm_list *head, struct dm_list *elem);
/*
* Delete an element from its list.
* Note that this doesn't change the element itself - it may still be safe
* to follow its pointers.
*/
void dm_list_del(struct dm_list *elem);
/*
* Remove an element from existing list and insert before 'head'.
*/
void dm_list_move(struct dm_list *head, struct dm_list *elem);
/*
* Join 'head1' to the end of 'head'.
*/
void dm_list_splice(struct dm_list *head, struct dm_list *head1);
/*
* Is the list empty?
*/
int dm_list_empty(const struct dm_list *head);
/*
* Is this the first element of the list?
*/
int dm_list_start(const struct dm_list *head, const struct dm_list *elem);
/*
* Is this the last element of the list?
*/
int dm_list_end(const struct dm_list *head, const struct dm_list *elem);
/*
* Return first element of the list or NULL if empty
*/
struct dm_list *dm_list_first(const struct dm_list *head);
/*
* Return last element of the list or NULL if empty
*/
struct dm_list *dm_list_last(const struct dm_list *head);
/*
* Return the previous element of the list, or NULL if we've reached the start.
*/
struct dm_list *dm_list_prev(const struct dm_list *head, const struct dm_list *elem);
/*
* Return the next element of the list, or NULL if we've reached the end.
*/
struct dm_list *dm_list_next(const struct dm_list *head, const struct dm_list *elem);
/*
* Given the address v of an instance of 'struct dm_list' called 'head'
* contained in a structure of type t, return the containing structure.
*/
#define dm_list_struct_base(v, t, head) \
((t *)((const char *)(v) - (const char *)&((t *) 0)->head))
/*
* Given the address v of an instance of 'struct dm_list list' contained in
* a structure of type t, return the containing structure.
*/
#define dm_list_item(v, t) dm_list_struct_base((v), t, list)
/*
* Given the address v of one known element e in a known structure of type t,
* return another element f.
*/
#define dm_struct_field(v, t, e, f) \
(((t *)((uintptr_t)(v) - (uintptr_t)&((t *) 0)->e))->f)
/*
* Given the address v of a known element e in a known structure of type t,
* return the list head 'list'
*/
#define dm_list_head(v, t, e) dm_struct_field(v, t, e, list)
/*
* Set v to each element of a list in turn.
*/
#define dm_list_iterate(v, head) \
for (v = (head)->n; v != head; v = v->n)
/*
* Set v to each element in a list in turn, starting from the element
* in front of 'start'.
* You can use this to 'unwind' a list_iterate and back out actions on
* already-processed elements.
* If 'start' is 'head' it walks the list backwards.
*/
#define dm_list_uniterate(v, head, start) \
for (v = (start)->p; v != head; v = v->p)
/*
* A safe way to walk a list and delete and free some elements along
* the way.
* t must be defined as a temporary variable of the same type as v.
*/
#define dm_list_iterate_safe(v, t, head) \
for (v = (head)->n, t = v->n; v != head; v = t, t = v->n)
/*
* Walk a list, setting 'v' in turn to the containing structure of each item.
* The containing structure should be the same type as 'v'.
* The 'struct dm_list' variable within the containing structure is 'field'.
*/
#define dm_list_iterate_items_gen(v, head, field) \
for (v = dm_list_struct_base((head)->n, __typeof__(*v), field); \
&v->field != (head); \
v = dm_list_struct_base(v->field.n, __typeof__(*v), field))
/*
* Walk a list, setting 'v' in turn to the containing structure of each item.
* The containing structure should be the same type as 'v'.
* The list should be 'struct dm_list list' within the containing structure.
*/
#define dm_list_iterate_items(v, head) dm_list_iterate_items_gen(v, (head), list)
/*
* Walk a list, setting 'v' in turn to the containing structure of each item.
* The containing structure should be the same type as 'v'.
* The 'struct dm_list' variable within the containing structure is 'field'.
* t must be defined as a temporary variable of the same type as v.
*/
#define dm_list_iterate_items_gen_safe(v, t, head, field) \
for (v = dm_list_struct_base((head)->n, __typeof__(*v), field), \
t = dm_list_struct_base(v->field.n, __typeof__(*v), field); \
&v->field != (head); \
v = t, t = dm_list_struct_base(v->field.n, __typeof__(*v), field))
/*
* Walk a list, setting 'v' in turn to the containing structure of each item.
* The containing structure should be the same type as 'v'.
* The list should be 'struct dm_list list' within the containing structure.
* t must be defined as a temporary variable of the same type as v.
*/
#define dm_list_iterate_items_safe(v, t, head) \
dm_list_iterate_items_gen_safe(v, t, (head), list)
/*
* Walk a list backwards, setting 'v' in turn to the containing structure
* of each item.
* The containing structure should be the same type as 'v'.
* The 'struct dm_list' variable within the containing structure is 'field'.
*/
#define dm_list_iterate_back_items_gen(v, head, field) \
for (v = dm_list_struct_base((head)->p, __typeof__(*v), field); \
&v->field != (head); \
v = dm_list_struct_base(v->field.p, __typeof__(*v), field))
/*
* Walk a list backwards, setting 'v' in turn to the containing structure
* of each item.
* The containing structure should be the same type as 'v'.
* The list should be 'struct dm_list list' within the containing structure.
*/
#define dm_list_iterate_back_items(v, head) dm_list_iterate_back_items_gen(v, (head), list)
/*
* Return the number of elements in a list by walking it.
*/
unsigned int dm_list_size(const struct dm_list *head);
/********* /*********
* selinux * selinux
*********/ *********/
@ -2758,7 +2436,7 @@ int dm_is_empty_dir(const char *dir);
int dm_fclose(FILE *stream); int dm_fclose(FILE *stream);
/* /*
* Returns size of a buffer which is allocated with dm_malloc. * Returns size of a buffer which is allocated with malloc.
* Pointer to the buffer is stored in *buf. * Pointer to the buffer is stored in *buf.
* Returns -1 on failure leaving buf undefined. * Returns -1 on failure leaving buf undefined.
*/ */
@ -3749,7 +3427,4 @@ int dm_udev_wait_immediate(uint32_t cookie, int *ready);
#define DM_DEV_DIR_UMASK 0022 #define DM_DEV_DIR_UMASK 0022
#define DM_CONTROL_NODE_UMASK 0177 #define DM_CONTROL_NODE_UMASK 0177
#ifdef __cplusplus
}
#endif
#endif /* LIB_DEVICE_MAPPER_H */ #endif /* LIB_DEVICE_MAPPER_H */

View File

@ -14,6 +14,7 @@
*/ */
#include "device_mapper/misc/dmlib.h" #include "device_mapper/misc/dmlib.h"
#include "base/memory/zalloc.h"
#include <ctype.h> #include <ctype.h>
@ -29,7 +30,7 @@ dm_bitset_t dm_bitset_create(struct dm_pool *mem, unsigned num_bits)
if (mem) if (mem)
bs = dm_pool_zalloc(mem, size); bs = dm_pool_zalloc(mem, size);
else else
bs = dm_zalloc(size); bs = zalloc(size);
if (!bs) if (!bs)
return NULL; return NULL;
@ -41,7 +42,7 @@ dm_bitset_t dm_bitset_create(struct dm_pool *mem, unsigned num_bits)
void dm_bitset_destroy(dm_bitset_t bs) void dm_bitset_destroy(dm_bitset_t bs)
{ {
dm_free(bs); free(bs);
} }
int dm_bitset_equal(dm_bitset_t in1, dm_bitset_t in2) int dm_bitset_equal(dm_bitset_t in1, dm_bitset_t in2)

View File

@ -13,6 +13,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "device_mapper/misc/dmlib.h" #include "device_mapper/misc/dmlib.h"
#include "device_mapper/ioctl/libdm-targets.h" #include "device_mapper/ioctl/libdm-targets.h"
#include "device_mapper/libdm-common.h" #include "device_mapper/libdm-common.h"
@ -467,7 +468,7 @@ static void _dm_zfree_string(char *string)
{ {
if (string) { if (string) {
memset(string, 0, strlen(string)); memset(string, 0, strlen(string));
dm_free(string); free(string);
} }
} }
@ -475,7 +476,7 @@ static void _dm_zfree_dmi(struct dm_ioctl *dmi)
{ {
if (dmi) { if (dmi) {
memset(dmi, 0, dmi->data_size); memset(dmi, 0, dmi->data_size);
dm_free(dmi); free(dmi);
} }
} }
@ -486,8 +487,8 @@ static void _dm_task_free_targets(struct dm_task *dmt)
for (t = dmt->head; t; t = n) { for (t = dmt->head; t; t = n) {
n = t->next; n = t->next;
_dm_zfree_string(t->params); _dm_zfree_string(t->params);
dm_free(t->type); free(t->type);
dm_free(t); free(t);
} }
dmt->head = dmt->tail = NULL; dmt->head = dmt->tail = NULL;
@ -497,14 +498,14 @@ void dm_task_destroy(struct dm_task *dmt)
{ {
_dm_task_free_targets(dmt); _dm_task_free_targets(dmt);
_dm_zfree_dmi(dmt->dmi.v4); _dm_zfree_dmi(dmt->dmi.v4);
dm_free(dmt->dev_name); free(dmt->dev_name);
dm_free(dmt->mangled_dev_name); free(dmt->mangled_dev_name);
dm_free(dmt->newname); free(dmt->newname);
dm_free(dmt->message); free(dmt->message);
dm_free(dmt->geometry); free(dmt->geometry);
dm_free(dmt->uuid); free(dmt->uuid);
dm_free(dmt->mangled_uuid); free(dmt->mangled_uuid);
dm_free(dmt); free(dmt);
} }
/* /*
@ -852,8 +853,8 @@ int dm_task_set_newuuid(struct dm_task *dmt, const char *newuuid)
newuuid = mangled_uuid; newuuid = mangled_uuid;
} }
dm_free(dmt->newname); free(dmt->newname);
if (!(dmt->newname = dm_strdup(newuuid))) { if (!(dmt->newname = strdup(newuuid))) {
log_error("dm_task_set_newuuid: strdup(%s) failed", newuuid); log_error("dm_task_set_newuuid: strdup(%s) failed", newuuid);
return 0; return 0;
} }
@ -864,8 +865,8 @@ int dm_task_set_newuuid(struct dm_task *dmt, const char *newuuid)
int dm_task_set_message(struct dm_task *dmt, const char *message) int dm_task_set_message(struct dm_task *dmt, const char *message)
{ {
dm_free(dmt->message); free(dmt->message);
if (!(dmt->message = dm_strdup(message))) { if (!(dmt->message = strdup(message))) {
log_error("dm_task_set_message: strdup failed"); log_error("dm_task_set_message: strdup failed");
return 0; return 0;
} }
@ -883,7 +884,7 @@ int dm_task_set_sector(struct dm_task *dmt, uint64_t sector)
int dm_task_set_geometry(struct dm_task *dmt, const char *cylinders, const char *heads, int dm_task_set_geometry(struct dm_task *dmt, const char *cylinders, const char *heads,
const char *sectors, const char *start) const char *sectors, const char *start)
{ {
dm_free(dmt->geometry); free(dmt->geometry);
if (dm_asprintf(&(dmt->geometry), "%s %s %s %s", if (dm_asprintf(&(dmt->geometry), "%s %s %s %s",
cylinders, heads, sectors, start) < 0) { cylinders, heads, sectors, start) < 0) {
log_error("dm_task_set_geometry: sprintf failed"); log_error("dm_task_set_geometry: sprintf failed");
@ -977,18 +978,18 @@ struct target *create_target(uint64_t start, uint64_t len, const char *type,
return NULL; return NULL;
} }
if (!(t = dm_zalloc(sizeof(*t)))) { if (!(t = zalloc(sizeof(*t)))) {
log_error("create_target: malloc(%" PRIsize_t ") failed", log_error("create_target: malloc(%" PRIsize_t ") failed",
sizeof(*t)); sizeof(*t));
return NULL; return NULL;
} }
if (!(t->params = dm_strdup(params))) { if (!(t->params = strdup(params))) {
log_error("create_target: strdup(params) failed"); log_error("create_target: strdup(params) failed");
goto bad; goto bad;
} }
if (!(t->type = dm_strdup(type))) { if (!(t->type = strdup(type))) {
log_error("create_target: strdup(type) failed"); log_error("create_target: strdup(type) failed");
goto bad; goto bad;
} }
@ -999,8 +1000,8 @@ struct target *create_target(uint64_t start, uint64_t len, const char *type,
bad: bad:
_dm_zfree_string(t->params); _dm_zfree_string(t->params);
dm_free(t->type); free(t->type);
dm_free(t); free(t);
return NULL; return NULL;
} }
@ -1168,7 +1169,7 @@ static struct dm_ioctl *_flatten(struct dm_task *dmt, unsigned repeat_count)
while (repeat_count--) while (repeat_count--)
len *= 2; len *= 2;
if (!(dmi = dm_zalloc(len))) if (!(dmi = zalloc(len)))
return NULL; return NULL;
version = &_cmd_data_v4[dmt->type].version; version = &_cmd_data_v4[dmt->type].version;
@ -1463,9 +1464,9 @@ static int _create_and_load_v4(struct dm_task *dmt)
/* Use the original structure last so the info will be correct */ /* Use the original structure last so the info will be correct */
dmt->type = DM_DEVICE_RESUME; dmt->type = DM_DEVICE_RESUME;
dm_free(dmt->uuid); free(dmt->uuid);
dmt->uuid = NULL; dmt->uuid = NULL;
dm_free(dmt->mangled_uuid); free(dmt->mangled_uuid);
dmt->mangled_uuid = NULL; dmt->mangled_uuid = NULL;
if (dm_task_run(dmt)) if (dm_task_run(dmt))
@ -1473,9 +1474,9 @@ static int _create_and_load_v4(struct dm_task *dmt)
revert: revert:
dmt->type = DM_DEVICE_REMOVE; dmt->type = DM_DEVICE_REMOVE;
dm_free(dmt->uuid); free(dmt->uuid);
dmt->uuid = NULL; dmt->uuid = NULL;
dm_free(dmt->mangled_uuid); free(dmt->mangled_uuid);
dmt->mangled_uuid = NULL; dmt->mangled_uuid = NULL;
/* /*
@ -2141,7 +2142,6 @@ void dm_lib_exit(void)
dm_bitset_destroy(_dm_bitset); dm_bitset_destroy(_dm_bitset);
_dm_bitset = NULL; _dm_bitset = NULL;
dm_pools_check_leaks(); dm_pools_check_leaks();
dm_dump_memory();
_version_ok = 1; _version_ok = 1;
_version_checked = 0; _version_checked = 0;
} }

View File

@ -13,6 +13,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "device_mapper/misc/dmlib.h" #include "device_mapper/misc/dmlib.h"
#include "ioctl/libdm-targets.h" #include "ioctl/libdm-targets.h"
#include "libdm-common.h" #include "libdm-common.h"
@ -308,7 +309,7 @@ dm_string_mangling_t dm_get_name_mangling_mode(void)
struct dm_task *dm_task_create(int type) struct dm_task *dm_task_create(int type)
{ {
struct dm_task *dmt = dm_zalloc(sizeof(*dmt)); struct dm_task *dmt = zalloc(sizeof(*dmt));
if (!dmt) { if (!dmt) {
log_error("dm_task_create: malloc(%" PRIsize_t ") failed", log_error("dm_task_create: malloc(%" PRIsize_t ") failed",
@ -317,7 +318,7 @@ struct dm_task *dm_task_create(int type)
} }
if (!dm_check_version()) { if (!dm_check_version()) {
dm_free(dmt); free(dmt);
return_NULL; return_NULL;
} }
@ -562,9 +563,9 @@ static int _dm_task_set_name(struct dm_task *dmt, const char *name,
char mangled_name[DM_NAME_LEN]; char mangled_name[DM_NAME_LEN];
int r = 0; int r = 0;
dm_free(dmt->dev_name); free(dmt->dev_name);
dmt->dev_name = NULL; dmt->dev_name = NULL;
dm_free(dmt->mangled_dev_name); free(dmt->mangled_dev_name);
dmt->mangled_dev_name = NULL; dmt->mangled_dev_name = NULL;
if (strlen(name) >= DM_NAME_LEN) { if (strlen(name) >= DM_NAME_LEN) {
@ -587,13 +588,13 @@ static int _dm_task_set_name(struct dm_task *dmt, const char *name,
log_debug_activation("Device name mangled [%s]: %s --> %s", log_debug_activation("Device name mangled [%s]: %s --> %s",
mangling_mode == DM_STRING_MANGLING_AUTO ? "auto" : "hex", mangling_mode == DM_STRING_MANGLING_AUTO ? "auto" : "hex",
name, mangled_name); name, mangled_name);
if (!(dmt->mangled_dev_name = dm_strdup(mangled_name))) { if (!(dmt->mangled_dev_name = strdup(mangled_name))) {
log_error("_dm_task_set_name: dm_strdup(%s) failed", mangled_name); log_error("_dm_task_set_name: strdup(%s) failed", mangled_name);
return 0; return 0;
} }
} }
if (!(dmt->dev_name = dm_strdup(name))) { if (!(dmt->dev_name = strdup(name))) {
log_error("_dm_task_set_name: strdup(%s) failed", name); log_error("_dm_task_set_name: strdup(%s) failed", name);
return 0; return 0;
} }
@ -689,8 +690,8 @@ static char *_task_get_string_mangled(const char *str, const char *str_name,
if ((r = mangle_string(str, str_name, strlen(str), buf, buf_size, mode)) < 0) if ((r = mangle_string(str, str_name, strlen(str), buf, buf_size, mode)) < 0)
return NULL; return NULL;
if (!(rs = r ? dm_strdup(buf) : dm_strdup(str))) if (!(rs = r ? strdup(buf) : strdup(str)))
log_error("_task_get_string_mangled: dm_strdup failed"); log_error("_task_get_string_mangled: strdup failed");
return rs; return rs;
} }
@ -710,8 +711,8 @@ static char *_task_get_string_unmangled(const char *str, const char *str_name,
(r = unmangle_string(str, str_name, strlen(str), buf, buf_size, mode)) < 0) (r = unmangle_string(str, str_name, strlen(str), buf, buf_size, mode)) < 0)
return NULL; return NULL;
if (!(rs = r ? dm_strdup(buf) : dm_strdup(str))) if (!(rs = r ? strdup(buf) : strdup(str)))
log_error("_task_get_string_unmangled: dm_strdup failed"); log_error("_task_get_string_unmangled: strdup failed");
return rs; return rs;
} }
@ -807,8 +808,8 @@ int dm_task_set_newname(struct dm_task *dmt, const char *newname)
newname = mangled_name; newname = mangled_name;
} }
dm_free(dmt->newname); free(dmt->newname);
if (!(dmt->newname = dm_strdup(newname))) { if (!(dmt->newname = strdup(newname))) {
log_error("dm_task_set_newname: strdup(%s) failed", newname); log_error("dm_task_set_newname: strdup(%s) failed", newname);
return 0; return 0;
} }
@ -824,9 +825,9 @@ int dm_task_set_uuid(struct dm_task *dmt, const char *uuid)
dm_string_mangling_t mangling_mode = dm_get_name_mangling_mode(); dm_string_mangling_t mangling_mode = dm_get_name_mangling_mode();
int r = 0; int r = 0;
dm_free(dmt->uuid); free(dmt->uuid);
dmt->uuid = NULL; dmt->uuid = NULL;
dm_free(dmt->mangled_uuid); free(dmt->mangled_uuid);
dmt->mangled_uuid = NULL; dmt->mangled_uuid = NULL;
if (!check_multiple_mangled_string_allowed(uuid, "UUID", mangling_mode)) if (!check_multiple_mangled_string_allowed(uuid, "UUID", mangling_mode))
@ -844,13 +845,13 @@ int dm_task_set_uuid(struct dm_task *dmt, const char *uuid)
mangling_mode == DM_STRING_MANGLING_AUTO ? "auto" : "hex", mangling_mode == DM_STRING_MANGLING_AUTO ? "auto" : "hex",
uuid, mangled_uuid); uuid, mangled_uuid);
if (!(dmt->mangled_uuid = dm_strdup(mangled_uuid))) { if (!(dmt->mangled_uuid = strdup(mangled_uuid))) {
log_error("dm_task_set_uuid: dm_strdup(%s) failed", mangled_uuid); log_error("dm_task_set_uuid: strdup(%s) failed", mangled_uuid);
return 0; return 0;
} }
} }
if (!(dmt->uuid = dm_strdup(uuid))) { if (!(dmt->uuid = strdup(uuid))) {
log_error("dm_task_set_uuid: strdup(%s) failed", uuid); log_error("dm_task_set_uuid: strdup(%s) failed", uuid);
return 0; return 0;
} }
@ -1458,7 +1459,7 @@ static void _del_node_op(struct node_op_parms *nop)
{ {
_count_node_ops[nop->type]--; _count_node_ops[nop->type]--;
dm_list_del(&nop->list); dm_list_del(&nop->list);
dm_free(nop); free(nop);
} }
@ -1562,7 +1563,7 @@ static int _stack_node_op(node_op_t type, const char *dev_name, uint32_t major,
warn_if_udev_failed = 0; warn_if_udev_failed = 0;
} }
if (!(nop = dm_malloc(sizeof(*nop) + len))) { if (!(nop = malloc(sizeof(*nop) + len))) {
log_error("Insufficient memory to stack mknod operation"); log_error("Insufficient memory to stack mknod operation");
return 0; return 0;
} }
@ -1828,8 +1829,8 @@ static int _sysfs_get_dm_name(uint32_t major, uint32_t minor, char *buf, size_t
int r = 0; int r = 0;
size_t len; size_t len;
if (!(sysfs_path = dm_malloc(PATH_MAX)) || if (!(sysfs_path = malloc(PATH_MAX)) ||
!(temp_buf = dm_malloc(PATH_MAX))) { !(temp_buf = malloc(PATH_MAX))) {
log_error("_sysfs_get_dm_name: failed to allocate temporary buffers"); log_error("_sysfs_get_dm_name: failed to allocate temporary buffers");
goto bad; goto bad;
} }
@ -1867,8 +1868,8 @@ bad:
if (fp && fclose(fp)) if (fp && fclose(fp))
log_sys_error("fclose", sysfs_path); log_sys_error("fclose", sysfs_path);
dm_free(temp_buf); free(temp_buf);
dm_free(sysfs_path); free(sysfs_path);
return r; return r;
} }
@ -1880,8 +1881,8 @@ static int _sysfs_get_kernel_name(uint32_t major, uint32_t minor, char *buf, siz
size_t len; size_t len;
int r = 0; int r = 0;
if (!(sysfs_path = dm_malloc(PATH_MAX)) || if (!(sysfs_path = malloc(PATH_MAX)) ||
!(temp_buf = dm_malloc(PATH_MAX))) { !(temp_buf = malloc(PATH_MAX))) {
log_error("_sysfs_get_kernel_name: failed to allocate temporary buffers"); log_error("_sysfs_get_kernel_name: failed to allocate temporary buffers");
goto bad; goto bad;
} }
@ -1916,8 +1917,8 @@ static int _sysfs_get_kernel_name(uint32_t major, uint32_t minor, char *buf, siz
strcpy(buf, name); strcpy(buf, name);
r = 1; r = 1;
bad: bad:
dm_free(temp_buf); free(temp_buf);
dm_free(sysfs_path); free(sysfs_path);
return r; return r;
} }

View File

@ -16,7 +16,7 @@
#ifndef LIB_DMCOMMON_H #ifndef LIB_DMCOMMON_H
#define LIB_DMCOMMON_H #define LIB_DMCOMMON_H
#include "libdevmapper.h" #include "device_mapper/all.h"
#define DM_DEFAULT_NAME_MANGLING_MODE_ENV_VAR_NAME "DM_DEFAULT_NAME_MANGLING_MODE" #define DM_DEFAULT_NAME_MANGLING_MODE_ENV_VAR_NAME "DM_DEFAULT_NAME_MANGLING_MODE"

View File

@ -269,11 +269,11 @@ static int _line_append(struct config_output *out, const char *fmt, ...)
if (!dm_pool_grow_object(out->mem, dyn_buf ? : buf, 0)) { if (!dm_pool_grow_object(out->mem, dyn_buf ? : buf, 0)) {
log_error("dm_pool_grow_object failed for config line"); log_error("dm_pool_grow_object failed for config line");
dm_free(dyn_buf); free(dyn_buf);
return 0; return 0;
} }
dm_free(dyn_buf); free(dyn_buf);
return 1; return 1;
} }
@ -1441,12 +1441,12 @@ static int _enumerate(const char *path, struct dm_config_node *cn, int (*cb)(con
} else } else
if (!cb(sub, cn, baton)) if (!cb(sub, cn, baton))
goto_bad; goto_bad;
dm_free(sub); free(sub);
cn = cn->sib; cn = cn->sib;
} }
return 1; return 1;
bad: bad:
dm_free(sub); free(sub);
return 0; return 0;
} }

View File

@ -19,6 +19,7 @@
#include "misc/dm-ioctl.h" #include "misc/dm-ioctl.h"
#include <stdarg.h> #include <stdarg.h>
#include <string.h>
#include <sys/param.h> #include <sys/param.h>
#include <sys/utsname.h> #include <sys/utsname.h>
@ -2660,7 +2661,7 @@ static int _emit_segment(struct dm_task *dmt, uint32_t major, uint32_t minor,
int ret; int ret;
do { do {
if (!(params = dm_malloc(paramsize))) { if (!(params = malloc(paramsize))) {
log_error("Insufficient space for target parameters."); log_error("Insufficient space for target parameters.");
return 0; return 0;
} }
@ -2668,7 +2669,7 @@ static int _emit_segment(struct dm_task *dmt, uint32_t major, uint32_t minor,
params[0] = '\0'; params[0] = '\0';
ret = _emit_segment_line(dmt, major, minor, seg, seg_start, ret = _emit_segment_line(dmt, major, minor, seg, seg_start,
params, paramsize); params, paramsize);
dm_free(params); free(params);
if (!ret) if (!ret)
stack; stack;

View File

@ -45,7 +45,7 @@ static int _create_dir_recursive(const char *dir)
log_verbose("Creating directory \"%s\"", dir); log_verbose("Creating directory \"%s\"", dir);
/* Create parent directories */ /* Create parent directories */
orig = s = dm_strdup(dir); orig = s = strdup(dir);
if (!s) { if (!s) {
log_error("Failed to duplicate directory name."); log_error("Failed to duplicate directory name.");
return 0; return 0;
@ -84,7 +84,7 @@ static int _create_dir_recursive(const char *dir)
r = 1; r = 1;
out: out:
dm_free(orig); free(orig);
return r; return r;
} }

View File

@ -13,6 +13,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "misc/dmlib.h" #include "misc/dmlib.h"
#include <ctype.h> #include <ctype.h>
@ -477,8 +478,8 @@ static int _report_field_string_list(struct dm_report *rh,
} }
/* more than one item - sort the list */ /* more than one item - sort the list */
if (!(arr = dm_malloc(sizeof(struct str_list_sort_item) * list_size))) { if (!(arr = malloc(sizeof(struct str_list_sort_item) * list_size))) {
log_error("dm_report_field_string_list: dm_malloc failed"); log_error("dm_report_field_string_list: malloc failed");
goto out; goto out;
} }
@ -547,7 +548,7 @@ static int _report_field_string_list(struct dm_report *rh,
out: out:
if (!r && sort_value) if (!r && sort_value)
dm_pool_free(rh->mem, sort_value); dm_pool_free(rh->mem, sort_value);
dm_free(arr); free(arr);
return r; return r;
} }
@ -1257,8 +1258,8 @@ struct dm_report *dm_report_init(uint32_t *report_types,
if (_contains_reserved_report_type(types)) if (_contains_reserved_report_type(types))
return_NULL; return_NULL;
if (!(rh = dm_zalloc(sizeof(*rh)))) { if (!(rh = zalloc(sizeof(*rh)))) {
log_error("dm_report_init: dm_malloc failed"); log_error("dm_report_init: malloc failed");
return NULL; return NULL;
} }
@ -1300,7 +1301,7 @@ struct dm_report *dm_report_init(uint32_t *report_types,
if (!(rh->mem = dm_pool_create("report", 10 * 1024))) { if (!(rh->mem = dm_pool_create("report", 10 * 1024))) {
log_error("dm_report_init: allocation of memory pool failed"); log_error("dm_report_init: allocation of memory pool failed");
dm_free(rh); free(rh);
return NULL; return NULL;
} }
@ -1348,7 +1349,7 @@ void dm_report_free(struct dm_report *rh)
if (rh->value_cache) if (rh->value_cache)
dm_hash_destroy(rh->value_cache); dm_hash_destroy(rh->value_cache);
dm_pool_destroy(rh->mem); dm_pool_destroy(rh->mem);
dm_free(rh); free(rh);
} }
static char *_toupperstr(char *str) static char *_toupperstr(char *str)
@ -2732,7 +2733,7 @@ static const char *_tok_value_string_list(const struct dm_report_field_type *ft,
goto bad; goto bad;
} else if (list_size == 1) } else if (list_size == 1)
goto out; goto out;
if (!(arr = dm_malloc(sizeof(item) * list_size))) { if (!(arr = malloc(sizeof(item) * list_size))) {
log_error("_tok_value_string_list: memory allocation failed for sort array"); log_error("_tok_value_string_list: memory allocation failed for sort array");
goto bad; goto bad;
} }
@ -2745,7 +2746,7 @@ static const char *_tok_value_string_list(const struct dm_report_field_type *ft,
for (i = 0; i < list_size; i++) for (i = 0; i < list_size; i++)
dm_list_add(&ssl->str_list.list, &arr[i]->list); dm_list_add(&ssl->str_list.list, &arr[i]->list);
dm_free(arr); free(arr);
out: out:
*end = s; *end = s;
if (sel_str_list) if (sel_str_list)
@ -3514,8 +3515,8 @@ static struct field_selection *_create_field_selection(struct dm_report *rh,
/* store comparison operand */ /* store comparison operand */
if (flags & FLD_CMP_REGEX) { if (flags & FLD_CMP_REGEX) {
/* REGEX */ /* REGEX */
if (!(s = dm_malloc(len + 1))) { if (!(s = malloc(len + 1))) {
log_error("dm_report: dm_malloc failed to store " log_error("dm_report: malloc failed to store "
"regex value for selection field %s", field_id); "regex value for selection field %s", field_id);
goto error; goto error;
} }
@ -3523,7 +3524,7 @@ static struct field_selection *_create_field_selection(struct dm_report *rh,
s[len] = '\0'; s[len] = '\0';
fs->value->v.r = dm_regex_create(rh->selection->mem, (const char * const *) &s, 1); fs->value->v.r = dm_regex_create(rh->selection->mem, (const char * const *) &s, 1);
dm_free(s); free(s);
if (!fs->value->v.r) { if (!fs->value->v.r) {
log_error("dm_report: failed to create regex " log_error("dm_report: failed to create regex "
"matcher for selection field %s", field_id); "matcher for selection field %s", field_id);
@ -4175,7 +4176,7 @@ static int _report_headings(struct dm_report *rh)
/* Including trailing '\0'! */ /* Including trailing '\0'! */
buf_size++; buf_size++;
if (!(buf = dm_malloc(buf_size))) { if (!(buf = malloc(buf_size))) {
log_error("dm_report: Could not allocate memory for heading buffer."); log_error("dm_report: Could not allocate memory for heading buffer.");
goto bad; goto bad;
} }
@ -4219,12 +4220,12 @@ static int _report_headings(struct dm_report *rh)
log_print("%s", heading); log_print("%s", heading);
dm_pool_free(rh->mem, (void *)heading); dm_pool_free(rh->mem, (void *)heading);
dm_free(buf); free(buf);
return 1; return 1;
bad: bad:
dm_free(buf); free(buf);
dm_pool_abandon_object(rh->mem); dm_pool_abandon_object(rh->mem);
return 0; return 0;
} }
@ -4398,24 +4399,24 @@ static int _output_field(struct dm_report *rh, struct dm_report_field *field)
return 0; return 0;
} }
} else if (rh->flags & DM_REPORT_OUTPUT_FIELD_NAME_PREFIX) { } else if (rh->flags & DM_REPORT_OUTPUT_FIELD_NAME_PREFIX) {
if (!(field_id = dm_strdup(fields[field->props->field_num].id))) { if (!(field_id = strdup(fields[field->props->field_num].id))) {
log_error("dm_report: Failed to copy field name"); log_error("dm_report: Failed to copy field name");
return 0; return 0;
} }
if (!dm_pool_grow_object(rh->mem, rh->output_field_name_prefix, 0)) { if (!dm_pool_grow_object(rh->mem, rh->output_field_name_prefix, 0)) {
log_error(UNABLE_TO_EXTEND_OUTPUT_LINE_MSG); log_error(UNABLE_TO_EXTEND_OUTPUT_LINE_MSG);
dm_free(field_id); free(field_id);
return 0; return 0;
} }
if (!dm_pool_grow_object(rh->mem, _toupperstr(field_id), 0)) { if (!dm_pool_grow_object(rh->mem, _toupperstr(field_id), 0)) {
log_error(UNABLE_TO_EXTEND_OUTPUT_LINE_MSG); log_error(UNABLE_TO_EXTEND_OUTPUT_LINE_MSG);
dm_free(field_id); free(field_id);
return 0; return 0;
} }
dm_free(field_id); free(field_id);
if (!dm_pool_grow_object(rh->mem, STANDARD_PAIR, 1)) { if (!dm_pool_grow_object(rh->mem, STANDARD_PAIR, 1)) {
log_error(UNABLE_TO_EXTEND_OUTPUT_LINE_MSG); log_error(UNABLE_TO_EXTEND_OUTPUT_LINE_MSG);
@ -4468,7 +4469,7 @@ static int _output_field(struct dm_report *rh, struct dm_report_field *field)
/* Including trailing '\0'! */ /* Including trailing '\0'! */
buf_size = width + 1; buf_size = width + 1;
if (!(buf = dm_malloc(buf_size))) { if (!(buf = malloc(buf_size))) {
log_error("dm_report: Could not allocate memory for output line buffer."); log_error("dm_report: Could not allocate memory for output line buffer.");
return 0; return 0;
} }
@ -4510,11 +4511,11 @@ static int _output_field(struct dm_report *rh, struct dm_report_field *field)
} }
} }
dm_free(buf); free(buf);
return 1; return 1;
bad: bad:
dm_free(buf); free(buf);
return 0; return 0;
} }

View File

@ -15,6 +15,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "misc/dmlib.h" #include "misc/dmlib.h"
#include "misc/kdev_t.h" #include "misc/kdev_t.h"
@ -156,7 +157,7 @@ static char *_program_id_from_proc(void)
if (fclose(comm)) if (fclose(comm))
stack; stack;
return dm_strdup(buf); return strdup(buf);
} }
static uint64_t _nr_areas(uint64_t len, uint64_t step) static uint64_t _nr_areas(uint64_t len, uint64_t step)
@ -184,12 +185,12 @@ struct dm_stats *dm_stats_create(const char *program_id)
size_t group_hint = sizeof(struct dm_stats_group); size_t group_hint = sizeof(struct dm_stats_group);
struct dm_stats *dms = NULL; struct dm_stats *dms = NULL;
if (!(dms = dm_zalloc(sizeof(*dms)))) if (!(dms = zalloc(sizeof(*dms))))
return_NULL; return_NULL;
/* FIXME: better hint. */ /* FIXME: better hint. */
if (!(dms->mem = dm_pool_create("stats_pool", 4096))) { if (!(dms->mem = dm_pool_create("stats_pool", 4096))) {
dm_free(dms); free(dms);
return_NULL; return_NULL;
} }
@ -202,7 +203,7 @@ struct dm_stats *dm_stats_create(const char *program_id)
if (!program_id || !strlen(program_id)) if (!program_id || !strlen(program_id))
dms->program_id = _program_id_from_proc(); dms->program_id = _program_id_from_proc();
else else
dms->program_id = dm_strdup(program_id); dms->program_id = strdup(program_id);
if (!dms->program_id) { if (!dms->program_id) {
log_error("Could not allocate memory for program_id"); log_error("Could not allocate memory for program_id");
@ -235,7 +236,7 @@ bad:
dm_pool_destroy(dms->hist_mem); dm_pool_destroy(dms->hist_mem);
if (dms->group_mem) if (dms->group_mem)
dm_pool_destroy(dms->group_mem); dm_pool_destroy(dms->group_mem);
dm_free(dms); free(dms);
return NULL; return NULL;
} }
@ -325,15 +326,15 @@ static void _stats_region_destroy(struct dm_stats_region *region)
* dropped from the pool along with the corresponding * dropped from the pool along with the corresponding
* regions table. * regions table.
* *
* The following objects are all allocated with dm_malloc. * The following objects are all allocated with malloc.
*/ */
region->counters = NULL; region->counters = NULL;
region->bounds = NULL; region->bounds = NULL;
dm_free(region->program_id); free(region->program_id);
region->program_id = NULL; region->program_id = NULL;
dm_free(region->aux_data); free(region->aux_data);
region->aux_data = NULL; region->aux_data = NULL;
region->region_id = DM_STATS_REGION_NOT_PRESENT; region->region_id = DM_STATS_REGION_NOT_PRESENT;
} }
@ -364,7 +365,7 @@ static void _stats_group_destroy(struct dm_stats_group *group)
group->histogram = NULL; group->histogram = NULL;
if (group->alias) { if (group->alias) {
dm_free((char *) group->alias); free((char *) group->alias);
group->alias = NULL; group->alias = NULL;
} }
if (group->regions) { if (group->regions) {
@ -414,7 +415,7 @@ static void _stats_clear_binding(struct dm_stats *dms)
dm_pool_free(dms->mem, dms->bind_name); dm_pool_free(dms->mem, dms->bind_name);
if (dms->bind_uuid) if (dms->bind_uuid)
dm_pool_free(dms->mem, dms->bind_uuid); dm_pool_free(dms->mem, dms->bind_uuid);
dm_free((char *) dms->name); free((char *) dms->name);
dms->bind_name = dms->bind_uuid = NULL; dms->bind_name = dms->bind_uuid = NULL;
dms->bind_major = dms->bind_minor = -1; dms->bind_major = dms->bind_minor = -1;
@ -534,7 +535,7 @@ static void *_get_hist_arg(struct dm_histogram *bounds, uint64_t scale,
*len = hist_len; *len = hist_len;
return dm_zalloc(hist_len); return zalloc(hist_len);
} }
static char *_build_histogram_arg(struct dm_histogram *bounds, int *precise) static char *_build_histogram_arg(struct dm_histogram *bounds, int *precise)
@ -587,7 +588,7 @@ static char *_build_histogram_arg(struct dm_histogram *bounds, int *precise)
bad: bad:
log_error("Could not build histogram arguments."); log_error("Could not build histogram arguments.");
dm_free(hist_arg); free(hist_arg);
return NULL; return NULL;
} }
@ -634,7 +635,7 @@ static int _stats_set_name_cache(struct dm_stats *dms)
if (!dm_task_run(dmt)) if (!dm_task_run(dmt))
goto_bad; goto_bad;
if (!(dms->name = dm_strdup(dm_task_get_name(dmt)))) if (!(dms->name = strdup(dm_task_get_name(dmt))))
goto_bad; goto_bad;
dm_task_destroy(dmt); dm_task_destroy(dmt);
@ -759,7 +760,7 @@ static int _parse_aux_data_group(struct dm_stats *dms,
group->regions = regions; group->regions = regions;
group->alias = NULL; group->alias = NULL;
if (strlen(alias)) { if (strlen(alias)) {
group->alias = dm_strdup(alias); group->alias = strdup(alias);
if (!group->alias) { if (!group->alias) {
log_error("Could not allocate memory for group alias"); log_error("Could not allocate memory for group alias");
goto bad; goto bad;
@ -768,16 +769,16 @@ static int _parse_aux_data_group(struct dm_stats *dms,
/* separate group tag from user aux_data */ /* separate group tag from user aux_data */
if ((strlen(end) > 1) || strncmp(end, "-", 1)) if ((strlen(end) > 1) || strncmp(end, "-", 1))
c = dm_strdup(end); c = strdup(end);
else else
c = dm_strdup(""); c = strdup("");
if (!c) { if (!c) {
log_error("Could not allocate memory for user aux_data"); log_error("Could not allocate memory for user aux_data");
goto bad_alias; goto bad_alias;
} }
dm_free(region->aux_data); free(region->aux_data);
region->aux_data = c; region->aux_data = c;
log_debug("Found group_id " FMTu64 ": alias=\"%s\"", group->group_id, log_debug("Found group_id " FMTu64 ": alias=\"%s\"", group->group_id,
@ -786,7 +787,7 @@ static int _parse_aux_data_group(struct dm_stats *dms,
return 1; return 1;
bad_alias: bad_alias:
dm_free((char *) group->alias); free((char *) group->alias);
bad: bad:
dm_bitset_destroy(regions); dm_bitset_destroy(regions);
return 0; return 0;
@ -971,10 +972,10 @@ static int _stats_parse_list_region(struct dm_stats *dms,
region->group_id = DM_STATS_GROUP_NOT_PRESENT; region->group_id = DM_STATS_GROUP_NOT_PRESENT;
if (!(region->program_id = dm_strdup(program_id))) if (!(region->program_id = strdup(program_id)))
return_0; return_0;
if (!(region->aux_data = dm_strdup(aux_data))) { if (!(region->aux_data = strdup(aux_data))) {
dm_free(region->program_id); free(region->program_id);
return_0; return_0;
} }
@ -1843,7 +1844,7 @@ static char *_build_group_tag(struct dm_stats *dms, uint64_t group_id)
buflen += DMS_GROUP_TAG_LEN; buflen += DMS_GROUP_TAG_LEN;
buflen += 1 + (alias ? strlen(alias) : 0); /* 'alias:' */ buflen += 1 + (alias ? strlen(alias) : 0); /* 'alias:' */
buf = aux_string = dm_malloc(buflen); buf = aux_string = malloc(buflen);
if (!buf) { if (!buf) {
log_error("Could not allocate memory for aux_data string."); log_error("Could not allocate memory for aux_data string.");
return NULL; return NULL;
@ -1869,7 +1870,7 @@ static char *_build_group_tag(struct dm_stats *dms, uint64_t group_id)
return aux_string; return aux_string;
bad: bad:
log_error("Could not format group aux_data."); log_error("Could not format group aux_data.");
dm_free(aux_string); free(aux_string);
return NULL; return NULL;
} }
@ -1906,14 +1907,14 @@ static int _stats_set_aux(struct dm_stats *dms,
if (!(dmt = _stats_send_message(dms, msg))) if (!(dmt = _stats_send_message(dms, msg)))
goto_bad; goto_bad;
dm_free((char *) group_tag); free((char *) group_tag);
/* no response to a @stats_set_aux message */ /* no response to a @stats_set_aux message */
dm_task_destroy(dmt); dm_task_destroy(dmt);
return 1; return 1;
bad: bad:
dm_free((char *) group_tag); free((char *) group_tag);
return 0; return 0;
} }
@ -1970,7 +1971,7 @@ static int _stats_create_region(struct dm_stats *dms, uint64_t *region_id,
return 0; return 0;
} }
} else } else
opt_args = dm_strdup(""); opt_args = strdup("");
if (dm_snprintf(msg, sizeof(msg), "@stats_create %s %s" FMTu64 if (dm_snprintf(msg, sizeof(msg), "@stats_create %s %s" FMTu64
" %s %s %s", (start || len) ? range : "-", " %s %s %s", (start || len) ? range : "-",
@ -1978,7 +1979,7 @@ static int _stats_create_region(struct dm_stats *dms, uint64_t *region_id,
(uint64_t)llabs(step), (uint64_t)llabs(step),
opt_args, program_id, aux_data) < 0) { opt_args, program_id, aux_data) < 0) {
log_error(err_fmt, "message"); log_error(err_fmt, "message");
dm_free((void *) opt_args); free((void *) opt_args);
return 0; return 0;
} }
@ -2003,7 +2004,7 @@ static int _stats_create_region(struct dm_stats *dms, uint64_t *region_id,
out: out:
if (dmt) if (dmt)
dm_task_destroy(dmt); dm_task_destroy(dmt);
dm_free((void *) opt_args); free((void *) opt_args);
return r; return r;
} }
@ -2028,7 +2029,7 @@ int dm_stats_create_region(struct dm_stats *dms, uint64_t *region_id,
r = _stats_create_region(dms, region_id, start, len, step, r = _stats_create_region(dms, region_id, start, len, step,
precise, hist_arg, program_id, user_data); precise, hist_arg, program_id, user_data);
dm_free(hist_arg); free(hist_arg);
out: out:
return r; return r;
@ -2398,9 +2399,9 @@ void dm_stats_destroy(struct dm_stats *dms)
dm_pool_destroy(dms->mem); dm_pool_destroy(dms->mem);
dm_pool_destroy(dms->hist_mem); dm_pool_destroy(dms->hist_mem);
dm_pool_destroy(dms->group_mem); dm_pool_destroy(dms->group_mem);
dm_free(dms->program_id); free(dms->program_id);
dm_free((char *) dms->name); free((char *) dms->name);
dm_free(dms); free(dms);
} }
/* /*
@ -2995,9 +2996,9 @@ int dm_stats_set_program_id(struct dm_stats *dms, int allow_empty,
if (!program_id) if (!program_id)
program_id = ""; program_id = "";
dm_free(dms->program_id); free(dms->program_id);
if (!(dms->program_id = dm_strdup(program_id))) if (!(dms->program_id = strdup(program_id)))
return_0; return_0;
return 1; return 1;
@ -3215,7 +3216,7 @@ int dm_stats_set_alias(struct dm_stats *dms, uint64_t group_id, const char *alia
group = &dms->groups[group_id]; group = &dms->groups[group_id];
old_alias = group->alias; old_alias = group->alias;
group->alias = dm_strdup(alias); group->alias = strdup(alias);
if (!group->alias) { if (!group->alias) {
log_error("Could not allocate memory for alias."); log_error("Could not allocate memory for alias.");
goto bad; goto bad;
@ -3226,12 +3227,12 @@ int dm_stats_set_alias(struct dm_stats *dms, uint64_t group_id, const char *alia
goto bad; goto bad;
} }
dm_free((char *) old_alias); free((char *) old_alias);
return 1; return 1;
bad: bad:
dm_free((char *) group->alias); free((char *) group->alias);
group->alias = old_alias; group->alias = old_alias;
return 0; return 0;
} }
@ -3492,7 +3493,7 @@ static struct dm_histogram *_alloc_dm_histogram(int nr_bins)
/* Allocate space for dm_histogram + nr_entries. */ /* Allocate space for dm_histogram + nr_entries. */
size_t size = sizeof(struct dm_histogram) + size_t size = sizeof(struct dm_histogram) +
(unsigned) nr_bins * sizeof(struct dm_histogram_bin); (unsigned) nr_bins * sizeof(struct dm_histogram_bin);
return dm_zalloc(size); return zalloc(size);
} }
/* /*
@ -3595,7 +3596,7 @@ struct dm_histogram *dm_histogram_bounds_from_string(const char *bounds_str)
badchar: badchar:
log_error("Invalid character in histogram: %c", *c); log_error("Invalid character in histogram: %c", *c);
bad: bad:
dm_free(dmh); free(dmh);
return NULL; return NULL;
} }
@ -3646,8 +3647,8 @@ void dm_histogram_bounds_destroy(struct dm_histogram *bounds)
(void *) bounds); (void *) bounds);
stack; stack;
} }
/* dm_free() expects a (void *). */ /* free() expects a (void *). */
dm_free((void *) bounds); free((void *) bounds);
} }
/* /*
@ -3897,7 +3898,7 @@ static int _stats_create_group(struct dm_stats *dms, dm_bitset_t regions,
group->regions = regions; group->regions = regions;
if (alias) if (alias)
group->alias = dm_strdup(alias); group->alias = strdup(alias);
else else
group->alias = NULL; group->alias = NULL;
@ -4231,7 +4232,7 @@ static int _stats_group_file_regions(struct dm_stats *dms, uint64_t *region_ids,
dm_bit_set(regions, region_ids[i]); dm_bit_set(regions, region_ids[i]);
buflen = _stats_group_tag_len(dms, regions); buflen = _stats_group_tag_len(dms, regions);
members = dm_malloc(buflen); members = malloc(buflen);
if (!members) { if (!members) {
log_error("Cannot map file: failed to allocate group " log_error("Cannot map file: failed to allocate group "
@ -4253,11 +4254,11 @@ static int _stats_group_file_regions(struct dm_stats *dms, uint64_t *region_ids,
if (!_stats_create_group(dms, regions, alias, &group_id)) if (!_stats_create_group(dms, regions, alias, &group_id))
goto bad; goto bad;
dm_free(members); free(members);
return 1; return 1;
bad: bad:
dm_bitset_destroy(regions); dm_bitset_destroy(regions);
dm_free(members); free(members);
return 0; return 0;
} }
@ -4408,7 +4409,7 @@ static struct _extent *_stats_get_extents_for_file(struct dm_pool *mem, int fd,
if (!dm_pool_begin_object(mem, sizeof(*extents))) if (!dm_pool_begin_object(mem, sizeof(*extents)))
return NULL; return NULL;
buf = dm_zalloc(STATS_FIE_BUF_LEN); buf = zalloc(STATS_FIE_BUF_LEN);
if (!buf) { if (!buf) {
log_error("Could not allocate memory for FIEMAP buffer."); log_error("Could not allocate memory for FIEMAP buffer.");
goto bad; goto bad;
@ -4462,14 +4463,14 @@ static struct _extent *_stats_get_extents_for_file(struct dm_pool *mem, int fd,
extents = dm_pool_end_object(mem); extents = dm_pool_end_object(mem);
/* free FIEMAP buffer. */ /* free FIEMAP buffer. */
dm_free(buf); free(buf);
return extents; return extents;
bad: bad:
*count = 0; *count = 0;
dm_pool_abandon_object(mem); dm_pool_abandon_object(mem);
dm_free(buf); free(buf);
return NULL; return NULL;
} }
@ -4677,7 +4678,7 @@ static uint64_t *_stats_map_file_regions(struct dm_stats *dms, int fd,
goto_out; goto_out;
/* make space for end-of-table marker */ /* make space for end-of-table marker */
if (!(regions = dm_malloc((1 + *count) * sizeof(*regions)))) { if (!(regions = malloc((1 + *count) * sizeof(*regions)))) {
log_error("Could not allocate memory for region IDs."); log_error("Could not allocate memory for region IDs.");
goto_out; goto_out;
} }
@ -4736,7 +4737,7 @@ static uint64_t *_stats_map_file_regions(struct dm_stats *dms, int fd,
log_error("Failed to update group aux_data."); log_error("Failed to update group aux_data.");
if (bounds) if (bounds)
dm_free(hist_arg); free(hist_arg);
/* the extent table will be empty if the file has been truncated. */ /* the extent table will be empty if the file has been truncated. */
if (extents) if (extents)
@ -4763,8 +4764,8 @@ out_remove:
out: out:
dm_pool_destroy(extent_mem); dm_pool_destroy(extent_mem);
dm_free(hist_arg); free(hist_arg);
dm_free(regions); free(regions);
return NULL; return NULL;
} }
@ -4799,7 +4800,7 @@ uint64_t *dm_stats_create_regions_from_fd(struct dm_stats *dms, int fd,
return regions; return regions;
out: out:
_stats_cleanup_region_ids(dms, regions, count); _stats_cleanup_region_ids(dms, regions, count);
dm_free(regions); free(regions);
return NULL; return NULL;
} }
@ -4836,7 +4837,7 @@ uint64_t *dm_stats_update_regions_from_fd(struct dm_stats *dms, int fd,
* A copy of the alias is needed to re-create the group when regroup=1. * A copy of the alias is needed to re-create the group when regroup=1.
*/ */
if (dms->groups[group_id].alias) { if (dms->groups[group_id].alias) {
alias = dm_strdup(dms->groups[group_id].alias); alias = strdup(dms->groups[group_id].alias);
if (!alias) { if (!alias) {
log_error("Failed to allocate group alias string."); log_error("Failed to allocate group alias string.");
return NULL; return NULL;
@ -4878,15 +4879,15 @@ uint64_t *dm_stats_update_regions_from_fd(struct dm_stats *dms, int fd,
if (!_stats_group_file_regions(dms, regions, count, alias)) if (!_stats_group_file_regions(dms, regions, count, alias))
goto bad; goto bad;
dm_free(bounds); free(bounds);
dm_free((char *) alias); free((char *) alias);
return regions; return regions;
bad: bad:
_stats_cleanup_region_ids(dms, regions, count); _stats_cleanup_region_ids(dms, regions, count);
dm_free(bounds); free(bounds);
dm_free(regions); free(regions);
out: out:
dm_free((char *) alias); free((char *) alias);
return NULL; return NULL;
} }
#else /* !HAVE_LINUX_FIEMAP */ #else /* !HAVE_LINUX_FIEMAP */

View File

@ -146,7 +146,7 @@ int dm_vasprintf(char **result, const char *format, va_list aq)
{ {
int i, n, size = 16; int i, n, size = 16;
va_list ap; va_list ap;
char *buf = dm_malloc(size); char *buf = malloc(size);
*result = 0; *result = 0;
@ -161,20 +161,20 @@ int dm_vasprintf(char **result, const char *format, va_list aq)
if (0 <= n && n < size) if (0 <= n && n < size)
break; break;
dm_free(buf); free(buf);
/* Up to glibc 2.0.6 returns -1 */ /* Up to glibc 2.0.6 returns -1 */
size = (n < 0) ? size * 2 : n + 1; size = (n < 0) ? size * 2 : n + 1;
if (!(buf = dm_malloc(size))) if (!(buf = malloc(size)))
return -1; return -1;
} }
if (i > 1) { if (i > 1) {
/* Reallocating more then once? */ /* Reallocating more then once? */
if (!(*result = dm_strdup(buf))) { if (!(*result = strdup(buf))) {
dm_free(buf); free(buf);
return -1; return -1;
} }
dm_free(buf); free(buf);
} else } else
*result = buf; *result = buf;

View File

@ -18,6 +18,7 @@
* the results of these routines should stay in-core. * the results of these routines should stay in-core.
*/ */
#include "base/memory/zalloc.h"
#include "misc/dmlib.h" #include "misc/dmlib.h"
#include <stdlib.h> #include <stdlib.h>
@ -53,7 +54,7 @@ struct dm_timestamp *dm_timestamp_alloc(void)
{ {
struct dm_timestamp *ts = NULL; struct dm_timestamp *ts = NULL;
if (!(ts = dm_zalloc(sizeof(*ts)))) if (!(ts = zalloc(sizeof(*ts))))
stack; stack;
return ts; return ts;
@ -101,7 +102,7 @@ struct dm_timestamp *dm_timestamp_alloc(void)
{ {
struct dm_timestamp *ts; struct dm_timestamp *ts;
if (!(ts = dm_malloc(sizeof(*ts)))) if (!(ts = malloc(sizeof(*ts))))
stack; stack;
return ts; return ts;
@ -174,5 +175,5 @@ void dm_timestamp_copy(struct dm_timestamp *ts_new, struct dm_timestamp *ts_old)
void dm_timestamp_destroy(struct dm_timestamp *ts) void dm_timestamp_destroy(struct dm_timestamp *ts)
{ {
dm_free(ts); free(ts);
} }

View File

@ -16,7 +16,7 @@
#ifndef _DM_LOGGING_H #ifndef _DM_LOGGING_H
#define _DM_LOGGING_H #define _DM_LOGGING_H
#include "device_mapper/libdevmapper.h" #include "device_mapper/all.h"
extern dm_log_with_errno_fn dm_log_with_errno; extern dm_log_with_errno_fn dm_log_with_errno;

View File

@ -26,7 +26,7 @@
#define _REENTRANT #define _REENTRANT
#define _GNU_SOURCE #define _GNU_SOURCE
#include "device_mapper/libdevmapper.h" #include "device_mapper/all.h"
#include "lib/misc/util.h" #include "lib/misc/util.h"
#include "dm-logging.h" #include "dm-logging.h"

View File

@ -1,413 +0,0 @@
/*
* Copyright (C) 2001-2004 Sistina Software, Inc. All rights reserved.
* Copyright (C) 2004-2011 Red Hat, Inc. All rights reserved.
*
* This file is part of the device-mapper userspace tools.
*
* This copyrighted material is made available to anyone wishing to use,
* modify, copy, or redistribute it subject to the terms and conditions
* of the GNU Lesser General Public License v.2.1.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program; if not, write to the Free Software Foundation,
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
#include "device_mapper/misc/dmlib.h"
#ifdef VALGRIND_POOL
#include "memcheck.h"
#endif
#include <assert.h>
#include <stdarg.h>
#include <unistd.h>
void *dm_malloc_aux(size_t s, const char *file, int line)
__attribute__((__malloc__)) __attribute__((__warn_unused_result__));
void *dm_malloc_aux_debug(size_t s, const char *file, int line)
__attribute__((__malloc__)) __attribute__((__warn_unused_result__));
static void *_dm_malloc_aligned_aux(size_t s, size_t a, const char *file, int line)
__attribute__((__malloc__)) __attribute__((__warn_unused_result__));
void *dm_zalloc_aux(size_t s, const char *file, int line)
__attribute__((__malloc__)) __attribute__((__warn_unused_result__));
void *dm_zalloc_aux_debug(size_t s, const char *file, int line)
__attribute__((__malloc__)) __attribute__((__warn_unused_result__));
void *dm_realloc_aux(void *p, unsigned int s, const char *file, int line)
__attribute__((__warn_unused_result__));
void dm_free_aux(void *p);
char *dm_strdup_aux(const char *str, const char *file, int line)
__attribute__((__warn_unused_result__));
int dm_dump_memory_debug(void);
void dm_bounds_check_debug(void);
char *dm_strdup_aux(const char *str, const char *file, int line)
{
char *ret;
if (!str) {
log_error(INTERNAL_ERROR "dm_strdup called with NULL pointer");
return NULL;
}
if ((ret = dm_malloc_aux_debug(strlen(str) + 1, file, line)))
strcpy(ret, str);
return ret;
}
struct memblock {
struct memblock *prev, *next; /* All allocated blocks are linked */
size_t length; /* Size of the requested block */
int id; /* Index of the block */
const char *file; /* File that allocated */
int line; /* Line that allocated */
void *magic; /* Address of this block */
} __attribute__((aligned(8)));
static struct {
unsigned block_serialno;/* Non-decreasing serialno of block */
unsigned blocks_allocated; /* Current number of blocks allocated */
unsigned blocks_max; /* Max no of concurrently-allocated blocks */
unsigned int bytes, mbytes;
} _mem_stats = {
0, 0, 0, 0, 0};
static struct memblock *_head = 0;
static struct memblock *_tail = 0;
void *dm_malloc_aux_debug(size_t s, const char *file, int line)
{
struct memblock *nb;
size_t tsize = s + sizeof(*nb) + sizeof(unsigned long);
if (s > 50000000) {
log_error("Huge memory allocation (size %" PRIsize_t
") rejected - metadata corruption?", s);
return 0;
}
if (!(nb = malloc(tsize))) {
log_error("couldn't allocate any memory, size = %" PRIsize_t,
s);
return 0;
}
/* set up the file and line info */
nb->file = file;
nb->line = line;
dm_bounds_check();
/* setup fields */
nb->magic = nb + 1;
nb->length = s;
nb->id = ++_mem_stats.block_serialno;
nb->next = 0;
/* stomp a pretty pattern across the new memory
and fill in the boundary bytes */
{
char *ptr = (char *) (nb + 1);
size_t i;
for (i = 0; i < s; i++)
*ptr++ = i & 0x1 ? (char) 0xba : (char) 0xbe;
for (i = 0; i < sizeof(unsigned long); i++)
*ptr++ = (char) nb->id;
}
nb->prev = _tail;
/* link to tail of the list */
if (!_head)
_head = _tail = nb;
else {
_tail->next = nb;
_tail = nb;
}
_mem_stats.blocks_allocated++;
if (_mem_stats.blocks_allocated > _mem_stats.blocks_max)
_mem_stats.blocks_max = _mem_stats.blocks_allocated;
_mem_stats.bytes += s;
if (_mem_stats.bytes > _mem_stats.mbytes)
_mem_stats.mbytes = _mem_stats.bytes;
/* log_debug_mem("Allocated: %u %u %u", nb->id, _mem_stats.blocks_allocated,
_mem_stats.bytes); */
#ifdef VALGRIND_POOL
VALGRIND_MAKE_MEM_UNDEFINED(nb + 1, s);
#endif
return nb + 1;
}
void *dm_zalloc_aux_debug(size_t s, const char *file, int line)
{
void *ptr = dm_malloc_aux_debug(s, file, line);
if (ptr)
memset(ptr, 0, s);
return ptr;
}
void dm_free_aux(void *p)
{
char *ptr;
size_t i;
struct memblock *mb = ((struct memblock *) p) - 1;
if (!p)
return;
dm_bounds_check();
/* sanity check */
assert(mb->magic == p);
#ifdef VALGRIND_POOL
VALGRIND_MAKE_MEM_DEFINED(p, mb->length);
#endif
/* check data at the far boundary */
ptr = (char *) p + mb->length;
for (i = 0; i < sizeof(unsigned long); i++)
if (ptr[i] != (char) mb->id)
assert(!"Damage at far end of block");
/* have we freed this before ? */
assert(mb->id != 0);
/* unlink */
if (mb->prev)
mb->prev->next = mb->next;
else
_head = mb->next;
if (mb->next)
mb->next->prev = mb->prev;
else
_tail = mb->prev;
mb->id = 0;
/* stomp a different pattern across the memory */
ptr = p;
for (i = 0; i < mb->length; i++)
ptr[i] = i & 1 ? (char) 0xde : (char) 0xad;
assert(_mem_stats.blocks_allocated);
_mem_stats.blocks_allocated--;
_mem_stats.bytes -= mb->length;
/* free the memory */
free(mb);
}
void *dm_realloc_aux(void *p, unsigned int s, const char *file, int line)
{
void *r;
struct memblock *mb = ((struct memblock *) p) - 1;
r = dm_malloc_aux_debug(s, file, line);
if (r && p) {
memcpy(r, p, mb->length);
dm_free_aux(p);
}
return r;
}
int dm_dump_memory_debug(void)
{
unsigned long tot = 0;
struct memblock *mb;
char str[32];
if (_head)
log_very_verbose("You have a memory leak:");
for (mb = _head; mb; mb = mb->next) {
#ifdef VALGRIND_POOL
/*
* We can't look at the memory in case it has had
* VALGRIND_MAKE_MEM_NOACCESS called on it.
*/
str[0] = '\0';
#else
size_t c;
for (c = 0; c < sizeof(str) - 1; c++) {
if (c >= mb->length)
str[c] = ' ';
else if (((char *)mb->magic)[c] == '\0')
str[c] = '\0';
else if (((char *)mb->magic)[c] < ' ')
str[c] = '?';
else
str[c] = ((char *)mb->magic)[c];
}
str[sizeof(str) - 1] = '\0';
#endif
LOG_MESG(_LOG_INFO, mb->file, mb->line, 0,
"block %d at %p, size %" PRIsize_t "\t [%s]",
mb->id, mb->magic, mb->length, str);
tot += mb->length;
}
if (_head)
log_very_verbose("%ld bytes leaked in total", tot);
return 1;
}
void dm_bounds_check_debug(void)
{
struct memblock *mb = _head;
while (mb) {
size_t i;
char *ptr = ((char *) (mb + 1)) + mb->length;
for (i = 0; i < sizeof(unsigned long); i++)
if (*ptr++ != (char) mb->id)
assert(!"Memory smash");
mb = mb->next;
}
}
void *dm_malloc_aux(size_t s, const char *file __attribute__((unused)),
int line __attribute__((unused)))
{
if (s > 50000000) {
log_error("Huge memory allocation (size %" PRIsize_t
") rejected - metadata corruption?", s);
return 0;
}
return malloc(s);
}
/* Allocate size s with alignment a (or page size if 0) */
static void *_dm_malloc_aligned_aux(size_t s, size_t a, const char *file __attribute__((unused)),
int line __attribute__((unused)))
{
void *memptr;
int r;
if (!a)
a = getpagesize();
if (s > 50000000) {
log_error("Huge memory allocation (size %" PRIsize_t
") rejected - metadata corruption?", s);
return 0;
}
if ((r = posix_memalign(&memptr, a, s))) {
log_error("Failed to allocate %" PRIsize_t " bytes aligned to %" PRIsize_t ": %s", s, a, strerror(r));
return 0;
}
return memptr;
}
void *dm_zalloc_aux(size_t s, const char *file, int line)
{
void *ptr = dm_malloc_aux(s, file, line);
if (ptr)
memset(ptr, 0, s);
return ptr;
}
#ifdef DEBUG_MEM
void *dm_malloc_wrapper(size_t s, const char *file, int line)
{
return dm_malloc_aux_debug(s, file, line);
}
void *dm_malloc_aligned_wrapper(size_t s, size_t a, const char *file, int line)
{
/* FIXME Implement alignment when debugging - currently just ignored */
return _dm_malloc_aux_debug(s, file, line);
}
void *dm_zalloc_wrapper(size_t s, const char *file, int line)
{
return dm_zalloc_aux_debug(s, file, line);
}
char *dm_strdup_wrapper(const char *str, const char *file, int line)
{
return dm_strdup_aux(str, file, line);
}
void dm_free_wrapper(void *ptr)
{
dm_free_aux(ptr);
}
void *dm_realloc_wrapper(void *p, unsigned int s, const char *file, int line)
{
return dm_realloc_aux(p, s, file, line);
}
int dm_dump_memory_wrapper(void)
{
return dm_dump_memory_debug();
}
void dm_bounds_check_wrapper(void)
{
dm_bounds_check_debug();
}
#else /* !DEBUG_MEM */
void *dm_malloc_wrapper(size_t s, const char *file, int line)
{
return dm_malloc_aux(s, file, line);
}
void *dm_malloc_aligned_wrapper(size_t s, size_t a, const char *file, int line)
{
return _dm_malloc_aligned_aux(s, a, file, line);
}
void *dm_zalloc_wrapper(size_t s, const char *file, int line)
{
return dm_zalloc_aux(s, file, line);
}
char *dm_strdup_wrapper(const char *str,
const char *file __attribute__((unused)),
int line __attribute__((unused)))
{
return strdup(str);
}
void dm_free_wrapper(void *ptr)
{
free(ptr);
}
void *dm_realloc_wrapper(void *p, unsigned int s,
const char *file __attribute__((unused)),
int line __attribute__((unused)))
{
return realloc(p, s);
}
int dm_dump_memory_wrapper(void)
{
return 1;
}
void dm_bounds_check_wrapper(void)
{
}
#endif /* DEBUG_MEM */

View File

@ -50,7 +50,7 @@ struct dm_pool {
struct dm_pool *dm_pool_create(const char *name, size_t chunk_hint) struct dm_pool *dm_pool_create(const char *name, size_t chunk_hint)
{ {
struct dm_pool *mem = dm_zalloc(sizeof(*mem)); struct dm_pool *mem = zalloc(sizeof(*mem));
if (!mem) { if (!mem) {
log_error("Couldn't create memory pool %s (size %" log_error("Couldn't create memory pool %s (size %"
@ -82,8 +82,8 @@ static void _free_blocks(struct dm_pool *p, struct block *b)
p->stats.blocks_allocated--; p->stats.blocks_allocated--;
n = b->next; n = b->next;
dm_free(b->data); free(b->data);
dm_free(b); free(b);
b = n; b = n;
} }
} }
@ -105,7 +105,7 @@ void dm_pool_destroy(struct dm_pool *p)
_pool_stats(p, "Destroying"); _pool_stats(p, "Destroying");
_free_blocks(p, p->blocks); _free_blocks(p, p->blocks);
dm_list_del(&p->list); dm_list_del(&p->list);
dm_free(p); free(p);
} }
void *dm_pool_alloc(struct dm_pool *p, size_t s) void *dm_pool_alloc(struct dm_pool *p, size_t s)
@ -139,7 +139,7 @@ static struct block *_new_block(size_t s, unsigned alignment)
{ {
/* FIXME: I'm currently ignoring the alignment arg. */ /* FIXME: I'm currently ignoring the alignment arg. */
size_t len = sizeof(struct block) + s; size_t len = sizeof(struct block) + s;
struct block *b = dm_malloc(len); struct block *b = malloc(len);
/* /*
* Too lazy to implement alignment for debug version, and * Too lazy to implement alignment for debug version, and
@ -153,9 +153,9 @@ static struct block *_new_block(size_t s, unsigned alignment)
return NULL; return NULL;
} }
if (!(b->data = dm_malloc(s))) { if (!(b->data = malloc(s))) {
log_error("Out of memory"); log_error("Out of memory");
dm_free(b); free(b);
return NULL; return NULL;
} }
@ -247,8 +247,8 @@ int dm_pool_grow_object(struct dm_pool *p, const void *extra, size_t delta)
if (p->object) { if (p->object) {
memcpy(new->data, p->object->data, p->object->size); memcpy(new->data, p->object->data, p->object->size);
dm_free(p->object->data); free(p->object->data);
dm_free(p->object); free(p->object);
} }
p->object = new; p->object = new;
@ -270,7 +270,7 @@ void *dm_pool_end_object(struct dm_pool *p)
void dm_pool_abandon_object(struct dm_pool *p) void dm_pool_abandon_object(struct dm_pool *p)
{ {
assert(p->begun); assert(p->begun);
dm_free(p->object); free(p->object);
p->begun = 0; p->begun = 0;
p->object = NULL; p->object = NULL;
} }

View File

@ -17,6 +17,7 @@
#include "memcheck.h" #include "memcheck.h"
#endif #endif
#include "base/memory/zalloc.h"
#include "device_mapper/misc/dmlib.h" #include "device_mapper/misc/dmlib.h"
#include <stddef.h> /* For musl libc */ #include <stddef.h> /* For musl libc */
#include <malloc.h> #include <malloc.h>
@ -48,7 +49,7 @@ static void _free_chunk(struct chunk *c);
struct dm_pool *dm_pool_create(const char *name, size_t chunk_hint) struct dm_pool *dm_pool_create(const char *name, size_t chunk_hint)
{ {
size_t new_size = 1024; size_t new_size = 1024;
struct dm_pool *p = dm_zalloc(sizeof(*p)); struct dm_pool *p = zalloc(sizeof(*p));
if (!p) { if (!p) {
log_error("Couldn't create memory pool %s (size %" log_error("Couldn't create memory pool %s (size %"
@ -82,7 +83,7 @@ void dm_pool_destroy(struct dm_pool *p)
pthread_mutex_lock(&_dm_pools_mutex); pthread_mutex_lock(&_dm_pools_mutex);
dm_list_del(&p->list); dm_list_del(&p->list);
pthread_mutex_unlock(&_dm_pools_mutex); pthread_mutex_unlock(&_dm_pools_mutex);
dm_free(p); free(p);
} }
void *dm_pool_alloc(struct dm_pool *p, size_t s) void *dm_pool_alloc(struct dm_pool *p, size_t s)
@ -281,7 +282,7 @@ static struct chunk *_new_chunk(struct dm_pool *p, size_t s)
# define aligned_malloc(s) (posix_memalign((void**)&c, _pagesize, \ # define aligned_malloc(s) (posix_memalign((void**)&c, _pagesize, \
ALIGN_ON_PAGE(s)) == 0) ALIGN_ON_PAGE(s)) == 0)
#else #else
# define aligned_malloc(s) (c = dm_malloc(s)) # define aligned_malloc(s) (c = malloc(s))
#endif /* DEBUG_ENFORCE_POOL_LOCKING */ #endif /* DEBUG_ENFORCE_POOL_LOCKING */
if (!aligned_malloc(s)) { if (!aligned_malloc(s)) {
#undef aligned_malloc #undef aligned_malloc
@ -315,7 +316,7 @@ static void _free_chunk(struct chunk *c)
/* since DEBUG_MEM is using own memory list */ /* since DEBUG_MEM is using own memory list */
free(c); /* for posix_memalign() */ free(c); /* for posix_memalign() */
#else #else
dm_free(c); free(c);
#endif #endif
} }

View File

@ -1,7 +1,7 @@
#include "target.h" #include "target.h"
// For DM_ARRAY_SIZE! // For DM_ARRAY_SIZE!
#include "device_mapper/libdevmapper.h" #include "device_mapper/all.h"
#include <ctype.h> #include <ctype.h>
#include <stdlib.h> #include <stdlib.h>

View File

@ -1514,7 +1514,7 @@ char *get_monitor_dso_path(struct cmd_context *cmd, int id)
get_shared_library_path(cmd, libpath, path, sizeof(path)); get_shared_library_path(cmd, libpath, path, sizeof(path));
return dm_strdup(path); return strdup(path);
} }
static char *_build_target_uuid(struct cmd_context *cmd, const struct logical_volume *lv) static char *_build_target_uuid(struct cmd_context *cmd, const struct logical_volume *lv)

View File

@ -628,7 +628,7 @@ int device_is_usable(struct device *dev, struct dev_usable_check_params check)
goto out; goto out;
} }
if (!(vgname = dm_strdup(name)) || if (!(vgname = strdup(name)) ||
!dm_split_lvm_name(NULL, NULL, &vgname, &lvname, &layer)) !dm_split_lvm_name(NULL, NULL, &vgname, &lvname, &layer))
goto_out; goto_out;
@ -736,7 +736,7 @@ int device_is_usable(struct device *dev, struct dev_usable_check_params check)
r = 1; r = 1;
out: out:
dm_free(vgname); free(vgname);
dm_task_destroy(dmt); dm_task_destroy(dmt);
return r; return r;
} }

View File

@ -327,7 +327,7 @@ static void _del_fs_op(struct fs_op_parms *fsp)
{ {
_count_fs_ops[fsp->type]--; _count_fs_ops[fsp->type]--;
dm_list_del(&fsp->list); dm_list_del(&fsp->list);
dm_free(fsp); free(fsp);
} }
/* Check if there is other the type of fs operation stacked */ /* Check if there is other the type of fs operation stacked */
@ -401,7 +401,7 @@ static int _stack_fs_op(fs_op_t type, const char *dev_dir, const char *vg_name,
_del_fs_op(fsp); _del_fs_op(fsp);
} }
if (!(fsp = dm_malloc(sizeof(*fsp) + len))) { if (!(fsp = malloc(sizeof(*fsp) + len))) {
log_error("No space to stack fs operation"); log_error("No space to stack fs operation");
return 0; return 0;
} }

57
lib/cache/lvmcache.c vendored
View File

@ -13,6 +13,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "lib/misc/lib.h" #include "lib/misc/lib.h"
#include "lib/cache/lvmcache.h" #include "lib/cache/lvmcache.h"
#include "lib/commands/toolcontext.h" #include "lib/commands/toolcontext.h"
@ -253,7 +254,7 @@ static void _destroy_duplicate_device_list(struct dm_list *head)
dm_list_iterate_items_safe(devl, devl2, head) { dm_list_iterate_items_safe(devl, devl2, head) {
dm_list_del(&devl->list); dm_list_del(&devl->list);
dm_free(devl); free(devl);
} }
dm_list_init(head); dm_list_init(head);
} }
@ -348,7 +349,7 @@ const struct format_type *lvmcache_fmt_from_vgname(struct cmd_context *cmd,
*/ */
dm_list_init(&devs); dm_list_init(&devs);
dm_list_iterate_items(info, &vginfo->infos) { dm_list_iterate_items(info, &vginfo->infos) {
if (!(devl = dm_malloc(sizeof(*devl)))) { if (!(devl = malloc(sizeof(*devl)))) {
log_error("device_list element allocation failed"); log_error("device_list element allocation failed");
return NULL; return NULL;
} }
@ -362,7 +363,7 @@ const struct format_type *lvmcache_fmt_from_vgname(struct cmd_context *cmd,
devl = dm_list_item(devh, struct device_list); devl = dm_list_item(devh, struct device_list);
label_read(devl->dev); label_read(devl->dev);
dm_list_del(&devl->list); dm_list_del(&devl->list);
dm_free(devl); free(devl);
} }
/* If vginfo changed, caller needs to rescan */ /* If vginfo changed, caller needs to rescan */
@ -566,7 +567,7 @@ static void _filter_duplicate_devs(struct cmd_context *cmd)
if (MAJOR(info->dev->dev) == dt->md_major) { if (MAJOR(info->dev->dev) == dt->md_major) {
log_debug_devs("Ignoring md component duplicate %s", dev_name(devl->dev)); log_debug_devs("Ignoring md component duplicate %s", dev_name(devl->dev));
dm_list_del(&devl->list); dm_list_del(&devl->list);
dm_free(devl); free(devl);
} }
} }
@ -836,7 +837,7 @@ next:
dm_list_move(add_cache_devs, &alt->list); dm_list_move(add_cache_devs, &alt->list);
if ((del = dm_zalloc(sizeof(*del)))) { if ((del = zalloc(sizeof(*del)))) {
del->dev = info->dev; del->dev = info->dev;
dm_list_add(del_cache_devs, &del->list); dm_list_add(del_cache_devs, &del->list);
} }
@ -922,7 +923,7 @@ int lvmcache_label_rescan_vg(struct cmd_context *cmd, const char *vgname, const
return 1; return 1;
dm_list_iterate_items(info, &vginfo->infos) { dm_list_iterate_items(info, &vginfo->infos) {
if (!(devl = dm_malloc(sizeof(*devl)))) { if (!(devl = malloc(sizeof(*devl)))) {
log_error("device_list element allocation failed"); log_error("device_list element allocation failed");
return 0; return 0;
} }
@ -945,7 +946,7 @@ int lvmcache_label_rescan_vg(struct cmd_context *cmd, const char *vgname, const
dm_list_iterate_items_safe(devl, devl2, &devs) { dm_list_iterate_items_safe(devl, devl2, &devs) {
dm_list_del(&devl->list); dm_list_del(&devl->list);
dm_free(devl); free(devl);
} }
if (!(vginfo = lvmcache_vginfo_from_vgname(vgname, vgid))) { if (!(vginfo = lvmcache_vginfo_from_vgname(vgname, vgid))) {
@ -1361,9 +1362,9 @@ static int _free_vginfo(struct lvmcache_vginfo *vginfo)
vginfo2 = vginfo2->next; vginfo2 = vginfo2->next;
} }
dm_free(vginfo->system_id); free(vginfo->system_id);
dm_free(vginfo->vgname); free(vginfo->vgname);
dm_free(vginfo->creation_host); free(vginfo->creation_host);
if (*vginfo->vgid && _vgid_hash && if (*vginfo->vgid && _vgid_hash &&
lvmcache_vginfo_from_vgid(vginfo->vgid) == vginfo) lvmcache_vginfo_from_vgid(vginfo->vgid) == vginfo)
@ -1371,7 +1372,7 @@ static int _free_vginfo(struct lvmcache_vginfo *vginfo)
dm_list_del(&vginfo->list); dm_list_del(&vginfo->list);
dm_free(vginfo); free(vginfo);
return r; return r;
} }
@ -1405,7 +1406,7 @@ void lvmcache_del(struct lvmcache_info *info)
info->label->labeller->ops->destroy_label(info->label->labeller, info->label->labeller->ops->destroy_label(info->label->labeller,
info->label); info->label);
label_destroy(info->label); label_destroy(info->label);
dm_free(info); free(info);
} }
void lvmcache_del_dev(struct device *dev) void lvmcache_del_dev(struct device *dev)
@ -1568,12 +1569,12 @@ static int _lvmcache_update_vgname(struct lvmcache_info *info,
* into the hash table. * into the hash table.
*/ */
if (!(vginfo = dm_zalloc(sizeof(*vginfo)))) { if (!(vginfo = zalloc(sizeof(*vginfo)))) {
log_error("lvmcache_update_vgname: list alloc failed"); log_error("lvmcache_update_vgname: list alloc failed");
return 0; return 0;
} }
if (!(vginfo->vgname = dm_strdup(vgname))) { if (!(vginfo->vgname = strdup(vgname))) {
dm_free(vginfo); free(vginfo);
log_error("cache vgname alloc failed for %s", vgname); log_error("cache vgname alloc failed for %s", vgname);
return 0; return 0;
} }
@ -1588,8 +1589,8 @@ static int _lvmcache_update_vgname(struct lvmcache_info *info,
primary_vginfo = lvmcache_vginfo_from_vgname(vgname, NULL); primary_vginfo = lvmcache_vginfo_from_vgname(vgname, NULL);
if (!_insert_vginfo(vginfo, vgid, vgstatus, creation_host, primary_vginfo)) { if (!_insert_vginfo(vginfo, vgid, vgstatus, creation_host, primary_vginfo)) {
dm_free(vginfo->vgname); free(vginfo->vgname);
dm_free(vginfo); free(vginfo);
return 0; return 0;
} }
@ -1647,9 +1648,9 @@ static int _lvmcache_update_vgstatus(struct lvmcache_info *info, uint32_t vgstat
info->vginfo->creation_host)) info->vginfo->creation_host))
goto set_lock_type; goto set_lock_type;
dm_free(info->vginfo->creation_host); free(info->vginfo->creation_host);
if (!(info->vginfo->creation_host = dm_strdup(creation_host))) { if (!(info->vginfo->creation_host = strdup(creation_host))) {
log_error("cache creation host alloc failed for %s.", log_error("cache creation host alloc failed for %s.",
creation_host); creation_host);
return 0; return 0;
@ -1666,9 +1667,9 @@ set_lock_type:
if (info->vginfo->lock_type && !strcmp(lock_type, info->vginfo->lock_type)) if (info->vginfo->lock_type && !strcmp(lock_type, info->vginfo->lock_type))
goto set_system_id; goto set_system_id;
dm_free(info->vginfo->lock_type); free(info->vginfo->lock_type);
if (!(info->vginfo->lock_type = dm_strdup(lock_type))) { if (!(info->vginfo->lock_type = strdup(lock_type))) {
log_error("cache lock_type alloc failed for %s", lock_type); log_error("cache lock_type alloc failed for %s", lock_type);
return 0; return 0;
} }
@ -1684,9 +1685,9 @@ set_system_id:
if (info->vginfo->system_id && !strcmp(system_id, info->vginfo->system_id)) if (info->vginfo->system_id && !strcmp(system_id, info->vginfo->system_id))
goto out; goto out;
dm_free(info->vginfo->system_id); free(info->vginfo->system_id);
if (!(info->vginfo->system_id = dm_strdup(system_id))) { if (!(info->vginfo->system_id = strdup(system_id))) {
log_error("cache system_id alloc failed for %s", system_id); log_error("cache system_id alloc failed for %s", system_id);
return 0; return 0;
} }
@ -1889,7 +1890,7 @@ static struct lvmcache_info * _create_info(struct labeller *labeller, struct dev
if (!(label = label_create(labeller))) if (!(label = label_create(labeller)))
return_NULL; return_NULL;
if (!(info = dm_zalloc(sizeof(*info)))) { if (!(info = zalloc(sizeof(*info)))) {
log_error("lvmcache_info allocation failed"); log_error("lvmcache_info allocation failed");
label_destroy(label); label_destroy(label);
return NULL; return NULL;
@ -1965,7 +1966,7 @@ struct lvmcache_info *lvmcache_add(struct labeller *labeller,
* use it. * use it.
*/ */
if (!(devl = dm_zalloc(sizeof(*devl)))) if (!(devl = zalloc(sizeof(*devl))))
return_NULL; return_NULL;
devl->dev = dev; devl->dev = dev;
@ -2020,8 +2021,8 @@ update_vginfo:
if (created) { if (created) {
dm_hash_remove(_pvid_hash, pvid_s); dm_hash_remove(_pvid_hash, pvid_s);
strcpy(info->dev->pvid, ""); strcpy(info->dev->pvid, "");
dm_free(info->label); free(info->label);
dm_free(info); free(info);
} }
return NULL; return NULL;
} }
@ -2034,7 +2035,7 @@ static void _lvmcache_destroy_entry(struct lvmcache_info *info)
_vginfo_detach_info(info); _vginfo_detach_info(info);
info->dev->pvid[0] = 0; info->dev->pvid[0] = 0;
label_destroy(info->label); label_destroy(info->label);
dm_free(info); free(info);
} }
static void _lvmcache_destroy_vgnamelist(struct lvmcache_vginfo *vginfo) static void _lvmcache_destroy_vgnamelist(struct lvmcache_vginfo *vginfo)

4
lib/cache/lvmetad.c vendored
View File

@ -196,7 +196,7 @@ void lvmetad_set_token(const struct dm_config_value *filter)
{ {
int ft = 0; int ft = 0;
dm_free(_lvmetad_token); free(_lvmetad_token);
while (filter && filter->type == DM_CFG_STRING) { while (filter && filter->type == DM_CFG_STRING) {
ft = calc_crc(ft, (const uint8_t *) filter->v.str, strlen(filter->v.str)); ft = calc_crc(ft, (const uint8_t *) filter->v.str, strlen(filter->v.str));
@ -209,7 +209,7 @@ void lvmetad_set_token(const struct dm_config_value *filter)
void lvmetad_release_token(void) void lvmetad_release_token(void)
{ {
dm_free(_lvmetad_token); free(_lvmetad_token);
_lvmetad_token = NULL; _lvmetad_token = NULL;
} }

View File

@ -12,6 +12,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "lib/misc/lib.h" #include "lib/misc/lib.h"
#include "lib/commands/toolcontext.h" #include "lib/commands/toolcontext.h"
#include "lib/metadata/segtype.h" #include "lib/metadata/segtype.h"
@ -261,7 +262,7 @@ static int _cache_pool_text_export(const struct lv_segment *seg,
static void _destroy(struct segment_type *segtype) static void _destroy(struct segment_type *segtype)
{ {
dm_free((void *) segtype); free((void *) segtype);
} }
#ifdef DEVMAPPER_SUPPORT #ifdef DEVMAPPER_SUPPORT
@ -611,7 +612,7 @@ int init_cache_segtypes(struct cmd_context *cmd,
struct segtype_library *seglib) struct segtype_library *seglib)
#endif #endif
{ {
struct segment_type *segtype = dm_zalloc(sizeof(*segtype)); struct segment_type *segtype = zalloc(sizeof(*segtype));
if (!segtype) { if (!segtype) {
log_error("Failed to allocate memory for cache_pool segtype"); log_error("Failed to allocate memory for cache_pool segtype");
@ -626,7 +627,7 @@ int init_cache_segtypes(struct cmd_context *cmd,
return_0; return_0;
log_very_verbose("Initialised segtype: %s", segtype->name); log_very_verbose("Initialised segtype: %s", segtype->name);
segtype = dm_zalloc(sizeof(*segtype)); segtype = zalloc(sizeof(*segtype));
if (!segtype) { if (!segtype) {
log_error("Failed to allocate memory for cache segtype"); log_error("Failed to allocate memory for cache segtype");
return 0; return 0;

View File

@ -13,6 +13,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "lib/misc/lib.h" #include "lib/misc/lib.h"
#include "lib/commands/toolcontext.h" #include "lib/commands/toolcontext.h"
#include "lib/metadata/metadata.h" #include "lib/metadata/metadata.h"
@ -1758,7 +1759,7 @@ void destroy_config_context(struct cmd_context *cmd)
if (cmd->libmem) if (cmd->libmem)
dm_pool_destroy(cmd->libmem); dm_pool_destroy(cmd->libmem);
dm_free(cmd); free(cmd);
} }
/* /*
@ -1771,7 +1772,7 @@ struct cmd_context *create_config_context(void)
{ {
struct cmd_context *cmd; struct cmd_context *cmd;
if (!(cmd = dm_zalloc(sizeof(*cmd)))) if (!(cmd = zalloc(sizeof(*cmd))))
goto_out; goto_out;
strcpy(cmd->system_dir, DEFAULT_SYS_DIR); strcpy(cmd->system_dir, DEFAULT_SYS_DIR);
@ -1838,7 +1839,7 @@ struct cmd_context *create_toolcontext(unsigned is_clvmd,
init_syslog(DEFAULT_LOG_FACILITY); init_syslog(DEFAULT_LOG_FACILITY);
if (!(cmd = dm_zalloc(sizeof(*cmd)))) { if (!(cmd = zalloc(sizeof(*cmd)))) {
log_error("Failed to allocate command context"); log_error("Failed to allocate command context");
return NULL; return NULL;
} }
@ -1870,7 +1871,7 @@ struct cmd_context *create_toolcontext(unsigned is_clvmd,
#endif #endif
) { ) {
/* Allocate 2 buffers */ /* Allocate 2 buffers */
if (!(cmd->linebuffer = dm_malloc(2 * _linebuffer_size))) { if (!(cmd->linebuffer = malloc(2 * _linebuffer_size))) {
log_error("Failed to allocate line buffer."); log_error("Failed to allocate line buffer.");
goto out; goto out;
} }
@ -2062,7 +2063,7 @@ static void _destroy_dev_types(struct cmd_context *cmd)
if (!cmd->dev_types) if (!cmd->dev_types)
return; return;
dm_free(cmd->dev_types); free(cmd->dev_types);
cmd->dev_types = NULL; cmd->dev_types = NULL;
} }
@ -2275,10 +2276,10 @@ void destroy_toolcontext(struct cmd_context *cmd)
cmd->linebuffer = NULL; /* Leave buffer in place (deliberate leak) */ cmd->linebuffer = NULL; /* Leave buffer in place (deliberate leak) */
} }
dm_free(cmd->linebuffer); free(cmd->linebuffer);
} }
#endif #endif
dm_free(cmd); free(cmd);
lvmetad_release_token(); lvmetad_release_token();
lvmetad_disconnect(); lvmetad_disconnect();

View File

@ -529,7 +529,7 @@ int config_file_read_fd(struct dm_config_tree *cft, struct device *dev, dev_io_r
} }
fb = fb + mmap_offset; fb = fb + mmap_offset;
} else { } else {
if (!(buf = dm_malloc(size + size2))) { if (!(buf = malloc(size + size2))) {
log_error("Failed to allocate circular buffer."); log_error("Failed to allocate circular buffer.");
return 0; return 0;
} }
@ -573,7 +573,7 @@ int config_file_read_fd(struct dm_config_tree *cft, struct device *dev, dev_io_r
out: out:
if (!use_mmap) if (!use_mmap)
dm_free(buf); free(buf);
else { else {
/* unmap the file */ /* unmap the file */
if (munmap(fb - mmap_offset, size + mmap_offset)) { if (munmap(fb - mmap_offset, size + mmap_offset)) {
@ -715,8 +715,8 @@ static struct dm_config_value *_get_def_array_values(struct cmd_context *cmd,
return array; return array;
} }
if (!(p = token = enc_value = dm_strdup(def_enc_value))) { if (!(p = token = enc_value = strdup(def_enc_value))) {
log_error("_get_def_array_values: dm_strdup failed"); log_error("_get_def_array_values: strdup failed");
return NULL; return NULL;
} }
/* Proper value always starts with '#'. */ /* Proper value always starts with '#'. */
@ -741,7 +741,7 @@ static struct dm_config_value *_get_def_array_values(struct cmd_context *cmd,
if (!(v = dm_config_create_value(cft))) { if (!(v = dm_config_create_value(cft))) {
log_error("Failed to create default config array value for %s.", def->name); log_error("Failed to create default config array value for %s.", def->name);
dm_free(enc_value); free(enc_value);
return NULL; return NULL;
} }
@ -770,7 +770,7 @@ static struct dm_config_value *_get_def_array_values(struct cmd_context *cmd,
break; break;
case 'S': case 'S':
if (!(r = dm_pool_strdup(cft->mem, token + 1))) { if (!(r = dm_pool_strdup(cft->mem, token + 1))) {
dm_free(enc_value); free(enc_value);
log_error("Failed to duplicate token for default " log_error("Failed to duplicate token for default "
"array value of %s.", def->name); "array value of %s.", def->name);
return NULL; return NULL;
@ -786,13 +786,13 @@ static struct dm_config_value *_get_def_array_values(struct cmd_context *cmd,
token = p; token = p;
} }
dm_free(enc_value); free(enc_value);
return array; return array;
bad: bad:
log_error(INTERNAL_ERROR "Default array value malformed for \"%s\", " log_error(INTERNAL_ERROR "Default array value malformed for \"%s\", "
"value: \"%s\", token: \"%s\".", def->name, "value: \"%s\", token: \"%s\".", def->name,
def->default_value.v_CFG_TYPE_STRING, token); def->default_value.v_CFG_TYPE_STRING, token);
dm_free(enc_value); free(enc_value);
return NULL; return NULL;
} }

View File

@ -16,7 +16,7 @@
#ifndef _LVM_CONFIG_H #ifndef _LVM_CONFIG_H
#define _LVM_CONFIG_H #define _LVM_CONFIG_H
#include "device_mapper/libdevmapper.h" #include "device_mapper/all.h"
#include "lib/device/device.h" #include "lib/device/device.h"
/* 16 bits: 3 bits for major, 4 bits for minor, 9 bits for patchlevel */ /* 16 bits: 3 bits for major, 4 bits for minor, 9 bits for patchlevel */

View File

@ -70,14 +70,14 @@ struct cb_set {
static struct cb_set *_cb_set_create(unsigned nr) static struct cb_set *_cb_set_create(unsigned nr)
{ {
int i; int i;
struct cb_set *cbs = dm_malloc(sizeof(*cbs)); struct cb_set *cbs = malloc(sizeof(*cbs));
if (!cbs) if (!cbs)
return NULL; return NULL;
cbs->vec = dm_malloc(nr * sizeof(*cbs->vec)); cbs->vec = malloc(nr * sizeof(*cbs->vec));
if (!cbs->vec) { if (!cbs->vec) {
dm_free(cbs); free(cbs);
return NULL; return NULL;
} }
@ -100,8 +100,8 @@ static void _cb_set_destroy(struct cb_set *cbs)
return; return;
} }
dm_free(cbs->vec); free(cbs->vec);
dm_free(cbs); free(cbs);
} }
static struct control_block *_cb_alloc(struct cb_set *cbs, void *context) static struct control_block *_cb_alloc(struct cb_set *cbs, void *context)
@ -155,7 +155,7 @@ static void _async_destroy(struct io_engine *ioe)
if (r) if (r)
log_sys_warn("io_destroy"); log_sys_warn("io_destroy");
dm_free(e); free(e);
} }
static bool _async_issue(struct io_engine *ioe, enum dir d, int fd, static bool _async_issue(struct io_engine *ioe, enum dir d, int fd,
@ -253,7 +253,7 @@ static unsigned _async_max_io(struct io_engine *e)
struct io_engine *create_async_io_engine(void) struct io_engine *create_async_io_engine(void)
{ {
int r; int r;
struct async_engine *e = dm_malloc(sizeof(*e)); struct async_engine *e = malloc(sizeof(*e));
if (!e) if (!e)
return NULL; return NULL;
@ -267,14 +267,14 @@ struct io_engine *create_async_io_engine(void)
r = io_setup(MAX_IO, &e->aio_context); r = io_setup(MAX_IO, &e->aio_context);
if (r < 0) { if (r < 0) {
log_warn("io_setup failed"); log_warn("io_setup failed");
dm_free(e); free(e);
return NULL; return NULL;
} }
e->cbs = _cb_set_create(MAX_IO); e->cbs = _cb_set_create(MAX_IO);
if (!e->cbs) { if (!e->cbs) {
log_warn("couldn't create control block set"); log_warn("couldn't create control block set");
dm_free(e); free(e);
return NULL; return NULL;
} }
@ -303,7 +303,7 @@ static struct sync_engine *_to_sync(struct io_engine *e)
static void _sync_destroy(struct io_engine *ioe) static void _sync_destroy(struct io_engine *ioe)
{ {
struct sync_engine *e = _to_sync(ioe); struct sync_engine *e = _to_sync(ioe);
dm_free(e); free(e);
} }
static bool _sync_issue(struct io_engine *ioe, enum dir d, int fd, static bool _sync_issue(struct io_engine *ioe, enum dir d, int fd,
@ -362,7 +362,7 @@ static bool _sync_wait(struct io_engine *ioe, io_complete_fn fn)
dm_list_iterate_items_safe(io, tmp, &e->complete) { dm_list_iterate_items_safe(io, tmp, &e->complete) {
fn(io->context, 0); fn(io->context, 0);
dm_list_del(&io->list); dm_list_del(&io->list);
dm_free(io); free(io);
} }
return true; return true;
@ -375,7 +375,7 @@ static unsigned _sync_max_io(struct io_engine *e)
struct io_engine *create_sync_io_engine(void) struct io_engine *create_sync_io_engine(void)
{ {
struct sync_engine *e = dm_malloc(sizeof(*e)); struct sync_engine *e = malloc(sizeof(*e));
if (!e) if (!e)
return NULL; return NULL;
@ -530,10 +530,10 @@ static bool _init_free_list(struct bcache *cache, unsigned count, unsigned pgsiz
return false; return false;
cache->raw_data = data; cache->raw_data = data;
cache->raw_blocks = dm_malloc(count * sizeof(*cache->raw_blocks)); cache->raw_blocks = malloc(count * sizeof(*cache->raw_blocks));
if (!cache->raw_blocks) if (!cache->raw_blocks)
dm_free(cache->raw_data); free(cache->raw_data);
for (i = 0; i < count; i++) { for (i = 0; i < count; i++) {
struct block *b = cache->raw_blocks + i; struct block *b = cache->raw_blocks + i;
@ -547,8 +547,8 @@ static bool _init_free_list(struct bcache *cache, unsigned count, unsigned pgsiz
static void _exit_free_list(struct bcache *cache) static void _exit_free_list(struct bcache *cache)
{ {
dm_free(cache->raw_data); free(cache->raw_data);
dm_free(cache->raw_blocks); free(cache->raw_blocks);
} }
static struct block *_alloc_block(struct bcache *cache) static struct block *_alloc_block(struct bcache *cache)
@ -885,7 +885,7 @@ struct bcache *bcache_create(sector_t block_sectors, unsigned nr_cache_blocks,
return NULL; return NULL;
} }
cache = dm_malloc(sizeof(*cache)); cache = malloc(sizeof(*cache));
if (!cache) if (!cache)
return NULL; return NULL;
@ -906,7 +906,7 @@ struct bcache *bcache_create(sector_t block_sectors, unsigned nr_cache_blocks,
cache->rtree = radix_tree_create(NULL, NULL); cache->rtree = radix_tree_create(NULL, NULL);
if (!cache->rtree) { if (!cache->rtree) {
cache->engine->destroy(cache->engine); cache->engine->destroy(cache->engine);
dm_free(cache); free(cache);
return NULL; return NULL;
} }
@ -920,7 +920,7 @@ struct bcache *bcache_create(sector_t block_sectors, unsigned nr_cache_blocks,
if (!_init_free_list(cache, nr_cache_blocks, pgsize)) { if (!_init_free_list(cache, nr_cache_blocks, pgsize)) {
cache->engine->destroy(cache->engine); cache->engine->destroy(cache->engine);
radix_tree_destroy(cache->rtree); radix_tree_destroy(cache->rtree);
dm_free(cache); free(cache);
return NULL; return NULL;
} }
@ -937,7 +937,7 @@ void bcache_destroy(struct bcache *cache)
_exit_free_list(cache); _exit_free_list(cache);
radix_tree_destroy(cache->rtree); radix_tree_destroy(cache->rtree);
cache->engine->destroy(cache->engine); cache->engine->destroy(cache->engine);
dm_free(cache); free(cache);
} }
sector_t bcache_block_sectors(struct bcache *cache) sector_t bcache_block_sectors(struct bcache *cache)

View File

@ -15,7 +15,7 @@
#ifndef BCACHE_H #ifndef BCACHE_H
#define BCACHE_H #define BCACHE_H
#include "device_mapper/libdevmapper.h" #include "device_mapper/all.h"
#include <linux/fs.h> #include <linux/fs.h>
#include <stdint.h> #include <stdint.h>

View File

@ -13,6 +13,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "lib/misc/lib.h" #include "lib/misc/lib.h"
#include "lib/datastruct/btree.h" #include "lib/datastruct/btree.h"
#include "lib/config/config.h" #include "lib/config/config.h"
@ -80,9 +81,9 @@ void dev_destroy_file(struct device *dev)
if (!(dev->flags & DEV_ALLOCED)) if (!(dev->flags & DEV_ALLOCED))
return; return;
dm_free((void *) dm_list_item(dev->aliases.n, struct dm_str_list)->str); free((void *) dm_list_item(dev->aliases.n, struct dm_str_list)->str);
dm_free(dev->aliases.n); free(dev->aliases.n);
dm_free(dev); free(dev);
} }
struct device *dev_create_file(const char *filename, struct device *dev, struct device *dev_create_file(const char *filename, struct device *dev,
@ -92,19 +93,19 @@ struct device *dev_create_file(const char *filename, struct device *dev,
if (allocate) { if (allocate) {
if (use_malloc) { if (use_malloc) {
if (!(dev = dm_zalloc(sizeof(*dev)))) { if (!(dev = zalloc(sizeof(*dev)))) {
log_error("struct device allocation failed"); log_error("struct device allocation failed");
return NULL; return NULL;
} }
if (!(alias = dm_zalloc(sizeof(*alias)))) { if (!(alias = zalloc(sizeof(*alias)))) {
log_error("struct dm_str_list allocation failed"); log_error("struct dm_str_list allocation failed");
dm_free(dev); free(dev);
return NULL; return NULL;
} }
if (!(alias->str = dm_strdup(filename))) { if (!(alias->str = strdup(filename))) {
log_error("filename strdup failed"); log_error("filename strdup failed");
dm_free(dev); free(dev);
dm_free(alias); free(alias);
return NULL; return NULL;
} }
} else { } else {
@ -123,7 +124,7 @@ struct device *dev_create_file(const char *filename, struct device *dev,
return NULL; return NULL;
} }
} }
} else if (!(alias->str = dm_strdup(filename))) { } else if (!(alias->str = strdup(filename))) {
log_error("filename strdup failed"); log_error("filename strdup failed");
return NULL; return NULL;
} }
@ -861,7 +862,7 @@ static int _insert_dev(const char *path, dev_t d)
static char *_join(const char *dir, const char *name) static char *_join(const char *dir, const char *name)
{ {
size_t len = strlen(dir) + strlen(name) + 2; size_t len = strlen(dir) + strlen(name) + 2;
char *r = dm_malloc(len); char *r = malloc(len);
if (r) if (r)
snprintf(r, len, "%s/%s", dir, name); snprintf(r, len, "%s/%s", dir, name);
@ -909,7 +910,7 @@ static int _insert_dir(const char *dir)
_collapse_slashes(path); _collapse_slashes(path);
r &= _insert(path, NULL, 1, 0); r &= _insert(path, NULL, 1, 0);
dm_free(path); free(path);
free(dirent[n]); free(dirent[n]);
} }
@ -1632,7 +1633,7 @@ struct device *dev_cache_get_by_devt(dev_t dev, struct dev_filter *f)
struct dev_iter *dev_iter_create(struct dev_filter *f, int unused) struct dev_iter *dev_iter_create(struct dev_filter *f, int unused)
{ {
struct dev_iter *di = dm_malloc(sizeof(*di)); struct dev_iter *di = malloc(sizeof(*di));
if (!di) { if (!di) {
log_error("dev_iter allocation failed"); log_error("dev_iter allocation failed");
@ -1651,7 +1652,7 @@ void dev_iter_destroy(struct dev_iter *iter)
{ {
if (iter->filter) if (iter->filter)
iter->filter->use_count--; iter->filter->use_count--;
dm_free(iter); free(iter);
} }
static struct device *_iter_next(struct dev_iter *iter) static struct device *_iter_next(struct dev_iter *iter)

View File

@ -256,7 +256,7 @@ static int _aligned_io(struct device_area *where, char *buffer,
return _io(where, buffer, should_write, reason); return _io(where, buffer, should_write, reason);
/* Allocate a bounce buffer with an extra block */ /* Allocate a bounce buffer with an extra block */
if (!(bounce_buf = bounce = dm_malloc((size_t) widened.size + block_size))) { if (!(bounce_buf = bounce = malloc((size_t) widened.size + block_size))) {
log_error("Bounce buffer malloc failed"); log_error("Bounce buffer malloc failed");
return 0; return 0;
} }
@ -294,7 +294,7 @@ static int _aligned_io(struct device_area *where, char *buffer,
r = 1; r = 1;
out: out:
dm_free(bounce_buf); free(bounce_buf);
return r; return r;
} }

View File

@ -12,6 +12,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "lib/misc/lib.h" #include "lib/misc/lib.h"
#include "lib/device/dev-type.h" #include "lib/device/dev-type.h"
#include "lib/mm/xlate.h" #include "lib/mm/xlate.h"
@ -49,7 +50,7 @@ struct dev_types *create_dev_types(const char *proc_dir,
const char *name; const char *name;
char *nl; char *nl;
if (!(dt = dm_zalloc(sizeof(struct dev_types)))) { if (!(dt = zalloc(sizeof(struct dev_types)))) {
log_error("Failed to allocate device type register."); log_error("Failed to allocate device type register.");
return NULL; return NULL;
} }
@ -204,7 +205,7 @@ struct dev_types *create_dev_types(const char *proc_dir,
return dt; return dt;
bad: bad:
dm_free(dt); free(dt);
return NULL; return NULL;
} }

View File

@ -22,7 +22,7 @@
#define DEV_ACCESSED_W 0x00000001 /* Device written to? */ #define DEV_ACCESSED_W 0x00000001 /* Device written to? */
#define DEV_REGULAR 0x00000002 /* Regular file? */ #define DEV_REGULAR 0x00000002 /* Regular file? */
#define DEV_ALLOCED 0x00000004 /* dm_malloc used */ #define DEV_ALLOCED 0x00000004 /* malloc used */
#define DEV_OPENED_RW 0x00000008 /* Opened RW */ #define DEV_OPENED_RW 0x00000008 /* Opened RW */
#define DEV_OPENED_EXCL 0x00000010 /* Opened EXCL */ #define DEV_OPENED_EXCL 0x00000010 /* Opened EXCL */
#define DEV_O_DIRECT 0x00000020 /* Use O_DIRECT */ #define DEV_O_DIRECT 0x00000020 /* Use O_DIRECT */

View File

@ -12,6 +12,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "lib/misc/lib.h" #include "lib/misc/lib.h"
#include "lib/commands/toolcontext.h" #include "lib/commands/toolcontext.h"
#include "lib/metadata/segtype.h" #include "lib/metadata/segtype.h"
@ -77,7 +78,7 @@ static int _errseg_modules_needed(struct dm_pool *mem,
static void _errseg_destroy(struct segment_type *segtype) static void _errseg_destroy(struct segment_type *segtype)
{ {
dm_free(segtype); free(segtype);
} }
static struct segtype_handler _error_ops = { static struct segtype_handler _error_ops = {
@ -92,7 +93,7 @@ static struct segtype_handler _error_ops = {
struct segment_type *init_error_segtype(struct cmd_context *cmd) struct segment_type *init_error_segtype(struct cmd_context *cmd)
{ {
struct segment_type *segtype = dm_zalloc(sizeof(*segtype)); struct segment_type *segtype = zalloc(sizeof(*segtype));
if (!segtype) if (!segtype)
return_NULL; return_NULL;

View File

@ -13,6 +13,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "lib/misc/lib.h" #include "lib/misc/lib.h"
#include "lib/filters/filter.h" #include "lib/filters/filter.h"
#include "lib/device/device.h" #include "lib/device/device.h"
@ -53,8 +54,8 @@ static void _composite_destroy(struct dev_filter *f)
for (filters = (struct dev_filter **) f->private; *filters; ++filters) for (filters = (struct dev_filter **) f->private; *filters; ++filters)
(*filters)->destroy(*filters); (*filters)->destroy(*filters);
dm_free(f->private); free(f->private);
dm_free(f); free(f);
} }
static int _dump(struct dev_filter *f, int merge_existing) static int _dump(struct dev_filter *f, int merge_existing)
@ -85,7 +86,7 @@ struct dev_filter *composite_filter_create(int n, int use_dev_ext_info, struct d
if (!filters) if (!filters)
return_NULL; return_NULL;
if (!(filters_copy = dm_malloc(sizeof(*filters) * (n + 1)))) { if (!(filters_copy = malloc(sizeof(*filters) * (n + 1)))) {
log_error("Composite filters allocation failed."); log_error("Composite filters allocation failed.");
return NULL; return NULL;
} }
@ -93,9 +94,9 @@ struct dev_filter *composite_filter_create(int n, int use_dev_ext_info, struct d
memcpy(filters_copy, filters, sizeof(*filters) * n); memcpy(filters_copy, filters, sizeof(*filters) * n);
filters_copy[n] = NULL; filters_copy[n] = NULL;
if (!(cft = dm_zalloc(sizeof(*cft)))) { if (!(cft = zalloc(sizeof(*cft)))) {
log_error("Composite filters allocation failed."); log_error("Composite filters allocation failed.");
dm_free(filters_copy); free(filters_copy);
return NULL; return NULL;
} }

View File

@ -12,6 +12,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "lib/misc/lib.h" #include "lib/misc/lib.h"
#include "lib/filters/filter.h" #include "lib/filters/filter.h"
@ -96,14 +97,14 @@ static void _destroy(struct dev_filter *f)
if (f->use_count) if (f->use_count)
log_error(INTERNAL_ERROR "Destroying firmware RAID filter while in use %u times.", f->use_count); log_error(INTERNAL_ERROR "Destroying firmware RAID filter while in use %u times.", f->use_count);
dm_free(f); free(f);
} }
struct dev_filter *fwraid_filter_create(struct dev_types *dt __attribute__((unused))) struct dev_filter *fwraid_filter_create(struct dev_types *dt __attribute__((unused)))
{ {
struct dev_filter *f; struct dev_filter *f;
if (!(f = dm_zalloc(sizeof(*f)))) { if (!(f = zalloc(sizeof(*f)))) {
log_error("Firmware RAID filter allocation failed"); log_error("Firmware RAID filter allocation failed");
return NULL; return NULL;
} }

View File

@ -12,6 +12,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "lib/misc/lib.h" #include "lib/misc/lib.h"
#include "lib/filters/filter.h" #include "lib/filters/filter.h"
@ -58,14 +59,14 @@ static void _destroy(struct dev_filter *f)
if (f->use_count) if (f->use_count)
log_error(INTERNAL_ERROR "Destroying internal filter while in use %u times.", f->use_count); log_error(INTERNAL_ERROR "Destroying internal filter while in use %u times.", f->use_count);
dm_free(f); free(f);
} }
struct dev_filter *internal_filter_create(void) struct dev_filter *internal_filter_create(void)
{ {
struct dev_filter *f; struct dev_filter *f;
if (!(f = dm_zalloc(sizeof(*f)))) { if (!(f = zalloc(sizeof(*f)))) {
log_error("md filter allocation failed"); log_error("md filter allocation failed");
return NULL; return NULL;
} }

View File

@ -13,6 +13,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "lib/misc/lib.h" #include "lib/misc/lib.h"
#include "lib/filters/filter.h" #include "lib/filters/filter.h"
@ -138,14 +139,14 @@ static void _destroy(struct dev_filter *f)
if (f->use_count) if (f->use_count)
log_error(INTERNAL_ERROR "Destroying md filter while in use %u times.", f->use_count); log_error(INTERNAL_ERROR "Destroying md filter while in use %u times.", f->use_count);
dm_free(f); free(f);
} }
struct dev_filter *md_filter_create(struct cmd_context *cmd, struct dev_types *dt) struct dev_filter *md_filter_create(struct cmd_context *cmd, struct dev_types *dt)
{ {
struct dev_filter *f; struct dev_filter *f;
if (!(f = dm_zalloc(sizeof(*f)))) { if (!(f = zalloc(sizeof(*f)))) {
log_error("md filter allocation failed"); log_error("md filter allocation failed");
return NULL; return NULL;
} }

View File

@ -12,6 +12,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "lib/misc/lib.h" #include "lib/misc/lib.h"
#include "lib/filters/filter.h" #include "lib/filters/filter.h"
#include "lib/activate/activate.h" #include "lib/activate/activate.h"
@ -265,7 +266,7 @@ static void _destroy(struct dev_filter *f)
if (f->use_count) if (f->use_count)
log_error(INTERNAL_ERROR "Destroying mpath filter while in use %u times.", f->use_count); log_error(INTERNAL_ERROR "Destroying mpath filter while in use %u times.", f->use_count);
dm_free(f); free(f);
} }
struct dev_filter *mpath_filter_create(struct dev_types *dt) struct dev_filter *mpath_filter_create(struct dev_types *dt)
@ -278,7 +279,7 @@ struct dev_filter *mpath_filter_create(struct dev_types *dt)
return NULL; return NULL;
} }
if (!(f = dm_zalloc(sizeof(*f)))) { if (!(f = zalloc(sizeof(*f)))) {
log_error("mpath filter allocation failed"); log_error("mpath filter allocation failed");
return NULL; return NULL;
} }

View File

@ -13,6 +13,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "lib/misc/lib.h" #include "lib/misc/lib.h"
#include "lib/filters/filter.h" #include "lib/filters/filter.h"
@ -49,14 +50,14 @@ static void _partitioned_filter_destroy(struct dev_filter *f)
if (f->use_count) if (f->use_count)
log_error(INTERNAL_ERROR "Destroying partitioned filter while in use %u times.", f->use_count); log_error(INTERNAL_ERROR "Destroying partitioned filter while in use %u times.", f->use_count);
dm_free(f); free(f);
} }
struct dev_filter *partitioned_filter_create(struct dev_types *dt) struct dev_filter *partitioned_filter_create(struct dev_types *dt)
{ {
struct dev_filter *f; struct dev_filter *f;
if (!(f = dm_zalloc(sizeof(struct dev_filter)))) { if (!(f = zalloc(sizeof(struct dev_filter)))) {
log_error("Partitioned filter allocation failed"); log_error("Partitioned filter allocation failed");
return NULL; return NULL;
} }

View File

@ -13,6 +13,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "lib/misc/lib.h" #include "lib/misc/lib.h"
#include "lib/filters/filter.h" #include "lib/filters/filter.h"
#include "lib/config/config.h" #include "lib/config/config.h"
@ -360,10 +361,10 @@ static void _persistent_destroy(struct dev_filter *f)
log_error(INTERNAL_ERROR "Destroying persistent filter while in use %u times.", f->use_count); log_error(INTERNAL_ERROR "Destroying persistent filter while in use %u times.", f->use_count);
dm_hash_destroy(pf->devices); dm_hash_destroy(pf->devices);
dm_free(pf->file); free(pf->file);
pf->real->destroy(pf->real); pf->real->destroy(pf->real);
dm_free(pf); free(pf);
dm_free(f); free(f);
} }
struct dev_filter *persistent_filter_create(struct dev_types *dt, struct dev_filter *persistent_filter_create(struct dev_types *dt,
@ -374,14 +375,14 @@ struct dev_filter *persistent_filter_create(struct dev_types *dt,
struct dev_filter *f = NULL; struct dev_filter *f = NULL;
struct stat info; struct stat info;
if (!(pf = dm_zalloc(sizeof(*pf)))) { if (!(pf = zalloc(sizeof(*pf)))) {
log_error("Allocation of persistent filter failed."); log_error("Allocation of persistent filter failed.");
return NULL; return NULL;
} }
pf->dt = dt; pf->dt = dt;
if (!(pf->file = dm_strdup(file))) { if (!(pf->file = strdup(file))) {
log_error("Filename duplication for persistent filter failed."); log_error("Filename duplication for persistent filter failed.");
goto bad; goto bad;
} }
@ -393,7 +394,7 @@ struct dev_filter *persistent_filter_create(struct dev_types *dt,
goto bad; goto bad;
} }
if (!(f = dm_zalloc(sizeof(*f)))) { if (!(f = zalloc(sizeof(*f)))) {
log_error("Allocation of device filter for persistent filter failed."); log_error("Allocation of device filter for persistent filter failed.");
goto bad; goto bad;
} }
@ -414,10 +415,10 @@ struct dev_filter *persistent_filter_create(struct dev_types *dt,
return f; return f;
bad: bad:
dm_free(pf->file); free(pf->file);
if (pf->devices) if (pf->devices)
dm_hash_destroy(pf->devices); dm_hash_destroy(pf->devices);
dm_free(pf); free(pf);
dm_free(f); free(f);
return NULL; return NULL;
} }

View File

@ -13,6 +13,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "lib/misc/lib.h" #include "lib/misc/lib.h"
#include "lib/filters/filter.h" #include "lib/filters/filter.h"
@ -64,14 +65,14 @@ static void _destroy(struct dev_filter *f)
if (f->use_count) if (f->use_count)
log_error(INTERNAL_ERROR "Destroying signature filter while in use %u times.", f->use_count); log_error(INTERNAL_ERROR "Destroying signature filter while in use %u times.", f->use_count);
dm_free(f); free(f);
} }
struct dev_filter *signature_filter_create(struct dev_types *dt) struct dev_filter *signature_filter_create(struct dev_types *dt)
{ {
struct dev_filter *f; struct dev_filter *f;
if (!(f = dm_zalloc(sizeof(*f)))) { if (!(f = zalloc(sizeof(*f)))) {
log_error("md filter allocation failed"); log_error("md filter allocation failed");
return NULL; return NULL;
} }

View File

@ -13,6 +13,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "lib/misc/lib.h" #include "lib/misc/lib.h"
#include "lib/filters/filter.h" #include "lib/filters/filter.h"
@ -36,14 +37,14 @@ static void _lvm_type_filter_destroy(struct dev_filter *f)
if (f->use_count) if (f->use_count)
log_error(INTERNAL_ERROR "Destroying lvm_type filter while in use %u times.", f->use_count); log_error(INTERNAL_ERROR "Destroying lvm_type filter while in use %u times.", f->use_count);
dm_free(f); free(f);
} }
struct dev_filter *lvm_type_filter_create(struct dev_types *dt) struct dev_filter *lvm_type_filter_create(struct dev_types *dt)
{ {
struct dev_filter *f; struct dev_filter *f;
if (!(f = dm_zalloc(sizeof(struct dev_filter)))) { if (!(f = zalloc(sizeof(struct dev_filter)))) {
log_error("LVM type filter allocation failed"); log_error("LVM type filter allocation failed");
return NULL; return NULL;
} }

View File

@ -12,6 +12,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "lib/misc/lib.h" #include "lib/misc/lib.h"
#include "lib/filters/filter.h" #include "lib/filters/filter.h"
#include "lib/activate/activate.h" #include "lib/activate/activate.h"
@ -157,15 +158,15 @@ static void _usable_filter_destroy(struct dev_filter *f)
if (f->use_count) if (f->use_count)
log_error(INTERNAL_ERROR "Destroying usable device filter while in use %u times.", f->use_count); log_error(INTERNAL_ERROR "Destroying usable device filter while in use %u times.", f->use_count);
dm_free(f->private); free(f->private);
dm_free(f); free(f);
} }
struct dev_filter *usable_filter_create(struct dev_types *dt __attribute__((unused)), filter_mode_t mode) struct dev_filter *usable_filter_create(struct dev_types *dt __attribute__((unused)), filter_mode_t mode)
{ {
struct dev_filter *f; struct dev_filter *f;
if (!(f = dm_zalloc(sizeof(struct dev_filter)))) { if (!(f = zalloc(sizeof(struct dev_filter)))) {
log_error("Usable device filter allocation failed"); log_error("Usable device filter allocation failed");
return NULL; return NULL;
} }
@ -173,9 +174,9 @@ struct dev_filter *usable_filter_create(struct dev_types *dt __attribute__((unus
f->passes_filter = _passes_usable_filter; f->passes_filter = _passes_usable_filter;
f->destroy = _usable_filter_destroy; f->destroy = _usable_filter_destroy;
f->use_count = 0; f->use_count = 0;
if (!(f->private = dm_zalloc(sizeof(filter_mode_t)))) { if (!(f->private = zalloc(sizeof(filter_mode_t)))) {
log_error("Usable device filter mode allocation failed"); log_error("Usable device filter mode allocation failed");
dm_free(f); free(f);
return NULL; return NULL;
} }
*((filter_mode_t *) f->private) = mode; *((filter_mode_t *) f->private) = mode;

View File

@ -55,7 +55,7 @@ int archive_init(struct cmd_context *cmd, const char *dir,
if (!*dir) if (!*dir)
return 1; return 1;
if (!(cmd->archive_params->dir = dm_strdup(dir))) { if (!(cmd->archive_params->dir = strdup(dir))) {
log_error("Couldn't copy archive directory name."); log_error("Couldn't copy archive directory name.");
return 0; return 0;
} }
@ -71,7 +71,7 @@ void archive_exit(struct cmd_context *cmd)
{ {
if (!cmd->archive_params) if (!cmd->archive_params)
return; return;
dm_free(cmd->archive_params->dir); free(cmd->archive_params->dir);
memset(cmd->archive_params, 0, sizeof(*cmd->archive_params)); memset(cmd->archive_params, 0, sizeof(*cmd->archive_params));
} }
@ -193,7 +193,7 @@ int backup_init(struct cmd_context *cmd, const char *dir,
if (!*dir) if (!*dir)
return 1; return 1;
if (!(cmd->backup_params->dir = dm_strdup(dir))) { if (!(cmd->backup_params->dir = strdup(dir))) {
log_error("Couldn't copy backup directory name."); log_error("Couldn't copy backup directory name.");
return 0; return 0;
} }
@ -206,7 +206,7 @@ void backup_exit(struct cmd_context *cmd)
{ {
if (!cmd->backup_params) if (!cmd->backup_params)
return; return;
dm_free(cmd->backup_params->dir); free(cmd->backup_params->dir);
memset(cmd->backup_params, 0, sizeof(*cmd->backup_params)); memset(cmd->backup_params, 0, sizeof(*cmd->backup_params));
} }

View File

@ -13,6 +13,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "lib/misc/lib.h" #include "lib/misc/lib.h"
#include "import-export.h" #include "import-export.h"
#include "lib/metadata/metadata.h" #include "lib/metadata/metadata.h"
@ -123,7 +124,7 @@ static int _extend_buffer(struct formatter *f)
log_debug_metadata("Doubling metadata output buffer to " FMTu32, log_debug_metadata("Doubling metadata output buffer to " FMTu32,
f->data.buf.size * 2); f->data.buf.size * 2);
if (!(newbuf = dm_realloc(f->data.buf.start, if (!(newbuf = realloc(f->data.buf.start,
f->data.buf.size * 2))) { f->data.buf.size * 2))) {
log_error("Buffer reallocation failed."); log_error("Buffer reallocation failed.");
return 0; return 0;
@ -383,7 +384,7 @@ static char *_alloc_printed_str_list(struct dm_list *list)
/* '[' + ']' + '\0' */ /* '[' + ']' + '\0' */
size += 3; size += 3;
if (!(buffer = buf = dm_malloc(size))) { if (!(buffer = buf = malloc(size))) {
log_error("Could not allocate memory for string list buffer."); log_error("Could not allocate memory for string list buffer.");
return NULL; return NULL;
} }
@ -408,7 +409,7 @@ static char *_alloc_printed_str_list(struct dm_list *list)
return buffer; return buffer;
bad: bad:
dm_free(buffer); free(buffer);
return_NULL; return_NULL;
} }
@ -421,10 +422,10 @@ static int _out_list(struct formatter *f, struct dm_list *list,
if (!(buffer = _alloc_printed_str_list(list))) if (!(buffer = _alloc_printed_str_list(list)))
return_0; return_0;
if (!out_text(f, "%s = %s", list_name, buffer)) { if (!out_text(f, "%s = %s", list_name, buffer)) {
dm_free(buffer); free(buffer);
return_0; return_0;
} }
dm_free(buffer); free(buffer);
} }
return 1; return 1;
@ -835,7 +836,7 @@ static int _alloc_printed_indirect_descendants(struct dm_list *indirect_glvs, ch
/* '[' + ']' + '\0' */ /* '[' + ']' + '\0' */
buf_size += 3; buf_size += 3;
if (!(*buffer = dm_malloc(buf_size))) { if (!(*buffer = malloc(buf_size))) {
log_error("Could not allocate memory for ancestor list buffer."); log_error("Could not allocate memory for ancestor list buffer.");
return 0; return 0;
} }
@ -863,7 +864,7 @@ static int _alloc_printed_indirect_descendants(struct dm_list *indirect_glvs, ch
return 1; return 1;
bad: bad:
if (*buffer) { if (*buffer) {
dm_free(*buffer); free(*buffer);
*buffer = NULL; *buffer = NULL;
} }
return 0; return 0;
@ -908,7 +909,7 @@ static int _print_historical_lv(struct formatter *f, struct historical_logical_v
r = 1; r = 1;
out: out:
dm_free(descendants_buffer); free(descendants_buffer);
return r; return r;
} }
@ -1034,7 +1035,7 @@ int text_vg_export_file(struct volume_group *vg, const char *desc, FILE *fp)
_init(); _init();
if (!(f = dm_zalloc(sizeof(*f)))) if (!(f = zalloc(sizeof(*f))))
return_0; return_0;
f->data.fp = fp; f->data.fp = fp;
@ -1046,7 +1047,7 @@ int text_vg_export_file(struct volume_group *vg, const char *desc, FILE *fp)
r = _text_vg_export(f, vg, desc); r = _text_vg_export(f, vg, desc);
if (r) if (r)
r = !ferror(f->data.fp); r = !ferror(f->data.fp);
dm_free(f); free(f);
return r; return r;
} }
@ -1058,11 +1059,11 @@ size_t text_vg_export_raw(struct volume_group *vg, const char *desc, char **buf)
_init(); _init();
if (!(f = dm_zalloc(sizeof(*f)))) if (!(f = zalloc(sizeof(*f))))
return_0; return_0;
f->data.buf.size = 65536; /* Initial metadata limit */ f->data.buf.size = 65536; /* Initial metadata limit */
if (!(f->data.buf.start = dm_malloc(f->data.buf.size))) { if (!(f->data.buf.start = malloc(f->data.buf.size))) {
log_error("text_export buffer allocation failed"); log_error("text_export buffer allocation failed");
goto out; goto out;
} }
@ -1073,7 +1074,7 @@ size_t text_vg_export_raw(struct volume_group *vg, const char *desc, char **buf)
f->nl = &_nl_raw; f->nl = &_nl_raw;
if (!_text_vg_export(f, vg, desc)) { if (!_text_vg_export(f, vg, desc)) {
dm_free(f->data.buf.start); free(f->data.buf.start);
goto_out; goto_out;
} }
@ -1081,7 +1082,7 @@ size_t text_vg_export_raw(struct volume_group *vg, const char *desc, char **buf)
*buf = f->data.buf.start; *buf = f->data.buf.start;
out: out:
dm_free(f); free(f);
return r; return r;
} }
@ -1102,11 +1103,11 @@ struct dm_config_tree *export_vg_to_config_tree(struct volume_group *vg)
if (!(vg_cft = config_tree_from_string_without_dup_node_check(buf))) { if (!(vg_cft = config_tree_from_string_without_dup_node_check(buf))) {
log_error("Error parsing metadata for VG %s.", vg->name); log_error("Error parsing metadata for VG %s.", vg->name);
dm_free(buf); free(buf);
return_NULL; return_NULL;
} }
dm_free(buf); free(buf);
return vg_cft; return vg_cft;
} }

View File

@ -235,7 +235,7 @@ int read_segtype_lvflags(uint64_t *status, char *segtype_str)
if (!(str = strchr(segtype_str, '+'))) if (!(str = strchr(segtype_str, '+')))
return 1; /* No flags */ return 1; /* No flags */
if (!(buffer = dm_strdup(str + 1))) { if (!(buffer = strdup(str + 1))) {
log_error("Cannot duplicate segment string."); log_error("Cannot duplicate segment string.");
return 0; return 0;
} }
@ -263,7 +263,7 @@ int read_segtype_lvflags(uint64_t *status, char *segtype_str)
else else
*str = '\0'; /* Cut away 1st. '+' */ *str = '\0'; /* Cut away 1st. '+' */
dm_free(buffer); free(buffer);
return 1; return 1;
} }

View File

@ -224,7 +224,7 @@ static int _pv_analyze_mda_raw (const struct format_type * fmt,
* "dm_config_maybe_section" returning true when there's no valid * "dm_config_maybe_section" returning true when there's no valid
* metadata in a sector (sectors with all nulls). * metadata in a sector (sectors with all nulls).
*/ */
if (!(buf = dm_malloc(size + size2))) if (!(buf = malloc(size + size2)))
goto_out; goto_out;
if (!dev_read_bytes(area->dev, offset, size, buf)) { if (!dev_read_bytes(area->dev, offset, size, buf)) {
@ -273,13 +273,13 @@ static int _pv_analyze_mda_raw (const struct format_type * fmt,
size += SECTOR_SIZE; size += SECTOR_SIZE;
} }
} }
dm_free(buf); free(buf);
buf = NULL; buf = NULL;
} }
r = 1; r = 1;
out: out:
dm_free(buf); free(buf);
return r; return r;
} }
@ -294,7 +294,7 @@ static int _text_lv_setup(struct format_instance *fid __attribute__((unused)),
if (lv->size > max_size) { if (lv->size > max_size) {
char *dummy = display_size(max_size); char *dummy = display_size(max_size);
log_error("logical volumes cannot be larger than %s", dummy); log_error("logical volumes cannot be larger than %s", dummy);
dm_free(dummy); free(dummy);
return 0; return 0;
} }
*/ */
@ -711,7 +711,7 @@ static int _vg_write_raw(struct format_instance *fid, struct volume_group *vg,
out: out:
if (!r) { if (!r) {
dm_free(fidtc->raw_metadata_buf); free(fidtc->raw_metadata_buf);
fidtc->raw_metadata_buf = NULL; fidtc->raw_metadata_buf = NULL;
} }
@ -807,7 +807,7 @@ static int _vg_commit_raw_rlocn(struct format_instance *fid,
out: out:
if (!precommit) { if (!precommit) {
dm_free(fidtc->raw_metadata_buf); free(fidtc->raw_metadata_buf);
fidtc->raw_metadata_buf = NULL; fidtc->raw_metadata_buf = NULL;
} }
@ -1547,7 +1547,7 @@ static int _add_raw(struct dm_list *raw_list, struct device_area *dev_area)
return 1; return 1;
} }
if (!(rl = dm_malloc(sizeof(struct raw_list)))) { if (!(rl = malloc(sizeof(struct raw_list)))) {
log_error("_add_raw allocation failed"); log_error("_add_raw allocation failed");
return 0; return 0;
} }
@ -1715,7 +1715,7 @@ static void _free_dirs(struct dm_list *dir_list)
dm_list_iterate_safe(dl, tmp, dir_list) { dm_list_iterate_safe(dl, tmp, dir_list) {
dm_list_del(dl); dm_list_del(dl);
dm_free(dl); free(dl);
} }
} }
@ -1725,7 +1725,7 @@ static void _free_raws(struct dm_list *raw_list)
dm_list_iterate_safe(rl, tmp, raw_list) { dm_list_iterate_safe(rl, tmp, raw_list) {
dm_list_del(rl); dm_list_del(rl);
dm_free(rl); free(rl);
} }
} }
@ -1737,10 +1737,10 @@ static void _text_destroy(struct format_type *fmt)
if (fmt->private) { if (fmt->private) {
_free_dirs(&((struct mda_lists *) fmt->private)->dirs); _free_dirs(&((struct mda_lists *) fmt->private)->dirs);
_free_raws(&((struct mda_lists *) fmt->private)->raws); _free_raws(&((struct mda_lists *) fmt->private)->raws);
dm_free(fmt->private); free(fmt->private);
} }
dm_free(fmt); free(fmt);
} }
static struct metadata_area_ops _metadata_text_file_ops = { static struct metadata_area_ops _metadata_text_file_ops = {
@ -2079,7 +2079,7 @@ static int _add_metadata_area_to_pv(struct physical_volume *pv,
if (!(mdac = dm_pool_zalloc(pv->fid->mem, sizeof(struct mda_context)))) { if (!(mdac = dm_pool_zalloc(pv->fid->mem, sizeof(struct mda_context)))) {
log_error("struct mda_context allocation failed"); log_error("struct mda_context allocation failed");
dm_free(mda); free(mda);
return 0; return 0;
} }
@ -2460,7 +2460,7 @@ static int _add_dir(const char *dir, struct dm_list *dir_list)
struct dir_list *dl; struct dir_list *dl;
if (dm_create_dir(dir)) { if (dm_create_dir(dir)) {
if (!(dl = dm_malloc(sizeof(struct dm_list) + strlen(dir) + 1))) { if (!(dl = malloc(sizeof(struct dm_list) + strlen(dir) + 1))) {
log_error("_add_dir allocation failed"); log_error("_add_dir allocation failed");
return 0; return 0;
} }
@ -2535,7 +2535,7 @@ struct format_type *create_text_format(struct cmd_context *cmd)
const struct dm_config_value *cv; const struct dm_config_value *cv;
struct mda_lists *mda_lists; struct mda_lists *mda_lists;
if (!(fmt = dm_malloc(sizeof(*fmt)))) { if (!(fmt = malloc(sizeof(*fmt)))) {
log_error("Failed to allocate text format type structure."); log_error("Failed to allocate text format type structure.");
return NULL; return NULL;
} }
@ -2550,9 +2550,9 @@ struct format_type *create_text_format(struct cmd_context *cmd)
FMT_UNLIMITED_STRIPESIZE | FMT_CONFIG_PROFILE | FMT_UNLIMITED_STRIPESIZE | FMT_CONFIG_PROFILE |
FMT_NON_POWER2_EXTENTS | FMT_PV_FLAGS; FMT_NON_POWER2_EXTENTS | FMT_PV_FLAGS;
if (!(mda_lists = dm_malloc(sizeof(struct mda_lists)))) { if (!(mda_lists = malloc(sizeof(struct mda_lists)))) {
log_error("Failed to allocate dir_list"); log_error("Failed to allocate dir_list");
dm_free(fmt); free(fmt);
return NULL; return NULL;
} }

View File

@ -13,6 +13,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "lib/misc/lib.h" #include "lib/misc/lib.h"
#include "lib/format_text/format-text.h" #include "lib/format_text/format-text.h"
#include "layout.h" #include "layout.h"
@ -198,7 +199,7 @@ int add_da(struct dm_pool *mem, struct dm_list *das,
struct data_area_list *dal; struct data_area_list *dal;
if (!mem) { if (!mem) {
if (!(dal = dm_malloc(sizeof(*dal)))) { if (!(dal = malloc(sizeof(*dal)))) {
log_error("struct data_area_list allocation failed"); log_error("struct data_area_list allocation failed");
return 0; return 0;
} }
@ -225,7 +226,7 @@ void del_das(struct dm_list *das)
dm_list_iterate_safe(dah, tmp, das) { dm_list_iterate_safe(dah, tmp, das) {
da = dm_list_item(dah, struct data_area_list); da = dm_list_item(dah, struct data_area_list);
dm_list_del(&da->list); dm_list_del(&da->list);
dm_free(da); free(da);
} }
} }
@ -250,14 +251,14 @@ int add_mda(const struct format_type *fmt, struct dm_pool *mem, struct dm_list *
struct mda_context *mdac, *mdac2; struct mda_context *mdac, *mdac2;
if (!mem) { if (!mem) {
if (!(mdal = dm_malloc(sizeof(struct metadata_area)))) { if (!(mdal = malloc(sizeof(struct metadata_area)))) {
log_error("struct mda_list allocation failed"); log_error("struct mda_list allocation failed");
return 0; return 0;
} }
if (!(mdac = dm_malloc(sizeof(struct mda_context)))) { if (!(mdac = malloc(sizeof(struct mda_context)))) {
log_error("struct mda_context allocation failed"); log_error("struct mda_context allocation failed");
dm_free(mdal); free(mdal);
return 0; return 0;
} }
} else { } else {
@ -304,9 +305,9 @@ void del_mdas(struct dm_list *mdas)
dm_list_iterate_safe(mdah, tmp, mdas) { dm_list_iterate_safe(mdah, tmp, mdas) {
mda = dm_list_item(mdah, struct metadata_area); mda = dm_list_item(mdah, struct metadata_area);
dm_free(mda->metadata_locn); free(mda->metadata_locn);
dm_list_del(&mda->list); dm_list_del(&mda->list);
dm_free(mda); free(mda);
} }
} }
@ -465,7 +466,7 @@ static void _text_destroy_label(struct labeller *l __attribute__((unused)),
static void _fmt_text_destroy(struct labeller *l) static void _fmt_text_destroy(struct labeller *l)
{ {
dm_free(l); free(l);
} }
struct label_ops _text_ops = { struct label_ops _text_ops = {
@ -481,7 +482,7 @@ struct labeller *text_labeller_create(const struct format_type *fmt)
{ {
struct labeller *l; struct labeller *l;
if (!(l = dm_zalloc(sizeof(*l)))) { if (!(l = zalloc(sizeof(*l)))) {
log_error("Couldn't allocate labeller object."); log_error("Couldn't allocate labeller object.");
return NULL; return NULL;
} }

View File

@ -12,13 +12,14 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "lib/misc/lib.h" #include "lib/misc/lib.h"
#include "lib/commands/toolcontext.h" #include "lib/commands/toolcontext.h"
#include "lib/metadata/segtype.h" #include "lib/metadata/segtype.h"
static void _freeseg_destroy(struct segment_type *segtype) static void _freeseg_destroy(struct segment_type *segtype)
{ {
dm_free(segtype); free(segtype);
} }
static struct segtype_handler _freeseg_ops = { static struct segtype_handler _freeseg_ops = {
@ -27,7 +28,7 @@ static struct segtype_handler _freeseg_ops = {
struct segment_type *init_free_segtype(struct cmd_context *cmd) struct segment_type *init_free_segtype(struct cmd_context *cmd)
{ {
struct segment_type *segtype = dm_zalloc(sizeof(*segtype)); struct segment_type *segtype = zalloc(sizeof(*segtype));
if (!segtype) if (!segtype)
return_NULL; return_NULL;

View File

@ -13,6 +13,9 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#define _GNU_SOURCE
#include "base/memory/zalloc.h"
#include "lib/misc/lib.h" #include "lib/misc/lib.h"
#include "lib/label/label.h" #include "lib/label/label.h"
#include "lib/misc/crc.h" #include "lib/misc/crc.h"
@ -26,7 +29,7 @@
#include <fcntl.h> #include <fcntl.h>
#include <unistd.h> #include <unistd.h>
#include <sys/time.h> #include <sys/time.h>
#include <sys/types.h>
/* FIXME Allow for larger labels? Restricted to single sector currently */ /* FIXME Allow for larger labels? Restricted to single sector currently */
@ -49,7 +52,7 @@ static struct labeller_i *_alloc_li(const char *name, struct labeller *l)
len = sizeof(*li) + strlen(name) + 1; len = sizeof(*li) + strlen(name) + 1;
if (!(li = dm_malloc(len))) { if (!(li = malloc(len))) {
log_error("Couldn't allocate memory for labeller list object."); log_error("Couldn't allocate memory for labeller list object.");
return NULL; return NULL;
} }
@ -73,7 +76,7 @@ void label_exit(void)
dm_list_iterate_items_safe(li, tli, &_labellers) { dm_list_iterate_items_safe(li, tli, &_labellers) {
dm_list_del(&li->list); dm_list_del(&li->list);
li->l->ops->destroy(li->l); li->l->ops->destroy(li->l);
dm_free(li); free(li);
} }
dm_list_init(&_labellers); dm_list_init(&_labellers);
@ -217,14 +220,14 @@ int label_write(struct device *dev, struct label *label)
void label_destroy(struct label *label) void label_destroy(struct label *label)
{ {
label->labeller->ops->destroy_label(label->labeller, label); label->labeller->ops->destroy_label(label->labeller, label);
dm_free(label); free(label);
} }
struct label *label_create(struct labeller *labeller) struct label *label_create(struct labeller *labeller)
{ {
struct label *label; struct label *label;
if (!(label = dm_zalloc(sizeof(*label)))) { if (!(label = zalloc(sizeof(*label)))) {
log_error("label allocaction failed"); log_error("label allocaction failed");
return NULL; return NULL;
} }
@ -831,7 +834,7 @@ int label_scan(struct cmd_context *cmd)
} }
while ((dev = dev_iter_get(iter))) { while ((dev = dev_iter_get(iter))) {
if (!(devl = dm_zalloc(sizeof(*devl)))) if (!(devl = zalloc(sizeof(*devl))))
continue; continue;
devl->dev = dev; devl->dev = dev;
dm_list_add(&all_devs, &devl->list); dm_list_add(&all_devs, &devl->list);
@ -858,7 +861,7 @@ int label_scan(struct cmd_context *cmd)
dm_list_iterate_items_safe(devl, devl2, &all_devs) { dm_list_iterate_items_safe(devl, devl2, &all_devs) {
dm_list_del(&devl->list); dm_list_del(&devl->list);
dm_free(devl); free(devl);
} }
return 1; return 1;
@ -997,7 +1000,7 @@ int label_read(struct device *dev)
int failed = 0; int failed = 0;
/* scanning is done by list, so make a single item list for this dev */ /* scanning is done by list, so make a single item list for this dev */
if (!(devl = dm_zalloc(sizeof(*devl)))) if (!(devl = zalloc(sizeof(*devl))))
return 0; return 0;
devl->dev = dev; devl->dev = dev;
dm_list_init(&one_dev); dm_list_init(&one_dev);
@ -1010,7 +1013,7 @@ int label_read(struct device *dev)
_scan_list(NULL, NULL, &one_dev, &failed); _scan_list(NULL, NULL, &one_dev, &failed);
dm_free(devl); free(devl);
if (failed) if (failed)
return 0; return 0;

View File

@ -123,13 +123,13 @@ static int _set_custom_log_stream(struct log_stream_item *stream_item, int custo
goto out; goto out;
} }
if (!(stream_item->buffer = dm_malloc(LOG_STREAM_BUFFER_SIZE))) { if (!(stream_item->buffer = malloc(LOG_STREAM_BUFFER_SIZE))) {
log_error("Failed to allocate buffer for stream on file " log_error("Failed to allocate buffer for stream on file "
"descriptor %d.", (int) custom_fd); "descriptor %d.", (int) custom_fd);
} else { } else {
if (setvbuf(final_stream, stream_item->buffer, _IOLBF, LOG_STREAM_BUFFER_SIZE)) { if (setvbuf(final_stream, stream_item->buffer, _IOLBF, LOG_STREAM_BUFFER_SIZE)) {
log_sys_error("setvbuf", ""); log_sys_error("setvbuf", "");
dm_free(stream_item->buffer); free(stream_item->buffer);
stream_item->buffer = NULL; stream_item->buffer = NULL;
} }
} }
@ -342,7 +342,7 @@ void release_log_memory(void)
if (!_log_direct) if (!_log_direct)
return; return;
dm_free((char *) _log_dev_alias.str); free((char *) _log_dev_alias.str);
_log_dev_alias.str = "activate_log file"; _log_dev_alias.str = "activate_log file";
} }
@ -396,7 +396,7 @@ void reset_lvm_errno(int store_errmsg)
_lvm_errno = 0; _lvm_errno = 0;
if (_lvm_errmsg) { if (_lvm_errmsg) {
dm_free(_lvm_errmsg); free(_lvm_errmsg);
_lvm_errmsg = NULL; _lvm_errmsg = NULL;
_lvm_errmsg_size = _lvm_errmsg_len = 0; _lvm_errmsg_size = _lvm_errmsg_len = 0;
} }
@ -542,7 +542,7 @@ static void _vprint_log(int level, const char *file, int line, int dm_errno_or_c
msglen = strlen(message); msglen = strlen(message);
if ((_lvm_errmsg_len + msglen + 1) >= _lvm_errmsg_size) { if ((_lvm_errmsg_len + msglen + 1) >= _lvm_errmsg_size) {
_lvm_errmsg_size = 2 * (_lvm_errmsg_len + msglen + 1); _lvm_errmsg_size = 2 * (_lvm_errmsg_len + msglen + 1);
if ((newbuf = dm_realloc(_lvm_errmsg, if ((newbuf = realloc(_lvm_errmsg,
_lvm_errmsg_size))) _lvm_errmsg_size)))
_lvm_errmsg = newbuf; _lvm_errmsg = newbuf;
else else

View File

@ -207,7 +207,7 @@ static int _process_poll_init(const struct cmd_context *cmd, const char *poll_ty
const char *e = getenv("LVM_SYSTEM_DIR"); const char *e = getenv("LVM_SYSTEM_DIR");
int r = 0; int r = 0;
str = dm_malloc(INTERV_SIZE * sizeof(char)); str = malloc(INTERV_SIZE * sizeof(char));
if (!str) if (!str)
return r; return r;
@ -266,7 +266,7 @@ out_rep:
daemon_reply_destroy(rep); daemon_reply_destroy(rep);
out_req: out_req:
daemon_request_destroy(req); daemon_request_destroy(req);
dm_free(str); free(str);
return r; return r;
} }

View File

@ -2384,7 +2384,7 @@ static int _reserve_required_area(struct alloc_handle *ah, struct alloc_state *a
/* Expand areas array if needed after an area was split. */ /* Expand areas array if needed after an area was split. */
if (ix_pva >= alloc_state->areas_size) { if (ix_pva >= alloc_state->areas_size) {
alloc_state->areas_size *= 2; alloc_state->areas_size *= 2;
if (!(alloc_state->areas = dm_realloc(alloc_state->areas, sizeof(*alloc_state->areas) * (alloc_state->areas_size)))) { if (!(alloc_state->areas = realloc(alloc_state->areas, sizeof(*alloc_state->areas) * (alloc_state->areas_size)))) {
log_error("Memory reallocation for parallel areas failed."); log_error("Memory reallocation for parallel areas failed.");
return 0; return 0;
} }
@ -3170,7 +3170,7 @@ static int _allocate(struct alloc_handle *ah,
alloc_state.areas_size += _stripes_per_mimage(prev_lvseg) * prev_lvseg->area_count; alloc_state.areas_size += _stripes_per_mimage(prev_lvseg) * prev_lvseg->area_count;
/* Allocate an array of pv_areas to hold the largest space on each PV */ /* Allocate an array of pv_areas to hold the largest space on each PV */
if (!(alloc_state.areas = dm_malloc(sizeof(*alloc_state.areas) * alloc_state.areas_size))) { if (!(alloc_state.areas = malloc(sizeof(*alloc_state.areas) * alloc_state.areas_size))) {
log_error("Couldn't allocate areas array."); log_error("Couldn't allocate areas array.");
return 0; return 0;
} }
@ -3251,7 +3251,7 @@ static int _allocate(struct alloc_handle *ah,
r = 1; r = 1;
out: out:
dm_free(alloc_state.areas); free(alloc_state.areas);
return r; return r;
} }

View File

@ -452,7 +452,7 @@ int vg_extend(struct volume_group *vg, int pv_count, const char *const *pv_names
/* attach each pv */ /* attach each pv */
for (i = 0; i < pv_count; i++) { for (i = 0; i < pv_count; i++) {
if (!(pv_name = dm_strdup(pv_names[i]))) { if (!(pv_name = strdup(pv_names[i]))) {
log_error("Failed to duplicate pv name %s.", pv_names[i]); log_error("Failed to duplicate pv name %s.", pv_names[i]);
return 0; return 0;
} }
@ -460,10 +460,10 @@ int vg_extend(struct volume_group *vg, int pv_count, const char *const *pv_names
if (!_vg_extend_single_pv(vg, pv_name, pp, &max_phys_block_size)) { if (!_vg_extend_single_pv(vg, pv_name, pp, &max_phys_block_size)) {
log_error("Unable to add physical volume '%s' to " log_error("Unable to add physical volume '%s' to "
"volume group '%s'.", pv_name, vg->name); "volume group '%s'.", pv_name, vg->name);
dm_free(pv_name); free(pv_name);
return 0; return 0;
} }
dm_free(pv_name); free(pv_name);
} }
(void) check_pv_dev_sizes(vg); (void) check_pv_dev_sizes(vg);

View File

@ -16,7 +16,7 @@
#define _LVM_PV_H #define _LVM_PV_H
#include "lib/uuid/uuid.h" #include "lib/uuid/uuid.h"
#include "device_mapper/libdevmapper.h" #include "device_mapper/all.h"
struct device; struct device;
struct format_type; struct format_type;

View File

@ -16,7 +16,7 @@
#define _LVM_VG_H #define _LVM_VG_H
#include "lib/uuid/uuid.h" #include "lib/uuid/uuid.h"
#include "device_mapper/libdevmapper.h" #include "device_mapper/all.h"
struct cmd_context; struct cmd_context;
struct format_instance; struct format_instance;

View File

@ -13,6 +13,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "lib/misc/lib.h" #include "lib/misc/lib.h"
#include "lib/commands/toolcontext.h" #include "lib/commands/toolcontext.h"
#include "lib/metadata/metadata.h" #include "lib/metadata/metadata.h"
@ -525,8 +526,8 @@ static int _mirrored_modules_needed(struct dm_pool *mem,
static void _mirrored_destroy(struct segment_type *segtype) static void _mirrored_destroy(struct segment_type *segtype)
{ {
dm_free((void *) segtype->dso); free((void *) segtype->dso);
dm_free(segtype); free(segtype);
} }
static struct segtype_handler _mirrored_ops = { static struct segtype_handler _mirrored_ops = {
@ -556,7 +557,7 @@ struct segment_type *init_segtype(struct cmd_context *cmd);
struct segment_type *init_segtype(struct cmd_context *cmd) struct segment_type *init_segtype(struct cmd_context *cmd)
#endif #endif
{ {
struct segment_type *segtype = dm_zalloc(sizeof(*segtype)); struct segment_type *segtype = zalloc(sizeof(*segtype));
if (!segtype) if (!segtype)
return_NULL; return_NULL;

View File

@ -79,8 +79,9 @@
#include "lib/misc/intl.h" #include "lib/misc/intl.h"
#include "device_mapper/libdevmapper.h" #include "device_mapper/all.h"
#include "lib/misc/util.h" #include "lib/misc/util.h"
#include "base/memory/zalloc.h"
#ifdef DM #ifdef DM
# include "libdm/misc/dm-logging.h" # include "libdm/misc/dm-logging.h"

View File

@ -166,7 +166,7 @@ void sync_dir(const char *file)
int fd; int fd;
char *dir, *c; char *dir, *c;
if (!(dir = dm_strdup(file))) { if (!(dir = strdup(file))) {
log_error("sync_dir failed in strdup"); log_error("sync_dir failed in strdup");
return; return;
} }
@ -194,7 +194,7 @@ void sync_dir(const char *file)
log_sys_error("close", dir); log_sys_error("close", dir);
out: out:
dm_free(dir); free(dir);
} }
/* /*
@ -210,7 +210,7 @@ int fcntl_lock_file(const char *file, short lock_type, int warn_if_read_only)
char *dir; char *dir;
char *c; char *c;
if (!(dir = dm_strdup(file))) { if (!(dir = strdup(file))) {
log_error("fcntl_lock_file failed in strdup."); log_error("fcntl_lock_file failed in strdup.");
return -1; return -1;
} }
@ -219,11 +219,11 @@ int fcntl_lock_file(const char *file, short lock_type, int warn_if_read_only)
*c = '\0'; *c = '\0';
if (!dm_create_dir(dir)) { if (!dm_create_dir(dir)) {
dm_free(dir); free(dir);
return -1; return -1;
} }
dm_free(dir); free(dir);
log_very_verbose("Locking %s (%s, %hd)", file, log_very_verbose("Locking %s (%s, %hd)", file,
(lock_type == F_WRLCK) ? "F_WRLCK" : "F_RDLCK", (lock_type == F_WRLCK) ? "F_WRLCK" : "F_RDLCK",

View File

@ -74,8 +74,8 @@ static int _release_lock(const char *file, int unlock)
} else } else
_drop_shared_flock(ll->res, ll->lf); _drop_shared_flock(ll->res, ll->lf);
dm_free(ll->res); free(ll->res);
dm_free(llh); free(llh);
if (file) if (file)
return 1; return 1;
@ -188,11 +188,11 @@ int lock_file(const char *file, uint32_t flags)
return 0; return 0;
} }
if (!(ll = dm_malloc(sizeof(struct lock_list)))) if (!(ll = malloc(sizeof(struct lock_list))))
return_0; return_0;
if (!(ll->res = dm_strdup(file))) { if (!(ll->res = strdup(file))) {
dm_free(ll); free(ll);
return_0; return_0;
} }
@ -211,8 +211,8 @@ int lock_file(const char *file, uint32_t flags)
if (r) if (r)
dm_list_add(&_lock_list, &ll->list); dm_list_add(&_lock_list, &ll->list);
else { else {
dm_free(ll->res); free(ll->res);
dm_free(ll); free(ll);
stack; stack;
} }

View File

@ -339,7 +339,7 @@ static int _memlock_maps(struct cmd_context *cmd, lvmlock_t lock, size_t *mstats
if (!_maps_buffer || len >= _maps_len) { if (!_maps_buffer || len >= _maps_len) {
if (_maps_buffer) if (_maps_buffer)
_maps_len *= 2; _maps_len *= 2;
if (!(line = dm_realloc(_maps_buffer, _maps_len))) { if (!(line = realloc(_maps_buffer, _maps_len))) {
log_error("Allocation of maps buffer failed."); log_error("Allocation of maps buffer failed.");
return 0; return 0;
} }
@ -551,7 +551,7 @@ static void _unlock_mem(struct cmd_context *cmd)
_restore_mmap(); _restore_mmap();
if (close(_maps_fd)) if (close(_maps_fd))
log_sys_error("close", _procselfmaps); log_sys_error("close", _procselfmaps);
dm_free(_maps_buffer); free(_maps_buffer);
_maps_buffer = NULL; _maps_buffer = NULL;
if (_mstats < unlock_mstats) { if (_mstats < unlock_mstats) {
if ((_mstats + lvm_getpagesize()) < unlock_mstats) if ((_mstats + lvm_getpagesize()) < unlock_mstats)

View File

@ -12,6 +12,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "lib/misc/lib.h" #include "lib/misc/lib.h"
#include "lib/metadata/segtype.h" #include "lib/metadata/segtype.h"
#include "lib/display/display.h" #include "lib/display/display.h"
@ -363,8 +364,8 @@ static int _raid_target_status_compatible(const char *type)
static void _raid_destroy(struct segment_type *segtype) static void _raid_destroy(struct segment_type *segtype)
{ {
dm_free((void *) segtype->dso); free((void *) segtype->dso);
dm_free(segtype); free(segtype);
} }
#ifdef DEVMAPPER_SUPPORT #ifdef DEVMAPPER_SUPPORT
@ -617,7 +618,7 @@ static struct segment_type *_init_raid_segtype(struct cmd_context *cmd,
const char *dso, const char *dso,
uint64_t monitored) uint64_t monitored)
{ {
struct segment_type *segtype = dm_zalloc(sizeof(*segtype)); struct segment_type *segtype = zalloc(sizeof(*segtype));
if (!segtype) { if (!segtype) {
log_error("Failed to allocate memory for %s segtype", log_error("Failed to allocate memory for %s segtype",
@ -631,7 +632,7 @@ static struct segment_type *_init_raid_segtype(struct cmd_context *cmd,
/* Never monitor raid0 or raid0_meta LVs */ /* Never monitor raid0 or raid0_meta LVs */
if (!segtype_is_any_raid0(segtype) && if (!segtype_is_any_raid0(segtype) &&
dso && (dso = dm_strdup(dso))) { dso && (dso = strdup(dso))) {
segtype->dso = dso; segtype->dso = dso;
segtype->flags |= monitored; segtype->flags |= monitored;
} }
@ -675,7 +676,7 @@ int init_multiple_segtypes(struct cmd_context *cmd, struct segtype_library *segl
break; break;
} }
dm_free(dso); free(dso);
return r; return r;
} }

View File

@ -14,7 +14,7 @@
#ifndef _LVM_PROPERTIES_H #ifndef _LVM_PROPERTIES_H
#define _LVM_PROPERTIES_H #define _LVM_PROPERTIES_H
#include "device_mapper/libdevmapper.h" #include "device_mapper/all.h"
#include "lib/metadata/metadata.h" #include "lib/metadata/metadata.h"
#include "lib/report/report.h" #include "lib/report/report.h"
#include "lib/properties/prop_common.h" #include "lib/properties/prop_common.h"

View File

@ -13,6 +13,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "lib/misc/lib.h" #include "lib/misc/lib.h"
#include "lib/metadata/metadata.h" #include "lib/metadata/metadata.h"
#include "lib/metadata/segtype.h" #include "lib/metadata/segtype.h"
@ -224,8 +225,8 @@ static int _snap_modules_needed(struct dm_pool *mem,
static void _snap_destroy(struct segment_type *segtype) static void _snap_destroy(struct segment_type *segtype)
{ {
dm_free((void *) segtype->dso); free((void *) segtype->dso);
dm_free(segtype); free(segtype);
} }
static struct segtype_handler _snapshot_ops = { static struct segtype_handler _snapshot_ops = {
@ -253,7 +254,7 @@ struct segment_type *init_segtype(struct cmd_context *cmd);
struct segment_type *init_segtype(struct cmd_context *cmd) struct segment_type *init_segtype(struct cmd_context *cmd)
#endif #endif
{ {
struct segment_type *segtype = dm_zalloc(sizeof(*segtype)); struct segment_type *segtype = zalloc(sizeof(*segtype));
if (!segtype) if (!segtype)
return_NULL; return_NULL;

View File

@ -13,6 +13,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "lib/misc/lib.h" #include "lib/misc/lib.h"
#include "lib/commands/toolcontext.h" #include "lib/commands/toolcontext.h"
#include "lib/metadata/segtype.h" #include "lib/metadata/segtype.h"
@ -212,7 +213,7 @@ static int _striped_target_present(struct cmd_context *cmd,
static void _striped_destroy(struct segment_type *segtype) static void _striped_destroy(struct segment_type *segtype)
{ {
dm_free(segtype); free(segtype);
} }
static struct segtype_handler _striped_ops = { static struct segtype_handler _striped_ops = {
@ -232,7 +233,7 @@ static struct segtype_handler _striped_ops = {
static struct segment_type *_init_segtype(struct cmd_context *cmd, const char *name, uint64_t target) static struct segment_type *_init_segtype(struct cmd_context *cmd, const char *name, uint64_t target)
{ {
struct segment_type *segtype = dm_zalloc(sizeof(*segtype)); struct segment_type *segtype = zalloc(sizeof(*segtype));
if (!segtype) if (!segtype)
return_NULL; return_NULL;

View File

@ -12,6 +12,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "lib/misc/lib.h" #include "lib/misc/lib.h"
#include "lib/display/display.h" #include "lib/display/display.h"
#include "lib/metadata/metadata.h" #include "lib/metadata/metadata.h"
@ -745,8 +746,8 @@ static int _thin_target_present(struct cmd_context *cmd,
static void _thin_destroy(struct segment_type *segtype) static void _thin_destroy(struct segment_type *segtype)
{ {
dm_free((void *) segtype->dso); free((void *) segtype->dso);
dm_free(segtype); free(segtype);
} }
static struct segtype_handler _thin_pool_ops = { static struct segtype_handler _thin_pool_ops = {
@ -803,7 +804,7 @@ int init_multiple_segtypes(struct cmd_context *cmd, struct segtype_library *segl
unsigned i; unsigned i;
for (i = 0; i < DM_ARRAY_SIZE(reg_segtypes); ++i) { for (i = 0; i < DM_ARRAY_SIZE(reg_segtypes); ++i) {
segtype = dm_zalloc(sizeof(*segtype)); segtype = zalloc(sizeof(*segtype));
if (!segtype) { if (!segtype) {
log_error("Failed to allocate memory for %s segtype", log_error("Failed to allocate memory for %s segtype",

View File

@ -12,6 +12,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "lib/misc/lib.h" #include "lib/misc/lib.h"
#include "lib/commands/toolcontext.h" #include "lib/commands/toolcontext.h"
#include "lib/metadata/segtype.h" #include "lib/metadata/segtype.h"
@ -49,8 +50,8 @@ static int _unknown_text_export(const struct lv_segment *seg, struct formatter *
static void _unknown_destroy(struct segment_type *segtype) static void _unknown_destroy(struct segment_type *segtype)
{ {
dm_free((void *) segtype->name); free((void *) segtype->name);
dm_free(segtype); free(segtype);
} }
static struct segtype_handler _unknown_ops = { static struct segtype_handler _unknown_ops = {
@ -61,7 +62,7 @@ static struct segtype_handler _unknown_ops = {
struct segment_type *init_unknown_segtype(struct cmd_context *cmd, const char *name) struct segment_type *init_unknown_segtype(struct cmd_context *cmd, const char *name)
{ {
struct segment_type *segtype = dm_zalloc(sizeof(*segtype)); struct segment_type *segtype = zalloc(sizeof(*segtype));
if (!segtype) { if (!segtype) {
log_error("Failed to allocate memory for unknown segtype"); log_error("Failed to allocate memory for unknown segtype");
@ -69,9 +70,9 @@ struct segment_type *init_unknown_segtype(struct cmd_context *cmd, const char *n
} }
segtype->ops = &_unknown_ops; segtype->ops = &_unknown_ops;
if (!(segtype->name = dm_strdup(name))) { if (!(segtype->name = strdup(name))) {
log_error("Failed to allocate name."); log_error("Failed to allocate name.");
dm_free(segtype); free(segtype);
return NULL; return NULL;
} }

View File

@ -12,6 +12,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "base/memory/zalloc.h"
#include "lib/misc/lib.h" #include "lib/misc/lib.h"
#include "lib/metadata/segtype.h" #include "lib/metadata/segtype.h"
#include "lib/datastruct/str_list.h" #include "lib/datastruct/str_list.h"
@ -71,7 +72,7 @@ static int _zero_modules_needed(struct dm_pool *mem,
static void _zero_destroy(struct segment_type *segtype) static void _zero_destroy(struct segment_type *segtype)
{ {
dm_free(segtype); free(segtype);
} }
static struct segtype_handler _zero_ops = { static struct segtype_handler _zero_ops = {
@ -86,7 +87,7 @@ static struct segtype_handler _zero_ops = {
struct segment_type *init_zero_segtype(struct cmd_context *cmd) struct segment_type *init_zero_segtype(struct cmd_context *cmd)
{ {
struct segment_type *segtype = dm_zalloc(sizeof(*segtype)); struct segment_type *segtype = zalloc(sizeof(*segtype));
if (!segtype) if (!segtype)
return_NULL; return_NULL;

View File

@ -63,12 +63,12 @@ int buffer_append_vf(struct buffer *buf, va_list ap)
!buffer_append(buf, append)) !buffer_append(buf, append))
goto fail; goto fail;
dm_free(append); free(append);
} }
return 1; return 1;
fail: fail:
dm_free(append); free(append);
return 0; return 0;
} }
@ -365,11 +365,11 @@ int buffer_realloc(struct buffer *buf, int needed)
alloc = needed; alloc = needed;
buf->allocated += alloc; buf->allocated += alloc;
new = dm_realloc(buf->mem, buf->allocated); new = realloc(buf->mem, buf->allocated);
if (new) if (new)
buf->mem = new; buf->mem = new;
else { /* utter failure */ else { /* utter failure */
dm_free(buf->mem); free(buf->mem);
buf->mem = 0; buf->mem = 0;
buf->allocated = buf->used = 0; buf->allocated = buf->used = 0;
return 0; return 0;
@ -402,7 +402,7 @@ int buffer_line(const char *line, void *baton)
void buffer_destroy(struct buffer *buf) void buffer_destroy(struct buffer *buf)
{ {
dm_free(buf->mem); free(buf->mem);
buffer_init(buf); buffer_init(buf);
} }

View File

@ -60,7 +60,7 @@ daemon_handle daemon_open(daemon_info i)
/* Check protocol and version matches */ /* Check protocol and version matches */
h.protocol = daemon_reply_str(r, "protocol", NULL); h.protocol = daemon_reply_str(r, "protocol", NULL);
if (h.protocol) if (h.protocol)
h.protocol = dm_strdup(h.protocol); /* keep around */ h.protocol = strdup(h.protocol); /* keep around */
h.protocol_version = daemon_reply_int(r, "version", 0); h.protocol_version = daemon_reply_int(r, "version", 0);
if (i.protocol && (!h.protocol || strcmp(h.protocol, i.protocol))) { if (i.protocol && (!h.protocol || strcmp(h.protocol, i.protocol))) {
@ -85,7 +85,7 @@ error:
if (r.cft) if (r.cft)
daemon_reply_destroy(r); daemon_reply_destroy(r);
dm_free((char *)h.protocol); free((char *)h.protocol);
h.protocol = NULL; h.protocol = NULL;
return h; return h;
@ -181,7 +181,7 @@ void daemon_close(daemon_handle h)
log_sys_error("close", "daemon_close"); log_sys_error("close", "daemon_close");
} }
dm_free((char *)h.protocol); free((char *)h.protocol);
} }
daemon_request daemon_request_make(const char *id) daemon_request daemon_request_make(const char *id)

View File

@ -91,7 +91,7 @@ void daemon_logf(log_state *s, int type, const char *fmt, ...) {
va_start(ap, fmt); va_start(ap, fmt);
if (dm_vasprintf(&buf, fmt, ap) >= 0) { if (dm_vasprintf(&buf, fmt, ap) >= 0) {
daemon_log(s, type, buf); daemon_log(s, type, buf);
dm_free(buf); free(buf);
} /* else return_0 */ } /* else return_0 */
va_end(ap); va_end(ap);
} }
@ -127,7 +127,7 @@ void daemon_log_multi(log_state *s, int type, const char *prefix, const char *ms
if (!_type_interesting(s, type)) if (!_type_interesting(s, type))
return; return;
buf = dm_strdup(msg); buf = strdup(msg);
pos = buf; pos = buf;
if (!buf) if (!buf)
@ -140,7 +140,7 @@ void daemon_log_multi(log_state *s, int type, const char *prefix, const char *ms
_log_line(pos, &b); _log_line(pos, &b);
pos = next ? next + 1 : 0; pos = next ? next + 1 : 0;
} }
dm_free(buf); free(buf);
} }
void daemon_log_enable(log_state *s, int outlet, int type, int enable) void daemon_log_enable(log_state *s, int outlet, int type, int enable)
@ -184,7 +184,7 @@ int daemon_log_parse(log_state *s, int outlet, const char *types, int enable)
if (!types || !types[0]) if (!types || !types[0])
return 1; return 1;
if (!(buf = dm_strdup(types))) if (!(buf = strdup(types)))
return 0; return 0;
pos = buf; pos = buf;
@ -193,13 +193,13 @@ int daemon_log_parse(log_state *s, int outlet, const char *types, int enable)
if (next) if (next)
*next = 0; *next = 0;
if (!_parse_one(s, outlet, pos, enable)) { if (!_parse_one(s, outlet, pos, enable)) {
dm_free(buf); free(buf);
return 0; return 0;
} }
pos = next ? next + 1 : 0; pos = next ? next + 1 : 0;
} }
dm_free(buf); free(buf);
return 1; return 1;
} }

View File

@ -515,7 +515,7 @@ static int _handle_connect(daemon_state s)
if (fcntl(client.socket_fd, F_SETFD, FD_CLOEXEC)) if (fcntl(client.socket_fd, F_SETFD, FD_CLOEXEC))
WARN(&s, "setting CLOEXEC on client socket fd %d failed", client.socket_fd); WARN(&s, "setting CLOEXEC on client socket fd %d failed", client.socket_fd);
if (!(ts = dm_malloc(sizeof(thread_state)))) { if (!(ts = malloc(sizeof(thread_state)))) {
if (close(client.socket_fd)) if (close(client.socket_fd))
perror("close"); perror("close");
ERROR(&s, "Failed to allocate thread state"); ERROR(&s, "Failed to allocate thread state");
@ -547,7 +547,7 @@ static void _reap(daemon_state s, int waiting)
if ((errno = pthread_join(ts->client.thread_id, &rv))) if ((errno = pthread_join(ts->client.thread_id, &rv)))
ERROR(&s, "pthread_join failed: %s", strerror(errno)); ERROR(&s, "pthread_join failed: %s", strerror(errno));
last->next = ts->next; last->next = ts->next;
dm_free(ts); free(ts);
} else } else
last = ts; last = ts;
ts = last->next; ts = last->next;

View File

@ -14,13 +14,74 @@
*/ */
/* /*
* This file must be included first by every device-mapper library source file. * This file must be included first by every library source file.
*/ */
#ifndef _DM_LIB_H #ifndef _DM_LIB_H
#define _DM_LIB_H #define _DM_LIB_H
#define DM #include "configure.h"
#include "lib/misc/lib.h" #define _REENTRANT
#define _GNU_SOURCE
/*
* Symbol export control macros
*
* DM_EXPORT_SYMBOL(func,ver)
* DM_EXPORT_SYMBOL_BASE(func,ver)
*
* For functions that have multiple implementations these macros control
* symbol export and versioning.
*
* Function definitions that exist in only one version never need to use
* these macros.
*
* Backwards compatible implementations must include a version tag of
* the form "_v1_02_104" as a suffix to the function name and use the
* macro DM_EXPORT_SYMBOL to export the function and bind it to the
* specified version string.
*
* Since versioning is only available when compiling with GCC the entire
* compatibility version should be enclosed in '#if defined(__GNUC__)',
* for example:
*
* int dm_foo(int bar)
* {
* return bar;
* }
*
* #if defined(__GNUC__)
* // Backward compatible dm_foo() version 1.02.104
* int dm_foo_v1_02_104(void);
* int dm_foo_v1_02_104(void)
* {
* return 0;
* }
* DM_EXPORT_SYMBOL(dm_foo,1_02_104)
* #endif
*
* A prototype for the compatibility version is required as these
* functions must not be declared static.
*
* The DM_EXPORT_SYMBOL_BASE macro is only used to export the base
* versions of library symbols prior to the introduction of symbol
* versioning: it must never be used for new symbols.
*/
#if defined(__GNUC__)
#define DM_EXPORT_SYMBOL(func, ver) \
__asm__(".symver " #func "_v" #ver ", " #func "@DM_" #ver )
#define DM_EXPORT_SYMBOL_BASE(func) \
__asm__(".symver " #func "_base, " #func "@Base" )
#else
#define DM_EXPORT_SYMBOL(func, ver)
#define DM_EXPORT_SYMBOL_BASE(func)
#endif
#include "lib/misc/util.h"
#include "libdm/libdevmapper.h"
#include "libdm/misc/dm-logging.h"
#include <unistd.h>
#endif #endif

View File

@ -27,7 +27,7 @@
#include <unistd.h> #include <unistd.h>
#include "configure.h" #include "configure.h"
#include "device_mapper/libdevmapper.h" #include "device_mapper/all.h"
//---------------------------------------------------------------- //----------------------------------------------------------------

View File

@ -16,7 +16,7 @@
#include "framework.h" #include "framework.h"
#include "units.h" #include "units.h"
#include "device_mapper/libdevmapper.h" #include "device_mapper/all.h"
//---------------------------------------------------------------- //----------------------------------------------------------------

View File

@ -13,7 +13,7 @@
*/ */
#include "units.h" #include "units.h"
#include "device_mapper/libdevmapper.h" #include "device_mapper/all.h"
enum { enum {
NR_BITS = 137 NR_BITS = 137

View File

@ -13,7 +13,7 @@
*/ */
#include "units.h" #include "units.h"
#include "device_mapper/libdevmapper.h" #include "device_mapper/all.h"
static void *_mem_init(void) static void *_mem_init(void)
{ {

View File

@ -13,7 +13,7 @@
*/ */
#include "units.h" #include "units.h"
#include "device_mapper/libdevmapper.h" #include "device_mapper/all.h"
static void test_dmlist_splice(void *fixture) static void test_dmlist_splice(void *fixture)
{ {

View File

@ -13,7 +13,7 @@
*/ */
#include "units.h" #include "units.h"
#include "device_mapper/libdevmapper.h" #include "device_mapper/all.h"
static void *_mem_init(void) static void *_mem_init(void)
{ {

View File

@ -1,7 +1,7 @@
#ifndef TEST_UNIT_FRAMEWORK_H #ifndef TEST_UNIT_FRAMEWORK_H
#define TEST_UNIT_FRAMEWORK_H #define TEST_UNIT_FRAMEWORK_H
#include "device_mapper/libdevmapper.h" #include "device_mapper/all.h"
#include <stdbool.h> #include <stdbool.h>
#include <stdint.h> #include <stdint.h>

View File

@ -14,7 +14,7 @@
*/ */
#include "units.h" #include "units.h"
#include "device_mapper/libdevmapper.h" #include "device_mapper/all.h"
#include "matcher_data.h" #include "matcher_data.h"

Some files were not shown because too many files have changed in this diff Show More