@@ -9,6 +9,7 @@
#include "internal.h"
#include "nfs3_fs.h"
+#include "nfstrace.h"
#define NFSDBG_FACILITY NFSDBG_PROC
@@ -96,6 +97,7 @@ struct posix_acl *nfs3_get_acl(struct inode *inode, int type, bool rcu)
nfs3_prepare_get_acl(&inode->i_default_acl);
status = rpc_call_sync(server->client_acl, &msg, 0);
+ trace_nfs_get_acl(inode, status);
dprintk("NFS reply getacl: %d\n", status);
/* pages may have been allocated at the xdr layer. */
@@ -287,6 +289,7 @@ int nfs3_set_acl(struct mnt_idmap *idmap, struct dentry *dentry,
acl = alloc;
}
status = __nfs3_proc_setacls(inode, acl, dfacl);
+ trace_nfs_set_acl(inode, status);
out:
if (acl != orig)
posix_acl_release(acl);
@@ -13,3 +13,5 @@ EXPORT_TRACEPOINT_SYMBOL_GPL(nfs_fsync_enter);
EXPORT_TRACEPOINT_SYMBOL_GPL(nfs_fsync_exit);
EXPORT_TRACEPOINT_SYMBOL_GPL(nfs_xdr_status);
EXPORT_TRACEPOINT_SYMBOL_GPL(nfs_xdr_bad_filehandle);
+EXPORT_TRACEPOINT_SYMBOL_GPL(nfs_get_acl);
+EXPORT_TRACEPOINT_SYMBOL_GPL(nfs_set_acl);
@@ -161,6 +161,45 @@ DEFINE_NFS_INODE_EVENT(nfs_readdir_force_readdirplus);
DEFINE_NFS_INODE_EVENT_DONE(nfs_readdir_cache_fill_done);
DEFINE_NFS_INODE_EVENT_DONE(nfs_readdir_uncached_done);
+DECLARE_EVENT_CLASS(nfs_acl_template,
+ TP_PROTO(
+ const struct inode *inode,
+ int error
+ ),
+
+ TP_ARGS(inode, error),
+
+ TP_STRUCT__entry(
+ __field(dev_t, dev)
+ __field(u32, fhandle)
+ __field(u64, fileid)
+ __field(unsigned long, error)
+ ),
+
+ TP_fast_assign(
+ __entry->dev = inode->i_sb->s_dev;
+ __entry->fileid = NFS_FILEID(inode);
+ __entry->fhandle = nfs_fhandle_hash(NFS_FH(inode));
+ __entry->error = error < 0 ? -error : 0;
+ ),
+
+ TP_printk(
+ "error=%ld (%s) fileid=%02x:%02x:%llu fhandle=0x%08x",
+ -__entry->error,
+ show_nfs_status(__entry->error),
+ MAJOR(__entry->dev), MINOR(__entry->dev),
+ (unsigned long long)__entry->fileid,
+ __entry->fhandle
+ )
+);
+
+DEFINE_EVENT(nfs_acl_template, nfs_get_acl,
+ TP_PROTO(const struct inode *inode, int error),
+ TP_ARGS(inode, error));
+DEFINE_EVENT(nfs_acl_template, nfs_set_acl,
+ TP_PROTO(const struct inode *inode, int error),
+ TP_ARGS(inode, error));
+
TRACE_EVENT(nfs_access_exit,
TP_PROTO(
const struct inode *inode,
@@ -51,6 +51,9 @@ TRACE_DEFINE_ENUM(NFSERR_JUKEBOX);
{ NFSERR_IO, "IO" }, \
{ NFSERR_NXIO, "NXIO" }, \
{ ECHILD, "CHILD" }, \
+ { ENOTSUPP, "ENOTSUPP" }, \
+ { EPFNOSUPPORT, "EPFNOSUPPORT" }, \
+ { EPROTONOSUPPORT, "EPROTONOSUPPORT" }, \
{ NFSERR_EAGAIN, "AGAIN" }, \
{ NFSERR_ACCES, "ACCES" }, \
{ NFSERR_EXIST, "EXIST" }, \
Add some new tracepoints to the NFSv3 acl events Signed-off-by: Chen Hanxiao <chenhx.fnst@fujitsu.com> --- v2: rename trace_nfs3_[sg]et_acl to trace_nfs_[sg]et_acl use show_nfs_status instead of show_nfs4_status fs/nfs/nfs3acl.c | 3 +++ fs/nfs/nfstrace.c | 2 ++ fs/nfs/nfstrace.h | 39 +++++++++++++++++++++++++++++++++++++++ include/trace/misc/nfs.h | 3 +++ 4 files changed, 47 insertions(+)