blob: a9f12969c7b256bc96e528f4df2c71b11a1b8163 [file] [log] [blame]
Namjae Jeona2a4a7e2013-04-20 01:28:40 +09001#undef TRACE_SYSTEM
2#define TRACE_SYSTEM f2fs
3
4#if !defined(_TRACE_F2FS_H) || defined(TRACE_HEADER_MULTI_READ)
5#define _TRACE_F2FS_H
6
7#include <linux/tracepoint.h>
8
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07009#define show_dev(dev) MAJOR(dev), MINOR(dev)
10#define show_dev_ino(entry) show_dev(entry->dev), (unsigned long)entry->ino
Namjae Jeon6ec178d2013-04-23 17:51:43 +090011
Steven Rostedt (Red Hat)5511b9a2015-03-27 16:18:07 -040012TRACE_DEFINE_ENUM(NODE);
13TRACE_DEFINE_ENUM(DATA);
14TRACE_DEFINE_ENUM(META);
15TRACE_DEFINE_ENUM(META_FLUSH);
Jaegeuk Kim5d799882015-04-22 16:07:38 -070016TRACE_DEFINE_ENUM(INMEM);
17TRACE_DEFINE_ENUM(INMEM_DROP);
Jaegeuk Kime6b120d2017-07-10 12:55:09 -070018TRACE_DEFINE_ENUM(INMEM_INVALIDATE);
19TRACE_DEFINE_ENUM(INMEM_REVOKE);
Jaegeuk Kim5d799882015-04-22 16:07:38 -070020TRACE_DEFINE_ENUM(IPU);
21TRACE_DEFINE_ENUM(OPU);
Steven Rostedt (Red Hat)5511b9a2015-03-27 16:18:07 -040022TRACE_DEFINE_ENUM(CURSEG_HOT_DATA);
23TRACE_DEFINE_ENUM(CURSEG_WARM_DATA);
24TRACE_DEFINE_ENUM(CURSEG_COLD_DATA);
25TRACE_DEFINE_ENUM(CURSEG_HOT_NODE);
26TRACE_DEFINE_ENUM(CURSEG_WARM_NODE);
27TRACE_DEFINE_ENUM(CURSEG_COLD_NODE);
28TRACE_DEFINE_ENUM(NO_CHECK_TYPE);
29TRACE_DEFINE_ENUM(GC_GREEDY);
30TRACE_DEFINE_ENUM(GC_CB);
31TRACE_DEFINE_ENUM(FG_GC);
32TRACE_DEFINE_ENUM(BG_GC);
33TRACE_DEFINE_ENUM(LFS);
34TRACE_DEFINE_ENUM(SSR);
35TRACE_DEFINE_ENUM(__REQ_RAHEAD);
Steven Rostedt (Red Hat)5511b9a2015-03-27 16:18:07 -040036TRACE_DEFINE_ENUM(__REQ_SYNC);
37TRACE_DEFINE_ENUM(__REQ_NOIDLE);
Mike Christie28a8f0d2016-06-05 14:32:25 -050038TRACE_DEFINE_ENUM(__REQ_PREFLUSH);
Steven Rostedt (Red Hat)5511b9a2015-03-27 16:18:07 -040039TRACE_DEFINE_ENUM(__REQ_FUA);
40TRACE_DEFINE_ENUM(__REQ_PRIO);
41TRACE_DEFINE_ENUM(__REQ_META);
42TRACE_DEFINE_ENUM(CP_UMOUNT);
43TRACE_DEFINE_ENUM(CP_FASTBOOT);
44TRACE_DEFINE_ENUM(CP_SYNC);
Jaegeuk Kim5d799882015-04-22 16:07:38 -070045TRACE_DEFINE_ENUM(CP_RECOVERY);
Steven Rostedt (Red Hat)5511b9a2015-03-27 16:18:07 -040046TRACE_DEFINE_ENUM(CP_DISCARD);
Jaegeuk Kime6b120d2017-07-10 12:55:09 -070047TRACE_DEFINE_ENUM(CP_TRIMMED);
Steven Rostedt (Red Hat)5511b9a2015-03-27 16:18:07 -040048
Namjae Jeon6ec178d2013-04-23 17:51:43 +090049#define show_block_type(type) \
50 __print_symbolic(type, \
51 { NODE, "NODE" }, \
52 { DATA, "DATA" }, \
53 { META, "META" }, \
Jaegeuk Kim8ce67cb2015-03-17 17:58:08 -070054 { META_FLUSH, "META_FLUSH" }, \
55 { INMEM, "INMEM" }, \
56 { INMEM_DROP, "INMEM_DROP" }, \
Jaegeuk Kime6b120d2017-07-10 12:55:09 -070057 { INMEM_INVALIDATE, "INMEM_INVALIDATE" }, \
Chao Yu28bc1062016-02-06 14:40:34 +080058 { INMEM_REVOKE, "INMEM_REVOKE" }, \
Jaegeuk Kim8ce67cb2015-03-17 17:58:08 -070059 { IPU, "IN-PLACE" }, \
60 { OPU, "OUT-OF-PLACE" })
Namjae Jeon6ec178d2013-04-23 17:51:43 +090061
Jaegeuk Kime6b120d2017-07-10 12:55:09 -070062#define F2FS_OP_FLAGS (REQ_RAHEAD | REQ_SYNC | REQ_META | REQ_PRIO | \
63 REQ_PREFLUSH | REQ_FUA)
64#define F2FS_BIO_FLAG_MASK(t) (t & F2FS_OP_FLAGS)
Jaegeuk Kima709f4a2013-11-24 14:42:23 +090065
Jaegeuk Kime6b120d2017-07-10 12:55:09 -070066#define show_bio_type(op,op_flags) show_bio_op(op), \
67 show_bio_op_flags(op_flags)
68
69#define show_bio_op(op) \
70 __print_symbolic(op, \
71 { REQ_OP_READ, "READ" }, \
72 { REQ_OP_WRITE, "WRITE" }, \
73 { REQ_OP_DISCARD, "DISCARD" }, \
74 { REQ_OP_SECURE_ERASE, "SECURE_ERASE" }, \
75 { REQ_OP_WRITE_SAME, "WRITE_SAME" })
Mike Christie04d328d2016-06-05 14:31:55 -050076
77#define show_bio_op_flags(flags) \
Jaegeuk Kime6b120d2017-07-10 12:55:09 -070078 __print_flags(F2FS_BIO_FLAG_MASK(flags), "|", \
79 { REQ_RAHEAD, "R" }, \
80 { REQ_SYNC, "S" }, \
81 { REQ_META, "M" }, \
82 { REQ_PRIO, "P" }, \
83 { REQ_PREFLUSH, "PF" }, \
84 { REQ_FUA, "FUA" })
Jaegeuk Kima709f4a2013-11-24 14:42:23 +090085
Jaegeuk Kimc4127262017-05-10 11:18:25 -070086#define show_block_temp(temp) \
87 __print_symbolic(temp, \
88 { HOT, "HOT" }, \
89 { WARM, "WARM" }, \
90 { COLD, "COLD" })
91
Namjae Jeon8e46b3e2013-04-23 16:42:53 +090092#define show_data_type(type) \
93 __print_symbolic(type, \
94 { CURSEG_HOT_DATA, "Hot DATA" }, \
95 { CURSEG_WARM_DATA, "Warm DATA" }, \
96 { CURSEG_COLD_DATA, "Cold DATA" }, \
97 { CURSEG_HOT_NODE, "Hot NODE" }, \
98 { CURSEG_WARM_NODE, "Warm NODE" }, \
99 { CURSEG_COLD_NODE, "Cold NODE" }, \
100 { NO_CHECK_TYPE, "No TYPE" })
101
Jaegeuk Kim26c6b882013-10-24 17:53:29 +0900102#define show_file_type(type) \
103 __print_symbolic(type, \
104 { 0, "FILE" }, \
105 { 1, "DIR" })
106
Namjae Jeon8e46b3e2013-04-23 16:42:53 +0900107#define show_gc_type(type) \
108 __print_symbolic(type, \
109 { FG_GC, "Foreground GC" }, \
110 { BG_GC, "Background GC" })
111
112#define show_alloc_mode(type) \
113 __print_symbolic(type, \
114 { LFS, "LFS-mode" }, \
115 { SSR, "SSR-mode" })
116
117#define show_victim_policy(type) \
118 __print_symbolic(type, \
119 { GC_GREEDY, "Greedy" }, \
120 { GC_CB, "Cost-Benefit" })
121
Jaegeuk Kim75ab4cb2014-09-20 21:57:51 -0700122#define show_cpreason(type) \
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700123 __print_flags(type, "|", \
Jaegeuk Kim75ab4cb2014-09-20 21:57:51 -0700124 { CP_UMOUNT, "Umount" }, \
Jaegeuk Kim119ee912015-01-29 11:45:33 -0800125 { CP_FASTBOOT, "Fastboot" }, \
Jaegeuk Kim4b2fecc2014-09-20 22:06:39 -0700126 { CP_SYNC, "Sync" }, \
Jaegeuk Kim10027552015-04-09 17:03:53 -0700127 { CP_RECOVERY, "Recovery" }, \
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700128 { CP_DISCARD, "Discard" }, \
129 { CP_UMOUNT, "Umount" }, \
130 { CP_TRIMMED, "Trimmed" })
Jaegeuk Kim75ab4cb2014-09-20 21:57:51 -0700131
Namjae Jeon8e46b3e2013-04-23 16:42:53 +0900132struct victim_sel_policy;
Jaegeuk Kim003a3e12015-04-06 19:55:34 -0700133struct f2fs_map_blocks;
Namjae Jeon8e46b3e2013-04-23 16:42:53 +0900134
Namjae Jeona2a4a7e2013-04-20 01:28:40 +0900135DECLARE_EVENT_CLASS(f2fs__inode,
136
137 TP_PROTO(struct inode *inode),
138
139 TP_ARGS(inode),
140
141 TP_STRUCT__entry(
142 __field(dev_t, dev)
143 __field(ino_t, ino)
144 __field(ino_t, pino)
145 __field(umode_t, mode)
146 __field(loff_t, size)
147 __field(unsigned int, nlink)
148 __field(blkcnt_t, blocks)
149 __field(__u8, advise)
150 ),
151
152 TP_fast_assign(
153 __entry->dev = inode->i_sb->s_dev;
154 __entry->ino = inode->i_ino;
155 __entry->pino = F2FS_I(inode)->i_pino;
156 __entry->mode = inode->i_mode;
157 __entry->nlink = inode->i_nlink;
158 __entry->size = inode->i_size;
159 __entry->blocks = inode->i_blocks;
160 __entry->advise = F2FS_I(inode)->i_advise;
161 ),
162
163 TP_printk("dev = (%d,%d), ino = %lu, pino = %lu, i_mode = 0x%hx, "
164 "i_size = %lld, i_nlink = %u, i_blocks = %llu, i_advise = 0x%x",
165 show_dev_ino(__entry),
166 (unsigned long)__entry->pino,
167 __entry->mode,
168 __entry->size,
169 (unsigned int)__entry->nlink,
170 (unsigned long long)__entry->blocks,
171 (unsigned char)__entry->advise)
172);
173
174DECLARE_EVENT_CLASS(f2fs__inode_exit,
175
176 TP_PROTO(struct inode *inode, int ret),
177
178 TP_ARGS(inode, ret),
179
180 TP_STRUCT__entry(
181 __field(dev_t, dev)
182 __field(ino_t, ino)
183 __field(int, ret)
184 ),
185
186 TP_fast_assign(
187 __entry->dev = inode->i_sb->s_dev;
188 __entry->ino = inode->i_ino;
189 __entry->ret = ret;
190 ),
191
192 TP_printk("dev = (%d,%d), ino = %lu, ret = %d",
193 show_dev_ino(__entry),
194 __entry->ret)
195);
196
197DEFINE_EVENT(f2fs__inode, f2fs_sync_file_enter,
198
199 TP_PROTO(struct inode *inode),
200
201 TP_ARGS(inode)
202);
203
204TRACE_EVENT(f2fs_sync_file_exit,
205
Jaegeuk Kim29e70432015-02-10 16:23:12 -0800206 TP_PROTO(struct inode *inode, int need_cp, int datasync, int ret),
Namjae Jeona2a4a7e2013-04-20 01:28:40 +0900207
208 TP_ARGS(inode, need_cp, datasync, ret),
209
210 TP_STRUCT__entry(
211 __field(dev_t, dev)
212 __field(ino_t, ino)
Jaegeuk Kim29e70432015-02-10 16:23:12 -0800213 __field(int, need_cp)
Namjae Jeona2a4a7e2013-04-20 01:28:40 +0900214 __field(int, datasync)
215 __field(int, ret)
216 ),
217
218 TP_fast_assign(
219 __entry->dev = inode->i_sb->s_dev;
220 __entry->ino = inode->i_ino;
221 __entry->need_cp = need_cp;
222 __entry->datasync = datasync;
223 __entry->ret = ret;
224 ),
225
226 TP_printk("dev = (%d,%d), ino = %lu, checkpoint is %s, "
227 "datasync = %d, ret = %d",
228 show_dev_ino(__entry),
229 __entry->need_cp ? "needed" : "not needed",
230 __entry->datasync,
231 __entry->ret)
232);
233
234TRACE_EVENT(f2fs_sync_fs,
235
236 TP_PROTO(struct super_block *sb, int wait),
237
238 TP_ARGS(sb, wait),
239
240 TP_STRUCT__entry(
241 __field(dev_t, dev)
Jaegeuk Kim29e70432015-02-10 16:23:12 -0800242 __field(int, dirty)
Namjae Jeona2a4a7e2013-04-20 01:28:40 +0900243 __field(int, wait)
244 ),
245
246 TP_fast_assign(
247 __entry->dev = sb->s_dev;
Chao Yucaf00472015-01-28 17:48:42 +0800248 __entry->dirty = is_sbi_flag_set(F2FS_SB(sb), SBI_IS_DIRTY);
Namjae Jeona2a4a7e2013-04-20 01:28:40 +0900249 __entry->wait = wait;
250 ),
251
252 TP_printk("dev = (%d,%d), superblock is %s, wait = %d",
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700253 show_dev(__entry->dev),
Namjae Jeona2a4a7e2013-04-20 01:28:40 +0900254 __entry->dirty ? "dirty" : "not dirty",
255 __entry->wait)
256);
257
258DEFINE_EVENT(f2fs__inode, f2fs_iget,
259
260 TP_PROTO(struct inode *inode),
261
262 TP_ARGS(inode)
263);
264
265DEFINE_EVENT(f2fs__inode_exit, f2fs_iget_exit,
266
267 TP_PROTO(struct inode *inode, int ret),
268
269 TP_ARGS(inode, ret)
270);
271
272DEFINE_EVENT(f2fs__inode, f2fs_evict_inode,
273
274 TP_PROTO(struct inode *inode),
275
276 TP_ARGS(inode)
277);
278
Jaegeuk Kimd70b4f52013-04-25 13:24:33 +0900279DEFINE_EVENT(f2fs__inode_exit, f2fs_new_inode,
280
281 TP_PROTO(struct inode *inode, int ret),
282
283 TP_ARGS(inode, ret)
284);
285
Namjae Jeona2a4a7e2013-04-20 01:28:40 +0900286TRACE_EVENT(f2fs_unlink_enter,
287
288 TP_PROTO(struct inode *dir, struct dentry *dentry),
289
290 TP_ARGS(dir, dentry),
291
292 TP_STRUCT__entry(
293 __field(dev_t, dev)
294 __field(ino_t, ino)
295 __field(loff_t, size)
296 __field(blkcnt_t, blocks)
297 __field(const char *, name)
298 ),
299
300 TP_fast_assign(
301 __entry->dev = dir->i_sb->s_dev;
302 __entry->ino = dir->i_ino;
303 __entry->size = dir->i_size;
304 __entry->blocks = dir->i_blocks;
305 __entry->name = dentry->d_name.name;
306 ),
307
308 TP_printk("dev = (%d,%d), dir ino = %lu, i_size = %lld, "
309 "i_blocks = %llu, name = %s",
310 show_dev_ino(__entry),
311 __entry->size,
312 (unsigned long long)__entry->blocks,
313 __entry->name)
314);
315
316DEFINE_EVENT(f2fs__inode_exit, f2fs_unlink_exit,
317
318 TP_PROTO(struct inode *inode, int ret),
319
320 TP_ARGS(inode, ret)
321);
Namjae Jeon51dd6242013-04-20 01:28:52 +0900322
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700323DEFINE_EVENT(f2fs__inode_exit, f2fs_drop_inode,
324
325 TP_PROTO(struct inode *inode, int ret),
326
327 TP_ARGS(inode, ret)
328);
329
Namjae Jeon51dd6242013-04-20 01:28:52 +0900330DEFINE_EVENT(f2fs__inode, f2fs_truncate,
331
332 TP_PROTO(struct inode *inode),
333
334 TP_ARGS(inode)
335);
336
337TRACE_EVENT(f2fs_truncate_data_blocks_range,
338
339 TP_PROTO(struct inode *inode, nid_t nid, unsigned int ofs, int free),
340
341 TP_ARGS(inode, nid, ofs, free),
342
343 TP_STRUCT__entry(
344 __field(dev_t, dev)
345 __field(ino_t, ino)
346 __field(nid_t, nid)
347 __field(unsigned int, ofs)
348 __field(int, free)
349 ),
350
351 TP_fast_assign(
352 __entry->dev = inode->i_sb->s_dev;
353 __entry->ino = inode->i_ino;
354 __entry->nid = nid;
355 __entry->ofs = ofs;
356 __entry->free = free;
357 ),
358
359 TP_printk("dev = (%d,%d), ino = %lu, nid = %u, offset = %u, freed = %d",
360 show_dev_ino(__entry),
361 (unsigned int)__entry->nid,
362 __entry->ofs,
363 __entry->free)
364);
365
366DECLARE_EVENT_CLASS(f2fs__truncate_op,
367
368 TP_PROTO(struct inode *inode, u64 from),
369
370 TP_ARGS(inode, from),
371
372 TP_STRUCT__entry(
373 __field(dev_t, dev)
374 __field(ino_t, ino)
375 __field(loff_t, size)
376 __field(blkcnt_t, blocks)
377 __field(u64, from)
378 ),
379
380 TP_fast_assign(
381 __entry->dev = inode->i_sb->s_dev;
382 __entry->ino = inode->i_ino;
383 __entry->size = inode->i_size;
384 __entry->blocks = inode->i_blocks;
385 __entry->from = from;
386 ),
387
388 TP_printk("dev = (%d,%d), ino = %lu, i_size = %lld, i_blocks = %llu, "
389 "start file offset = %llu",
390 show_dev_ino(__entry),
391 __entry->size,
392 (unsigned long long)__entry->blocks,
393 (unsigned long long)__entry->from)
394);
395
396DEFINE_EVENT(f2fs__truncate_op, f2fs_truncate_blocks_enter,
397
398 TP_PROTO(struct inode *inode, u64 from),
399
400 TP_ARGS(inode, from)
401);
402
403DEFINE_EVENT(f2fs__inode_exit, f2fs_truncate_blocks_exit,
404
405 TP_PROTO(struct inode *inode, int ret),
406
407 TP_ARGS(inode, ret)
408);
409
410DEFINE_EVENT(f2fs__truncate_op, f2fs_truncate_inode_blocks_enter,
411
412 TP_PROTO(struct inode *inode, u64 from),
413
414 TP_ARGS(inode, from)
415);
416
417DEFINE_EVENT(f2fs__inode_exit, f2fs_truncate_inode_blocks_exit,
418
419 TP_PROTO(struct inode *inode, int ret),
420
421 TP_ARGS(inode, ret)
422);
423
424DECLARE_EVENT_CLASS(f2fs__truncate_node,
425
426 TP_PROTO(struct inode *inode, nid_t nid, block_t blk_addr),
427
428 TP_ARGS(inode, nid, blk_addr),
429
430 TP_STRUCT__entry(
431 __field(dev_t, dev)
432 __field(ino_t, ino)
433 __field(nid_t, nid)
434 __field(block_t, blk_addr)
435 ),
436
437 TP_fast_assign(
438 __entry->dev = inode->i_sb->s_dev;
439 __entry->ino = inode->i_ino;
440 __entry->nid = nid;
441 __entry->blk_addr = blk_addr;
442 ),
443
444 TP_printk("dev = (%d,%d), ino = %lu, nid = %u, block_address = 0x%llx",
445 show_dev_ino(__entry),
446 (unsigned int)__entry->nid,
447 (unsigned long long)__entry->blk_addr)
448);
449
450DEFINE_EVENT(f2fs__truncate_node, f2fs_truncate_nodes_enter,
451
452 TP_PROTO(struct inode *inode, nid_t nid, block_t blk_addr),
453
454 TP_ARGS(inode, nid, blk_addr)
455);
456
457DEFINE_EVENT(f2fs__inode_exit, f2fs_truncate_nodes_exit,
458
459 TP_PROTO(struct inode *inode, int ret),
460
461 TP_ARGS(inode, ret)
462);
463
464DEFINE_EVENT(f2fs__truncate_node, f2fs_truncate_node,
465
466 TP_PROTO(struct inode *inode, nid_t nid, block_t blk_addr),
467
468 TP_ARGS(inode, nid, blk_addr)
469);
470
471TRACE_EVENT(f2fs_truncate_partial_nodes,
472
473 TP_PROTO(struct inode *inode, nid_t nid[], int depth, int err),
474
475 TP_ARGS(inode, nid, depth, err),
476
477 TP_STRUCT__entry(
478 __field(dev_t, dev)
479 __field(ino_t, ino)
480 __field(nid_t, nid[3])
481 __field(int, depth)
482 __field(int, err)
483 ),
484
485 TP_fast_assign(
486 __entry->dev = inode->i_sb->s_dev;
487 __entry->ino = inode->i_ino;
488 __entry->nid[0] = nid[0];
489 __entry->nid[1] = nid[1];
490 __entry->nid[2] = nid[2];
491 __entry->depth = depth;
492 __entry->err = err;
493 ),
494
495 TP_printk("dev = (%d,%d), ino = %lu, "
496 "nid[0] = %u, nid[1] = %u, nid[2] = %u, depth = %d, err = %d",
497 show_dev_ino(__entry),
498 (unsigned int)__entry->nid[0],
499 (unsigned int)__entry->nid[1],
500 (unsigned int)__entry->nid[2],
501 __entry->depth,
502 __entry->err)
503);
504
Jaegeuk Kim003a3e12015-04-06 19:55:34 -0700505TRACE_EVENT(f2fs_map_blocks,
506 TP_PROTO(struct inode *inode, struct f2fs_map_blocks *map, int ret),
Namjae Jeon848753a2013-04-23 16:38:02 +0900507
Jaegeuk Kim003a3e12015-04-06 19:55:34 -0700508 TP_ARGS(inode, map, ret),
Namjae Jeon848753a2013-04-23 16:38:02 +0900509
510 TP_STRUCT__entry(
511 __field(dev_t, dev)
512 __field(ino_t, ino)
Jaegeuk Kim003a3e12015-04-06 19:55:34 -0700513 __field(block_t, m_lblk)
514 __field(block_t, m_pblk)
515 __field(unsigned int, m_len)
Namjae Jeon848753a2013-04-23 16:38:02 +0900516 __field(int, ret)
517 ),
518
519 TP_fast_assign(
520 __entry->dev = inode->i_sb->s_dev;
521 __entry->ino = inode->i_ino;
Jaegeuk Kim003a3e12015-04-06 19:55:34 -0700522 __entry->m_lblk = map->m_lblk;
523 __entry->m_pblk = map->m_pblk;
524 __entry->m_len = map->m_len;
Namjae Jeon848753a2013-04-23 16:38:02 +0900525 __entry->ret = ret;
526 ),
527
528 TP_printk("dev = (%d,%d), ino = %lu, file offset = %llu, "
Jaegeuk Kim003a3e12015-04-06 19:55:34 -0700529 "start blkaddr = 0x%llx, len = 0x%llx, err = %d",
Namjae Jeon848753a2013-04-23 16:38:02 +0900530 show_dev_ino(__entry),
Jaegeuk Kim003a3e12015-04-06 19:55:34 -0700531 (unsigned long long)__entry->m_lblk,
532 (unsigned long long)__entry->m_pblk,
533 (unsigned long long)__entry->m_len,
Namjae Jeon848753a2013-04-23 16:38:02 +0900534 __entry->ret)
535);
536
Jaegeuk Kim5c267432015-10-05 11:32:34 -0700537TRACE_EVENT(f2fs_background_gc,
538
Chao Yu80049562017-08-07 23:12:46 +0800539 TP_PROTO(struct super_block *sb, unsigned int wait_ms,
Jaegeuk Kim5c267432015-10-05 11:32:34 -0700540 unsigned int prefree, unsigned int free),
541
542 TP_ARGS(sb, wait_ms, prefree, free),
543
544 TP_STRUCT__entry(
545 __field(dev_t, dev)
Chao Yu80049562017-08-07 23:12:46 +0800546 __field(unsigned int, wait_ms)
Jaegeuk Kim5c267432015-10-05 11:32:34 -0700547 __field(unsigned int, prefree)
548 __field(unsigned int, free)
549 ),
550
551 TP_fast_assign(
552 __entry->dev = sb->s_dev;
553 __entry->wait_ms = wait_ms;
554 __entry->prefree = prefree;
555 __entry->free = free;
556 ),
557
Chao Yu80049562017-08-07 23:12:46 +0800558 TP_printk("dev = (%d,%d), wait_ms = %u, prefree = %u, free = %u",
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700559 show_dev(__entry->dev),
Jaegeuk Kim5c267432015-10-05 11:32:34 -0700560 __entry->wait_ms,
561 __entry->prefree,
562 __entry->free)
563);
564
Chao Yu796786d2017-08-11 18:00:15 +0800565TRACE_EVENT(f2fs_gc_begin,
566
567 TP_PROTO(struct super_block *sb, bool sync, bool background,
568 long long dirty_nodes, long long dirty_dents,
569 long long dirty_imeta, unsigned int free_sec,
570 unsigned int free_seg, int reserved_seg,
571 unsigned int prefree_seg),
572
573 TP_ARGS(sb, sync, background, dirty_nodes, dirty_dents, dirty_imeta,
574 free_sec, free_seg, reserved_seg, prefree_seg),
575
576 TP_STRUCT__entry(
577 __field(dev_t, dev)
578 __field(bool, sync)
579 __field(bool, background)
580 __field(long long, dirty_nodes)
581 __field(long long, dirty_dents)
582 __field(long long, dirty_imeta)
583 __field(unsigned int, free_sec)
584 __field(unsigned int, free_seg)
585 __field(int, reserved_seg)
586 __field(unsigned int, prefree_seg)
587 ),
588
589 TP_fast_assign(
590 __entry->dev = sb->s_dev;
591 __entry->sync = sync;
592 __entry->background = background;
593 __entry->dirty_nodes = dirty_nodes;
594 __entry->dirty_dents = dirty_dents;
595 __entry->dirty_imeta = dirty_imeta;
596 __entry->free_sec = free_sec;
597 __entry->free_seg = free_seg;
598 __entry->reserved_seg = reserved_seg;
599 __entry->prefree_seg = prefree_seg;
600 ),
601
602 TP_printk("dev = (%d,%d), sync = %d, background = %d, nodes = %lld, "
603 "dents = %lld, imeta = %lld, free_sec:%u, free_seg:%u, "
604 "rsv_seg:%d, prefree_seg:%u",
605 show_dev(__entry->dev),
606 __entry->sync,
607 __entry->background,
608 __entry->dirty_nodes,
609 __entry->dirty_dents,
610 __entry->dirty_imeta,
611 __entry->free_sec,
612 __entry->free_seg,
613 __entry->reserved_seg,
614 __entry->prefree_seg)
615);
616
617TRACE_EVENT(f2fs_gc_end,
618
619 TP_PROTO(struct super_block *sb, int ret, int seg_freed,
620 int sec_freed, long long dirty_nodes,
621 long long dirty_dents, long long dirty_imeta,
622 unsigned int free_sec, unsigned int free_seg,
623 int reserved_seg, unsigned int prefree_seg),
624
625 TP_ARGS(sb, ret, seg_freed, sec_freed, dirty_nodes, dirty_dents,
626 dirty_imeta, free_sec, free_seg, reserved_seg, prefree_seg),
627
628 TP_STRUCT__entry(
629 __field(dev_t, dev)
630 __field(int, ret)
631 __field(int, seg_freed)
632 __field(int, sec_freed)
633 __field(long long, dirty_nodes)
634 __field(long long, dirty_dents)
635 __field(long long, dirty_imeta)
636 __field(unsigned int, free_sec)
637 __field(unsigned int, free_seg)
638 __field(int, reserved_seg)
639 __field(unsigned int, prefree_seg)
640 ),
641
642 TP_fast_assign(
643 __entry->dev = sb->s_dev;
644 __entry->ret = ret;
645 __entry->seg_freed = seg_freed;
646 __entry->sec_freed = sec_freed;
647 __entry->dirty_nodes = dirty_nodes;
648 __entry->dirty_dents = dirty_dents;
649 __entry->dirty_imeta = dirty_imeta;
650 __entry->free_sec = free_sec;
651 __entry->free_seg = free_seg;
652 __entry->reserved_seg = reserved_seg;
653 __entry->prefree_seg = prefree_seg;
654 ),
655
656 TP_printk("dev = (%d,%d), ret = %d, seg_freed = %d, sec_freed = %d, "
657 "nodes = %lld, dents = %lld, imeta = %lld, free_sec:%u, "
658 "free_seg:%u, rsv_seg:%d, prefree_seg:%u",
659 show_dev(__entry->dev),
660 __entry->ret,
661 __entry->seg_freed,
662 __entry->sec_freed,
663 __entry->dirty_nodes,
664 __entry->dirty_dents,
665 __entry->dirty_imeta,
666 __entry->free_sec,
667 __entry->free_seg,
668 __entry->reserved_seg,
669 __entry->prefree_seg)
670);
671
Namjae Jeon8e46b3e2013-04-23 16:42:53 +0900672TRACE_EVENT(f2fs_get_victim,
673
674 TP_PROTO(struct super_block *sb, int type, int gc_type,
675 struct victim_sel_policy *p, unsigned int pre_victim,
676 unsigned int prefree, unsigned int free),
677
678 TP_ARGS(sb, type, gc_type, p, pre_victim, prefree, free),
679
680 TP_STRUCT__entry(
681 __field(dev_t, dev)
682 __field(int, type)
683 __field(int, gc_type)
684 __field(int, alloc_mode)
685 __field(int, gc_mode)
686 __field(unsigned int, victim)
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700687 __field(unsigned int, cost)
Namjae Jeon8e46b3e2013-04-23 16:42:53 +0900688 __field(unsigned int, ofs_unit)
689 __field(unsigned int, pre_victim)
690 __field(unsigned int, prefree)
691 __field(unsigned int, free)
692 ),
693
694 TP_fast_assign(
695 __entry->dev = sb->s_dev;
696 __entry->type = type;
697 __entry->gc_type = gc_type;
698 __entry->alloc_mode = p->alloc_mode;
699 __entry->gc_mode = p->gc_mode;
700 __entry->victim = p->min_segno;
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700701 __entry->cost = p->min_cost;
Namjae Jeon8e46b3e2013-04-23 16:42:53 +0900702 __entry->ofs_unit = p->ofs_unit;
703 __entry->pre_victim = pre_victim;
704 __entry->prefree = prefree;
705 __entry->free = free;
706 ),
707
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700708 TP_printk("dev = (%d,%d), type = %s, policy = (%s, %s, %s), "
709 "victim = %u, cost = %u, ofs_unit = %u, "
710 "pre_victim_secno = %d, prefree = %u, free = %u",
711 show_dev(__entry->dev),
Namjae Jeon8e46b3e2013-04-23 16:42:53 +0900712 show_data_type(__entry->type),
713 show_gc_type(__entry->gc_type),
714 show_alloc_mode(__entry->alloc_mode),
715 show_victim_policy(__entry->gc_mode),
716 __entry->victim,
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700717 __entry->cost,
Namjae Jeon8e46b3e2013-04-23 16:42:53 +0900718 __entry->ofs_unit,
719 (int)__entry->pre_victim,
720 __entry->prefree,
721 __entry->free)
722);
723
Namjae Jeonc01e2852013-04-23 17:00:52 +0900724TRACE_EVENT(f2fs_fallocate,
725
726 TP_PROTO(struct inode *inode, int mode,
727 loff_t offset, loff_t len, int ret),
728
729 TP_ARGS(inode, mode, offset, len, ret),
730
731 TP_STRUCT__entry(
732 __field(dev_t, dev)
733 __field(ino_t, ino)
734 __field(int, mode)
735 __field(loff_t, offset)
736 __field(loff_t, len)
737 __field(loff_t, size)
738 __field(blkcnt_t, blocks)
739 __field(int, ret)
740 ),
741
742 TP_fast_assign(
743 __entry->dev = inode->i_sb->s_dev;
744 __entry->ino = inode->i_ino;
745 __entry->mode = mode;
746 __entry->offset = offset;
747 __entry->len = len;
748 __entry->size = inode->i_size;
749 __entry->blocks = inode->i_blocks;
750 __entry->ret = ret;
751 ),
752
753 TP_printk("dev = (%d,%d), ino = %lu, mode = %x, offset = %lld, "
754 "len = %lld, i_size = %lld, i_blocks = %llu, ret = %d",
755 show_dev_ino(__entry),
756 __entry->mode,
757 (unsigned long long)__entry->offset,
758 (unsigned long long)__entry->len,
759 (unsigned long long)__entry->size,
760 (unsigned long long)__entry->blocks,
761 __entry->ret)
762);
763
Chao Yu70407fa2014-07-31 21:11:22 +0800764TRACE_EVENT(f2fs_direct_IO_enter,
765
766 TP_PROTO(struct inode *inode, loff_t offset, unsigned long len, int rw),
767
768 TP_ARGS(inode, offset, len, rw),
769
770 TP_STRUCT__entry(
771 __field(dev_t, dev)
772 __field(ino_t, ino)
773 __field(loff_t, pos)
774 __field(unsigned long, len)
775 __field(int, rw)
776 ),
777
778 TP_fast_assign(
779 __entry->dev = inode->i_sb->s_dev;
780 __entry->ino = inode->i_ino;
781 __entry->pos = offset;
782 __entry->len = len;
783 __entry->rw = rw;
784 ),
785
786 TP_printk("dev = (%d,%d), ino = %lu pos = %lld len = %lu rw = %d",
787 show_dev_ino(__entry),
788 __entry->pos,
789 __entry->len,
790 __entry->rw)
791);
792
793TRACE_EVENT(f2fs_direct_IO_exit,
794
795 TP_PROTO(struct inode *inode, loff_t offset, unsigned long len,
796 int rw, int ret),
797
798 TP_ARGS(inode, offset, len, rw, ret),
799
800 TP_STRUCT__entry(
801 __field(dev_t, dev)
802 __field(ino_t, ino)
803 __field(loff_t, pos)
804 __field(unsigned long, len)
805 __field(int, rw)
806 __field(int, ret)
807 ),
808
809 TP_fast_assign(
810 __entry->dev = inode->i_sb->s_dev;
811 __entry->ino = inode->i_ino;
812 __entry->pos = offset;
813 __entry->len = len;
814 __entry->rw = rw;
815 __entry->ret = ret;
816 ),
817
818 TP_printk("dev = (%d,%d), ino = %lu pos = %lld len = %lu "
819 "rw = %d ret = %d",
820 show_dev_ino(__entry),
821 __entry->pos,
822 __entry->len,
823 __entry->rw,
824 __entry->ret)
825);
826
Chao Yu46008c62016-05-09 19:56:30 +0800827TRACE_EVENT(f2fs_reserve_new_blocks,
Namjae Jeonc01e2852013-04-23 17:00:52 +0900828
Chao Yu46008c62016-05-09 19:56:30 +0800829 TP_PROTO(struct inode *inode, nid_t nid, unsigned int ofs_in_node,
830 blkcnt_t count),
Namjae Jeonc01e2852013-04-23 17:00:52 +0900831
Chao Yu46008c62016-05-09 19:56:30 +0800832 TP_ARGS(inode, nid, ofs_in_node, count),
Namjae Jeonc01e2852013-04-23 17:00:52 +0900833
834 TP_STRUCT__entry(
835 __field(dev_t, dev)
836 __field(nid_t, nid)
837 __field(unsigned int, ofs_in_node)
Chao Yu46008c62016-05-09 19:56:30 +0800838 __field(blkcnt_t, count)
Namjae Jeonc01e2852013-04-23 17:00:52 +0900839 ),
840
841 TP_fast_assign(
842 __entry->dev = inode->i_sb->s_dev;
843 __entry->nid = nid;
844 __entry->ofs_in_node = ofs_in_node;
Chao Yu46008c62016-05-09 19:56:30 +0800845 __entry->count = count;
Namjae Jeonc01e2852013-04-23 17:00:52 +0900846 ),
847
Chao Yu46008c62016-05-09 19:56:30 +0800848 TP_printk("dev = (%d,%d), nid = %u, ofs_in_node = %u, count = %llu",
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700849 show_dev(__entry->dev),
Namjae Jeonc01e2852013-04-23 17:00:52 +0900850 (unsigned int)__entry->nid,
Chao Yu46008c62016-05-09 19:56:30 +0800851 __entry->ofs_in_node,
852 (unsigned long long)__entry->count)
Namjae Jeonc01e2852013-04-23 17:00:52 +0900853);
854
Chao Yu3e1c8f12014-12-23 16:35:21 +0800855DECLARE_EVENT_CLASS(f2fs__submit_page_bio,
856
Chao Yu2ace38e2014-12-24 16:08:14 +0800857 TP_PROTO(struct page *page, struct f2fs_io_info *fio),
Chao Yu3e1c8f12014-12-23 16:35:21 +0800858
Chao Yu2ace38e2014-12-24 16:08:14 +0800859 TP_ARGS(page, fio),
Chao Yu3e1c8f12014-12-23 16:35:21 +0800860
861 TP_STRUCT__entry(
862 __field(dev_t, dev)
863 __field(ino_t, ino)
864 __field(pgoff_t, index)
Chao Yu7a9d7542016-02-22 18:36:38 +0800865 __field(block_t, old_blkaddr)
866 __field(block_t, new_blkaddr)
Mike Christie04d328d2016-06-05 14:31:55 -0500867 __field(int, op)
868 __field(int, op_flags)
Jaegeuk Kimc4127262017-05-10 11:18:25 -0700869 __field(int, temp)
Chao Yu3e1c8f12014-12-23 16:35:21 +0800870 __field(int, type)
871 ),
872
873 TP_fast_assign(
874 __entry->dev = page->mapping->host->i_sb->s_dev;
875 __entry->ino = page->mapping->host->i_ino;
876 __entry->index = page->index;
Chao Yu7a9d7542016-02-22 18:36:38 +0800877 __entry->old_blkaddr = fio->old_blkaddr;
878 __entry->new_blkaddr = fio->new_blkaddr;
Mike Christie04d328d2016-06-05 14:31:55 -0500879 __entry->op = fio->op;
880 __entry->op_flags = fio->op_flags;
Jaegeuk Kimc4127262017-05-10 11:18:25 -0700881 __entry->temp = fio->temp;
Chao Yu2ace38e2014-12-24 16:08:14 +0800882 __entry->type = fio->type;
Chao Yu3e1c8f12014-12-23 16:35:21 +0800883 ),
884
885 TP_printk("dev = (%d,%d), ino = %lu, page_index = 0x%lx, "
Jaegeuk Kimc4127262017-05-10 11:18:25 -0700886 "oldaddr = 0x%llx, newaddr = 0x%llx, rw = %s(%s), type = %s_%s",
Chao Yu3e1c8f12014-12-23 16:35:21 +0800887 show_dev_ino(__entry),
888 (unsigned long)__entry->index,
Chao Yu7a9d7542016-02-22 18:36:38 +0800889 (unsigned long long)__entry->old_blkaddr,
890 (unsigned long long)__entry->new_blkaddr,
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700891 show_bio_type(__entry->op, __entry->op_flags),
Jaegeuk Kimc4127262017-05-10 11:18:25 -0700892 show_block_temp(__entry->temp),
Chao Yu3e1c8f12014-12-23 16:35:21 +0800893 show_block_type(__entry->type))
894);
895
896DEFINE_EVENT_CONDITION(f2fs__submit_page_bio, f2fs_submit_page_bio,
897
Chao Yu2ace38e2014-12-24 16:08:14 +0800898 TP_PROTO(struct page *page, struct f2fs_io_info *fio),
Chao Yu3e1c8f12014-12-23 16:35:21 +0800899
Chao Yu2ace38e2014-12-24 16:08:14 +0800900 TP_ARGS(page, fio),
Chao Yu3e1c8f12014-12-23 16:35:21 +0800901
902 TP_CONDITION(page->mapping)
903);
904
Jaegeuk Kim9bc576a2017-05-10 11:28:38 -0700905DEFINE_EVENT_CONDITION(f2fs__submit_page_bio, f2fs_submit_page_write,
Chao Yu3e1c8f12014-12-23 16:35:21 +0800906
Chao Yu2ace38e2014-12-24 16:08:14 +0800907 TP_PROTO(struct page *page, struct f2fs_io_info *fio),
Chao Yu3e1c8f12014-12-23 16:35:21 +0800908
Chao Yu2ace38e2014-12-24 16:08:14 +0800909 TP_ARGS(page, fio),
Chao Yu3e1c8f12014-12-23 16:35:21 +0800910
911 TP_CONDITION(page->mapping)
912);
913
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700914DECLARE_EVENT_CLASS(f2fs__bio,
Namjae Jeon6ec178d2013-04-23 17:51:43 +0900915
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700916 TP_PROTO(struct super_block *sb, int type, struct bio *bio),
Namjae Jeon6ec178d2013-04-23 17:51:43 +0900917
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700918 TP_ARGS(sb, type, bio),
Namjae Jeon6ec178d2013-04-23 17:51:43 +0900919
920 TP_STRUCT__entry(
921 __field(dev_t, dev)
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700922 __field(dev_t, target)
Mike Christie04d328d2016-06-05 14:31:55 -0500923 __field(int, op)
924 __field(int, op_flags)
Chao Yud4d288b2013-11-24 12:36:42 +0900925 __field(int, type)
Namjae Jeon6ec178d2013-04-23 17:51:43 +0900926 __field(sector_t, sector)
927 __field(unsigned int, size)
928 ),
929
930 TP_fast_assign(
931 __entry->dev = sb->s_dev;
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700932 __entry->target = bio->bi_bdev->bd_dev;
933 __entry->op = bio_op(bio);
934 __entry->op_flags = bio->bi_opf;
935 __entry->type = type;
Kent Overstreet4f024f32013-10-11 15:44:27 -0700936 __entry->sector = bio->bi_iter.bi_sector;
937 __entry->size = bio->bi_iter.bi_size;
Namjae Jeon6ec178d2013-04-23 17:51:43 +0900938 ),
939
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700940 TP_printk("dev = (%d,%d)/(%d,%d), rw = %s(%s), %s, sector = %lld, size = %u",
941 show_dev(__entry->target),
942 show_dev(__entry->dev),
943 show_bio_type(__entry->op, __entry->op_flags),
Chao Yud4d288b2013-11-24 12:36:42 +0900944 show_block_type(__entry->type),
Namjae Jeon6ec178d2013-04-23 17:51:43 +0900945 (unsigned long long)__entry->sector,
946 __entry->size)
947);
948
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700949DEFINE_EVENT_CONDITION(f2fs__bio, f2fs_prepare_write_bio,
Chao Yud4d288b2013-11-24 12:36:42 +0900950
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700951 TP_PROTO(struct super_block *sb, int type, struct bio *bio),
Chao Yud4d288b2013-11-24 12:36:42 +0900952
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700953 TP_ARGS(sb, type, bio),
Jaegeuk Kim93dfe2a2013-11-30 12:51:14 +0900954
955 TP_CONDITION(bio)
Chao Yud4d288b2013-11-24 12:36:42 +0900956);
957
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700958DEFINE_EVENT_CONDITION(f2fs__bio, f2fs_prepare_read_bio,
Chao Yud4d288b2013-11-24 12:36:42 +0900959
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700960 TP_PROTO(struct super_block *sb, int type, struct bio *bio),
Chao Yud4d288b2013-11-24 12:36:42 +0900961
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700962 TP_ARGS(sb, type, bio),
963
964 TP_CONDITION(bio)
965);
966
967DEFINE_EVENT_CONDITION(f2fs__bio, f2fs_submit_read_bio,
968
969 TP_PROTO(struct super_block *sb, int type, struct bio *bio),
970
971 TP_ARGS(sb, type, bio),
972
973 TP_CONDITION(bio)
974);
975
976DEFINE_EVENT_CONDITION(f2fs__bio, f2fs_submit_write_bio,
977
978 TP_PROTO(struct super_block *sb, int type, struct bio *bio),
979
980 TP_ARGS(sb, type, bio),
Jaegeuk Kim93dfe2a2013-11-30 12:51:14 +0900981
982 TP_CONDITION(bio)
Chao Yud4d288b2013-11-24 12:36:42 +0900983);
984
Chao Yu62aed042014-05-06 16:46:04 +0800985TRACE_EVENT(f2fs_write_begin,
986
987 TP_PROTO(struct inode *inode, loff_t pos, unsigned int len,
988 unsigned int flags),
989
990 TP_ARGS(inode, pos, len, flags),
991
992 TP_STRUCT__entry(
993 __field(dev_t, dev)
994 __field(ino_t, ino)
995 __field(loff_t, pos)
996 __field(unsigned int, len)
997 __field(unsigned int, flags)
998 ),
999
1000 TP_fast_assign(
1001 __entry->dev = inode->i_sb->s_dev;
1002 __entry->ino = inode->i_ino;
1003 __entry->pos = pos;
1004 __entry->len = len;
1005 __entry->flags = flags;
1006 ),
1007
1008 TP_printk("dev = (%d,%d), ino = %lu, pos = %llu, len = %u, flags = %u",
1009 show_dev_ino(__entry),
1010 (unsigned long long)__entry->pos,
1011 __entry->len,
1012 __entry->flags)
1013);
1014
Chao Yudfb2bf32014-05-06 16:47:23 +08001015TRACE_EVENT(f2fs_write_end,
1016
1017 TP_PROTO(struct inode *inode, loff_t pos, unsigned int len,
1018 unsigned int copied),
1019
1020 TP_ARGS(inode, pos, len, copied),
1021
1022 TP_STRUCT__entry(
1023 __field(dev_t, dev)
1024 __field(ino_t, ino)
1025 __field(loff_t, pos)
1026 __field(unsigned int, len)
1027 __field(unsigned int, copied)
1028 ),
1029
1030 TP_fast_assign(
1031 __entry->dev = inode->i_sb->s_dev;
1032 __entry->ino = inode->i_ino;
1033 __entry->pos = pos;
1034 __entry->len = len;
1035 __entry->copied = copied;
1036 ),
1037
1038 TP_printk("dev = (%d,%d), ino = %lu, pos = %llu, len = %u, copied = %u",
1039 show_dev_ino(__entry),
1040 (unsigned long long)__entry->pos,
1041 __entry->len,
1042 __entry->copied)
1043);
1044
Jaegeuk Kim26c6b882013-10-24 17:53:29 +09001045DECLARE_EVENT_CLASS(f2fs__page,
1046
1047 TP_PROTO(struct page *page, int type),
1048
1049 TP_ARGS(page, type),
1050
1051 TP_STRUCT__entry(
1052 __field(dev_t, dev)
1053 __field(ino_t, ino)
1054 __field(int, type)
1055 __field(int, dir)
1056 __field(pgoff_t, index)
1057 __field(int, dirty)
Chao Yuc20e89c2014-05-06 16:53:08 +08001058 __field(int, uptodate)
Jaegeuk Kim26c6b882013-10-24 17:53:29 +09001059 ),
1060
1061 TP_fast_assign(
1062 __entry->dev = page->mapping->host->i_sb->s_dev;
1063 __entry->ino = page->mapping->host->i_ino;
1064 __entry->type = type;
1065 __entry->dir = S_ISDIR(page->mapping->host->i_mode);
1066 __entry->index = page->index;
1067 __entry->dirty = PageDirty(page);
Chao Yuc20e89c2014-05-06 16:53:08 +08001068 __entry->uptodate = PageUptodate(page);
Jaegeuk Kim26c6b882013-10-24 17:53:29 +09001069 ),
1070
Chao Yuc20e89c2014-05-06 16:53:08 +08001071 TP_printk("dev = (%d,%d), ino = %lu, %s, %s, index = %lu, "
1072 "dirty = %d, uptodate = %d",
Jaegeuk Kim26c6b882013-10-24 17:53:29 +09001073 show_dev_ino(__entry),
1074 show_block_type(__entry->type),
1075 show_file_type(__entry->dir),
1076 (unsigned long)__entry->index,
Chao Yuc20e89c2014-05-06 16:53:08 +08001077 __entry->dirty,
1078 __entry->uptodate)
Jaegeuk Kim26c6b882013-10-24 17:53:29 +09001079);
1080
Chao Yuecda0de2014-05-06 16:48:26 +08001081DEFINE_EVENT(f2fs__page, f2fs_writepage,
1082
1083 TP_PROTO(struct page *page, int type),
1084
1085 TP_ARGS(page, type)
1086);
1087
Jaegeuk Kim8ce67cb2015-03-17 17:58:08 -07001088DEFINE_EVENT(f2fs__page, f2fs_do_write_data_page,
1089
1090 TP_PROTO(struct page *page, int type),
1091
1092 TP_ARGS(page, type)
1093);
1094
Chao Yuc20e89c2014-05-06 16:53:08 +08001095DEFINE_EVENT(f2fs__page, f2fs_readpage,
1096
1097 TP_PROTO(struct page *page, int type),
1098
1099 TP_ARGS(page, type)
1100);
1101
Jaegeuk Kim26c6b882013-10-24 17:53:29 +09001102DEFINE_EVENT(f2fs__page, f2fs_set_page_dirty,
1103
1104 TP_PROTO(struct page *page, int type),
1105
1106 TP_ARGS(page, type)
1107);
1108
Jaegeuk Kime943a102013-10-25 14:26:31 +09001109DEFINE_EVENT(f2fs__page, f2fs_vm_page_mkwrite,
1110
1111 TP_PROTO(struct page *page, int type),
1112
1113 TP_ARGS(page, type)
1114);
1115
Jaegeuk Kim8ce67cb2015-03-17 17:58:08 -07001116DEFINE_EVENT(f2fs__page, f2fs_register_inmem_page,
1117
1118 TP_PROTO(struct page *page, int type),
1119
1120 TP_ARGS(page, type)
1121);
1122
1123DEFINE_EVENT(f2fs__page, f2fs_commit_inmem_page,
1124
1125 TP_PROTO(struct page *page, int type),
1126
1127 TP_ARGS(page, type)
1128);
1129
Chao Yue5748432014-05-06 16:51:24 +08001130TRACE_EVENT(f2fs_writepages,
1131
1132 TP_PROTO(struct inode *inode, struct writeback_control *wbc, int type),
1133
1134 TP_ARGS(inode, wbc, type),
1135
1136 TP_STRUCT__entry(
1137 __field(dev_t, dev)
1138 __field(ino_t, ino)
1139 __field(int, type)
1140 __field(int, dir)
1141 __field(long, nr_to_write)
1142 __field(long, pages_skipped)
1143 __field(loff_t, range_start)
1144 __field(loff_t, range_end)
1145 __field(pgoff_t, writeback_index)
1146 __field(int, sync_mode)
1147 __field(char, for_kupdate)
1148 __field(char, for_background)
1149 __field(char, tagged_writepages)
1150 __field(char, for_reclaim)
1151 __field(char, range_cyclic)
1152 __field(char, for_sync)
1153 ),
1154
1155 TP_fast_assign(
1156 __entry->dev = inode->i_sb->s_dev;
1157 __entry->ino = inode->i_ino;
1158 __entry->type = type;
1159 __entry->dir = S_ISDIR(inode->i_mode);
1160 __entry->nr_to_write = wbc->nr_to_write;
1161 __entry->pages_skipped = wbc->pages_skipped;
1162 __entry->range_start = wbc->range_start;
1163 __entry->range_end = wbc->range_end;
1164 __entry->writeback_index = inode->i_mapping->writeback_index;
1165 __entry->sync_mode = wbc->sync_mode;
1166 __entry->for_kupdate = wbc->for_kupdate;
1167 __entry->for_background = wbc->for_background;
1168 __entry->tagged_writepages = wbc->tagged_writepages;
1169 __entry->for_reclaim = wbc->for_reclaim;
1170 __entry->range_cyclic = wbc->range_cyclic;
1171 __entry->for_sync = wbc->for_sync;
1172 ),
1173
1174 TP_printk("dev = (%d,%d), ino = %lu, %s, %s, nr_to_write %ld, "
1175 "skipped %ld, start %lld, end %lld, wb_idx %lu, sync_mode %d, "
1176 "kupdate %u background %u tagged %u reclaim %u cyclic %u sync %u",
1177 show_dev_ino(__entry),
1178 show_block_type(__entry->type),
1179 show_file_type(__entry->dir),
1180 __entry->nr_to_write,
1181 __entry->pages_skipped,
1182 __entry->range_start,
1183 __entry->range_end,
1184 (unsigned long)__entry->writeback_index,
1185 __entry->sync_mode,
1186 __entry->for_kupdate,
1187 __entry->for_background,
1188 __entry->tagged_writepages,
1189 __entry->for_reclaim,
1190 __entry->range_cyclic,
1191 __entry->for_sync)
1192);
1193
Chao Yub8c29402015-10-12 17:02:26 +08001194TRACE_EVENT(f2fs_readpages,
1195
1196 TP_PROTO(struct inode *inode, struct page *page, unsigned int nrpage),
1197
1198 TP_ARGS(inode, page, nrpage),
1199
1200 TP_STRUCT__entry(
1201 __field(dev_t, dev)
1202 __field(ino_t, ino)
1203 __field(pgoff_t, start)
1204 __field(unsigned int, nrpage)
1205 ),
1206
1207 TP_fast_assign(
1208 __entry->dev = inode->i_sb->s_dev;
1209 __entry->ino = inode->i_ino;
1210 __entry->start = page->index;
1211 __entry->nrpage = nrpage;
1212 ),
1213
1214 TP_printk("dev = (%d,%d), ino = %lu, start = %lu nrpage = %u",
1215 show_dev_ino(__entry),
1216 (unsigned long)__entry->start,
1217 __entry->nrpage)
1218);
1219
Namjae Jeon2af4bd62013-04-23 18:26:54 +09001220TRACE_EVENT(f2fs_write_checkpoint,
1221
Jaegeuk Kim75ab4cb2014-09-20 21:57:51 -07001222 TP_PROTO(struct super_block *sb, int reason, char *msg),
Namjae Jeon2af4bd62013-04-23 18:26:54 +09001223
Jaegeuk Kim75ab4cb2014-09-20 21:57:51 -07001224 TP_ARGS(sb, reason, msg),
Namjae Jeon2af4bd62013-04-23 18:26:54 +09001225
1226 TP_STRUCT__entry(
1227 __field(dev_t, dev)
Jaegeuk Kim75ab4cb2014-09-20 21:57:51 -07001228 __field(int, reason)
Namjae Jeon2af4bd62013-04-23 18:26:54 +09001229 __field(char *, msg)
1230 ),
1231
1232 TP_fast_assign(
1233 __entry->dev = sb->s_dev;
Jaegeuk Kim75ab4cb2014-09-20 21:57:51 -07001234 __entry->reason = reason;
Namjae Jeon2af4bd62013-04-23 18:26:54 +09001235 __entry->msg = msg;
1236 ),
1237
1238 TP_printk("dev = (%d,%d), checkpoint for %s, state = %s",
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001239 show_dev(__entry->dev),
Jaegeuk Kim75ab4cb2014-09-20 21:57:51 -07001240 show_cpreason(__entry->reason),
Namjae Jeon2af4bd62013-04-23 18:26:54 +09001241 __entry->msg)
1242);
1243
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001244DECLARE_EVENT_CLASS(f2fs_discard,
Jaegeuk Kim1661d072013-11-12 17:01:00 +09001245
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001246 TP_PROTO(struct block_device *dev, block_t blkstart, block_t blklen),
Jaegeuk Kim1661d072013-11-12 17:01:00 +09001247
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001248 TP_ARGS(dev, blkstart, blklen),
Jaegeuk Kim1661d072013-11-12 17:01:00 +09001249
1250 TP_STRUCT__entry(
1251 __field(dev_t, dev)
1252 __field(block_t, blkstart)
1253 __field(block_t, blklen)
1254 ),
1255
1256 TP_fast_assign(
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001257 __entry->dev = dev->bd_dev;
Jaegeuk Kim1661d072013-11-12 17:01:00 +09001258 __entry->blkstart = blkstart;
1259 __entry->blklen = blklen;
1260 ),
1261
1262 TP_printk("dev = (%d,%d), blkstart = 0x%llx, blklen = 0x%llx",
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001263 show_dev(__entry->dev),
Jaegeuk Kim1661d072013-11-12 17:01:00 +09001264 (unsigned long long)__entry->blkstart,
1265 (unsigned long long)__entry->blklen)
1266);
Jaegeuk Kim24a9ee02014-07-25 17:46:10 -07001267
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001268DEFINE_EVENT(f2fs_discard, f2fs_queue_discard,
1269
1270 TP_PROTO(struct block_device *dev, block_t blkstart, block_t blklen),
1271
1272 TP_ARGS(dev, blkstart, blklen)
1273);
1274
1275DEFINE_EVENT(f2fs_discard, f2fs_issue_discard,
1276
1277 TP_PROTO(struct block_device *dev, block_t blkstart, block_t blklen),
1278
1279 TP_ARGS(dev, blkstart, blklen)
1280);
1281
Chao Yu8258fd32017-10-04 09:08:36 +08001282DEFINE_EVENT(f2fs_discard, f2fs_remove_discard,
1283
1284 TP_PROTO(struct block_device *dev, block_t blkstart, block_t blklen),
1285
1286 TP_ARGS(dev, blkstart, blklen)
1287);
1288
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001289TRACE_EVENT(f2fs_issue_reset_zone,
1290
1291 TP_PROTO(struct block_device *dev, block_t blkstart),
1292
1293 TP_ARGS(dev, blkstart),
1294
1295 TP_STRUCT__entry(
1296 __field(dev_t, dev)
1297 __field(block_t, blkstart)
1298 ),
1299
1300 TP_fast_assign(
1301 __entry->dev = dev->bd_dev;
1302 __entry->blkstart = blkstart;
1303 ),
1304
1305 TP_printk("dev = (%d,%d), reset zone at block = 0x%llx",
1306 show_dev(__entry->dev),
1307 (unsigned long long)__entry->blkstart)
1308);
1309
Jaegeuk Kim24a9ee02014-07-25 17:46:10 -07001310TRACE_EVENT(f2fs_issue_flush,
1311
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001312 TP_PROTO(struct block_device *dev, unsigned int nobarrier,
1313 unsigned int flush_merge, int ret),
Jaegeuk Kim24a9ee02014-07-25 17:46:10 -07001314
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001315 TP_ARGS(dev, nobarrier, flush_merge, ret),
Jaegeuk Kim24a9ee02014-07-25 17:46:10 -07001316
1317 TP_STRUCT__entry(
1318 __field(dev_t, dev)
Jaegeuk Kim29e70432015-02-10 16:23:12 -08001319 __field(unsigned int, nobarrier)
1320 __field(unsigned int, flush_merge)
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001321 __field(int, ret)
Jaegeuk Kim24a9ee02014-07-25 17:46:10 -07001322 ),
1323
1324 TP_fast_assign(
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001325 __entry->dev = dev->bd_dev;
Jaegeuk Kim24a9ee02014-07-25 17:46:10 -07001326 __entry->nobarrier = nobarrier;
1327 __entry->flush_merge = flush_merge;
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001328 __entry->ret = ret;
Jaegeuk Kim24a9ee02014-07-25 17:46:10 -07001329 ),
1330
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001331 TP_printk("dev = (%d,%d), %s %s, ret = %d",
1332 show_dev(__entry->dev),
Jaegeuk Kim24a9ee02014-07-25 17:46:10 -07001333 __entry->nobarrier ? "skip (nobarrier)" : "issue",
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001334 __entry->flush_merge ? " with flush_merge" : "",
1335 __entry->ret)
Jaegeuk Kim24a9ee02014-07-25 17:46:10 -07001336);
Chao Yu1ec46102015-02-05 17:59:59 +08001337
1338TRACE_EVENT(f2fs_lookup_extent_tree_start,
1339
1340 TP_PROTO(struct inode *inode, unsigned int pgofs),
1341
1342 TP_ARGS(inode, pgofs),
1343
1344 TP_STRUCT__entry(
1345 __field(dev_t, dev)
1346 __field(ino_t, ino)
1347 __field(unsigned int, pgofs)
1348 ),
1349
1350 TP_fast_assign(
1351 __entry->dev = inode->i_sb->s_dev;
1352 __entry->ino = inode->i_ino;
1353 __entry->pgofs = pgofs;
1354 ),
1355
1356 TP_printk("dev = (%d,%d), ino = %lu, pgofs = %u",
1357 show_dev_ino(__entry),
1358 __entry->pgofs)
1359);
1360
1361TRACE_EVENT_CONDITION(f2fs_lookup_extent_tree_end,
1362
1363 TP_PROTO(struct inode *inode, unsigned int pgofs,
Jaegeuk Kim84bc9262015-06-29 16:01:14 -07001364 struct extent_info *ei),
Chao Yu1ec46102015-02-05 17:59:59 +08001365
Jaegeuk Kim84bc9262015-06-29 16:01:14 -07001366 TP_ARGS(inode, pgofs, ei),
Chao Yu1ec46102015-02-05 17:59:59 +08001367
Jaegeuk Kim84bc9262015-06-29 16:01:14 -07001368 TP_CONDITION(ei),
Chao Yu1ec46102015-02-05 17:59:59 +08001369
1370 TP_STRUCT__entry(
1371 __field(dev_t, dev)
1372 __field(ino_t, ino)
1373 __field(unsigned int, pgofs)
1374 __field(unsigned int, fofs)
1375 __field(u32, blk)
1376 __field(unsigned int, len)
1377 ),
1378
1379 TP_fast_assign(
1380 __entry->dev = inode->i_sb->s_dev;
1381 __entry->ino = inode->i_ino;
1382 __entry->pgofs = pgofs;
Jaegeuk Kim84bc9262015-06-29 16:01:14 -07001383 __entry->fofs = ei->fofs;
1384 __entry->blk = ei->blk;
1385 __entry->len = ei->len;
Chao Yu1ec46102015-02-05 17:59:59 +08001386 ),
1387
1388 TP_printk("dev = (%d,%d), ino = %lu, pgofs = %u, "
1389 "ext_info(fofs: %u, blk: %u, len: %u)",
1390 show_dev_ino(__entry),
1391 __entry->pgofs,
1392 __entry->fofs,
1393 __entry->blk,
1394 __entry->len)
1395);
1396
Chao Yu744288c2015-09-06 17:50:13 +08001397TRACE_EVENT(f2fs_update_extent_tree_range,
Chao Yu1ec46102015-02-05 17:59:59 +08001398
Chao Yu744288c2015-09-06 17:50:13 +08001399 TP_PROTO(struct inode *inode, unsigned int pgofs, block_t blkaddr,
1400 unsigned int len),
Chao Yu1ec46102015-02-05 17:59:59 +08001401
Chao Yu744288c2015-09-06 17:50:13 +08001402 TP_ARGS(inode, pgofs, blkaddr, len),
Chao Yu1ec46102015-02-05 17:59:59 +08001403
1404 TP_STRUCT__entry(
1405 __field(dev_t, dev)
1406 __field(ino_t, ino)
1407 __field(unsigned int, pgofs)
1408 __field(u32, blk)
Chao Yu744288c2015-09-06 17:50:13 +08001409 __field(unsigned int, len)
Chao Yu1ec46102015-02-05 17:59:59 +08001410 ),
1411
1412 TP_fast_assign(
1413 __entry->dev = inode->i_sb->s_dev;
1414 __entry->ino = inode->i_ino;
1415 __entry->pgofs = pgofs;
1416 __entry->blk = blkaddr;
Chao Yu744288c2015-09-06 17:50:13 +08001417 __entry->len = len;
Chao Yu1ec46102015-02-05 17:59:59 +08001418 ),
1419
Chao Yu744288c2015-09-06 17:50:13 +08001420 TP_printk("dev = (%d,%d), ino = %lu, pgofs = %u, "
1421 "blkaddr = %u, len = %u",
Chao Yu1ec46102015-02-05 17:59:59 +08001422 show_dev_ino(__entry),
1423 __entry->pgofs,
Chao Yu744288c2015-09-06 17:50:13 +08001424 __entry->blk,
1425 __entry->len)
Chao Yu1ec46102015-02-05 17:59:59 +08001426);
1427
1428TRACE_EVENT(f2fs_shrink_extent_tree,
1429
1430 TP_PROTO(struct f2fs_sb_info *sbi, unsigned int node_cnt,
1431 unsigned int tree_cnt),
1432
1433 TP_ARGS(sbi, node_cnt, tree_cnt),
1434
1435 TP_STRUCT__entry(
1436 __field(dev_t, dev)
1437 __field(unsigned int, node_cnt)
1438 __field(unsigned int, tree_cnt)
1439 ),
1440
1441 TP_fast_assign(
1442 __entry->dev = sbi->sb->s_dev;
1443 __entry->node_cnt = node_cnt;
1444 __entry->tree_cnt = tree_cnt;
1445 ),
1446
1447 TP_printk("dev = (%d,%d), shrunk: node_cnt = %u, tree_cnt = %u",
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001448 show_dev(__entry->dev),
Chao Yu1ec46102015-02-05 17:59:59 +08001449 __entry->node_cnt,
1450 __entry->tree_cnt)
1451);
1452
1453TRACE_EVENT(f2fs_destroy_extent_tree,
1454
1455 TP_PROTO(struct inode *inode, unsigned int node_cnt),
1456
1457 TP_ARGS(inode, node_cnt),
1458
1459 TP_STRUCT__entry(
1460 __field(dev_t, dev)
1461 __field(ino_t, ino)
1462 __field(unsigned int, node_cnt)
1463 ),
1464
1465 TP_fast_assign(
1466 __entry->dev = inode->i_sb->s_dev;
1467 __entry->ino = inode->i_ino;
1468 __entry->node_cnt = node_cnt;
1469 ),
1470
1471 TP_printk("dev = (%d,%d), ino = %lu, destroyed: node_cnt = %u",
1472 show_dev_ino(__entry),
1473 __entry->node_cnt)
1474);
1475
Chao Yu4cf18532015-12-17 17:17:16 +08001476DECLARE_EVENT_CLASS(f2fs_sync_dirty_inodes,
1477
Jaegeuk Kim523be8a2016-05-13 12:36:58 -07001478 TP_PROTO(struct super_block *sb, int type, s64 count),
Chao Yu4cf18532015-12-17 17:17:16 +08001479
1480 TP_ARGS(sb, type, count),
1481
1482 TP_STRUCT__entry(
1483 __field(dev_t, dev)
1484 __field(int, type)
Jaegeuk Kim523be8a2016-05-13 12:36:58 -07001485 __field(s64, count)
Chao Yu4cf18532015-12-17 17:17:16 +08001486 ),
1487
1488 TP_fast_assign(
1489 __entry->dev = sb->s_dev;
1490 __entry->type = type;
1491 __entry->count = count;
1492 ),
1493
Jaegeuk Kim523be8a2016-05-13 12:36:58 -07001494 TP_printk("dev = (%d,%d), %s, dirty count = %lld",
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001495 show_dev(__entry->dev),
Chao Yu4cf18532015-12-17 17:17:16 +08001496 show_file_type(__entry->type),
1497 __entry->count)
1498);
1499
1500DEFINE_EVENT(f2fs_sync_dirty_inodes, f2fs_sync_dirty_inodes_enter,
1501
Jaegeuk Kim523be8a2016-05-13 12:36:58 -07001502 TP_PROTO(struct super_block *sb, int type, s64 count),
Chao Yu4cf18532015-12-17 17:17:16 +08001503
1504 TP_ARGS(sb, type, count)
1505);
1506
1507DEFINE_EVENT(f2fs_sync_dirty_inodes, f2fs_sync_dirty_inodes_exit,
1508
Jaegeuk Kim523be8a2016-05-13 12:36:58 -07001509 TP_PROTO(struct super_block *sb, int type, s64 count),
Chao Yu4cf18532015-12-17 17:17:16 +08001510
1511 TP_ARGS(sb, type, count)
1512);
1513
Namjae Jeona2a4a7e2013-04-20 01:28:40 +09001514#endif /* _TRACE_F2FS_H */
1515
1516 /* This part must be outside protection */
1517#include <trace/define_trace.h>