Re: odd TRACE_DEFINE_ENUM behavior

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Thu, 4 Jan 2018 11:13:03 -0500
Chuck Lever <chuck.lever@xxxxxxxxxx> wrote:

> Hi Steven-
> 
> In commit 8224b2734ab1 ("NFS: Add static NFS I/O tracepoints") I added
> nfs_show_stable to symbolically display the value of the NFS WRITE stable
> field. However, I couldn't get the thing to work with the already-defined
> enums in linux/nfs.h, and had to resort to coding numeric constants:
> 
> 799 /*
> 800  * XXX: I tried using NFS_UNSTABLE and friends in this table, but they
> 801  * all evaluate to 0 for some reason, even if I include linux/nfs.h.
> 802  */
> 803 #define nfs_show_stable(stable) \
> 804         __print_symbolic(stable, \
> 805                         { 0, " (UNSTABLE)" }, \
> 806                         { 1, " (DATA_SYNC)" }, \
> 807                         { 2, " (FILE_SYNC)" })
> 
> If I code this macro the way the others are written, ie:
> 
> TRACE_DEFINE_ENUM(NFS_UNSTABLE);
> TRACE_DEFINE_ENUM(NFS_DATA_SYNC);
> TRACE_DEFINE_ENUM(NFS_FILE_SYNC);
> 
> #define nfs_show_stable(stable) \
> 	__print_symbolic(stable, \
> 			{ NFS_UNSTABLE, " (UNSTABLE)" }, \
> 			{ NFS_DATA_SYNC, " (DATA_SYNC)" }, \
> 			{ NFS_FILE_SYNC, " (FILE_SYNC)" })
> 
> When the field contains 0 it displays "(UNSTABLE)", and when the field
> contains a non-zero value the displayed symbol is blank.
nfs_initiate_write,
Can you show my what is in

 /sys/kernel/debug/tracing/events/nfs/nfs_initiate_write/format

> 
> More recently I observed a similar issue when adding static trace points
> in net/sunrpc/xprtrdma/ , and with existing __print_symbolic call sites
> in sunrpc.ko.
> 
> There is no file /sys/kernel/debug/tracing/enum_map on my system.

That's a debug feature. You need to enable CONFIG_TRACE_ENUM_MAP_FILE

-- Steve

> 
> Am I missing something?
> 
> 
> --
> Chuck Lever
> 
> 

--
To unsubscribe from this list: send the line "unsubscribe linux-nfs" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [Linux Filesystem Development]     [Linux USB Development]     [Linux Media Development]     [Video for Linux]     [Linux NILFS]     [Linux Audio Users]     [Yosemite Info]     [Linux SCSI]

  Powered by Linux