#include #include #include #include #include #include #include #include #include #include #define LOG_ERR(msg) do { \ fprintf (stderr, "%s : Error (%s)\n", msg, strerror (errno)); \ } while (0) glfs_t * init_glfs (const char *hostname, const char *volname, const char *logfile) { int ret = -1; glfs_t *fs = NULL; fs = glfs_new (volname); if (!fs) { LOG_ERR ("glfs_new failed"); return NULL; } ret = glfs_set_volfile_server (fs, "tcp", hostname, 24007); if (ret < 0) { LOG_ERR ("glfs_set_volfile_server failed"); goto out; } ret = glfs_set_logging (fs, logfile, 7); if (ret < 0) { LOG_ERR ("glfs_set_logging failed"); goto out; } ret = glfs_init (fs); if (ret < 0) { LOG_ERR ("glfs_init failed"); goto out; } ret = 0; out: if (ret) { glfs_fini (fs); fs = NULL; } return fs; } int glfs_test_function (const char *hostname, const char *volname, const char *logfile) { int ret = -1; int flags = O_CREAT | O_RDWR; glfs_t *fs = NULL; glfs_fd_t *glfd = NULL; const char *buff = "This is from my prog\n"; const char *filename = "glfs_test.txt"; fs = init_glfs (hostname, volname, logfile); if (fs == NULL) { LOG_ERR ("init_glfs failed"); return -1; } glfd = glfs_creat (fs, filename, flags, 0644); if (glfd == NULL) { LOG_ERR ("glfs_creat failed"); goto out; } ret = glfs_write (glfd, buff, strlen (buff), flags); if (ret < 0) { LOG_ERR ("glfs_write failed"); goto out; } ret = glfs_close (glfd); if (ret < 0) { LOG_ERR ("glfs_write failed"); goto out; } out: ret = glfs_fini (fs); if (ret) { LOG_ERR ("glfs_fini failed"); } return ret; } int main (int argc, char *argv[]) { int ret = 0; char *hostname = NULL; char *volname = NULL; char *logfile = NULL; if (argc != 4) { fprintf (stderr, "Invalid argument\n"); exit(1); } hostname = argv[1]; volname = argv[2]; logfile = argv[3]; ret = glfs_test_function (hostname, volname, logfile); if (ret) { LOG_ERR ("glfs_test_function failed"); } return ret; }