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:
commit
7c4b19c335
@ -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)))
|
||||||
|
@ -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
94
base/data-struct/hash.h
Normal 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
|
@ -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
209
base/data-struct/list.h
Normal 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
3
configure
vendored
@ -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" ;;
|
||||||
|
|
||||||
|
@ -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
|
||||||
])
|
])
|
||||||
|
@ -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
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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");
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
@ -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 \
|
||||||
|
@ -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 */
|
@ -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)
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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"
|
||||||
|
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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 */
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
@ -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"
|
||||||
|
|
||||||
|
@ -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 */
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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>
|
||||||
|
@ -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)
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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
57
lib/cache/lvmcache.c
vendored
@ -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
4
lib/cache/lvmetad.c
vendored
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
@ -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();
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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 */
|
||||||
|
@ -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)
|
||||||
|
@ -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>
|
||||||
|
@ -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)
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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 */
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
|
@ -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));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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);
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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"
|
||||||
|
@ -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",
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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)
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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"
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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",
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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)
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
|
@ -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
|
||||||
|
@ -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"
|
||||||
|
|
||||||
//----------------------------------------------------------------
|
//----------------------------------------------------------------
|
||||||
|
|
||||||
|
@ -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"
|
||||||
|
|
||||||
//----------------------------------------------------------------
|
//----------------------------------------------------------------
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
@ -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)
|
||||||
{
|
{
|
||||||
|
@ -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)
|
||||||
{
|
{
|
||||||
|
@ -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)
|
||||||
{
|
{
|
||||||
|
@ -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>
|
||||||
|
@ -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
Loading…
x
Reference in New Issue
Block a user