2011-02-21 11:13:14 +08: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 08:21:10 +08: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-22 07:56:45 +08: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 08:22:33 +08: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-23 21:29:08 +08:00
DECLARE_EVENT_CLASS ( ocfs2__pointer ,
TP_PROTO ( void * pointer ) ,
TP_ARGS ( pointer ) ,
TP_STRUCT__entry (
__field ( void * , pointer )
) ,
TP_fast_assign (
__entry - > pointer = pointer ;
) ,
TP_printk ( " %p " , __entry - > pointer )
) ;
# define DEFINE_OCFS2_POINTER_EVENT(name) \
DEFINE_EVENT ( ocfs2__pointer , name , \
TP_PROTO ( void * pointer ) , \
TP_ARGS ( pointer ) )
2011-02-23 22:01:17 +08:00
DECLARE_EVENT_CLASS ( ocfs2__string ,
TP_PROTO ( const char * name ) ,
TP_ARGS ( name ) ,
TP_STRUCT__entry (
__string ( name , name )
) ,
TP_fast_assign (
__assign_str ( name , name ) ;
) ,
TP_printk ( " %s " , __get_str ( name ) )
) ;
# define DEFINE_OCFS2_STRING_EVENT(name) \
DEFINE_EVENT ( ocfs2__string , name , \
TP_PROTO ( const char * name ) , \
TP_ARGS ( name ) )
2011-02-22 08:21:10 +08: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-23 22:19:12 +08:00
DECLARE_EVENT_CLASS ( ocfs2__uint_int ,
TP_PROTO ( unsigned int value1 , int value2 ) ,
TP_ARGS ( value1 , value2 ) ,
TP_STRUCT__entry (
__field ( unsigned int , value1 )
__field ( int , value2 )
) ,
TP_fast_assign (
__entry - > value1 = value1 ;
__entry - > value2 = value2 ;
) ,
TP_printk ( " %u %d " , __entry - > value1 , __entry - > value2 )
) ;
# define DEFINE_OCFS2_UINT_INT_EVENT(name) \
DEFINE_EVENT ( ocfs2__uint_int , name , \
TP_PROTO ( unsigned int val1 , int val2 ) , \
TP_ARGS ( val1 , val2 ) )
2011-02-22 08:22:33 +08: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 08:21:10 +08: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 22:24:57 +08:00
DECLARE_EVENT_CLASS ( ocfs2__ull_int ,
TP_PROTO ( unsigned long long value1 , int value2 ) ,
TP_ARGS ( value1 , value2 ) ,
TP_STRUCT__entry (
__field ( unsigned long long , value1 )
__field ( int , value2 )
) ,
TP_fast_assign (
__entry - > value1 = value1 ;
__entry - > value2 = value2 ;
) ,
TP_printk ( " %llu %d " , __entry - > value1 , __entry - > value2 )
) ;
# define DEFINE_OCFS2_ULL_INT_EVENT(name) \
DEFINE_EVENT ( ocfs2__ull_int , name , \
TP_PROTO ( unsigned long long val1 , int val2 ) , \
TP_ARGS ( val1 , val2 ) )
2011-02-22 08:22:33 +08: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 ) )
2011-02-22 08:20:04 +08:00
DECLARE_EVENT_CLASS ( ocfs2__ull_ull_uint ,
TP_PROTO ( unsigned long long value1 ,
unsigned long long value2 , unsigned int value3 ) ,
TP_ARGS ( value1 , value2 , value3 ) ,
TP_STRUCT__entry (
__field ( unsigned long long , value1 )
__field ( unsigned long long , value2 )
__field ( unsigned int , value3 )
) ,
TP_fast_assign (
__entry - > value1 = value1 ;
__entry - > value2 = value2 ;
__entry - > value3 = value3 ;
) ,
TP_printk ( " %llu %llu %u " ,
__entry - > value1 , __entry - > value2 , __entry - > value3 )
) ;
# define DEFINE_OCFS2_ULL_ULL_UINT_EVENT(name) \
DEFINE_EVENT ( ocfs2__ull_ull_uint , name , \
TP_PROTO ( unsigned long long val1 , \
unsigned long long val2 , unsigned int val3 ) , \
TP_ARGS ( val1 , val2 , val3 ) )
2011-02-22 08:22:33 +08:00
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-22 07:56:45 +08: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 ) )
2011-02-22 22:14:41 +08:00
DECLARE_EVENT_CLASS ( ocfs2__ull_ull_ull ,
TP_PROTO ( unsigned long long value1 ,
unsigned long long value2 , unsigned long long value3 ) ,
TP_ARGS ( value1 , value2 , value3 ) ,
TP_STRUCT__entry (
__field ( unsigned long long , value1 )
__field ( unsigned long long , value2 )
__field ( unsigned long long , value3 )
) ,
TP_fast_assign (
__entry - > value1 = value1 ;
__entry - > value2 = value2 ;
__entry - > value3 = value3 ;
) ,
TP_printk ( " %llu %llu %llu " ,
__entry - > value1 , __entry - > value2 , __entry - > value3 )
) ;
# define DEFINE_OCFS2_ULL_ULL_ULL_EVENT(name) \
DEFINE_EVENT ( ocfs2__ull_ull_ull , name , \
TP_PROTO ( unsigned long long value1 , unsigned long long value2 , \
unsigned long long value3 ) , \
TP_ARGS ( value1 , value2 , value3 ) )
2011-02-22 07:56:45 +08:00
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 08:22:33 +08: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-23 22:01:17 +08:00
DECLARE_EVENT_CLASS ( ocfs2__ull_ull_uint_uint ,
TP_PROTO ( unsigned long long value1 , unsigned long long value2 ,
unsigned int value3 , unsigned int value4 ) ,
TP_ARGS ( value1 , value2 , value3 , value4 ) ,
TP_STRUCT__entry (
__field ( unsigned long long , value1 )
__field ( unsigned long long , value2 )
__field ( unsigned int , value3 )
__field ( unsigned int , value4 )
) ,
TP_fast_assign (
__entry - > value1 = value1 ;
__entry - > value2 = value2 ;
__entry - > value3 = value3 ;
__entry - > value4 = value4 ;
) ,
TP_printk ( " %llu %llu %u %u " ,
__entry - > value1 , __entry - > value2 ,
__entry - > value3 , __entry - > value4 )
) ;
# define DEFINE_OCFS2_ULL_ULL_UINT_UINT_EVENT(name) \
DEFINE_EVENT ( ocfs2__ull_ull_uint_uint , name , \
TP_PROTO ( unsigned long long ull , unsigned long long ull1 , \
unsigned int value2 , unsigned int value3 ) , \
TP_ARGS ( ull , ull1 , value2 , value3 ) )
2011-02-22 08:21:10 +08: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 )
) ;
2011-05-23 10:36:45 +08:00
TRACE_EVENT ( ocfs2_trim_extent ,
TP_PROTO ( struct super_block * sb , unsigned long long blk ,
unsigned long long count ) ,
TP_ARGS ( sb , blk , count ) ,
TP_STRUCT__entry (
__field ( int , dev_major )
__field ( int , dev_minor )
__field ( unsigned long long , blk )
__field ( __u64 , count )
) ,
TP_fast_assign (
__entry - > dev_major = MAJOR ( sb - > s_dev ) ;
__entry - > dev_minor = MINOR ( sb - > s_dev ) ;
__entry - > blk = blk ;
__entry - > count = count ;
) ,
TP_printk ( " %d %d %llu %llu " ,
__entry - > dev_major , __entry - > dev_minor ,
__entry - > blk , __entry - > count )
) ;
DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT ( ocfs2_trim_group ) ;
DEFINE_OCFS2_ULL_ULL_ULL_EVENT ( ocfs2_trim_fs ) ;
2011-02-22 08:21:10 +08:00
/* End of trace events for fs/ocfs2/alloc.c. */
2011-02-21 11:13:14 +08:00
2011-02-22 07:56:45 +08: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 08:22:33 +08:00
2011-02-22 08:24:01 +08:00
/* Trace events for fs/ocfs2/resize.c. */
DEFINE_OCFS2_UINT_UINT_EVENT ( ocfs2_update_last_group_and_inode ) ;
DEFINE_OCFS2_ULL_UINT_EVENT ( ocfs2_group_extend ) ;
DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT ( ocfs2_group_add ) ;
/* End of trace events for fs/ocfs2/resize.c. */
2011-02-22 08:22:33 +08: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-22 08:20:04 +08:00
/* Trace events for fs/ocfs2/refcounttree.c. */
DEFINE_OCFS2_ULL_EVENT ( ocfs2_validate_refcount_block ) ;
DEFINE_OCFS2_ULL_EVENT ( ocfs2_purge_refcount_trees ) ;
DEFINE_OCFS2_ULL_EVENT ( ocfs2_create_refcount_tree ) ;
DEFINE_OCFS2_ULL_EVENT ( ocfs2_create_refcount_tree_blkno ) ;
DEFINE_OCFS2_ULL_INT_INT_INT_EVENT ( ocfs2_change_refcount_rec ) ;
DEFINE_OCFS2_ULL_UINT_EVENT ( ocfs2_expand_inline_ref_root ) ;
DEFINE_OCFS2_ULL_UINT_UINT_EVENT ( ocfs2_divide_leaf_refcount_block ) ;
DEFINE_OCFS2_ULL_UINT_EVENT ( ocfs2_new_leaf_refcount_block ) ;
DECLARE_EVENT_CLASS ( ocfs2__refcount_tree_ops ,
TP_PROTO ( unsigned long long blkno , int index ,
unsigned long long cpos ,
unsigned int clusters , unsigned int refcount ) ,
TP_ARGS ( blkno , index , cpos , clusters , refcount ) ,
TP_STRUCT__entry (
__field ( unsigned long long , blkno )
__field ( int , index )
__field ( unsigned long long , cpos )
__field ( unsigned int , clusters )
__field ( unsigned int , refcount )
) ,
TP_fast_assign (
__entry - > blkno = blkno ;
__entry - > index = index ;
__entry - > cpos = cpos ;
__entry - > clusters = clusters ;
__entry - > refcount = refcount ;
) ,
TP_printk ( " %llu %d %llu %u %u " , __entry - > blkno , __entry - > index ,
__entry - > cpos , __entry - > clusters , __entry - > refcount )
) ;
# define DEFINE_OCFS2_REFCOUNT_TREE_OPS_EVENT(name) \
DEFINE_EVENT ( ocfs2__refcount_tree_ops , name , \
TP_PROTO ( unsigned long long blkno , int index , \
unsigned long long cpos , \
unsigned int count , unsigned int refcount ) , \
TP_ARGS ( blkno , index , cpos , count , refcount ) )
DEFINE_OCFS2_REFCOUNT_TREE_OPS_EVENT ( ocfs2_insert_refcount_rec ) ;
TRACE_EVENT ( ocfs2_split_refcount_rec ,
TP_PROTO ( unsigned long long cpos ,
unsigned int clusters , unsigned int refcount ,
unsigned long long split_cpos ,
unsigned int split_clusters , unsigned int split_refcount ) ,
TP_ARGS ( cpos , clusters , refcount ,
split_cpos , split_clusters , split_refcount ) ,
TP_STRUCT__entry (
__field ( unsigned long long , cpos )
__field ( unsigned int , clusters )
__field ( unsigned int , refcount )
__field ( unsigned long long , split_cpos )
__field ( unsigned int , split_clusters )
__field ( unsigned int , split_refcount )
) ,
TP_fast_assign (
__entry - > cpos = cpos ;
__entry - > clusters = clusters ;
__entry - > refcount = refcount ;
__entry - > split_cpos = split_cpos ;
__entry - > split_clusters = split_clusters ;
__entry - > split_refcount = split_refcount ;
) ,
TP_printk ( " %llu %u %u %llu %u %u " ,
__entry - > cpos , __entry - > clusters , __entry - > refcount ,
__entry - > split_cpos , __entry - > split_clusters ,
__entry - > split_refcount )
) ;
DEFINE_OCFS2_REFCOUNT_TREE_OPS_EVENT ( ocfs2_split_refcount_rec_insert ) ;
DEFINE_OCFS2_ULL_ULL_UINT_EVENT ( ocfs2_increase_refcount_begin ) ;
DEFINE_OCFS2_ULL_UINT_UINT_EVENT ( ocfs2_increase_refcount_change ) ;
DEFINE_OCFS2_ULL_UINT_EVENT ( ocfs2_increase_refcount_insert ) ;
DEFINE_OCFS2_ULL_UINT_UINT_EVENT ( ocfs2_increase_refcount_split ) ;
DEFINE_OCFS2_ULL_ULL_UINT_EVENT ( ocfs2_remove_refcount_extent ) ;
DEFINE_OCFS2_ULL_EVENT ( ocfs2_restore_refcount_block ) ;
DEFINE_OCFS2_ULL_ULL_UINT_EVENT ( ocfs2_decrease_refcount_rec ) ;
TRACE_EVENT ( ocfs2_decrease_refcount ,
TP_PROTO ( unsigned long long owner ,
unsigned long long cpos ,
unsigned int len , int delete ) ,
TP_ARGS ( owner , cpos , len , delete ) ,
TP_STRUCT__entry (
__field ( unsigned long long , owner )
__field ( unsigned long long , cpos )
__field ( unsigned int , len )
__field ( int , delete )
) ,
TP_fast_assign (
__entry - > owner = owner ;
__entry - > cpos = cpos ;
__entry - > len = len ;
__entry - > delete = delete ;
) ,
TP_printk ( " %llu %llu %u %d " ,
__entry - > owner , __entry - > cpos , __entry - > len , __entry - > delete )
) ;
DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT ( ocfs2_mark_extent_refcounted ) ;
DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT ( ocfs2_calc_refcount_meta_credits ) ;
TRACE_EVENT ( ocfs2_calc_refcount_meta_credits_iterate ,
TP_PROTO ( int recs_add , unsigned long long cpos ,
unsigned int clusters , unsigned long long r_cpos ,
unsigned int r_clusters , unsigned int refcount , int index ) ,
TP_ARGS ( recs_add , cpos , clusters , r_cpos , r_clusters , refcount , index ) ,
TP_STRUCT__entry (
__field ( int , recs_add )
__field ( unsigned long long , cpos )
__field ( unsigned int , clusters )
__field ( unsigned long long , r_cpos )
__field ( unsigned int , r_clusters )
__field ( unsigned int , refcount )
__field ( int , index )
) ,
TP_fast_assign (
__entry - > recs_add = recs_add ;
__entry - > cpos = cpos ;
__entry - > clusters = clusters ;
__entry - > r_cpos = r_cpos ;
__entry - > r_clusters = r_clusters ;
__entry - > refcount = refcount ;
__entry - > index = index ;
) ,
TP_printk ( " %d %llu %u %llu %u %u %d " ,
__entry - > recs_add , __entry - > cpos , __entry - > clusters ,
__entry - > r_cpos , __entry - > r_clusters ,
__entry - > refcount , __entry - > index )
) ;
DEFINE_OCFS2_INT_INT_EVENT ( ocfs2_add_refcount_flag ) ;
DEFINE_OCFS2_INT_INT_EVENT ( ocfs2_prepare_refcount_change_for_del ) ;
DEFINE_OCFS2_INT_INT_EVENT ( ocfs2_lock_refcount_allocators ) ;
DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT ( ocfs2_duplicate_clusters_by_page ) ;
DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT ( ocfs2_duplicate_clusters_by_jbd ) ;
TRACE_EVENT ( ocfs2_clear_ext_refcount ,
TP_PROTO ( unsigned long long ino , unsigned int cpos ,
unsigned int len , unsigned int p_cluster ,
unsigned int ext_flags ) ,
TP_ARGS ( ino , cpos , len , p_cluster , ext_flags ) ,
TP_STRUCT__entry (
__field ( unsigned long long , ino )
__field ( unsigned int , cpos )
__field ( unsigned int , len )
__field ( unsigned int , p_cluster )
__field ( unsigned int , ext_flags )
) ,
TP_fast_assign (
__entry - > ino = ino ;
__entry - > cpos = cpos ;
__entry - > len = len ;
__entry - > p_cluster = p_cluster ;
__entry - > ext_flags = ext_flags ;
) ,
TP_printk ( " %llu %u %u %u %u " ,
__entry - > ino , __entry - > cpos , __entry - > len ,
__entry - > p_cluster , __entry - > ext_flags )
) ;
TRACE_EVENT ( ocfs2_replace_clusters ,
TP_PROTO ( unsigned long long ino , unsigned int cpos ,
unsigned int old , unsigned int new , unsigned int len ,
unsigned int ext_flags ) ,
TP_ARGS ( ino , cpos , old , new , len , ext_flags ) ,
TP_STRUCT__entry (
__field ( unsigned long long , ino )
__field ( unsigned int , cpos )
__field ( unsigned int , old )
__field ( unsigned int , new )
__field ( unsigned int , len )
__field ( unsigned int , ext_flags )
) ,
TP_fast_assign (
__entry - > ino = ino ;
__entry - > cpos = cpos ;
__entry - > old = old ;
__entry - > new = new ;
__entry - > len = len ;
__entry - > ext_flags = ext_flags ;
) ,
TP_printk ( " %llu %u %u %u %u %u " ,
__entry - > ino , __entry - > cpos , __entry - > old , __entry - > new ,
__entry - > len , __entry - > ext_flags )
) ;
DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT ( ocfs2_make_clusters_writable ) ;
TRACE_EVENT ( ocfs2_refcount_cow_hunk ,
TP_PROTO ( unsigned long long ino , unsigned int cpos ,
unsigned int write_len , unsigned int max_cpos ,
unsigned int cow_start , unsigned int cow_len ) ,
TP_ARGS ( ino , cpos , write_len , max_cpos , cow_start , cow_len ) ,
TP_STRUCT__entry (
__field ( unsigned long long , ino )
__field ( unsigned int , cpos )
__field ( unsigned int , write_len )
__field ( unsigned int , max_cpos )
__field ( unsigned int , cow_start )
__field ( unsigned int , cow_len )
) ,
TP_fast_assign (
__entry - > ino = ino ;
__entry - > cpos = cpos ;
__entry - > write_len = write_len ;
__entry - > max_cpos = max_cpos ;
__entry - > cow_start = cow_start ;
__entry - > cow_len = cow_len ;
) ,
TP_printk ( " %llu %u %u %u %u %u " ,
__entry - > ino , __entry - > cpos , __entry - > write_len ,
__entry - > max_cpos , __entry - > cow_start , __entry - > cow_len )
) ;
/* End of trace events for fs/ocfs2/refcounttree.c. */
2011-02-22 21:33:59 +08:00
/* Trace events for fs/ocfs2/aops.c. */
DECLARE_EVENT_CLASS ( ocfs2__get_block ,
TP_PROTO ( unsigned long long ino , unsigned long long iblock ,
void * bh_result , int create ) ,
TP_ARGS ( ino , iblock , bh_result , create ) ,
TP_STRUCT__entry (
__field ( unsigned long long , ino )
__field ( unsigned long long , iblock )
__field ( void * , bh_result )
__field ( int , create )
) ,
TP_fast_assign (
__entry - > ino = ino ;
__entry - > iblock = iblock ;
__entry - > bh_result = bh_result ;
__entry - > create = create ;
) ,
TP_printk ( " %llu %llu %p %d " ,
__entry - > ino , __entry - > iblock ,
__entry - > bh_result , __entry - > create )
) ;
# define DEFINE_OCFS2_GET_BLOCK_EVENT(name) \
DEFINE_EVENT ( ocfs2__get_block , name , \
TP_PROTO ( unsigned long long ino , unsigned long long iblock , \
void * bh_result , int create ) , \
TP_ARGS ( ino , iblock , bh_result , create ) )
DEFINE_OCFS2_GET_BLOCK_EVENT ( ocfs2_symlink_get_block ) ;
DEFINE_OCFS2_GET_BLOCK_EVENT ( ocfs2_get_block ) ;
DEFINE_OCFS2_ULL_ULL_EVENT ( ocfs2_get_block_end ) ;
DEFINE_OCFS2_ULL_ULL_EVENT ( ocfs2_readpage ) ;
DEFINE_OCFS2_ULL_ULL_EVENT ( ocfs2_writepage ) ;
DEFINE_OCFS2_ULL_ULL_EVENT ( ocfs2_bmap ) ;
TRACE_EVENT ( ocfs2_try_to_write_inline_data ,
TP_PROTO ( unsigned long long ino , unsigned int len ,
unsigned long long pos , unsigned int flags ) ,
TP_ARGS ( ino , len , pos , flags ) ,
TP_STRUCT__entry (
__field ( unsigned long long , ino )
__field ( unsigned int , len )
__field ( unsigned long long , pos )
__field ( unsigned int , flags )
) ,
TP_fast_assign (
__entry - > ino = ino ;
__entry - > len = len ;
__entry - > pos = pos ;
__entry - > flags = flags ;
) ,
TP_printk ( " %llu %u %llu 0x%x " ,
__entry - > ino , __entry - > len , __entry - > pos , __entry - > flags )
) ;
TRACE_EVENT ( ocfs2_write_begin_nolock ,
TP_PROTO ( unsigned long long ino ,
long long i_size , unsigned int i_clusters ,
unsigned long long pos , unsigned int len ,
unsigned int flags , void * page ,
unsigned int clusters , unsigned int extents_to_split ) ,
TP_ARGS ( ino , i_size , i_clusters , pos , len , flags ,
page , clusters , extents_to_split ) ,
TP_STRUCT__entry (
__field ( unsigned long long , ino )
__field ( long long , i_size )
__field ( unsigned int , i_clusters )
__field ( unsigned long long , pos )
__field ( unsigned int , len )
__field ( unsigned int , flags )
__field ( void * , page )
__field ( unsigned int , clusters )
__field ( unsigned int , extents_to_split )
) ,
TP_fast_assign (
__entry - > ino = ino ;
__entry - > i_size = i_size ;
__entry - > i_clusters = i_clusters ;
__entry - > pos = pos ;
__entry - > len = len ;
__entry - > flags = flags ;
__entry - > page = page ;
__entry - > clusters = clusters ;
__entry - > extents_to_split = extents_to_split ;
) ,
TP_printk ( " %llu %lld %u %llu %u %u %p %u %u " ,
__entry - > ino , __entry - > i_size , __entry - > i_clusters ,
__entry - > pos , __entry - > len ,
__entry - > flags , __entry - > page , __entry - > clusters ,
__entry - > extents_to_split )
) ;
TRACE_EVENT ( ocfs2_write_end_inline ,
TP_PROTO ( unsigned long long ino ,
unsigned long long pos , unsigned int copied ,
unsigned int id_count , unsigned int features ) ,
TP_ARGS ( ino , pos , copied , id_count , features ) ,
TP_STRUCT__entry (
__field ( unsigned long long , ino )
__field ( unsigned long long , pos )
__field ( unsigned int , copied )
__field ( unsigned int , id_count )
__field ( unsigned int , features )
) ,
TP_fast_assign (
__entry - > ino = ino ;
__entry - > pos = pos ;
__entry - > copied = copied ;
__entry - > id_count = id_count ;
__entry - > features = features ;
) ,
TP_printk ( " %llu %llu %u %u %u " ,
__entry - > ino , __entry - > pos , __entry - > copied ,
__entry - > id_count , __entry - > features )
) ;
/* End of trace events for fs/ocfs2/aops.c. */
2011-02-22 21:59:46 +08:00
/* Trace events for fs/ocfs2/mmap.c. */
TRACE_EVENT ( ocfs2_fault ,
TP_PROTO ( unsigned long long ino ,
void * area , void * page , unsigned long pgoff ) ,
TP_ARGS ( ino , area , page , pgoff ) ,
TP_STRUCT__entry (
__field ( unsigned long long , ino )
__field ( void * , area )
__field ( void * , page )
__field ( unsigned long , pgoff )
) ,
TP_fast_assign (
__entry - > ino = ino ;
__entry - > area = area ;
__entry - > page = page ;
__entry - > pgoff = pgoff ;
) ,
TP_printk ( " %llu %p %p %lu " ,
__entry - > ino , __entry - > area , __entry - > page , __entry - > pgoff )
) ;
/* End of trace events for fs/ocfs2/mmap.c. */
2011-02-22 22:14:41 +08:00
/* Trace events for fs/ocfs2/file.c. */
DECLARE_EVENT_CLASS ( ocfs2__file_ops ,
TP_PROTO ( void * inode , void * file , void * dentry ,
unsigned long long ino ,
unsigned int d_len , const unsigned char * d_name ,
unsigned long long para ) ,
TP_ARGS ( inode , file , dentry , ino , d_len , d_name , para ) ,
TP_STRUCT__entry (
__field ( void * , inode )
__field ( void * , file )
__field ( void * , dentry )
__field ( unsigned long long , ino )
__field ( unsigned int , d_len )
__string ( d_name , d_name )
__field ( unsigned long long , para )
) ,
TP_fast_assign (
__entry - > inode = inode ;
__entry - > file = file ;
__entry - > dentry = dentry ;
__entry - > ino = ino ;
__entry - > d_len = d_len ;
__assign_str ( d_name , d_name ) ;
__entry - > para = para ;
) ,
TP_printk ( " %p %p %p %llu %llu %.*s " , __entry - > inode , __entry - > file ,
__entry - > dentry , __entry - > ino , __entry - > para ,
__entry - > d_len , __get_str ( d_name ) )
) ;
# define DEFINE_OCFS2_FILE_OPS(name) \
DEFINE_EVENT ( ocfs2__file_ops , name , \
TP_PROTO ( void * inode , void * file , void * dentry , \
unsigned long long ino , \
unsigned int d_len , const unsigned char * d_name , \
unsigned long long mode ) , \
TP_ARGS ( inode , file , dentry , ino , d_len , d_name , mode ) )
DEFINE_OCFS2_FILE_OPS ( ocfs2_file_open ) ;
DEFINE_OCFS2_FILE_OPS ( ocfs2_file_release ) ;
DEFINE_OCFS2_FILE_OPS ( ocfs2_sync_file ) ;
DEFINE_OCFS2_FILE_OPS ( ocfs2_file_aio_write ) ;
DEFINE_OCFS2_FILE_OPS ( ocfs2_file_splice_write ) ;
DEFINE_OCFS2_FILE_OPS ( ocfs2_file_splice_read ) ;
DEFINE_OCFS2_FILE_OPS ( ocfs2_file_aio_read ) ;
DEFINE_OCFS2_ULL_ULL_ULL_EVENT ( ocfs2_truncate_file ) ;
DEFINE_OCFS2_ULL_ULL_EVENT ( ocfs2_truncate_file_error ) ;
TRACE_EVENT ( ocfs2_extend_allocation ,
TP_PROTO ( unsigned long long ip_blkno , unsigned long long size ,
unsigned int clusters , unsigned int clusters_to_add ,
int why , int restart_func ) ,
TP_ARGS ( ip_blkno , size , clusters , clusters_to_add , why , restart_func ) ,
TP_STRUCT__entry (
__field ( unsigned long long , ip_blkno )
__field ( unsigned long long , size )
__field ( unsigned int , clusters )
__field ( unsigned int , clusters_to_add )
__field ( int , why )
__field ( int , restart_func )
) ,
TP_fast_assign (
__entry - > ip_blkno = ip_blkno ;
__entry - > size = size ;
__entry - > clusters = clusters ;
__entry - > clusters_to_add = clusters_to_add ;
__entry - > why = why ;
__entry - > restart_func = restart_func ;
) ,
TP_printk ( " %llu %llu %u %u %d %d " ,
__entry - > ip_blkno , __entry - > size , __entry - > clusters ,
__entry - > clusters_to_add , __entry - > why , __entry - > restart_func )
) ;
TRACE_EVENT ( ocfs2_extend_allocation_end ,
TP_PROTO ( unsigned long long ino ,
unsigned int di_clusters , unsigned long long di_size ,
unsigned int ip_clusters , unsigned long long i_size ) ,
TP_ARGS ( ino , di_clusters , di_size , ip_clusters , i_size ) ,
TP_STRUCT__entry (
__field ( unsigned long long , ino )
__field ( unsigned int , di_clusters )
__field ( unsigned long long , di_size )
__field ( unsigned int , ip_clusters )
__field ( unsigned long long , i_size )
) ,
TP_fast_assign (
__entry - > ino = ino ;
__entry - > di_clusters = di_clusters ;
__entry - > di_size = di_size ;
__entry - > ip_clusters = ip_clusters ;
__entry - > i_size = i_size ;
) ,
TP_printk ( " %llu %u %llu %u %llu " , __entry - > ino , __entry - > di_clusters ,
__entry - > di_size , __entry - > ip_clusters , __entry - > i_size )
) ;
TRACE_EVENT ( ocfs2_write_zero_page ,
TP_PROTO ( unsigned long long ino ,
unsigned long long abs_from , unsigned long long abs_to ,
unsigned long index , unsigned int zero_from ,
unsigned int zero_to ) ,
TP_ARGS ( ino , abs_from , abs_to , index , zero_from , zero_to ) ,
TP_STRUCT__entry (
__field ( unsigned long long , ino )
__field ( unsigned long long , abs_from )
__field ( unsigned long long , abs_to )
__field ( unsigned long , index )
__field ( unsigned int , zero_from )
__field ( unsigned int , zero_to )
) ,
TP_fast_assign (
__entry - > ino = ino ;
__entry - > abs_from = abs_from ;
__entry - > abs_to = abs_to ;
__entry - > index = index ;
__entry - > zero_from = zero_from ;
__entry - > zero_to = zero_to ;
) ,
TP_printk ( " %llu %llu %llu %lu %u %u " , __entry - > ino ,
__entry - > abs_from , __entry - > abs_to ,
__entry - > index , __entry - > zero_from , __entry - > zero_to )
) ;
DEFINE_OCFS2_ULL_ULL_ULL_EVENT ( ocfs2_zero_extend_range ) ;
DEFINE_OCFS2_ULL_ULL_ULL_EVENT ( ocfs2_zero_extend ) ;
TRACE_EVENT ( ocfs2_setattr ,
TP_PROTO ( void * inode , void * dentry ,
unsigned long long ino ,
unsigned int d_len , const unsigned char * d_name ,
unsigned int ia_valid , unsigned int ia_mode ,
unsigned int ia_uid , unsigned int ia_gid ) ,
TP_ARGS ( inode , dentry , ino , d_len , d_name ,
ia_valid , ia_mode , ia_uid , ia_gid ) ,
TP_STRUCT__entry (
__field ( void * , inode )
__field ( void * , dentry )
__field ( unsigned long long , ino )
__field ( unsigned int , d_len )
__string ( d_name , d_name )
__field ( unsigned int , ia_valid )
__field ( unsigned int , ia_mode )
__field ( unsigned int , ia_uid )
__field ( unsigned int , ia_gid )
) ,
TP_fast_assign (
__entry - > inode = inode ;
__entry - > dentry = dentry ;
__entry - > ino = ino ;
__entry - > d_len = d_len ;
__assign_str ( d_name , d_name ) ;
__entry - > ia_valid = ia_valid ;
__entry - > ia_mode = ia_mode ;
__entry - > ia_uid = ia_uid ;
__entry - > ia_gid = ia_gid ;
) ,
TP_printk ( " %p %p %llu %.*s %u %u %u %u " , __entry - > inode ,
__entry - > dentry , __entry - > ino , __entry - > d_len ,
__get_str ( d_name ) , __entry - > ia_valid , __entry - > ia_mode ,
__entry - > ia_uid , __entry - > ia_gid )
) ;
DEFINE_OCFS2_ULL_UINT_EVENT ( ocfs2_write_remove_suid ) ;
DEFINE_OCFS2_ULL_ULL_ULL_EVENT ( ocfs2_zero_partial_clusters ) ;
DEFINE_OCFS2_ULL_ULL_EVENT ( ocfs2_zero_partial_clusters_range1 ) ;
DEFINE_OCFS2_ULL_ULL_EVENT ( ocfs2_zero_partial_clusters_range2 ) ;
DEFINE_OCFS2_ULL_ULL_ULL_EVENT ( ocfs2_remove_inode_range ) ;
TRACE_EVENT ( ocfs2_prepare_inode_for_write ,
TP_PROTO ( unsigned long long ino , unsigned long long saved_pos ,
int appending , unsigned long count ,
int * direct_io , int * has_refcount ) ,
TP_ARGS ( ino , saved_pos , appending , count , direct_io , has_refcount ) ,
TP_STRUCT__entry (
__field ( unsigned long long , ino )
__field ( unsigned long long , saved_pos )
__field ( int , appending )
__field ( unsigned long , count )
__field ( int , direct_io )
__field ( int , has_refcount )
) ,
TP_fast_assign (
__entry - > ino = ino ;
__entry - > saved_pos = saved_pos ;
__entry - > appending = appending ;
__entry - > count = count ;
__entry - > direct_io = direct_io ? * direct_io : - 1 ;
__entry - > has_refcount = has_refcount ? * has_refcount : - 1 ;
) ,
TP_printk ( " %llu %llu %d %lu %d %d " , __entry - > ino ,
__entry - > saved_pos , __entry - > appending , __entry - > count ,
__entry - > direct_io , __entry - > has_refcount )
) ;
DEFINE_OCFS2_INT_EVENT ( generic_file_aio_read_ret ) ;
/* End of trace events for fs/ocfs2/file.c. */
2011-02-22 22:24:57 +08:00
/* Trace events for fs/ocfs2/inode.c. */
TRACE_EVENT ( ocfs2_iget_begin ,
TP_PROTO ( unsigned long long ino , unsigned int flags , int sysfile_type ) ,
TP_ARGS ( ino , flags , sysfile_type ) ,
TP_STRUCT__entry (
__field ( unsigned long long , ino )
__field ( unsigned int , flags )
__field ( int , sysfile_type )
) ,
TP_fast_assign (
__entry - > ino = ino ;
__entry - > flags = flags ;
__entry - > sysfile_type = sysfile_type ;
) ,
TP_printk ( " %llu %u %d " , __entry - > ino ,
__entry - > flags , __entry - > sysfile_type )
) ;
DEFINE_OCFS2_ULL_EVENT ( ocfs2_iget5_locked ) ;
TRACE_EVENT ( ocfs2_iget_end ,
TP_PROTO ( void * inode , unsigned long long ino ) ,
TP_ARGS ( inode , ino ) ,
TP_STRUCT__entry (
__field ( void * , inode )
__field ( unsigned long long , ino )
) ,
TP_fast_assign (
__entry - > inode = inode ;
__entry - > ino = ino ;
) ,
TP_printk ( " %p %llu " , __entry - > inode , __entry - > ino )
) ;
TRACE_EVENT ( ocfs2_find_actor ,
TP_PROTO ( void * inode , unsigned long long ino ,
void * args , unsigned long long fi_blkno ) ,
TP_ARGS ( inode , ino , args , fi_blkno ) ,
TP_STRUCT__entry (
__field ( void * , inode )
__field ( unsigned long long , ino )
__field ( void * , args )
__field ( unsigned long long , fi_blkno )
) ,
TP_fast_assign (
__entry - > inode = inode ;
__entry - > ino = ino ;
__entry - > args = args ;
__entry - > fi_blkno = fi_blkno ;
) ,
TP_printk ( " %p %llu %p %llu " , __entry - > inode , __entry - > ino ,
__entry - > args , __entry - > fi_blkno )
) ;
DEFINE_OCFS2_ULL_UINT_EVENT ( ocfs2_populate_inode ) ;
DEFINE_OCFS2_ULL_INT_EVENT ( ocfs2_read_locked_inode ) ;
DEFINE_OCFS2_INT_INT_EVENT ( ocfs2_check_orphan_recovery_state ) ;
DEFINE_OCFS2_ULL_EVENT ( ocfs2_validate_inode_block ) ;
TRACE_EVENT ( ocfs2_inode_is_valid_to_delete ,
TP_PROTO ( void * task , void * dc_task , unsigned long long ino ,
unsigned int flags ) ,
TP_ARGS ( task , dc_task , ino , flags ) ,
TP_STRUCT__entry (
__field ( void * , task )
__field ( void * , dc_task )
__field ( unsigned long long , ino )
__field ( unsigned int , flags )
) ,
TP_fast_assign (
__entry - > task = task ;
__entry - > dc_task = dc_task ;
__entry - > ino = ino ;
__entry - > flags = flags ;
) ,
TP_printk ( " %p %p %llu %u " , __entry - > task , __entry - > dc_task ,
__entry - > ino , __entry - > flags )
) ;
DEFINE_OCFS2_ULL_UINT_EVENT ( ocfs2_query_inode_wipe_begin ) ;
DEFINE_OCFS2_UINT_EVENT ( ocfs2_query_inode_wipe_succ ) ;
DEFINE_OCFS2_INT_INT_EVENT ( ocfs2_query_inode_wipe_end ) ;
DEFINE_OCFS2_ULL_INT_EVENT ( ocfs2_cleanup_delete_inode ) ;
DEFINE_OCFS2_ULL_ULL_UINT_EVENT ( ocfs2_delete_inode ) ;
DEFINE_OCFS2_ULL_UINT_EVENT ( ocfs2_clear_inode ) ;
DEFINE_OCFS2_ULL_UINT_UINT_EVENT ( ocfs2_drop_inode ) ;
TRACE_EVENT ( ocfs2_inode_revalidate ,
TP_PROTO ( void * inode , unsigned long long ino ,
unsigned int flags ) ,
TP_ARGS ( inode , ino , flags ) ,
TP_STRUCT__entry (
__field ( void * , inode )
__field ( unsigned long long , ino )
__field ( unsigned int , flags )
) ,
TP_fast_assign (
__entry - > inode = inode ;
__entry - > ino = ino ;
__entry - > flags = flags ;
) ,
TP_printk ( " %p %llu %u " , __entry - > inode , __entry - > ino , __entry - > flags )
) ;
DEFINE_OCFS2_ULL_EVENT ( ocfs2_mark_inode_dirty ) ;
/* End of trace events for fs/ocfs2/inode.c. */
2011-02-22 22:27:33 +08:00
/* Trace events for fs/ocfs2/extent_map.c. */
TRACE_EVENT ( ocfs2_read_virt_blocks ,
TP_PROTO ( void * inode , unsigned long long vblock , int nr ,
void * bhs , unsigned int flags , void * validate ) ,
TP_ARGS ( inode , vblock , nr , bhs , flags , validate ) ,
TP_STRUCT__entry (
__field ( void * , inode )
__field ( unsigned long long , vblock )
__field ( int , nr )
__field ( void * , bhs )
__field ( unsigned int , flags )
__field ( void * , validate )
) ,
TP_fast_assign (
__entry - > inode = inode ;
__entry - > vblock = vblock ;
__entry - > nr = nr ;
__entry - > bhs = bhs ;
__entry - > flags = flags ;
__entry - > validate = validate ;
) ,
TP_printk ( " %p %llu %d %p %x %p " , __entry - > inode , __entry - > vblock ,
__entry - > nr , __entry - > bhs , __entry - > flags , __entry - > validate )
) ;
/* End of trace events for fs/ocfs2/extent_map.c. */
2011-02-22 22:29:08 +08:00
/* Trace events for fs/ocfs2/slot_map.c. */
DEFINE_OCFS2_UINT_EVENT ( ocfs2_refresh_slot_info ) ;
DEFINE_OCFS2_ULL_UINT_EVENT ( ocfs2_map_slot_buffers ) ;
DEFINE_OCFS2_ULL_UINT_EVENT ( ocfs2_map_slot_buffers_block ) ;
DEFINE_OCFS2_INT_EVENT ( ocfs2_find_slot ) ;
/* End of trace events for fs/ocfs2/slot_map.c. */
2011-02-23 21:17:39 +08:00
/* Trace events for fs/ocfs2/heartbeat.c. */
DEFINE_OCFS2_INT_EVENT ( ocfs2_do_node_down ) ;
/* End of trace events for fs/ocfs2/heartbeat.c. */
2011-02-23 21:29:08 +08:00
/* Trace events for fs/ocfs2/super.c. */
TRACE_EVENT ( ocfs2_remount ,
TP_PROTO ( unsigned long s_flags , unsigned long osb_flags , int flags ) ,
TP_ARGS ( s_flags , osb_flags , flags ) ,
TP_STRUCT__entry (
__field ( unsigned long , s_flags )
__field ( unsigned long , osb_flags )
__field ( int , flags )
) ,
TP_fast_assign (
__entry - > s_flags = s_flags ;
__entry - > osb_flags = osb_flags ;
__entry - > flags = flags ;
) ,
TP_printk ( " %lu %lu %d " , __entry - > s_flags ,
__entry - > osb_flags , __entry - > flags )
) ;
TRACE_EVENT ( ocfs2_fill_super ,
TP_PROTO ( void * sb , void * data , int silent ) ,
TP_ARGS ( sb , data , silent ) ,
TP_STRUCT__entry (
__field ( void * , sb )
__field ( void * , data )
__field ( int , silent )
) ,
TP_fast_assign (
__entry - > sb = sb ;
__entry - > data = data ;
__entry - > silent = silent ;
) ,
TP_printk ( " %p %p %d " , __entry - > sb ,
__entry - > data , __entry - > silent )
) ;
TRACE_EVENT ( ocfs2_parse_options ,
TP_PROTO ( int is_remount , char * options ) ,
TP_ARGS ( is_remount , options ) ,
TP_STRUCT__entry (
__field ( int , is_remount )
__string ( options , options )
) ,
TP_fast_assign (
__entry - > is_remount = is_remount ;
__assign_str ( options , options ) ;
) ,
TP_printk ( " %d %s " , __entry - > is_remount , __get_str ( options ) )
) ;
DEFINE_OCFS2_POINTER_EVENT ( ocfs2_put_super ) ;
TRACE_EVENT ( ocfs2_statfs ,
TP_PROTO ( void * sb , void * buf ) ,
TP_ARGS ( sb , buf ) ,
TP_STRUCT__entry (
__field ( void * , sb )
__field ( void * , buf )
) ,
TP_fast_assign (
__entry - > sb = sb ;
__entry - > buf = buf ;
) ,
TP_printk ( " %p %p " , __entry - > sb , __entry - > buf )
) ;
DEFINE_OCFS2_POINTER_EVENT ( ocfs2_dismount_volume ) ;
TRACE_EVENT ( ocfs2_initialize_super ,
TP_PROTO ( char * label , char * uuid_str , unsigned long long root_dir ,
unsigned long long system_dir , int cluster_bits ) ,
TP_ARGS ( label , uuid_str , root_dir , system_dir , cluster_bits ) ,
TP_STRUCT__entry (
__string ( label , label )
__string ( uuid_str , uuid_str )
__field ( unsigned long long , root_dir )
__field ( unsigned long long , system_dir )
__field ( int , cluster_bits )
) ,
TP_fast_assign (
__assign_str ( label , label ) ;
__assign_str ( uuid_str , uuid_str ) ;
__entry - > root_dir = root_dir ;
__entry - > system_dir = system_dir ;
__entry - > cluster_bits = cluster_bits ;
) ,
TP_printk ( " %s %s %llu %llu %d " , __get_str ( label ) , __get_str ( uuid_str ) ,
__entry - > root_dir , __entry - > system_dir , __entry - > cluster_bits )
) ;
/* End of trace events for fs/ocfs2/super.c. */
2011-02-23 22:01:17 +08:00
/* Trace events for fs/ocfs2/xattr.c. */
DEFINE_OCFS2_ULL_EVENT ( ocfs2_validate_xattr_block ) ;
DEFINE_OCFS2_UINT_EVENT ( ocfs2_xattr_extend_allocation ) ;
TRACE_EVENT ( ocfs2_init_xattr_set_ctxt ,
TP_PROTO ( const char * name , int meta , int clusters , int credits ) ,
TP_ARGS ( name , meta , clusters , credits ) ,
TP_STRUCT__entry (
__string ( name , name )
__field ( int , meta )
__field ( int , clusters )
__field ( int , credits )
) ,
TP_fast_assign (
__assign_str ( name , name ) ;
__entry - > meta = meta ;
__entry - > clusters = clusters ;
__entry - > credits = credits ;
) ,
TP_printk ( " %s %d %d %d " , __get_str ( name ) , __entry - > meta ,
__entry - > clusters , __entry - > credits )
) ;
DECLARE_EVENT_CLASS ( ocfs2__xattr_find ,
TP_PROTO ( unsigned long long ino , const char * name , int name_index ,
unsigned int hash , unsigned long long location ,
int xe_index ) ,
TP_ARGS ( ino , name , name_index , hash , location , xe_index ) ,
TP_STRUCT__entry (
__field ( unsigned long long , ino )
__string ( name , name )
__field ( int , name_index )
__field ( unsigned int , hash )
__field ( unsigned long long , location )
__field ( int , xe_index )
) ,
TP_fast_assign (
__entry - > ino = ino ;
__assign_str ( name , name ) ;
__entry - > name_index = name_index ;
__entry - > hash = hash ;
__entry - > location = location ;
__entry - > xe_index = xe_index ;
) ,
TP_printk ( " %llu %s %d %u %llu %d " , __entry - > ino , __get_str ( name ) ,
__entry - > name_index , __entry - > hash , __entry - > location ,
__entry - > xe_index )
) ;
# define DEFINE_OCFS2_XATTR_FIND_EVENT(name) \
DEFINE_EVENT ( ocfs2__xattr_find , name , \
TP_PROTO ( unsigned long long ino , const char * name , int name_index , \
unsigned int hash , unsigned long long bucket , \
int xe_index ) , \
TP_ARGS ( ino , name , name_index , hash , bucket , xe_index ) )
DEFINE_OCFS2_XATTR_FIND_EVENT ( ocfs2_xattr_bucket_find ) ;
DEFINE_OCFS2_XATTR_FIND_EVENT ( ocfs2_xattr_index_block_find ) ;
DEFINE_OCFS2_XATTR_FIND_EVENT ( ocfs2_xattr_index_block_find_rec ) ;
DEFINE_OCFS2_ULL_ULL_UINT_EVENT ( ocfs2_iterate_xattr_buckets ) ;
DEFINE_OCFS2_ULL_UINT_EVENT ( ocfs2_iterate_xattr_bucket ) ;
DEFINE_OCFS2_ULL_ULL_EVENT ( ocfs2_cp_xattr_block_to_bucket_begin ) ;
DEFINE_OCFS2_UINT_UINT_UINT_EVENT ( ocfs2_cp_xattr_block_to_bucket_end ) ;
DEFINE_OCFS2_ULL_EVENT ( ocfs2_xattr_create_index_block_begin ) ;
DEFINE_OCFS2_ULL_EVENT ( ocfs2_xattr_create_index_block ) ;
DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT ( ocfs2_defrag_xattr_bucket ) ;
DEFINE_OCFS2_ULL_ULL_EVENT ( ocfs2_mv_xattr_bucket_cross_cluster ) ;
DEFINE_OCFS2_ULL_ULL_EVENT ( ocfs2_divide_xattr_bucket_begin ) ;
DEFINE_OCFS2_UINT_UINT_UINT_EVENT ( ocfs2_divide_xattr_bucket_move ) ;
DEFINE_OCFS2_ULL_ULL_UINT_EVENT ( ocfs2_cp_xattr_bucket ) ;
DEFINE_OCFS2_ULL_ULL_EVENT ( ocfs2_mv_xattr_buckets ) ;
DEFINE_OCFS2_ULL_ULL_UINT_EVENT ( ocfs2_adjust_xattr_cross_cluster ) ;
DEFINE_OCFS2_ULL_ULL_UINT_UINT_EVENT ( ocfs2_add_new_xattr_cluster_begin ) ;
DEFINE_OCFS2_ULL_UINT_EVENT ( ocfs2_add_new_xattr_cluster ) ;
DEFINE_OCFS2_ULL_UINT_UINT_EVENT ( ocfs2_add_new_xattr_cluster_insert ) ;
DEFINE_OCFS2_ULL_ULL_UINT_UINT_EVENT ( ocfs2_extend_xattr_bucket ) ;
DEFINE_OCFS2_ULL_EVENT ( ocfs2_add_new_xattr_bucket ) ;
DEFINE_OCFS2_ULL_UINT_UINT_EVENT ( ocfs2_xattr_bucket_value_truncate ) ;
DEFINE_OCFS2_ULL_ULL_UINT_UINT_EVENT ( ocfs2_rm_xattr_cluster ) ;
DEFINE_OCFS2_ULL_UINT_EVENT ( ocfs2_reflink_xattr_header ) ;
DEFINE_OCFS2_ULL_INT_EVENT ( ocfs2_create_empty_xattr_block ) ;
DEFINE_OCFS2_STRING_EVENT ( ocfs2_xattr_set_entry_bucket ) ;
DEFINE_OCFS2_STRING_EVENT ( ocfs2_xattr_set_entry_index_block ) ;
DEFINE_OCFS2_ULL_UINT_EVENT ( ocfs2_xattr_bucket_value_refcount ) ;
DEFINE_OCFS2_ULL_UINT_UINT_EVENT ( ocfs2_reflink_xattr_buckets ) ;
DEFINE_OCFS2_ULL_UINT_EVENT ( ocfs2_reflink_xattr_rec ) ;
/* End of trace events for fs/ocfs2/xattr.c. */
2011-02-23 22:10:56 +08:00
/* Trace events for fs/ocfs2/reservations.c. */
DEFINE_OCFS2_UINT_UINT_EVENT ( ocfs2_resv_insert ) ;
DEFINE_OCFS2_ULL_UINT_UINT_UINT_EVENT ( ocfs2_resmap_find_free_bits_begin ) ;
DEFINE_OCFS2_UINT_UINT_EVENT ( ocfs2_resmap_find_free_bits_end ) ;
TRACE_EVENT ( ocfs2_resv_find_window_begin ,
TP_PROTO ( unsigned int r_start , unsigned int r_end , unsigned int goal ,
unsigned int wanted , int empty_root ) ,
TP_ARGS ( r_start , r_end , goal , wanted , empty_root ) ,
TP_STRUCT__entry (
__field ( unsigned int , r_start )
__field ( unsigned int , r_end )
__field ( unsigned int , goal )
__field ( unsigned int , wanted )
__field ( int , empty_root )
) ,
TP_fast_assign (
__entry - > r_start = r_start ;
__entry - > r_end = r_end ;
__entry - > goal = goal ;
__entry - > wanted = wanted ;
__entry - > empty_root = empty_root ;
) ,
TP_printk ( " %u %u %u %u %d " , __entry - > r_start , __entry - > r_end ,
__entry - > goal , __entry - > wanted , __entry - > empty_root )
) ;
DEFINE_OCFS2_UINT_UINT_EVENT ( ocfs2_resv_find_window_prev ) ;
DEFINE_OCFS2_INT_INT_EVENT ( ocfs2_resv_find_window_next ) ;
DEFINE_OCFS2_UINT_UINT_UINT_EVENT ( ocfs2_cannibalize_resv_begin ) ;
TRACE_EVENT ( ocfs2_cannibalize_resv_end ,
TP_PROTO ( unsigned int start , unsigned int end , unsigned int len ,
unsigned int last_start , unsigned int last_len ) ,
TP_ARGS ( start , end , len , last_start , last_len ) ,
TP_STRUCT__entry (
__field ( unsigned int , start )
__field ( unsigned int , end )
__field ( unsigned int , len )
__field ( unsigned int , last_start )
__field ( unsigned int , last_len )
) ,
TP_fast_assign (
__entry - > start = start ;
__entry - > end = end ;
__entry - > len = len ;
__entry - > last_start = last_start ;
__entry - > last_len = last_len ;
) ,
TP_printk ( " %u %u %u %u %u " , __entry - > start , __entry - > end ,
__entry - > len , __entry - > last_start , __entry - > last_len )
) ;
DEFINE_OCFS2_UINT_UINT_EVENT ( ocfs2_resmap_resv_bits ) ;
TRACE_EVENT ( ocfs2_resmap_claimed_bits_begin ,
TP_PROTO ( unsigned int cstart , unsigned int cend , unsigned int clen ,
unsigned int r_start , unsigned int r_end , unsigned int r_len ,
unsigned int last_start , unsigned int last_len ) ,
TP_ARGS ( cstart , cend , clen , r_start , r_end ,
r_len , last_start , last_len ) ,
TP_STRUCT__entry (
__field ( unsigned int , cstart )
__field ( unsigned int , cend )
__field ( unsigned int , clen )
__field ( unsigned int , r_start )
__field ( unsigned int , r_end )
__field ( unsigned int , r_len )
__field ( unsigned int , last_start )
__field ( unsigned int , last_len )
) ,
TP_fast_assign (
__entry - > cstart = cstart ;
__entry - > cend = cend ;
__entry - > clen = clen ;
__entry - > r_start = r_start ;
__entry - > r_end = r_end ;
__entry - > r_len = r_len ;
__entry - > last_start = last_start ;
__entry - > last_len = last_len ;
) ,
TP_printk ( " %u %u %u %u %u %u %u %u " ,
__entry - > cstart , __entry - > cend , __entry - > clen ,
__entry - > r_start , __entry - > r_end , __entry - > r_len ,
__entry - > last_start , __entry - > last_len )
) ;
TRACE_EVENT ( ocfs2_resmap_claimed_bits_end ,
TP_PROTO ( unsigned int start , unsigned int end , unsigned int len ,
unsigned int last_start , unsigned int last_len ) ,
TP_ARGS ( start , end , len , last_start , last_len ) ,
TP_STRUCT__entry (
__field ( unsigned int , start )
__field ( unsigned int , end )
__field ( unsigned int , len )
__field ( unsigned int , last_start )
__field ( unsigned int , last_len )
) ,
TP_fast_assign (
__entry - > start = start ;
__entry - > end = end ;
__entry - > len = len ;
__entry - > last_start = last_start ;
__entry - > last_len = last_len ;
) ,
TP_printk ( " %u %u %u %u %u " , __entry - > start , __entry - > end ,
__entry - > len , __entry - > last_start , __entry - > last_len )
) ;
/* End of trace events for fs/ocfs2/reservations.c. */
2011-02-23 22:12:48 +08:00
/* Trace events for fs/ocfs2/quota_local.c. */
DEFINE_OCFS2_ULL_UINT_EVENT ( ocfs2_recover_local_quota_file ) ;
DEFINE_OCFS2_INT_EVENT ( ocfs2_finish_quota_recovery ) ;
DEFINE_OCFS2_ULL_ULL_UINT_EVENT ( olq_set_dquot ) ;
/* End of trace events for fs/ocfs2/quota_local.c. */
2011-02-23 22:19:12 +08:00
/* Trace events for fs/ocfs2/quota_global.c. */
DEFINE_OCFS2_ULL_EVENT ( ocfs2_validate_quota_block ) ;
TRACE_EVENT ( ocfs2_sync_dquot ,
TP_PROTO ( unsigned int dq_id , long long dqb_curspace ,
long long spacechange , long long curinodes ,
long long inodechange ) ,
TP_ARGS ( dq_id , dqb_curspace , spacechange , curinodes , inodechange ) ,
TP_STRUCT__entry (
__field ( unsigned int , dq_id )
__field ( long long , dqb_curspace )
__field ( long long , spacechange )
__field ( long long , curinodes )
__field ( long long , inodechange )
) ,
TP_fast_assign (
__entry - > dq_id = dq_id ;
__entry - > dqb_curspace = dqb_curspace ;
__entry - > spacechange = spacechange ;
__entry - > curinodes = curinodes ;
__entry - > inodechange = inodechange ;
) ,
TP_printk ( " %u %lld %lld %lld %lld " , __entry - > dq_id ,
__entry - > dqb_curspace , __entry - > spacechange ,
__entry - > curinodes , __entry - > inodechange )
) ;
TRACE_EVENT ( ocfs2_sync_dquot_helper ,
TP_PROTO ( unsigned int dq_id , unsigned int dq_type , unsigned long type ,
const char * s_id ) ,
TP_ARGS ( dq_id , dq_type , type , s_id ) ,
TP_STRUCT__entry (
__field ( unsigned int , dq_id )
__field ( unsigned int , dq_type )
__field ( unsigned long , type )
__string ( s_id , s_id )
) ,
TP_fast_assign (
__entry - > dq_id = dq_id ;
__entry - > dq_type = dq_type ;
__entry - > type = type ;
__assign_str ( s_id , s_id ) ;
) ,
TP_printk ( " %u %u %lu %s " , __entry - > dq_id , __entry - > dq_type ,
__entry - > type , __get_str ( s_id ) )
) ;
DEFINE_OCFS2_UINT_INT_EVENT ( ocfs2_write_dquot ) ;
DEFINE_OCFS2_UINT_INT_EVENT ( ocfs2_release_dquot ) ;
DEFINE_OCFS2_UINT_INT_EVENT ( ocfs2_acquire_dquot ) ;
DEFINE_OCFS2_UINT_INT_EVENT ( ocfs2_mark_dquot_dirty ) ;
/* End of trace events for fs/ocfs2/quota_global.c. */
2011-02-23 22:30:23 +08:00
/* Trace events for fs/ocfs2/dir.c. */
DEFINE_OCFS2_INT_EVENT ( ocfs2_search_dirblock ) ;
DEFINE_OCFS2_ULL_EVENT ( ocfs2_validate_dir_block ) ;
DEFINE_OCFS2_POINTER_EVENT ( ocfs2_find_entry_el ) ;
TRACE_EVENT ( ocfs2_dx_dir_search ,
TP_PROTO ( unsigned long long ino , int namelen , const char * name ,
unsigned int major_hash , unsigned int minor_hash ,
unsigned long long blkno ) ,
TP_ARGS ( ino , namelen , name , major_hash , minor_hash , blkno ) ,
TP_STRUCT__entry (
__field ( unsigned long long , ino )
__field ( int , namelen )
__string ( name , name )
__field ( unsigned int , major_hash )
__field ( unsigned int , minor_hash )
__field ( unsigned long long , blkno )
) ,
TP_fast_assign (
__entry - > ino = ino ;
__entry - > namelen = namelen ;
__assign_str ( name , name ) ;
__entry - > major_hash = major_hash ;
__entry - > minor_hash = minor_hash ;
__entry - > blkno = blkno ;
) ,
TP_printk ( " %llu %.*s %u %u %llu " , __entry - > ino ,
__entry - > namelen , __get_str ( name ) ,
__entry - > major_hash , __entry - > minor_hash , __entry - > blkno )
) ;
DEFINE_OCFS2_UINT_UINT_EVENT ( ocfs2_dx_dir_search_leaf_info ) ;
DEFINE_OCFS2_ULL_INT_EVENT ( ocfs2_delete_entry_dx ) ;
DEFINE_OCFS2_ULL_EVENT ( ocfs2_readdir ) ;
TRACE_EVENT ( ocfs2_find_files_on_disk ,
TP_PROTO ( int namelen , const char * name , void * blkno ,
unsigned long long dir ) ,
TP_ARGS ( namelen , name , blkno , dir ) ,
TP_STRUCT__entry (
__field ( int , namelen )
__string ( name , name )
__field ( void * , blkno )
__field ( unsigned long long , dir )
) ,
TP_fast_assign (
__entry - > namelen = namelen ;
__assign_str ( name , name ) ;
__entry - > blkno = blkno ;
__entry - > dir = dir ;
) ,
TP_printk ( " %.*s %p %llu " , __entry - > namelen , __get_str ( name ) ,
__entry - > blkno , __entry - > dir )
) ;
TRACE_EVENT ( ocfs2_check_dir_for_entry ,
TP_PROTO ( unsigned long long dir , int namelen , const char * name ) ,
TP_ARGS ( dir , namelen , name ) ,
TP_STRUCT__entry (
__field ( unsigned long long , dir )
__field ( int , namelen )
__string ( name , name )
) ,
TP_fast_assign (
__entry - > dir = dir ;
__entry - > namelen = namelen ;
__assign_str ( name , name ) ;
) ,
TP_printk ( " %llu %.*s " , __entry - > dir ,
__entry - > namelen , __get_str ( name ) )
) ;
DEFINE_OCFS2_ULL_ULL_EVENT ( ocfs2_dx_dir_attach_index ) ;
DEFINE_OCFS2_ULL_ULL_UINT_EVENT ( ocfs2_dx_dir_format_cluster ) ;
TRACE_EVENT ( ocfs2_dx_dir_index_root_block ,
TP_PROTO ( unsigned long long dir ,
unsigned int major_hash , unsigned int minor_hash ,
int namelen , const char * name , unsigned int num_used ) ,
TP_ARGS ( dir , major_hash , minor_hash , namelen , name , num_used ) ,
TP_STRUCT__entry (
__field ( unsigned long long , dir )
__field ( unsigned int , major_hash )
__field ( unsigned int , minor_hash )
__field ( int , namelen )
__string ( name , name )
__field ( unsigned int , num_used )
) ,
TP_fast_assign (
__entry - > dir = dir ;
__entry - > major_hash = major_hash ;
__entry - > minor_hash = minor_hash ;
__entry - > namelen = namelen ;
__assign_str ( name , name ) ;
__entry - > num_used = num_used ;
) ,
TP_printk ( " %llu %x %x %.*s %u " , __entry - > dir ,
__entry - > major_hash , __entry - > minor_hash ,
__entry - > namelen , __get_str ( name ) , __entry - > num_used )
) ;
DEFINE_OCFS2_ULL_ULL_EVENT ( ocfs2_extend_dir ) ;
DEFINE_OCFS2_ULL_ULL_UINT_EVENT ( ocfs2_dx_dir_rebalance ) ;
DEFINE_OCFS2_UINT_UINT_UINT_EVENT ( ocfs2_dx_dir_rebalance_split ) ;
DEFINE_OCFS2_ULL_INT_EVENT ( ocfs2_prepare_dir_for_insert ) ;
/* End of trace events for fs/ocfs2/dir.c. */
2011-02-23 22:45:26 +08:00
/* Trace events for fs/ocfs2/namei.c. */
DECLARE_EVENT_CLASS ( ocfs2__dentry_ops ,
TP_PROTO ( void * dir , void * dentry , int name_len , const char * name ,
unsigned long long dir_blkno , unsigned long long extra ) ,
TP_ARGS ( dir , dentry , name_len , name , dir_blkno , extra ) ,
TP_STRUCT__entry (
__field ( void * , dir )
__field ( void * , dentry )
__field ( int , name_len )
__string ( name , name )
__field ( unsigned long long , dir_blkno )
__field ( unsigned long long , extra )
) ,
TP_fast_assign (
__entry - > dir = dir ;
__entry - > dentry = dentry ;
__entry - > name_len = name_len ;
__assign_str ( name , name ) ;
__entry - > dir_blkno = dir_blkno ;
__entry - > extra = extra ;
) ,
TP_printk ( " %p %p %.*s %llu %llu " , __entry - > dir , __entry - > dentry ,
__entry - > name_len , __get_str ( name ) ,
__entry - > dir_blkno , __entry - > extra )
) ;
# define DEFINE_OCFS2_DENTRY_OPS(name) \
DEFINE_EVENT ( ocfs2__dentry_ops , name , \
TP_PROTO ( void * dir , void * dentry , int name_len , const char * name , \
unsigned long long dir_blkno , unsigned long long extra ) , \
TP_ARGS ( dir , dentry , name_len , name , dir_blkno , extra ) )
DEFINE_OCFS2_DENTRY_OPS ( ocfs2_lookup ) ;
DEFINE_OCFS2_DENTRY_OPS ( ocfs2_mkdir ) ;
DEFINE_OCFS2_DENTRY_OPS ( ocfs2_create ) ;
DEFINE_OCFS2_DENTRY_OPS ( ocfs2_unlink ) ;
DEFINE_OCFS2_DENTRY_OPS ( ocfs2_symlink_create ) ;
DEFINE_OCFS2_DENTRY_OPS ( ocfs2_mv_orphaned_inode_to_new ) ;
DEFINE_OCFS2_POINTER_EVENT ( ocfs2_lookup_ret ) ;
TRACE_EVENT ( ocfs2_mknod ,
TP_PROTO ( void * dir , void * dentry , int name_len , const char * name ,
unsigned long long dir_blkno , unsigned long dev , int mode ) ,
TP_ARGS ( dir , dentry , name_len , name , dir_blkno , dev , mode ) ,
TP_STRUCT__entry (
__field ( void * , dir )
__field ( void * , dentry )
__field ( int , name_len )
__string ( name , name )
__field ( unsigned long long , dir_blkno )
__field ( unsigned long , dev )
__field ( int , mode )
) ,
TP_fast_assign (
__entry - > dir = dir ;
__entry - > dentry = dentry ;
__entry - > name_len = name_len ;
__assign_str ( name , name ) ;
__entry - > dir_blkno = dir_blkno ;
__entry - > dev = dev ;
__entry - > mode = mode ;
) ,
TP_printk ( " %p %p %.*s %llu %lu %d " , __entry - > dir , __entry - > dentry ,
__entry - > name_len , __get_str ( name ) ,
__entry - > dir_blkno , __entry - > dev , __entry - > mode )
) ;
TRACE_EVENT ( ocfs2_link ,
TP_PROTO ( unsigned long long ino , int old_len , const char * old_name ,
int name_len , const char * name ) ,
TP_ARGS ( ino , old_len , old_name , name_len , name ) ,
TP_STRUCT__entry (
__field ( unsigned long long , ino )
__field ( int , old_len )
__string ( old_name , old_name )
__field ( int , name_len )
__string ( name , name )
) ,
TP_fast_assign (
__entry - > ino = ino ;
__entry - > old_len = old_len ;
__assign_str ( old_name , old_name ) ;
__entry - > name_len = name_len ;
__assign_str ( name , name ) ;
) ,
TP_printk ( " %llu %.*s %.*s " , __entry - > ino ,
__entry - > old_len , __get_str ( old_name ) ,
__entry - > name_len , __get_str ( name ) )
) ;
DEFINE_OCFS2_ULL_ULL_UINT_EVENT ( ocfs2_unlink_noent ) ;
DEFINE_OCFS2_ULL_ULL_EVENT ( ocfs2_double_lock ) ;
DEFINE_OCFS2_ULL_ULL_EVENT ( ocfs2_double_lock_end ) ;
TRACE_EVENT ( ocfs2_rename ,
TP_PROTO ( void * old_dir , void * old_dentry ,
void * new_dir , void * new_dentry ,
int old_len , const char * old_name ,
int new_len , const char * new_name ) ,
TP_ARGS ( old_dir , old_dentry , new_dir , new_dentry ,
old_len , old_name , new_len , new_name ) ,
TP_STRUCT__entry (
__field ( void * , old_dir )
__field ( void * , old_dentry )
__field ( void * , new_dir )
__field ( void * , new_dentry )
__field ( int , old_len )
__string ( old_name , old_name )
__field ( int , new_len )
__string ( new_name , new_name )
) ,
TP_fast_assign (
__entry - > old_dir = old_dir ;
__entry - > old_dentry = old_dentry ;
__entry - > new_dir = new_dir ;
__entry - > new_dentry = new_dentry ;
__entry - > old_len = old_len ;
__assign_str ( old_name , old_name ) ;
__entry - > new_len = new_len ;
__assign_str ( new_name , new_name ) ;
) ,
TP_printk ( " %p %p %p %p %.*s %.*s " ,
__entry - > old_dir , __entry - > old_dentry ,
__entry - > new_dir , __entry - > new_dentry ,
__entry - > old_len , __get_str ( old_name ) ,
__entry - > new_len , __get_str ( new_name ) )
) ;
TRACE_EVENT ( ocfs2_rename_target_exists ,
TP_PROTO ( int new_len , const char * new_name ) ,
TP_ARGS ( new_len , new_name ) ,
TP_STRUCT__entry (
__field ( int , new_len )
__string ( new_name , new_name )
) ,
TP_fast_assign (
__entry - > new_len = new_len ;
__assign_str ( new_name , new_name ) ;
) ,
TP_printk ( " %.*s " , __entry - > new_len , __get_str ( new_name ) )
) ;
DEFINE_OCFS2_ULL_ULL_UINT_EVENT ( ocfs2_rename_disagree ) ;
TRACE_EVENT ( ocfs2_rename_over_existing ,
TP_PROTO ( unsigned long long new_blkno , void * new_bh ,
unsigned long long newdi_blkno ) ,
TP_ARGS ( new_blkno , new_bh , newdi_blkno ) ,
TP_STRUCT__entry (
__field ( unsigned long long , new_blkno )
__field ( void * , new_bh )
__field ( unsigned long long , newdi_blkno )
) ,
TP_fast_assign (
__entry - > new_blkno = new_blkno ;
__entry - > new_bh = new_bh ;
__entry - > newdi_blkno = newdi_blkno ;
) ,
TP_printk ( " %llu %p %llu " , __entry - > new_blkno , __entry - > new_bh ,
__entry - > newdi_blkno )
) ;
DEFINE_OCFS2_ULL_ULL_UINT_EVENT ( ocfs2_create_symlink_data ) ;
TRACE_EVENT ( ocfs2_symlink_begin ,
TP_PROTO ( void * dir , void * dentry , const char * symname ,
int len , const char * name ) ,
TP_ARGS ( dir , dentry , symname , len , name ) ,
TP_STRUCT__entry (
__field ( void * , dir )
__field ( void * , dentry )
__field ( const char * , symname )
__field ( int , len )
__string ( name , name )
) ,
TP_fast_assign (
__entry - > dir = dir ;
__entry - > dentry = dentry ;
__entry - > symname = symname ;
__entry - > len = len ;
__assign_str ( name , name ) ;
) ,
TP_printk ( " %p %p %s %.*s " , __entry - > dir , __entry - > dentry ,
__entry - > symname , __entry - > len , __get_str ( name ) )
) ;
TRACE_EVENT ( ocfs2_blkno_stringify ,
TP_PROTO ( unsigned long long blkno , const char * name , int namelen ) ,
TP_ARGS ( blkno , name , namelen ) ,
TP_STRUCT__entry (
__field ( unsigned long long , blkno )
__string ( name , name )
__field ( int , namelen )
) ,
TP_fast_assign (
__entry - > blkno = blkno ;
__assign_str ( name , name ) ;
__entry - > namelen = namelen ;
) ,
TP_printk ( " %llu %s %d " , __entry - > blkno , __get_str ( name ) ,
__entry - > namelen )
) ;
DEFINE_OCFS2_ULL_EVENT ( ocfs2_orphan_add_begin ) ;
DEFINE_OCFS2_ULL_UINT_EVENT ( ocfs2_orphan_add_end ) ;
TRACE_EVENT ( ocfs2_orphan_del ,
TP_PROTO ( unsigned long long dir , const char * name , int namelen ) ,
TP_ARGS ( dir , name , namelen ) ,
TP_STRUCT__entry (
__field ( unsigned long long , dir )
__string ( name , name )
__field ( int , namelen )
) ,
TP_fast_assign (
__entry - > dir = dir ;
__assign_str ( name , name ) ;
__entry - > namelen = namelen ;
) ,
TP_printk ( " %llu %s %d " , __entry - > dir , __get_str ( name ) ,
__entry - > namelen )
) ;
/* End of trace events for fs/ocfs2/namei.c. */
2011-02-23 22:51:49 +08:00
/* Trace events for fs/ocfs2/dcache.c. */
TRACE_EVENT ( ocfs2_dentry_revalidate ,
TP_PROTO ( void * dentry , int len , const char * name ) ,
TP_ARGS ( dentry , len , name ) ,
TP_STRUCT__entry (
__field ( void * , dentry )
__field ( int , len )
__string ( name , name )
) ,
TP_fast_assign (
__entry - > dentry = dentry ;
__entry - > len = len ;
__assign_str ( name , name ) ;
) ,
TP_printk ( " %p %.*s " , __entry - > dentry , __entry - > len , __get_str ( name ) )
) ;
TRACE_EVENT ( ocfs2_dentry_revalidate_negative ,
TP_PROTO ( int len , const char * name , unsigned long pgen ,
unsigned long gen ) ,
TP_ARGS ( len , name , pgen , gen ) ,
TP_STRUCT__entry (
__field ( int , len )
__string ( name , name )
__field ( unsigned long , pgen )
__field ( unsigned long , gen )
) ,
TP_fast_assign (
__entry - > len = len ;
__assign_str ( name , name ) ;
__entry - > pgen = pgen ;
__entry - > gen = gen ;
) ,
TP_printk ( " %.*s %lu %lu " , __entry - > len , __get_str ( name ) ,
__entry - > pgen , __entry - > gen )
) ;
DEFINE_OCFS2_ULL_EVENT ( ocfs2_dentry_revalidate_delete ) ;
DEFINE_OCFS2_ULL_INT_EVENT ( ocfs2_dentry_revalidate_orphaned ) ;
DEFINE_OCFS2_ULL_EVENT ( ocfs2_dentry_revalidate_nofsdata ) ;
DEFINE_OCFS2_INT_EVENT ( ocfs2_dentry_revalidate_ret ) ;
TRACE_EVENT ( ocfs2_find_local_alias ,
TP_PROTO ( int len , const char * name ) ,
TP_ARGS ( len , name ) ,
TP_STRUCT__entry (
__field ( int , len )
__string ( name , name )
) ,
TP_fast_assign (
__entry - > len = len ;
__assign_str ( name , name ) ;
) ,
TP_printk ( " %.*s " , __entry - > len , __get_str ( name ) )
) ;
TRACE_EVENT ( ocfs2_dentry_attach_lock ,
TP_PROTO ( int len , const char * name ,
unsigned long long parent , void * fsdata ) ,
TP_ARGS ( len , name , parent , fsdata ) ,
TP_STRUCT__entry (
__field ( int , len )
__string ( name , name )
__field ( unsigned long long , parent )
__field ( void * , fsdata )
) ,
TP_fast_assign (
__entry - > len = len ;
__assign_str ( name , name ) ;
__entry - > parent = parent ;
__entry - > fsdata = fsdata ;
) ,
TP_printk ( " %.*s %llu %p " , __entry - > len , __get_str ( name ) ,
__entry - > parent , __entry - > fsdata )
) ;
TRACE_EVENT ( ocfs2_dentry_attach_lock_found ,
TP_PROTO ( const char * name , unsigned long long parent ,
unsigned long long ino ) ,
TP_ARGS ( name , parent , ino ) ,
TP_STRUCT__entry (
__string ( name , name )
__field ( unsigned long long , parent )
__field ( unsigned long long , ino )
) ,
TP_fast_assign (
__assign_str ( name , name ) ;
__entry - > parent = parent ;
__entry - > ino = ino ;
) ,
TP_printk ( " %s %llu %llu " , __get_str ( name ) , __entry - > parent , __entry - > ino )
) ;
/* End of trace events for fs/ocfs2/dcache.c. */
2011-02-24 13:50:19 +08:00
/* Trace events for fs/ocfs2/export.c. */
TRACE_EVENT ( ocfs2_get_dentry_begin ,
TP_PROTO ( void * sb , void * handle , unsigned long long blkno ) ,
TP_ARGS ( sb , handle , blkno ) ,
TP_STRUCT__entry (
__field ( void * , sb )
__field ( void * , handle )
__field ( unsigned long long , blkno )
) ,
TP_fast_assign (
__entry - > sb = sb ;
__entry - > handle = handle ;
__entry - > blkno = blkno ;
) ,
TP_printk ( " %p %p %llu " , __entry - > sb , __entry - > handle , __entry - > blkno )
) ;
DEFINE_OCFS2_INT_INT_EVENT ( ocfs2_get_dentry_test_bit ) ;
DEFINE_OCFS2_ULL_UINT_EVENT ( ocfs2_get_dentry_stale ) ;
DEFINE_OCFS2_ULL_UINT_UINT_EVENT ( ocfs2_get_dentry_generation ) ;
DEFINE_OCFS2_POINTER_EVENT ( ocfs2_get_dentry_end ) ;
TRACE_EVENT ( ocfs2_get_parent ,
TP_PROTO ( void * child , int len , const char * name ,
unsigned long long ino ) ,
TP_ARGS ( child , len , name , ino ) ,
TP_STRUCT__entry (
__field ( void * , child )
__field ( int , len )
__string ( name , name )
__field ( unsigned long long , ino )
) ,
TP_fast_assign (
__entry - > child = child ;
__entry - > len = len ;
__assign_str ( name , name ) ;
__entry - > ino = ino ;
) ,
TP_printk ( " %p %.*s %llu " , __entry - > child , __entry - > len ,
__get_str ( name ) , __entry - > ino )
) ;
DEFINE_OCFS2_POINTER_EVENT ( ocfs2_get_parent_end ) ;
TRACE_EVENT ( ocfs2_encode_fh_begin ,
TP_PROTO ( void * dentry , int name_len , const char * name ,
void * fh , int len , int connectable ) ,
TP_ARGS ( dentry , name_len , name , fh , len , connectable ) ,
TP_STRUCT__entry (
__field ( void * , dentry )
__field ( int , name_len )
__string ( name , name )
__field ( void * , fh )
__field ( int , len )
__field ( int , connectable )
) ,
TP_fast_assign (
__entry - > dentry = dentry ;
__entry - > name_len = name_len ;
__assign_str ( name , name ) ;
__entry - > fh = fh ;
__entry - > len = len ;
__entry - > connectable = connectable ;
) ,
TP_printk ( " %p %.*s %p %d %d " , __entry - > dentry , __entry - > name_len ,
__get_str ( name ) , __entry - > fh , __entry - > len ,
__entry - > connectable )
) ;
DEFINE_OCFS2_ULL_UINT_EVENT ( ocfs2_encode_fh_self ) ;
DEFINE_OCFS2_ULL_UINT_EVENT ( ocfs2_encode_fh_parent ) ;
DEFINE_OCFS2_INT_EVENT ( ocfs2_encode_fh_type ) ;
/* End of trace events for fs/ocfs2/export.c. */
2011-02-24 14:15:35 +08:00
/* Trace events for fs/ocfs2/journal.c. */
DEFINE_OCFS2_UINT_EVENT ( ocfs2_commit_cache_begin ) ;
DEFINE_OCFS2_ULL_UINT_EVENT ( ocfs2_commit_cache_end ) ;
DEFINE_OCFS2_INT_INT_EVENT ( ocfs2_extend_trans ) ;
DEFINE_OCFS2_INT_EVENT ( ocfs2_extend_trans_restart ) ;
ocfs2: lighten up allocate transaction
The issue scenario is as following:
When fallocating a very large disk space for a small file,
__ocfs2_extend_allocation attempts to get a very large transaction. For
some journal sizes, there may be not enough room for this transaction,
and the fallocate will fail.
The patch below extends & restarts the transaction as necessary while
allocating space, and should work with even the smallest journal. This
patch refers ext4 resize.
Test:
# mkfs.ocfs2 -b 4K -C 32K -T datafiles /dev/sdc
...(jounral size is 32M)
# mount.ocfs2 /dev/sdc /mnt/ocfs2/
# touch /mnt/ocfs2/1.log
# fallocate -o 0 -l 400G /mnt/ocfs2/1.log
fallocate: /mnt/ocfs2/1.log: fallocate failed: Cannot allocate memory
# tail -f /var/log/messages
[ 7372.278591] JBD: fallocate wants too many credits (2051 > 2048)
[ 7372.278597] (fallocate,6438,0):__ocfs2_extend_allocation:709 ERROR: status = -12
[ 7372.278603] (fallocate,6438,0):ocfs2_allocate_unwritten_extents:1504 ERROR: status = -12
[ 7372.278607] (fallocate,6438,0):__ocfs2_change_file_space:1955 ERROR: status = -12
^C
With this patch, the test works well.
Signed-off-by: Younger Liu <younger.liu@huawei.com>
Cc: Jie Liu <jeff.liu@oracle.com>
Cc: Joel Becker <jlbec@evilplan.org>
Cc: Mark Fasheh <mfasheh@suse.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2013-09-11 14:19:44 -07:00
DEFINE_OCFS2_INT_INT_EVENT ( ocfs2_allocate_extend_trans ) ;
2011-02-24 14:15:35 +08:00
DEFINE_OCFS2_ULL_ULL_UINT_UINT_EVENT ( ocfs2_journal_access ) ;
DEFINE_OCFS2_ULL_EVENT ( ocfs2_journal_dirty ) ;
DEFINE_OCFS2_ULL_ULL_UINT_EVENT ( ocfs2_journal_init ) ;
DEFINE_OCFS2_UINT_EVENT ( ocfs2_journal_init_maxlen ) ;
DEFINE_OCFS2_INT_EVENT ( ocfs2_journal_shutdown ) ;
DEFINE_OCFS2_POINTER_EVENT ( ocfs2_journal_shutdown_wait ) ;
DEFINE_OCFS2_ULL_EVENT ( ocfs2_complete_recovery ) ;
DEFINE_OCFS2_INT_EVENT ( ocfs2_complete_recovery_end ) ;
TRACE_EVENT ( ocfs2_complete_recovery_slot ,
TP_PROTO ( int slot , unsigned long long la_ino ,
unsigned long long tl_ino , void * qrec ) ,
TP_ARGS ( slot , la_ino , tl_ino , qrec ) ,
TP_STRUCT__entry (
__field ( int , slot )
__field ( unsigned long long , la_ino )
__field ( unsigned long long , tl_ino )
__field ( void * , qrec )
) ,
TP_fast_assign (
__entry - > slot = slot ;
__entry - > la_ino = la_ino ;
__entry - > tl_ino = tl_ino ;
__entry - > qrec = qrec ;
) ,
TP_printk ( " %d %llu %llu %p " , __entry - > slot , __entry - > la_ino ,
__entry - > tl_ino , __entry - > qrec )
) ;
DEFINE_OCFS2_INT_INT_EVENT ( ocfs2_recovery_thread_node ) ;
DEFINE_OCFS2_INT_EVENT ( ocfs2_recovery_thread_end ) ;
TRACE_EVENT ( ocfs2_recovery_thread ,
TP_PROTO ( int node_num , int osb_node_num , int disable ,
void * recovery_thread , int map_set ) ,
TP_ARGS ( node_num , osb_node_num , disable , recovery_thread , map_set ) ,
TP_STRUCT__entry (
__field ( int , node_num )
__field ( int , osb_node_num )
__field ( int , disable )
__field ( void * , recovery_thread )
__field ( int , map_set )
) ,
TP_fast_assign (
__entry - > node_num = node_num ;
__entry - > osb_node_num = osb_node_num ;
__entry - > disable = disable ;
__entry - > recovery_thread = recovery_thread ;
__entry - > map_set = map_set ;
) ,
TP_printk ( " %d %d %d %p %d " , __entry - > node_num ,
__entry - > osb_node_num , __entry - > disable ,
__entry - > recovery_thread , __entry - > map_set )
) ;
DEFINE_OCFS2_UINT_UINT_UINT_EVENT ( ocfs2_replay_journal_recovered ) ;
DEFINE_OCFS2_INT_EVENT ( ocfs2_replay_journal_lock_err ) ;
DEFINE_OCFS2_INT_EVENT ( ocfs2_replay_journal_skip ) ;
DEFINE_OCFS2_UINT_UINT_UINT_EVENT ( ocfs2_recover_node ) ;
DEFINE_OCFS2_UINT_UINT_EVENT ( ocfs2_recover_node_skip ) ;
DEFINE_OCFS2_UINT_UINT_EVENT ( ocfs2_mark_dead_nodes ) ;
DEFINE_OCFS2_UINT_UINT_UINT_EVENT ( ocfs2_queue_orphan_scan_begin ) ;
DEFINE_OCFS2_UINT_UINT_UINT_EVENT ( ocfs2_queue_orphan_scan_end ) ;
DEFINE_OCFS2_ULL_EVENT ( ocfs2_orphan_filldir ) ;
DEFINE_OCFS2_INT_EVENT ( ocfs2_recover_orphans ) ;
DEFINE_OCFS2_ULL_EVENT ( ocfs2_recover_orphans_iput ) ;
DEFINE_OCFS2_INT_EVENT ( ocfs2_wait_on_mount ) ;
/* End of trace events for fs/ocfs2/journal.c. */
2011-02-24 16:09:38 +08:00
/* Trace events for fs/ocfs2/buffer_head_io.c. */
DEFINE_OCFS2_ULL_UINT_EVENT ( ocfs2_read_blocks_sync ) ;
DEFINE_OCFS2_ULL_EVENT ( ocfs2_read_blocks_sync_jbd ) ;
2011-02-24 16:22:20 +08:00
DEFINE_OCFS2_ULL_ULL_EVENT ( ocfs2_read_blocks_from_disk ) ;
2011-02-24 16:09:38 +08:00
DEFINE_OCFS2_ULL_INT_INT_INT_EVENT ( ocfs2_read_blocks_bh ) ;
DEFINE_OCFS2_ULL_INT_INT_INT_EVENT ( ocfs2_read_blocks_end ) ;
TRACE_EVENT ( ocfs2_write_block ,
TP_PROTO ( unsigned long long block , void * ci ) ,
TP_ARGS ( block , ci ) ,
TP_STRUCT__entry (
__field ( unsigned long long , block )
__field ( void * , ci )
) ,
TP_fast_assign (
__entry - > block = block ;
__entry - > ci = ci ;
) ,
TP_printk ( " %llu %p " , __entry - > block , __entry - > ci )
) ;
TRACE_EVENT ( ocfs2_read_blocks_begin ,
TP_PROTO ( void * ci , unsigned long long block ,
unsigned int nr , int flags ) ,
TP_ARGS ( ci , block , nr , flags ) ,
TP_STRUCT__entry (
__field ( void * , ci )
__field ( unsigned long long , block )
__field ( unsigned int , nr )
__field ( int , flags )
) ,
TP_fast_assign (
__entry - > ci = ci ;
__entry - > block = block ;
__entry - > nr = nr ;
__entry - > flags = flags ;
) ,
TP_printk ( " %p %llu %u %d " , __entry - > ci , __entry - > block ,
__entry - > nr , __entry - > flags )
) ;
/* End of trace events for fs/ocfs2/buffer_head_io.c. */
2011-02-24 16:22:20 +08:00
/* Trace events for fs/ocfs2/uptodate.c. */
DEFINE_OCFS2_ULL_EVENT ( ocfs2_purge_copied_metadata_tree ) ;
DEFINE_OCFS2_ULL_UINT_UINT_EVENT ( ocfs2_metadata_cache_purge ) ;
DEFINE_OCFS2_ULL_ULL_UINT_EVENT ( ocfs2_buffer_cached_begin ) ;
TRACE_EVENT ( ocfs2_buffer_cached_end ,
TP_PROTO ( int index , void * item ) ,
TP_ARGS ( index , item ) ,
TP_STRUCT__entry (
__field ( int , index )
__field ( void * , item )
) ,
TP_fast_assign (
__entry - > index = index ;
__entry - > item = item ;
) ,
TP_printk ( " %d %p " , __entry - > index , __entry - > item )
) ;
DEFINE_OCFS2_ULL_ULL_UINT_EVENT ( ocfs2_append_cache_array ) ;
DEFINE_OCFS2_ULL_ULL_UINT_EVENT ( ocfs2_insert_cache_tree ) ;
DEFINE_OCFS2_ULL_UINT_UINT_EVENT ( ocfs2_expand_cache ) ;
DEFINE_OCFS2_ULL_UINT_UINT_EVENT ( ocfs2_set_buffer_uptodate ) ;
DEFINE_OCFS2_ULL_ULL_EVENT ( ocfs2_set_buffer_uptodate_begin ) ;
DEFINE_OCFS2_ULL_UINT_UINT_EVENT ( ocfs2_remove_metadata_array ) ;
DEFINE_OCFS2_ULL_ULL_EVENT ( ocfs2_remove_metadata_tree ) ;
DEFINE_OCFS2_ULL_ULL_UINT_UINT_EVENT ( ocfs2_remove_block_from_cache ) ;
/* End of trace events for fs/ocfs2/uptodate.c. */
2011-02-21 11:13:14 +08: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>