diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2010-03-05 13:47:00 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2010-03-05 13:47:00 -0500 |
commit | 1f63b9c15b17d5af360c180f5c71537e954d5d3b (patch) | |
tree | 4da17d6f2035ae093680fa2caa3e1c84b44bb237 /include | |
parent | b24bc1e61cec2174faf5dfa632da16b6ca17144f (diff) | |
parent | 64e290ec69be39f1887fa0b403c1e417b6b038e7 (diff) |
Merge branch 'for_linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tytso/ext4
* 'for_linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tytso/ext4: (36 commits)
ext4: fix up rb_root initializations to use RB_ROOT
ext4: Code cleanup for EXT4_IOC_MOVE_EXT ioctl
ext4: Fix the NULL reference in double_down_write_data_sem()
ext4: Fix insertion point of extent in mext_insert_across_blocks()
ext4: consolidate in_range() definitions
ext4: cleanup to use ext4_grp_offs_to_block()
ext4: cleanup to use ext4_group_first_block_no()
ext4: Release page references acquired in ext4_da_block_invalidatepages
ext4: Fix ext4_quota_write cross block boundary behaviour
ext4: Convert BUG_ON checks to use ext4_error() instead
ext4: Use direct_IO_no_locking in ext4 dio read
ext4: use ext4_get_block_write in buffer write
ext4: mechanical rename some of the direct I/O get_block's identifiers
ext4: make "offset" consistent in ext4_check_dir_entry()
ext4: Handle non empty on-disk orphan link
ext4: explicitly remove inode from orphan list after failed direct io
ext4: fix error handling in migrate
ext4: deprecate obsoleted mount options
ext4: Fix fencepost error in chosing choosing group vs file preallocation.
jbd2: clean up an assertion in jbd2_journal_commit_transaction()
...
Diffstat (limited to 'include')
-rw-r--r-- | include/linux/jbd2.h | 11 | ||||
-rw-r--r-- | include/trace/events/ext4.h | 101 | ||||
-rw-r--r-- | include/trace/events/jbd2.h | 28 |
3 files changed, 131 insertions, 9 deletions
diff --git a/include/linux/jbd2.h b/include/linux/jbd2.h index 638ce4554c76..8ada2a129d08 100644 --- a/include/linux/jbd2.h +++ b/include/linux/jbd2.h | |||
@@ -69,15 +69,8 @@ extern u8 jbd2_journal_enable_debug; | |||
69 | #define jbd_debug(f, a...) /**/ | 69 | #define jbd_debug(f, a...) /**/ |
70 | #endif | 70 | #endif |
71 | 71 | ||
72 | static inline void *jbd2_alloc(size_t size, gfp_t flags) | 72 | extern void *jbd2_alloc(size_t size, gfp_t flags); |
73 | { | 73 | extern void jbd2_free(void *ptr, size_t size); |
74 | return (void *)__get_free_pages(flags, get_order(size)); | ||
75 | } | ||
76 | |||
77 | static inline void jbd2_free(void *ptr, size_t size) | ||
78 | { | ||
79 | free_pages((unsigned long)ptr, get_order(size)); | ||
80 | }; | ||
81 | 74 | ||
82 | #define JBD2_MIN_JOURNAL_BLOCKS 1024 | 75 | #define JBD2_MIN_JOURNAL_BLOCKS 1024 |
83 | 76 | ||
diff --git a/include/trace/events/ext4.h b/include/trace/events/ext4.h index d0b6cd3afb2f..2aa6aa3e8f61 100644 --- a/include/trace/events/ext4.h +++ b/include/trace/events/ext4.h | |||
@@ -874,6 +874,107 @@ TRACE_EVENT(ext4_forget, | |||
874 | __entry->mode, __entry->is_metadata, __entry->block) | 874 | __entry->mode, __entry->is_metadata, __entry->block) |
875 | ); | 875 | ); |
876 | 876 | ||
877 | TRACE_EVENT(ext4_da_update_reserve_space, | ||
878 | TP_PROTO(struct inode *inode, int used_blocks), | ||
879 | |||
880 | TP_ARGS(inode, used_blocks), | ||
881 | |||
882 | TP_STRUCT__entry( | ||
883 | __field( dev_t, dev ) | ||
884 | __field( ino_t, ino ) | ||
885 | __field( umode_t, mode ) | ||
886 | __field( __u64, i_blocks ) | ||
887 | __field( int, used_blocks ) | ||
888 | __field( int, reserved_data_blocks ) | ||
889 | __field( int, reserved_meta_blocks ) | ||
890 | __field( int, allocated_meta_blocks ) | ||
891 | ), | ||
892 | |||
893 | TP_fast_assign( | ||
894 | __entry->dev = inode->i_sb->s_dev; | ||
895 | __entry->ino = inode->i_ino; | ||
896 | __entry->mode = inode->i_mode; | ||
897 | __entry->i_blocks = inode->i_blocks; | ||
898 | __entry->used_blocks = used_blocks; | ||
899 | __entry->reserved_data_blocks = EXT4_I(inode)->i_reserved_data_blocks; | ||
900 | __entry->reserved_meta_blocks = EXT4_I(inode)->i_reserved_meta_blocks; | ||
901 | __entry->allocated_meta_blocks = EXT4_I(inode)->i_allocated_meta_blocks; | ||
902 | ), | ||
903 | |||
904 | TP_printk("dev %s ino %lu mode 0%o i_blocks %llu used_blocks %d reserved_data_blocks %d reserved_meta_blocks %d allocated_meta_blocks %d", | ||
905 | jbd2_dev_to_name(__entry->dev), (unsigned long) __entry->ino, | ||
906 | __entry->mode, (unsigned long long) __entry->i_blocks, | ||
907 | __entry->used_blocks, __entry->reserved_data_blocks, | ||
908 | __entry->reserved_meta_blocks, __entry->allocated_meta_blocks) | ||
909 | ); | ||
910 | |||
911 | TRACE_EVENT(ext4_da_reserve_space, | ||
912 | TP_PROTO(struct inode *inode, int md_needed), | ||
913 | |||
914 | TP_ARGS(inode, md_needed), | ||
915 | |||
916 | TP_STRUCT__entry( | ||
917 | __field( dev_t, dev ) | ||
918 | __field( ino_t, ino ) | ||
919 | __field( umode_t, mode ) | ||
920 | __field( __u64, i_blocks ) | ||
921 | __field( int, md_needed ) | ||
922 | __field( int, reserved_data_blocks ) | ||
923 | __field( int, reserved_meta_blocks ) | ||
924 | ), | ||
925 | |||
926 | TP_fast_assign( | ||
927 | __entry->dev = inode->i_sb->s_dev; | ||
928 | __entry->ino = inode->i_ino; | ||
929 | __entry->mode = inode->i_mode; | ||
930 | __entry->i_blocks = inode->i_blocks; | ||
931 | __entry->md_needed = md_needed; | ||
932 | __entry->reserved_data_blocks = EXT4_I(inode)->i_reserved_data_blocks; | ||
933 | __entry->reserved_meta_blocks = EXT4_I(inode)->i_reserved_meta_blocks; | ||
934 | ), | ||
935 | |||
936 | TP_printk("dev %s ino %lu mode 0%o i_blocks %llu md_needed %d reserved_data_blocks %d reserved_meta_blocks %d", | ||
937 | jbd2_dev_to_name(__entry->dev), (unsigned long) __entry->ino, | ||
938 | __entry->mode, (unsigned long long) __entry->i_blocks, | ||
939 | __entry->md_needed, __entry->reserved_data_blocks, | ||
940 | __entry->reserved_meta_blocks) | ||
941 | ); | ||
942 | |||
943 | TRACE_EVENT(ext4_da_release_space, | ||
944 | TP_PROTO(struct inode *inode, int freed_blocks), | ||
945 | |||
946 | TP_ARGS(inode, freed_blocks), | ||
947 | |||
948 | TP_STRUCT__entry( | ||
949 | __field( dev_t, dev ) | ||
950 | __field( ino_t, ino ) | ||
951 | __field( umode_t, mode ) | ||
952 | __field( __u64, i_blocks ) | ||
953 | __field( int, freed_blocks ) | ||
954 | __field( int, reserved_data_blocks ) | ||
955 | __field( int, reserved_meta_blocks ) | ||
956 | __field( int, allocated_meta_blocks ) | ||
957 | ), | ||
958 | |||
959 | TP_fast_assign( | ||
960 | __entry->dev = inode->i_sb->s_dev; | ||
961 | __entry->ino = inode->i_ino; | ||
962 | __entry->mode = inode->i_mode; | ||
963 | __entry->i_blocks = inode->i_blocks; | ||
964 | __entry->freed_blocks = freed_blocks; | ||
965 | __entry->reserved_data_blocks = EXT4_I(inode)->i_reserved_data_blocks; | ||
966 | __entry->reserved_meta_blocks = EXT4_I(inode)->i_reserved_meta_blocks; | ||
967 | __entry->allocated_meta_blocks = EXT4_I(inode)->i_allocated_meta_blocks; | ||
968 | ), | ||
969 | |||
970 | TP_printk("dev %s ino %lu mode 0%o i_blocks %llu freed_blocks %d reserved_data_blocks %d reserved_meta_blocks %d allocated_meta_blocks %d", | ||
971 | jbd2_dev_to_name(__entry->dev), (unsigned long) __entry->ino, | ||
972 | __entry->mode, (unsigned long long) __entry->i_blocks, | ||
973 | __entry->freed_blocks, __entry->reserved_data_blocks, | ||
974 | __entry->reserved_meta_blocks, __entry->allocated_meta_blocks) | ||
975 | ); | ||
976 | |||
977 | |||
877 | #endif /* _TRACE_EXT4_H */ | 978 | #endif /* _TRACE_EXT4_H */ |
878 | 979 | ||
879 | /* This part must be outside protection */ | 980 | /* This part must be outside protection */ |
diff --git a/include/trace/events/jbd2.h b/include/trace/events/jbd2.h index 96b370a050de..bf16545cc977 100644 --- a/include/trace/events/jbd2.h +++ b/include/trace/events/jbd2.h | |||
@@ -199,6 +199,34 @@ TRACE_EVENT(jbd2_checkpoint_stats, | |||
199 | __entry->forced_to_close, __entry->written, __entry->dropped) | 199 | __entry->forced_to_close, __entry->written, __entry->dropped) |
200 | ); | 200 | ); |
201 | 201 | ||
202 | TRACE_EVENT(jbd2_cleanup_journal_tail, | ||
203 | |||
204 | TP_PROTO(journal_t *journal, tid_t first_tid, | ||
205 | unsigned long block_nr, unsigned long freed), | ||
206 | |||
207 | TP_ARGS(journal, first_tid, block_nr, freed), | ||
208 | |||
209 | TP_STRUCT__entry( | ||
210 | __field( dev_t, dev ) | ||
211 | __field( tid_t, tail_sequence ) | ||
212 | __field( tid_t, first_tid ) | ||
213 | __field(unsigned long, block_nr ) | ||
214 | __field(unsigned long, freed ) | ||
215 | ), | ||
216 | |||
217 | TP_fast_assign( | ||
218 | __entry->dev = journal->j_fs_dev->bd_dev; | ||
219 | __entry->tail_sequence = journal->j_tail_sequence; | ||
220 | __entry->first_tid = first_tid; | ||
221 | __entry->block_nr = block_nr; | ||
222 | __entry->freed = freed; | ||
223 | ), | ||
224 | |||
225 | TP_printk("dev %s from %u to %u offset %lu freed %lu", | ||
226 | jbd2_dev_to_name(__entry->dev), __entry->tail_sequence, | ||
227 | __entry->first_tid, __entry->block_nr, __entry->freed) | ||
228 | ); | ||
229 | |||
202 | #endif /* _TRACE_JBD2_H */ | 230 | #endif /* _TRACE_JBD2_H */ |
203 | 231 | ||
204 | /* This part must be outside protection */ | 232 | /* This part must be outside protection */ |