2011-02-21 03:13:14 +00:00
|
|
|
#undef TRACE_SYSTEM
|
|
|
|
#define TRACE_SYSTEM ocfs2
|
|
|
|
|
|
|
|
#if !defined(_TRACE_OCFS2_H) || defined(TRACE_HEADER_MULTI_READ)
|
|
|
|
#define _TRACE_OCFS2_H
|
|
|
|
|
|
|
|
#include <linux/tracepoint.h>
|
|
|
|
|
2011-02-22 00:21:10 +00:00
|
|
|
DECLARE_EVENT_CLASS(ocfs2__int,
|
|
|
|
TP_PROTO(int num),
|
|
|
|
TP_ARGS(num),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field(int, num)
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->num = num;
|
|
|
|
),
|
|
|
|
TP_printk("%d", __entry->num)
|
|
|
|
);
|
|
|
|
|
|
|
|
#define DEFINE_OCFS2_INT_EVENT(name) \
|
|
|
|
DEFINE_EVENT(ocfs2__int, name, \
|
|
|
|
TP_PROTO(int num), \
|
|
|
|
TP_ARGS(num))
|
|
|
|
|
2011-02-21 23:56:45 +00:00
|
|
|
DECLARE_EVENT_CLASS(ocfs2__uint,
|
|
|
|
TP_PROTO(unsigned int num),
|
|
|
|
TP_ARGS(num),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field( unsigned int, num )
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->num = num;
|
|
|
|
),
|
|
|
|
TP_printk("%u", __entry->num)
|
|
|
|
);
|
|
|
|
|
|
|
|
#define DEFINE_OCFS2_UINT_EVENT(name) \
|
|
|
|
DEFINE_EVENT(ocfs2__uint, name, \
|
|
|
|
TP_PROTO(unsigned int num), \
|
|
|
|
TP_ARGS(num))
|
|
|
|
|
2011-02-22 00:22:33 +00:00
|
|
|
DECLARE_EVENT_CLASS(ocfs2__ull,
|
|
|
|
TP_PROTO(unsigned long long blkno),
|
|
|
|
TP_ARGS(blkno),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field(unsigned long long, blkno)
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->blkno = blkno;
|
|
|
|
),
|
|
|
|
TP_printk("%llu", __entry->blkno)
|
|
|
|
);
|
|
|
|
|
|
|
|
#define DEFINE_OCFS2_ULL_EVENT(name) \
|
|
|
|
DEFINE_EVENT(ocfs2__ull, name, \
|
|
|
|
TP_PROTO(unsigned long long num), \
|
|
|
|
TP_ARGS(num))
|
|
|
|
|
2011-02-22 00:21:10 +00:00
|
|
|
DECLARE_EVENT_CLASS(ocfs2__int_int,
|
|
|
|
TP_PROTO(int value1, int value2),
|
|
|
|
TP_ARGS(value1, value2),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field(int, value1)
|
|
|
|
__field(int, value2)
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->value1 = value1;
|
|
|
|
__entry->value2 = value2;
|
|
|
|
),
|
|
|
|
TP_printk("%d %d", __entry->value1, __entry->value2)
|
|
|
|
);
|
|
|
|
|
|
|
|
#define DEFINE_OCFS2_INT_INT_EVENT(name) \
|
|
|
|
DEFINE_EVENT(ocfs2__int_int, name, \
|
|
|
|
TP_PROTO(int val1, int val2), \
|
|
|
|
TP_ARGS(val1, val2))
|
|
|
|
|
2011-02-22 00:22:33 +00:00
|
|
|
DECLARE_EVENT_CLASS(ocfs2__uint_uint,
|
|
|
|
TP_PROTO(unsigned int value1, unsigned int value2),
|
|
|
|
TP_ARGS(value1, value2),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field(unsigned int, value1)
|
|
|
|
__field(unsigned int, value2)
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->value1 = value1;
|
|
|
|
__entry->value2 = value2;
|
|
|
|
),
|
|
|
|
TP_printk("%u %u", __entry->value1, __entry->value2)
|
|
|
|
);
|
|
|
|
|
|
|
|
#define DEFINE_OCFS2_UINT_UINT_EVENT(name) \
|
|
|
|
DEFINE_EVENT(ocfs2__uint_uint, name, \
|
|
|
|
TP_PROTO(unsigned int val1, unsigned int val2), \
|
|
|
|
TP_ARGS(val1, val2))
|
|
|
|
|
2011-02-22 00:21:10 +00:00
|
|
|
DECLARE_EVENT_CLASS(ocfs2__ull_uint,
|
|
|
|
TP_PROTO(unsigned long long value1, unsigned int value2),
|
|
|
|
TP_ARGS(value1, value2),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field(unsigned long long, value1)
|
|
|
|
__field(unsigned int, value2)
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->value1 = value1;
|
|
|
|
__entry->value2 = value2;
|
|
|
|
),
|
|
|
|
TP_printk("%llu %u", __entry->value1, __entry->value2)
|
|
|
|
);
|
|
|
|
|
|
|
|
#define DEFINE_OCFS2_ULL_UINT_EVENT(name) \
|
|
|
|
DEFINE_EVENT(ocfs2__ull_uint, name, \
|
|
|
|
TP_PROTO(unsigned long long val1, unsigned int val2), \
|
|
|
|
TP_ARGS(val1, val2))
|
|
|
|
|
2011-02-22 00:22:33 +00:00
|
|
|
DECLARE_EVENT_CLASS(ocfs2__ull_ull,
|
|
|
|
TP_PROTO(unsigned long long value1, unsigned long long value2),
|
|
|
|
TP_ARGS(value1, value2),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field(unsigned long long, value1)
|
|
|
|
__field(unsigned long long, value2)
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->value1 = value1;
|
|
|
|
__entry->value2 = value2;
|
|
|
|
),
|
|
|
|
TP_printk("%llu %llu", __entry->value1, __entry->value2)
|
|
|
|
);
|
|
|
|
|
|
|
|
#define DEFINE_OCFS2_ULL_ULL_EVENT(name) \
|
|
|
|
DEFINE_EVENT(ocfs2__ull_ull, name, \
|
|
|
|
TP_PROTO(unsigned long long val1, unsigned long long val2), \
|
|
|
|
TP_ARGS(val1, val2))
|
|
|
|
|
|
|
|
DECLARE_EVENT_CLASS(ocfs2__ull_uint_uint,
|
|
|
|
TP_PROTO(unsigned long long value1,
|
|
|
|
unsigned int value2, unsigned int value3),
|
|
|
|
TP_ARGS(value1, value2, value3),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field(unsigned long long, value1)
|
|
|
|
__field(unsigned int, value2)
|
|
|
|
__field(unsigned int, value3)
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->value1 = value1;
|
|
|
|
__entry->value2 = value2;
|
|
|
|
__entry->value3 = value3;
|
|
|
|
),
|
|
|
|
TP_printk("%llu %u %u", __entry->value1,
|
|
|
|
__entry->value2, __entry->value3)
|
|
|
|
);
|
|
|
|
|
|
|
|
#define DEFINE_OCFS2_ULL_UINT_UINT_EVENT(name) \
|
|
|
|
DEFINE_EVENT(ocfs2__ull_uint_uint, name, \
|
|
|
|
TP_PROTO(unsigned long long val1, \
|
|
|
|
unsigned int val2, unsigned int val3), \
|
|
|
|
TP_ARGS(val1, val2, val3))
|
|
|
|
|
2011-02-21 23:56:45 +00:00
|
|
|
DECLARE_EVENT_CLASS(ocfs2__uint_uint_uint,
|
|
|
|
TP_PROTO(unsigned int value1, unsigned int value2,
|
|
|
|
unsigned int value3),
|
|
|
|
TP_ARGS(value1, value2, value3),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field( unsigned int, value1 )
|
|
|
|
__field( unsigned int, value2 )
|
|
|
|
__field( unsigned int, value3 )
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->value1 = value1;
|
|
|
|
__entry->value2 = value2;
|
|
|
|
__entry->value3 = value3;
|
|
|
|
),
|
|
|
|
TP_printk("%u %u %u", __entry->value1, __entry->value2, __entry->value3)
|
|
|
|
);
|
|
|
|
|
|
|
|
#define DEFINE_OCFS2_UINT_UINT_UINT_EVENT(name) \
|
|
|
|
DEFINE_EVENT(ocfs2__uint_uint_uint, name, \
|
|
|
|
TP_PROTO(unsigned int value1, unsigned int value2, \
|
|
|
|
unsigned int value3), \
|
|
|
|
TP_ARGS(value1, value2, value3))
|
|
|
|
|
|
|
|
DECLARE_EVENT_CLASS(ocfs2__ull_int_int_int,
|
|
|
|
TP_PROTO(unsigned long long ull, int value1, int value2, int value3),
|
|
|
|
TP_ARGS(ull, value1, value2, value3),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field( unsigned long long, ull )
|
|
|
|
__field( int, value1 )
|
|
|
|
__field( int, value2 )
|
|
|
|
__field( int, value3 )
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->ull = ull;
|
|
|
|
__entry->value1 = value1;
|
|
|
|
__entry->value2 = value2;
|
|
|
|
__entry->value3 = value3;
|
|
|
|
),
|
|
|
|
TP_printk("%llu %d %d %d",
|
|
|
|
__entry->ull, __entry->value1,
|
|
|
|
__entry->value2, __entry->value3)
|
|
|
|
);
|
|
|
|
|
|
|
|
#define DEFINE_OCFS2_ULL_INT_INT_INT_EVENT(name) \
|
|
|
|
DEFINE_EVENT(ocfs2__ull_int_int_int, name, \
|
|
|
|
TP_PROTO(unsigned long long ull, int value1, \
|
|
|
|
int value2, int value3), \
|
|
|
|
TP_ARGS(ull, value1, value2, value3))
|
|
|
|
|
2011-02-22 00:22:33 +00:00
|
|
|
DECLARE_EVENT_CLASS(ocfs2__ull_uint_uint_uint,
|
|
|
|
TP_PROTO(unsigned long long ull, unsigned int value1,
|
|
|
|
unsigned int value2, unsigned int value3),
|
|
|
|
TP_ARGS(ull, value1, value2, value3),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field(unsigned long long, ull)
|
|
|
|
__field(unsigned int, value1)
|
|
|
|
__field(unsigned int, value2)
|
|
|
|
__field(unsigned int, value3)
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->ull = ull;
|
|
|
|
__entry->value1 = value1;
|
|
|
|
__entry->value2 = value2;
|
|
|
|
__entry->value3 = value3;
|
|
|
|
),
|
|
|
|
TP_printk("%llu %u %u %u",
|
|
|
|
__entry->ull, __entry->value1,
|
|
|
|
__entry->value2, __entry->value3)
|
|
|
|
);
|
|
|
|
|
|
|
|
#define DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(name) \
|
|
|
|
DEFINE_EVENT(ocfs2__ull_uint_uint_uint, name, \
|
|
|
|
TP_PROTO(unsigned long long ull, unsigned int value1, \
|
|
|
|
unsigned int value2, unsigned int value3), \
|
|
|
|
TP_ARGS(ull, value1, value2, value3))
|
|
|
|
|
2011-02-22 00:21:10 +00:00
|
|
|
/* Trace events for fs/ocfs2/alloc.c. */
|
|
|
|
DECLARE_EVENT_CLASS(ocfs2__btree_ops,
|
|
|
|
TP_PROTO(unsigned long long owner,\
|
|
|
|
unsigned int value1, unsigned int value2),
|
|
|
|
TP_ARGS(owner, value1, value2),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field(unsigned long long, owner)
|
|
|
|
__field(unsigned int, value1)
|
|
|
|
__field(unsigned int, value2)
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->owner = owner;
|
|
|
|
__entry->value1 = value1;
|
|
|
|
__entry->value2 = value2;
|
|
|
|
),
|
|
|
|
TP_printk("%llu %u %u",
|
|
|
|
__entry->owner, __entry->value1, __entry->value2)
|
|
|
|
);
|
|
|
|
|
|
|
|
#define DEFINE_OCFS2_BTREE_EVENT(name) \
|
|
|
|
DEFINE_EVENT(ocfs2__btree_ops, name, \
|
|
|
|
TP_PROTO(unsigned long long owner, \
|
|
|
|
unsigned int value1, unsigned int value2), \
|
|
|
|
TP_ARGS(owner, value1, value2))
|
|
|
|
|
|
|
|
DEFINE_OCFS2_BTREE_EVENT(ocfs2_adjust_rightmost_branch);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_BTREE_EVENT(ocfs2_rotate_tree_right);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_BTREE_EVENT(ocfs2_append_rec_to_path);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_BTREE_EVENT(ocfs2_insert_extent_start);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_BTREE_EVENT(ocfs2_add_clusters_in_btree);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_INT_EVENT(ocfs2_num_free_extents);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_INT_EVENT(ocfs2_complete_edge_insert);
|
|
|
|
|
|
|
|
TRACE_EVENT(ocfs2_grow_tree,
|
|
|
|
TP_PROTO(unsigned long long owner, int depth),
|
|
|
|
TP_ARGS(owner, depth),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field(unsigned long long, owner)
|
|
|
|
__field(int, depth)
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->owner = owner;
|
|
|
|
__entry->depth = depth;
|
|
|
|
),
|
|
|
|
TP_printk("%llu %d", __entry->owner, __entry->depth)
|
|
|
|
);
|
|
|
|
|
|
|
|
TRACE_EVENT(ocfs2_rotate_subtree,
|
|
|
|
TP_PROTO(int subtree_root, unsigned long long blkno,
|
|
|
|
int depth),
|
|
|
|
TP_ARGS(subtree_root, blkno, depth),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field(int, subtree_root)
|
|
|
|
__field(unsigned long long, blkno)
|
|
|
|
__field(int, depth)
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->subtree_root = subtree_root;
|
|
|
|
__entry->blkno = blkno;
|
|
|
|
__entry->depth = depth;
|
|
|
|
),
|
|
|
|
TP_printk("%d %llu %d", __entry->subtree_root,
|
|
|
|
__entry->blkno, __entry->depth)
|
|
|
|
);
|
|
|
|
|
|
|
|
TRACE_EVENT(ocfs2_insert_extent,
|
|
|
|
TP_PROTO(unsigned int ins_appending, unsigned int ins_contig,
|
|
|
|
int ins_contig_index, int free_records, int ins_tree_depth),
|
|
|
|
TP_ARGS(ins_appending, ins_contig, ins_contig_index, free_records,
|
|
|
|
ins_tree_depth),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field(unsigned int, ins_appending)
|
|
|
|
__field(unsigned int, ins_contig)
|
|
|
|
__field(int, ins_contig_index)
|
|
|
|
__field(int, free_records)
|
|
|
|
__field(int, ins_tree_depth)
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->ins_appending = ins_appending;
|
|
|
|
__entry->ins_contig = ins_contig;
|
|
|
|
__entry->ins_contig_index = ins_contig_index;
|
|
|
|
__entry->free_records = free_records;
|
|
|
|
__entry->ins_tree_depth = ins_tree_depth;
|
|
|
|
),
|
|
|
|
TP_printk("%u %u %d %d %d",
|
|
|
|
__entry->ins_appending, __entry->ins_contig,
|
|
|
|
__entry->ins_contig_index, __entry->free_records,
|
|
|
|
__entry->ins_tree_depth)
|
|
|
|
);
|
|
|
|
|
|
|
|
TRACE_EVENT(ocfs2_split_extent,
|
|
|
|
TP_PROTO(int split_index, unsigned int c_contig_type,
|
|
|
|
unsigned int c_has_empty_extent,
|
|
|
|
unsigned int c_split_covers_rec),
|
|
|
|
TP_ARGS(split_index, c_contig_type,
|
|
|
|
c_has_empty_extent, c_split_covers_rec),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field(int, split_index)
|
|
|
|
__field(unsigned int, c_contig_type)
|
|
|
|
__field(unsigned int, c_has_empty_extent)
|
|
|
|
__field(unsigned int, c_split_covers_rec)
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->split_index = split_index;
|
|
|
|
__entry->c_contig_type = c_contig_type;
|
|
|
|
__entry->c_has_empty_extent = c_has_empty_extent;
|
|
|
|
__entry->c_split_covers_rec = c_split_covers_rec;
|
|
|
|
),
|
|
|
|
TP_printk("%d %u %u %u", __entry->split_index, __entry->c_contig_type,
|
|
|
|
__entry->c_has_empty_extent, __entry->c_split_covers_rec)
|
|
|
|
);
|
|
|
|
|
|
|
|
TRACE_EVENT(ocfs2_remove_extent,
|
|
|
|
TP_PROTO(unsigned long long owner, unsigned int cpos,
|
|
|
|
unsigned int len, int index,
|
|
|
|
unsigned int e_cpos, unsigned int clusters),
|
|
|
|
TP_ARGS(owner, cpos, len, index, e_cpos, clusters),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field(unsigned long long, owner)
|
|
|
|
__field(unsigned int, cpos)
|
|
|
|
__field(unsigned int, len)
|
|
|
|
__field(int, index)
|
|
|
|
__field(unsigned int, e_cpos)
|
|
|
|
__field(unsigned int, clusters)
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->owner = owner;
|
|
|
|
__entry->cpos = cpos;
|
|
|
|
__entry->len = len;
|
|
|
|
__entry->index = index;
|
|
|
|
__entry->e_cpos = e_cpos;
|
|
|
|
__entry->clusters = clusters;
|
|
|
|
),
|
|
|
|
TP_printk("%llu %u %u %d %u %u",
|
|
|
|
__entry->owner, __entry->cpos, __entry->len, __entry->index,
|
|
|
|
__entry->e_cpos, __entry->clusters)
|
|
|
|
);
|
|
|
|
|
|
|
|
TRACE_EVENT(ocfs2_commit_truncate,
|
|
|
|
TP_PROTO(unsigned long long ino, unsigned int new_cpos,
|
|
|
|
unsigned int clusters, unsigned int depth),
|
|
|
|
TP_ARGS(ino, new_cpos, clusters, depth),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field(unsigned long long, ino)
|
|
|
|
__field(unsigned int, new_cpos)
|
|
|
|
__field(unsigned int, clusters)
|
|
|
|
__field(unsigned int, depth)
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->ino = ino;
|
|
|
|
__entry->new_cpos = new_cpos;
|
|
|
|
__entry->clusters = clusters;
|
|
|
|
__entry->depth = depth;
|
|
|
|
),
|
|
|
|
TP_printk("%llu %u %u %u",
|
|
|
|
__entry->ino, __entry->new_cpos,
|
|
|
|
__entry->clusters, __entry->depth)
|
|
|
|
);
|
|
|
|
|
|
|
|
TRACE_EVENT(ocfs2_validate_extent_block,
|
|
|
|
TP_PROTO(unsigned long long blkno),
|
|
|
|
TP_ARGS(blkno),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field(unsigned long long, blkno)
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->blkno = blkno;
|
|
|
|
),
|
|
|
|
TP_printk("%llu ", __entry->blkno)
|
|
|
|
);
|
|
|
|
|
|
|
|
TRACE_EVENT(ocfs2_rotate_leaf,
|
|
|
|
TP_PROTO(unsigned int insert_cpos, int insert_index,
|
|
|
|
int has_empty, int next_free,
|
|
|
|
unsigned int l_count),
|
|
|
|
TP_ARGS(insert_cpos, insert_index, has_empty,
|
|
|
|
next_free, l_count),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field(unsigned int, insert_cpos)
|
|
|
|
__field(int, insert_index)
|
|
|
|
__field(int, has_empty)
|
|
|
|
__field(int, next_free)
|
|
|
|
__field(unsigned int, l_count)
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->insert_cpos = insert_cpos;
|
|
|
|
__entry->insert_index = insert_index;
|
|
|
|
__entry->has_empty = has_empty;
|
|
|
|
__entry->next_free = next_free;
|
|
|
|
__entry->l_count = l_count;
|
|
|
|
),
|
|
|
|
TP_printk("%u %d %d %d %u", __entry->insert_cpos,
|
|
|
|
__entry->insert_index, __entry->has_empty,
|
|
|
|
__entry->next_free, __entry->l_count)
|
|
|
|
);
|
|
|
|
|
|
|
|
TRACE_EVENT(ocfs2_add_clusters_in_btree_ret,
|
|
|
|
TP_PROTO(int status, int reason, int err),
|
|
|
|
TP_ARGS(status, reason, err),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field(int, status)
|
|
|
|
__field(int, reason)
|
|
|
|
__field(int, err)
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->status = status;
|
|
|
|
__entry->reason = reason;
|
|
|
|
__entry->err = err;
|
|
|
|
),
|
|
|
|
TP_printk("%d %d %d", __entry->status,
|
|
|
|
__entry->reason, __entry->err)
|
|
|
|
);
|
|
|
|
|
|
|
|
TRACE_EVENT(ocfs2_mark_extent_written,
|
|
|
|
TP_PROTO(unsigned long long owner, unsigned int cpos,
|
|
|
|
unsigned int len, unsigned int phys),
|
|
|
|
TP_ARGS(owner, cpos, len, phys),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field(unsigned long long, owner)
|
|
|
|
__field(unsigned int, cpos)
|
|
|
|
__field(unsigned int, len)
|
|
|
|
__field(unsigned int, phys)
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->owner = owner;
|
|
|
|
__entry->cpos = cpos;
|
|
|
|
__entry->len = len;
|
|
|
|
__entry->phys = phys;
|
|
|
|
),
|
|
|
|
TP_printk("%llu %u %u %u",
|
|
|
|
__entry->owner, __entry->cpos,
|
|
|
|
__entry->len, __entry->phys)
|
|
|
|
);
|
|
|
|
|
|
|
|
DECLARE_EVENT_CLASS(ocfs2__truncate_log_ops,
|
|
|
|
TP_PROTO(unsigned long long blkno, int index,
|
|
|
|
unsigned int start, unsigned int num),
|
|
|
|
TP_ARGS(blkno, index, start, num),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field(unsigned long long, blkno)
|
|
|
|
__field(int, index)
|
|
|
|
__field(unsigned int, start)
|
|
|
|
__field(unsigned int, num)
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->blkno = blkno;
|
|
|
|
__entry->index = index;
|
|
|
|
__entry->start = start;
|
|
|
|
__entry->num = num;
|
|
|
|
),
|
|
|
|
TP_printk("%llu %d %u %u",
|
|
|
|
__entry->blkno, __entry->index,
|
|
|
|
__entry->start, __entry->num)
|
|
|
|
);
|
|
|
|
|
|
|
|
#define DEFINE_OCFS2_TRUNCATE_LOG_OPS_EVENT(name) \
|
|
|
|
DEFINE_EVENT(ocfs2__truncate_log_ops, name, \
|
|
|
|
TP_PROTO(unsigned long long blkno, int index, \
|
|
|
|
unsigned int start, unsigned int num), \
|
|
|
|
TP_ARGS(blkno, index, start, num))
|
|
|
|
|
|
|
|
DEFINE_OCFS2_TRUNCATE_LOG_OPS_EVENT(ocfs2_truncate_log_append);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_TRUNCATE_LOG_OPS_EVENT(ocfs2_replay_truncate_records);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_flush_truncate_log);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_INT_EVENT(ocfs2_begin_truncate_log_recovery);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_INT_EVENT(ocfs2_truncate_log_recovery_num);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_complete_truncate_log_recovery);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_free_cached_blocks);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_cache_cluster_dealloc);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_INT_INT_EVENT(ocfs2_run_deallocs);
|
|
|
|
|
|
|
|
TRACE_EVENT(ocfs2_cache_block_dealloc,
|
|
|
|
TP_PROTO(int type, int slot, unsigned long long suballoc,
|
|
|
|
unsigned long long blkno, unsigned int bit),
|
|
|
|
TP_ARGS(type, slot, suballoc, blkno, bit),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field(int, type)
|
|
|
|
__field(int, slot)
|
|
|
|
__field(unsigned long long, suballoc)
|
|
|
|
__field(unsigned long long, blkno)
|
|
|
|
__field(unsigned int, bit)
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->type = type;
|
|
|
|
__entry->slot = slot;
|
|
|
|
__entry->suballoc = suballoc;
|
|
|
|
__entry->blkno = blkno;
|
|
|
|
__entry->bit = bit;
|
|
|
|
),
|
|
|
|
TP_printk("%d %d %llu %llu %u",
|
|
|
|
__entry->type, __entry->slot, __entry->suballoc,
|
|
|
|
__entry->blkno, __entry->bit)
|
|
|
|
);
|
|
|
|
|
|
|
|
/* End of trace events for fs/ocfs2/alloc.c. */
|
2011-02-21 03:13:14 +00:00
|
|
|
|
2011-02-21 23:56:45 +00:00
|
|
|
/* Trace events for fs/ocfs2/localalloc.c. */
|
|
|
|
|
|
|
|
DEFINE_OCFS2_UINT_UINT_UINT_EVENT(ocfs2_la_set_sizes);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_ULL_INT_INT_INT_EVENT(ocfs2_alloc_should_use_local);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_INT_EVENT(ocfs2_load_local_alloc);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_INT_EVENT(ocfs2_begin_local_alloc_recovery);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_ULL_INT_INT_INT_EVENT(ocfs2_reserve_local_alloc_bits);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_UINT_EVENT(ocfs2_local_alloc_count_bits);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_INT_INT_EVENT(ocfs2_local_alloc_find_clear_bits_search_bitmap);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_ULL_INT_INT_INT_EVENT(ocfs2_local_alloc_find_clear_bits);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_INT_INT_EVENT(ocfs2_sync_local_to_main);
|
|
|
|
|
|
|
|
TRACE_EVENT(ocfs2_sync_local_to_main_free,
|
|
|
|
TP_PROTO(int count, int bit, unsigned long long start_blk,
|
|
|
|
unsigned long long blkno),
|
|
|
|
TP_ARGS(count, bit, start_blk, blkno),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field(int, count)
|
|
|
|
__field(int, bit)
|
|
|
|
__field(unsigned long long, start_blk)
|
|
|
|
__field(unsigned long long, blkno)
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->count = count;
|
|
|
|
__entry->bit = bit;
|
|
|
|
__entry->start_blk = start_blk;
|
|
|
|
__entry->blkno = blkno;
|
|
|
|
),
|
|
|
|
TP_printk("%d %d %llu %llu",
|
|
|
|
__entry->count, __entry->bit, __entry->start_blk,
|
|
|
|
__entry->blkno)
|
|
|
|
);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_INT_INT_EVENT(ocfs2_local_alloc_new_window);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_local_alloc_new_window_result);
|
|
|
|
|
|
|
|
/* End of trace events for fs/ocfs2/localalloc.c. */
|
2011-02-22 00:22:33 +00:00
|
|
|
|
|
|
|
/* Trace events for fs/ocfs2/suballoc.c. */
|
|
|
|
|
|
|
|
DEFINE_OCFS2_ULL_EVENT(ocfs2_validate_group_descriptor);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_block_group_alloc_contig);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_block_group_alloc_discontig);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_ULL_EVENT(ocfs2_block_group_alloc);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_UINT_UINT_EVENT(ocfs2_reserve_suballoc_bits_nospc);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_UINT_UINT_UINT_EVENT(ocfs2_reserve_suballoc_bits_no_new_group);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_ULL_EVENT(ocfs2_reserve_new_inode_new_group);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_UINT_UINT_EVENT(ocfs2_block_group_set_bits);
|
|
|
|
|
|
|
|
TRACE_EVENT(ocfs2_relink_block_group,
|
|
|
|
TP_PROTO(unsigned long long i_blkno, unsigned int chain,
|
|
|
|
unsigned long long bg_blkno,
|
|
|
|
unsigned long long prev_blkno),
|
|
|
|
TP_ARGS(i_blkno, chain, bg_blkno, prev_blkno),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field(unsigned long long, i_blkno)
|
|
|
|
__field(unsigned int, chain)
|
|
|
|
__field(unsigned long long, bg_blkno)
|
|
|
|
__field(unsigned long long, prev_blkno)
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->i_blkno = i_blkno;
|
|
|
|
__entry->chain = chain;
|
|
|
|
__entry->bg_blkno = bg_blkno;
|
|
|
|
__entry->prev_blkno = prev_blkno;
|
|
|
|
),
|
|
|
|
TP_printk("%llu %u %llu %llu",
|
|
|
|
__entry->i_blkno, __entry->chain, __entry->bg_blkno,
|
|
|
|
__entry->prev_blkno)
|
|
|
|
);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT(ocfs2_cluster_group_search_wrong_max_bits);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_cluster_group_search_max_block);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_ULL_ULL_EVENT(ocfs2_block_group_search_max_block);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_ULL_UINT_UINT_EVENT(ocfs2_search_chain_begin);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_search_chain_succ);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_search_chain_end);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_UINT_EVENT(ocfs2_claim_suballoc_bits);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_claim_new_inode_at_loc);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_UINT_UINT_EVENT(ocfs2_block_group_clear_bits);
|
|
|
|
|
|
|
|
TRACE_EVENT(ocfs2_free_suballoc_bits,
|
|
|
|
TP_PROTO(unsigned long long inode, unsigned long long group,
|
|
|
|
unsigned int start_bit, unsigned int count),
|
|
|
|
TP_ARGS(inode, group, start_bit, count),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field(unsigned long long, inode)
|
|
|
|
__field(unsigned long long, group)
|
|
|
|
__field(unsigned int, start_bit)
|
|
|
|
__field(unsigned int, count)
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->inode = inode;
|
|
|
|
__entry->group = group;
|
|
|
|
__entry->start_bit = start_bit;
|
|
|
|
__entry->count = count;
|
|
|
|
),
|
|
|
|
TP_printk("%llu %llu %u %u", __entry->inode, __entry->group,
|
|
|
|
__entry->start_bit, __entry->count)
|
|
|
|
);
|
|
|
|
|
|
|
|
TRACE_EVENT(ocfs2_free_clusters,
|
|
|
|
TP_PROTO(unsigned long long bg_blkno, unsigned long long start_blk,
|
|
|
|
unsigned int start_bit, unsigned int count),
|
|
|
|
TP_ARGS(bg_blkno, start_blk, start_bit, count),
|
|
|
|
TP_STRUCT__entry(
|
|
|
|
__field(unsigned long long, bg_blkno)
|
|
|
|
__field(unsigned long long, start_blk)
|
|
|
|
__field(unsigned int, start_bit)
|
|
|
|
__field(unsigned int, count)
|
|
|
|
),
|
|
|
|
TP_fast_assign(
|
|
|
|
__entry->bg_blkno = bg_blkno;
|
|
|
|
__entry->start_blk = start_blk;
|
|
|
|
__entry->start_bit = start_bit;
|
|
|
|
__entry->count = count;
|
|
|
|
),
|
|
|
|
TP_printk("%llu %llu %u %u", __entry->bg_blkno, __entry->start_blk,
|
|
|
|
__entry->start_bit, __entry->count)
|
|
|
|
);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_ULL_EVENT(ocfs2_get_suballoc_slot_bit);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_test_suballoc_bit);
|
|
|
|
|
|
|
|
DEFINE_OCFS2_ULL_EVENT(ocfs2_test_inode_bit);
|
|
|
|
|
|
|
|
/* End of trace events for fs/ocfs2/suballoc.c. */
|
2011-02-21 03:13:14 +00:00
|
|
|
#endif /* _TRACE_OCFS2_H */
|
|
|
|
|
|
|
|
/* This part must be outside protection */
|
|
|
|
#undef TRACE_INCLUDE_PATH
|
|
|
|
#define TRACE_INCLUDE_PATH .
|
|
|
|
#define TRACE_INCLUDE_FILE ocfs2_trace
|
|
|
|
#include <trace/define_trace.h>
|