f3a06403b8
g_new(T, n) is neater than g_malloc(sizeof(T) * n). It's also safer, for two reasons. One, it catches multiplication overflowing size_t. Two, it returns T * rather than void *, which lets the compiler catch more type errors. This commit only touches allocations with size arguments of the form sizeof(T). Same Coccinelle semantic patch as in commit b45c03f. Signed-off-by: Markus Armbruster <armbru@redhat.com> Reviewed-by: Eric Blake <eblake@redhat.com> Signed-off-by: Michael Roth <mdroth@linux.vnet.ibm.com>
74 lines
1.6 KiB
C
74 lines
1.6 KiB
C
/*
|
|
* QEMU Guest Agent command state interfaces
|
|
*
|
|
* Copyright IBM Corp. 2011
|
|
*
|
|
* Authors:
|
|
* Michael Roth <mdroth@linux.vnet.ibm.com>
|
|
*
|
|
* This work is licensed under the terms of the GNU GPL, version 2 or later.
|
|
* See the COPYING file in the top-level directory.
|
|
*/
|
|
#include <glib.h>
|
|
#include "qga/guest-agent-core.h"
|
|
|
|
struct GACommandState {
|
|
GSList *groups;
|
|
};
|
|
|
|
typedef struct GACommandGroup {
|
|
void (*init)(void);
|
|
void (*cleanup)(void);
|
|
} GACommandGroup;
|
|
|
|
/* handle init/cleanup for stateful guest commands */
|
|
|
|
void ga_command_state_add(GACommandState *cs,
|
|
void (*init)(void),
|
|
void (*cleanup)(void))
|
|
{
|
|
GACommandGroup *cg = g_new0(GACommandGroup, 1);
|
|
cg->init = init;
|
|
cg->cleanup = cleanup;
|
|
cs->groups = g_slist_append(cs->groups, cg);
|
|
}
|
|
|
|
static void ga_command_group_init(gpointer opaque, gpointer unused)
|
|
{
|
|
GACommandGroup *cg = opaque;
|
|
|
|
g_assert(cg);
|
|
if (cg->init) {
|
|
cg->init();
|
|
}
|
|
}
|
|
|
|
void ga_command_state_init_all(GACommandState *cs)
|
|
{
|
|
g_assert(cs);
|
|
g_slist_foreach(cs->groups, ga_command_group_init, NULL);
|
|
}
|
|
|
|
static void ga_command_group_cleanup(gpointer opaque, gpointer unused)
|
|
{
|
|
GACommandGroup *cg = opaque;
|
|
|
|
g_assert(cg);
|
|
if (cg->cleanup) {
|
|
cg->cleanup();
|
|
}
|
|
}
|
|
|
|
void ga_command_state_cleanup_all(GACommandState *cs)
|
|
{
|
|
g_assert(cs);
|
|
g_slist_foreach(cs->groups, ga_command_group_cleanup, NULL);
|
|
}
|
|
|
|
GACommandState *ga_command_state_new(void)
|
|
{
|
|
GACommandState *cs = g_new0(GACommandState, 1);
|
|
cs->groups = NULL;
|
|
return cs;
|
|
}
|