[Gluster-devel] Proper error path handling when libgfapi routines fail

Bharata B Rao bharata.rao at gmail.com
Wed Jul 18 06:06:01 UTC 2012


Hi Avati,

In QEMU, this is how I am planning to use libgfapi to set the GlusterFS backend.

struct glfs *glfs;
int ret = 0;

glfs = glfs_new(volname);
if (!glfs) {
    ret = -errno;
    goto out_glfs_new_failed;
}

ret = glfs_set_volfile_server(glfs, "socket", server, port);
if (ret < 0) {
    ret = -errno;
    goto out_set_volfile_failed;
}

/* optional */
ret = glfs_set_logging(glfs, logfile, loglevel);
if (ret < 0) {
    ret = -errno;
    goto out_set_logging_failed;
}

ret = glfs_init(glfs);
if (ret < 0) {
    ret = -errno;
    goto out_glfs_init_failed;
}
return ret;

out_glfs_init_failed:
    glfs_unset_logging(glfs, ...);
out_set_logging_failed:
    glfs_unset_volfile_server(glfs, ...);
out_set_volfile_failed:
    glfs_free(glfs);
out_glfs_new_failed:
    return ret;

I see only glfs_fini() in libgfapi currently. I see that all of the
APIs I am using above at least allocate memory which needs to be freed
up at the end or during failure. Are such cleanup routines already
present in libgfapi that could use ? If not, can you please provide
the clean up routines for the above mentioned 4 APIs that QEMU would
be using ?

Regards,
Bharata.
-- 
http://bharata.sulekha.com/blog/posts.htm, http://raobharata.wordpress.com/




More information about the Gluster-devel mailing list