9
#include <glusterfs/api/glfs.h>
10
#include <glusterfs/api/glfs-handles.h>
12
#define LOG_ERR(func, ret) \
15
fprintf(stderr, "%s : returned error %d (%s)\n", func, ret, \
19
fprintf(stderr, "%s : returned %d\n", func, ret); \
26
up_async_invalidate(struct glfs_upcall *up_arg, void *data)
28
struct glfs_upcall_inode *in_arg = NULL;
29
enum glfs_upcall_reason reason = 0;
30
struct glfs_object *object = NULL;
37
reason = glfs_upcall_get_reason(up_arg);
41
if (reason == GLFS_UPCALL_INODE_INVALIDATE) {
42
in_arg = glfs_upcall_get_event(up_arg);
44
object = glfs_upcall_inode_get_object(in_arg);
45
flags = glfs_upcall_inode_get_flags(in_arg);
46
expire = glfs_upcall_inode_get_expire(in_arg);
49
" upcall event type - %d,"
50
" object(%p), flags(%d), "
51
" expire_time_attr(%d)\n",
52
reason, object, flags, expire);
61
perform_io(glfs_t *fs, glfs_t *fs2, int cnt)
63
glfs_t *fs_tmp = NULL;
64
glfs_t *fs_tmp2 = NULL;
65
glfs_fd_t *fd_tmp = NULL;
66
glfs_fd_t *fd_tmp2 = NULL;
68
char *writebuf = NULL;
70
glfs_fd_t *fd2 = NULL;
71
char *filename = "file_tmp";
78
fd = glfs_creat(fs, filename, O_RDWR | O_SYNC, 0644);
81
LOG_ERR("glfs_creat", ret);
84
fd2 = glfs_open(fs2, filename, O_SYNC | O_RDWR | O_CREAT);
87
LOG_ERR("glfs_open-fs2", ret);
104
writebuf = malloc(10);
106
memcpy(writebuf, "abcd", 4);
107
ret = glfs_write(fd_tmp, writebuf, 4, 0);
110
LOG_ERR("glfs_write", ret);
114
fprintf(stderr, "Could not allocate writebuf\n");
119
ret = glfs_lseek(fd_tmp2, 0, SEEK_SET);
120
LOG_ERR("glfs_lseek", ret);
122
memset(readbuf, 0, sizeof(readbuf));
123
ret = glfs_pread(fd_tmp2, readbuf, 4, 0, 0, NULL);
127
LOG_ERR("glfs_pread", ret);
146
main(int argc, char *argv[])
152
unsigned int cnt = 5;
153
struct glfs_upcall *cbk = NULL;
154
char *logfile = NULL;
155
char *volname = NULL;
156
char *hostname = NULL;
157
int up_events = GLFS_EVENT_ANY;
160
fprintf(stderr, "Invalid argument\n");
169
fs = glfs_new(volname);
171
fprintf(stderr, "glfs_new: returned NULL\n");
175
ret = glfs_set_volfile_server(fs, "tcp", hostname, 24007);
176
LOG_ERR("glfs_set_volfile_server", ret);
178
ret = glfs_set_logging(fs, logfile, 7);
179
LOG_ERR("glfs_set_logging", ret);
182
LOG_ERR("glfs_init", ret);
185
fs2 = glfs_new(volname);
187
fprintf(stderr, "glfs_new fs2: returned NULL\n");
191
ret = glfs_set_volfile_server(fs2, "tcp", hostname, 24007);
192
LOG_ERR("glfs_set_volfile_server-fs2", ret);
194
ret = glfs_set_logging(fs2, logfile, 7);
195
LOG_ERR("glfs_set_logging-fs2", ret);
197
ret = glfs_init(fs2);
198
LOG_ERR("glfs_init-fs2", ret);
201
ret = glfs_upcall_register(fs, up_events, up_async_invalidate, NULL);
204
if (!(ret & GLFS_EVENT_INODE_INVALIDATE)) {
206
"glfs_upcall_register return doesn't contain"
211
ret = glfs_upcall_register(fs2, up_events, up_async_invalidate, NULL);
214
if ((ret < 0) || !(ret & GLFS_EVENT_INODE_INVALIDATE)) {
216
"glfs_upcall_register return doesn't contain"
222
ret = perform_io(fs, fs2, cnt);
223
LOG_ERR("perform_io", ret);
225
if (upcall_recv == 0) {
226
fprintf(stderr, "Upcalls are not received.\n");
229
fprintf(stderr, "Received %d upcalls as expected\n", upcall_recv);
236
ret = glfs_upcall_unregister(fs, up_events);
239
if ((ret < 0) || !(ret & GLFS_EVENT_INODE_INVALIDATE)) {
241
"glfs_upcall_unregister return doesn't contain"
246
ret = glfs_upcall_unregister(fs2, up_events);
249
if ((ret < 0) || !(ret & GLFS_EVENT_INODE_INVALIDATE)) {
251
"glfs_upcall_unregister return doesn't contain"
258
ret = perform_io(fs, fs2, cnt);
259
LOG_ERR("perform_io", ret);
261
if (upcall_recv != 0) {
262
fprintf(stderr, "%d upcalls received even after unregister.\n",
267
"Post unregister, no upcalls received as"
275
fprintf(stderr, "glfs_fini(fs) returned %d\n", ret);
279
ret = glfs_fini(fs2);
280
fprintf(stderr, "glfs_fini(fs2) returned %d\n", ret);