summaryrefslogtreecommitdiffstats
path: root/src/libcephfs_proxy/proxy_mount.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/libcephfs_proxy/proxy_mount.h')
-rw-r--r--src/libcephfs_proxy/proxy_mount.h64
1 files changed, 64 insertions, 0 deletions
diff --git a/src/libcephfs_proxy/proxy_mount.h b/src/libcephfs_proxy/proxy_mount.h
new file mode 100644
index 00000000000..14bd58fabb2
--- /dev/null
+++ b/src/libcephfs_proxy/proxy_mount.h
@@ -0,0 +1,64 @@
+
+#ifndef __LIBCEPHFSD_PROXY_MOUNT_H__
+#define __LIBCEPHFSD_PROXY_MOUNT_H__
+
+#include "proxy.h"
+#include "proxy_list.h"
+
+#include "include/cephfs/libcephfs.h"
+
+typedef struct _proxy_instance {
+ uint8_t hash[32];
+ list_t list;
+ list_t siblings;
+ list_t changes;
+ struct ceph_mount_info *cmount;
+ struct Inode *root;
+ bool inited;
+ bool mounted;
+} proxy_instance_t;
+
+typedef struct _proxy_mount {
+ proxy_instance_t *instance;
+ UserPerm *perms;
+ struct Inode *root;
+ struct Inode *cwd;
+ char *cwd_path;
+ uint64_t root_ino;
+ uint64_t cwd_ino;
+ uint32_t cwd_path_len;
+} proxy_mount_t;
+
+static inline struct ceph_mount_info *proxy_cmount(proxy_mount_t *mount)
+{
+ return mount->instance->cmount;
+}
+
+int32_t proxy_inode_ref(proxy_mount_t *mount, uint64_t inode);
+
+int32_t proxy_mount_create(proxy_mount_t **pmount, const char *id);
+
+int32_t proxy_mount_config(proxy_mount_t *mount, const char *config);
+
+int32_t proxy_mount_set(proxy_mount_t *mount, const char *name,
+ const char *value);
+
+int32_t proxy_mount_get(proxy_mount_t *mount, const char *name, char *value,
+ size_t size);
+
+int32_t proxy_mount_select(proxy_mount_t *mount, const char *fs);
+
+int32_t proxy_mount_init(proxy_mount_t *mount);
+
+int32_t proxy_mount_mount(proxy_mount_t *mount, const char *root);
+
+int32_t proxy_mount_unmount(proxy_mount_t *mount);
+
+int32_t proxy_mount_release(proxy_mount_t *mount);
+
+int32_t proxy_path_resolve(proxy_mount_t *mount, const char *path,
+ struct Inode **inode, struct ceph_statx *stx,
+ uint32_t want, uint32_t flags, UserPerm *perms,
+ char **realpath);
+
+#endif