xref: /linux-6.15/include/trace/events/writeback.h (revision 6cc4c3aa)
1b2441318SGreg Kroah-Hartman /* SPDX-License-Identifier: GPL-2.0 */
2455b2864SDave Chinner #undef TRACE_SYSTEM
3455b2864SDave Chinner #define TRACE_SYSTEM writeback
4455b2864SDave Chinner 
5455b2864SDave Chinner #if !defined(_TRACE_WRITEBACK_H) || defined(TRACE_HEADER_MULTI_READ)
6455b2864SDave Chinner #define _TRACE_WRITEBACK_H
7455b2864SDave Chinner 
8f479447aSSteven Rostedt (Red Hat) #include <linux/tracepoint.h>
9455b2864SDave Chinner #include <linux/backing-dev.h>
10455b2864SDave Chinner #include <linux/writeback.h>
11455b2864SDave Chinner 
12251d6a47SWu Fengguang #define show_inode_state(state)					\
13251d6a47SWu Fengguang 	__print_flags(state, "|",				\
14251d6a47SWu Fengguang 		{I_DIRTY_SYNC,		"I_DIRTY_SYNC"},	\
15251d6a47SWu Fengguang 		{I_DIRTY_DATASYNC,	"I_DIRTY_DATASYNC"},	\
16251d6a47SWu Fengguang 		{I_DIRTY_PAGES,		"I_DIRTY_PAGES"},	\
17251d6a47SWu Fengguang 		{I_NEW,			"I_NEW"},		\
18251d6a47SWu Fengguang 		{I_WILL_FREE,		"I_WILL_FREE"},		\
19251d6a47SWu Fengguang 		{I_FREEING,		"I_FREEING"},		\
20251d6a47SWu Fengguang 		{I_CLEAR,		"I_CLEAR"},		\
21251d6a47SWu Fengguang 		{I_SYNC,		"I_SYNC"},		\
220ae45f63STheodore Ts'o 		{I_DIRTY_TIME,		"I_DIRTY_TIME"},	\
23459ca85aSJulian Sun 		{I_REFERENCED,		"I_REFERENCED"},	\
24459ca85aSJulian Sun 		{I_LINKABLE,		"I_LINKABLE"},		\
25459ca85aSJulian Sun 		{I_WB_SWITCH,		"I_WB_SWITCH"},		\
26459ca85aSJulian Sun 		{I_OVL_INUSE,		"I_OVL_INUSE"},		\
27459ca85aSJulian Sun 		{I_CREATING,		"I_CREATING"},		\
28459ca85aSJulian Sun 		{I_DONTCACHE,		"I_DONTCACHE"},		\
29459ca85aSJulian Sun 		{I_SYNC_QUEUED,		"I_SYNC_QUEUED"},	\
30459ca85aSJulian Sun 		{I_PINNING_NETFS_WB,	"I_PINNING_NETFS_WB"},	\
31459ca85aSJulian Sun 		{I_LRU_ISOLATING,	"I_LRU_ISOLATING"}	\
32251d6a47SWu Fengguang 	)
33251d6a47SWu Fengguang 
3491df6089SSteven Rostedt (Red Hat) /* enums need to be exported to user space */
3591df6089SSteven Rostedt (Red Hat) #undef EM
3691df6089SSteven Rostedt (Red Hat) #undef EMe
3791df6089SSteven Rostedt (Red Hat) #define EM(a,b) 	TRACE_DEFINE_ENUM(a);
3891df6089SSteven Rostedt (Red Hat) #define EMe(a,b)	TRACE_DEFINE_ENUM(a);
3991df6089SSteven Rostedt (Red Hat) 
40b3bba872SWu Fengguang #define WB_WORK_REASON							\
4191df6089SSteven Rostedt (Red Hat) 	EM( WB_REASON_BACKGROUND,		"background")		\
42726d061fSJohannes Weiner 	EM( WB_REASON_VMSCAN,			"vmscan")		\
4391df6089SSteven Rostedt (Red Hat) 	EM( WB_REASON_SYNC,			"sync")			\
4491df6089SSteven Rostedt (Red Hat) 	EM( WB_REASON_PERIODIC,			"periodic")		\
4591df6089SSteven Rostedt (Red Hat) 	EM( WB_REASON_LAPTOP_TIMER,		"laptop_timer")		\
4691df6089SSteven Rostedt (Red Hat) 	EM( WB_REASON_FS_FREE_SPACE,		"fs_free_space")	\
473d3d9c07SChunguang Xu 	EM( WB_REASON_FORKER_THREAD,		"forker_thread")	\
483d3d9c07SChunguang Xu 	EMe(WB_REASON_FOREIGN_FLUSH,		"foreign_flush")
4991df6089SSteven Rostedt (Red Hat) 
5091df6089SSteven Rostedt (Red Hat) WB_WORK_REASON
5191df6089SSteven Rostedt (Red Hat) 
5291df6089SSteven Rostedt (Red Hat) /*
5391df6089SSteven Rostedt (Red Hat)  * Now redefine the EM() and EMe() macros to map the enums to the strings
5491df6089SSteven Rostedt (Red Hat)  * that will be printed in the output.
5591df6089SSteven Rostedt (Red Hat)  */
5691df6089SSteven Rostedt (Red Hat) #undef EM
5791df6089SSteven Rostedt (Red Hat) #undef EMe
5891df6089SSteven Rostedt (Red Hat) #define EM(a,b)		{ a, b },
5991df6089SSteven Rostedt (Red Hat) #define EMe(a,b)	{ a, b }
60b3bba872SWu Fengguang 
61455b2864SDave Chinner struct wb_writeback_work;
62455b2864SDave Chinner 
63b9b0ff61SMatthew Wilcox (Oracle) DECLARE_EVENT_CLASS(writeback_folio_template,
649fb0a7daSTejun Heo 
65b9b0ff61SMatthew Wilcox (Oracle) 	TP_PROTO(struct folio *folio, struct address_space *mapping),
669fb0a7daSTejun Heo 
67b9b0ff61SMatthew Wilcox (Oracle) 	TP_ARGS(folio, mapping),
689fb0a7daSTejun Heo 
699fb0a7daSTejun Heo 	TP_STRUCT__entry (
709fb0a7daSTejun Heo 		__array(char, name, 32)
71f05499a0STejun Heo 		__field(ino_t, ino)
729fb0a7daSTejun Heo 		__field(pgoff_t, index)
739fb0a7daSTejun Heo 	),
749fb0a7daSTejun Heo 
759fb0a7daSTejun Heo 	TP_fast_assign(
76d1a445d3SQian Cai 		strscpy_pad(__entry->name,
7768f23b89STheodore Ts'o 			    bdi_dev_name(mapping ? inode_to_bdi(mapping->host) :
7868f23b89STheodore Ts'o 					 NULL), 32);
7954abe19eSRafael Aquini 		__entry->ino = (mapping && mapping->host) ? mapping->host->i_ino : 0;
80b9b0ff61SMatthew Wilcox (Oracle) 		__entry->index = folio->index;
819fb0a7daSTejun Heo 	),
829fb0a7daSTejun Heo 
839fb0a7daSTejun Heo 	TP_printk("bdi %s: ino=%lu index=%lu",
849fb0a7daSTejun Heo 		__entry->name,
8540363cf1SQian Cai 		(unsigned long)__entry->ino,
869fb0a7daSTejun Heo 		__entry->index
879fb0a7daSTejun Heo 	)
889fb0a7daSTejun Heo );
899fb0a7daSTejun Heo 
90b9b0ff61SMatthew Wilcox (Oracle) DEFINE_EVENT(writeback_folio_template, writeback_dirty_folio,
9119343b5bSYafang Shao 
92b9b0ff61SMatthew Wilcox (Oracle) 	TP_PROTO(struct folio *folio, struct address_space *mapping),
9319343b5bSYafang Shao 
94b9b0ff61SMatthew Wilcox (Oracle) 	TP_ARGS(folio, mapping)
9519343b5bSYafang Shao );
9619343b5bSYafang Shao 
97b9b0ff61SMatthew Wilcox (Oracle) DEFINE_EVENT(writeback_folio_template, folio_wait_writeback,
9819343b5bSYafang Shao 
99b9b0ff61SMatthew Wilcox (Oracle) 	TP_PROTO(struct folio *folio, struct address_space *mapping),
10019343b5bSYafang Shao 
101b9b0ff61SMatthew Wilcox (Oracle) 	TP_ARGS(folio, mapping)
10219343b5bSYafang Shao );
10319343b5bSYafang Shao 
1049fb0a7daSTejun Heo DECLARE_EVENT_CLASS(writeback_dirty_inode_template,
1059fb0a7daSTejun Heo 
1069fb0a7daSTejun Heo 	TP_PROTO(struct inode *inode, int flags),
1079fb0a7daSTejun Heo 
1089fb0a7daSTejun Heo 	TP_ARGS(inode, flags),
1099fb0a7daSTejun Heo 
1109fb0a7daSTejun Heo 	TP_STRUCT__entry (
1119fb0a7daSTejun Heo 		__array(char, name, 32)
112f05499a0STejun Heo 		__field(ino_t, ino)
1130ae45f63STheodore Ts'o 		__field(unsigned long, state)
1149fb0a7daSTejun Heo 		__field(unsigned long, flags)
1159fb0a7daSTejun Heo 	),
1169fb0a7daSTejun Heo 
1179fb0a7daSTejun Heo 	TP_fast_assign(
118de1414a6SChristoph Hellwig 		struct backing_dev_info *bdi = inode_to_bdi(inode);
1199fb0a7daSTejun Heo 
1209fb0a7daSTejun Heo 		/* may be called for files on pseudo FSes w/ unregistered bdi */
12168f23b89STheodore Ts'o 		strscpy_pad(__entry->name, bdi_dev_name(bdi), 32);
1229fb0a7daSTejun Heo 		__entry->ino		= inode->i_ino;
1230ae45f63STheodore Ts'o 		__entry->state		= inode->i_state;
1249fb0a7daSTejun Heo 		__entry->flags		= flags;
1259fb0a7daSTejun Heo 	),
1269fb0a7daSTejun Heo 
1270ae45f63STheodore Ts'o 	TP_printk("bdi %s: ino=%lu state=%s flags=%s",
1289fb0a7daSTejun Heo 		__entry->name,
12940363cf1SQian Cai 		(unsigned long)__entry->ino,
1300ae45f63STheodore Ts'o 		show_inode_state(__entry->state),
1319fb0a7daSTejun Heo 		show_inode_state(__entry->flags)
1329fb0a7daSTejun Heo 	)
1339fb0a7daSTejun Heo );
1349fb0a7daSTejun Heo 
1350ae45f63STheodore Ts'o DEFINE_EVENT(writeback_dirty_inode_template, writeback_mark_inode_dirty,
1360ae45f63STheodore Ts'o 
1370ae45f63STheodore Ts'o 	TP_PROTO(struct inode *inode, int flags),
1380ae45f63STheodore Ts'o 
1390ae45f63STheodore Ts'o 	TP_ARGS(inode, flags)
1400ae45f63STheodore Ts'o );
1410ae45f63STheodore Ts'o 
1429fb0a7daSTejun Heo DEFINE_EVENT(writeback_dirty_inode_template, writeback_dirty_inode_start,
1439fb0a7daSTejun Heo 
1449fb0a7daSTejun Heo 	TP_PROTO(struct inode *inode, int flags),
1459fb0a7daSTejun Heo 
1469fb0a7daSTejun Heo 	TP_ARGS(inode, flags)
1479fb0a7daSTejun Heo );
1489fb0a7daSTejun Heo 
1499fb0a7daSTejun Heo DEFINE_EVENT(writeback_dirty_inode_template, writeback_dirty_inode,
1509fb0a7daSTejun Heo 
1519fb0a7daSTejun Heo 	TP_PROTO(struct inode *inode, int flags),
1529fb0a7daSTejun Heo 
1539fb0a7daSTejun Heo 	TP_ARGS(inode, flags)
1549fb0a7daSTejun Heo );
1559fb0a7daSTejun Heo 
1565634cc2aSTejun Heo #ifdef CREATE_TRACE_POINTS
1575634cc2aSTejun Heo #ifdef CONFIG_CGROUP_WRITEBACK
1585634cc2aSTejun Heo 
__trace_wb_assign_cgroup(struct bdi_writeback * wb)159f05499a0STejun Heo static inline ino_t __trace_wb_assign_cgroup(struct bdi_writeback *wb)
1605634cc2aSTejun Heo {
16167c0496eSTejun Heo 	return cgroup_ino(wb->memcg_css->cgroup);
1625634cc2aSTejun Heo }
1635634cc2aSTejun Heo 
__trace_wbc_assign_cgroup(struct writeback_control * wbc)164f05499a0STejun Heo static inline ino_t __trace_wbc_assign_cgroup(struct writeback_control *wbc)
1655634cc2aSTejun Heo {
1665634cc2aSTejun Heo 	if (wbc->wb)
167a664edb3SYang Shi 		return __trace_wb_assign_cgroup(wbc->wb);
1685634cc2aSTejun Heo 	else
169f05499a0STejun Heo 		return 1;
1705634cc2aSTejun Heo }
1715634cc2aSTejun Heo #else	/* CONFIG_CGROUP_WRITEBACK */
1725634cc2aSTejun Heo 
__trace_wb_assign_cgroup(struct bdi_writeback * wb)173f05499a0STejun Heo static inline ino_t __trace_wb_assign_cgroup(struct bdi_writeback *wb)
1745634cc2aSTejun Heo {
175f05499a0STejun Heo 	return 1;
1765634cc2aSTejun Heo }
1775634cc2aSTejun Heo 
__trace_wbc_assign_cgroup(struct writeback_control * wbc)178f05499a0STejun Heo static inline ino_t __trace_wbc_assign_cgroup(struct writeback_control *wbc)
1795634cc2aSTejun Heo {
180f05499a0STejun Heo 	return 1;
1815634cc2aSTejun Heo }
1825634cc2aSTejun Heo 
1835634cc2aSTejun Heo #endif	/* CONFIG_CGROUP_WRITEBACK */
1845634cc2aSTejun Heo #endif	/* CREATE_TRACE_POINTS */
1855634cc2aSTejun Heo 
1863a8e9ac8STejun Heo #ifdef CONFIG_CGROUP_WRITEBACK
1873a8e9ac8STejun Heo TRACE_EVENT(inode_foreign_history,
1883a8e9ac8STejun Heo 
1893a8e9ac8STejun Heo 	TP_PROTO(struct inode *inode, struct writeback_control *wbc,
1903a8e9ac8STejun Heo 		 unsigned int history),
1913a8e9ac8STejun Heo 
1923a8e9ac8STejun Heo 	TP_ARGS(inode, wbc, history),
1933a8e9ac8STejun Heo 
1943a8e9ac8STejun Heo 	TP_STRUCT__entry(
1953a8e9ac8STejun Heo 		__array(char,		name, 32)
196f05499a0STejun Heo 		__field(ino_t,		ino)
197f05499a0STejun Heo 		__field(ino_t,		cgroup_ino)
1983a8e9ac8STejun Heo 		__field(unsigned int,	history)
1993a8e9ac8STejun Heo 	),
2003a8e9ac8STejun Heo 
2013a8e9ac8STejun Heo 	TP_fast_assign(
202fdeb17c7SHui Su 		strscpy_pad(__entry->name, bdi_dev_name(inode_to_bdi(inode)), 32);
2033a8e9ac8STejun Heo 		__entry->ino		= inode->i_ino;
2043a8e9ac8STejun Heo 		__entry->cgroup_ino	= __trace_wbc_assign_cgroup(wbc);
2053a8e9ac8STejun Heo 		__entry->history	= history;
2063a8e9ac8STejun Heo 	),
2073a8e9ac8STejun Heo 
208f05499a0STejun Heo 	TP_printk("bdi %s: ino=%lu cgroup_ino=%lu history=0x%x",
2093a8e9ac8STejun Heo 		__entry->name,
21040363cf1SQian Cai 		(unsigned long)__entry->ino,
21140363cf1SQian Cai 		(unsigned long)__entry->cgroup_ino,
2123a8e9ac8STejun Heo 		__entry->history
2133a8e9ac8STejun Heo 	)
2143a8e9ac8STejun Heo );
2153a8e9ac8STejun Heo 
2163a8e9ac8STejun Heo TRACE_EVENT(inode_switch_wbs,
2173a8e9ac8STejun Heo 
2183a8e9ac8STejun Heo 	TP_PROTO(struct inode *inode, struct bdi_writeback *old_wb,
2193a8e9ac8STejun Heo 		 struct bdi_writeback *new_wb),
2203a8e9ac8STejun Heo 
2213a8e9ac8STejun Heo 	TP_ARGS(inode, old_wb, new_wb),
2223a8e9ac8STejun Heo 
2233a8e9ac8STejun Heo 	TP_STRUCT__entry(
2243a8e9ac8STejun Heo 		__array(char,		name, 32)
225f05499a0STejun Heo 		__field(ino_t,		ino)
226f05499a0STejun Heo 		__field(ino_t,		old_cgroup_ino)
227f05499a0STejun Heo 		__field(ino_t,		new_cgroup_ino)
2283a8e9ac8STejun Heo 	),
2293a8e9ac8STejun Heo 
2303a8e9ac8STejun Heo 	TP_fast_assign(
231fdeb17c7SHui Su 		strscpy_pad(__entry->name, bdi_dev_name(old_wb->bdi), 32);
2323a8e9ac8STejun Heo 		__entry->ino		= inode->i_ino;
2333a8e9ac8STejun Heo 		__entry->old_cgroup_ino	= __trace_wb_assign_cgroup(old_wb);
2343a8e9ac8STejun Heo 		__entry->new_cgroup_ino	= __trace_wb_assign_cgroup(new_wb);
2353a8e9ac8STejun Heo 	),
2363a8e9ac8STejun Heo 
237f05499a0STejun Heo 	TP_printk("bdi %s: ino=%lu old_cgroup_ino=%lu new_cgroup_ino=%lu",
2383a8e9ac8STejun Heo 		__entry->name,
23940363cf1SQian Cai 		(unsigned long)__entry->ino,
24040363cf1SQian Cai 		(unsigned long)__entry->old_cgroup_ino,
24140363cf1SQian Cai 		(unsigned long)__entry->new_cgroup_ino
2423a8e9ac8STejun Heo 	)
2433a8e9ac8STejun Heo );
2443a8e9ac8STejun Heo 
2453a8e9ac8STejun Heo TRACE_EVENT(track_foreign_dirty,
2463a8e9ac8STejun Heo 
2479d8053fcSMatthew Wilcox (Oracle) 	TP_PROTO(struct folio *folio, struct bdi_writeback *wb),
2483a8e9ac8STejun Heo 
2499d8053fcSMatthew Wilcox (Oracle) 	TP_ARGS(folio, wb),
2503a8e9ac8STejun Heo 
2513a8e9ac8STejun Heo 	TP_STRUCT__entry(
2523a8e9ac8STejun Heo 		__array(char,		name, 32)
2533a8e9ac8STejun Heo 		__field(u64,		bdi_id)
254f05499a0STejun Heo 		__field(ino_t,		ino)
2553a8e9ac8STejun Heo 		__field(unsigned int,	memcg_id)
256f05499a0STejun Heo 		__field(ino_t,		cgroup_ino)
257f05499a0STejun Heo 		__field(ino_t,		page_cgroup_ino)
2583a8e9ac8STejun Heo 	),
2593a8e9ac8STejun Heo 
2603a8e9ac8STejun Heo 	TP_fast_assign(
2619d8053fcSMatthew Wilcox (Oracle) 		struct address_space *mapping = folio_mapping(folio);
2620feacaa2STejun Heo 		struct inode *inode = mapping ? mapping->host : NULL;
2630feacaa2STejun Heo 
264fdeb17c7SHui Su 		strscpy_pad(__entry->name, bdi_dev_name(wb->bdi), 32);
2653a8e9ac8STejun Heo 		__entry->bdi_id		= wb->bdi->id;
2660feacaa2STejun Heo 		__entry->ino		= inode ? inode->i_ino : 0;
2673a8e9ac8STejun Heo 		__entry->memcg_id	= wb->memcg_css->id;
2683a8e9ac8STejun Heo 		__entry->cgroup_ino	= __trace_wb_assign_cgroup(wb);
2699d8053fcSMatthew Wilcox (Oracle) 		__entry->page_cgroup_ino = cgroup_ino(folio_memcg(folio)->css.cgroup);
2703a8e9ac8STejun Heo 	),
2713a8e9ac8STejun Heo 
272f05499a0STejun Heo 	TP_printk("bdi %s[%llu]: ino=%lu memcg_id=%u cgroup_ino=%lu page_cgroup_ino=%lu",
2733a8e9ac8STejun Heo 		__entry->name,
2743a8e9ac8STejun Heo 		__entry->bdi_id,
27540363cf1SQian Cai 		(unsigned long)__entry->ino,
2763a8e9ac8STejun Heo 		__entry->memcg_id,
27740363cf1SQian Cai 		(unsigned long)__entry->cgroup_ino,
27840363cf1SQian Cai 		(unsigned long)__entry->page_cgroup_ino
2793a8e9ac8STejun Heo 	)
2803a8e9ac8STejun Heo );
2813a8e9ac8STejun Heo 
2823a8e9ac8STejun Heo TRACE_EVENT(flush_foreign,
2833a8e9ac8STejun Heo 
2843a8e9ac8STejun Heo 	TP_PROTO(struct bdi_writeback *wb, unsigned int frn_bdi_id,
2853a8e9ac8STejun Heo 		 unsigned int frn_memcg_id),
2863a8e9ac8STejun Heo 
2873a8e9ac8STejun Heo 	TP_ARGS(wb, frn_bdi_id, frn_memcg_id),
2883a8e9ac8STejun Heo 
2893a8e9ac8STejun Heo 	TP_STRUCT__entry(
2903a8e9ac8STejun Heo 		__array(char,		name, 32)
291f05499a0STejun Heo 		__field(ino_t,		cgroup_ino)
2923a8e9ac8STejun Heo 		__field(unsigned int,	frn_bdi_id)
2933a8e9ac8STejun Heo 		__field(unsigned int,	frn_memcg_id)
2943a8e9ac8STejun Heo 	),
2953a8e9ac8STejun Heo 
2963a8e9ac8STejun Heo 	TP_fast_assign(
297fdeb17c7SHui Su 		strscpy_pad(__entry->name, bdi_dev_name(wb->bdi), 32);
2983a8e9ac8STejun Heo 		__entry->cgroup_ino	= __trace_wb_assign_cgroup(wb);
2993a8e9ac8STejun Heo 		__entry->frn_bdi_id	= frn_bdi_id;
3003a8e9ac8STejun Heo 		__entry->frn_memcg_id	= frn_memcg_id;
3013a8e9ac8STejun Heo 	),
3023a8e9ac8STejun Heo 
303f05499a0STejun Heo 	TP_printk("bdi %s: cgroup_ino=%lu frn_bdi_id=%u frn_memcg_id=%u",
3043a8e9ac8STejun Heo 		__entry->name,
30540363cf1SQian Cai 		(unsigned long)__entry->cgroup_ino,
3063a8e9ac8STejun Heo 		__entry->frn_bdi_id,
3073a8e9ac8STejun Heo 		__entry->frn_memcg_id
3083a8e9ac8STejun Heo 	)
3093a8e9ac8STejun Heo );
3103a8e9ac8STejun Heo #endif
3113a8e9ac8STejun Heo 
3129fb0a7daSTejun Heo DECLARE_EVENT_CLASS(writeback_write_inode_template,
3139fb0a7daSTejun Heo 
3149fb0a7daSTejun Heo 	TP_PROTO(struct inode *inode, struct writeback_control *wbc),
3159fb0a7daSTejun Heo 
3169fb0a7daSTejun Heo 	TP_ARGS(inode, wbc),
3179fb0a7daSTejun Heo 
3189fb0a7daSTejun Heo 	TP_STRUCT__entry (
3199fb0a7daSTejun Heo 		__array(char, name, 32)
320f05499a0STejun Heo 		__field(ino_t, ino)
3219fb0a7daSTejun Heo 		__field(int, sync_mode)
322f05499a0STejun Heo 		__field(ino_t, cgroup_ino)
3239fb0a7daSTejun Heo 	),
3249fb0a7daSTejun Heo 
3259fb0a7daSTejun Heo 	TP_fast_assign(
326d1a445d3SQian Cai 		strscpy_pad(__entry->name,
32768f23b89STheodore Ts'o 			    bdi_dev_name(inode_to_bdi(inode)), 32);
3289fb0a7daSTejun Heo 		__entry->ino		= inode->i_ino;
3299fb0a7daSTejun Heo 		__entry->sync_mode	= wbc->sync_mode;
330a664edb3SYang Shi 		__entry->cgroup_ino	= __trace_wbc_assign_cgroup(wbc);
3319fb0a7daSTejun Heo 	),
3329fb0a7daSTejun Heo 
333f05499a0STejun Heo 	TP_printk("bdi %s: ino=%lu sync_mode=%d cgroup_ino=%lu",
3349fb0a7daSTejun Heo 		__entry->name,
33540363cf1SQian Cai 		(unsigned long)__entry->ino,
3365634cc2aSTejun Heo 		__entry->sync_mode,
33740363cf1SQian Cai 		(unsigned long)__entry->cgroup_ino
3389fb0a7daSTejun Heo 	)
3399fb0a7daSTejun Heo );
3409fb0a7daSTejun Heo 
3419fb0a7daSTejun Heo DEFINE_EVENT(writeback_write_inode_template, writeback_write_inode_start,
3429fb0a7daSTejun Heo 
3439fb0a7daSTejun Heo 	TP_PROTO(struct inode *inode, struct writeback_control *wbc),
3449fb0a7daSTejun Heo 
3459fb0a7daSTejun Heo 	TP_ARGS(inode, wbc)
3469fb0a7daSTejun Heo );
3479fb0a7daSTejun Heo 
3489fb0a7daSTejun Heo DEFINE_EVENT(writeback_write_inode_template, writeback_write_inode,
3499fb0a7daSTejun Heo 
3509fb0a7daSTejun Heo 	TP_PROTO(struct inode *inode, struct writeback_control *wbc),
3519fb0a7daSTejun Heo 
3529fb0a7daSTejun Heo 	TP_ARGS(inode, wbc)
3539fb0a7daSTejun Heo );
3549fb0a7daSTejun Heo 
355455b2864SDave Chinner DECLARE_EVENT_CLASS(writeback_work_class,
3565634cc2aSTejun Heo 	TP_PROTO(struct bdi_writeback *wb, struct wb_writeback_work *work),
3575634cc2aSTejun Heo 	TP_ARGS(wb, work),
358455b2864SDave Chinner 	TP_STRUCT__entry(
359455b2864SDave Chinner 		__array(char, name, 32)
360455b2864SDave Chinner 		__field(long, nr_pages)
361455b2864SDave Chinner 		__field(dev_t, sb_dev)
362455b2864SDave Chinner 		__field(int, sync_mode)
363455b2864SDave Chinner 		__field(int, for_kupdate)
364455b2864SDave Chinner 		__field(int, range_cyclic)
365455b2864SDave Chinner 		__field(int, for_background)
3660e175a18SCurt Wohlgemuth 		__field(int, reason)
367f05499a0STejun Heo 		__field(ino_t, cgroup_ino)
368455b2864SDave Chinner 	),
369455b2864SDave Chinner 	TP_fast_assign(
37068f23b89STheodore Ts'o 		strscpy_pad(__entry->name, bdi_dev_name(wb->bdi), 32);
371455b2864SDave Chinner 		__entry->nr_pages = work->nr_pages;
372455b2864SDave Chinner 		__entry->sb_dev = work->sb ? work->sb->s_dev : 0;
373455b2864SDave Chinner 		__entry->sync_mode = work->sync_mode;
374455b2864SDave Chinner 		__entry->for_kupdate = work->for_kupdate;
375455b2864SDave Chinner 		__entry->range_cyclic = work->range_cyclic;
376455b2864SDave Chinner 		__entry->for_background	= work->for_background;
3770e175a18SCurt Wohlgemuth 		__entry->reason = work->reason;
378a664edb3SYang Shi 		__entry->cgroup_ino = __trace_wb_assign_cgroup(wb);
379455b2864SDave Chinner 	),
380455b2864SDave Chinner 	TP_printk("bdi %s: sb_dev %d:%d nr_pages=%ld sync_mode=%d "
381f05499a0STejun Heo 		  "kupdate=%d range_cyclic=%d background=%d reason=%s cgroup_ino=%lu",
382455b2864SDave Chinner 		  __entry->name,
383455b2864SDave Chinner 		  MAJOR(__entry->sb_dev), MINOR(__entry->sb_dev),
384455b2864SDave Chinner 		  __entry->nr_pages,
385455b2864SDave Chinner 		  __entry->sync_mode,
386455b2864SDave Chinner 		  __entry->for_kupdate,
387455b2864SDave Chinner 		  __entry->range_cyclic,
3880e175a18SCurt Wohlgemuth 		  __entry->for_background,
3895634cc2aSTejun Heo 		  __print_symbolic(__entry->reason, WB_WORK_REASON),
39040363cf1SQian Cai 		  (unsigned long)__entry->cgroup_ino
391455b2864SDave Chinner 	)
392455b2864SDave Chinner );
393455b2864SDave Chinner #define DEFINE_WRITEBACK_WORK_EVENT(name) \
394455b2864SDave Chinner DEFINE_EVENT(writeback_work_class, name, \
3955634cc2aSTejun Heo 	TP_PROTO(struct bdi_writeback *wb, struct wb_writeback_work *work), \
3965634cc2aSTejun Heo 	TP_ARGS(wb, work))
397455b2864SDave Chinner DEFINE_WRITEBACK_WORK_EVENT(writeback_queue);
398455b2864SDave Chinner DEFINE_WRITEBACK_WORK_EVENT(writeback_exec);
399d46db3d5SWu Fengguang DEFINE_WRITEBACK_WORK_EVENT(writeback_start);
400d46db3d5SWu Fengguang DEFINE_WRITEBACK_WORK_EVENT(writeback_written);
401d46db3d5SWu Fengguang DEFINE_WRITEBACK_WORK_EVENT(writeback_wait);
402455b2864SDave Chinner 
403455b2864SDave Chinner TRACE_EVENT(writeback_pages_written,
404455b2864SDave Chinner 	TP_PROTO(long pages_written),
405455b2864SDave Chinner 	TP_ARGS(pages_written),
406455b2864SDave Chinner 	TP_STRUCT__entry(
407455b2864SDave Chinner 		__field(long,		pages)
408455b2864SDave Chinner 	),
409455b2864SDave Chinner 	TP_fast_assign(
410455b2864SDave Chinner 		__entry->pages		= pages_written;
411455b2864SDave Chinner 	),
412455b2864SDave Chinner 	TP_printk("%ld", __entry->pages)
413455b2864SDave Chinner );
414455b2864SDave Chinner 
415455b2864SDave Chinner DECLARE_EVENT_CLASS(writeback_class,
4165634cc2aSTejun Heo 	TP_PROTO(struct bdi_writeback *wb),
4175634cc2aSTejun Heo 	TP_ARGS(wb),
4185634cc2aSTejun Heo 	TP_STRUCT__entry(
4195634cc2aSTejun Heo 		__array(char, name, 32)
420f05499a0STejun Heo 		__field(ino_t, cgroup_ino)
4215634cc2aSTejun Heo 	),
4225634cc2aSTejun Heo 	TP_fast_assign(
42368f23b89STheodore Ts'o 		strscpy_pad(__entry->name, bdi_dev_name(wb->bdi), 32);
424a664edb3SYang Shi 		__entry->cgroup_ino = __trace_wb_assign_cgroup(wb);
4255634cc2aSTejun Heo 	),
426f05499a0STejun Heo 	TP_printk("bdi %s: cgroup_ino=%lu",
4275634cc2aSTejun Heo 		  __entry->name,
42840363cf1SQian Cai 		  (unsigned long)__entry->cgroup_ino
4295634cc2aSTejun Heo 	)
4305634cc2aSTejun Heo );
4315634cc2aSTejun Heo #define DEFINE_WRITEBACK_EVENT(name) \
4325634cc2aSTejun Heo DEFINE_EVENT(writeback_class, name, \
4335634cc2aSTejun Heo 	TP_PROTO(struct bdi_writeback *wb), \
4345634cc2aSTejun Heo 	TP_ARGS(wb))
4355634cc2aSTejun Heo 
4365634cc2aSTejun Heo DEFINE_WRITEBACK_EVENT(writeback_wake_background);
4375634cc2aSTejun Heo 
4385634cc2aSTejun Heo TRACE_EVENT(writeback_bdi_register,
439455b2864SDave Chinner 	TP_PROTO(struct backing_dev_info *bdi),
440455b2864SDave Chinner 	TP_ARGS(bdi),
441455b2864SDave Chinner 	TP_STRUCT__entry(
442455b2864SDave Chinner 		__array(char, name, 32)
443455b2864SDave Chinner 	),
444455b2864SDave Chinner 	TP_fast_assign(
44568f23b89STheodore Ts'o 		strscpy_pad(__entry->name, bdi_dev_name(bdi), 32);
446455b2864SDave Chinner 	),
447455b2864SDave Chinner 	TP_printk("bdi %s",
448455b2864SDave Chinner 		__entry->name
449455b2864SDave Chinner 	)
450455b2864SDave Chinner );
451455b2864SDave Chinner 
452028c2dd1SDave Chinner DECLARE_EVENT_CLASS(wbc_class,
453028c2dd1SDave Chinner 	TP_PROTO(struct writeback_control *wbc, struct backing_dev_info *bdi),
454028c2dd1SDave Chinner 	TP_ARGS(wbc, bdi),
455028c2dd1SDave Chinner 	TP_STRUCT__entry(
456028c2dd1SDave Chinner 		__array(char, name, 32)
457028c2dd1SDave Chinner 		__field(long, nr_to_write)
458028c2dd1SDave Chinner 		__field(long, pages_skipped)
459028c2dd1SDave Chinner 		__field(int, sync_mode)
460028c2dd1SDave Chinner 		__field(int, for_kupdate)
461028c2dd1SDave Chinner 		__field(int, for_background)
462028c2dd1SDave Chinner 		__field(int, for_reclaim)
463028c2dd1SDave Chinner 		__field(int, range_cyclic)
464028c2dd1SDave Chinner 		__field(long, range_start)
465028c2dd1SDave Chinner 		__field(long, range_end)
466f05499a0STejun Heo 		__field(ino_t, cgroup_ino)
467028c2dd1SDave Chinner 	),
468028c2dd1SDave Chinner 
469028c2dd1SDave Chinner 	TP_fast_assign(
47068f23b89STheodore Ts'o 		strscpy_pad(__entry->name, bdi_dev_name(bdi), 32);
471028c2dd1SDave Chinner 		__entry->nr_to_write	= wbc->nr_to_write;
472028c2dd1SDave Chinner 		__entry->pages_skipped	= wbc->pages_skipped;
473028c2dd1SDave Chinner 		__entry->sync_mode	= wbc->sync_mode;
474028c2dd1SDave Chinner 		__entry->for_kupdate	= wbc->for_kupdate;
475028c2dd1SDave Chinner 		__entry->for_background	= wbc->for_background;
476028c2dd1SDave Chinner 		__entry->for_reclaim	= wbc->for_reclaim;
477028c2dd1SDave Chinner 		__entry->range_cyclic	= wbc->range_cyclic;
478028c2dd1SDave Chinner 		__entry->range_start	= (long)wbc->range_start;
479028c2dd1SDave Chinner 		__entry->range_end	= (long)wbc->range_end;
480a664edb3SYang Shi 		__entry->cgroup_ino	= __trace_wbc_assign_cgroup(wbc);
481028c2dd1SDave Chinner 	),
482028c2dd1SDave Chinner 
483028c2dd1SDave Chinner 	TP_printk("bdi %s: towrt=%ld skip=%ld mode=%d kupd=%d "
484d46db3d5SWu Fengguang 		"bgrd=%d reclm=%d cyclic=%d "
485f05499a0STejun Heo 		"start=0x%lx end=0x%lx cgroup_ino=%lu",
486028c2dd1SDave Chinner 		__entry->name,
487028c2dd1SDave Chinner 		__entry->nr_to_write,
488028c2dd1SDave Chinner 		__entry->pages_skipped,
489028c2dd1SDave Chinner 		__entry->sync_mode,
490028c2dd1SDave Chinner 		__entry->for_kupdate,
491028c2dd1SDave Chinner 		__entry->for_background,
492028c2dd1SDave Chinner 		__entry->for_reclaim,
493028c2dd1SDave Chinner 		__entry->range_cyclic,
494028c2dd1SDave Chinner 		__entry->range_start,
4955634cc2aSTejun Heo 		__entry->range_end,
49640363cf1SQian Cai 		(unsigned long)__entry->cgroup_ino
4975634cc2aSTejun Heo 	)
498028c2dd1SDave Chinner )
499028c2dd1SDave Chinner 
500028c2dd1SDave Chinner #define DEFINE_WBC_EVENT(name) \
501028c2dd1SDave Chinner DEFINE_EVENT(wbc_class, name, \
502028c2dd1SDave Chinner 	TP_PROTO(struct writeback_control *wbc, struct backing_dev_info *bdi), \
503028c2dd1SDave Chinner 	TP_ARGS(wbc, bdi))
5049e094383SDave Chinner DEFINE_WBC_EVENT(wbc_writepage);
505028c2dd1SDave Chinner 
506e84d0a4fSWu Fengguang TRACE_EVENT(writeback_queue_io,
507e84d0a4fSWu Fengguang 	TP_PROTO(struct bdi_writeback *wb,
508ad4e38ddSCurt Wohlgemuth 		 struct wb_writeback_work *work,
509f9cae926SJan Kara 		 unsigned long dirtied_before,
510e84d0a4fSWu Fengguang 		 int moved),
511f9cae926SJan Kara 	TP_ARGS(wb, work, dirtied_before, moved),
512e84d0a4fSWu Fengguang 	TP_STRUCT__entry(
513e84d0a4fSWu Fengguang 		__array(char,		name, 32)
514e84d0a4fSWu Fengguang 		__field(unsigned long,	older)
515e84d0a4fSWu Fengguang 		__field(long,		age)
516e84d0a4fSWu Fengguang 		__field(int,		moved)
5170e175a18SCurt Wohlgemuth 		__field(int,		reason)
518f05499a0STejun Heo 		__field(ino_t,		cgroup_ino)
519e84d0a4fSWu Fengguang 	),
520e84d0a4fSWu Fengguang 	TP_fast_assign(
52168f23b89STheodore Ts'o 		strscpy_pad(__entry->name, bdi_dev_name(wb->bdi), 32);
522f9cae926SJan Kara 		__entry->older	= dirtied_before;
523f9cae926SJan Kara 		__entry->age	= (jiffies - dirtied_before) * 1000 / HZ;
524e84d0a4fSWu Fengguang 		__entry->moved	= moved;
5250e175a18SCurt Wohlgemuth 		__entry->reason	= work->reason;
526a664edb3SYang Shi 		__entry->cgroup_ino	= __trace_wb_assign_cgroup(wb);
527e84d0a4fSWu Fengguang 	),
528f05499a0STejun Heo 	TP_printk("bdi %s: older=%lu age=%ld enqueue=%d reason=%s cgroup_ino=%lu",
529e84d0a4fSWu Fengguang 		__entry->name,
530f9cae926SJan Kara 		__entry->older,	/* dirtied_before in jiffies */
531f9cae926SJan Kara 		__entry->age,	/* dirtied_before in relative milliseconds */
5320e175a18SCurt Wohlgemuth 		__entry->moved,
5335634cc2aSTejun Heo 		__print_symbolic(__entry->reason, WB_WORK_REASON),
53440363cf1SQian Cai 		(unsigned long)__entry->cgroup_ino
535b3bba872SWu Fengguang 	)
536e84d0a4fSWu Fengguang );
537e84d0a4fSWu Fengguang 
538e1cbe236SWu Fengguang TRACE_EVENT(global_dirty_state,
539e1cbe236SWu Fengguang 
540e1cbe236SWu Fengguang 	TP_PROTO(unsigned long background_thresh,
541e1cbe236SWu Fengguang 		 unsigned long dirty_thresh
542e1cbe236SWu Fengguang 	),
543e1cbe236SWu Fengguang 
544e1cbe236SWu Fengguang 	TP_ARGS(background_thresh,
545e1cbe236SWu Fengguang 		dirty_thresh
546e1cbe236SWu Fengguang 	),
547e1cbe236SWu Fengguang 
548e1cbe236SWu Fengguang 	TP_STRUCT__entry(
549e1cbe236SWu Fengguang 		__field(unsigned long,	nr_dirty)
550e1cbe236SWu Fengguang 		__field(unsigned long,	nr_writeback)
551e1cbe236SWu Fengguang 		__field(unsigned long,	background_thresh)
552e1cbe236SWu Fengguang 		__field(unsigned long,	dirty_thresh)
553e1cbe236SWu Fengguang 		__field(unsigned long,	dirty_limit)
554e1cbe236SWu Fengguang 		__field(unsigned long,	nr_dirtied)
555e1cbe236SWu Fengguang 		__field(unsigned long,	nr_written)
556e1cbe236SWu Fengguang 	),
557e1cbe236SWu Fengguang 
558e1cbe236SWu Fengguang 	TP_fast_assign(
55911fb9989SMel Gorman 		__entry->nr_dirty	= global_node_page_state(NR_FILE_DIRTY);
56011fb9989SMel Gorman 		__entry->nr_writeback	= global_node_page_state(NR_WRITEBACK);
561c4a25635SMel Gorman 		__entry->nr_dirtied	= global_node_page_state(NR_DIRTIED);
562c4a25635SMel Gorman 		__entry->nr_written	= global_node_page_state(NR_WRITTEN);
563e1cbe236SWu Fengguang 		__entry->background_thresh = background_thresh;
564e1cbe236SWu Fengguang 		__entry->dirty_thresh	= dirty_thresh;
565dcc25ae7STejun Heo 		__entry->dirty_limit	= global_wb_domain.dirty_limit;
566e1cbe236SWu Fengguang 	),
567e1cbe236SWu Fengguang 
5688d92890bSNeilBrown 	TP_printk("dirty=%lu writeback=%lu "
569e1cbe236SWu Fengguang 		  "bg_thresh=%lu thresh=%lu limit=%lu "
570e1cbe236SWu Fengguang 		  "dirtied=%lu written=%lu",
571e1cbe236SWu Fengguang 		  __entry->nr_dirty,
572e1cbe236SWu Fengguang 		  __entry->nr_writeback,
573e1cbe236SWu Fengguang 		  __entry->background_thresh,
574e1cbe236SWu Fengguang 		  __entry->dirty_thresh,
575e1cbe236SWu Fengguang 		  __entry->dirty_limit,
576e1cbe236SWu Fengguang 		  __entry->nr_dirtied,
577e1cbe236SWu Fengguang 		  __entry->nr_written
578e1cbe236SWu Fengguang 	)
579e1cbe236SWu Fengguang );
580e1cbe236SWu Fengguang 
581b48c104dSWu Fengguang #define KBps(x)			((x) << (PAGE_SHIFT - 10))
582b48c104dSWu Fengguang 
583b48c104dSWu Fengguang TRACE_EVENT(bdi_dirty_ratelimit,
584b48c104dSWu Fengguang 
5855634cc2aSTejun Heo 	TP_PROTO(struct bdi_writeback *wb,
586b48c104dSWu Fengguang 		 unsigned long dirty_rate,
587b48c104dSWu Fengguang 		 unsigned long task_ratelimit),
588b48c104dSWu Fengguang 
5895634cc2aSTejun Heo 	TP_ARGS(wb, dirty_rate, task_ratelimit),
590b48c104dSWu Fengguang 
591b48c104dSWu Fengguang 	TP_STRUCT__entry(
592b48c104dSWu Fengguang 		__array(char,		bdi, 32)
593b48c104dSWu Fengguang 		__field(unsigned long,	write_bw)
594b48c104dSWu Fengguang 		__field(unsigned long,	avg_write_bw)
595b48c104dSWu Fengguang 		__field(unsigned long,	dirty_rate)
596b48c104dSWu Fengguang 		__field(unsigned long,	dirty_ratelimit)
597b48c104dSWu Fengguang 		__field(unsigned long,	task_ratelimit)
598b48c104dSWu Fengguang 		__field(unsigned long,	balanced_dirty_ratelimit)
599f05499a0STejun Heo 		__field(ino_t,		cgroup_ino)
600b48c104dSWu Fengguang 	),
601b48c104dSWu Fengguang 
602b48c104dSWu Fengguang 	TP_fast_assign(
60368f23b89STheodore Ts'o 		strscpy_pad(__entry->bdi, bdi_dev_name(wb->bdi), 32);
6045634cc2aSTejun Heo 		__entry->write_bw	= KBps(wb->write_bandwidth);
6055634cc2aSTejun Heo 		__entry->avg_write_bw	= KBps(wb->avg_write_bandwidth);
606b48c104dSWu Fengguang 		__entry->dirty_rate	= KBps(dirty_rate);
6075634cc2aSTejun Heo 		__entry->dirty_ratelimit = KBps(wb->dirty_ratelimit);
608b48c104dSWu Fengguang 		__entry->task_ratelimit	= KBps(task_ratelimit);
609b48c104dSWu Fengguang 		__entry->balanced_dirty_ratelimit =
6105634cc2aSTejun Heo 					KBps(wb->balanced_dirty_ratelimit);
611a664edb3SYang Shi 		__entry->cgroup_ino	= __trace_wb_assign_cgroup(wb);
612b48c104dSWu Fengguang 	),
613b48c104dSWu Fengguang 
614b48c104dSWu Fengguang 	TP_printk("bdi %s: "
615b48c104dSWu Fengguang 		  "write_bw=%lu awrite_bw=%lu dirty_rate=%lu "
616b48c104dSWu Fengguang 		  "dirty_ratelimit=%lu task_ratelimit=%lu "
617f05499a0STejun Heo 		  "balanced_dirty_ratelimit=%lu cgroup_ino=%lu",
618b48c104dSWu Fengguang 		  __entry->bdi,
619b48c104dSWu Fengguang 		  __entry->write_bw,		/* write bandwidth */
620b48c104dSWu Fengguang 		  __entry->avg_write_bw,	/* avg write bandwidth */
621b48c104dSWu Fengguang 		  __entry->dirty_rate,		/* bdi dirty rate */
622b48c104dSWu Fengguang 		  __entry->dirty_ratelimit,	/* base ratelimit */
623b48c104dSWu Fengguang 		  __entry->task_ratelimit, /* ratelimit with position control */
6245634cc2aSTejun Heo 		  __entry->balanced_dirty_ratelimit, /* the balanced ratelimit */
62540363cf1SQian Cai 		  (unsigned long)__entry->cgroup_ino
626b48c104dSWu Fengguang 	)
627b48c104dSWu Fengguang );
628b48c104dSWu Fengguang 
629ece13ac3SWu Fengguang TRACE_EVENT(balance_dirty_pages,
630ece13ac3SWu Fengguang 
6315634cc2aSTejun Heo 	TP_PROTO(struct bdi_writeback *wb,
632f1ab2831STang Yizhou 		 struct dirty_throttle_control *dtc,
633ece13ac3SWu Fengguang 		 unsigned long dirty_ratelimit,
634ece13ac3SWu Fengguang 		 unsigned long task_ratelimit,
635ece13ac3SWu Fengguang 		 unsigned long dirtied,
63683712358SWu Fengguang 		 unsigned long period,
637ece13ac3SWu Fengguang 		 long pause,
638ece13ac3SWu Fengguang 		 unsigned long start_time),
639ece13ac3SWu Fengguang 
640f1ab2831STang Yizhou 	TP_ARGS(wb, dtc,
641ece13ac3SWu Fengguang 		dirty_ratelimit, task_ratelimit,
64283712358SWu Fengguang 		dirtied, period, pause, start_time),
643ece13ac3SWu Fengguang 
644ece13ac3SWu Fengguang 	TP_STRUCT__entry(
645ece13ac3SWu Fengguang 		__array(	 char,	bdi, 32)
646ece13ac3SWu Fengguang 		__field(unsigned long,	limit)
647ece13ac3SWu Fengguang 		__field(unsigned long,	setpoint)
648ece13ac3SWu Fengguang 		__field(unsigned long,	dirty)
64928c24ef9STang Yizhou 		__field(unsigned long,	wb_setpoint)
65028c24ef9STang Yizhou 		__field(unsigned long,	wb_dirty)
651ece13ac3SWu Fengguang 		__field(unsigned long,	dirty_ratelimit)
652ece13ac3SWu Fengguang 		__field(unsigned long,	task_ratelimit)
653ece13ac3SWu Fengguang 		__field(unsigned int,	dirtied)
654ece13ac3SWu Fengguang 		__field(unsigned int,	dirtied_pause)
655ece13ac3SWu Fengguang 		__field(unsigned long,	paused)
656ece13ac3SWu Fengguang 		__field(	 long,	pause)
65783712358SWu Fengguang 		__field(unsigned long,	period)
65883712358SWu Fengguang 		__field(	 long,	think)
659f05499a0STejun Heo 		__field(ino_t,		cgroup_ino)
660ece13ac3SWu Fengguang 	),
661ece13ac3SWu Fengguang 
662ece13ac3SWu Fengguang 	TP_fast_assign(
663f1ab2831STang Yizhou 		unsigned long freerun = (dtc->thresh + dtc->bg_thresh) / 2;
66468f23b89STheodore Ts'o 		strscpy_pad(__entry->bdi, bdi_dev_name(wb->bdi), 32);
665ece13ac3SWu Fengguang 
666*6cc4c3aaSTang Yizhou 		__entry->limit		= dtc->limit;
667*6cc4c3aaSTang Yizhou 		__entry->setpoint	= (dtc->limit + freerun) / 2;
668f1ab2831STang Yizhou 		__entry->dirty		= dtc->dirty;
66928c24ef9STang Yizhou 		__entry->wb_setpoint	= __entry->setpoint *
670f1ab2831STang Yizhou 						dtc->wb_thresh / (dtc->thresh + 1);
67128c24ef9STang Yizhou 		__entry->wb_dirty	= dtc->wb_dirty;
672ece13ac3SWu Fengguang 		__entry->dirty_ratelimit = KBps(dirty_ratelimit);
673ece13ac3SWu Fengguang 		__entry->task_ratelimit	= KBps(task_ratelimit);
674ece13ac3SWu Fengguang 		__entry->dirtied	= dirtied;
675ece13ac3SWu Fengguang 		__entry->dirtied_pause	= current->nr_dirtied_pause;
67683712358SWu Fengguang 		__entry->think		= current->dirty_paused_when == 0 ? 0 :
67783712358SWu Fengguang 			 (long)(jiffies - current->dirty_paused_when) * 1000/HZ;
67883712358SWu Fengguang 		__entry->period		= period * 1000 / HZ;
679ece13ac3SWu Fengguang 		__entry->pause		= pause * 1000 / HZ;
680ece13ac3SWu Fengguang 		__entry->paused		= (jiffies - start_time) * 1000 / HZ;
681a664edb3SYang Shi 		__entry->cgroup_ino	= __trace_wb_assign_cgroup(wb);
682ece13ac3SWu Fengguang 	),
683ece13ac3SWu Fengguang 
684ece13ac3SWu Fengguang 
685ece13ac3SWu Fengguang 	TP_printk("bdi %s: "
686ece13ac3SWu Fengguang 		  "limit=%lu setpoint=%lu dirty=%lu "
68728c24ef9STang Yizhou 		  "wb_setpoint=%lu wb_dirty=%lu "
688ece13ac3SWu Fengguang 		  "dirty_ratelimit=%lu task_ratelimit=%lu "
689ece13ac3SWu Fengguang 		  "dirtied=%u dirtied_pause=%u "
690f05499a0STejun Heo 		  "paused=%lu pause=%ld period=%lu think=%ld cgroup_ino=%lu",
691ece13ac3SWu Fengguang 		  __entry->bdi,
692ece13ac3SWu Fengguang 		  __entry->limit,
693ece13ac3SWu Fengguang 		  __entry->setpoint,
694ece13ac3SWu Fengguang 		  __entry->dirty,
69528c24ef9STang Yizhou 		  __entry->wb_setpoint,
69628c24ef9STang Yizhou 		  __entry->wb_dirty,
697ece13ac3SWu Fengguang 		  __entry->dirty_ratelimit,
698ece13ac3SWu Fengguang 		  __entry->task_ratelimit,
699ece13ac3SWu Fengguang 		  __entry->dirtied,
700ece13ac3SWu Fengguang 		  __entry->dirtied_pause,
701ece13ac3SWu Fengguang 		  __entry->paused,	/* ms */
70283712358SWu Fengguang 		  __entry->pause,	/* ms */
70383712358SWu Fengguang 		  __entry->period,	/* ms */
7045634cc2aSTejun Heo 		  __entry->think,	/* ms */
70540363cf1SQian Cai 		  (unsigned long)__entry->cgroup_ino
706ece13ac3SWu Fengguang 	  )
707ece13ac3SWu Fengguang );
708ece13ac3SWu Fengguang 
709cc1676d9SJan Kara TRACE_EVENT(writeback_sb_inodes_requeue,
710cc1676d9SJan Kara 
711cc1676d9SJan Kara 	TP_PROTO(struct inode *inode),
712cc1676d9SJan Kara 	TP_ARGS(inode),
713cc1676d9SJan Kara 
714cc1676d9SJan Kara 	TP_STRUCT__entry(
715cc1676d9SJan Kara 		__array(char, name, 32)
716f05499a0STejun Heo 		__field(ino_t, ino)
717cc1676d9SJan Kara 		__field(unsigned long, state)
718cc1676d9SJan Kara 		__field(unsigned long, dirtied_when)
719f05499a0STejun Heo 		__field(ino_t, cgroup_ino)
720cc1676d9SJan Kara 	),
721cc1676d9SJan Kara 
722cc1676d9SJan Kara 	TP_fast_assign(
723d1a445d3SQian Cai 		strscpy_pad(__entry->name,
72468f23b89STheodore Ts'o 			    bdi_dev_name(inode_to_bdi(inode)), 32);
725cc1676d9SJan Kara 		__entry->ino		= inode->i_ino;
726cc1676d9SJan Kara 		__entry->state		= inode->i_state;
727cc1676d9SJan Kara 		__entry->dirtied_when	= inode->dirtied_when;
728a664edb3SYang Shi 		__entry->cgroup_ino	= __trace_wb_assign_cgroup(inode_to_wb(inode));
729cc1676d9SJan Kara 	),
730cc1676d9SJan Kara 
731f05499a0STejun Heo 	TP_printk("bdi %s: ino=%lu state=%s dirtied_when=%lu age=%lu cgroup_ino=%lu",
732cc1676d9SJan Kara 		  __entry->name,
73340363cf1SQian Cai 		  (unsigned long)__entry->ino,
734cc1676d9SJan Kara 		  show_inode_state(__entry->state),
735cc1676d9SJan Kara 		  __entry->dirtied_when,
7365634cc2aSTejun Heo 		  (jiffies - __entry->dirtied_when) / HZ,
73740363cf1SQian Cai 		  (unsigned long)__entry->cgroup_ino
738cc1676d9SJan Kara 	)
739cc1676d9SJan Kara );
740cc1676d9SJan Kara 
741251d6a47SWu Fengguang DECLARE_EVENT_CLASS(writeback_single_inode_template,
742251d6a47SWu Fengguang 
743251d6a47SWu Fengguang 	TP_PROTO(struct inode *inode,
744251d6a47SWu Fengguang 		 struct writeback_control *wbc,
745251d6a47SWu Fengguang 		 unsigned long nr_to_write
746251d6a47SWu Fengguang 	),
747251d6a47SWu Fengguang 
748251d6a47SWu Fengguang 	TP_ARGS(inode, wbc, nr_to_write),
749251d6a47SWu Fengguang 
750251d6a47SWu Fengguang 	TP_STRUCT__entry(
751251d6a47SWu Fengguang 		__array(char, name, 32)
752f05499a0STejun Heo 		__field(ino_t, ino)
753251d6a47SWu Fengguang 		__field(unsigned long, state)
754c8ad6206SWu Fengguang 		__field(unsigned long, dirtied_when)
755251d6a47SWu Fengguang 		__field(unsigned long, writeback_index)
756251d6a47SWu Fengguang 		__field(long, nr_to_write)
757251d6a47SWu Fengguang 		__field(unsigned long, wrote)
758f05499a0STejun Heo 		__field(ino_t, cgroup_ino)
759251d6a47SWu Fengguang 	),
760251d6a47SWu Fengguang 
761251d6a47SWu Fengguang 	TP_fast_assign(
762d1a445d3SQian Cai 		strscpy_pad(__entry->name,
76368f23b89STheodore Ts'o 			    bdi_dev_name(inode_to_bdi(inode)), 32);
764251d6a47SWu Fengguang 		__entry->ino		= inode->i_ino;
765251d6a47SWu Fengguang 		__entry->state		= inode->i_state;
766c8ad6206SWu Fengguang 		__entry->dirtied_when	= inode->dirtied_when;
767251d6a47SWu Fengguang 		__entry->writeback_index = inode->i_mapping->writeback_index;
768251d6a47SWu Fengguang 		__entry->nr_to_write	= nr_to_write;
769251d6a47SWu Fengguang 		__entry->wrote		= nr_to_write - wbc->nr_to_write;
770a664edb3SYang Shi 		__entry->cgroup_ino	= __trace_wbc_assign_cgroup(wbc);
771251d6a47SWu Fengguang 	),
772251d6a47SWu Fengguang 
773c8ad6206SWu Fengguang 	TP_printk("bdi %s: ino=%lu state=%s dirtied_when=%lu age=%lu "
774f05499a0STejun Heo 		  "index=%lu to_write=%ld wrote=%lu cgroup_ino=%lu",
775251d6a47SWu Fengguang 		  __entry->name,
77640363cf1SQian Cai 		  (unsigned long)__entry->ino,
777251d6a47SWu Fengguang 		  show_inode_state(__entry->state),
778c8ad6206SWu Fengguang 		  __entry->dirtied_when,
779c8ad6206SWu Fengguang 		  (jiffies - __entry->dirtied_when) / HZ,
780251d6a47SWu Fengguang 		  __entry->writeback_index,
781251d6a47SWu Fengguang 		  __entry->nr_to_write,
7825634cc2aSTejun Heo 		  __entry->wrote,
78340363cf1SQian Cai 		  (unsigned long)__entry->cgroup_ino
784251d6a47SWu Fengguang 	)
785251d6a47SWu Fengguang );
786251d6a47SWu Fengguang 
7879fb0a7daSTejun Heo DEFINE_EVENT(writeback_single_inode_template, writeback_single_inode_start,
7889fb0a7daSTejun Heo 	TP_PROTO(struct inode *inode,
7899fb0a7daSTejun Heo 		 struct writeback_control *wbc,
7909fb0a7daSTejun Heo 		 unsigned long nr_to_write),
7919fb0a7daSTejun Heo 	TP_ARGS(inode, wbc, nr_to_write)
7929fb0a7daSTejun Heo );
7939fb0a7daSTejun Heo 
794251d6a47SWu Fengguang DEFINE_EVENT(writeback_single_inode_template, writeback_single_inode,
795251d6a47SWu Fengguang 	TP_PROTO(struct inode *inode,
796251d6a47SWu Fengguang 		 struct writeback_control *wbc,
797251d6a47SWu Fengguang 		 unsigned long nr_to_write),
798251d6a47SWu Fengguang 	TP_ARGS(inode, wbc, nr_to_write)
799251d6a47SWu Fengguang );
800251d6a47SWu Fengguang 
8019a46b04fSBrian Foster DECLARE_EVENT_CLASS(writeback_inode_template,
8020ae45f63STheodore Ts'o 	TP_PROTO(struct inode *inode),
8030ae45f63STheodore Ts'o 
8040ae45f63STheodore Ts'o 	TP_ARGS(inode),
8050ae45f63STheodore Ts'o 
8060ae45f63STheodore Ts'o 	TP_STRUCT__entry(
8070ae45f63STheodore Ts'o 		__field(	dev_t,	dev			)
808f05499a0STejun Heo 		__field(	ino_t,	ino			)
8090ae45f63STheodore Ts'o 		__field(unsigned long,	state			)
8100ae45f63STheodore Ts'o 		__field(	__u16, mode			)
8110ae45f63STheodore Ts'o 		__field(unsigned long, dirtied_when		)
8120ae45f63STheodore Ts'o 	),
8130ae45f63STheodore Ts'o 
8140ae45f63STheodore Ts'o 	TP_fast_assign(
8150ae45f63STheodore Ts'o 		__entry->dev	= inode->i_sb->s_dev;
8160ae45f63STheodore Ts'o 		__entry->ino	= inode->i_ino;
8170ae45f63STheodore Ts'o 		__entry->state	= inode->i_state;
8180ae45f63STheodore Ts'o 		__entry->mode	= inode->i_mode;
8190ae45f63STheodore Ts'o 		__entry->dirtied_when = inode->dirtied_when;
8200ae45f63STheodore Ts'o 	),
8210ae45f63STheodore Ts'o 
8220ae45f63STheodore Ts'o 	TP_printk("dev %d,%d ino %lu dirtied %lu state %s mode 0%o",
8230ae45f63STheodore Ts'o 		  MAJOR(__entry->dev), MINOR(__entry->dev),
82440363cf1SQian Cai 		  (unsigned long)__entry->ino, __entry->dirtied_when,
8250ae45f63STheodore Ts'o 		  show_inode_state(__entry->state), __entry->mode)
8260ae45f63STheodore Ts'o );
8270ae45f63STheodore Ts'o 
8289a46b04fSBrian Foster DEFINE_EVENT(writeback_inode_template, writeback_lazytime,
8290ae45f63STheodore Ts'o 	TP_PROTO(struct inode *inode),
8300ae45f63STheodore Ts'o 
8310ae45f63STheodore Ts'o 	TP_ARGS(inode)
8320ae45f63STheodore Ts'o );
8330ae45f63STheodore Ts'o 
8349a46b04fSBrian Foster DEFINE_EVENT(writeback_inode_template, writeback_lazytime_iput,
8350ae45f63STheodore Ts'o 	TP_PROTO(struct inode *inode),
8360ae45f63STheodore Ts'o 
8370ae45f63STheodore Ts'o 	TP_ARGS(inode)
8380ae45f63STheodore Ts'o );
8390ae45f63STheodore Ts'o 
8409a46b04fSBrian Foster DEFINE_EVENT(writeback_inode_template, writeback_dirty_inode_enqueue,
8410ae45f63STheodore Ts'o 
8420ae45f63STheodore Ts'o 	TP_PROTO(struct inode *inode),
8430ae45f63STheodore Ts'o 
8440ae45f63STheodore Ts'o 	TP_ARGS(inode)
8450ae45f63STheodore Ts'o );
8460ae45f63STheodore Ts'o 
8479a46b04fSBrian Foster /*
8489a46b04fSBrian Foster  * Inode writeback list tracking.
8499a46b04fSBrian Foster  */
8509a46b04fSBrian Foster 
8519a46b04fSBrian Foster DEFINE_EVENT(writeback_inode_template, sb_mark_inode_writeback,
8529a46b04fSBrian Foster 	TP_PROTO(struct inode *inode),
8539a46b04fSBrian Foster 	TP_ARGS(inode)
8549a46b04fSBrian Foster );
8559a46b04fSBrian Foster 
8569a46b04fSBrian Foster DEFINE_EVENT(writeback_inode_template, sb_clear_inode_writeback,
8579a46b04fSBrian Foster 	TP_PROTO(struct inode *inode),
8589a46b04fSBrian Foster 	TP_ARGS(inode)
8599a46b04fSBrian Foster );
8609a46b04fSBrian Foster 
861455b2864SDave Chinner #endif /* _TRACE_WRITEBACK_H */
862455b2864SDave Chinner 
863455b2864SDave Chinner /* This part must be outside protection */
864455b2864SDave Chinner #include <trace/define_trace.h>
865