1353ac78dSAneesh Kumar K.V /* 2af8b38b0SGreg Kurz * 9p 3353ac78dSAneesh Kumar K.V * 4353ac78dSAneesh Kumar K.V * Copyright IBM, Corp. 2010 5353ac78dSAneesh Kumar K.V * 6353ac78dSAneesh Kumar K.V * Authors: 7353ac78dSAneesh Kumar K.V * Aneesh Kumar K.V <aneesh.kumar@linux.vnet.ibm.com> 8353ac78dSAneesh Kumar K.V * 9353ac78dSAneesh Kumar K.V * This work is licensed under the terms of the GNU GPL, version 2. See 10353ac78dSAneesh Kumar K.V * the COPYING file in the top-level directory. 11353ac78dSAneesh Kumar K.V * 12353ac78dSAneesh Kumar K.V */ 13121d0712SMarkus Armbruster 14121d0712SMarkus Armbruster #ifndef FILE_OP_9P_H 15121d0712SMarkus Armbruster #define FILE_OP_9P_H 16121d0712SMarkus Armbruster 17353ac78dSAneesh Kumar K.V #include <dirent.h> 18353ac78dSAneesh Kumar K.V #include <utime.h> 19353ac78dSAneesh Kumar K.V #include <sys/vfs.h> 20b8bbdb88SPradeep Jagadeesh #include "qemu-fsdev-throttle.h" 210174fe73SAneesh Kumar K.V 22353ac78dSAneesh Kumar K.V #define SM_LOCAL_MODE_BITS 0600 23353ac78dSAneesh Kumar K.V #define SM_LOCAL_DIR_MODE_BITS 0700 24353ac78dSAneesh Kumar K.V 251a8d0bb3SGreg Kurz typedef struct FsCred { 26353ac78dSAneesh Kumar K.V uid_t fc_uid; 27353ac78dSAneesh Kumar K.V gid_t fc_gid; 28353ac78dSAneesh Kumar K.V mode_t fc_mode; 29353ac78dSAneesh Kumar K.V dev_t fc_rdev; 30353ac78dSAneesh Kumar K.V } FsCred; 31353ac78dSAneesh Kumar K.V 321a8d0bb3SGreg Kurz typedef struct FsContext FsContext; 331a8d0bb3SGreg Kurz typedef struct V9fsPath V9fsPath; 34e06a765eSHarsh Prateek Bora 351a8d0bb3SGreg Kurz typedef struct ExtendedOps { 361a8d0bb3SGreg Kurz int (*get_st_gen)(FsContext *, V9fsPath *, mode_t, uint64_t *); 371a8d0bb3SGreg Kurz } ExtendedOps; 38353ac78dSAneesh Kumar K.V 39d3ab98e6SAneesh Kumar K.V /* export flags */ 40c98f1d4aSAneesh Kumar K.V #define V9FS_IMMEDIATE_WRITEOUT 0x00000001 41c98f1d4aSAneesh Kumar K.V #define V9FS_PATHNAME_FSCONTEXT 0x00000002 42b97400caSAneesh Kumar K.V /* 43b97400caSAneesh Kumar K.V * uid/gid set on fileserver files 44b97400caSAneesh Kumar K.V */ 45b97400caSAneesh Kumar K.V #define V9FS_SM_PASSTHROUGH 0x00000004 46b97400caSAneesh Kumar K.V /* 47b97400caSAneesh Kumar K.V * uid/gid part of xattr 48b97400caSAneesh Kumar K.V */ 49b97400caSAneesh Kumar K.V #define V9FS_SM_MAPPED 0x00000008 50b97400caSAneesh Kumar K.V /* 51b97400caSAneesh Kumar K.V * Server will try to set uid/gid. 52b97400caSAneesh Kumar K.V * On failure ignore the error. 53b97400caSAneesh Kumar K.V */ 54b97400caSAneesh Kumar K.V #define V9FS_SM_NONE 0x00000010 552c30dd74SAneesh Kumar K.V /* 562c30dd74SAneesh Kumar K.V * uid/gid part of .virtfs_meatadata namespace 572c30dd74SAneesh Kumar K.V */ 582c30dd74SAneesh Kumar K.V #define V9FS_SM_MAPPED_FILE 0x00000020 592c30dd74SAneesh Kumar K.V #define V9FS_RDONLY 0x00000040 602c30dd74SAneesh Kumar K.V #define V9FS_PROXY_SOCK_FD 0x00000080 612c30dd74SAneesh Kumar K.V #define V9FS_PROXY_SOCK_NAME 0x00000100 62*1a6ed33cSAntonios Motakis /* 63*1a6ed33cSAntonios Motakis * multidevs option (either one of the two applies exclusively) 64*1a6ed33cSAntonios Motakis */ 65*1a6ed33cSAntonios Motakis #define V9FS_REMAP_INODES 0x00000200 66*1a6ed33cSAntonios Motakis #define V9FS_FORBID_MULTIDEVS 0x00000400 67b97400caSAneesh Kumar K.V 682c30dd74SAneesh Kumar K.V #define V9FS_SEC_MASK 0x0000003C 69d3ab98e6SAneesh Kumar K.V 702c74c2cbSM. Mohan Kumar 7199519f0aSAneesh Kumar K.V typedef struct FileOperations FileOperations; 7201847522SGreg Kurz typedef struct XattrOperations XattrOperations; 7301847522SGreg Kurz 7499519f0aSAneesh Kumar K.V /* 7599519f0aSAneesh Kumar K.V * Structure to store the various fsdev's passed through command line. 7699519f0aSAneesh Kumar K.V */ 7799519f0aSAneesh Kumar K.V typedef struct FsDriverEntry { 7899519f0aSAneesh Kumar K.V char *fsdev_id; 7999519f0aSAneesh Kumar K.V char *path; 8099519f0aSAneesh Kumar K.V int export_flags; 8199519f0aSAneesh Kumar K.V FileOperations *ops; 82b8bbdb88SPradeep Jagadeesh FsThrottle fst; 83b96feb2cSTobias Schramm mode_t fmode; 84b96feb2cSTobias Schramm mode_t dmode; 8599519f0aSAneesh Kumar K.V } FsDriverEntry; 862c74c2cbSM. Mohan Kumar 871a8d0bb3SGreg Kurz struct FsContext { 88353ac78dSAneesh Kumar K.V uid_t uid; 89b97400caSAneesh Kumar K.V char *fs_root; 90d3ab98e6SAneesh Kumar K.V int export_flags; 9101847522SGreg Kurz XattrOperations **xops; 921a8d0bb3SGreg Kurz ExtendedOps exops; 93b8bbdb88SPradeep Jagadeesh FsThrottle *fst; 94532decb7SAneesh Kumar K.V /* fs driver specific data */ 95532decb7SAneesh Kumar K.V void *private; 96b96feb2cSTobias Schramm mode_t fmode; 97b96feb2cSTobias Schramm mode_t dmode; 981a8d0bb3SGreg Kurz }; 99353ac78dSAneesh Kumar K.V 1001a8d0bb3SGreg Kurz struct V9fsPath { 1012f008a8cSAneesh Kumar K.V uint16_t size; 1022289be19SAneesh Kumar K.V char *data; 1031a8d0bb3SGreg Kurz }; 1042289be19SAneesh Kumar K.V 105cc720ddbSAneesh Kumar K.V typedef union V9fsFidOpenState V9fsFidOpenState; 106cc720ddbSAneesh Kumar K.V 107353ac78dSAneesh Kumar K.V void cred_init(FsCred *); 108353ac78dSAneesh Kumar K.V 10999519f0aSAneesh Kumar K.V struct FileOperations 110353ac78dSAneesh Kumar K.V { 11191cda4e8SGreg Kurz int (*parse_opts)(QemuOpts *, FsDriverEntry *, Error **errp); 11265603a80SGreg Kurz int (*init)(FsContext *, Error **errp); 1131a8d0bb3SGreg Kurz void (*cleanup)(FsContext *); 1142289be19SAneesh Kumar K.V int (*lstat)(FsContext *, V9fsPath *, struct stat *); 1152289be19SAneesh Kumar K.V ssize_t (*readlink)(FsContext *, V9fsPath *, char *, size_t); 1162289be19SAneesh Kumar K.V int (*chmod)(FsContext *, V9fsPath *, FsCred *); 1172289be19SAneesh Kumar K.V int (*chown)(FsContext *, V9fsPath *, FsCred *); 1182289be19SAneesh Kumar K.V int (*mknod)(FsContext *, V9fsPath *, const char *, FsCred *); 1192289be19SAneesh Kumar K.V int (*utimensat)(FsContext *, V9fsPath *, const struct timespec *); 120353ac78dSAneesh Kumar K.V int (*remove)(FsContext *, const char *); 1212289be19SAneesh Kumar K.V int (*symlink)(FsContext *, const char *, V9fsPath *, 1222289be19SAneesh Kumar K.V const char *, FsCred *); 1232289be19SAneesh Kumar K.V int (*link)(FsContext *, V9fsPath *, V9fsPath *, const char *); 124353ac78dSAneesh Kumar K.V int (*setuid)(FsContext *, uid_t); 125cc720ddbSAneesh Kumar K.V int (*close)(FsContext *, V9fsFidOpenState *); 126cc720ddbSAneesh Kumar K.V int (*closedir)(FsContext *, V9fsFidOpenState *); 127cc720ddbSAneesh Kumar K.V int (*opendir)(FsContext *, V9fsPath *, V9fsFidOpenState *); 128cc720ddbSAneesh Kumar K.V int (*open)(FsContext *, V9fsPath *, int, V9fsFidOpenState *); 129cc720ddbSAneesh Kumar K.V int (*open2)(FsContext *, V9fsPath *, const char *, 130cc720ddbSAneesh Kumar K.V int, FsCred *, V9fsFidOpenState *); 131cc720ddbSAneesh Kumar K.V void (*rewinddir)(FsContext *, V9fsFidOpenState *); 132cc720ddbSAneesh Kumar K.V off_t (*telldir)(FsContext *, V9fsFidOpenState *); 133635324e8SGreg Kurz struct dirent * (*readdir)(FsContext *, V9fsFidOpenState *); 134cc720ddbSAneesh Kumar K.V void (*seekdir)(FsContext *, V9fsFidOpenState *, off_t); 135cc720ddbSAneesh Kumar K.V ssize_t (*preadv)(FsContext *, V9fsFidOpenState *, 136cc720ddbSAneesh Kumar K.V const struct iovec *, int, off_t); 137cc720ddbSAneesh Kumar K.V ssize_t (*pwritev)(FsContext *, V9fsFidOpenState *, 138cc720ddbSAneesh Kumar K.V const struct iovec *, int, off_t); 1392289be19SAneesh Kumar K.V int (*mkdir)(FsContext *, V9fsPath *, const char *, FsCred *); 1408b888272SAneesh Kumar K.V int (*fstat)(FsContext *, int, V9fsFidOpenState *, struct stat *); 141353ac78dSAneesh Kumar K.V int (*rename)(FsContext *, const char *, const char *); 1422289be19SAneesh Kumar K.V int (*truncate)(FsContext *, V9fsPath *, off_t); 1438b888272SAneesh Kumar K.V int (*fsync)(FsContext *, int, V9fsFidOpenState *, int); 1442289be19SAneesh Kumar K.V int (*statfs)(FsContext *s, V9fsPath *path, struct statfs *stbuf); 1452289be19SAneesh Kumar K.V ssize_t (*lgetxattr)(FsContext *, V9fsPath *, 146353ac78dSAneesh Kumar K.V const char *, void *, size_t); 1472289be19SAneesh Kumar K.V ssize_t (*llistxattr)(FsContext *, V9fsPath *, void *, size_t); 1482289be19SAneesh Kumar K.V int (*lsetxattr)(FsContext *, V9fsPath *, 149353ac78dSAneesh Kumar K.V const char *, void *, size_t, int); 1502289be19SAneesh Kumar K.V int (*lremovexattr)(FsContext *, V9fsPath *, const char *); 1512289be19SAneesh Kumar K.V int (*name_to_path)(FsContext *, V9fsPath *, const char *, V9fsPath *); 1522289be19SAneesh Kumar K.V int (*renameat)(FsContext *ctx, V9fsPath *olddir, const char *old_name, 1532289be19SAneesh Kumar K.V V9fsPath *newdir, const char *new_name); 1542289be19SAneesh Kumar K.V int (*unlinkat)(FsContext *ctx, V9fsPath *dir, const char *name, int flags); 15599519f0aSAneesh Kumar K.V }; 156353ac78dSAneesh Kumar K.V 157353ac78dSAneesh Kumar K.V #endif 158