#include #include #include #include #include #define NO_INIT 1 glfs_t * setup_new_client(char *hostname, char *volname, char *log_file, int flag) { int ret = 0; glfs_t *fs = NULL; fs = glfs_new(volname); if (!fs) { fprintf(stderr, "\nglfs_new: returned NULL (%s)\n", strerror(errno)); goto error; } ret = glfs_set_volfile_server(fs, "tcp", hostname, 24007); if (ret < 0) { fprintf(stderr, "\nglfs_set_volfile_server failed ret:%d (%s)\n", ret, strerror(errno)); goto error; } ret = glfs_set_logging(fs, log_file, 7); if (ret < 0) { fprintf(stderr, "\nglfs_set_logging failed with ret: %d (%s)\n", ret, strerror(errno)); goto error; } if (flag == NO_INIT) goto out; ret = glfs_init(fs); if (ret < 0) { fprintf(stderr, "\nglfs_init failed with ret: %d (%s)\n", ret, strerror(errno)); goto error; } out: return fs; error: return NULL; } int main(int argc, char *argv[]) { int ret = 0; glfs_t *fs1 = NULL; glfs_t *fs2 = NULL; glfs_t *fs3 = NULL; char *volname = NULL; char *log_file = NULL; char *hostname = NULL; if (argc != 4) { fprintf( stderr, "Expect following args %s \n", argv[0]); return -1; } hostname = argv[1]; volname = argv[2]; log_file = argv[3]; fs1 = setup_new_client(hostname, volname, log_file, NO_INIT); if (!fs1) { fprintf(stderr, "\nsetup_new_client: returned NULL (%s)\n", strerror(errno)); goto error; } fs2 = setup_new_client(hostname, volname, log_file, 0); if (!fs2) { fprintf(stderr, "\nsetup_new_client: returned NULL (%s)\n", strerror(errno)); goto error; } fs3 = setup_new_client(hostname, volname, log_file, 0); if (!fs3) { fprintf(stderr, "\nsetup_new_client: returned NULL (%s)\n", strerror(errno)); goto error; } ret = glfs_fini(fs3); if (ret < 0) { fprintf(stderr, "glfs_fini failed with ret: %d (%s)\n", ret, strerror(errno)); goto error; } /* The crash is seen in gf_log_flush_timeout_cbk(), and this gets * triggered when 30s timer expires, hence the sleep of 31s */ sleep(31); ret = glfs_fini(fs2); if (ret < 0) { fprintf(stderr, "glfs_fini failed with ret: %d (%s)\n", ret, strerror(errno)); goto error; } ret = glfs_init(fs1); if (ret < 0) { fprintf(stderr, "\nglfs_init failed with ret: %d (%s)\n", ret, strerror(errno)); goto error; } ret = glfs_fini(fs1); if (ret < 0) { fprintf(stderr, "glfs_fini failed with ret: %d (%s)\n", ret, strerror(errno)); goto error; } return 0; error: return -1; }