blob: b1c373ff5c4775767e21c11e0aa5b6b2f7970a08 [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
Chao Yud67586d2017-10-17 17:33:41 +0800724TRACE_EVENT(f2fs_lookup_start,
725
726 TP_PROTO(struct inode *dir, struct dentry *dentry, unsigned int flags),
727
728 TP_ARGS(dir, dentry, flags),
729
730 TP_STRUCT__entry(
731 __field(dev_t, dev)
732 __field(ino_t, ino)
733 __field(const char *, name)
734 __field(unsigned int, flags)
735 ),
736
737 TP_fast_assign(
738 __entry->dev = dir->i_sb->s_dev;
739 __entry->ino = dir->i_ino;
740 __entry->name = dentry->d_name.name;
741 __entry->flags = flags;
742 ),
743
744 TP_printk("dev = (%d,%d), pino = %lu, name:%s, flags:%u",
745 show_dev_ino(__entry),
746 __entry->name,
747 __entry->flags)
748);
749
750TRACE_EVENT(f2fs_lookup_end,
751
752 TP_PROTO(struct inode *dir, struct dentry *dentry, nid_t ino,
753 int err),
754
755 TP_ARGS(dir, dentry, ino, err),
756
757 TP_STRUCT__entry(
758 __field(dev_t, dev)
759 __field(ino_t, ino)
760 __field(const char *, name)
761 __field(nid_t, cino)
762 __field(int, err)
763 ),
764
765 TP_fast_assign(
766 __entry->dev = dir->i_sb->s_dev;
767 __entry->ino = dir->i_ino;
768 __entry->name = dentry->d_name.name;
769 __entry->cino = ino;
770 __entry->err = err;
771 ),
772
773 TP_printk("dev = (%d,%d), pino = %lu, name:%s, ino:%u, err:%d",
774 show_dev_ino(__entry),
775 __entry->name,
776 __entry->cino,
777 __entry->err)
778);
779
Namjae Jeonc01e2852013-04-23 17:00:52 +0900780TRACE_EVENT(f2fs_fallocate,
781
782 TP_PROTO(struct inode *inode, int mode,
783 loff_t offset, loff_t len, int ret),
784
785 TP_ARGS(inode, mode, offset, len, ret),
786
787 TP_STRUCT__entry(
788 __field(dev_t, dev)
789 __field(ino_t, ino)
790 __field(int, mode)
791 __field(loff_t, offset)
792 __field(loff_t, len)
793 __field(loff_t, size)
794 __field(blkcnt_t, blocks)
795 __field(int, ret)
796 ),
797
798 TP_fast_assign(
799 __entry->dev = inode->i_sb->s_dev;
800 __entry->ino = inode->i_ino;
801 __entry->mode = mode;
802 __entry->offset = offset;
803 __entry->len = len;
804 __entry->size = inode->i_size;
805 __entry->blocks = inode->i_blocks;
806 __entry->ret = ret;
807 ),
808
809 TP_printk("dev = (%d,%d), ino = %lu, mode = %x, offset = %lld, "
810 "len = %lld, i_size = %lld, i_blocks = %llu, ret = %d",
811 show_dev_ino(__entry),
812 __entry->mode,
813 (unsigned long long)__entry->offset,
814 (unsigned long long)__entry->len,
815 (unsigned long long)__entry->size,
816 (unsigned long long)__entry->blocks,
817 __entry->ret)
818);
819
Chao Yu70407fa2014-07-31 21:11:22 +0800820TRACE_EVENT(f2fs_direct_IO_enter,
821
822 TP_PROTO(struct inode *inode, loff_t offset, unsigned long len, int rw),
823
824 TP_ARGS(inode, offset, len, rw),
825
826 TP_STRUCT__entry(
827 __field(dev_t, dev)
828 __field(ino_t, ino)
829 __field(loff_t, pos)
830 __field(unsigned long, len)
831 __field(int, rw)
832 ),
833
834 TP_fast_assign(
835 __entry->dev = inode->i_sb->s_dev;
836 __entry->ino = inode->i_ino;
837 __entry->pos = offset;
838 __entry->len = len;
839 __entry->rw = rw;
840 ),
841
842 TP_printk("dev = (%d,%d), ino = %lu pos = %lld len = %lu rw = %d",
843 show_dev_ino(__entry),
844 __entry->pos,
845 __entry->len,
846 __entry->rw)
847);
848
849TRACE_EVENT(f2fs_direct_IO_exit,
850
851 TP_PROTO(struct inode *inode, loff_t offset, unsigned long len,
852 int rw, int ret),
853
854 TP_ARGS(inode, offset, len, rw, ret),
855
856 TP_STRUCT__entry(
857 __field(dev_t, dev)
858 __field(ino_t, ino)
859 __field(loff_t, pos)
860 __field(unsigned long, len)
861 __field(int, rw)
862 __field(int, ret)
863 ),
864
865 TP_fast_assign(
866 __entry->dev = inode->i_sb->s_dev;
867 __entry->ino = inode->i_ino;
868 __entry->pos = offset;
869 __entry->len = len;
870 __entry->rw = rw;
871 __entry->ret = ret;
872 ),
873
874 TP_printk("dev = (%d,%d), ino = %lu pos = %lld len = %lu "
875 "rw = %d ret = %d",
876 show_dev_ino(__entry),
877 __entry->pos,
878 __entry->len,
879 __entry->rw,
880 __entry->ret)
881);
882
Chao Yu46008c62016-05-09 19:56:30 +0800883TRACE_EVENT(f2fs_reserve_new_blocks,
Namjae Jeonc01e2852013-04-23 17:00:52 +0900884
Chao Yu46008c62016-05-09 19:56:30 +0800885 TP_PROTO(struct inode *inode, nid_t nid, unsigned int ofs_in_node,
886 blkcnt_t count),
Namjae Jeonc01e2852013-04-23 17:00:52 +0900887
Chao Yu46008c62016-05-09 19:56:30 +0800888 TP_ARGS(inode, nid, ofs_in_node, count),
Namjae Jeonc01e2852013-04-23 17:00:52 +0900889
890 TP_STRUCT__entry(
891 __field(dev_t, dev)
892 __field(nid_t, nid)
893 __field(unsigned int, ofs_in_node)
Chao Yu46008c62016-05-09 19:56:30 +0800894 __field(blkcnt_t, count)
Namjae Jeonc01e2852013-04-23 17:00:52 +0900895 ),
896
897 TP_fast_assign(
898 __entry->dev = inode->i_sb->s_dev;
899 __entry->nid = nid;
900 __entry->ofs_in_node = ofs_in_node;
Chao Yu46008c62016-05-09 19:56:30 +0800901 __entry->count = count;
Namjae Jeonc01e2852013-04-23 17:00:52 +0900902 ),
903
Chao Yu46008c62016-05-09 19:56:30 +0800904 TP_printk("dev = (%d,%d), nid = %u, ofs_in_node = %u, count = %llu",
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700905 show_dev(__entry->dev),
Namjae Jeonc01e2852013-04-23 17:00:52 +0900906 (unsigned int)__entry->nid,
Chao Yu46008c62016-05-09 19:56:30 +0800907 __entry->ofs_in_node,
908 (unsigned long long)__entry->count)
Namjae Jeonc01e2852013-04-23 17:00:52 +0900909);
910
Chao Yu3e1c8f12014-12-23 16:35:21 +0800911DECLARE_EVENT_CLASS(f2fs__submit_page_bio,
912
Chao Yu2ace38e2014-12-24 16:08:14 +0800913 TP_PROTO(struct page *page, struct f2fs_io_info *fio),
Chao Yu3e1c8f12014-12-23 16:35:21 +0800914
Chao Yu2ace38e2014-12-24 16:08:14 +0800915 TP_ARGS(page, fio),
Chao Yu3e1c8f12014-12-23 16:35:21 +0800916
917 TP_STRUCT__entry(
918 __field(dev_t, dev)
919 __field(ino_t, ino)
920 __field(pgoff_t, index)
Chao Yu7a9d7542016-02-22 18:36:38 +0800921 __field(block_t, old_blkaddr)
922 __field(block_t, new_blkaddr)
Mike Christie04d328d2016-06-05 14:31:55 -0500923 __field(int, op)
924 __field(int, op_flags)
Jaegeuk Kimc4127262017-05-10 11:18:25 -0700925 __field(int, temp)
Chao Yu3e1c8f12014-12-23 16:35:21 +0800926 __field(int, type)
927 ),
928
929 TP_fast_assign(
930 __entry->dev = page->mapping->host->i_sb->s_dev;
931 __entry->ino = page->mapping->host->i_ino;
932 __entry->index = page->index;
Chao Yu7a9d7542016-02-22 18:36:38 +0800933 __entry->old_blkaddr = fio->old_blkaddr;
934 __entry->new_blkaddr = fio->new_blkaddr;
Mike Christie04d328d2016-06-05 14:31:55 -0500935 __entry->op = fio->op;
936 __entry->op_flags = fio->op_flags;
Jaegeuk Kimc4127262017-05-10 11:18:25 -0700937 __entry->temp = fio->temp;
Chao Yu2ace38e2014-12-24 16:08:14 +0800938 __entry->type = fio->type;
Chao Yu3e1c8f12014-12-23 16:35:21 +0800939 ),
940
941 TP_printk("dev = (%d,%d), ino = %lu, page_index = 0x%lx, "
Jaegeuk Kimc4127262017-05-10 11:18:25 -0700942 "oldaddr = 0x%llx, newaddr = 0x%llx, rw = %s(%s), type = %s_%s",
Chao Yu3e1c8f12014-12-23 16:35:21 +0800943 show_dev_ino(__entry),
944 (unsigned long)__entry->index,
Chao Yu7a9d7542016-02-22 18:36:38 +0800945 (unsigned long long)__entry->old_blkaddr,
946 (unsigned long long)__entry->new_blkaddr,
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700947 show_bio_type(__entry->op, __entry->op_flags),
Jaegeuk Kimc4127262017-05-10 11:18:25 -0700948 show_block_temp(__entry->temp),
Chao Yu3e1c8f12014-12-23 16:35:21 +0800949 show_block_type(__entry->type))
950);
951
952DEFINE_EVENT_CONDITION(f2fs__submit_page_bio, f2fs_submit_page_bio,
953
Chao Yu2ace38e2014-12-24 16:08:14 +0800954 TP_PROTO(struct page *page, struct f2fs_io_info *fio),
Chao Yu3e1c8f12014-12-23 16:35:21 +0800955
Chao Yu2ace38e2014-12-24 16:08:14 +0800956 TP_ARGS(page, fio),
Chao Yu3e1c8f12014-12-23 16:35:21 +0800957
958 TP_CONDITION(page->mapping)
959);
960
Jaegeuk Kim9bc576a2017-05-10 11:28:38 -0700961DEFINE_EVENT_CONDITION(f2fs__submit_page_bio, f2fs_submit_page_write,
Chao Yu3e1c8f12014-12-23 16:35:21 +0800962
Chao Yu2ace38e2014-12-24 16:08:14 +0800963 TP_PROTO(struct page *page, struct f2fs_io_info *fio),
Chao Yu3e1c8f12014-12-23 16:35:21 +0800964
Chao Yu2ace38e2014-12-24 16:08:14 +0800965 TP_ARGS(page, fio),
Chao Yu3e1c8f12014-12-23 16:35:21 +0800966
967 TP_CONDITION(page->mapping)
968);
969
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700970DECLARE_EVENT_CLASS(f2fs__bio,
Namjae Jeon6ec178d2013-04-23 17:51:43 +0900971
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700972 TP_PROTO(struct super_block *sb, int type, struct bio *bio),
Namjae Jeon6ec178d2013-04-23 17:51:43 +0900973
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700974 TP_ARGS(sb, type, bio),
Namjae Jeon6ec178d2013-04-23 17:51:43 +0900975
976 TP_STRUCT__entry(
977 __field(dev_t, dev)
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700978 __field(dev_t, target)
Mike Christie04d328d2016-06-05 14:31:55 -0500979 __field(int, op)
980 __field(int, op_flags)
Chao Yud4d288b2013-11-24 12:36:42 +0900981 __field(int, type)
Namjae Jeon6ec178d2013-04-23 17:51:43 +0900982 __field(sector_t, sector)
983 __field(unsigned int, size)
984 ),
985
986 TP_fast_assign(
987 __entry->dev = sb->s_dev;
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700988 __entry->target = bio->bi_bdev->bd_dev;
989 __entry->op = bio_op(bio);
990 __entry->op_flags = bio->bi_opf;
991 __entry->type = type;
Kent Overstreet4f024f32013-10-11 15:44:27 -0700992 __entry->sector = bio->bi_iter.bi_sector;
993 __entry->size = bio->bi_iter.bi_size;
Namjae Jeon6ec178d2013-04-23 17:51:43 +0900994 ),
995
Jaegeuk Kime6b120d2017-07-10 12:55:09 -0700996 TP_printk("dev = (%d,%d)/(%d,%d), rw = %s(%s), %s, sector = %lld, size = %u",
997 show_dev(__entry->target),
998 show_dev(__entry->dev),
999 show_bio_type(__entry->op, __entry->op_flags),
Chao Yud4d288b2013-11-24 12:36:42 +09001000 show_block_type(__entry->type),
Namjae Jeon6ec178d2013-04-23 17:51:43 +09001001 (unsigned long long)__entry->sector,
1002 __entry->size)
1003);
1004
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001005DEFINE_EVENT_CONDITION(f2fs__bio, f2fs_prepare_write_bio,
Chao Yud4d288b2013-11-24 12:36:42 +09001006
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001007 TP_PROTO(struct super_block *sb, int type, struct bio *bio),
Chao Yud4d288b2013-11-24 12:36:42 +09001008
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001009 TP_ARGS(sb, type, bio),
Jaegeuk Kim93dfe2a2013-11-30 12:51:14 +09001010
1011 TP_CONDITION(bio)
Chao Yud4d288b2013-11-24 12:36:42 +09001012);
1013
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001014DEFINE_EVENT_CONDITION(f2fs__bio, f2fs_prepare_read_bio,
Chao Yud4d288b2013-11-24 12:36:42 +09001015
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001016 TP_PROTO(struct super_block *sb, int type, struct bio *bio),
Chao Yud4d288b2013-11-24 12:36:42 +09001017
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001018 TP_ARGS(sb, type, bio),
1019
1020 TP_CONDITION(bio)
1021);
1022
1023DEFINE_EVENT_CONDITION(f2fs__bio, f2fs_submit_read_bio,
1024
1025 TP_PROTO(struct super_block *sb, int type, struct bio *bio),
1026
1027 TP_ARGS(sb, type, bio),
1028
1029 TP_CONDITION(bio)
1030);
1031
1032DEFINE_EVENT_CONDITION(f2fs__bio, f2fs_submit_write_bio,
1033
1034 TP_PROTO(struct super_block *sb, int type, struct bio *bio),
1035
1036 TP_ARGS(sb, type, bio),
Jaegeuk Kim93dfe2a2013-11-30 12:51:14 +09001037
1038 TP_CONDITION(bio)
Chao Yud4d288b2013-11-24 12:36:42 +09001039);
1040
Chao Yu62aed042014-05-06 16:46:04 +08001041TRACE_EVENT(f2fs_write_begin,
1042
1043 TP_PROTO(struct inode *inode, loff_t pos, unsigned int len,
1044 unsigned int flags),
1045
1046 TP_ARGS(inode, pos, len, flags),
1047
1048 TP_STRUCT__entry(
1049 __field(dev_t, dev)
1050 __field(ino_t, ino)
1051 __field(loff_t, pos)
1052 __field(unsigned int, len)
1053 __field(unsigned int, flags)
1054 ),
1055
1056 TP_fast_assign(
1057 __entry->dev = inode->i_sb->s_dev;
1058 __entry->ino = inode->i_ino;
1059 __entry->pos = pos;
1060 __entry->len = len;
1061 __entry->flags = flags;
1062 ),
1063
1064 TP_printk("dev = (%d,%d), ino = %lu, pos = %llu, len = %u, flags = %u",
1065 show_dev_ino(__entry),
1066 (unsigned long long)__entry->pos,
1067 __entry->len,
1068 __entry->flags)
1069);
1070
Chao Yudfb2bf32014-05-06 16:47:23 +08001071TRACE_EVENT(f2fs_write_end,
1072
1073 TP_PROTO(struct inode *inode, loff_t pos, unsigned int len,
1074 unsigned int copied),
1075
1076 TP_ARGS(inode, pos, len, copied),
1077
1078 TP_STRUCT__entry(
1079 __field(dev_t, dev)
1080 __field(ino_t, ino)
1081 __field(loff_t, pos)
1082 __field(unsigned int, len)
1083 __field(unsigned int, copied)
1084 ),
1085
1086 TP_fast_assign(
1087 __entry->dev = inode->i_sb->s_dev;
1088 __entry->ino = inode->i_ino;
1089 __entry->pos = pos;
1090 __entry->len = len;
1091 __entry->copied = copied;
1092 ),
1093
1094 TP_printk("dev = (%d,%d), ino = %lu, pos = %llu, len = %u, copied = %u",
1095 show_dev_ino(__entry),
1096 (unsigned long long)__entry->pos,
1097 __entry->len,
1098 __entry->copied)
1099);
1100
Jaegeuk Kim26c6b882013-10-24 17:53:29 +09001101DECLARE_EVENT_CLASS(f2fs__page,
1102
1103 TP_PROTO(struct page *page, int type),
1104
1105 TP_ARGS(page, type),
1106
1107 TP_STRUCT__entry(
1108 __field(dev_t, dev)
1109 __field(ino_t, ino)
1110 __field(int, type)
1111 __field(int, dir)
1112 __field(pgoff_t, index)
1113 __field(int, dirty)
Chao Yuc20e89c2014-05-06 16:53:08 +08001114 __field(int, uptodate)
Jaegeuk Kim26c6b882013-10-24 17:53:29 +09001115 ),
1116
1117 TP_fast_assign(
1118 __entry->dev = page->mapping->host->i_sb->s_dev;
1119 __entry->ino = page->mapping->host->i_ino;
1120 __entry->type = type;
1121 __entry->dir = S_ISDIR(page->mapping->host->i_mode);
1122 __entry->index = page->index;
1123 __entry->dirty = PageDirty(page);
Chao Yuc20e89c2014-05-06 16:53:08 +08001124 __entry->uptodate = PageUptodate(page);
Jaegeuk Kim26c6b882013-10-24 17:53:29 +09001125 ),
1126
Chao Yuc20e89c2014-05-06 16:53:08 +08001127 TP_printk("dev = (%d,%d), ino = %lu, %s, %s, index = %lu, "
1128 "dirty = %d, uptodate = %d",
Jaegeuk Kim26c6b882013-10-24 17:53:29 +09001129 show_dev_ino(__entry),
1130 show_block_type(__entry->type),
1131 show_file_type(__entry->dir),
1132 (unsigned long)__entry->index,
Chao Yuc20e89c2014-05-06 16:53:08 +08001133 __entry->dirty,
1134 __entry->uptodate)
Jaegeuk Kim26c6b882013-10-24 17:53:29 +09001135);
1136
Chao Yuecda0de2014-05-06 16:48:26 +08001137DEFINE_EVENT(f2fs__page, f2fs_writepage,
1138
1139 TP_PROTO(struct page *page, int type),
1140
1141 TP_ARGS(page, type)
1142);
1143
Jaegeuk Kim8ce67cb2015-03-17 17:58:08 -07001144DEFINE_EVENT(f2fs__page, f2fs_do_write_data_page,
1145
1146 TP_PROTO(struct page *page, int type),
1147
1148 TP_ARGS(page, type)
1149);
1150
Chao Yuc20e89c2014-05-06 16:53:08 +08001151DEFINE_EVENT(f2fs__page, f2fs_readpage,
1152
1153 TP_PROTO(struct page *page, int type),
1154
1155 TP_ARGS(page, type)
1156);
1157
Jaegeuk Kim26c6b882013-10-24 17:53:29 +09001158DEFINE_EVENT(f2fs__page, f2fs_set_page_dirty,
1159
1160 TP_PROTO(struct page *page, int type),
1161
1162 TP_ARGS(page, type)
1163);
1164
Jaegeuk Kime943a102013-10-25 14:26:31 +09001165DEFINE_EVENT(f2fs__page, f2fs_vm_page_mkwrite,
1166
1167 TP_PROTO(struct page *page, int type),
1168
1169 TP_ARGS(page, type)
1170);
1171
Jaegeuk Kim8ce67cb2015-03-17 17:58:08 -07001172DEFINE_EVENT(f2fs__page, f2fs_register_inmem_page,
1173
1174 TP_PROTO(struct page *page, int type),
1175
1176 TP_ARGS(page, type)
1177);
1178
1179DEFINE_EVENT(f2fs__page, f2fs_commit_inmem_page,
1180
1181 TP_PROTO(struct page *page, int type),
1182
1183 TP_ARGS(page, type)
1184);
1185
Chao Yue5748432014-05-06 16:51:24 +08001186TRACE_EVENT(f2fs_writepages,
1187
1188 TP_PROTO(struct inode *inode, struct writeback_control *wbc, int type),
1189
1190 TP_ARGS(inode, wbc, type),
1191
1192 TP_STRUCT__entry(
1193 __field(dev_t, dev)
1194 __field(ino_t, ino)
1195 __field(int, type)
1196 __field(int, dir)
1197 __field(long, nr_to_write)
1198 __field(long, pages_skipped)
1199 __field(loff_t, range_start)
1200 __field(loff_t, range_end)
1201 __field(pgoff_t, writeback_index)
1202 __field(int, sync_mode)
1203 __field(char, for_kupdate)
1204 __field(char, for_background)
1205 __field(char, tagged_writepages)
1206 __field(char, for_reclaim)
1207 __field(char, range_cyclic)
1208 __field(char, for_sync)
1209 ),
1210
1211 TP_fast_assign(
1212 __entry->dev = inode->i_sb->s_dev;
1213 __entry->ino = inode->i_ino;
1214 __entry->type = type;
1215 __entry->dir = S_ISDIR(inode->i_mode);
1216 __entry->nr_to_write = wbc->nr_to_write;
1217 __entry->pages_skipped = wbc->pages_skipped;
1218 __entry->range_start = wbc->range_start;
1219 __entry->range_end = wbc->range_end;
1220 __entry->writeback_index = inode->i_mapping->writeback_index;
1221 __entry->sync_mode = wbc->sync_mode;
1222 __entry->for_kupdate = wbc->for_kupdate;
1223 __entry->for_background = wbc->for_background;
1224 __entry->tagged_writepages = wbc->tagged_writepages;
1225 __entry->for_reclaim = wbc->for_reclaim;
1226 __entry->range_cyclic = wbc->range_cyclic;
1227 __entry->for_sync = wbc->for_sync;
1228 ),
1229
1230 TP_printk("dev = (%d,%d), ino = %lu, %s, %s, nr_to_write %ld, "
1231 "skipped %ld, start %lld, end %lld, wb_idx %lu, sync_mode %d, "
1232 "kupdate %u background %u tagged %u reclaim %u cyclic %u sync %u",
1233 show_dev_ino(__entry),
1234 show_block_type(__entry->type),
1235 show_file_type(__entry->dir),
1236 __entry->nr_to_write,
1237 __entry->pages_skipped,
1238 __entry->range_start,
1239 __entry->range_end,
1240 (unsigned long)__entry->writeback_index,
1241 __entry->sync_mode,
1242 __entry->for_kupdate,
1243 __entry->for_background,
1244 __entry->tagged_writepages,
1245 __entry->for_reclaim,
1246 __entry->range_cyclic,
1247 __entry->for_sync)
1248);
1249
Chao Yub8c29402015-10-12 17:02:26 +08001250TRACE_EVENT(f2fs_readpages,
1251
1252 TP_PROTO(struct inode *inode, struct page *page, unsigned int nrpage),
1253
1254 TP_ARGS(inode, page, nrpage),
1255
1256 TP_STRUCT__entry(
1257 __field(dev_t, dev)
1258 __field(ino_t, ino)
1259 __field(pgoff_t, start)
1260 __field(unsigned int, nrpage)
1261 ),
1262
1263 TP_fast_assign(
1264 __entry->dev = inode->i_sb->s_dev;
1265 __entry->ino = inode->i_ino;
1266 __entry->start = page->index;
1267 __entry->nrpage = nrpage;
1268 ),
1269
1270 TP_printk("dev = (%d,%d), ino = %lu, start = %lu nrpage = %u",
1271 show_dev_ino(__entry),
1272 (unsigned long)__entry->start,
1273 __entry->nrpage)
1274);
1275
Namjae Jeon2af4bd62013-04-23 18:26:54 +09001276TRACE_EVENT(f2fs_write_checkpoint,
1277
Jaegeuk Kim75ab4cb2014-09-20 21:57:51 -07001278 TP_PROTO(struct super_block *sb, int reason, char *msg),
Namjae Jeon2af4bd62013-04-23 18:26:54 +09001279
Jaegeuk Kim75ab4cb2014-09-20 21:57:51 -07001280 TP_ARGS(sb, reason, msg),
Namjae Jeon2af4bd62013-04-23 18:26:54 +09001281
1282 TP_STRUCT__entry(
1283 __field(dev_t, dev)
Jaegeuk Kim75ab4cb2014-09-20 21:57:51 -07001284 __field(int, reason)
Namjae Jeon2af4bd62013-04-23 18:26:54 +09001285 __field(char *, msg)
1286 ),
1287
1288 TP_fast_assign(
1289 __entry->dev = sb->s_dev;
Jaegeuk Kim75ab4cb2014-09-20 21:57:51 -07001290 __entry->reason = reason;
Namjae Jeon2af4bd62013-04-23 18:26:54 +09001291 __entry->msg = msg;
1292 ),
1293
1294 TP_printk("dev = (%d,%d), checkpoint for %s, state = %s",
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001295 show_dev(__entry->dev),
Jaegeuk Kim75ab4cb2014-09-20 21:57:51 -07001296 show_cpreason(__entry->reason),
Namjae Jeon2af4bd62013-04-23 18:26:54 +09001297 __entry->msg)
1298);
1299
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001300DECLARE_EVENT_CLASS(f2fs_discard,
Jaegeuk Kim1661d072013-11-12 17:01:00 +09001301
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001302 TP_PROTO(struct block_device *dev, block_t blkstart, block_t blklen),
Jaegeuk Kim1661d072013-11-12 17:01:00 +09001303
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001304 TP_ARGS(dev, blkstart, blklen),
Jaegeuk Kim1661d072013-11-12 17:01:00 +09001305
1306 TP_STRUCT__entry(
1307 __field(dev_t, dev)
1308 __field(block_t, blkstart)
1309 __field(block_t, blklen)
1310 ),
1311
1312 TP_fast_assign(
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001313 __entry->dev = dev->bd_dev;
Jaegeuk Kim1661d072013-11-12 17:01:00 +09001314 __entry->blkstart = blkstart;
1315 __entry->blklen = blklen;
1316 ),
1317
1318 TP_printk("dev = (%d,%d), blkstart = 0x%llx, blklen = 0x%llx",
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001319 show_dev(__entry->dev),
Jaegeuk Kim1661d072013-11-12 17:01:00 +09001320 (unsigned long long)__entry->blkstart,
1321 (unsigned long long)__entry->blklen)
1322);
Jaegeuk Kim24a9ee02014-07-25 17:46:10 -07001323
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001324DEFINE_EVENT(f2fs_discard, f2fs_queue_discard,
1325
1326 TP_PROTO(struct block_device *dev, block_t blkstart, block_t blklen),
1327
1328 TP_ARGS(dev, blkstart, blklen)
1329);
1330
1331DEFINE_EVENT(f2fs_discard, f2fs_issue_discard,
1332
1333 TP_PROTO(struct block_device *dev, block_t blkstart, block_t blklen),
1334
1335 TP_ARGS(dev, blkstart, blklen)
1336);
1337
Chao Yu8258fd32017-10-04 09:08:36 +08001338DEFINE_EVENT(f2fs_discard, f2fs_remove_discard,
1339
1340 TP_PROTO(struct block_device *dev, block_t blkstart, block_t blklen),
1341
1342 TP_ARGS(dev, blkstart, blklen)
1343);
1344
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001345TRACE_EVENT(f2fs_issue_reset_zone,
1346
1347 TP_PROTO(struct block_device *dev, block_t blkstart),
1348
1349 TP_ARGS(dev, blkstart),
1350
1351 TP_STRUCT__entry(
1352 __field(dev_t, dev)
1353 __field(block_t, blkstart)
1354 ),
1355
1356 TP_fast_assign(
1357 __entry->dev = dev->bd_dev;
1358 __entry->blkstart = blkstart;
1359 ),
1360
1361 TP_printk("dev = (%d,%d), reset zone at block = 0x%llx",
1362 show_dev(__entry->dev),
1363 (unsigned long long)__entry->blkstart)
1364);
1365
Jaegeuk Kim24a9ee02014-07-25 17:46:10 -07001366TRACE_EVENT(f2fs_issue_flush,
1367
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001368 TP_PROTO(struct block_device *dev, unsigned int nobarrier,
1369 unsigned int flush_merge, int ret),
Jaegeuk Kim24a9ee02014-07-25 17:46:10 -07001370
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001371 TP_ARGS(dev, nobarrier, flush_merge, ret),
Jaegeuk Kim24a9ee02014-07-25 17:46:10 -07001372
1373 TP_STRUCT__entry(
1374 __field(dev_t, dev)
Jaegeuk Kim29e70432015-02-10 16:23:12 -08001375 __field(unsigned int, nobarrier)
1376 __field(unsigned int, flush_merge)
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001377 __field(int, ret)
Jaegeuk Kim24a9ee02014-07-25 17:46:10 -07001378 ),
1379
1380 TP_fast_assign(
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001381 __entry->dev = dev->bd_dev;
Jaegeuk Kim24a9ee02014-07-25 17:46:10 -07001382 __entry->nobarrier = nobarrier;
1383 __entry->flush_merge = flush_merge;
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001384 __entry->ret = ret;
Jaegeuk Kim24a9ee02014-07-25 17:46:10 -07001385 ),
1386
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001387 TP_printk("dev = (%d,%d), %s %s, ret = %d",
1388 show_dev(__entry->dev),
Jaegeuk Kim24a9ee02014-07-25 17:46:10 -07001389 __entry->nobarrier ? "skip (nobarrier)" : "issue",
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001390 __entry->flush_merge ? " with flush_merge" : "",
1391 __entry->ret)
Jaegeuk Kim24a9ee02014-07-25 17:46:10 -07001392);
Chao Yu1ec46102015-02-05 17:59:59 +08001393
1394TRACE_EVENT(f2fs_lookup_extent_tree_start,
1395
1396 TP_PROTO(struct inode *inode, unsigned int pgofs),
1397
1398 TP_ARGS(inode, pgofs),
1399
1400 TP_STRUCT__entry(
1401 __field(dev_t, dev)
1402 __field(ino_t, ino)
1403 __field(unsigned int, pgofs)
1404 ),
1405
1406 TP_fast_assign(
1407 __entry->dev = inode->i_sb->s_dev;
1408 __entry->ino = inode->i_ino;
1409 __entry->pgofs = pgofs;
1410 ),
1411
1412 TP_printk("dev = (%d,%d), ino = %lu, pgofs = %u",
1413 show_dev_ino(__entry),
1414 __entry->pgofs)
1415);
1416
1417TRACE_EVENT_CONDITION(f2fs_lookup_extent_tree_end,
1418
1419 TP_PROTO(struct inode *inode, unsigned int pgofs,
Jaegeuk Kim84bc9262015-06-29 16:01:14 -07001420 struct extent_info *ei),
Chao Yu1ec46102015-02-05 17:59:59 +08001421
Jaegeuk Kim84bc9262015-06-29 16:01:14 -07001422 TP_ARGS(inode, pgofs, ei),
Chao Yu1ec46102015-02-05 17:59:59 +08001423
Jaegeuk Kim84bc9262015-06-29 16:01:14 -07001424 TP_CONDITION(ei),
Chao Yu1ec46102015-02-05 17:59:59 +08001425
1426 TP_STRUCT__entry(
1427 __field(dev_t, dev)
1428 __field(ino_t, ino)
1429 __field(unsigned int, pgofs)
1430 __field(unsigned int, fofs)
1431 __field(u32, blk)
1432 __field(unsigned int, len)
1433 ),
1434
1435 TP_fast_assign(
1436 __entry->dev = inode->i_sb->s_dev;
1437 __entry->ino = inode->i_ino;
1438 __entry->pgofs = pgofs;
Jaegeuk Kim84bc9262015-06-29 16:01:14 -07001439 __entry->fofs = ei->fofs;
1440 __entry->blk = ei->blk;
1441 __entry->len = ei->len;
Chao Yu1ec46102015-02-05 17:59:59 +08001442 ),
1443
1444 TP_printk("dev = (%d,%d), ino = %lu, pgofs = %u, "
1445 "ext_info(fofs: %u, blk: %u, len: %u)",
1446 show_dev_ino(__entry),
1447 __entry->pgofs,
1448 __entry->fofs,
1449 __entry->blk,
1450 __entry->len)
1451);
1452
Chao Yu744288c2015-09-06 17:50:13 +08001453TRACE_EVENT(f2fs_update_extent_tree_range,
Chao Yu1ec46102015-02-05 17:59:59 +08001454
Chao Yu744288c2015-09-06 17:50:13 +08001455 TP_PROTO(struct inode *inode, unsigned int pgofs, block_t blkaddr,
1456 unsigned int len),
Chao Yu1ec46102015-02-05 17:59:59 +08001457
Chao Yu744288c2015-09-06 17:50:13 +08001458 TP_ARGS(inode, pgofs, blkaddr, len),
Chao Yu1ec46102015-02-05 17:59:59 +08001459
1460 TP_STRUCT__entry(
1461 __field(dev_t, dev)
1462 __field(ino_t, ino)
1463 __field(unsigned int, pgofs)
1464 __field(u32, blk)
Chao Yu744288c2015-09-06 17:50:13 +08001465 __field(unsigned int, len)
Chao Yu1ec46102015-02-05 17:59:59 +08001466 ),
1467
1468 TP_fast_assign(
1469 __entry->dev = inode->i_sb->s_dev;
1470 __entry->ino = inode->i_ino;
1471 __entry->pgofs = pgofs;
1472 __entry->blk = blkaddr;
Chao Yu744288c2015-09-06 17:50:13 +08001473 __entry->len = len;
Chao Yu1ec46102015-02-05 17:59:59 +08001474 ),
1475
Chao Yu744288c2015-09-06 17:50:13 +08001476 TP_printk("dev = (%d,%d), ino = %lu, pgofs = %u, "
1477 "blkaddr = %u, len = %u",
Chao Yu1ec46102015-02-05 17:59:59 +08001478 show_dev_ino(__entry),
1479 __entry->pgofs,
Chao Yu744288c2015-09-06 17:50:13 +08001480 __entry->blk,
1481 __entry->len)
Chao Yu1ec46102015-02-05 17:59:59 +08001482);
1483
1484TRACE_EVENT(f2fs_shrink_extent_tree,
1485
1486 TP_PROTO(struct f2fs_sb_info *sbi, unsigned int node_cnt,
1487 unsigned int tree_cnt),
1488
1489 TP_ARGS(sbi, node_cnt, tree_cnt),
1490
1491 TP_STRUCT__entry(
1492 __field(dev_t, dev)
1493 __field(unsigned int, node_cnt)
1494 __field(unsigned int, tree_cnt)
1495 ),
1496
1497 TP_fast_assign(
1498 __entry->dev = sbi->sb->s_dev;
1499 __entry->node_cnt = node_cnt;
1500 __entry->tree_cnt = tree_cnt;
1501 ),
1502
1503 TP_printk("dev = (%d,%d), shrunk: node_cnt = %u, tree_cnt = %u",
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001504 show_dev(__entry->dev),
Chao Yu1ec46102015-02-05 17:59:59 +08001505 __entry->node_cnt,
1506 __entry->tree_cnt)
1507);
1508
1509TRACE_EVENT(f2fs_destroy_extent_tree,
1510
1511 TP_PROTO(struct inode *inode, unsigned int node_cnt),
1512
1513 TP_ARGS(inode, node_cnt),
1514
1515 TP_STRUCT__entry(
1516 __field(dev_t, dev)
1517 __field(ino_t, ino)
1518 __field(unsigned int, node_cnt)
1519 ),
1520
1521 TP_fast_assign(
1522 __entry->dev = inode->i_sb->s_dev;
1523 __entry->ino = inode->i_ino;
1524 __entry->node_cnt = node_cnt;
1525 ),
1526
1527 TP_printk("dev = (%d,%d), ino = %lu, destroyed: node_cnt = %u",
1528 show_dev_ino(__entry),
1529 __entry->node_cnt)
1530);
1531
Chao Yu4cf18532015-12-17 17:17:16 +08001532DECLARE_EVENT_CLASS(f2fs_sync_dirty_inodes,
1533
Jaegeuk Kim523be8a2016-05-13 12:36:58 -07001534 TP_PROTO(struct super_block *sb, int type, s64 count),
Chao Yu4cf18532015-12-17 17:17:16 +08001535
1536 TP_ARGS(sb, type, count),
1537
1538 TP_STRUCT__entry(
1539 __field(dev_t, dev)
1540 __field(int, type)
Jaegeuk Kim523be8a2016-05-13 12:36:58 -07001541 __field(s64, count)
Chao Yu4cf18532015-12-17 17:17:16 +08001542 ),
1543
1544 TP_fast_assign(
1545 __entry->dev = sb->s_dev;
1546 __entry->type = type;
1547 __entry->count = count;
1548 ),
1549
Jaegeuk Kim523be8a2016-05-13 12:36:58 -07001550 TP_printk("dev = (%d,%d), %s, dirty count = %lld",
Jaegeuk Kime6b120d2017-07-10 12:55:09 -07001551 show_dev(__entry->dev),
Chao Yu4cf18532015-12-17 17:17:16 +08001552 show_file_type(__entry->type),
1553 __entry->count)
1554);
1555
1556DEFINE_EVENT(f2fs_sync_dirty_inodes, f2fs_sync_dirty_inodes_enter,
1557
Jaegeuk Kim523be8a2016-05-13 12:36:58 -07001558 TP_PROTO(struct super_block *sb, int type, s64 count),
Chao Yu4cf18532015-12-17 17:17:16 +08001559
1560 TP_ARGS(sb, type, count)
1561);
1562
1563DEFINE_EVENT(f2fs_sync_dirty_inodes, f2fs_sync_dirty_inodes_exit,
1564
Jaegeuk Kim523be8a2016-05-13 12:36:58 -07001565 TP_PROTO(struct super_block *sb, int type, s64 count),
Chao Yu4cf18532015-12-17 17:17:16 +08001566
1567 TP_ARGS(sb, type, count)
1568);
1569
Namjae Jeona2a4a7e2013-04-20 01:28:40 +09001570#endif /* _TRACE_F2FS_H */
1571
1572 /* This part must be outside protection */
1573#include <trace/define_trace.h>