| 
									
										
										
										
											2010-07-07 13:24:06 +10:00
										 |  |  | #undef TRACE_SYSTEM
 | 
					
						
							|  |  |  | #define TRACE_SYSTEM writeback
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if !defined(_TRACE_WRITEBACK_H) || defined(TRACE_HEADER_MULTI_READ)
 | 
					
						
							|  |  |  | #define _TRACE_WRITEBACK_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <linux/backing-dev.h>
 | 
					
						
							| 
									
										
										
										
											2010-07-19 16:49:17 -07:00
										 |  |  | #include <linux/device.h>
 | 
					
						
							| 
									
										
										
										
											2010-07-07 13:24:06 +10:00
										 |  |  | #include <linux/writeback.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct wb_writeback_work; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | DECLARE_EVENT_CLASS(writeback_work_class, | 
					
						
							|  |  |  | 	TP_PROTO(struct backing_dev_info *bdi, struct wb_writeback_work *work), | 
					
						
							|  |  |  | 	TP_ARGS(bdi, work), | 
					
						
							|  |  |  | 	TP_STRUCT__entry( | 
					
						
							|  |  |  | 		__array(char, name, 32) | 
					
						
							|  |  |  | 		__field(long, nr_pages) | 
					
						
							|  |  |  | 		__field(dev_t, sb_dev) | 
					
						
							|  |  |  | 		__field(int, sync_mode) | 
					
						
							|  |  |  | 		__field(int, for_kupdate) | 
					
						
							|  |  |  | 		__field(int, range_cyclic) | 
					
						
							|  |  |  | 		__field(int, for_background) | 
					
						
							|  |  |  | 	), | 
					
						
							|  |  |  | 	TP_fast_assign( | 
					
						
							|  |  |  | 		strncpy(__entry->name, dev_name(bdi->dev), 32); | 
					
						
							|  |  |  | 		__entry->nr_pages = work->nr_pages; | 
					
						
							|  |  |  | 		__entry->sb_dev = work->sb ? work->sb->s_dev : 0; | 
					
						
							|  |  |  | 		__entry->sync_mode = work->sync_mode; | 
					
						
							|  |  |  | 		__entry->for_kupdate = work->for_kupdate; | 
					
						
							|  |  |  | 		__entry->range_cyclic = work->range_cyclic; | 
					
						
							|  |  |  | 		__entry->for_background	= work->for_background; | 
					
						
							|  |  |  | 	), | 
					
						
							|  |  |  | 	TP_printk("bdi %s: sb_dev %d:%d nr_pages=%ld sync_mode=%d " | 
					
						
							|  |  |  | 		  "kupdate=%d range_cyclic=%d background=%d", | 
					
						
							|  |  |  | 		  __entry->name, | 
					
						
							|  |  |  | 		  MAJOR(__entry->sb_dev), MINOR(__entry->sb_dev), | 
					
						
							|  |  |  | 		  __entry->nr_pages, | 
					
						
							|  |  |  | 		  __entry->sync_mode, | 
					
						
							|  |  |  | 		  __entry->for_kupdate, | 
					
						
							|  |  |  | 		  __entry->range_cyclic, | 
					
						
							|  |  |  | 		  __entry->for_background | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | ); | 
					
						
							|  |  |  | #define DEFINE_WRITEBACK_WORK_EVENT(name) \
 | 
					
						
							|  |  |  | DEFINE_EVENT(writeback_work_class, name, \ | 
					
						
							|  |  |  | 	TP_PROTO(struct backing_dev_info *bdi, struct wb_writeback_work *work), \ | 
					
						
							|  |  |  | 	TP_ARGS(bdi, work)) | 
					
						
							|  |  |  | DEFINE_WRITEBACK_WORK_EVENT(writeback_nothread); | 
					
						
							|  |  |  | DEFINE_WRITEBACK_WORK_EVENT(writeback_queue); | 
					
						
							|  |  |  | DEFINE_WRITEBACK_WORK_EVENT(writeback_exec); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TRACE_EVENT(writeback_pages_written, | 
					
						
							|  |  |  | 	TP_PROTO(long pages_written), | 
					
						
							|  |  |  | 	TP_ARGS(pages_written), | 
					
						
							|  |  |  | 	TP_STRUCT__entry( | 
					
						
							|  |  |  | 		__field(long,		pages) | 
					
						
							|  |  |  | 	), | 
					
						
							|  |  |  | 	TP_fast_assign( | 
					
						
							|  |  |  | 		__entry->pages		= pages_written; | 
					
						
							|  |  |  | 	), | 
					
						
							|  |  |  | 	TP_printk("%ld", __entry->pages) | 
					
						
							|  |  |  | ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | DECLARE_EVENT_CLASS(writeback_class, | 
					
						
							|  |  |  | 	TP_PROTO(struct backing_dev_info *bdi), | 
					
						
							|  |  |  | 	TP_ARGS(bdi), | 
					
						
							|  |  |  | 	TP_STRUCT__entry( | 
					
						
							|  |  |  | 		__array(char, name, 32) | 
					
						
							|  |  |  | 	), | 
					
						
							|  |  |  | 	TP_fast_assign( | 
					
						
							|  |  |  | 		strncpy(__entry->name, dev_name(bdi->dev), 32); | 
					
						
							|  |  |  | 	), | 
					
						
							|  |  |  | 	TP_printk("bdi %s", | 
					
						
							|  |  |  | 		  __entry->name | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | ); | 
					
						
							|  |  |  | #define DEFINE_WRITEBACK_EVENT(name) \
 | 
					
						
							|  |  |  | DEFINE_EVENT(writeback_class, name, \ | 
					
						
							|  |  |  | 	TP_PROTO(struct backing_dev_info *bdi), \ | 
					
						
							|  |  |  | 	TP_ARGS(bdi)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | DEFINE_WRITEBACK_EVENT(writeback_nowork); | 
					
						
							| 
									
										
										
										
											2010-07-25 14:29:24 +03:00
										 |  |  | DEFINE_WRITEBACK_EVENT(writeback_wake_thread); | 
					
						
							|  |  |  | DEFINE_WRITEBACK_EVENT(writeback_wake_forker_thread); | 
					
						
							| 
									
										
										
										
											2010-07-07 13:24:06 +10:00
										 |  |  | DEFINE_WRITEBACK_EVENT(writeback_bdi_register); | 
					
						
							|  |  |  | DEFINE_WRITEBACK_EVENT(writeback_bdi_unregister); | 
					
						
							|  |  |  | DEFINE_WRITEBACK_EVENT(writeback_thread_start); | 
					
						
							|  |  |  | DEFINE_WRITEBACK_EVENT(writeback_thread_stop); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-07 13:24:07 +10:00
										 |  |  | DECLARE_EVENT_CLASS(wbc_class, | 
					
						
							|  |  |  | 	TP_PROTO(struct writeback_control *wbc, struct backing_dev_info *bdi), | 
					
						
							|  |  |  | 	TP_ARGS(wbc, bdi), | 
					
						
							|  |  |  | 	TP_STRUCT__entry( | 
					
						
							|  |  |  | 		__array(char, name, 32) | 
					
						
							|  |  |  | 		__field(long, nr_to_write) | 
					
						
							|  |  |  | 		__field(long, pages_skipped) | 
					
						
							|  |  |  | 		__field(int, sync_mode) | 
					
						
							|  |  |  | 		__field(int, nonblocking) | 
					
						
							|  |  |  | 		__field(int, encountered_congestion) | 
					
						
							|  |  |  | 		__field(int, for_kupdate) | 
					
						
							|  |  |  | 		__field(int, for_background) | 
					
						
							|  |  |  | 		__field(int, for_reclaim) | 
					
						
							|  |  |  | 		__field(int, range_cyclic) | 
					
						
							|  |  |  | 		__field(int, more_io) | 
					
						
							|  |  |  | 		__field(unsigned long, older_than_this) | 
					
						
							|  |  |  | 		__field(long, range_start) | 
					
						
							|  |  |  | 		__field(long, range_end) | 
					
						
							|  |  |  | 	), | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	TP_fast_assign( | 
					
						
							|  |  |  | 		strncpy(__entry->name, dev_name(bdi->dev), 32); | 
					
						
							|  |  |  | 		__entry->nr_to_write	= wbc->nr_to_write; | 
					
						
							|  |  |  | 		__entry->pages_skipped	= wbc->pages_skipped; | 
					
						
							|  |  |  | 		__entry->sync_mode	= wbc->sync_mode; | 
					
						
							|  |  |  | 		__entry->for_kupdate	= wbc->for_kupdate; | 
					
						
							|  |  |  | 		__entry->for_background	= wbc->for_background; | 
					
						
							|  |  |  | 		__entry->for_reclaim	= wbc->for_reclaim; | 
					
						
							|  |  |  | 		__entry->range_cyclic	= wbc->range_cyclic; | 
					
						
							|  |  |  | 		__entry->more_io	= wbc->more_io; | 
					
						
							|  |  |  | 		__entry->older_than_this = wbc->older_than_this ? | 
					
						
							|  |  |  | 						*wbc->older_than_this : 0; | 
					
						
							|  |  |  | 		__entry->range_start	= (long)wbc->range_start; | 
					
						
							|  |  |  | 		__entry->range_end	= (long)wbc->range_end; | 
					
						
							|  |  |  | 	), | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	TP_printk("bdi %s: towrt=%ld skip=%ld mode=%d kupd=%d " | 
					
						
							|  |  |  | 		"bgrd=%d reclm=%d cyclic=%d more=%d older=0x%lx " | 
					
						
							|  |  |  | 		"start=0x%lx end=0x%lx", | 
					
						
							|  |  |  | 		__entry->name, | 
					
						
							|  |  |  | 		__entry->nr_to_write, | 
					
						
							|  |  |  | 		__entry->pages_skipped, | 
					
						
							|  |  |  | 		__entry->sync_mode, | 
					
						
							|  |  |  | 		__entry->for_kupdate, | 
					
						
							|  |  |  | 		__entry->for_background, | 
					
						
							|  |  |  | 		__entry->for_reclaim, | 
					
						
							|  |  |  | 		__entry->range_cyclic, | 
					
						
							|  |  |  | 		__entry->more_io, | 
					
						
							|  |  |  | 		__entry->older_than_this, | 
					
						
							|  |  |  | 		__entry->range_start, | 
					
						
							|  |  |  | 		__entry->range_end) | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define DEFINE_WBC_EVENT(name) \
 | 
					
						
							|  |  |  | DEFINE_EVENT(wbc_class, name, \ | 
					
						
							|  |  |  | 	TP_PROTO(struct writeback_control *wbc, struct backing_dev_info *bdi), \ | 
					
						
							|  |  |  | 	TP_ARGS(wbc, bdi)) | 
					
						
							|  |  |  | DEFINE_WBC_EVENT(wbc_writeback_start); | 
					
						
							|  |  |  | DEFINE_WBC_EVENT(wbc_writeback_written); | 
					
						
							|  |  |  | DEFINE_WBC_EVENT(wbc_writeback_wait); | 
					
						
							|  |  |  | DEFINE_WBC_EVENT(wbc_balance_dirty_start); | 
					
						
							|  |  |  | DEFINE_WBC_EVENT(wbc_balance_dirty_written); | 
					
						
							|  |  |  | DEFINE_WBC_EVENT(wbc_balance_dirty_wait); | 
					
						
							| 
									
										
										
										
											2010-07-07 13:24:08 +10:00
										 |  |  | DEFINE_WBC_EVENT(wbc_writepage); | 
					
						
							| 
									
										
										
										
											2010-07-07 13:24:07 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-07 13:24:06 +10:00
										 |  |  | #endif /* _TRACE_WRITEBACK_H */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* This part must be outside protection */ | 
					
						
							|  |  |  | #include <trace/define_trace.h>
 |