Gautham R Shenoy | 74db920 | 2010-04-29 17:44:43 +0530 | [diff] [blame] | 1 | /* |
Greg Kurz | af8b38b | 2016-06-06 11:52:34 +0200 | [diff] [blame] | 2 | * 9p |
Gautham R Shenoy | 74db920 | 2010-04-29 17:44:43 +0530 | [diff] [blame] | 3 | * |
| 4 | * Copyright IBM, Corp. 2010 |
| 5 | * |
| 6 | * Authors: |
| 7 | * Aneesh Kumar K.V <aneesh.kumar@linux.vnet.ibm.com> |
| 8 | * |
| 9 | * This work is licensed under the terms of the GNU GPL, version 2. See |
| 10 | * the COPYING file in the top-level directory. |
| 11 | * |
| 12 | */ |
Markus Armbruster | 121d071 | 2016-06-29 10:12:57 +0200 | [diff] [blame] | 13 | |
| 14 | #ifndef FILE_OP_9P_H |
| 15 | #define FILE_OP_9P_H |
| 16 | |
Gautham R Shenoy | 74db920 | 2010-04-29 17:44:43 +0530 | [diff] [blame] | 17 | #include <dirent.h> |
Gautham R Shenoy | 74db920 | 2010-04-29 17:44:43 +0530 | [diff] [blame] | 18 | #include <utime.h> |
Venkateswararao Jujjuri (JV) | 758e8e3 | 2010-06-14 13:34:41 -0700 | [diff] [blame] | 19 | #include <sys/vfs.h> |
Pradeep Jagadeesh | b8bbdb8 | 2017-02-28 10:31:46 +0100 | [diff] [blame] | 20 | #include "qemu-fsdev-throttle.h" |
Aneesh Kumar K.V | 0174fe7 | 2011-08-02 11:35:54 +0530 | [diff] [blame] | 21 | |
Venkateswararao Jujjuri (JV) | 758e8e3 | 2010-06-14 13:34:41 -0700 | [diff] [blame] | 22 | #define SM_LOCAL_MODE_BITS 0600 |
| 23 | #define SM_LOCAL_DIR_MODE_BITS 0700 |
| 24 | |
Venkateswararao Jujjuri (JV) | 758e8e3 | 2010-06-14 13:34:41 -0700 | [diff] [blame] | 25 | typedef struct FsCred |
| 26 | { |
| 27 | uid_t fc_uid; |
| 28 | gid_t fc_gid; |
| 29 | mode_t fc_mode; |
| 30 | dev_t fc_rdev; |
| 31 | } FsCred; |
Gautham R Shenoy | 74db920 | 2010-04-29 17:44:43 +0530 | [diff] [blame] | 32 | |
Aneesh Kumar K.V | fc22118 | 2010-10-18 15:28:16 +0530 | [diff] [blame] | 33 | struct xattr_operations; |
Harsh Prateek Bora | e06a765 | 2011-10-12 19:11:25 +0530 | [diff] [blame] | 34 | struct FsContext; |
| 35 | struct V9fsPath; |
| 36 | |
| 37 | typedef struct extended_ops { |
| 38 | int (*get_st_gen)(struct FsContext *, struct V9fsPath *, |
| 39 | mode_t, uint64_t *); |
| 40 | } extended_ops; |
Aneesh Kumar K.V | fc22118 | 2010-10-18 15:28:16 +0530 | [diff] [blame] | 41 | |
Aneesh Kumar K.V | d3ab98e | 2011-10-12 19:11:23 +0530 | [diff] [blame] | 42 | /* export flags */ |
Aneesh Kumar K.V | c98f1d4 | 2011-10-12 20:59:18 +0530 | [diff] [blame] | 43 | #define V9FS_IMMEDIATE_WRITEOUT 0x00000001 |
| 44 | #define V9FS_PATHNAME_FSCONTEXT 0x00000002 |
Aneesh Kumar K.V | b97400c | 2011-10-13 13:21:00 +0530 | [diff] [blame] | 45 | /* |
| 46 | * uid/gid set on fileserver files |
| 47 | */ |
| 48 | #define V9FS_SM_PASSTHROUGH 0x00000004 |
| 49 | /* |
| 50 | * uid/gid part of xattr |
| 51 | */ |
| 52 | #define V9FS_SM_MAPPED 0x00000008 |
| 53 | /* |
| 54 | * Server will try to set uid/gid. |
| 55 | * On failure ignore the error. |
| 56 | */ |
| 57 | #define V9FS_SM_NONE 0x00000010 |
Aneesh Kumar K.V | 2c30dd7 | 2012-01-19 12:21:11 +0530 | [diff] [blame] | 58 | /* |
| 59 | * uid/gid part of .virtfs_meatadata namespace |
| 60 | */ |
| 61 | #define V9FS_SM_MAPPED_FILE 0x00000020 |
| 62 | #define V9FS_RDONLY 0x00000040 |
| 63 | #define V9FS_PROXY_SOCK_FD 0x00000080 |
| 64 | #define V9FS_PROXY_SOCK_NAME 0x00000100 |
Aneesh Kumar K.V | b97400c | 2011-10-13 13:21:00 +0530 | [diff] [blame] | 65 | |
Aneesh Kumar K.V | 2c30dd7 | 2012-01-19 12:21:11 +0530 | [diff] [blame] | 66 | #define V9FS_SEC_MASK 0x0000003C |
Aneesh Kumar K.V | d3ab98e | 2011-10-12 19:11:23 +0530 | [diff] [blame] | 67 | |
M. Mohan Kumar | 2c74c2c | 2011-10-25 12:10:39 +0530 | [diff] [blame] | 68 | |
Aneesh Kumar K.V | 99519f0 | 2011-12-14 13:48:59 +0530 | [diff] [blame] | 69 | typedef struct FileOperations FileOperations; |
| 70 | /* |
| 71 | * Structure to store the various fsdev's passed through command line. |
| 72 | */ |
| 73 | typedef struct FsDriverEntry { |
| 74 | char *fsdev_id; |
| 75 | char *path; |
| 76 | int export_flags; |
| 77 | FileOperations *ops; |
Pradeep Jagadeesh | b8bbdb8 | 2017-02-28 10:31:46 +0100 | [diff] [blame] | 78 | FsThrottle fst; |
Tobias Schramm | b96feb2 | 2017-06-29 15:11:50 +0200 | [diff] [blame] | 79 | mode_t fmode; |
| 80 | mode_t dmode; |
Aneesh Kumar K.V | 99519f0 | 2011-12-14 13:48:59 +0530 | [diff] [blame] | 81 | } FsDriverEntry; |
M. Mohan Kumar | 2c74c2c | 2011-10-25 12:10:39 +0530 | [diff] [blame] | 82 | |
Gautham R Shenoy | 74db920 | 2010-04-29 17:44:43 +0530 | [diff] [blame] | 83 | typedef struct FsContext |
| 84 | { |
Gautham R Shenoy | 74db920 | 2010-04-29 17:44:43 +0530 | [diff] [blame] | 85 | uid_t uid; |
Aneesh Kumar K.V | b97400c | 2011-10-13 13:21:00 +0530 | [diff] [blame] | 86 | char *fs_root; |
Aneesh Kumar K.V | d3ab98e | 2011-10-12 19:11:23 +0530 | [diff] [blame] | 87 | int export_flags; |
Aneesh Kumar K.V | fc22118 | 2010-10-18 15:28:16 +0530 | [diff] [blame] | 88 | struct xattr_operations **xops; |
Harsh Prateek Bora | e06a765 | 2011-10-12 19:11:25 +0530 | [diff] [blame] | 89 | struct extended_ops exops; |
Pradeep Jagadeesh | b8bbdb8 | 2017-02-28 10:31:46 +0100 | [diff] [blame] | 90 | FsThrottle *fst; |
Aneesh Kumar K.V | 532decb | 2011-08-02 11:35:54 +0530 | [diff] [blame] | 91 | /* fs driver specific data */ |
| 92 | void *private; |
Tobias Schramm | b96feb2 | 2017-06-29 15:11:50 +0200 | [diff] [blame] | 93 | mode_t fmode; |
| 94 | mode_t dmode; |
Gautham R Shenoy | 74db920 | 2010-04-29 17:44:43 +0530 | [diff] [blame] | 95 | } FsContext; |
| 96 | |
Aneesh Kumar K.V | 2289be1 | 2011-09-09 15:14:18 +0530 | [diff] [blame] | 97 | typedef struct V9fsPath { |
Aneesh Kumar K.V | 2f008a8 | 2011-12-21 12:37:23 +0530 | [diff] [blame] | 98 | uint16_t size; |
Aneesh Kumar K.V | 2289be1 | 2011-09-09 15:14:18 +0530 | [diff] [blame] | 99 | char *data; |
| 100 | } V9fsPath; |
| 101 | |
Aneesh Kumar K.V | cc720dd | 2011-10-25 12:10:40 +0530 | [diff] [blame] | 102 | typedef union V9fsFidOpenState V9fsFidOpenState; |
| 103 | |
Blue Swirl | 64b85a8 | 2011-01-23 16:21:20 +0000 | [diff] [blame] | 104 | void cred_init(FsCred *); |
Venkateswararao Jujjuri (JV) | 758e8e3 | 2010-06-14 13:34:41 -0700 | [diff] [blame] | 105 | |
Aneesh Kumar K.V | 99519f0 | 2011-12-14 13:48:59 +0530 | [diff] [blame] | 106 | struct FileOperations |
Gautham R Shenoy | 74db920 | 2010-04-29 17:44:43 +0530 | [diff] [blame] | 107 | { |
Aneesh Kumar K.V | 99519f0 | 2011-12-14 13:48:59 +0530 | [diff] [blame] | 108 | int (*parse_opts)(QemuOpts *, struct FsDriverEntry *); |
Aneesh Kumar K.V | 0174fe7 | 2011-08-02 11:35:54 +0530 | [diff] [blame] | 109 | int (*init)(struct FsContext *); |
Li Qiang | 702dbcc | 2016-11-23 13:53:34 +0100 | [diff] [blame] | 110 | void (*cleanup)(struct FsContext *); |
Aneesh Kumar K.V | 2289be1 | 2011-09-09 15:14:18 +0530 | [diff] [blame] | 111 | int (*lstat)(FsContext *, V9fsPath *, struct stat *); |
| 112 | ssize_t (*readlink)(FsContext *, V9fsPath *, char *, size_t); |
| 113 | int (*chmod)(FsContext *, V9fsPath *, FsCred *); |
| 114 | int (*chown)(FsContext *, V9fsPath *, FsCred *); |
| 115 | int (*mknod)(FsContext *, V9fsPath *, const char *, FsCred *); |
| 116 | int (*utimensat)(FsContext *, V9fsPath *, const struct timespec *); |
Anthony Liguori | 5bae190 | 2010-04-29 17:45:01 +0530 | [diff] [blame] | 117 | int (*remove)(FsContext *, const char *); |
Aneesh Kumar K.V | 2289be1 | 2011-09-09 15:14:18 +0530 | [diff] [blame] | 118 | int (*symlink)(FsContext *, const char *, V9fsPath *, |
| 119 | const char *, FsCred *); |
| 120 | int (*link)(FsContext *, V9fsPath *, V9fsPath *, const char *); |
Anthony Liguori | 131dcb2 | 2010-04-29 17:44:47 +0530 | [diff] [blame] | 121 | int (*setuid)(FsContext *, uid_t); |
Aneesh Kumar K.V | cc720dd | 2011-10-25 12:10:40 +0530 | [diff] [blame] | 122 | int (*close)(FsContext *, V9fsFidOpenState *); |
| 123 | int (*closedir)(FsContext *, V9fsFidOpenState *); |
| 124 | int (*opendir)(FsContext *, V9fsPath *, V9fsFidOpenState *); |
| 125 | int (*open)(FsContext *, V9fsPath *, int, V9fsFidOpenState *); |
| 126 | int (*open2)(FsContext *, V9fsPath *, const char *, |
| 127 | int, FsCred *, V9fsFidOpenState *); |
| 128 | void (*rewinddir)(FsContext *, V9fsFidOpenState *); |
| 129 | off_t (*telldir)(FsContext *, V9fsFidOpenState *); |
Greg Kurz | 635324e | 2016-06-06 11:52:34 +0200 | [diff] [blame] | 130 | struct dirent * (*readdir)(FsContext *, V9fsFidOpenState *); |
Aneesh Kumar K.V | cc720dd | 2011-10-25 12:10:40 +0530 | [diff] [blame] | 131 | void (*seekdir)(FsContext *, V9fsFidOpenState *, off_t); |
| 132 | ssize_t (*preadv)(FsContext *, V9fsFidOpenState *, |
| 133 | const struct iovec *, int, off_t); |
| 134 | ssize_t (*pwritev)(FsContext *, V9fsFidOpenState *, |
| 135 | const struct iovec *, int, off_t); |
Aneesh Kumar K.V | 2289be1 | 2011-09-09 15:14:18 +0530 | [diff] [blame] | 136 | int (*mkdir)(FsContext *, V9fsPath *, const char *, FsCred *); |
Aneesh Kumar K.V | 8b88827 | 2011-12-04 22:35:28 +0530 | [diff] [blame] | 137 | int (*fstat)(FsContext *, int, V9fsFidOpenState *, struct stat *); |
Anthony Liguori | 8cf89e0 | 2010-04-29 17:45:00 +0530 | [diff] [blame] | 138 | int (*rename)(FsContext *, const char *, const char *); |
Aneesh Kumar K.V | 2289be1 | 2011-09-09 15:14:18 +0530 | [diff] [blame] | 139 | int (*truncate)(FsContext *, V9fsPath *, off_t); |
Aneesh Kumar K.V | 8b88827 | 2011-12-04 22:35:28 +0530 | [diff] [blame] | 140 | int (*fsync)(FsContext *, int, V9fsFidOpenState *, int); |
Aneesh Kumar K.V | 2289be1 | 2011-09-09 15:14:18 +0530 | [diff] [blame] | 141 | int (*statfs)(FsContext *s, V9fsPath *path, struct statfs *stbuf); |
| 142 | ssize_t (*lgetxattr)(FsContext *, V9fsPath *, |
Aneesh Kumar K.V | fa32ef8 | 2010-09-02 11:09:06 +0530 | [diff] [blame] | 143 | const char *, void *, size_t); |
Aneesh Kumar K.V | 2289be1 | 2011-09-09 15:14:18 +0530 | [diff] [blame] | 144 | ssize_t (*llistxattr)(FsContext *, V9fsPath *, void *, size_t); |
| 145 | int (*lsetxattr)(FsContext *, V9fsPath *, |
Aneesh Kumar K.V | 10b468b | 2010-09-02 11:09:07 +0530 | [diff] [blame] | 146 | const char *, void *, size_t, int); |
Aneesh Kumar K.V | 2289be1 | 2011-09-09 15:14:18 +0530 | [diff] [blame] | 147 | int (*lremovexattr)(FsContext *, V9fsPath *, const char *); |
| 148 | int (*name_to_path)(FsContext *, V9fsPath *, const char *, V9fsPath *); |
| 149 | int (*renameat)(FsContext *ctx, V9fsPath *olddir, const char *old_name, |
| 150 | V9fsPath *newdir, const char *new_name); |
| 151 | int (*unlinkat)(FsContext *ctx, V9fsPath *dir, const char *name, int flags); |
Gautham R Shenoy | 74db920 | 2010-04-29 17:44:43 +0530 | [diff] [blame] | 152 | void *opaque; |
Aneesh Kumar K.V | 99519f0 | 2011-12-14 13:48:59 +0530 | [diff] [blame] | 153 | }; |
Aneesh Kumar K.V | fc22118 | 2010-10-18 15:28:16 +0530 | [diff] [blame] | 154 | |
Gautham R Shenoy | 74db920 | 2010-04-29 17:44:43 +0530 | [diff] [blame] | 155 | #endif |