This allows calls like open(file, O_CREAT|O_RDONLY, 0200) which would
otherwise fail because we cannot open the file after mknod() has
created it with 0200 permissions.
}
#endif
+static int xmp_create(const char *path, mode_t mode,
+ struct fuse_file_info *fi)
+{
+ int res;
+
+ res = open(path, fi->flags, mode);
+ if (res == -1)
+ return -errno;
+
+ fi->fh = res;
+ return 0;
+}
+
static int xmp_open(const char *path, struct fuse_file_info *fi)
{
int res;
.utimens = xmp_utimens,
#endif
.open = xmp_open,
+ .create = xmp_create,
.read = xmp_read,
.write = xmp_write,
.statfs = xmp_statfs,