forked from cifsd-team/ksmbd
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvfs.h
218 lines (188 loc) · 7.35 KB
/
vfs.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
// SPDX-License-Identifier: GPL-2.0-or-later
/*
* Copyright (C) 2016 Namjae Jeon <[email protected]>
* Copyright (C) 2018 Samsung Electronics Co., Ltd.
*/
#ifndef __CIFSD_VFS_H__
#define __CIFSD_VFS_H__
#include <linux/file.h>
#include <linux/fs.h>
/* CREATION TIME XATTR PREFIX */
#define CREATION_TIME_PREFIX "creation.time."
#define CREATION_TIME_PREFIX_LEN (sizeof(CREATION_TIME_PREFIX) - 1)
#define CREATIOM_TIME_LEN (sizeof(__u64))
#define XATTR_NAME_CREATION_TIME \
(XATTR_USER_PREFIX CREATION_TIME_PREFIX)
#define XATTR_NAME_CREATION_TIME_LEN (sizeof(XATTR_NAME_CREATION_TIME) - 1)
/* STREAM XATTR PREFIX */
#define STREAM_PREFIX "stream."
#define STREAM_PREFIX_LEN (sizeof(STREAM_PREFIX) - 1)
#define XATTR_NAME_STREAM (XATTR_USER_PREFIX STREAM_PREFIX)
#define XATTR_NAME_STREAM_LEN (sizeof(XATTR_NAME_STREAM) - 1)
/* FILE ATTRIBUITE XATTR PREFIX */
#define FILE_ATTRIBUTE_PREFIX "file.attribute."
#define FILE_ATTRIBUTE_PREFIX_LEN (sizeof(FILE_ATTRIBUTE_PREFIX) - 1)
#define FILE_ATTRIBUTE_LEN (sizeof(__u32))
#define XATTR_NAME_FILE_ATTRIBUTE \
(XATTR_USER_PREFIX FILE_ATTRIBUTE_PREFIX)
#define XATTR_NAME_FILE_ATTRIBUTE_LEN \
(sizeof(XATTR_USER_PREFIX FILE_ATTRIBUTE_PREFIX) - 1)
/* CreateOptions */
/* Flag is set, it must not be a file , valid for directory only */
#define FILE_DIRECTORY_FILE_LE cpu_to_le32(0x00000001)
#define FILE_WRITE_THROUGH_LE cpu_to_le32(0x00000002)
#define FILE_SEQUENTIAL_ONLY_LE cpu_to_le32(0x00000004)
/* Should not buffer on server*/
#define FILE_NO_INTERMEDIATE_BUFFERING_LE cpu_to_le32(0x00000008)
/* MBZ */
#define FILE_SYNCHRONOUS_IO_ALERT_LE cpu_to_le32(0x00000010)
/* MBZ */
#define FILE_SYNCHRONOUS_IO_NONALERT_LE cpu_to_le32(0x00000020)
/* Flaf must not be set for directory */
#define FILE_NON_DIRECTORY_FILE_LE cpu_to_le32(0x00000040)
/* Should be zero */
#define CREATE_TREE_CONNECTION cpu_to_le32(0x00000080)
#define FILE_COMPLETE_IF_OPLOCKED_LE cpu_to_le32(0x00000100)
#define FILE_NO_EA_KNOWLEDGE_LE cpu_to_le32(0x00000200)
#define FILE_OPEN_REMOTE_INSTANCE cpu_to_le32(0x00000400)
/**
* Doc says this is obsolete "open for recovery" flag should be zero
* in any case.
*/
#define CREATE_OPEN_FOR_RECOVERY cpu_to_le32(0x00000400)
#define FILE_RANDOM_ACCESS_LE cpu_to_le32(0x00000800)
#define FILE_DELETE_ON_CLOSE_LE cpu_to_le32(0x00001000)
#define FILE_OPEN_BY_FILE_ID_LE cpu_to_le32(0x00002000)
#define FILE_OPEN_FOR_BACKUP_INTENT_LE cpu_to_le32(0x00004000)
#define FILE_NO_COMPRESSION_LE cpu_to_le32(0x00008000)
/* Should be zero*/
#define FILE_OPEN_REQUIRING_OPLOCK cpu_to_le32(0x00010000)
#define FILE_DISALLOW_EXCLUSIVE cpu_to_le32(0x00020000)
#define FILE_RESERVE_OPFILTER_LE cpu_to_le32(0x00100000)
#define FILE_OPEN_REPARSE_POINT_LE cpu_to_le32(0x00200000)
#define FILE_OPEN_NO_RECALL_LE cpu_to_le32(0x00400000)
/* Should be zero */
#define FILE_OPEN_FOR_FREE_SPACE_QUERY_LE cpu_to_le32(0x00800000)
#define CREATE_OPTIONS_MASK cpu_to_le32(0x00FFFFFF)
#define CREATE_OPTION_READONLY 0x10000000
/* system. NB not sent over wire */
#define CREATE_OPTION_SPECIAL 0x20000000
struct cifsd_work;
struct cifsd_file;
struct cifsd_dir_info {
char *name;
char *bufptr;
bool hide_dot_file;
int out_buf_len;
int num_entry;
int data_count;
int last_entry_offset;
};
struct cifsd_readdir_data {
struct dir_context ctx;
char *dirent;
unsigned int used;
unsigned int full;
unsigned int dirent_count;
unsigned int file_attr;
};
struct cifsd_dirent {
__le64 ino;
__le64 offset;
__le32 namelen;
__le32 d_type;
char name[];
};
/* cifsd kstat wrapper to get valid create time when reading dir entry */
struct cifsd_kstat {
struct kstat *kstat;
__u64 create_time;
__le32 file_attributes;
};
struct cifsd_fs_sector_size {
unsigned short logical_sector_size;
unsigned int physical_sector_size;
unsigned int optimal_io_size;
};
int cifsd_vfs_create(struct cifsd_work *work, const char *name, umode_t mode);
int cifsd_vfs_mkdir(struct cifsd_work *work, const char *name, umode_t mode);
int cifsd_vfs_read(struct cifsd_work *work, struct cifsd_file *fp,
size_t count, loff_t *pos);
int cifsd_vfs_write(struct cifsd_work *work, struct cifsd_file *fp,
char *buf, size_t count, loff_t *pos, bool sync, ssize_t *written);
int cifsd_vfs_getattr(struct cifsd_work *work, uint64_t fid,
struct kstat *stat);
int cifsd_vfs_setattr(struct cifsd_work *work, const char *name,
uint64_t fid, struct iattr *attrs);
int cifsd_vfs_fsync(struct cifsd_work *work, uint64_t fid, uint64_t p_id);
int cifsd_vfs_remove_file(char *name);
int cifsd_vfs_link(const char *oldname, const char *newname);
int cifsd_vfs_symlink(const char *name, const char *symname);
int cifsd_vfs_readlink(struct path *path, char *buf, int lenp);
int cifsd_vfs_rename(char *abs_oldname, char *abs_newname,
struct cifsd_file *fp);
int cifsd_vfs_truncate(struct cifsd_work *work, const char *name,
struct cifsd_file *fp, loff_t size);
struct srv_copychunk;
int cifsd_vfs_copy_file_ranges(struct cifsd_work *work,
struct cifsd_file *src_fp,
struct cifsd_file *dst_fp,
struct srv_copychunk *chunks,
unsigned int chunk_count,
unsigned int *chunk_count_written,
unsigned int *chunk_size_written,
loff_t *total_size_written);
struct cifsd_file *cifsd_vfs_dentry_open(struct cifsd_work *work,
const struct path *path,
int flags,
int option,
int fexist);
ssize_t cifsd_vfs_listxattr(struct dentry *dentry, char **list, int size);
ssize_t cifsd_vfs_getxattr(struct dentry *dentry,
char *xattr_name,
char **xattr_buf);
ssize_t cifsd_vfs_casexattr_len(struct dentry *dentry,
char *attr_name,
int attr_name_len);
int cifsd_vfs_setxattr(struct dentry *dentry,
const char *attr_name,
const void *attr_value,
size_t attr_size,
int flags);
int cifsd_vfs_fsetxattr(const char *filename,
const char *attr_name,
const void *attr_value,
size_t attr_size,
int flags);
int cifsd_vfs_xattr_stream_name(char *stream_name,
char **xattr_stream_name);
int cifsd_vfs_truncate_xattr(struct dentry *dentry, int wo_streams);
int cifsd_vfs_remove_xattr(struct dentry *dentry, char *attr_name);
int cifsd_vfs_kern_path(char *name, unsigned int flags, struct path *path,
bool caseless);
bool cifsd_vfs_empty_dir(struct cifsd_file *fp);
void cifsd_vfs_set_fadvise(struct file *filp, int option);
int cifsd_vfs_lock(struct file *filp, int cmd, struct file_lock *flock);
int cifsd_vfs_readdir(struct file *file, struct cifsd_readdir_data *rdata);
int cifsd_vfs_alloc_size(struct cifsd_work *work,
struct cifsd_file *fp,
loff_t len);
int cifsd_vfs_zero_data(struct cifsd_work *work,
struct cifsd_file *fp,
loff_t off,
loff_t len,
bool is_sparse);
int cifsd_vfs_unlink(struct dentry *dir, struct dentry *dentry);
unsigned short cifsd_vfs_logical_sector_size(struct inode *inode);
void cifsd_vfs_smb2_sector_size(struct inode *inode,
struct cifsd_fs_sector_size *fs_ss);
bool cifsd_vfs_empty_dir(struct cifsd_file *fp);
char *cifsd_vfs_readdir_name(struct cifsd_work *work,
struct cifsd_kstat *cifsd_kstat,
struct cifsd_dirent *de,
char *dirpath);
void *cifsd_vfs_init_kstat(char **p, struct cifsd_kstat *cifsd_kstat);
int cifsd_vfs_posix_lock_wait(struct file_lock *flock);
int cifsd_vfs_posix_lock_wait_timeout(struct file_lock *flock, long timeout);
void cifsd_vfs_posix_lock_unblock(struct file_lock *flock);
#endif /* __CIFSD_VFS_H__ */