diff options
author | Namjae Jeon <namjae.jeon@samsung.com> | 2013-04-23 04:51:43 -0400 |
---|---|---|
committer | Jaegeuk Kim <jaegeuk.kim@samsung.com> | 2013-04-23 05:15:17 -0400 |
commit | 6ec178dac6768204a6edf70f4a53d40b691c12b4 (patch) | |
tree | 88a7676da49821341d3c193ddc9c8cce73db31a8 /include/trace/events | |
parent | c01e285324793a86c2c90c8451ed6feb04b3d310 (diff) |
f2fs: add tracepoints for write page operations
Add tracepoints to debug the various page write operation
like data pages, meta pages.
Signed-off-by: Namjae Jeon <namjae.jeon@samsung.com>
Signed-off-by: Pankaj Kumar <pankaj.km@samsung.com>
Acked-by: Steven Rostedt <rostedt@goodmis.org>
[Jaegeuk: remove unnecessary tracepoints]
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
Diffstat (limited to 'include/trace/events')
-rw-r--r-- | include/trace/events/f2fs.h | 67 |
1 files changed, 67 insertions, 0 deletions
diff --git a/include/trace/events/f2fs.h b/include/trace/events/f2fs.h index 56b6240e6c01..ae2da92e0768 100644 --- a/include/trace/events/f2fs.h +++ b/include/trace/events/f2fs.h | |||
@@ -8,6 +8,14 @@ | |||
8 | 8 | ||
9 | #define show_dev(entry) MAJOR(entry->dev), MINOR(entry->dev) | 9 | #define show_dev(entry) MAJOR(entry->dev), MINOR(entry->dev) |
10 | #define show_dev_ino(entry) show_dev(entry), (unsigned long)entry->ino | 10 | #define show_dev_ino(entry) show_dev(entry), (unsigned long)entry->ino |
11 | |||
12 | #define show_block_type(type) \ | ||
13 | __print_symbolic(type, \ | ||
14 | { NODE, "NODE" }, \ | ||
15 | { DATA, "DATA" }, \ | ||
16 | { META, "META" }, \ | ||
17 | { META_FLUSH, "META_FLUSH" }) | ||
18 | |||
11 | #define show_bio_type(type) \ | 19 | #define show_bio_type(type) \ |
12 | __print_symbolic(type, \ | 20 | __print_symbolic(type, \ |
13 | { READ, "READ" }, \ | 21 | { READ, "READ" }, \ |
@@ -578,6 +586,65 @@ TRACE_EVENT(f2fs_reserve_new_block, | |||
578 | __entry->ofs_in_node) | 586 | __entry->ofs_in_node) |
579 | ); | 587 | ); |
580 | 588 | ||
589 | TRACE_EVENT(f2fs_do_submit_bio, | ||
590 | |||
591 | TP_PROTO(struct super_block *sb, int btype, bool sync, struct bio *bio), | ||
592 | |||
593 | TP_ARGS(sb, btype, sync, bio), | ||
594 | |||
595 | TP_STRUCT__entry( | ||
596 | __field(dev_t, dev) | ||
597 | __field(int, btype) | ||
598 | __field(bool, sync) | ||
599 | __field(sector_t, sector) | ||
600 | __field(unsigned int, size) | ||
601 | ), | ||
602 | |||
603 | TP_fast_assign( | ||
604 | __entry->dev = sb->s_dev; | ||
605 | __entry->btype = btype; | ||
606 | __entry->sync = sync; | ||
607 | __entry->sector = bio->bi_sector; | ||
608 | __entry->size = bio->bi_size; | ||
609 | ), | ||
610 | |||
611 | TP_printk("dev = (%d,%d), type = %s, io = %s, sector = %lld, size = %u", | ||
612 | show_dev(__entry), | ||
613 | show_block_type(__entry->btype), | ||
614 | __entry->sync ? "sync" : "no sync", | ||
615 | (unsigned long long)__entry->sector, | ||
616 | __entry->size) | ||
617 | ); | ||
618 | |||
619 | TRACE_EVENT(f2fs_submit_write_page, | ||
620 | |||
621 | TP_PROTO(struct page *page, block_t blk_addr, int type), | ||
622 | |||
623 | TP_ARGS(page, blk_addr, type), | ||
624 | |||
625 | TP_STRUCT__entry( | ||
626 | __field(dev_t, dev) | ||
627 | __field(ino_t, ino) | ||
628 | __field(int, type) | ||
629 | __field(pgoff_t, index) | ||
630 | __field(block_t, block) | ||
631 | ), | ||
632 | |||
633 | TP_fast_assign( | ||
634 | __entry->dev = page->mapping->host->i_sb->s_dev; | ||
635 | __entry->ino = page->mapping->host->i_ino; | ||
636 | __entry->type = type; | ||
637 | __entry->index = page->index; | ||
638 | __entry->block = blk_addr; | ||
639 | ), | ||
640 | |||
641 | TP_printk("dev = (%d,%d), ino = %lu, %s, index = %lu, blkaddr = 0x%llx", | ||
642 | show_dev_ino(__entry), | ||
643 | show_block_type(__entry->type), | ||
644 | (unsigned long)__entry->index, | ||
645 | (unsigned long long)__entry->block) | ||
646 | ); | ||
647 | |||
581 | #endif /* _TRACE_F2FS_H */ | 648 | #endif /* _TRACE_F2FS_H */ |
582 | 649 | ||
583 | /* This part must be outside protection */ | 650 | /* This part must be outside protection */ |