diff options
-rw-r--r-- | fs/ocfs2/cluster/masklog.c | 1 | ||||
-rw-r--r-- | fs/ocfs2/cluster/masklog.h | 1 | ||||
-rw-r--r-- | fs/ocfs2/inode.c | 107 | ||||
-rw-r--r-- | fs/ocfs2/ocfs2_trace.h | 136 |
4 files changed, 182 insertions, 63 deletions
diff --git a/fs/ocfs2/cluster/masklog.c b/fs/ocfs2/cluster/masklog.c index 036e8b8814f7..e18fb801633e 100644 --- a/fs/ocfs2/cluster/masklog.c +++ b/fs/ocfs2/cluster/masklog.c | |||
@@ -99,7 +99,6 @@ static struct mlog_attribute mlog_attrs[MLOG_MAX_BITS] = { | |||
99 | define_mask(BH_IO), | 99 | define_mask(BH_IO), |
100 | define_mask(UPTODATE), | 100 | define_mask(UPTODATE), |
101 | define_mask(NAMEI), | 101 | define_mask(NAMEI), |
102 | define_mask(INODE), | ||
103 | define_mask(VOTE), | 102 | define_mask(VOTE), |
104 | define_mask(DCACHE), | 103 | define_mask(DCACHE), |
105 | define_mask(CONN), | 104 | define_mask(CONN), |
diff --git a/fs/ocfs2/cluster/masklog.h b/fs/ocfs2/cluster/masklog.h index d07780ab9f8f..b76d07786107 100644 --- a/fs/ocfs2/cluster/masklog.h +++ b/fs/ocfs2/cluster/masklog.h | |||
@@ -101,7 +101,6 @@ | |||
101 | #define ML_BH_IO 0x0000000000100000ULL /* ocfs2 buffer I/O */ | 101 | #define ML_BH_IO 0x0000000000100000ULL /* ocfs2 buffer I/O */ |
102 | #define ML_UPTODATE 0x0000000000200000ULL /* ocfs2 caching sequence #'s */ | 102 | #define ML_UPTODATE 0x0000000000200000ULL /* ocfs2 caching sequence #'s */ |
103 | #define ML_NAMEI 0x0000000000400000ULL /* ocfs2 directory / namespace */ | 103 | #define ML_NAMEI 0x0000000000400000ULL /* ocfs2 directory / namespace */ |
104 | #define ML_INODE 0x0000000000800000ULL /* ocfs2 inode manipulation */ | ||
105 | #define ML_VOTE 0x0000000001000000ULL /* ocfs2 node messaging */ | 104 | #define ML_VOTE 0x0000000001000000ULL /* ocfs2 node messaging */ |
106 | #define ML_DCACHE 0x0000000002000000ULL /* ocfs2 dcache operations */ | 105 | #define ML_DCACHE 0x0000000002000000ULL /* ocfs2 dcache operations */ |
107 | #define ML_CONN 0x0000000004000000ULL /* net connection management */ | 106 | #define ML_CONN 0x0000000004000000ULL /* net connection management */ |
diff --git a/fs/ocfs2/inode.c b/fs/ocfs2/inode.c index 8ec0cb01cb7c..177d3a6c2a5f 100644 --- a/fs/ocfs2/inode.c +++ b/fs/ocfs2/inode.c | |||
@@ -31,7 +31,6 @@ | |||
31 | 31 | ||
32 | #include <asm/byteorder.h> | 32 | #include <asm/byteorder.h> |
33 | 33 | ||
34 | #define MLOG_MASK_PREFIX ML_INODE | ||
35 | #include <cluster/masklog.h> | 34 | #include <cluster/masklog.h> |
36 | 35 | ||
37 | #include "ocfs2.h" | 36 | #include "ocfs2.h" |
@@ -53,6 +52,7 @@ | |||
53 | #include "uptodate.h" | 52 | #include "uptodate.h" |
54 | #include "xattr.h" | 53 | #include "xattr.h" |
55 | #include "refcounttree.h" | 54 | #include "refcounttree.h" |
55 | #include "ocfs2_trace.h" | ||
56 | 56 | ||
57 | #include "buffer_head_io.h" | 57 | #include "buffer_head_io.h" |
58 | 58 | ||
@@ -131,7 +131,8 @@ struct inode *ocfs2_iget(struct ocfs2_super *osb, u64 blkno, unsigned flags, | |||
131 | struct super_block *sb = osb->sb; | 131 | struct super_block *sb = osb->sb; |
132 | struct ocfs2_find_inode_args args; | 132 | struct ocfs2_find_inode_args args; |
133 | 133 | ||
134 | mlog(0, "(blkno = %llu)\n", (unsigned long long)blkno); | 134 | trace_ocfs2_iget_begin((unsigned long long)blkno, flags, |
135 | sysfile_type); | ||
135 | 136 | ||
136 | /* Ok. By now we've either got the offsets passed to us by the | 137 | /* Ok. By now we've either got the offsets passed to us by the |
137 | * caller, or we just pulled them off the bh. Lets do some | 138 | * caller, or we just pulled them off the bh. Lets do some |
@@ -157,8 +158,8 @@ struct inode *ocfs2_iget(struct ocfs2_super *osb, u64 blkno, unsigned flags, | |||
157 | mlog_errno(PTR_ERR(inode)); | 158 | mlog_errno(PTR_ERR(inode)); |
158 | goto bail; | 159 | goto bail; |
159 | } | 160 | } |
161 | trace_ocfs2_iget5_locked(inode->i_state); | ||
160 | if (inode->i_state & I_NEW) { | 162 | if (inode->i_state & I_NEW) { |
161 | mlog(0, "Inode was not in inode cache, reading it.\n"); | ||
162 | ocfs2_read_locked_inode(inode, &args); | 163 | ocfs2_read_locked_inode(inode, &args); |
163 | unlock_new_inode(inode); | 164 | unlock_new_inode(inode); |
164 | } | 165 | } |
@@ -170,9 +171,8 @@ struct inode *ocfs2_iget(struct ocfs2_super *osb, u64 blkno, unsigned flags, | |||
170 | 171 | ||
171 | bail: | 172 | bail: |
172 | if (!IS_ERR(inode)) { | 173 | if (!IS_ERR(inode)) { |
173 | mlog(0, "returning inode with number %llu\n", | 174 | trace_ocfs2_iget_end(inode, |
174 | (unsigned long long)OCFS2_I(inode)->ip_blkno); | 175 | (unsigned long long)OCFS2_I(inode)->ip_blkno); |
175 | mlog(0, "inode %p\n", inode); | ||
176 | } | 176 | } |
177 | 177 | ||
178 | return inode; | 178 | return inode; |
@@ -192,12 +192,12 @@ static int ocfs2_find_actor(struct inode *inode, void *opaque) | |||
192 | struct ocfs2_inode_info *oi = OCFS2_I(inode); | 192 | struct ocfs2_inode_info *oi = OCFS2_I(inode); |
193 | int ret = 0; | 193 | int ret = 0; |
194 | 194 | ||
195 | mlog(0, "(0x%p, %lu, 0x%p)\n", inode, inode->i_ino, opaque); | ||
196 | |||
197 | args = opaque; | 195 | args = opaque; |
198 | 196 | ||
199 | mlog_bug_on_msg(!inode, "No inode in find actor!\n"); | 197 | mlog_bug_on_msg(!inode, "No inode in find actor!\n"); |
200 | 198 | ||
199 | trace_ocfs2_find_actor(inode, inode->i_ino, opaque, args->fi_blkno); | ||
200 | |||
201 | if (oi->ip_blkno != args->fi_blkno) | 201 | if (oi->ip_blkno != args->fi_blkno) |
202 | goto bail; | 202 | goto bail; |
203 | 203 | ||
@@ -217,8 +217,6 @@ static int ocfs2_init_locked_inode(struct inode *inode, void *opaque) | |||
217 | static struct lock_class_key ocfs2_quota_ip_alloc_sem_key, | 217 | static struct lock_class_key ocfs2_quota_ip_alloc_sem_key, |
218 | ocfs2_file_ip_alloc_sem_key; | 218 | ocfs2_file_ip_alloc_sem_key; |
219 | 219 | ||
220 | mlog(0, "inode = %p, opaque = %p\n", inode, opaque); | ||
221 | |||
222 | inode->i_ino = args->fi_ino; | 220 | inode->i_ino = args->fi_ino; |
223 | OCFS2_I(inode)->ip_blkno = args->fi_blkno; | 221 | OCFS2_I(inode)->ip_blkno = args->fi_blkno; |
224 | if (args->fi_sysfile_type != 0) | 222 | if (args->fi_sysfile_type != 0) |
@@ -244,9 +242,6 @@ void ocfs2_populate_inode(struct inode *inode, struct ocfs2_dinode *fe, | |||
244 | struct ocfs2_super *osb; | 242 | struct ocfs2_super *osb; |
245 | int use_plocks = 1; | 243 | int use_plocks = 1; |
246 | 244 | ||
247 | mlog(0, "(0x%p, size:%llu)\n", inode, | ||
248 | (unsigned long long)le64_to_cpu(fe->i_size)); | ||
249 | |||
250 | sb = inode->i_sb; | 245 | sb = inode->i_sb; |
251 | osb = OCFS2_SB(sb); | 246 | osb = OCFS2_SB(sb); |
252 | 247 | ||
@@ -298,20 +293,20 @@ void ocfs2_populate_inode(struct inode *inode, struct ocfs2_dinode *fe, | |||
298 | 293 | ||
299 | inode->i_nlink = ocfs2_read_links_count(fe); | 294 | inode->i_nlink = ocfs2_read_links_count(fe); |
300 | 295 | ||
296 | trace_ocfs2_populate_inode(OCFS2_I(inode)->ip_blkno, | ||
297 | le32_to_cpu(fe->i_flags)); | ||
301 | if (fe->i_flags & cpu_to_le32(OCFS2_SYSTEM_FL)) { | 298 | if (fe->i_flags & cpu_to_le32(OCFS2_SYSTEM_FL)) { |
302 | OCFS2_I(inode)->ip_flags |= OCFS2_INODE_SYSTEM_FILE; | 299 | OCFS2_I(inode)->ip_flags |= OCFS2_INODE_SYSTEM_FILE; |
303 | inode->i_flags |= S_NOQUOTA; | 300 | inode->i_flags |= S_NOQUOTA; |
304 | } | 301 | } |
305 | 302 | ||
306 | if (fe->i_flags & cpu_to_le32(OCFS2_LOCAL_ALLOC_FL)) { | 303 | if (fe->i_flags & cpu_to_le32(OCFS2_LOCAL_ALLOC_FL)) { |
307 | OCFS2_I(inode)->ip_flags |= OCFS2_INODE_BITMAP; | 304 | OCFS2_I(inode)->ip_flags |= OCFS2_INODE_BITMAP; |
308 | mlog(0, "local alloc inode: i_ino=%lu\n", inode->i_ino); | ||
309 | } else if (fe->i_flags & cpu_to_le32(OCFS2_BITMAP_FL)) { | 305 | } else if (fe->i_flags & cpu_to_le32(OCFS2_BITMAP_FL)) { |
310 | OCFS2_I(inode)->ip_flags |= OCFS2_INODE_BITMAP; | 306 | OCFS2_I(inode)->ip_flags |= OCFS2_INODE_BITMAP; |
311 | } else if (fe->i_flags & cpu_to_le32(OCFS2_QUOTA_FL)) { | 307 | } else if (fe->i_flags & cpu_to_le32(OCFS2_QUOTA_FL)) { |
312 | inode->i_flags |= S_NOQUOTA; | 308 | inode->i_flags |= S_NOQUOTA; |
313 | } else if (fe->i_flags & cpu_to_le32(OCFS2_SUPER_BLOCK_FL)) { | 309 | } else if (fe->i_flags & cpu_to_le32(OCFS2_SUPER_BLOCK_FL)) { |
314 | mlog(0, "superblock inode: i_ino=%lu\n", inode->i_ino); | ||
315 | /* we can't actually hit this as read_inode can't | 310 | /* we can't actually hit this as read_inode can't |
316 | * handle superblocks today ;-) */ | 311 | * handle superblocks today ;-) */ |
317 | BUG(); | 312 | BUG(); |
@@ -391,8 +386,6 @@ static int ocfs2_read_locked_inode(struct inode *inode, | |||
391 | int status, can_lock; | 386 | int status, can_lock; |
392 | u32 generation = 0; | 387 | u32 generation = 0; |
393 | 388 | ||
394 | mlog(0, "(0x%p, 0x%p)\n", inode, args); | ||
395 | |||
396 | status = -EINVAL; | 389 | status = -EINVAL; |
397 | if (inode == NULL || inode->i_sb == NULL) { | 390 | if (inode == NULL || inode->i_sb == NULL) { |
398 | mlog(ML_ERROR, "bad inode\n"); | 391 | mlog(ML_ERROR, "bad inode\n"); |
@@ -440,6 +433,9 @@ static int ocfs2_read_locked_inode(struct inode *inode, | |||
440 | && !(args->fi_flags & OCFS2_FI_FLAG_ORPHAN_RECOVERY) | 433 | && !(args->fi_flags & OCFS2_FI_FLAG_ORPHAN_RECOVERY) |
441 | && !ocfs2_mount_local(osb); | 434 | && !ocfs2_mount_local(osb); |
442 | 435 | ||
436 | trace_ocfs2_read_locked_inode( | ||
437 | (unsigned long long)OCFS2_I(inode)->ip_blkno, can_lock); | ||
438 | |||
443 | /* | 439 | /* |
444 | * To maintain backwards compatibility with older versions of | 440 | * To maintain backwards compatibility with older versions of |
445 | * ocfs2-tools, we still store the generation value for system | 441 | * ocfs2-tools, we still store the generation value for system |
@@ -689,8 +685,6 @@ static int ocfs2_check_orphan_recovery_state(struct ocfs2_super *osb, | |||
689 | 685 | ||
690 | spin_lock(&osb->osb_lock); | 686 | spin_lock(&osb->osb_lock); |
691 | if (ocfs2_node_map_test_bit(osb, &osb->osb_recovering_orphan_dirs, slot)) { | 687 | if (ocfs2_node_map_test_bit(osb, &osb->osb_recovering_orphan_dirs, slot)) { |
692 | mlog(0, "Recovery is happening on orphan dir %d, will skip " | ||
693 | "this inode\n", slot); | ||
694 | ret = -EDEADLK; | 688 | ret = -EDEADLK; |
695 | goto out; | 689 | goto out; |
696 | } | 690 | } |
@@ -699,6 +693,7 @@ static int ocfs2_check_orphan_recovery_state(struct ocfs2_super *osb, | |||
699 | osb->osb_orphan_wipes[slot]++; | 693 | osb->osb_orphan_wipes[slot]++; |
700 | out: | 694 | out: |
701 | spin_unlock(&osb->osb_lock); | 695 | spin_unlock(&osb->osb_lock); |
696 | trace_ocfs2_check_orphan_recovery_state(slot, ret); | ||
702 | return ret; | 697 | return ret; |
703 | } | 698 | } |
704 | 699 | ||
@@ -809,6 +804,10 @@ static int ocfs2_inode_is_valid_to_delete(struct inode *inode) | |||
809 | struct ocfs2_inode_info *oi = OCFS2_I(inode); | 804 | struct ocfs2_inode_info *oi = OCFS2_I(inode); |
810 | struct ocfs2_super *osb = OCFS2_SB(inode->i_sb); | 805 | struct ocfs2_super *osb = OCFS2_SB(inode->i_sb); |
811 | 806 | ||
807 | trace_ocfs2_inode_is_valid_to_delete(current, osb->dc_task, | ||
808 | (unsigned long long)oi->ip_blkno, | ||
809 | oi->ip_flags); | ||
810 | |||
812 | /* We shouldn't be getting here for the root directory | 811 | /* We shouldn't be getting here for the root directory |
813 | * inode.. */ | 812 | * inode.. */ |
814 | if (inode == osb->root_inode) { | 813 | if (inode == osb->root_inode) { |
@@ -821,11 +820,8 @@ static int ocfs2_inode_is_valid_to_delete(struct inode *inode) | |||
821 | * have to skip deleting this guy. That's OK though because | 820 | * have to skip deleting this guy. That's OK though because |
822 | * the node who's doing the actual deleting should handle it | 821 | * the node who's doing the actual deleting should handle it |
823 | * anyway. */ | 822 | * anyway. */ |
824 | if (current == osb->dc_task) { | 823 | if (current == osb->dc_task) |
825 | mlog(0, "Skipping delete of %lu because we're currently " | ||
826 | "in downconvert\n", inode->i_ino); | ||
827 | goto bail; | 824 | goto bail; |
828 | } | ||
829 | 825 | ||
830 | spin_lock(&oi->ip_lock); | 826 | spin_lock(&oi->ip_lock); |
831 | /* OCFS2 *never* deletes system files. This should technically | 827 | /* OCFS2 *never* deletes system files. This should technically |
@@ -840,11 +836,8 @@ static int ocfs2_inode_is_valid_to_delete(struct inode *inode) | |||
840 | /* If we have allowd wipe of this inode for another node, it | 836 | /* If we have allowd wipe of this inode for another node, it |
841 | * will be marked here so we can safely skip it. Recovery will | 837 | * will be marked here so we can safely skip it. Recovery will |
842 | * cleanup any inodes we might inadvertantly skip here. */ | 838 | * cleanup any inodes we might inadvertantly skip here. */ |
843 | if (oi->ip_flags & OCFS2_INODE_SKIP_DELETE) { | 839 | if (oi->ip_flags & OCFS2_INODE_SKIP_DELETE) |
844 | mlog(0, "Skipping delete of %lu because another node " | ||
845 | "has done this for us.\n", inode->i_ino); | ||
846 | goto bail_unlock; | 840 | goto bail_unlock; |
847 | } | ||
848 | 841 | ||
849 | ret = 1; | 842 | ret = 1; |
850 | bail_unlock: | 843 | bail_unlock: |
@@ -861,28 +854,27 @@ static int ocfs2_query_inode_wipe(struct inode *inode, | |||
861 | struct buffer_head *di_bh, | 854 | struct buffer_head *di_bh, |
862 | int *wipe) | 855 | int *wipe) |
863 | { | 856 | { |
864 | int status = 0; | 857 | int status = 0, reason = 0; |
865 | struct ocfs2_inode_info *oi = OCFS2_I(inode); | 858 | struct ocfs2_inode_info *oi = OCFS2_I(inode); |
866 | struct ocfs2_dinode *di; | 859 | struct ocfs2_dinode *di; |
867 | 860 | ||
868 | *wipe = 0; | 861 | *wipe = 0; |
869 | 862 | ||
863 | trace_ocfs2_query_inode_wipe_begin((unsigned long long)oi->ip_blkno, | ||
864 | inode->i_nlink); | ||
865 | |||
870 | /* While we were waiting for the cluster lock in | 866 | /* While we were waiting for the cluster lock in |
871 | * ocfs2_delete_inode, another node might have asked to delete | 867 | * ocfs2_delete_inode, another node might have asked to delete |
872 | * the inode. Recheck our flags to catch this. */ | 868 | * the inode. Recheck our flags to catch this. */ |
873 | if (!ocfs2_inode_is_valid_to_delete(inode)) { | 869 | if (!ocfs2_inode_is_valid_to_delete(inode)) { |
874 | mlog(0, "Skipping delete of %llu because flags changed\n", | 870 | reason = 1; |
875 | (unsigned long long)oi->ip_blkno); | ||
876 | goto bail; | 871 | goto bail; |
877 | } | 872 | } |
878 | 873 | ||
879 | /* Now that we have an up to date inode, we can double check | 874 | /* Now that we have an up to date inode, we can double check |
880 | * the link count. */ | 875 | * the link count. */ |
881 | if (inode->i_nlink) { | 876 | if (inode->i_nlink) |
882 | mlog(0, "Skipping delete of %llu because nlink = %u\n", | ||
883 | (unsigned long long)oi->ip_blkno, inode->i_nlink); | ||
884 | goto bail; | 877 | goto bail; |
885 | } | ||
886 | 878 | ||
887 | /* Do some basic inode verification... */ | 879 | /* Do some basic inode verification... */ |
888 | di = (struct ocfs2_dinode *) di_bh->b_data; | 880 | di = (struct ocfs2_dinode *) di_bh->b_data; |
@@ -897,9 +889,7 @@ static int ocfs2_query_inode_wipe(struct inode *inode, | |||
897 | * ORPHANED_FL not. | 889 | * ORPHANED_FL not. |
898 | */ | 890 | */ |
899 | if (di->i_dyn_features & cpu_to_le16(OCFS2_HAS_REFCOUNT_FL)) { | 891 | if (di->i_dyn_features & cpu_to_le16(OCFS2_HAS_REFCOUNT_FL)) { |
900 | mlog(0, "Reflinked inode %llu is no longer orphaned. " | 892 | reason = 2; |
901 | "it shouldn't be deleted\n", | ||
902 | (unsigned long long)oi->ip_blkno); | ||
903 | goto bail; | 893 | goto bail; |
904 | } | 894 | } |
905 | 895 | ||
@@ -936,8 +926,7 @@ static int ocfs2_query_inode_wipe(struct inode *inode, | |||
936 | status = ocfs2_try_open_lock(inode, 1); | 926 | status = ocfs2_try_open_lock(inode, 1); |
937 | if (status == -EAGAIN) { | 927 | if (status == -EAGAIN) { |
938 | status = 0; | 928 | status = 0; |
939 | mlog(0, "Skipping delete of %llu because it is in use on " | 929 | reason = 3; |
940 | "other nodes\n", (unsigned long long)oi->ip_blkno); | ||
941 | goto bail; | 930 | goto bail; |
942 | } | 931 | } |
943 | if (status < 0) { | 932 | if (status < 0) { |
@@ -946,11 +935,10 @@ static int ocfs2_query_inode_wipe(struct inode *inode, | |||
946 | } | 935 | } |
947 | 936 | ||
948 | *wipe = 1; | 937 | *wipe = 1; |
949 | mlog(0, "Inode %llu is ok to wipe from orphan dir %u\n", | 938 | trace_ocfs2_query_inode_wipe_succ(le16_to_cpu(di->i_orphaned_slot)); |
950 | (unsigned long long)oi->ip_blkno, | ||
951 | le16_to_cpu(di->i_orphaned_slot)); | ||
952 | 939 | ||
953 | bail: | 940 | bail: |
941 | trace_ocfs2_query_inode_wipe_end(status, reason); | ||
954 | return status; | 942 | return status; |
955 | } | 943 | } |
956 | 944 | ||
@@ -960,8 +948,8 @@ bail: | |||
960 | static void ocfs2_cleanup_delete_inode(struct inode *inode, | 948 | static void ocfs2_cleanup_delete_inode(struct inode *inode, |
961 | int sync_data) | 949 | int sync_data) |
962 | { | 950 | { |
963 | mlog(0, "Cleanup inode %llu, sync = %d\n", | 951 | trace_ocfs2_cleanup_delete_inode( |
964 | (unsigned long long)OCFS2_I(inode)->ip_blkno, sync_data); | 952 | (unsigned long long)OCFS2_I(inode)->ip_blkno, sync_data); |
965 | if (sync_data) | 953 | if (sync_data) |
966 | write_inode_now(inode, 1); | 954 | write_inode_now(inode, 1); |
967 | truncate_inode_pages(&inode->i_data, 0); | 955 | truncate_inode_pages(&inode->i_data, 0); |
@@ -973,15 +961,15 @@ static void ocfs2_delete_inode(struct inode *inode) | |||
973 | sigset_t oldset; | 961 | sigset_t oldset; |
974 | struct buffer_head *di_bh = NULL; | 962 | struct buffer_head *di_bh = NULL; |
975 | 963 | ||
976 | mlog(0, "(inode->i_ino = %lu)\n", inode->i_ino); | 964 | trace_ocfs2_delete_inode(inode->i_ino, |
965 | (unsigned long long)OCFS2_I(inode)->ip_blkno, | ||
966 | is_bad_inode(inode)); | ||
977 | 967 | ||
978 | /* When we fail in read_inode() we mark inode as bad. The second test | 968 | /* When we fail in read_inode() we mark inode as bad. The second test |
979 | * catches the case when inode allocation fails before allocating | 969 | * catches the case when inode allocation fails before allocating |
980 | * a block for inode. */ | 970 | * a block for inode. */ |
981 | if (is_bad_inode(inode) || !OCFS2_I(inode)->ip_blkno) { | 971 | if (is_bad_inode(inode) || !OCFS2_I(inode)->ip_blkno) |
982 | mlog(0, "Skipping delete of bad inode\n"); | ||
983 | goto bail; | 972 | goto bail; |
984 | } | ||
985 | 973 | ||
986 | dquot_initialize(inode); | 974 | dquot_initialize(inode); |
987 | 975 | ||
@@ -1082,8 +1070,8 @@ static void ocfs2_clear_inode(struct inode *inode) | |||
1082 | struct ocfs2_inode_info *oi = OCFS2_I(inode); | 1070 | struct ocfs2_inode_info *oi = OCFS2_I(inode); |
1083 | 1071 | ||
1084 | end_writeback(inode); | 1072 | end_writeback(inode); |
1085 | mlog(0, "Clearing inode: %llu, nlink = %u\n", | 1073 | trace_ocfs2_clear_inode((unsigned long long)oi->ip_blkno, |
1086 | (unsigned long long)OCFS2_I(inode)->ip_blkno, inode->i_nlink); | 1074 | inode->i_nlink); |
1087 | 1075 | ||
1088 | mlog_bug_on_msg(OCFS2_SB(inode->i_sb) == NULL, | 1076 | mlog_bug_on_msg(OCFS2_SB(inode->i_sb) == NULL, |
1089 | "Inode=%lu\n", inode->i_ino); | 1077 | "Inode=%lu\n", inode->i_ino); |
@@ -1193,8 +1181,8 @@ int ocfs2_drop_inode(struct inode *inode) | |||
1193 | struct ocfs2_inode_info *oi = OCFS2_I(inode); | 1181 | struct ocfs2_inode_info *oi = OCFS2_I(inode); |
1194 | int res; | 1182 | int res; |
1195 | 1183 | ||
1196 | mlog(0, "Drop inode %llu, nlink = %u, ip_flags = 0x%x\n", | 1184 | trace_ocfs2_drop_inode((unsigned long long)oi->ip_blkno, |
1197 | (unsigned long long)oi->ip_blkno, inode->i_nlink, oi->ip_flags); | 1185 | inode->i_nlink, oi->ip_flags); |
1198 | 1186 | ||
1199 | if (oi->ip_flags & OCFS2_INODE_MAYBE_ORPHANED) | 1187 | if (oi->ip_flags & OCFS2_INODE_MAYBE_ORPHANED) |
1200 | res = 1; | 1188 | res = 1; |
@@ -1212,11 +1200,11 @@ int ocfs2_inode_revalidate(struct dentry *dentry) | |||
1212 | struct inode *inode = dentry->d_inode; | 1200 | struct inode *inode = dentry->d_inode; |
1213 | int status = 0; | 1201 | int status = 0; |
1214 | 1202 | ||
1215 | mlog(0, "(inode = 0x%p, ino = %llu)\n", inode, | 1203 | trace_ocfs2_inode_revalidate(inode, |
1216 | inode ? (unsigned long long)OCFS2_I(inode)->ip_blkno : 0ULL); | 1204 | inode ? (unsigned long long)OCFS2_I(inode)->ip_blkno : 0ULL, |
1205 | inode ? (unsigned long long)OCFS2_I(inode)->ip_flags : 0); | ||
1217 | 1206 | ||
1218 | if (!inode) { | 1207 | if (!inode) { |
1219 | mlog(0, "eep, no inode!\n"); | ||
1220 | status = -ENOENT; | 1208 | status = -ENOENT; |
1221 | goto bail; | 1209 | goto bail; |
1222 | } | 1210 | } |
@@ -1224,7 +1212,6 @@ int ocfs2_inode_revalidate(struct dentry *dentry) | |||
1224 | spin_lock(&OCFS2_I(inode)->ip_lock); | 1212 | spin_lock(&OCFS2_I(inode)->ip_lock); |
1225 | if (OCFS2_I(inode)->ip_flags & OCFS2_INODE_DELETED) { | 1213 | if (OCFS2_I(inode)->ip_flags & OCFS2_INODE_DELETED) { |
1226 | spin_unlock(&OCFS2_I(inode)->ip_lock); | 1214 | spin_unlock(&OCFS2_I(inode)->ip_lock); |
1227 | mlog(0, "inode deleted!\n"); | ||
1228 | status = -ENOENT; | 1215 | status = -ENOENT; |
1229 | goto bail; | 1216 | goto bail; |
1230 | } | 1217 | } |
@@ -1255,8 +1242,7 @@ int ocfs2_mark_inode_dirty(handle_t *handle, | |||
1255 | int status; | 1242 | int status; |
1256 | struct ocfs2_dinode *fe = (struct ocfs2_dinode *) bh->b_data; | 1243 | struct ocfs2_dinode *fe = (struct ocfs2_dinode *) bh->b_data; |
1257 | 1244 | ||
1258 | mlog(0, "(inode %llu)\n", | 1245 | trace_ocfs2_mark_inode_dirty((unsigned long long)OCFS2_I(inode)->ip_blkno); |
1259 | (unsigned long long)OCFS2_I(inode)->ip_blkno); | ||
1260 | 1246 | ||
1261 | status = ocfs2_journal_access_di(handle, INODE_CACHE(inode), bh, | 1247 | status = ocfs2_journal_access_di(handle, INODE_CACHE(inode), bh, |
1262 | OCFS2_JOURNAL_ACCESS_WRITE); | 1248 | OCFS2_JOURNAL_ACCESS_WRITE); |
@@ -1328,8 +1314,7 @@ int ocfs2_validate_inode_block(struct super_block *sb, | |||
1328 | int rc; | 1314 | int rc; |
1329 | struct ocfs2_dinode *di = (struct ocfs2_dinode *)bh->b_data; | 1315 | struct ocfs2_dinode *di = (struct ocfs2_dinode *)bh->b_data; |
1330 | 1316 | ||
1331 | mlog(0, "Validating dinode %llu\n", | 1317 | trace_ocfs2_validate_inode_block((unsigned long long)bh->b_blocknr); |
1332 | (unsigned long long)bh->b_blocknr); | ||
1333 | 1318 | ||
1334 | BUG_ON(!buffer_uptodate(bh)); | 1319 | BUG_ON(!buffer_uptodate(bh)); |
1335 | 1320 | ||
diff --git a/fs/ocfs2/ocfs2_trace.h b/fs/ocfs2/ocfs2_trace.h index 16013b5588c6..052057a01ea8 100644 --- a/fs/ocfs2/ocfs2_trace.h +++ b/fs/ocfs2/ocfs2_trace.h | |||
@@ -114,6 +114,25 @@ DEFINE_EVENT(ocfs2__ull_uint, name, \ | |||
114 | TP_PROTO(unsigned long long val1, unsigned int val2), \ | 114 | TP_PROTO(unsigned long long val1, unsigned int val2), \ |
115 | TP_ARGS(val1, val2)) | 115 | TP_ARGS(val1, val2)) |
116 | 116 | ||
117 | DECLARE_EVENT_CLASS(ocfs2__ull_int, | ||
118 | TP_PROTO(unsigned long long value1, int value2), | ||
119 | TP_ARGS(value1, value2), | ||
120 | TP_STRUCT__entry( | ||
121 | __field(unsigned long long, value1) | ||
122 | __field(int, value2) | ||
123 | ), | ||
124 | TP_fast_assign( | ||
125 | __entry->value1 = value1; | ||
126 | __entry->value2 = value2; | ||
127 | ), | ||
128 | TP_printk("%llu %d", __entry->value1, __entry->value2) | ||
129 | ); | ||
130 | |||
131 | #define DEFINE_OCFS2_ULL_INT_EVENT(name) \ | ||
132 | DEFINE_EVENT(ocfs2__ull_int, name, \ | ||
133 | TP_PROTO(unsigned long long val1, int val2), \ | ||
134 | TP_ARGS(val1, val2)) | ||
135 | |||
117 | DECLARE_EVENT_CLASS(ocfs2__ull_ull, | 136 | DECLARE_EVENT_CLASS(ocfs2__ull_ull, |
118 | TP_PROTO(unsigned long long value1, unsigned long long value2), | 137 | TP_PROTO(unsigned long long value1, unsigned long long value2), |
119 | TP_ARGS(value1, value2), | 138 | TP_ARGS(value1, value2), |
@@ -1354,6 +1373,123 @@ DEFINE_OCFS2_INT_EVENT(generic_file_aio_read_ret); | |||
1354 | 1373 | ||
1355 | /* End of trace events for fs/ocfs2/file.c. */ | 1374 | /* End of trace events for fs/ocfs2/file.c. */ |
1356 | 1375 | ||
1376 | /* Trace events for fs/ocfs2/inode.c. */ | ||
1377 | |||
1378 | TRACE_EVENT(ocfs2_iget_begin, | ||
1379 | TP_PROTO(unsigned long long ino, unsigned int flags, int sysfile_type), | ||
1380 | TP_ARGS(ino, flags, sysfile_type), | ||
1381 | TP_STRUCT__entry( | ||
1382 | __field(unsigned long long, ino) | ||
1383 | __field(unsigned int, flags) | ||
1384 | __field(int, sysfile_type) | ||
1385 | ), | ||
1386 | TP_fast_assign( | ||
1387 | __entry->ino = ino; | ||
1388 | __entry->flags = flags; | ||
1389 | __entry->sysfile_type = sysfile_type; | ||
1390 | ), | ||
1391 | TP_printk("%llu %u %d", __entry->ino, | ||
1392 | __entry->flags, __entry->sysfile_type) | ||
1393 | ); | ||
1394 | |||
1395 | DEFINE_OCFS2_ULL_EVENT(ocfs2_iget5_locked); | ||
1396 | |||
1397 | TRACE_EVENT(ocfs2_iget_end, | ||
1398 | TP_PROTO(void *inode, unsigned long long ino), | ||
1399 | TP_ARGS(inode, ino), | ||
1400 | TP_STRUCT__entry( | ||
1401 | __field(void *, inode) | ||
1402 | __field(unsigned long long, ino) | ||
1403 | ), | ||
1404 | TP_fast_assign( | ||
1405 | __entry->inode = inode; | ||
1406 | __entry->ino = ino; | ||
1407 | ), | ||
1408 | TP_printk("%p %llu", __entry->inode, __entry->ino) | ||
1409 | ); | ||
1410 | |||
1411 | TRACE_EVENT(ocfs2_find_actor, | ||
1412 | TP_PROTO(void *inode, unsigned long long ino, | ||
1413 | void *args, unsigned long long fi_blkno), | ||
1414 | TP_ARGS(inode, ino, args, fi_blkno), | ||
1415 | TP_STRUCT__entry( | ||
1416 | __field(void *, inode) | ||
1417 | __field(unsigned long long, ino) | ||
1418 | __field(void *, args) | ||
1419 | __field(unsigned long long, fi_blkno) | ||
1420 | ), | ||
1421 | TP_fast_assign( | ||
1422 | __entry->inode = inode; | ||
1423 | __entry->ino = ino; | ||
1424 | __entry->args = args; | ||
1425 | __entry->fi_blkno = fi_blkno; | ||
1426 | ), | ||
1427 | TP_printk("%p %llu %p %llu", __entry->inode, __entry->ino, | ||
1428 | __entry->args, __entry->fi_blkno) | ||
1429 | ); | ||
1430 | |||
1431 | DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_populate_inode); | ||
1432 | |||
1433 | DEFINE_OCFS2_ULL_INT_EVENT(ocfs2_read_locked_inode); | ||
1434 | |||
1435 | DEFINE_OCFS2_INT_INT_EVENT(ocfs2_check_orphan_recovery_state); | ||
1436 | |||
1437 | DEFINE_OCFS2_ULL_EVENT(ocfs2_validate_inode_block); | ||
1438 | |||
1439 | TRACE_EVENT(ocfs2_inode_is_valid_to_delete, | ||
1440 | TP_PROTO(void *task, void *dc_task, unsigned long long ino, | ||
1441 | unsigned int flags), | ||
1442 | TP_ARGS(task, dc_task, ino, flags), | ||
1443 | TP_STRUCT__entry( | ||
1444 | __field(void *, task) | ||
1445 | __field(void *, dc_task) | ||
1446 | __field(unsigned long long, ino) | ||
1447 | __field(unsigned int, flags) | ||
1448 | ), | ||
1449 | TP_fast_assign( | ||
1450 | __entry->task = task; | ||
1451 | __entry->dc_task = dc_task; | ||
1452 | __entry->ino = ino; | ||
1453 | __entry->flags = flags; | ||
1454 | ), | ||
1455 | TP_printk("%p %p %llu %u", __entry->task, __entry->dc_task, | ||
1456 | __entry->ino, __entry->flags) | ||
1457 | ); | ||
1458 | |||
1459 | DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_query_inode_wipe_begin); | ||
1460 | |||
1461 | DEFINE_OCFS2_UINT_EVENT(ocfs2_query_inode_wipe_succ); | ||
1462 | |||
1463 | DEFINE_OCFS2_INT_INT_EVENT(ocfs2_query_inode_wipe_end); | ||
1464 | |||
1465 | DEFINE_OCFS2_ULL_INT_EVENT(ocfs2_cleanup_delete_inode); | ||
1466 | |||
1467 | DEFINE_OCFS2_ULL_ULL_UINT_EVENT(ocfs2_delete_inode); | ||
1468 | |||
1469 | DEFINE_OCFS2_ULL_UINT_EVENT(ocfs2_clear_inode); | ||
1470 | |||
1471 | DEFINE_OCFS2_ULL_UINT_UINT_EVENT(ocfs2_drop_inode); | ||
1472 | |||
1473 | TRACE_EVENT(ocfs2_inode_revalidate, | ||
1474 | TP_PROTO(void *inode, unsigned long long ino, | ||
1475 | unsigned int flags), | ||
1476 | TP_ARGS(inode, ino, flags), | ||
1477 | TP_STRUCT__entry( | ||
1478 | __field(void *, inode) | ||
1479 | __field(unsigned long long, ino) | ||
1480 | __field(unsigned int, flags) | ||
1481 | ), | ||
1482 | TP_fast_assign( | ||
1483 | __entry->inode = inode; | ||
1484 | __entry->ino = ino; | ||
1485 | __entry->flags = flags; | ||
1486 | ), | ||
1487 | TP_printk("%p %llu %u", __entry->inode, __entry->ino, __entry->flags) | ||
1488 | ); | ||
1489 | |||
1490 | DEFINE_OCFS2_ULL_EVENT(ocfs2_mark_inode_dirty); | ||
1491 | |||
1492 | /* End of trace events for fs/ocfs2/inode.c. */ | ||
1357 | #endif /* _TRACE_OCFS2_H */ | 1493 | #endif /* _TRACE_OCFS2_H */ |
1358 | 1494 | ||
1359 | /* This part must be outside protection */ | 1495 | /* This part must be outside protection */ |