Skip to content

Commit

Permalink
tpm-backend: Initialize and free data members in it's own methods
Browse files Browse the repository at this point in the history
Initialize and free TPMBackend data members in it's own instance_init() and
instance_finalize methods.

Took the opportunity to remove unneeded destroy() method from TpmDriverOps
interface as TPMBackend is a Qemu Object, we can use object_unref() inplace of
tpm_backend_destroy() to free the backend object, hence removed destroy() from
TPMDriverOps interface.

Signed-off-by: Amarnath Valluri <amarnath.valluri@intel.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Reviewed-by: Stefan Berger <stefanb@linux.vnet.ibm.com>
Signed-off-by: Stefan Berger <stefanb@linux.vnet.ibm.com>
  • Loading branch information
avalluri authored and stefanberger committed Oct 13, 2017
1 parent b19a5ee commit f35fe5c
Show file tree
Hide file tree
Showing 4 changed files with 19 additions and 37 deletions.
16 changes: 6 additions & 10 deletions backends/tpm.c
Expand Up @@ -51,15 +51,6 @@ const char *tpm_backend_get_desc(TPMBackend *s)
return k->ops->desc();
}

void tpm_backend_destroy(TPMBackend *s)
{
TPMBackendClass *k = TPM_BACKEND_GET_CLASS(s);

k->ops->destroy(s);

tpm_backend_thread_end(s);
}

int tpm_backend_init(TPMBackend *s, TPMState *state,
TPMRecvDataCB *datacb)
{
Expand Down Expand Up @@ -182,17 +173,22 @@ static void tpm_backend_prop_set_opened(Object *obj, bool value, Error **errp)

static void tpm_backend_instance_init(Object *obj)
{
TPMBackend *s = TPM_BACKEND(obj);

object_property_add_bool(obj, "opened",
tpm_backend_prop_get_opened,
tpm_backend_prop_set_opened,
NULL);

s->fe_model = -1;
}

static void tpm_backend_instance_finalize(Object *obj)
{
TPMBackend *s = TPM_BACKEND(obj);

g_free(s->id);
g_free(s->path);
g_free(s->cancel_path);
tpm_backend_thread_end(s);
}

Expand Down
31 changes: 12 additions & 19 deletions hw/tpm/tpm_passthrough.c
Expand Up @@ -417,8 +417,6 @@ static TPMBackend *tpm_passthrough_create(QemuOpts *opts, const char *id)
TPMPassthruState *tpm_pt = TPM_PASSTHROUGH(tb);

tb->id = g_strdup(id);
/* let frontend set the fe_model to proper value */
tb->fe_model = -1;

if (tpm_passthrough_handle_device_opts(opts, tb)) {
goto err_exit;
Expand All @@ -432,26 +430,11 @@ static TPMBackend *tpm_passthrough_create(QemuOpts *opts, const char *id)
return tb;

err_exit:
g_free(tb->id);
object_unref(obj);

return NULL;
}

static void tpm_passthrough_destroy(TPMBackend *tb)
{
TPMPassthruState *tpm_pt = TPM_PASSTHROUGH(tb);

tpm_passthrough_cancel_cmd(tb);

qemu_close(tpm_pt->tpm_fd);
qemu_close(tpm_pt->cancel_fd);

g_free(tb->id);
g_free(tb->path);
g_free(tb->cancel_path);
g_free(tpm_pt->tpm_dev);
}

static const QemuOptDesc tpm_passthrough_cmdline_opts[] = {
TPM_STANDARD_CMDLINE_OPTS,
{
Expand All @@ -472,7 +455,6 @@ static const TPMDriverOps tpm_passthrough_driver = {
.opts = tpm_passthrough_cmdline_opts,
.desc = tpm_passthrough_create_desc,
.create = tpm_passthrough_create,
.destroy = tpm_passthrough_destroy,
.init = tpm_passthrough_init,
.startup_tpm = tpm_passthrough_startup_tpm,
.realloc_buffer = tpm_passthrough_realloc_buffer,
Expand All @@ -486,10 +468,21 @@ static const TPMDriverOps tpm_passthrough_driver = {

static void tpm_passthrough_inst_init(Object *obj)
{
TPMPassthruState *tpm_pt = TPM_PASSTHROUGH(obj);

tpm_pt->tpm_fd = -1;
tpm_pt->cancel_fd = -1;
}

static void tpm_passthrough_inst_finalize(Object *obj)
{
TPMPassthruState *tpm_pt = TPM_PASSTHROUGH(obj);

tpm_passthrough_cancel_cmd(TPM_BACKEND(obj));

qemu_close(tpm_pt->tpm_fd);
qemu_close(tpm_pt->cancel_fd);
g_free(tpm_pt->tpm_dev);
}

static void tpm_passthrough_class_init(ObjectClass *klass, void *data)
Expand Down
7 changes: 0 additions & 7 deletions include/sysemu/tpm_backend.h
Expand Up @@ -78,7 +78,6 @@ struct TPMDriverOps {
const char *(*desc)(void);

TPMBackend *(*create)(QemuOpts *opts, const char *id);
void (*destroy)(TPMBackend *t);

/* initialize the backend */
int (*init)(TPMBackend *t);
Expand Down Expand Up @@ -117,12 +116,6 @@ enum TpmType tpm_backend_get_type(TPMBackend *s);
*/
const char *tpm_backend_get_desc(TPMBackend *s);

/**
* tpm_backend_destroy:
* @s: the backend to destroy
*/
void tpm_backend_destroy(TPMBackend *s);

/**
* tpm_backend_init:
* @s: the backend to initialized
Expand Down
2 changes: 1 addition & 1 deletion tpm.c
Expand Up @@ -157,7 +157,7 @@ void tpm_cleanup(void)

QLIST_FOREACH_SAFE(drv, &tpm_backends, list, next) {
QLIST_REMOVE(drv, list);
tpm_backend_destroy(drv);
object_unref(OBJECT(drv));
}
}

Expand Down

0 comments on commit f35fe5c

Please sign in to comment.