Always increment even if the read fails (otherwise we spin if we hit the kernel bug...
[Samba.git] / source / include / vfs.h
blob9ca4bde0c536f0af6ddf106f2976d34c0d447e60
1 /*
2 Unix SMB/Netbios implementation.
3 Version 1.9.
4 VFS structures and parameters
5 Copyright (C) Tim Potter 1999
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 2 of the License, or
10 (at your option) any later version.
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with this program; if not, write to the Free Software
19 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
22 #ifndef _VFS_H
23 #define _VFS_H
25 /* Avoid conflict with an AIX include file */
27 #ifdef vfs_ops
28 #undef vfs_ops
29 #endif
32 * As we're now (thanks Andrew ! :-) using file_structs and connection
33 * structs in the vfs - then anyone writing a vfs must include includes.h...
37 * This next constant specifies the version number of the VFS interface
38 * this smbd will load. Increment this if *ANY* changes are made to the
39 * vfs_ops below. JRA.
42 #define SMB_VFS_INTERFACE_VERSION 1
44 /* VFS operations structure */
46 struct connection_struct;
47 struct files_struct;
48 struct security_descriptor_info;
50 struct vfs_ops {
52 /* Disk operations */
54 int (*connect)(struct connection_struct *conn, char *service, char *user);
55 void (*disconnect)(struct connection_struct *conn);
56 SMB_BIG_UINT (*disk_free)(struct connection_struct *conn, char *path, BOOL small_query, SMB_BIG_UINT *bsize,
57 SMB_BIG_UINT *dfree, SMB_BIG_UINT *dsize);
59 /* Directory operations */
61 DIR *(*opendir)(struct connection_struct *conn, char *fname);
62 struct dirent *(*readdir)(struct connection_struct *conn, DIR *dirp);
63 int (*mkdir)(struct connection_struct *conn, char *path, mode_t mode);
64 int (*rmdir)(struct connection_struct *conn, char *path);
65 int (*closedir)(struct connection_struct *conn, DIR *dir);
67 /* File operations */
69 int (*open)(struct connection_struct *conn, char *fname, int flags, mode_t mode);
70 int (*close)(struct files_struct *fsp, int fd);
71 ssize_t (*read)(struct files_struct *fsp, int fd, char *data, size_t n);
72 ssize_t (*write)(struct files_struct *fsp, int fd, char *data, size_t n);
73 SMB_OFF_T (*lseek)(struct files_struct *fsp, int filedes, SMB_OFF_T offset, int whence);
74 int (*rename)(struct connection_struct *conn, char *old, char *new);
75 int (*fsync)(struct files_struct *fsp, int fd);
76 int (*stat)(struct connection_struct *conn, char *fname, SMB_STRUCT_STAT *sbuf);
77 int (*fstat)(struct files_struct *fsp, int fd, SMB_STRUCT_STAT *sbuf);
78 int (*lstat)(struct connection_struct *conn, char *path, SMB_STRUCT_STAT *sbuf);
79 int (*unlink)(struct connection_struct *conn, char *path);
80 int (*chmod)(struct connection_struct *conn, char *path, mode_t mode);
81 int (*chown)(struct connection_struct *conn, char *path, uid_t uid, gid_t gid);
82 int (*chdir)(struct connection_struct *conn, char *path);
83 char *(*getwd)(struct connection_struct *conn, char *buf);
84 int (*utime)(struct connection_struct *conn, char *path, struct utimbuf *times);
85 int (*ftruncate)(struct files_struct *fsp, int fd, SMB_OFF_T offset);
86 BOOL (*lock)(struct files_struct *fsp, int fd, int op, SMB_OFF_T offset, SMB_OFF_T count, int type);
88 /* NT ACL operations. */
90 size_t (*fget_nt_acl)(struct files_struct *fsp, int fd, struct security_descriptor_info **ppdesc);
91 size_t (*get_nt_acl)(struct files_struct *fsp, char *name, struct security_descriptor_info **ppdesc);
92 BOOL (*fset_nt_acl)(struct files_struct *fsp, int fd, uint32 security_info_sent, struct security_descriptor_info *psd);
93 BOOL (*set_nt_acl)(struct files_struct *fsp, char *name, uint32 security_info_sent, struct security_descriptor_info *psd);
95 /* POSIX ACL operations. */
97 int (*chmod_acl)(struct connection_struct *conn, char *name, mode_t mode);
98 int (*fchmod_acl)(struct files_struct *fsp, int fd, mode_t mode);
102 struct vfs_options {
103 struct vfs_options *prev, *next;
104 char *name;
105 char *value;
108 #endif /* _VFS_H */