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