提交 8cb5a303 编写于 作者: R Ritesh Harjani 提交者: Theodore Ts'o

ext4: convert ext4_fc_track_dentry type events to use event class

One should use DECLARE_EVENT_CLASS for similar event types instead of
defining TRACE_EVENT for each event type. This is helpful in reducing
the text section footprint for e.g. [1]

[1]: https://lwn.net/Articles/381064/Signed-off-by: NRitesh Harjani <riteshh@linux.ibm.com>
Reviewed-by: NHarshad Shirwadkar <harshadshirwadkar@gmail.com>
Reviewed-by: NJan Kara <jack@suse.cz>
Link: https://lore.kernel.org/r/a019cb46219ef4b30e4d98d7ced7d8819a2fc61d.1647057583.git.riteshh@linux.ibm.comSigned-off-by: NTheodore Ts'o <tytso@mit.edu>
上级 7af1974a
...@@ -2780,33 +2780,39 @@ TRACE_EVENT(ext4_fc_stats, ...@@ -2780,33 +2780,39 @@ TRACE_EVENT(ext4_fc_stats,
__entry->fc_numblks) __entry->fc_numblks)
); );
#define DEFINE_TRACE_DENTRY_EVENT(__type) \ DECLARE_EVENT_CLASS(ext4_fc_track_dentry,
TRACE_EVENT(ext4_fc_track_##__type, \
TP_PROTO(struct inode *inode, struct dentry *dentry, int ret), \ TP_PROTO(struct inode *inode, struct dentry *dentry, int ret),
\
TP_ARGS(inode, dentry, ret), \ TP_ARGS(inode, dentry, ret),
\
TP_STRUCT__entry( \ TP_STRUCT__entry(
__field(dev_t, dev) \ __field(dev_t, dev)
__field(int, ino) \ __field(ino_t, i_ino)
__field(int, error) \ __field(int, error)
), \ ),
\
TP_fast_assign( \ TP_fast_assign(
__entry->dev = inode->i_sb->s_dev; \ __entry->dev = inode->i_sb->s_dev;
__entry->ino = inode->i_ino; \ __entry->i_ino = inode->i_ino;
__entry->error = ret; \ __entry->error = ret;
), \ ),
\
TP_printk("dev %d:%d, inode %d, error %d, fc_%s", \ TP_printk("dev %d,%d, ino %lu, error %d",
MAJOR(__entry->dev), MINOR(__entry->dev), \ MAJOR(__entry->dev), MINOR(__entry->dev),
__entry->ino, __entry->error, \ __entry->i_ino, __entry->error
#__type) \
) )
);
#define DEFINE_EVENT_CLASS_DENTRY(__type) \
DEFINE_EVENT(ext4_fc_track_dentry, ext4_fc_track_##__type, \
TP_PROTO(struct inode *inode, struct dentry *dentry, int ret), \
TP_ARGS(inode, dentry, ret) \
)
DEFINE_TRACE_DENTRY_EVENT(create); DEFINE_EVENT_CLASS_DENTRY(create);
DEFINE_TRACE_DENTRY_EVENT(link); DEFINE_EVENT_CLASS_DENTRY(link);
DEFINE_TRACE_DENTRY_EVENT(unlink); DEFINE_EVENT_CLASS_DENTRY(unlink);
TRACE_EVENT(ext4_fc_track_inode, TRACE_EVENT(ext4_fc_track_inode,
TP_PROTO(struct inode *inode, int ret), TP_PROTO(struct inode *inode, int ret),
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册