2 * Time auditing VFS module for samba. Log time taken for VFS call to syslog
5 * Copyright (C) Abhidnya Chirmule <achirmul@in.ibm.com> 2009
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 3 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, see <http://www.gnu.org/licenses/>.
22 * This module implements logging for time taken for all Samba VFS operations.
24 * vfs objects = time_audit
31 #define DBGC_CLASS DBGC_VFS
33 static double audit_timeout;
35 static void smb_time_audit_log(const char *syscallname, double elapsed)
37 DEBUG(0, ("WARNING: System call \"%s\" took unexpectedly long "
38 "(%.2f seconds) -- Validate that file and storage "
39 "subsystems are operating normally\n", syscallname,
43 static int smb_time_audit_connect(vfs_handle_struct *handle,
44 const char *svc, const char *user)
55 result = SMB_VFS_NEXT_CONNECT(handle, svc, user);
56 timediff = timeval_elapsed(&tv);
57 if (timediff > audit_timeout) {
58 smb_time_audit_log("connect", timediff);
63 static void smb_time_audit_disconnect(vfs_handle_struct *handle)
69 SMB_VFS_NEXT_DISCONNECT(handle);
70 timediff = timeval_elapsed(&tv);
72 if (timediff > audit_timeout) {
73 smb_time_audit_log("disconnect", timediff);
79 static uint64_t smb_time_audit_disk_free(vfs_handle_struct *handle,
81 bool small_query, uint64_t *bsize,
82 uint64_t *dfree, uint64_t *dsize)
89 result = SMB_VFS_NEXT_DISK_FREE(handle, path, small_query, bsize,
91 timediff = timeval_elapsed(&tv);
93 /* Don't have a reasonable notion of failure here */
94 if (timediff > audit_timeout) {
95 smb_time_audit_log("disk_free", timediff);
101 static int smb_time_audit_get_quota(struct vfs_handle_struct *handle,
102 enum SMB_QUOTA_TYPE qtype, unid_t id,
110 result = SMB_VFS_NEXT_GET_QUOTA(handle, qtype, id, qt);
111 timediff = timeval_elapsed(&tv);
113 if (timediff > audit_timeout) {
114 smb_time_audit_log("get_quota", timediff);
119 static int smb_time_audit_set_quota(struct vfs_handle_struct *handle,
120 enum SMB_QUOTA_TYPE qtype, unid_t id,
128 result = SMB_VFS_NEXT_SET_QUOTA(handle, qtype, id, qt);
129 timediff = timeval_elapsed(&tv);
131 if (timediff > audit_timeout) {
132 smb_time_audit_log("set_quota", timediff);
138 static int smb_time_audit_get_shadow_copy_data(struct vfs_handle_struct *handle,
139 struct files_struct *fsp,
140 SHADOW_COPY_DATA *shadow_copy_data,
148 result = SMB_VFS_NEXT_GET_SHADOW_COPY_DATA(handle, fsp,
149 shadow_copy_data, labels);
150 timediff = timeval_elapsed(&tv);
152 if (timediff > audit_timeout) {
153 smb_time_audit_log("get_shadow_copy_data", timediff);
159 static int smb_time_audit_statvfs(struct vfs_handle_struct *handle,
161 struct vfs_statvfs_struct *statbuf)
168 result = SMB_VFS_NEXT_STATVFS(handle, path, statbuf);
169 timediff = timeval_elapsed(&tv);
171 if (timediff > audit_timeout) {
172 smb_time_audit_log("statvfs", timediff);
178 static uint32_t smb_time_audit_fs_capabilities(struct vfs_handle_struct *handle,
179 enum timestamp_set_resolution *p_ts_res)
186 result = SMB_VFS_NEXT_FS_CAPABILITIES(handle, p_ts_res);
187 timediff = timeval_elapsed(&tv);
189 if (timediff > audit_timeout) {
190 smb_time_audit_log("fs_capabilities", timediff);
196 static SMB_STRUCT_DIR *smb_time_audit_opendir(vfs_handle_struct *handle,
198 const char *mask, uint32 attr)
200 SMB_STRUCT_DIR *result;
205 result = SMB_VFS_NEXT_OPENDIR(handle, fname, mask, attr);
206 timediff = timeval_elapsed(&tv);
208 if (timediff > audit_timeout) {
209 smb_time_audit_log("opendir", timediff);
215 static SMB_STRUCT_DIRENT *smb_time_audit_readdir(vfs_handle_struct *handle,
216 SMB_STRUCT_DIR *dirp,
217 SMB_STRUCT_STAT *sbuf)
219 SMB_STRUCT_DIRENT *result;
224 result = SMB_VFS_NEXT_READDIR(handle, dirp, sbuf);
225 timediff = timeval_elapsed(&tv);
227 if (timediff > audit_timeout) {
228 smb_time_audit_log("readdir", timediff);
234 static void smb_time_audit_seekdir(vfs_handle_struct *handle,
235 SMB_STRUCT_DIR *dirp, long offset)
241 SMB_VFS_NEXT_SEEKDIR(handle, dirp, offset);
242 timediff = timeval_elapsed(&tv);
244 if (timediff > audit_timeout) {
245 smb_time_audit_log("seekdir", timediff);
251 static long smb_time_audit_telldir(vfs_handle_struct *handle,
252 SMB_STRUCT_DIR *dirp)
259 result = SMB_VFS_NEXT_TELLDIR(handle, dirp);
260 timediff = timeval_elapsed(&tv);
262 if (timediff > audit_timeout) {
263 smb_time_audit_log("telldir", timediff);
269 static void smb_time_audit_rewinddir(vfs_handle_struct *handle,
270 SMB_STRUCT_DIR *dirp)
276 SMB_VFS_NEXT_REWINDDIR(handle, dirp);
277 timediff = timeval_elapsed(&tv);
279 if (timediff > audit_timeout) {
280 smb_time_audit_log("rewinddir", timediff);
286 static int smb_time_audit_mkdir(vfs_handle_struct *handle,
287 const char *path, mode_t mode)
294 result = SMB_VFS_NEXT_MKDIR(handle, path, mode);
295 timediff = timeval_elapsed(&tv);
297 if (timediff > audit_timeout) {
298 smb_time_audit_log("mkdir", timediff);
304 static int smb_time_audit_rmdir(vfs_handle_struct *handle,
312 result = SMB_VFS_NEXT_RMDIR(handle, path);
313 timediff = timeval_elapsed(&tv);
315 if (timediff > audit_timeout) {
316 smb_time_audit_log("rmdir", timediff);
322 static int smb_time_audit_closedir(vfs_handle_struct *handle,
323 SMB_STRUCT_DIR *dirp)
330 result = SMB_VFS_NEXT_CLOSEDIR(handle, dirp);
331 timediff = timeval_elapsed(&tv);
333 if (timediff > audit_timeout) {
334 smb_time_audit_log("closedir", timediff);
340 static void smb_time_audit_init_search_op(vfs_handle_struct *handle,
341 SMB_STRUCT_DIR *dirp)
347 SMB_VFS_NEXT_INIT_SEARCH_OP(handle, dirp);
348 timediff = timeval_elapsed(&tv);
350 if (timediff > audit_timeout) {
351 smb_time_audit_log("init_search_op", timediff);
356 static int smb_time_audit_open(vfs_handle_struct *handle,
357 struct smb_filename *fname,
359 int flags, mode_t mode)
366 result = SMB_VFS_NEXT_OPEN(handle, fname, fsp, flags, mode);
367 timediff = timeval_elapsed(&tv);
369 if (timediff > audit_timeout) {
370 smb_time_audit_log("open", timediff);
376 static NTSTATUS smb_time_audit_create_file(vfs_handle_struct *handle,
377 struct smb_request *req,
378 uint16_t root_dir_fid,
379 struct smb_filename *fname,
380 uint32_t access_mask,
381 uint32_t share_access,
382 uint32_t create_disposition,
383 uint32_t create_options,
384 uint32_t file_attributes,
385 uint32_t oplock_request,
386 uint64_t allocation_size,
387 uint32_t private_flags,
388 struct security_descriptor *sd,
389 struct ea_list *ea_list,
390 files_struct **result_fsp,
398 result = SMB_VFS_NEXT_CREATE_FILE(
401 root_dir_fid, /* root_dir_fid */
403 access_mask, /* access_mask */
404 share_access, /* share_access */
405 create_disposition, /* create_disposition*/
406 create_options, /* create_options */
407 file_attributes, /* file_attributes */
408 oplock_request, /* oplock_request */
409 allocation_size, /* allocation_size */
412 ea_list, /* ea_list */
413 result_fsp, /* result */
415 timediff = timeval_elapsed(&tv);
417 if (timediff > audit_timeout) {
418 smb_time_audit_log("create_file", timediff);
424 static int smb_time_audit_close(vfs_handle_struct *handle, files_struct *fsp)
431 result = SMB_VFS_NEXT_CLOSE(handle, fsp);
432 timediff = timeval_elapsed(&tv);
434 if (timediff > audit_timeout) {
435 smb_time_audit_log("close", timediff);
441 static ssize_t smb_time_audit_read(vfs_handle_struct *handle,
442 files_struct *fsp, void *data, size_t n)
449 result = SMB_VFS_NEXT_READ(handle, fsp, data, n);
450 timediff = timeval_elapsed(&tv);
452 if (timediff > audit_timeout) {
453 smb_time_audit_log("read", timediff);
459 static ssize_t smb_time_audit_pread(vfs_handle_struct *handle,
461 void *data, size_t n, SMB_OFF_T offset)
468 result = SMB_VFS_NEXT_PREAD(handle, fsp, data, n, offset);
469 timediff = timeval_elapsed(&tv);
471 if (timediff > audit_timeout) {
472 smb_time_audit_log("pread", timediff);
478 static ssize_t smb_time_audit_write(vfs_handle_struct *handle,
480 const void *data, size_t n)
487 result = SMB_VFS_NEXT_WRITE(handle, fsp, data, n);
488 timediff = timeval_elapsed(&tv);
490 if (timediff > audit_timeout) {
491 smb_time_audit_log("write", timediff);
497 static ssize_t smb_time_audit_pwrite(vfs_handle_struct *handle,
499 const void *data, size_t n,
507 result = SMB_VFS_NEXT_PWRITE(handle, fsp, data, n, offset);
508 timediff = timeval_elapsed(&tv);
510 if (timediff > audit_timeout) {
511 smb_time_audit_log("pwrite", timediff);
517 static SMB_OFF_T smb_time_audit_lseek(vfs_handle_struct *handle,
519 SMB_OFF_T offset, int whence)
526 result = SMB_VFS_NEXT_LSEEK(handle, fsp, offset, whence);
527 timediff = timeval_elapsed(&tv);
529 if (timediff > audit_timeout) {
530 smb_time_audit_log("lseek", timediff);
536 static ssize_t smb_time_audit_sendfile(vfs_handle_struct *handle, int tofd,
537 files_struct *fromfsp,
538 const DATA_BLOB *hdr, SMB_OFF_T offset,
546 result = SMB_VFS_NEXT_SENDFILE(handle, tofd, fromfsp, hdr, offset, n);
547 timediff = timeval_elapsed(&tv);
549 if (timediff > audit_timeout) {
550 smb_time_audit_log("sendfile", timediff);
556 static ssize_t smb_time_audit_recvfile(vfs_handle_struct *handle, int fromfd,
566 result = SMB_VFS_NEXT_RECVFILE(handle, fromfd, tofsp, offset, n);
567 timediff = timeval_elapsed(&tv);
569 if (timediff > audit_timeout) {
570 smb_time_audit_log("recvfile", timediff);
576 static int smb_time_audit_rename(vfs_handle_struct *handle,
577 const struct smb_filename *oldname,
578 const struct smb_filename *newname)
585 result = SMB_VFS_NEXT_RENAME(handle, oldname, newname);
586 timediff = timeval_elapsed(&tv);
588 if (timediff > audit_timeout) {
589 smb_time_audit_log("rename", timediff);
595 static int smb_time_audit_fsync(vfs_handle_struct *handle, files_struct *fsp)
602 result = SMB_VFS_NEXT_FSYNC(handle, fsp);
603 timediff = timeval_elapsed(&tv);
605 if (timediff > audit_timeout) {
606 smb_time_audit_log("fsync", timediff);
612 static int smb_time_audit_stat(vfs_handle_struct *handle,
613 struct smb_filename *fname)
620 result = SMB_VFS_NEXT_STAT(handle, fname);
621 timediff = timeval_elapsed(&tv);
623 if (timediff > audit_timeout) {
624 smb_time_audit_log("stat", timediff);
630 static int smb_time_audit_fstat(vfs_handle_struct *handle, files_struct *fsp,
631 SMB_STRUCT_STAT *sbuf)
638 result = SMB_VFS_NEXT_FSTAT(handle, fsp, sbuf);
639 timediff = timeval_elapsed(&tv);
641 if (timediff > audit_timeout) {
642 smb_time_audit_log("fstat", timediff);
648 static int smb_time_audit_lstat(vfs_handle_struct *handle,
649 struct smb_filename *path)
656 result = SMB_VFS_NEXT_LSTAT(handle, path);
657 timediff = timeval_elapsed(&tv);
659 if (timediff > audit_timeout) {
660 smb_time_audit_log("lstat", timediff);
666 static uint64_t smb_time_audit_get_alloc_size(vfs_handle_struct *handle,
668 const SMB_STRUCT_STAT *sbuf)
675 result = SMB_VFS_NEXT_GET_ALLOC_SIZE(handle, fsp, sbuf);
676 timediff = timeval_elapsed(&tv);
678 if (timediff > audit_timeout) {
679 smb_time_audit_log("get_alloc_size", timediff);
685 static int smb_time_audit_unlink(vfs_handle_struct *handle,
686 const struct smb_filename *path)
693 result = SMB_VFS_NEXT_UNLINK(handle, path);
694 timediff = timeval_elapsed(&tv);
696 if (timediff > audit_timeout) {
697 smb_time_audit_log("unlink", timediff);
703 static int smb_time_audit_chmod(vfs_handle_struct *handle,
704 const char *path, mode_t mode)
711 result = SMB_VFS_NEXT_CHMOD(handle, path, mode);
712 timediff = timeval_elapsed(&tv);
714 if (timediff > audit_timeout) {
715 smb_time_audit_log("chmod", timediff);
721 static int smb_time_audit_fchmod(vfs_handle_struct *handle, files_struct *fsp,
729 result = SMB_VFS_NEXT_FCHMOD(handle, fsp, mode);
730 timediff = timeval_elapsed(&tv);
732 if (timediff > audit_timeout) {
733 smb_time_audit_log("fchmod", timediff);
739 static int smb_time_audit_chown(vfs_handle_struct *handle,
740 const char *path, uid_t uid, gid_t gid)
747 result = SMB_VFS_NEXT_CHOWN(handle, path, uid, gid);
748 timediff = timeval_elapsed(&tv);
750 if (timediff > audit_timeout) {
751 smb_time_audit_log("chown", timediff);
757 static int smb_time_audit_fchown(vfs_handle_struct *handle, files_struct *fsp,
758 uid_t uid, gid_t gid)
765 result = SMB_VFS_NEXT_FCHOWN(handle, fsp, uid, gid);
766 timediff = timeval_elapsed(&tv);
768 if (timediff > audit_timeout) {
769 smb_time_audit_log("fchown", timediff);
775 static int smb_time_audit_lchown(vfs_handle_struct *handle,
776 const char *path, uid_t uid, gid_t gid)
783 result = SMB_VFS_NEXT_LCHOWN(handle, path, uid, gid);
784 timediff = timeval_elapsed(&tv);
786 if (timediff > audit_timeout) {
787 smb_time_audit_log("lchown", timediff);
793 static int smb_time_audit_chdir(vfs_handle_struct *handle, const char *path)
800 result = SMB_VFS_NEXT_CHDIR(handle, path);
801 timediff = timeval_elapsed(&tv);
803 if (timediff > audit_timeout) {
804 smb_time_audit_log("chdir", timediff);
810 static char *smb_time_audit_getwd(vfs_handle_struct *handle, char *path)
817 result = SMB_VFS_NEXT_GETWD(handle, path);
818 timediff = timeval_elapsed(&tv);
820 if (timediff > audit_timeout) {
821 smb_time_audit_log("getwd", timediff);
827 static int smb_time_audit_ntimes(vfs_handle_struct *handle,
828 const struct smb_filename *path,
829 struct smb_file_time *ft)
836 result = SMB_VFS_NEXT_NTIMES(handle, path, ft);
837 timediff = timeval_elapsed(&tv);
839 if (timediff > audit_timeout) {
840 smb_time_audit_log("ntimes", timediff);
846 static int smb_time_audit_ftruncate(vfs_handle_struct *handle,
855 result = SMB_VFS_NEXT_FTRUNCATE(handle, fsp, len);
856 timediff = timeval_elapsed(&tv);
858 if (timediff > audit_timeout) {
859 smb_time_audit_log("ftruncate", timediff);
865 static bool smb_time_audit_lock(vfs_handle_struct *handle, files_struct *fsp,
866 int op, SMB_OFF_T offset, SMB_OFF_T count,
874 result = SMB_VFS_NEXT_LOCK(handle, fsp, op, offset, count, type);
875 timediff = timeval_elapsed(&tv);
877 if (timediff > audit_timeout) {
878 smb_time_audit_log("lock", timediff);
884 static int smb_time_audit_kernel_flock(struct vfs_handle_struct *handle,
885 struct files_struct *fsp,
886 uint32 share_mode, uint32 access_mask)
893 result = SMB_VFS_NEXT_KERNEL_FLOCK(handle, fsp, share_mode,
895 timediff = timeval_elapsed(&tv);
897 if (timediff > audit_timeout) {
898 smb_time_audit_log("kernel_flock", timediff);
904 static int smb_time_audit_linux_setlease(vfs_handle_struct *handle,
913 result = SMB_VFS_NEXT_LINUX_SETLEASE(handle, fsp, leasetype);
914 timediff = timeval_elapsed(&tv);
916 if (timediff > audit_timeout) {
917 smb_time_audit_log("linux_setlease", timediff);
923 static bool smb_time_audit_getlock(vfs_handle_struct *handle,
925 SMB_OFF_T *poffset, SMB_OFF_T *pcount,
926 int *ptype, pid_t *ppid)
933 result = SMB_VFS_NEXT_GETLOCK(handle, fsp, poffset, pcount, ptype,
935 timediff = timeval_elapsed(&tv);
937 if (timediff > audit_timeout) {
938 smb_time_audit_log("getlock", timediff);
944 static int smb_time_audit_symlink(vfs_handle_struct *handle,
945 const char *oldpath, const char *newpath)
952 result = SMB_VFS_NEXT_SYMLINK(handle, oldpath, newpath);
953 timediff = timeval_elapsed(&tv);
955 if (timediff > audit_timeout) {
956 smb_time_audit_log("symlink", timediff);
962 static int smb_time_audit_readlink(vfs_handle_struct *handle,
963 const char *path, char *buf, size_t bufsiz)
970 result = SMB_VFS_NEXT_READLINK(handle, path, buf, bufsiz);
971 timediff = timeval_elapsed(&tv);
973 if (timediff > audit_timeout) {
974 smb_time_audit_log("readlink", timediff);
980 static int smb_time_audit_link(vfs_handle_struct *handle,
981 const char *oldpath, const char *newpath)
988 result = SMB_VFS_NEXT_LINK(handle, oldpath, newpath);
989 timediff = timeval_elapsed(&tv);
991 if (timediff > audit_timeout) {
992 smb_time_audit_log("link", timediff);
998 static int smb_time_audit_mknod(vfs_handle_struct *handle,
999 const char *pathname, mode_t mode,
1007 result = SMB_VFS_NEXT_MKNOD(handle, pathname, mode, dev);
1008 timediff = timeval_elapsed(&tv);
1010 if (timediff > audit_timeout) {
1011 smb_time_audit_log("mknod", timediff);
1017 static char *smb_time_audit_realpath(vfs_handle_struct *handle,
1018 const char *path, char *resolved_path)
1025 result = SMB_VFS_NEXT_REALPATH(handle, path, resolved_path);
1026 timediff = timeval_elapsed(&tv);
1028 if (timediff > audit_timeout) {
1029 smb_time_audit_log("realpath", timediff);
1035 static NTSTATUS smb_time_audit_notify_watch(struct vfs_handle_struct *handle,
1036 struct sys_notify_context *ctx,
1037 struct notify_entry *e,
1038 void (*callback)(struct sys_notify_context *ctx,
1040 struct notify_event *ev),
1041 void *private_data, void *handle_p)
1048 result = SMB_VFS_NEXT_NOTIFY_WATCH(handle, ctx, e, callback,
1049 private_data, handle_p);
1050 timediff = timeval_elapsed(&tv);
1052 if (timediff > audit_timeout) {
1053 smb_time_audit_log("notify_watch", timediff);
1059 static int smb_time_audit_chflags(vfs_handle_struct *handle,
1060 const char *path, unsigned int flags)
1067 result = SMB_VFS_NEXT_CHFLAGS(handle, path, flags);
1068 timediff = timeval_elapsed(&tv);
1070 if (timediff > audit_timeout) {
1071 smb_time_audit_log("chflags", timediff);
1077 static struct file_id smb_time_audit_file_id_create(struct vfs_handle_struct *handle,
1078 const SMB_STRUCT_STAT *sbuf)
1080 struct file_id id_zero;
1081 struct file_id result;
1085 ZERO_STRUCT(id_zero);
1088 result = SMB_VFS_NEXT_FILE_ID_CREATE(handle, sbuf);
1089 timediff = timeval_elapsed(&tv);
1091 if (timediff > audit_timeout) {
1092 smb_time_audit_log("file_id_create", timediff);
1098 static NTSTATUS smb_time_audit_streaminfo(vfs_handle_struct *handle,
1099 struct files_struct *fsp,
1101 TALLOC_CTX *mem_ctx,
1102 unsigned int *pnum_streams,
1103 struct stream_struct **pstreams)
1110 result = SMB_VFS_NEXT_STREAMINFO(handle, fsp, fname, mem_ctx,
1111 pnum_streams, pstreams);
1112 timediff = timeval_elapsed(&tv);
1114 if (timediff > audit_timeout) {
1115 smb_time_audit_log("streaminfo", timediff);
1121 static int smb_time_audit_get_real_filename(struct vfs_handle_struct *handle,
1124 TALLOC_CTX *mem_ctx,
1132 result = SMB_VFS_NEXT_GET_REAL_FILENAME(handle, path, name, mem_ctx,
1134 timediff = timeval_elapsed(&tv);
1136 if (timediff > audit_timeout) {
1137 smb_time_audit_log("get_real_filename", timediff);
1143 static const char *smb_time_audit_connectpath(vfs_handle_struct *handle,
1151 result = SMB_VFS_NEXT_CONNECTPATH(handle, fname);
1152 timediff = timeval_elapsed(&tv);
1154 if (timediff > audit_timeout) {
1155 smb_time_audit_log("connectpath", timediff);
1161 static NTSTATUS smb_time_audit_brl_lock_windows(struct vfs_handle_struct *handle,
1162 struct byte_range_lock *br_lck,
1163 struct lock_struct *plock,
1165 struct blocking_lock_record *blr)
1172 result = SMB_VFS_NEXT_BRL_LOCK_WINDOWS(handle, br_lck, plock,
1173 blocking_lock, blr);
1174 timediff = timeval_elapsed(&tv);
1176 if (timediff > audit_timeout) {
1177 smb_time_audit_log("brl_lock_windows", timediff);
1183 static bool smb_time_audit_brl_unlock_windows(struct vfs_handle_struct *handle,
1184 struct messaging_context *msg_ctx,
1185 struct byte_range_lock *br_lck,
1186 const struct lock_struct *plock)
1193 result = SMB_VFS_NEXT_BRL_UNLOCK_WINDOWS(handle, msg_ctx, br_lck,
1195 timediff = timeval_elapsed(&tv);
1197 if (timediff > audit_timeout) {
1198 smb_time_audit_log("brl_unlock_windows", timediff);
1204 static bool smb_time_audit_brl_cancel_windows(struct vfs_handle_struct *handle,
1205 struct byte_range_lock *br_lck,
1206 struct lock_struct *plock,
1207 struct blocking_lock_record *blr)
1214 result = SMB_VFS_NEXT_BRL_CANCEL_WINDOWS(handle, br_lck, plock, blr);
1215 timediff = timeval_elapsed(&tv);
1217 if (timediff > audit_timeout) {
1218 smb_time_audit_log("brl_cancel_windows", timediff);
1224 static bool smb_time_audit_strict_lock(struct vfs_handle_struct *handle,
1225 struct files_struct *fsp,
1226 struct lock_struct *plock)
1233 result = SMB_VFS_NEXT_STRICT_LOCK(handle, fsp, plock);
1234 timediff = timeval_elapsed(&tv);
1236 if (timediff > audit_timeout) {
1237 smb_time_audit_log("strict_lock", timediff);
1243 static void smb_time_audit_strict_unlock(struct vfs_handle_struct *handle,
1244 struct files_struct *fsp,
1245 struct lock_struct *plock)
1251 SMB_VFS_NEXT_STRICT_UNLOCK(handle, fsp, plock);
1252 timediff = timeval_elapsed(&tv);
1254 if (timediff > audit_timeout) {
1255 smb_time_audit_log("strict_unlock", timediff);
1261 static NTSTATUS smb_time_audit_translate_name(struct vfs_handle_struct *handle,
1263 enum vfs_translate_direction direction,
1264 TALLOC_CTX *mem_ctx,
1272 result = SMB_VFS_NEXT_TRANSLATE_NAME(handle, name, direction, mem_ctx,
1274 timediff = timeval_elapsed(&tv);
1276 if (timediff > audit_timeout) {
1277 smb_time_audit_log("translate_name", timediff);
1283 static NTSTATUS smb_time_audit_fget_nt_acl(vfs_handle_struct *handle,
1285 uint32 security_info,
1286 struct security_descriptor **ppdesc)
1293 result = SMB_VFS_NEXT_FGET_NT_ACL(handle, fsp, security_info, ppdesc);
1294 timediff = timeval_elapsed(&tv);
1296 if (timediff > audit_timeout) {
1297 smb_time_audit_log("fget_nt_acl", timediff);
1303 static NTSTATUS smb_time_audit_get_nt_acl(vfs_handle_struct *handle,
1305 uint32 security_info,
1306 struct security_descriptor **ppdesc)
1313 result = SMB_VFS_NEXT_GET_NT_ACL(handle, name, security_info, ppdesc);
1314 timediff = timeval_elapsed(&tv);
1316 if (timediff > audit_timeout) {
1317 smb_time_audit_log("get_nt_acl", timediff);
1323 static NTSTATUS smb_time_audit_fset_nt_acl(vfs_handle_struct *handle,
1325 uint32 security_info_sent,
1326 const struct security_descriptor *psd)
1333 result = SMB_VFS_NEXT_FSET_NT_ACL(handle, fsp, security_info_sent,
1335 timediff = timeval_elapsed(&tv);
1337 if (timediff > audit_timeout) {
1338 smb_time_audit_log("fset_nt_acl", timediff);
1344 static int smb_time_audit_chmod_acl(vfs_handle_struct *handle,
1345 const char *path, mode_t mode)
1352 result = SMB_VFS_NEXT_CHMOD_ACL(handle, path, mode);
1353 timediff = timeval_elapsed(&tv);
1355 if (timediff > audit_timeout) {
1356 smb_time_audit_log("chmod_acl", timediff);
1362 static int smb_time_audit_fchmod_acl(vfs_handle_struct *handle,
1363 files_struct *fsp, mode_t mode)
1370 result = SMB_VFS_NEXT_FCHMOD_ACL(handle, fsp, mode);
1371 timediff = timeval_elapsed(&tv);
1373 if (timediff > audit_timeout) {
1374 smb_time_audit_log("fchmod_acl", timediff);
1380 static int smb_time_audit_sys_acl_get_entry(vfs_handle_struct *handle,
1381 SMB_ACL_T theacl, int entry_id,
1382 SMB_ACL_ENTRY_T *entry_p)
1389 result = SMB_VFS_NEXT_SYS_ACL_GET_ENTRY(handle, theacl, entry_id,
1391 timediff = timeval_elapsed(&tv);
1393 if (timediff > audit_timeout) {
1394 smb_time_audit_log("sys_acl_get_entry", timediff);
1400 static int smb_time_audit_sys_acl_get_tag_type(vfs_handle_struct *handle,
1401 SMB_ACL_ENTRY_T entry_d,
1402 SMB_ACL_TAG_T *tag_type_p)
1409 result = SMB_VFS_NEXT_SYS_ACL_GET_TAG_TYPE(handle, entry_d,
1411 timediff = timeval_elapsed(&tv);
1413 if (timediff > audit_timeout) {
1414 smb_time_audit_log("sys_acl_get_tag_type", timediff);
1420 static int smb_time_audit_sys_acl_get_permset(vfs_handle_struct *handle,
1421 SMB_ACL_ENTRY_T entry_d,
1422 SMB_ACL_PERMSET_T *permset_p)
1429 result = SMB_VFS_NEXT_SYS_ACL_GET_PERMSET(handle, entry_d,
1431 timediff = timeval_elapsed(&tv);
1433 if (timediff > audit_timeout) {
1434 smb_time_audit_log("sys_acl_get_permset", timediff);
1440 static void * smb_time_audit_sys_acl_get_qualifier(vfs_handle_struct *handle,
1441 SMB_ACL_ENTRY_T entry_d)
1448 result = SMB_VFS_NEXT_SYS_ACL_GET_QUALIFIER(handle, entry_d);
1449 timediff = timeval_elapsed(&tv);
1451 if (timediff > audit_timeout) {
1452 smb_time_audit_log("sys_acl_get_qualifier", timediff);
1458 static SMB_ACL_T smb_time_audit_sys_acl_get_file(vfs_handle_struct *handle,
1460 SMB_ACL_TYPE_T type)
1467 result = SMB_VFS_NEXT_SYS_ACL_GET_FILE(handle, path_p, type);
1468 timediff = timeval_elapsed(&tv);
1470 if (timediff > audit_timeout) {
1471 smb_time_audit_log("sys_acl_get_file", timediff);
1477 static SMB_ACL_T smb_time_audit_sys_acl_get_fd(vfs_handle_struct *handle,
1485 result = SMB_VFS_NEXT_SYS_ACL_GET_FD(handle, fsp);
1486 timediff = timeval_elapsed(&tv);
1488 if (timediff > audit_timeout) {
1489 smb_time_audit_log("sys_acl_get_fd", timediff);
1495 static int smb_time_audit_sys_acl_clear_perms(vfs_handle_struct *handle,
1496 SMB_ACL_PERMSET_T permset)
1503 result = SMB_VFS_NEXT_SYS_ACL_CLEAR_PERMS(handle, permset);
1504 timediff = timeval_elapsed(&tv);
1506 if (timediff > audit_timeout) {
1507 smb_time_audit_log("sys_acl_clear_perms", timediff);
1513 static int smb_time_audit_sys_acl_add_perm(vfs_handle_struct *handle,
1514 SMB_ACL_PERMSET_T permset,
1515 SMB_ACL_PERM_T perm)
1522 result = SMB_VFS_NEXT_SYS_ACL_ADD_PERM(handle, permset, perm);
1523 timediff = timeval_elapsed(&tv);
1525 if (timediff > audit_timeout) {
1526 smb_time_audit_log("sys_acl_add_perm", timediff);
1532 static char * smb_time_audit_sys_acl_to_text(vfs_handle_struct *handle,
1541 result = SMB_VFS_NEXT_SYS_ACL_TO_TEXT(handle, theacl, plen);
1542 timediff = timeval_elapsed(&tv);
1544 if (timediff > audit_timeout) {
1545 smb_time_audit_log("sys_acl_to_text", timediff);
1551 static SMB_ACL_T smb_time_audit_sys_acl_init(vfs_handle_struct *handle,
1559 result = SMB_VFS_NEXT_SYS_ACL_INIT(handle, count);
1560 timediff = timeval_elapsed(&tv);
1562 if (timediff > audit_timeout) {
1563 smb_time_audit_log("sys_acl_init", timediff);
1569 static int smb_time_audit_sys_acl_create_entry(vfs_handle_struct *handle,
1571 SMB_ACL_ENTRY_T *pentry)
1578 result = SMB_VFS_NEXT_SYS_ACL_CREATE_ENTRY(handle, pacl, pentry);
1579 timediff = timeval_elapsed(&tv);
1581 if (timediff > audit_timeout) {
1582 smb_time_audit_log("sys_acl_create_entry", timediff);
1588 static int smb_time_audit_sys_acl_set_tag_type(vfs_handle_struct *handle,
1589 SMB_ACL_ENTRY_T entry,
1590 SMB_ACL_TAG_T tagtype)
1597 result = SMB_VFS_NEXT_SYS_ACL_SET_TAG_TYPE(handle, entry,
1599 timediff = timeval_elapsed(&tv);
1601 if (timediff > audit_timeout) {
1602 smb_time_audit_log("sys_acl_set_tag_type", timediff);
1608 static int smb_time_audit_sys_acl_set_qualifier(vfs_handle_struct *handle,
1609 SMB_ACL_ENTRY_T entry,
1617 result = SMB_VFS_NEXT_SYS_ACL_SET_QUALIFIER(handle, entry, qual);
1618 timediff = timeval_elapsed(&tv);
1620 if (timediff > audit_timeout) {
1621 smb_time_audit_log("sys_acl_set_qualifier", timediff);
1627 static int smb_time_audit_sys_acl_set_permset(vfs_handle_struct *handle,
1628 SMB_ACL_ENTRY_T entry,
1629 SMB_ACL_PERMSET_T permset)
1636 result = SMB_VFS_NEXT_SYS_ACL_SET_PERMSET(handle, entry, permset);
1637 timediff = timeval_elapsed(&tv);
1639 if (timediff > audit_timeout) {
1640 smb_time_audit_log("sys_acl_set_permset", timediff);
1646 static int smb_time_audit_sys_acl_valid(vfs_handle_struct *handle,
1654 result = SMB_VFS_NEXT_SYS_ACL_VALID(handle, theacl);
1655 timediff = timeval_elapsed(&tv);
1657 if (timediff > audit_timeout) {
1658 smb_time_audit_log("sys_acl_valid", timediff);
1664 static int smb_time_audit_sys_acl_set_file(vfs_handle_struct *handle,
1666 SMB_ACL_TYPE_T acltype,
1674 result = SMB_VFS_NEXT_SYS_ACL_SET_FILE(handle, name, acltype,
1676 timediff = timeval_elapsed(&tv);
1678 if (timediff > audit_timeout) {
1679 smb_time_audit_log("sys_acl_set_file", timediff);
1685 static int smb_time_audit_sys_acl_set_fd(vfs_handle_struct *handle,
1694 result = SMB_VFS_NEXT_SYS_ACL_SET_FD(handle, fsp, theacl);
1695 timediff = timeval_elapsed(&tv);
1697 if (timediff > audit_timeout) {
1698 smb_time_audit_log("sys_acl_set_fd", timediff);
1704 static int smb_time_audit_sys_acl_delete_def_file(vfs_handle_struct *handle,
1712 result = SMB_VFS_NEXT_SYS_ACL_DELETE_DEF_FILE(handle, path);
1713 timediff = timeval_elapsed(&tv);
1715 if (timediff > audit_timeout) {
1716 smb_time_audit_log("sys_acl_delete_def_file", timediff);
1722 static int smb_time_audit_sys_acl_get_perm(vfs_handle_struct *handle,
1723 SMB_ACL_PERMSET_T permset,
1724 SMB_ACL_PERM_T perm)
1731 result = SMB_VFS_NEXT_SYS_ACL_GET_PERM(handle, permset, perm);
1732 timediff = timeval_elapsed(&tv);
1734 if (timediff > audit_timeout) {
1735 smb_time_audit_log("sys_acl_get_perm", timediff);
1741 static int smb_time_audit_sys_acl_free_text(vfs_handle_struct *handle,
1749 result = SMB_VFS_NEXT_SYS_ACL_FREE_TEXT(handle, text);
1750 timediff = timeval_elapsed(&tv);
1752 if (timediff > audit_timeout) {
1753 smb_time_audit_log("sys_acl_free_text", timediff);
1759 static int smb_time_audit_sys_acl_free_acl(vfs_handle_struct *handle,
1760 SMB_ACL_T posix_acl)
1767 result = SMB_VFS_NEXT_SYS_ACL_FREE_ACL(handle, posix_acl);
1768 timediff = timeval_elapsed(&tv);
1770 if (timediff > audit_timeout) {
1771 smb_time_audit_log("sys_acl_free_acl", timediff);
1777 static int smb_time_audit_sys_acl_free_qualifier(vfs_handle_struct *handle,
1779 SMB_ACL_TAG_T tagtype)
1786 result = SMB_VFS_NEXT_SYS_ACL_FREE_QUALIFIER(handle, qualifier,
1788 timediff = timeval_elapsed(&tv);
1790 if (timediff > audit_timeout) {
1791 smb_time_audit_log("sys_acl_free_qualifier", timediff);
1797 static ssize_t smb_time_audit_getxattr(struct vfs_handle_struct *handle,
1798 const char *path, const char *name,
1799 void *value, size_t size)
1806 result = SMB_VFS_NEXT_GETXATTR(handle, path, name, value, size);
1807 timediff = timeval_elapsed(&tv);
1809 if (timediff > audit_timeout) {
1810 smb_time_audit_log("getxattr", timediff);
1816 static ssize_t smb_time_audit_lgetxattr(struct vfs_handle_struct *handle,
1817 const char *path, const char *name,
1818 void *value, size_t size)
1825 result = SMB_VFS_NEXT_LGETXATTR(handle, path, name, value, size);
1826 timediff = timeval_elapsed(&tv);
1828 if (timediff > audit_timeout) {
1829 smb_time_audit_log("lgetxattr", timediff);
1835 static ssize_t smb_time_audit_fgetxattr(struct vfs_handle_struct *handle,
1836 struct files_struct *fsp,
1837 const char *name, void *value,
1845 result = SMB_VFS_NEXT_FGETXATTR(handle, fsp, name, value, size);
1846 timediff = timeval_elapsed(&tv);
1848 if (timediff > audit_timeout) {
1849 smb_time_audit_log("fgetxattr", timediff);
1855 static ssize_t smb_time_audit_listxattr(struct vfs_handle_struct *handle,
1856 const char *path, char *list,
1864 result = SMB_VFS_NEXT_LISTXATTR(handle, path, list, size);
1865 timediff = timeval_elapsed(&tv);
1867 if (timediff > audit_timeout) {
1868 smb_time_audit_log("listxattr", timediff);
1874 static ssize_t smb_time_audit_llistxattr(struct vfs_handle_struct *handle,
1875 const char *path, char *list,
1883 result = SMB_VFS_NEXT_LLISTXATTR(handle, path, list, size);
1884 timediff = timeval_elapsed(&tv);
1886 if (timediff > audit_timeout) {
1887 smb_time_audit_log("llistxattr", timediff);
1893 static ssize_t smb_time_audit_flistxattr(struct vfs_handle_struct *handle,
1894 struct files_struct *fsp, char *list,
1902 result = SMB_VFS_NEXT_FLISTXATTR(handle, fsp, list, size);
1903 timediff = timeval_elapsed(&tv);
1905 if (timediff > audit_timeout) {
1906 smb_time_audit_log("flistxattr", timediff);
1912 static int smb_time_audit_removexattr(struct vfs_handle_struct *handle,
1913 const char *path, const char *name)
1920 result = SMB_VFS_NEXT_REMOVEXATTR(handle, path, name);
1921 timediff = timeval_elapsed(&tv);
1923 if (timediff > audit_timeout) {
1924 smb_time_audit_log("removexattr", timediff);
1930 static int smb_time_audit_lremovexattr(struct vfs_handle_struct *handle,
1931 const char *path, const char *name)
1938 result = SMB_VFS_NEXT_LREMOVEXATTR(handle, path, name);
1939 timediff = timeval_elapsed(&tv);
1941 if (timediff > audit_timeout) {
1942 smb_time_audit_log("lremovexattr", timediff);
1948 static int smb_time_audit_fremovexattr(struct vfs_handle_struct *handle,
1949 struct files_struct *fsp,
1957 result = SMB_VFS_NEXT_FREMOVEXATTR(handle, fsp, name);
1958 timediff = timeval_elapsed(&tv);
1960 if (timediff > audit_timeout) {
1961 smb_time_audit_log("fremovexattr", timediff);
1967 static int smb_time_audit_setxattr(struct vfs_handle_struct *handle,
1968 const char *path, const char *name,
1969 const void *value, size_t size,
1977 result = SMB_VFS_NEXT_SETXATTR(handle, path, name, value, size,
1979 timediff = timeval_elapsed(&tv);
1981 if (timediff > audit_timeout) {
1982 smb_time_audit_log("setxattr", timediff);
1988 static int smb_time_audit_lsetxattr(struct vfs_handle_struct *handle,
1989 const char *path, const char *name,
1990 const void *value, size_t size,
1998 result = SMB_VFS_NEXT_LSETXATTR(handle, path, name, value, size,
2000 timediff = timeval_elapsed(&tv);
2002 if (timediff > audit_timeout) {
2003 smb_time_audit_log("lsetxattr", timediff);
2009 static int smb_time_audit_fsetxattr(struct vfs_handle_struct *handle,
2010 struct files_struct *fsp, const char *name,
2011 const void *value, size_t size, int flags)
2018 result = SMB_VFS_NEXT_FSETXATTR(handle, fsp, name, value, size, flags);
2019 timediff = timeval_elapsed(&tv);
2021 if (timediff > audit_timeout) {
2022 smb_time_audit_log("fsetxattr", timediff);
2028 static int smb_time_audit_aio_read(struct vfs_handle_struct *handle,
2029 struct files_struct *fsp,
2030 SMB_STRUCT_AIOCB *aiocb)
2037 result = SMB_VFS_NEXT_AIO_READ(handle, fsp, aiocb);
2038 timediff = timeval_elapsed(&tv);
2040 if (timediff > audit_timeout) {
2041 smb_time_audit_log("aio_read", timediff);
2047 static int smb_time_audit_aio_write(struct vfs_handle_struct *handle,
2048 struct files_struct *fsp,
2049 SMB_STRUCT_AIOCB *aiocb)
2056 result = SMB_VFS_NEXT_AIO_WRITE(handle, fsp, aiocb);
2057 timediff = timeval_elapsed(&tv);
2059 if (timediff > audit_timeout) {
2060 smb_time_audit_log("aio_write", timediff);
2066 static ssize_t smb_time_audit_aio_return(struct vfs_handle_struct *handle,
2067 struct files_struct *fsp,
2068 SMB_STRUCT_AIOCB *aiocb)
2075 result = SMB_VFS_NEXT_AIO_RETURN(handle, fsp, aiocb);
2076 timediff = timeval_elapsed(&tv);
2078 if (timediff > audit_timeout) {
2079 smb_time_audit_log("aio_return", timediff);
2085 static int smb_time_audit_aio_cancel(struct vfs_handle_struct *handle,
2086 struct files_struct *fsp,
2087 SMB_STRUCT_AIOCB *aiocb)
2094 result = SMB_VFS_NEXT_AIO_CANCEL(handle, fsp, aiocb);
2095 timediff = timeval_elapsed(&tv);
2097 if (timediff > audit_timeout) {
2098 smb_time_audit_log("aio_cancel", timediff);
2104 static int smb_time_audit_aio_error(struct vfs_handle_struct *handle,
2105 struct files_struct *fsp,
2106 SMB_STRUCT_AIOCB *aiocb)
2113 result = SMB_VFS_NEXT_AIO_ERROR(handle, fsp, aiocb);
2114 timediff = timeval_elapsed(&tv);
2116 if (timediff > audit_timeout) {
2117 smb_time_audit_log("aio_error", timediff);
2123 static int smb_time_audit_aio_fsync(struct vfs_handle_struct *handle,
2124 struct files_struct *fsp, int op,
2125 SMB_STRUCT_AIOCB *aiocb)
2132 result = SMB_VFS_NEXT_AIO_FSYNC(handle, fsp, op, aiocb);
2133 timediff = timeval_elapsed(&tv);
2135 if (timediff > audit_timeout) {
2136 smb_time_audit_log("aio_fsync", timediff);
2142 static int smb_time_audit_aio_suspend(struct vfs_handle_struct *handle,
2143 struct files_struct *fsp,
2144 const SMB_STRUCT_AIOCB * const aiocb[],
2145 int n, const struct timespec *ts)
2152 result = SMB_VFS_NEXT_AIO_SUSPEND(handle, fsp, aiocb, n, ts);
2153 timediff = timeval_elapsed(&tv);
2155 if (timediff > audit_timeout) {
2156 smb_time_audit_log("aio_suspend", timediff);
2162 static bool smb_time_audit_aio_force(struct vfs_handle_struct *handle,
2163 struct files_struct *fsp)
2170 result = SMB_VFS_NEXT_AIO_FORCE(handle, fsp);
2171 timediff = timeval_elapsed(&tv);
2173 if (timediff > audit_timeout) {
2174 smb_time_audit_log("aio_force", timediff);
2182 /* VFS operations */
2184 static struct vfs_fn_pointers vfs_time_audit_fns = {
2185 .connect_fn = smb_time_audit_connect,
2186 .disconnect = smb_time_audit_disconnect,
2187 .disk_free = smb_time_audit_disk_free,
2188 .get_quota = smb_time_audit_get_quota,
2189 .set_quota = smb_time_audit_set_quota,
2190 .get_shadow_copy_data = smb_time_audit_get_shadow_copy_data,
2191 .statvfs = smb_time_audit_statvfs,
2192 .fs_capabilities = smb_time_audit_fs_capabilities,
2193 .opendir = smb_time_audit_opendir,
2194 .readdir = smb_time_audit_readdir,
2195 .seekdir = smb_time_audit_seekdir,
2196 .telldir = smb_time_audit_telldir,
2197 .rewind_dir = smb_time_audit_rewinddir,
2198 .mkdir = smb_time_audit_mkdir,
2199 .rmdir = smb_time_audit_rmdir,
2200 .closedir = smb_time_audit_closedir,
2201 .init_search_op = smb_time_audit_init_search_op,
2202 .open = smb_time_audit_open,
2203 .create_file = smb_time_audit_create_file,
2204 .close_fn = smb_time_audit_close,
2205 .vfs_read = smb_time_audit_read,
2206 .pread = smb_time_audit_pread,
2207 .write = smb_time_audit_write,
2208 .pwrite = smb_time_audit_pwrite,
2209 .lseek = smb_time_audit_lseek,
2210 .sendfile = smb_time_audit_sendfile,
2211 .recvfile = smb_time_audit_recvfile,
2212 .rename = smb_time_audit_rename,
2213 .fsync = smb_time_audit_fsync,
2214 .stat = smb_time_audit_stat,
2215 .fstat = smb_time_audit_fstat,
2216 .lstat = smb_time_audit_lstat,
2217 .get_alloc_size = smb_time_audit_get_alloc_size,
2218 .unlink = smb_time_audit_unlink,
2219 .chmod = smb_time_audit_chmod,
2220 .fchmod = smb_time_audit_fchmod,
2221 .chown = smb_time_audit_chown,
2222 .fchown = smb_time_audit_fchown,
2223 .lchown = smb_time_audit_lchown,
2224 .chdir = smb_time_audit_chdir,
2225 .getwd = smb_time_audit_getwd,
2226 .ntimes = smb_time_audit_ntimes,
2227 .ftruncate = smb_time_audit_ftruncate,
2228 .lock = smb_time_audit_lock,
2229 .kernel_flock = smb_time_audit_kernel_flock,
2230 .linux_setlease = smb_time_audit_linux_setlease,
2231 .getlock = smb_time_audit_getlock,
2232 .symlink = smb_time_audit_symlink,
2233 .vfs_readlink = smb_time_audit_readlink,
2234 .link = smb_time_audit_link,
2235 .mknod = smb_time_audit_mknod,
2236 .realpath = smb_time_audit_realpath,
2237 .notify_watch = smb_time_audit_notify_watch,
2238 .chflags = smb_time_audit_chflags,
2239 .file_id_create = smb_time_audit_file_id_create,
2240 .streaminfo = smb_time_audit_streaminfo,
2241 .get_real_filename = smb_time_audit_get_real_filename,
2242 .connectpath = smb_time_audit_connectpath,
2243 .brl_lock_windows = smb_time_audit_brl_lock_windows,
2244 .brl_unlock_windows = smb_time_audit_brl_unlock_windows,
2245 .brl_cancel_windows = smb_time_audit_brl_cancel_windows,
2246 .strict_lock = smb_time_audit_strict_lock,
2247 .strict_unlock = smb_time_audit_strict_unlock,
2248 .translate_name = smb_time_audit_translate_name,
2249 .fget_nt_acl = smb_time_audit_fget_nt_acl,
2250 .get_nt_acl = smb_time_audit_get_nt_acl,
2251 .fset_nt_acl = smb_time_audit_fset_nt_acl,
2252 .chmod_acl = smb_time_audit_chmod_acl,
2253 .fchmod_acl = smb_time_audit_fchmod_acl,
2254 .sys_acl_get_entry = smb_time_audit_sys_acl_get_entry,
2255 .sys_acl_get_tag_type = smb_time_audit_sys_acl_get_tag_type,
2256 .sys_acl_get_permset = smb_time_audit_sys_acl_get_permset,
2257 .sys_acl_get_qualifier = smb_time_audit_sys_acl_get_qualifier,
2258 .sys_acl_get_file = smb_time_audit_sys_acl_get_file,
2259 .sys_acl_get_fd = smb_time_audit_sys_acl_get_fd,
2260 .sys_acl_clear_perms = smb_time_audit_sys_acl_clear_perms,
2261 .sys_acl_add_perm = smb_time_audit_sys_acl_add_perm,
2262 .sys_acl_to_text = smb_time_audit_sys_acl_to_text,
2263 .sys_acl_init = smb_time_audit_sys_acl_init,
2264 .sys_acl_create_entry = smb_time_audit_sys_acl_create_entry,
2265 .sys_acl_set_tag_type = smb_time_audit_sys_acl_set_tag_type,
2266 .sys_acl_set_qualifier = smb_time_audit_sys_acl_set_qualifier,
2267 .sys_acl_set_permset = smb_time_audit_sys_acl_set_permset,
2268 .sys_acl_valid = smb_time_audit_sys_acl_valid,
2269 .sys_acl_set_file = smb_time_audit_sys_acl_set_file,
2270 .sys_acl_set_fd = smb_time_audit_sys_acl_set_fd,
2271 .sys_acl_delete_def_file = smb_time_audit_sys_acl_delete_def_file,
2272 .sys_acl_get_perm = smb_time_audit_sys_acl_get_perm,
2273 .sys_acl_free_text = smb_time_audit_sys_acl_free_text,
2274 .sys_acl_free_acl = smb_time_audit_sys_acl_free_acl,
2275 .sys_acl_free_qualifier = smb_time_audit_sys_acl_free_qualifier,
2276 .getxattr = smb_time_audit_getxattr,
2277 .lgetxattr = smb_time_audit_lgetxattr,
2278 .fgetxattr = smb_time_audit_fgetxattr,
2279 .listxattr = smb_time_audit_listxattr,
2280 .llistxattr = smb_time_audit_llistxattr,
2281 .flistxattr = smb_time_audit_flistxattr,
2282 .removexattr = smb_time_audit_removexattr,
2283 .lremovexattr = smb_time_audit_lremovexattr,
2284 .fremovexattr = smb_time_audit_fremovexattr,
2285 .setxattr = smb_time_audit_setxattr,
2286 .lsetxattr = smb_time_audit_lsetxattr,
2287 .fsetxattr = smb_time_audit_fsetxattr,
2288 .aio_read = smb_time_audit_aio_read,
2289 .aio_write = smb_time_audit_aio_write,
2290 .aio_return_fn = smb_time_audit_aio_return,
2291 .aio_cancel = smb_time_audit_aio_cancel,
2292 .aio_error_fn = smb_time_audit_aio_error,
2293 .aio_fsync = smb_time_audit_aio_fsync,
2294 .aio_suspend = smb_time_audit_aio_suspend,
2295 .aio_force = smb_time_audit_aio_force,
2299 NTSTATUS vfs_time_audit_init(void);
2300 NTSTATUS vfs_time_audit_init(void)
2302 audit_timeout = (double)lp_parm_int(-1, "time_audit", "timeout",
2304 return smb_register_vfs(SMB_VFS_INTERFACE_VERSION, "time_audit",
2305 &vfs_time_audit_fns);