==================
* There are new ``timefs1`` and ``timefs2`` examples that demonstrate
- the use of the `fuse_lowlevel_notify_store` and
+ the use of the `fuse_lowlevel_notify_store`,
+ `fuse_lowlevel_notify_retrieve`, and
`fuse_lowlevel_notify_inval_inode` functions.
* The ``-o big_writes`` mount option has been removed. It is now
static int lookup_cnt = 0;
static size_t file_size;
+/* Keep track if we ever stored data (==1), and
+ received it back correctly (==2) */
+static int retrieve_status = 0;
+
/* Command line parsing */
struct options {
int no_notify;
reply_buf_limited(req, file_contents, file_size, off, size);
}
+static void tfs_retrieve_reply(fuse_req_t req, void *cookie, fuse_ino_t ino,
+ off_t offset, struct fuse_bufvec *data) {
+ struct fuse_bufvec bufv;
+ char buf[MAX_STR_LEN];
+ char *expected;
+ ssize_t ret;
+
+ assert(ino == FILE_INO);
+ assert(offset == 0);
+ expected = (char*) cookie;
+
+ bufv.count = 1;
+ bufv.idx = 0;
+ bufv.off = 0;
+ bufv.buf[0].size = MAX_STR_LEN;
+ bufv.buf[0].mem = buf;
+ bufv.buf[0].flags = 0;
+
+ ret = fuse_buf_copy(&bufv, data, 0);
+ assert(ret > 0);
+ assert(strncmp(buf, expected, ret) == 0);
+ free(expected);
+ retrieve_status = 2;
+ fuse_reply_none(req);
+}
+
+
static struct fuse_lowlevel_ops tfs_oper = {
.lookup = tfs_lookup,
.getattr = tfs_getattr,
.open = tfs_open,
.read = tfs_read,
.forget = tfs_forget,
+ .retrieve_reply = tfs_retrieve_reply,
};
static void* update_fs(void *data) {
struct fuse_session *se = (struct fuse_session*) data;
struct tm *now;
time_t t;
- struct fuse_bufvec bufv;
+ struct fuse_bufvec bufv;
while(1) {
t = time(NULL);
bufv.buf[0].flags = 0;
assert(fuse_lowlevel_notify_store(se, FILE_INO, 0,
&bufv, 0) == 0);
+
+ /* To make sure that everything worked correctly, ask the
+ kernel to send us back the stored data */
+ assert(fuse_lowlevel_notify_retrieve
+ (se, FILE_INO, MAX_STR_LEN, 0,
+ (void*) strdup(file_contents)) == 0);
+ if(retrieve_status == 0)
+ retrieve_status = 1;
}
sleep(options.update_interval);
}
else
ret = fuse_session_loop_mt(se);
+ assert(retrieve_status != 1);
fuse_session_unmount(se);
err_out3:
fuse_remove_signal_handlers(se);