aboutsummaryrefslogtreecommitdiffstats
path: root/fs/ocfs2
diff options
context:
space:
mode:
Diffstat (limited to 'fs/ocfs2')
-rw-r--r--fs/ocfs2/alloc.c88
-rw-r--r--fs/ocfs2/aops.c20
-rw-r--r--fs/ocfs2/buffer_head_io.c11
-rw-r--r--fs/ocfs2/cluster/heartbeat.c38
-rw-r--r--fs/ocfs2/cluster/masklog.h10
-rw-r--r--fs/ocfs2/dcache.c9
-rw-r--r--fs/ocfs2/dir.c42
-rw-r--r--fs/ocfs2/dlm/dlmast.c22
-rw-r--r--fs/ocfs2/dlm/dlmcommon.h21
-rw-r--r--fs/ocfs2/dlm/dlmconvert.c11
-rw-r--r--fs/ocfs2/dlm/dlmdebug.c18
-rw-r--r--fs/ocfs2/dlm/dlmfs.c3
-rw-r--r--fs/ocfs2/dlm/dlmlock.c14
-rw-r--r--fs/ocfs2/dlm/dlmmaster.c227
-rw-r--r--fs/ocfs2/dlm/dlmrecovery.c50
-rw-r--r--fs/ocfs2/dlm/dlmunlock.c11
-rw-r--r--fs/ocfs2/dlmglue.c103
-rw-r--r--fs/ocfs2/export.c24
-rw-r--r--fs/ocfs2/extent_map.c34
-rw-r--r--fs/ocfs2/file.c46
-rw-r--r--fs/ocfs2/file.h4
-rw-r--r--fs/ocfs2/inode.c116
-rw-r--r--fs/ocfs2/journal.c37
-rw-r--r--fs/ocfs2/localalloc.c17
-rw-r--r--fs/ocfs2/namei.c84
-rw-r--r--fs/ocfs2/ocfs2.h12
-rw-r--r--fs/ocfs2/suballoc.c72
-rw-r--r--fs/ocfs2/super.c24
-rw-r--r--fs/ocfs2/super.h8
-rw-r--r--fs/ocfs2/uptodate.c40
-rw-r--r--fs/ocfs2/vote.c63
31 files changed, 772 insertions, 507 deletions
diff --git a/fs/ocfs2/alloc.c b/fs/ocfs2/alloc.c
index 6b9812db3779..edaab05a93e0 100644
--- a/fs/ocfs2/alloc.c
+++ b/fs/ocfs2/alloc.c
@@ -566,9 +566,8 @@ static int ocfs2_do_insert_extent(struct ocfs2_super *osb,
566 next_free = le16_to_cpu(el->l_next_free_rec); 566 next_free = le16_to_cpu(el->l_next_free_rec);
567 if (next_free == 0) { 567 if (next_free == 0) {
568 ocfs2_error(inode->i_sb, 568 ocfs2_error(inode->i_sb,
569 "Dinode %"MLFu64" has a bad " 569 "Dinode %llu has a bad extent list",
570 "extent list", 570 (unsigned long long)OCFS2_I(inode)->ip_blkno);
571 OCFS2_I(inode)->ip_blkno);
572 status = -EIO; 571 status = -EIO;
573 goto bail; 572 goto bail;
574 } 573 }
@@ -611,9 +610,8 @@ static int ocfs2_do_insert_extent(struct ocfs2_super *osb,
611 next_free = le16_to_cpu(el->l_next_free_rec); 610 next_free = le16_to_cpu(el->l_next_free_rec);
612 if (next_free == 0) { 611 if (next_free == 0) {
613 ocfs2_error(inode->i_sb, 612 ocfs2_error(inode->i_sb,
614 "Dinode %"MLFu64" has a bad " 613 "Dinode %llu has a bad extent list",
615 "extent list", 614 (unsigned long long)OCFS2_I(inode)->ip_blkno);
616 OCFS2_I(inode)->ip_blkno);
617 status = -EIO; 615 status = -EIO;
618 goto bail; 616 goto bail;
619 } 617 }
@@ -652,8 +650,9 @@ static int ocfs2_do_insert_extent(struct ocfs2_super *osb,
652 /* having an empty extent at eof is legal. */ 650 /* having an empty extent at eof is legal. */
653 if (el->l_recs[i].e_cpos != fe->i_clusters) { 651 if (el->l_recs[i].e_cpos != fe->i_clusters) {
654 ocfs2_error(inode->i_sb, 652 ocfs2_error(inode->i_sb,
655 "Dinode %"MLFu64" trailing extent is bad: " 653 "Dinode %llu trailing extent is bad: "
656 "cpos (%u) != number of clusters (%u)", 654 "cpos (%u) != number of clusters (%u)",
655 (unsigned long long)OCFS2_I(inode)->ip_blkno,
657 le32_to_cpu(el->l_recs[i].e_cpos), 656 le32_to_cpu(el->l_recs[i].e_cpos),
658 le32_to_cpu(fe->i_clusters)); 657 le32_to_cpu(fe->i_clusters));
659 status = -EIO; 658 status = -EIO;
@@ -747,19 +746,19 @@ static int ocfs2_find_branch_target(struct ocfs2_super *osb,
747 746
748 while(le16_to_cpu(el->l_tree_depth) > 1) { 747 while(le16_to_cpu(el->l_tree_depth) > 1) {
749 if (le16_to_cpu(el->l_next_free_rec) == 0) { 748 if (le16_to_cpu(el->l_next_free_rec) == 0) {
750 ocfs2_error(inode->i_sb, "Dinode %"MLFu64" has empty " 749 ocfs2_error(inode->i_sb, "Dinode %llu has empty "
751 "extent list (next_free_rec == 0)", 750 "extent list (next_free_rec == 0)",
752 OCFS2_I(inode)->ip_blkno); 751 (unsigned long long)OCFS2_I(inode)->ip_blkno);
753 status = -EIO; 752 status = -EIO;
754 goto bail; 753 goto bail;
755 } 754 }
756 i = le16_to_cpu(el->l_next_free_rec) - 1; 755 i = le16_to_cpu(el->l_next_free_rec) - 1;
757 blkno = le64_to_cpu(el->l_recs[i].e_blkno); 756 blkno = le64_to_cpu(el->l_recs[i].e_blkno);
758 if (!blkno) { 757 if (!blkno) {
759 ocfs2_error(inode->i_sb, "Dinode %"MLFu64" has extent " 758 ocfs2_error(inode->i_sb, "Dinode %llu has extent "
760 "list where extent # %d has no physical " 759 "list where extent # %d has no physical "
761 "block start", 760 "block start",
762 OCFS2_I(inode)->ip_blkno, i); 761 (unsigned long long)OCFS2_I(inode)->ip_blkno, i);
763 status = -EIO; 762 status = -EIO;
764 goto bail; 763 goto bail;
765 } 764 }
@@ -826,9 +825,9 @@ int ocfs2_insert_extent(struct ocfs2_super *osb,
826 825
827 mlog_entry_void(); 826 mlog_entry_void();
828 827
829 mlog(0, "add %u clusters starting at block %"MLFu64" to " 828 mlog(0, "add %u clusters starting at block %llu to inode %llu\n",
830 "inode %"MLFu64"\n", 829 new_clusters, (unsigned long long)start_blk,
831 new_clusters, start_blk, OCFS2_I(inode)->ip_blkno); 830 (unsigned long long)OCFS2_I(inode)->ip_blkno);
832 831
833 fe = (struct ocfs2_dinode *) fe_bh->b_data; 832 fe = (struct ocfs2_dinode *) fe_bh->b_data;
834 el = &fe->id2.i_list; 833 el = &fe->id2.i_list;
@@ -963,8 +962,8 @@ static int ocfs2_truncate_log_append(struct ocfs2_super *osb,
963 struct ocfs2_dinode *di; 962 struct ocfs2_dinode *di;
964 struct ocfs2_truncate_log *tl; 963 struct ocfs2_truncate_log *tl;
965 964
966 mlog_entry("start_blk = %"MLFu64", num_clusters = %u\n", start_blk, 965 mlog_entry("start_blk = %llu, num_clusters = %u\n",
967 num_clusters); 966 (unsigned long long)start_blk, num_clusters);
968 967
969 BUG_ON(mutex_trylock(&tl_inode->i_mutex)); 968 BUG_ON(mutex_trylock(&tl_inode->i_mutex));
970 969
@@ -981,8 +980,9 @@ static int ocfs2_truncate_log_append(struct ocfs2_super *osb,
981 tl_count = le16_to_cpu(tl->tl_count); 980 tl_count = le16_to_cpu(tl->tl_count);
982 mlog_bug_on_msg(tl_count > ocfs2_truncate_recs_per_inode(osb->sb) || 981 mlog_bug_on_msg(tl_count > ocfs2_truncate_recs_per_inode(osb->sb) ||
983 tl_count == 0, 982 tl_count == 0,
984 "Truncate record count on #%"MLFu64" invalid (" 983 "Truncate record count on #%llu invalid "
985 "wanted %u, actual %u\n", OCFS2_I(tl_inode)->ip_blkno, 984 "wanted %u, actual %u\n",
985 (unsigned long long)OCFS2_I(tl_inode)->ip_blkno,
986 ocfs2_truncate_recs_per_inode(osb->sb), 986 ocfs2_truncate_recs_per_inode(osb->sb),
987 le16_to_cpu(tl->tl_count)); 987 le16_to_cpu(tl->tl_count));
988 988
@@ -1002,8 +1002,8 @@ static int ocfs2_truncate_log_append(struct ocfs2_super *osb,
1002 } 1002 }
1003 1003
1004 mlog(0, "Log truncate of %u clusters starting at cluster %u to " 1004 mlog(0, "Log truncate of %u clusters starting at cluster %u to "
1005 "%"MLFu64" (index = %d)\n", num_clusters, start_cluster, 1005 "%llu (index = %d)\n", num_clusters, start_cluster,
1006 OCFS2_I(tl_inode)->ip_blkno, index); 1006 (unsigned long long)OCFS2_I(tl_inode)->ip_blkno, index);
1007 1007
1008 if (ocfs2_truncate_log_can_coalesce(tl, start_cluster)) { 1008 if (ocfs2_truncate_log_can_coalesce(tl, start_cluster)) {
1009 /* 1009 /*
@@ -1134,8 +1134,8 @@ static int __ocfs2_flush_truncate_log(struct ocfs2_super *osb)
1134 } 1134 }
1135 1135
1136 num_to_flush = le16_to_cpu(tl->tl_used); 1136 num_to_flush = le16_to_cpu(tl->tl_used);
1137 mlog(0, "Flush %u records from truncate log #%"MLFu64"\n", 1137 mlog(0, "Flush %u records from truncate log #%llu\n",
1138 num_to_flush, OCFS2_I(tl_inode)->ip_blkno); 1138 num_to_flush, (unsigned long long)OCFS2_I(tl_inode)->ip_blkno);
1139 if (!num_to_flush) { 1139 if (!num_to_flush) {
1140 status = 0; 1140 status = 0;
1141 goto bail; 1141 goto bail;
@@ -1360,8 +1360,8 @@ int ocfs2_complete_truncate_log_recovery(struct ocfs2_super *osb,
1360 1360
1361 tl = &tl_copy->id2.i_dealloc; 1361 tl = &tl_copy->id2.i_dealloc;
1362 num_recs = le16_to_cpu(tl->tl_used); 1362 num_recs = le16_to_cpu(tl->tl_used);
1363 mlog(0, "cleanup %u records from %"MLFu64"\n", num_recs, 1363 mlog(0, "cleanup %u records from %llu\n", num_recs,
1364 tl_copy->i_blkno); 1364 (unsigned long long)tl_copy->i_blkno);
1365 1365
1366 mutex_lock(&tl_inode->i_mutex); 1366 mutex_lock(&tl_inode->i_mutex);
1367 for(i = 0; i < num_recs; i++) { 1367 for(i = 0; i < num_recs; i++) {
@@ -1529,7 +1529,8 @@ static int ocfs2_find_new_last_ext_blk(struct ocfs2_super *osb,
1529 1529
1530 *new_last_eb = bh; 1530 *new_last_eb = bh;
1531 get_bh(*new_last_eb); 1531 get_bh(*new_last_eb);
1532 mlog(0, "returning block %"MLFu64"\n", le64_to_cpu(eb->h_blkno)); 1532 mlog(0, "returning block %llu\n",
1533 (unsigned long long)le64_to_cpu(eb->h_blkno));
1533bail: 1534bail:
1534 if (bh) 1535 if (bh)
1535 brelse(bh); 1536 brelse(bh);
@@ -1646,8 +1647,8 @@ static int ocfs2_do_truncate(struct ocfs2_super *osb,
1646 1647
1647 /* if our tree depth > 0, update all the tree blocks below us. */ 1648 /* if our tree depth > 0, update all the tree blocks below us. */
1648 while (depth) { 1649 while (depth) {
1649 mlog(0, "traveling tree (depth = %d, next_eb = %"MLFu64")\n", 1650 mlog(0, "traveling tree (depth = %d, next_eb = %llu)\n",
1650 depth, next_eb); 1651 depth, (unsigned long long)next_eb);
1651 status = ocfs2_read_block(osb, next_eb, &eb_bh, 1652 status = ocfs2_read_block(osb, next_eb, &eb_bh,
1652 OCFS2_BH_CACHED, inode); 1653 OCFS2_BH_CACHED, inode);
1653 if (status < 0) { 1654 if (status < 0) {
@@ -1674,12 +1675,12 @@ static int ocfs2_do_truncate(struct ocfs2_super *osb,
1674 1675
1675 i = le16_to_cpu(el->l_next_free_rec) - 1; 1676 i = le16_to_cpu(el->l_next_free_rec) - 1;
1676 1677
1677 mlog(0, "extent block %"MLFu64", before: record %d: " 1678 mlog(0, "extent block %llu, before: record %d: "
1678 "(%u, %u, %"MLFu64"), next = %u\n", 1679 "(%u, %u, %llu), next = %u\n",
1679 le64_to_cpu(eb->h_blkno), i, 1680 (unsigned long long)le64_to_cpu(eb->h_blkno), i,
1680 le32_to_cpu(el->l_recs[i].e_cpos), 1681 le32_to_cpu(el->l_recs[i].e_cpos),
1681 le32_to_cpu(el->l_recs[i].e_clusters), 1682 le32_to_cpu(el->l_recs[i].e_clusters),
1682 le64_to_cpu(el->l_recs[i].e_blkno), 1683 (unsigned long long)le64_to_cpu(el->l_recs[i].e_blkno),
1683 le16_to_cpu(el->l_next_free_rec)); 1684 le16_to_cpu(el->l_next_free_rec));
1684 1685
1685 BUG_ON(le32_to_cpu(el->l_recs[i].e_clusters) < clusters_to_del); 1686 BUG_ON(le32_to_cpu(el->l_recs[i].e_clusters) < clusters_to_del);
@@ -1697,12 +1698,12 @@ static int ocfs2_do_truncate(struct ocfs2_super *osb,
1697 BUG_ON(!el->l_next_free_rec); 1698 BUG_ON(!el->l_next_free_rec);
1698 le16_add_cpu(&el->l_next_free_rec, -1); 1699 le16_add_cpu(&el->l_next_free_rec, -1);
1699 } 1700 }
1700 mlog(0, "extent block %"MLFu64", after: record %d: " 1701 mlog(0, "extent block %llu, after: record %d: "
1701 "(%u, %u, %"MLFu64"), next = %u\n", 1702 "(%u, %u, %llu), next = %u\n",
1702 le64_to_cpu(eb->h_blkno), i, 1703 (unsigned long long)le64_to_cpu(eb->h_blkno), i,
1703 le32_to_cpu(el->l_recs[i].e_cpos), 1704 le32_to_cpu(el->l_recs[i].e_cpos),
1704 le32_to_cpu(el->l_recs[i].e_clusters), 1705 le32_to_cpu(el->l_recs[i].e_clusters),
1705 le64_to_cpu(el->l_recs[i].e_blkno), 1706 (unsigned long long)le64_to_cpu(el->l_recs[i].e_blkno),
1706 le16_to_cpu(el->l_next_free_rec)); 1707 le16_to_cpu(el->l_next_free_rec));
1707 1708
1708 status = ocfs2_journal_dirty(handle, eb_bh); 1709 status = ocfs2_journal_dirty(handle, eb_bh);
@@ -1792,10 +1793,10 @@ int ocfs2_commit_truncate(struct ocfs2_super *osb,
1792 last_eb = le64_to_cpu(fe->i_last_eb_blk); 1793 last_eb = le64_to_cpu(fe->i_last_eb_blk);
1793start: 1794start:
1794 mlog(0, "ocfs2_commit_truncate: fe->i_clusters = %u, " 1795 mlog(0, "ocfs2_commit_truncate: fe->i_clusters = %u, "
1795 "last_eb = %"MLFu64", fe->i_last_eb_blk = %"MLFu64", " 1796 "last_eb = %llu, fe->i_last_eb_blk = %llu, "
1796 "fe->id2.i_list.l_tree_depth = %u last_eb_bh = %p\n", 1797 "fe->id2.i_list.l_tree_depth = %u last_eb_bh = %p\n",
1797 le32_to_cpu(fe->i_clusters), last_eb, 1798 le32_to_cpu(fe->i_clusters), (unsigned long long)last_eb,
1798 le64_to_cpu(fe->i_last_eb_blk), 1799 (unsigned long long)le64_to_cpu(fe->i_last_eb_blk),
1799 le16_to_cpu(fe->id2.i_list.l_tree_depth), last_eb_bh); 1800 le16_to_cpu(fe->id2.i_list.l_tree_depth), last_eb_bh);
1800 1801
1801 if (last_eb != le64_to_cpu(fe->i_last_eb_blk)) { 1802 if (last_eb != le64_to_cpu(fe->i_last_eb_blk)) {
@@ -1934,16 +1935,17 @@ int ocfs2_prepare_truncate(struct ocfs2_super *osb,
1934 fe = (struct ocfs2_dinode *) fe_bh->b_data; 1935 fe = (struct ocfs2_dinode *) fe_bh->b_data;
1935 1936
1936 mlog(0, "fe->i_clusters = %u, new_i_clusters = %u, fe->i_size =" 1937 mlog(0, "fe->i_clusters = %u, new_i_clusters = %u, fe->i_size ="
1937 "%"MLFu64"\n", fe->i_clusters, new_i_clusters, fe->i_size); 1938 "%llu\n", fe->i_clusters, new_i_clusters,
1939 (unsigned long long)fe->i_size);
1938 1940
1939 if (le32_to_cpu(fe->i_clusters) <= new_i_clusters) { 1941 if (le32_to_cpu(fe->i_clusters) <= new_i_clusters) {
1940 ocfs2_error(inode->i_sb, "Dinode %"MLFu64" has cluster count " 1942 ocfs2_error(inode->i_sb, "Dinode %llu has cluster count "
1941 "%u and size %"MLFu64" whereas struct inode has " 1943 "%u and size %llu whereas struct inode has "
1942 "cluster count %u and size %llu which caused an " 1944 "cluster count %u and size %llu which caused an "
1943 "invalid truncate to %u clusters.", 1945 "invalid truncate to %u clusters.",
1944 le64_to_cpu(fe->i_blkno), 1946 (unsigned long long)le64_to_cpu(fe->i_blkno),
1945 le32_to_cpu(fe->i_clusters), 1947 le32_to_cpu(fe->i_clusters),
1946 le64_to_cpu(fe->i_size), 1948 (unsigned long long)le64_to_cpu(fe->i_size),
1947 OCFS2_I(inode)->ip_clusters, i_size_read(inode), 1949 OCFS2_I(inode)->ip_clusters, i_size_read(inode),
1948 new_i_clusters); 1950 new_i_clusters);
1949 mlog_meta_lvb(ML_ERROR, &OCFS2_I(inode)->ip_meta_lockres); 1951 mlog_meta_lvb(ML_ERROR, &OCFS2_I(inode)->ip_meta_lockres);
diff --git a/fs/ocfs2/aops.c b/fs/ocfs2/aops.c
index 8f4467a930a5..0d858d0b25be 100644
--- a/fs/ocfs2/aops.c
+++ b/fs/ocfs2/aops.c
@@ -74,8 +74,8 @@ static int ocfs2_symlink_get_block(struct inode *inode, sector_t iblock,
74 fe = (struct ocfs2_dinode *) bh->b_data; 74 fe = (struct ocfs2_dinode *) bh->b_data;
75 75
76 if (!OCFS2_IS_VALID_DINODE(fe)) { 76 if (!OCFS2_IS_VALID_DINODE(fe)) {
77 mlog(ML_ERROR, "Invalid dinode #%"MLFu64": signature = %.*s\n", 77 mlog(ML_ERROR, "Invalid dinode #%llu: signature = %.*s\n",
78 fe->i_blkno, 7, fe->i_signature); 78 (unsigned long long)fe->i_blkno, 7, fe->i_signature);
79 goto bail; 79 goto bail;
80 } 80 }
81 81
@@ -162,8 +162,8 @@ static int ocfs2_get_block(struct inode *inode, sector_t iblock,
162 NULL); 162 NULL);
163 if (err) { 163 if (err) {
164 mlog(ML_ERROR, "Error %d from get_blocks(0x%p, %llu, 1, " 164 mlog(ML_ERROR, "Error %d from get_blocks(0x%p, %llu, 1, "
165 "%"MLFu64", NULL)\n", err, inode, 165 "%llu, NULL)\n", err, inode, (unsigned long long)iblock,
166 (unsigned long long)iblock, p_blkno); 166 (unsigned long long)p_blkno);
167 goto bail; 167 goto bail;
168 } 168 }
169 169
@@ -171,13 +171,15 @@ static int ocfs2_get_block(struct inode *inode, sector_t iblock,
171 171
172 if (bh_result->b_blocknr == 0) { 172 if (bh_result->b_blocknr == 0) {
173 err = -EIO; 173 err = -EIO;
174 mlog(ML_ERROR, "iblock = %llu p_blkno = %"MLFu64" " 174 mlog(ML_ERROR, "iblock = %llu p_blkno = %llu blkno=(%llu)\n",
175 "blkno=(%"MLFu64")\n", (unsigned long long)iblock, 175 (unsigned long long)iblock,
176 p_blkno, OCFS2_I(inode)->ip_blkno); 176 (unsigned long long)p_blkno,
177 (unsigned long long)OCFS2_I(inode)->ip_blkno);
177 } 178 }
178 179
179 past_eof = ocfs2_blocks_for_bytes(inode->i_sb, i_size_read(inode)); 180 past_eof = ocfs2_blocks_for_bytes(inode->i_sb, i_size_read(inode));
180 mlog(0, "Inode %lu, past_eof = %"MLFu64"\n", inode->i_ino, past_eof); 181 mlog(0, "Inode %lu, past_eof = %llu\n", inode->i_ino,
182 (unsigned long long)past_eof);
181 183
182 if (create && (iblock >= past_eof)) 184 if (create && (iblock >= past_eof))
183 set_buffer_new(bh_result); 185 set_buffer_new(bh_result);
@@ -538,7 +540,6 @@ bail:
538 * fs_count, map_bh, dio->rw == WRITE); 540 * fs_count, map_bh, dio->rw == WRITE);
539 */ 541 */
540static int ocfs2_direct_IO_get_blocks(struct inode *inode, sector_t iblock, 542static int ocfs2_direct_IO_get_blocks(struct inode *inode, sector_t iblock,
541 unsigned long max_blocks,
542 struct buffer_head *bh_result, int create) 543 struct buffer_head *bh_result, int create)
543{ 544{
544 int ret; 545 int ret;
@@ -546,6 +547,7 @@ static int ocfs2_direct_IO_get_blocks(struct inode *inode, sector_t iblock,
546 u64 p_blkno; 547 u64 p_blkno;
547 int contig_blocks; 548 int contig_blocks;
548 unsigned char blocksize_bits; 549 unsigned char blocksize_bits;
550 unsigned long max_blocks = bh_result->b_size >> inode->i_blkbits;
549 551
550 if (!inode || !bh_result) { 552 if (!inode || !bh_result) {
551 mlog(ML_ERROR, "inode or bh_result is null\n"); 553 mlog(ML_ERROR, "inode or bh_result is null\n");
diff --git a/fs/ocfs2/buffer_head_io.c b/fs/ocfs2/buffer_head_io.c
index bae3d7548bea..9a24adf9be6e 100644
--- a/fs/ocfs2/buffer_head_io.c
+++ b/fs/ocfs2/buffer_head_io.c
@@ -97,8 +97,8 @@ int ocfs2_read_blocks(struct ocfs2_super *osb, u64 block, int nr,
97 int i, ignore_cache = 0; 97 int i, ignore_cache = 0;
98 struct buffer_head *bh; 98 struct buffer_head *bh;
99 99
100 mlog_entry("(block=(%"MLFu64"), nr=(%d), flags=%d, inode=%p)\n", 100 mlog_entry("(block=(%llu), nr=(%d), flags=%d, inode=%p)\n",
101 block, nr, flags, inode); 101 (unsigned long long)block, nr, flags, inode);
102 102
103 if (osb == NULL || osb->sb == NULL || bhs == NULL) { 103 if (osb == NULL || osb->sb == NULL || bhs == NULL) {
104 status = -EINVAL; 104 status = -EINVAL;
@@ -143,9 +143,9 @@ int ocfs2_read_blocks(struct ocfs2_super *osb, u64 block, int nr,
143 if (flags & OCFS2_BH_CACHED && 143 if (flags & OCFS2_BH_CACHED &&
144 !ocfs2_buffer_uptodate(inode, bh)) { 144 !ocfs2_buffer_uptodate(inode, bh)) {
145 mlog(ML_UPTODATE, 145 mlog(ML_UPTODATE,
146 "bh (%llu), inode %"MLFu64" not uptodate\n", 146 "bh (%llu), inode %llu not uptodate\n",
147 (unsigned long long)bh->b_blocknr, 147 (unsigned long long)bh->b_blocknr,
148 OCFS2_I(inode)->ip_blkno); 148 (unsigned long long)OCFS2_I(inode)->ip_blkno);
149 ignore_cache = 1; 149 ignore_cache = 1;
150 } 150 }
151 151
@@ -222,7 +222,8 @@ int ocfs2_read_blocks(struct ocfs2_super *osb, u64 block, int nr,
222 if (inode) 222 if (inode)
223 mutex_unlock(&OCFS2_I(inode)->ip_io_mutex); 223 mutex_unlock(&OCFS2_I(inode)->ip_io_mutex);
224 224
225 mlog(ML_BH_IO, "block=(%"MLFu64"), nr=(%d), cached=%s\n", block, nr, 225 mlog(ML_BH_IO, "block=(%llu), nr=(%d), cached=%s\n",
226 (unsigned long long)block, nr,
226 (!(flags & OCFS2_BH_CACHED) || ignore_cache) ? "no" : "yes"); 227 (!(flags & OCFS2_BH_CACHED) || ignore_cache) ? "no" : "yes");
227 228
228bail: 229bail:
diff --git a/fs/ocfs2/cluster/heartbeat.c b/fs/ocfs2/cluster/heartbeat.c
index d08971d29b63..bff0f0d06867 100644
--- a/fs/ocfs2/cluster/heartbeat.c
+++ b/fs/ocfs2/cluster/heartbeat.c
@@ -449,11 +449,11 @@ static u32 o2hb_compute_block_crc_le(struct o2hb_region *reg,
449 449
450static void o2hb_dump_slot(struct o2hb_disk_heartbeat_block *hb_block) 450static void o2hb_dump_slot(struct o2hb_disk_heartbeat_block *hb_block)
451{ 451{
452 mlog(ML_ERROR, "Dump slot information: seq = 0x%"MLFx64", node = %u, " 452 mlog(ML_ERROR, "Dump slot information: seq = 0x%llx, node = %u, "
453 "cksum = 0x%x, generation 0x%"MLFx64"\n", 453 "cksum = 0x%x, generation 0x%llx\n",
454 le64_to_cpu(hb_block->hb_seq), hb_block->hb_node, 454 (long long)le64_to_cpu(hb_block->hb_seq),
455 le32_to_cpu(hb_block->hb_cksum), 455 hb_block->hb_node, le32_to_cpu(hb_block->hb_cksum),
456 le64_to_cpu(hb_block->hb_generation)); 456 (long long)le64_to_cpu(hb_block->hb_generation));
457} 457}
458 458
459static int o2hb_verify_crc(struct o2hb_region *reg, 459static int o2hb_verify_crc(struct o2hb_region *reg,
@@ -516,8 +516,9 @@ static inline void o2hb_prepare_block(struct o2hb_region *reg,
516 hb_block->hb_cksum = cpu_to_le32(o2hb_compute_block_crc_le(reg, 516 hb_block->hb_cksum = cpu_to_le32(o2hb_compute_block_crc_le(reg,
517 hb_block)); 517 hb_block));
518 518
519 mlog(ML_HB_BIO, "our node generation = 0x%"MLFx64", cksum = 0x%x\n", 519 mlog(ML_HB_BIO, "our node generation = 0x%llx, cksum = 0x%x\n",
520 cpu_to_le64(generation), le32_to_cpu(hb_block->hb_cksum)); 520 (long long)cpu_to_le64(generation),
521 le32_to_cpu(hb_block->hb_cksum));
521} 522}
522 523
523static void o2hb_fire_callbacks(struct o2hb_callback *hbcall, 524static void o2hb_fire_callbacks(struct o2hb_callback *hbcall,
@@ -686,19 +687,20 @@ static int o2hb_check_slot(struct o2hb_region *reg,
686 if (slot->ds_last_generation != le64_to_cpu(hb_block->hb_generation)) { 687 if (slot->ds_last_generation != le64_to_cpu(hb_block->hb_generation)) {
687 gen_changed = 1; 688 gen_changed = 1;
688 slot->ds_equal_samples = 0; 689 slot->ds_equal_samples = 0;
689 mlog(ML_HEARTBEAT, "Node %d changed generation (0x%"MLFx64" " 690 mlog(ML_HEARTBEAT, "Node %d changed generation (0x%llx "
690 "to 0x%"MLFx64")\n", slot->ds_node_num, 691 "to 0x%llx)\n", slot->ds_node_num,
691 slot->ds_last_generation, 692 (long long)slot->ds_last_generation,
692 le64_to_cpu(hb_block->hb_generation)); 693 (long long)le64_to_cpu(hb_block->hb_generation));
693 } 694 }
694 695
695 slot->ds_last_generation = le64_to_cpu(hb_block->hb_generation); 696 slot->ds_last_generation = le64_to_cpu(hb_block->hb_generation);
696 697
697 mlog(ML_HEARTBEAT, "Slot %d gen 0x%"MLFx64" cksum 0x%x " 698 mlog(ML_HEARTBEAT, "Slot %d gen 0x%llx cksum 0x%x "
698 "seq %"MLFu64" last %"MLFu64" changed %u equal %u\n", 699 "seq %llu last %llu changed %u equal %u\n",
699 slot->ds_node_num, slot->ds_last_generation, 700 slot->ds_node_num, (long long)slot->ds_last_generation,
700 le32_to_cpu(hb_block->hb_cksum), le64_to_cpu(hb_block->hb_seq), 701 le32_to_cpu(hb_block->hb_cksum),
701 slot->ds_last_time, slot->ds_changed_samples, 702 (unsigned long long)le64_to_cpu(hb_block->hb_seq),
703 (unsigned long long)slot->ds_last_time, slot->ds_changed_samples,
702 slot->ds_equal_samples); 704 slot->ds_equal_samples);
703 705
704 spin_lock(&o2hb_live_lock); 706 spin_lock(&o2hb_live_lock);
@@ -708,8 +710,8 @@ fire_callbacks:
708 * changes at any time during their dead time */ 710 * changes at any time during their dead time */
709 if (list_empty(&slot->ds_live_item) && 711 if (list_empty(&slot->ds_live_item) &&
710 slot->ds_changed_samples >= O2HB_LIVE_THRESHOLD) { 712 slot->ds_changed_samples >= O2HB_LIVE_THRESHOLD) {
711 mlog(ML_HEARTBEAT, "Node %d (id 0x%"MLFx64") joined my " 713 mlog(ML_HEARTBEAT, "Node %d (id 0x%llx) joined my region\n",
712 "region\n", slot->ds_node_num, slot->ds_last_generation); 714 slot->ds_node_num, (long long)slot->ds_last_generation);
713 715
714 /* first on the list generates a callback */ 716 /* first on the list generates a callback */
715 if (list_empty(&o2hb_live_slots[slot->ds_node_num])) { 717 if (list_empty(&o2hb_live_slots[slot->ds_node_num])) {
diff --git a/fs/ocfs2/cluster/masklog.h b/fs/ocfs2/cluster/masklog.h
index 2cadc3009c83..73edad782537 100644
--- a/fs/ocfs2/cluster/masklog.h
+++ b/fs/ocfs2/cluster/masklog.h
@@ -256,16 +256,6 @@ extern struct mlog_bits mlog_and_bits, mlog_not_bits;
256 } \ 256 } \
257} while (0) 257} while (0)
258 258
259#if (BITS_PER_LONG == 32) || defined(CONFIG_X86_64) || (defined(CONFIG_UML_X86) && defined(CONFIG_64BIT))
260#define MLFi64 "lld"
261#define MLFu64 "llu"
262#define MLFx64 "llx"
263#else
264#define MLFi64 "ld"
265#define MLFu64 "lu"
266#define MLFx64 "lx"
267#endif
268
269#include <linux/kobject.h> 259#include <linux/kobject.h>
270#include <linux/sysfs.h> 260#include <linux/sysfs.h>
271int mlog_sys_init(struct subsystem *o2cb_subsys); 261int mlog_sys_init(struct subsystem *o2cb_subsys);
diff --git a/fs/ocfs2/dcache.c b/fs/ocfs2/dcache.c
index bd85182e97bc..1a01380e3878 100644
--- a/fs/ocfs2/dcache.c
+++ b/fs/ocfs2/dcache.c
@@ -64,15 +64,16 @@ static int ocfs2_dentry_revalidate(struct dentry *dentry,
64 /* did we or someone else delete this inode? */ 64 /* did we or someone else delete this inode? */
65 if (OCFS2_I(inode)->ip_flags & OCFS2_INODE_DELETED) { 65 if (OCFS2_I(inode)->ip_flags & OCFS2_INODE_DELETED) {
66 spin_unlock(&OCFS2_I(inode)->ip_lock); 66 spin_unlock(&OCFS2_I(inode)->ip_lock);
67 mlog(0, "inode (%"MLFu64") deleted, returning false\n", 67 mlog(0, "inode (%llu) deleted, returning false\n",
68 OCFS2_I(inode)->ip_blkno); 68 (unsigned long long)OCFS2_I(inode)->ip_blkno);
69 goto bail; 69 goto bail;
70 } 70 }
71 spin_unlock(&OCFS2_I(inode)->ip_lock); 71 spin_unlock(&OCFS2_I(inode)->ip_lock);
72 72
73 if (!inode->i_nlink) { 73 if (!inode->i_nlink) {
74 mlog(0, "Inode %"MLFu64" orphaned, returning false " 74 mlog(0, "Inode %llu orphaned, returning false "
75 "dir = %d\n", OCFS2_I(inode)->ip_blkno, 75 "dir = %d\n",
76 (unsigned long long)OCFS2_I(inode)->ip_blkno,
76 S_ISDIR(inode->i_mode)); 77 S_ISDIR(inode->i_mode));
77 goto bail; 78 goto bail;
78 } 79 }
diff --git a/fs/ocfs2/dir.c b/fs/ocfs2/dir.c
index 57158fa75d91..ae47f450792f 100644
--- a/fs/ocfs2/dir.c
+++ b/fs/ocfs2/dir.c
@@ -83,7 +83,8 @@ int ocfs2_readdir(struct file * filp, void * dirent, filldir_t filldir)
83 struct super_block * sb = inode->i_sb; 83 struct super_block * sb = inode->i_sb;
84 int have_disk_lock = 0; 84 int have_disk_lock = 0;
85 85
86 mlog_entry("dirino=%"MLFu64"\n", OCFS2_I(inode)->ip_blkno); 86 mlog_entry("dirino=%llu\n",
87 (unsigned long long)OCFS2_I(inode)->ip_blkno);
87 88
88 stored = 0; 89 stored = 0;
89 bh = NULL; 90 bh = NULL;
@@ -104,9 +105,9 @@ int ocfs2_readdir(struct file * filp, void * dirent, filldir_t filldir)
104 blk = (filp->f_pos) >> sb->s_blocksize_bits; 105 blk = (filp->f_pos) >> sb->s_blocksize_bits;
105 bh = ocfs2_bread(inode, blk, &err, 0); 106 bh = ocfs2_bread(inode, blk, &err, 0);
106 if (!bh) { 107 if (!bh) {
107 mlog(ML_ERROR, "directory #%"MLFu64" contains a hole " 108 mlog(ML_ERROR,
108 "at offset %lld\n", 109 "directory #%llu contains a hole at offset %lld\n",
109 OCFS2_I(inode)->ip_blkno, 110 (unsigned long long)OCFS2_I(inode)->ip_blkno,
110 filp->f_pos); 111 filp->f_pos);
111 filp->f_pos += sb->s_blocksize - offset; 112 filp->f_pos += sb->s_blocksize - offset;
112 continue; 113 continue;
@@ -214,9 +215,9 @@ int ocfs2_find_files_on_disk(const char *name,
214 int status = -ENOENT; 215 int status = -ENOENT;
215 struct ocfs2_super *osb = OCFS2_SB(inode->i_sb); 216 struct ocfs2_super *osb = OCFS2_SB(inode->i_sb);
216 217
217 mlog_entry("(osb=%p, parent=%"MLFu64", name='%.*s', blkno=%p, " 218 mlog_entry("(osb=%p, parent=%llu, name='%.*s', blkno=%p, inode=%p)\n",
218 "inode=%p)\n", 219 osb, (unsigned long long)OCFS2_I(inode)->ip_blkno,
219 osb, OCFS2_I(inode)->ip_blkno, namelen, name, blkno, inode); 220 namelen, name, blkno, inode);
220 221
221 *dirent_bh = ocfs2_find_entry(name, namelen, inode, dirent); 222 *dirent_bh = ocfs2_find_entry(name, namelen, inode, dirent);
222 if (!*dirent_bh || !*dirent) { 223 if (!*dirent_bh || !*dirent) {
@@ -255,8 +256,8 @@ int ocfs2_check_dir_for_entry(struct inode *dir,
255 struct buffer_head *dirent_bh = NULL; 256 struct buffer_head *dirent_bh = NULL;
256 struct ocfs2_dir_entry *dirent = NULL; 257 struct ocfs2_dir_entry *dirent = NULL;
257 258
258 mlog_entry("dir %"MLFu64", name '%.*s'\n", OCFS2_I(dir)->ip_blkno, 259 mlog_entry("dir %llu, name '%.*s'\n",
259 namelen, name); 260 (unsigned long long)OCFS2_I(dir)->ip_blkno, namelen, name);
260 261
261 ret = -EEXIST; 262 ret = -EEXIST;
262 dirent_bh = ocfs2_find_entry(name, namelen, dir, &dirent); 263 dirent_bh = ocfs2_find_entry(name, namelen, dir, &dirent);
@@ -287,9 +288,8 @@ int ocfs2_empty_dir(struct inode *inode)
287 if ((i_size_read(inode) < 288 if ((i_size_read(inode) <
288 (OCFS2_DIR_REC_LEN(1) + OCFS2_DIR_REC_LEN(2))) || 289 (OCFS2_DIR_REC_LEN(1) + OCFS2_DIR_REC_LEN(2))) ||
289 !(bh = ocfs2_bread(inode, 0, &err, 0))) { 290 !(bh = ocfs2_bread(inode, 0, &err, 0))) {
290 mlog(ML_ERROR, "bad directory (dir #%"MLFu64") - " 291 mlog(ML_ERROR, "bad directory (dir #%llu) - no data block\n",
291 "no data block\n", 292 (unsigned long long)OCFS2_I(inode)->ip_blkno);
292 OCFS2_I(inode)->ip_blkno);
293 return 1; 293 return 1;
294 } 294 }
295 295
@@ -300,9 +300,8 @@ int ocfs2_empty_dir(struct inode *inode)
300 !le64_to_cpu(de1->inode) || 300 !le64_to_cpu(de1->inode) ||
301 strcmp(".", de->name) || 301 strcmp(".", de->name) ||
302 strcmp("..", de1->name)) { 302 strcmp("..", de1->name)) {
303 mlog(ML_ERROR, "bad directory (dir #%"MLFu64") - " 303 mlog(ML_ERROR, "bad directory (dir #%llu) - no `.' or `..'\n",
304 "no `.' or `..'\n", 304 (unsigned long long)OCFS2_I(inode)->ip_blkno);
305 OCFS2_I(inode)->ip_blkno);
306 brelse(bh); 305 brelse(bh);
307 return 1; 306 return 1;
308 } 307 }
@@ -314,9 +313,8 @@ int ocfs2_empty_dir(struct inode *inode)
314 bh = ocfs2_bread(inode, 313 bh = ocfs2_bread(inode,
315 offset >> sb->s_blocksize_bits, &err, 0); 314 offset >> sb->s_blocksize_bits, &err, 0);
316 if (!bh) { 315 if (!bh) {
317 mlog(ML_ERROR, "directory #%"MLFu64" contains " 316 mlog(ML_ERROR, "dir %llu has a hole at %lu\n",
318 "a hole at offset %lu\n", 317 (unsigned long long)OCFS2_I(inode)->ip_blkno, offset);
319 OCFS2_I(inode)->ip_blkno, offset);
320 offset += sb->s_blocksize; 318 offset += sb->s_blocksize;
321 continue; 319 continue;
322 } 320 }
@@ -406,8 +404,8 @@ static int ocfs2_extend_dir(struct ocfs2_super *osb,
406 mlog_entry_void(); 404 mlog_entry_void();
407 405
408 dir_i_size = i_size_read(dir); 406 dir_i_size = i_size_read(dir);
409 mlog(0, "extending dir %"MLFu64" (i_size = %lld)\n", 407 mlog(0, "extending dir %llu (i_size = %lld)\n",
410 OCFS2_I(dir)->ip_blkno, dir_i_size); 408 (unsigned long long)OCFS2_I(dir)->ip_blkno, dir_i_size);
411 409
412 handle = ocfs2_alloc_handle(osb); 410 handle = ocfs2_alloc_handle(osb);
413 if (handle == NULL) { 411 if (handle == NULL) {
@@ -531,8 +529,8 @@ int ocfs2_prepare_dir_for_insert(struct ocfs2_super *osb,
531 529
532 mlog_entry_void(); 530 mlog_entry_void();
533 531
534 mlog(0, "getting ready to insert namelen %d into dir %"MLFu64"\n", 532 mlog(0, "getting ready to insert namelen %d into dir %llu\n",
535 namelen, OCFS2_I(dir)->ip_blkno); 533 namelen, (unsigned long long)OCFS2_I(dir)->ip_blkno);
536 534
537 BUG_ON(!S_ISDIR(dir->i_mode)); 535 BUG_ON(!S_ISDIR(dir->i_mode));
538 fe = (struct ocfs2_dinode *) parent_fe_bh->b_data; 536 fe = (struct ocfs2_dinode *) parent_fe_bh->b_data;
diff --git a/fs/ocfs2/dlm/dlmast.c b/fs/ocfs2/dlm/dlmast.c
index 8d17d28ef91c..355593dd8ef8 100644
--- a/fs/ocfs2/dlm/dlmast.c
+++ b/fs/ocfs2/dlm/dlmast.c
@@ -307,8 +307,11 @@ int dlm_proxy_ast_handler(struct o2net_msg *msg, u32 len, void *data)
307 307
308 if (past->type != DLM_AST && 308 if (past->type != DLM_AST &&
309 past->type != DLM_BAST) { 309 past->type != DLM_BAST) {
310 mlog(ML_ERROR, "Unknown ast type! %d, cookie=%"MLFu64", " 310 mlog(ML_ERROR, "Unknown ast type! %d, cookie=%u:%llu"
311 "name=%.*s\n", past->type, cookie, locklen, name); 311 "name=%.*s\n", past->type,
312 dlm_get_lock_cookie_node(cookie),
313 dlm_get_lock_cookie_seq(cookie),
314 locklen, name);
312 ret = DLM_IVLOCKID; 315 ret = DLM_IVLOCKID;
313 goto leave; 316 goto leave;
314 } 317 }
@@ -316,9 +319,11 @@ int dlm_proxy_ast_handler(struct o2net_msg *msg, u32 len, void *data)
316 res = dlm_lookup_lockres(dlm, name, locklen); 319 res = dlm_lookup_lockres(dlm, name, locklen);
317 if (!res) { 320 if (!res) {
318 mlog(ML_ERROR, "got %sast for unknown lockres! " 321 mlog(ML_ERROR, "got %sast for unknown lockres! "
319 "cookie=%"MLFu64", name=%.*s, namelen=%u\n", 322 "cookie=%u:%llu, name=%.*s, namelen=%u\n",
320 past->type == DLM_AST ? "" : "b", 323 past->type == DLM_AST ? "" : "b",
321 cookie, locklen, name, locklen); 324 dlm_get_lock_cookie_node(cookie),
325 dlm_get_lock_cookie_seq(cookie),
326 locklen, name, locklen);
322 ret = DLM_IVLOCKID; 327 ret = DLM_IVLOCKID;
323 goto leave; 328 goto leave;
324 } 329 }
@@ -360,9 +365,12 @@ int dlm_proxy_ast_handler(struct o2net_msg *msg, u32 len, void *data)
360 goto do_ast; 365 goto do_ast;
361 } 366 }
362 367
363 mlog(ML_ERROR, "got %sast for unknown lock! cookie=%"MLFu64", " 368 mlog(ML_ERROR, "got %sast for unknown lock! cookie=%u:%llu, "
364 "name=%.*s, namelen=%u\n", 369 "name=%.*s, namelen=%u\n",
365 past->type == DLM_AST ? "" : "b", cookie, locklen, name, locklen); 370 past->type == DLM_AST ? "" : "b",
371 dlm_get_lock_cookie_node(cookie),
372 dlm_get_lock_cookie_seq(cookie),
373 locklen, name, locklen);
366 374
367 ret = DLM_NORMAL; 375 ret = DLM_NORMAL;
368unlock_out: 376unlock_out:
diff --git a/fs/ocfs2/dlm/dlmcommon.h b/fs/ocfs2/dlm/dlmcommon.h
index 9c772583744a..88cc43df18f1 100644
--- a/fs/ocfs2/dlm/dlmcommon.h
+++ b/fs/ocfs2/dlm/dlmcommon.h
@@ -630,6 +630,21 @@ __dlm_lockres_state_to_status(struct dlm_lock_resource *res)
630 return status; 630 return status;
631} 631}
632 632
633static inline u8 dlm_get_lock_cookie_node(u64 cookie)
634{
635 u8 ret;
636 cookie >>= 56;
637 ret = (u8)(cookie & 0xffULL);
638 return ret;
639}
640
641static inline unsigned long long dlm_get_lock_cookie_seq(u64 cookie)
642{
643 unsigned long long ret;
644 ret = ((unsigned long long)cookie) & 0x00ffffffffffffffULL;
645 return ret;
646}
647
633struct dlm_lock * dlm_new_lock(int type, u8 node, u64 cookie, 648struct dlm_lock * dlm_new_lock(int type, u8 node, u64 cookie,
634 struct dlm_lockstatus *lksb); 649 struct dlm_lockstatus *lksb);
635void dlm_lock_get(struct dlm_lock *lock); 650void dlm_lock_get(struct dlm_lock *lock);
@@ -658,6 +673,7 @@ void dlm_complete_thread(struct dlm_ctxt *dlm);
658int dlm_launch_recovery_thread(struct dlm_ctxt *dlm); 673int dlm_launch_recovery_thread(struct dlm_ctxt *dlm);
659void dlm_complete_recovery_thread(struct dlm_ctxt *dlm); 674void dlm_complete_recovery_thread(struct dlm_ctxt *dlm);
660void dlm_wait_for_recovery(struct dlm_ctxt *dlm); 675void dlm_wait_for_recovery(struct dlm_ctxt *dlm);
676void dlm_kick_recovery_thread(struct dlm_ctxt *dlm);
661int dlm_is_node_dead(struct dlm_ctxt *dlm, u8 node); 677int dlm_is_node_dead(struct dlm_ctxt *dlm, u8 node);
662int dlm_wait_for_node_death(struct dlm_ctxt *dlm, u8 node, int timeout); 678int dlm_wait_for_node_death(struct dlm_ctxt *dlm, u8 node, int timeout);
663 679
@@ -762,6 +778,11 @@ int dlm_request_all_locks_handler(struct o2net_msg *msg, u32 len, void *data);
762int dlm_reco_data_done_handler(struct o2net_msg *msg, u32 len, void *data); 778int dlm_reco_data_done_handler(struct o2net_msg *msg, u32 len, void *data);
763int dlm_begin_reco_handler(struct o2net_msg *msg, u32 len, void *data); 779int dlm_begin_reco_handler(struct o2net_msg *msg, u32 len, void *data);
764int dlm_finalize_reco_handler(struct o2net_msg *msg, u32 len, void *data); 780int dlm_finalize_reco_handler(struct o2net_msg *msg, u32 len, void *data);
781int dlm_do_master_requery(struct dlm_ctxt *dlm, struct dlm_lock_resource *res,
782 u8 nodenum, u8 *real_master);
783int dlm_lockres_master_requery(struct dlm_ctxt *dlm,
784 struct dlm_lock_resource *res, u8 *real_master);
785
765 786
766int dlm_dispatch_assert_master(struct dlm_ctxt *dlm, 787int dlm_dispatch_assert_master(struct dlm_ctxt *dlm,
767 struct dlm_lock_resource *res, 788 struct dlm_lock_resource *res,
diff --git a/fs/ocfs2/dlm/dlmconvert.c b/fs/ocfs2/dlm/dlmconvert.c
index f66e2d818ccd..8285228d9e37 100644
--- a/fs/ocfs2/dlm/dlmconvert.c
+++ b/fs/ocfs2/dlm/dlmconvert.c
@@ -284,8 +284,10 @@ enum dlm_status dlmconvert_remote(struct dlm_ctxt *dlm,
284 if (lock->ml.convert_type != LKM_IVMODE) { 284 if (lock->ml.convert_type != LKM_IVMODE) {
285 __dlm_print_one_lock_resource(res); 285 __dlm_print_one_lock_resource(res);
286 mlog(ML_ERROR, "converting a remote lock that is already " 286 mlog(ML_ERROR, "converting a remote lock that is already "
287 "converting! (cookie=%"MLFu64", conv=%d)\n", 287 "converting! (cookie=%u:%llu, conv=%d)\n",
288 lock->ml.cookie, lock->ml.convert_type); 288 dlm_get_lock_cookie_node(lock->ml.cookie),
289 dlm_get_lock_cookie_seq(lock->ml.cookie),
290 lock->ml.convert_type);
289 status = DLM_DENIED; 291 status = DLM_DENIED;
290 goto bail; 292 goto bail;
291 } 293 }
@@ -513,8 +515,9 @@ int dlm_convert_lock_handler(struct o2net_msg *msg, u32 len, void *data)
513leave: 515leave:
514 if (!lock) 516 if (!lock)
515 mlog(ML_ERROR, "did not find lock to convert on grant queue! " 517 mlog(ML_ERROR, "did not find lock to convert on grant queue! "
516 "cookie=%"MLFu64"\n", 518 "cookie=%u:%llu\n",
517 cnv->cookie); 519 dlm_get_lock_cookie_node(cnv->cookie),
520 dlm_get_lock_cookie_seq(cnv->cookie));
518 else 521 else
519 dlm_lock_put(lock); 522 dlm_lock_put(lock);
520 523
diff --git a/fs/ocfs2/dlm/dlmdebug.c b/fs/ocfs2/dlm/dlmdebug.c
index 54f61b76ab51..c7eae5d3324e 100644
--- a/fs/ocfs2/dlm/dlmdebug.c
+++ b/fs/ocfs2/dlm/dlmdebug.c
@@ -72,8 +72,10 @@ void __dlm_print_one_lock_resource(struct dlm_lock_resource *res)
72 lock = list_entry(iter2, struct dlm_lock, list); 72 lock = list_entry(iter2, struct dlm_lock, list);
73 spin_lock(&lock->spinlock); 73 spin_lock(&lock->spinlock);
74 mlog(ML_NOTICE, " type=%d, conv=%d, node=%u, " 74 mlog(ML_NOTICE, " type=%d, conv=%d, node=%u, "
75 "cookie=%"MLFu64", ast=(empty=%c,pend=%c), bast=(empty=%c,pend=%c)\n", 75 "cookie=%u:%llu, ast=(empty=%c,pend=%c), bast=(empty=%c,pend=%c)\n",
76 lock->ml.type, lock->ml.convert_type, lock->ml.node, lock->ml.cookie, 76 lock->ml.type, lock->ml.convert_type, lock->ml.node,
77 dlm_get_lock_cookie_node(lock->ml.cookie),
78 dlm_get_lock_cookie_seq(lock->ml.cookie),
77 list_empty(&lock->ast_list) ? 'y' : 'n', 79 list_empty(&lock->ast_list) ? 'y' : 'n',
78 lock->ast_pending ? 'y' : 'n', 80 lock->ast_pending ? 'y' : 'n',
79 list_empty(&lock->bast_list) ? 'y' : 'n', 81 list_empty(&lock->bast_list) ? 'y' : 'n',
@@ -85,8 +87,10 @@ void __dlm_print_one_lock_resource(struct dlm_lock_resource *res)
85 lock = list_entry(iter2, struct dlm_lock, list); 87 lock = list_entry(iter2, struct dlm_lock, list);
86 spin_lock(&lock->spinlock); 88 spin_lock(&lock->spinlock);
87 mlog(ML_NOTICE, " type=%d, conv=%d, node=%u, " 89 mlog(ML_NOTICE, " type=%d, conv=%d, node=%u, "
88 "cookie=%"MLFu64", ast=(empty=%c,pend=%c), bast=(empty=%c,pend=%c)\n", 90 "cookie=%u:%llu, ast=(empty=%c,pend=%c), bast=(empty=%c,pend=%c)\n",
89 lock->ml.type, lock->ml.convert_type, lock->ml.node, lock->ml.cookie, 91 lock->ml.type, lock->ml.convert_type, lock->ml.node,
92 dlm_get_lock_cookie_node(lock->ml.cookie),
93 dlm_get_lock_cookie_seq(lock->ml.cookie),
90 list_empty(&lock->ast_list) ? 'y' : 'n', 94 list_empty(&lock->ast_list) ? 'y' : 'n',
91 lock->ast_pending ? 'y' : 'n', 95 lock->ast_pending ? 'y' : 'n',
92 list_empty(&lock->bast_list) ? 'y' : 'n', 96 list_empty(&lock->bast_list) ? 'y' : 'n',
@@ -98,8 +102,10 @@ void __dlm_print_one_lock_resource(struct dlm_lock_resource *res)
98 lock = list_entry(iter2, struct dlm_lock, list); 102 lock = list_entry(iter2, struct dlm_lock, list);
99 spin_lock(&lock->spinlock); 103 spin_lock(&lock->spinlock);
100 mlog(ML_NOTICE, " type=%d, conv=%d, node=%u, " 104 mlog(ML_NOTICE, " type=%d, conv=%d, node=%u, "
101 "cookie=%"MLFu64", ast=(empty=%c,pend=%c), bast=(empty=%c,pend=%c)\n", 105 "cookie=%u:%llu, ast=(empty=%c,pend=%c), bast=(empty=%c,pend=%c)\n",
102 lock->ml.type, lock->ml.convert_type, lock->ml.node, lock->ml.cookie, 106 lock->ml.type, lock->ml.convert_type, lock->ml.node,
107 dlm_get_lock_cookie_node(lock->ml.cookie),
108 dlm_get_lock_cookie_seq(lock->ml.cookie),
103 list_empty(&lock->ast_list) ? 'y' : 'n', 109 list_empty(&lock->ast_list) ? 'y' : 'n',
104 lock->ast_pending ? 'y' : 'n', 110 lock->ast_pending ? 'y' : 'n',
105 list_empty(&lock->bast_list) ? 'y' : 'n', 111 list_empty(&lock->bast_list) ? 'y' : 'n',
diff --git a/fs/ocfs2/dlm/dlmfs.c b/fs/ocfs2/dlm/dlmfs.c
index dd2d24dc25e0..7e88e24b3471 100644
--- a/fs/ocfs2/dlm/dlmfs.c
+++ b/fs/ocfs2/dlm/dlmfs.c
@@ -596,7 +596,8 @@ static int __init init_dlmfs_fs(void)
596 596
597 dlmfs_inode_cache = kmem_cache_create("dlmfs_inode_cache", 597 dlmfs_inode_cache = kmem_cache_create("dlmfs_inode_cache",
598 sizeof(struct dlmfs_inode_private), 598 sizeof(struct dlmfs_inode_private),
599 0, SLAB_HWCACHE_ALIGN|SLAB_RECLAIM_ACCOUNT, 599 0, (SLAB_HWCACHE_ALIGN|SLAB_RECLAIM_ACCOUNT|
600 SLAB_MEM_SPREAD),
600 dlmfs_init_once, NULL); 601 dlmfs_init_once, NULL);
601 if (!dlmfs_inode_cache) 602 if (!dlmfs_inode_cache)
602 return -ENOMEM; 603 return -ENOMEM;
diff --git a/fs/ocfs2/dlm/dlmlock.c b/fs/ocfs2/dlm/dlmlock.c
index 671d4ff222cc..6fea28318d6d 100644
--- a/fs/ocfs2/dlm/dlmlock.c
+++ b/fs/ocfs2/dlm/dlmlock.c
@@ -141,13 +141,23 @@ static enum dlm_status dlmlock_master(struct dlm_ctxt *dlm,
141 res->lockname.len)) { 141 res->lockname.len)) {
142 kick_thread = 1; 142 kick_thread = 1;
143 call_ast = 1; 143 call_ast = 1;
144 } else {
145 mlog(0, "%s: returning DLM_NORMAL to "
146 "node %u for reco lock\n", dlm->name,
147 lock->ml.node);
144 } 148 }
145 } else { 149 } else {
146 /* for NOQUEUE request, unless we get the 150 /* for NOQUEUE request, unless we get the
147 * lock right away, return DLM_NOTQUEUED */ 151 * lock right away, return DLM_NOTQUEUED */
148 if (flags & LKM_NOQUEUE) 152 if (flags & LKM_NOQUEUE) {
149 status = DLM_NOTQUEUED; 153 status = DLM_NOTQUEUED;
150 else { 154 if (dlm_is_recovery_lock(res->lockname.name,
155 res->lockname.len)) {
156 mlog(0, "%s: returning NOTQUEUED to "
157 "node %u for reco lock\n", dlm->name,
158 lock->ml.node);
159 }
160 } else {
151 dlm_lock_get(lock); 161 dlm_lock_get(lock);
152 list_add_tail(&lock->list, &res->blocked); 162 list_add_tail(&lock->list, &res->blocked);
153 kick_thread = 1; 163 kick_thread = 1;
diff --git a/fs/ocfs2/dlm/dlmmaster.c b/fs/ocfs2/dlm/dlmmaster.c
index 847dd3cc4cf5..940be4c13b1f 100644
--- a/fs/ocfs2/dlm/dlmmaster.c
+++ b/fs/ocfs2/dlm/dlmmaster.c
@@ -239,6 +239,8 @@ static void dlm_remove_nonlocal_locks(struct dlm_ctxt *dlm,
239static int dlm_mark_lockres_migrating(struct dlm_ctxt *dlm, 239static int dlm_mark_lockres_migrating(struct dlm_ctxt *dlm,
240 struct dlm_lock_resource *res, 240 struct dlm_lock_resource *res,
241 u8 target); 241 u8 target);
242static int dlm_pre_master_reco_lockres(struct dlm_ctxt *dlm,
243 struct dlm_lock_resource *res);
242 244
243 245
244int dlm_is_host_down(int errno) 246int dlm_is_host_down(int errno)
@@ -677,6 +679,7 @@ struct dlm_lock_resource * dlm_get_lock_resource(struct dlm_ctxt *dlm,
677 struct dlm_node_iter iter; 679 struct dlm_node_iter iter;
678 unsigned int namelen; 680 unsigned int namelen;
679 int tries = 0; 681 int tries = 0;
682 int bit, wait_on_recovery = 0;
680 683
681 BUG_ON(!lockid); 684 BUG_ON(!lockid);
682 685
@@ -762,6 +765,18 @@ lookup:
762 dlm_init_mle(mle, DLM_MLE_MASTER, dlm, res, NULL, 0); 765 dlm_init_mle(mle, DLM_MLE_MASTER, dlm, res, NULL, 0);
763 set_bit(dlm->node_num, mle->maybe_map); 766 set_bit(dlm->node_num, mle->maybe_map);
764 list_add(&mle->list, &dlm->master_list); 767 list_add(&mle->list, &dlm->master_list);
768
769 /* still holding the dlm spinlock, check the recovery map
770 * to see if there are any nodes that still need to be
771 * considered. these will not appear in the mle nodemap
772 * but they might own this lockres. wait on them. */
773 bit = find_next_bit(dlm->recovery_map, O2NM_MAX_NODES, 0);
774 if (bit < O2NM_MAX_NODES) {
775 mlog(ML_NOTICE, "%s:%.*s: at least one node (%d) to"
776 "recover before lock mastery can begin\n",
777 dlm->name, namelen, (char *)lockid, bit);
778 wait_on_recovery = 1;
779 }
765 } 780 }
766 781
767 /* at this point there is either a DLM_MLE_BLOCK or a 782 /* at this point there is either a DLM_MLE_BLOCK or a
@@ -779,6 +794,39 @@ lookup:
779 spin_unlock(&dlm->master_lock); 794 spin_unlock(&dlm->master_lock);
780 spin_unlock(&dlm->spinlock); 795 spin_unlock(&dlm->spinlock);
781 796
797 while (wait_on_recovery) {
798 /* any cluster changes that occurred after dropping the
799 * dlm spinlock would be detectable be a change on the mle,
800 * so we only need to clear out the recovery map once. */
801 if (dlm_is_recovery_lock(lockid, namelen)) {
802 mlog(ML_NOTICE, "%s: recovery map is not empty, but "
803 "must master $RECOVERY lock now\n", dlm->name);
804 if (!dlm_pre_master_reco_lockres(dlm, res))
805 wait_on_recovery = 0;
806 else {
807 mlog(0, "%s: waiting 500ms for heartbeat state "
808 "change\n", dlm->name);
809 msleep(500);
810 }
811 continue;
812 }
813
814 dlm_kick_recovery_thread(dlm);
815 msleep(100);
816 dlm_wait_for_recovery(dlm);
817
818 spin_lock(&dlm->spinlock);
819 bit = find_next_bit(dlm->recovery_map, O2NM_MAX_NODES, 0);
820 if (bit < O2NM_MAX_NODES) {
821 mlog(ML_NOTICE, "%s:%.*s: at least one node (%d) to"
822 "recover before lock mastery can begin\n",
823 dlm->name, namelen, (char *)lockid, bit);
824 wait_on_recovery = 1;
825 } else
826 wait_on_recovery = 0;
827 spin_unlock(&dlm->spinlock);
828 }
829
782 /* must wait for lock to be mastered elsewhere */ 830 /* must wait for lock to be mastered elsewhere */
783 if (blocked) 831 if (blocked)
784 goto wait; 832 goto wait;
@@ -792,7 +840,15 @@ redo_request:
792 mlog_errno(ret); 840 mlog_errno(ret);
793 if (mle->master != O2NM_MAX_NODES) { 841 if (mle->master != O2NM_MAX_NODES) {
794 /* found a master ! */ 842 /* found a master ! */
795 break; 843 if (mle->master <= nodenum)
844 break;
845 /* if our master request has not reached the master
846 * yet, keep going until it does. this is how the
847 * master will know that asserts are needed back to
848 * the lower nodes. */
849 mlog(0, "%s:%.*s: requests only up to %u but master "
850 "is %u, keep going\n", dlm->name, namelen,
851 lockid, nodenum, mle->master);
796 } 852 }
797 } 853 }
798 854
@@ -860,7 +916,19 @@ recheck:
860 /* check if another node has already become the owner */ 916 /* check if another node has already become the owner */
861 spin_lock(&res->spinlock); 917 spin_lock(&res->spinlock);
862 if (res->owner != DLM_LOCK_RES_OWNER_UNKNOWN) { 918 if (res->owner != DLM_LOCK_RES_OWNER_UNKNOWN) {
919 mlog(0, "%s:%.*s: owner is suddenly %u\n", dlm->name,
920 res->lockname.len, res->lockname.name, res->owner);
863 spin_unlock(&res->spinlock); 921 spin_unlock(&res->spinlock);
922 /* this will cause the master to re-assert across
923 * the whole cluster, freeing up mles */
924 ret = dlm_do_master_request(mle, res->owner);
925 if (ret < 0) {
926 /* give recovery a chance to run */
927 mlog(ML_ERROR, "link to %u went down?: %d\n", res->owner, ret);
928 msleep(500);
929 goto recheck;
930 }
931 ret = 0;
864 goto leave; 932 goto leave;
865 } 933 }
866 spin_unlock(&res->spinlock); 934 spin_unlock(&res->spinlock);
@@ -1244,13 +1312,14 @@ int dlm_master_request_handler(struct o2net_msg *msg, u32 len, void *data)
1244{ 1312{
1245 u8 response = DLM_MASTER_RESP_MAYBE; 1313 u8 response = DLM_MASTER_RESP_MAYBE;
1246 struct dlm_ctxt *dlm = data; 1314 struct dlm_ctxt *dlm = data;
1247 struct dlm_lock_resource *res; 1315 struct dlm_lock_resource *res = NULL;
1248 struct dlm_master_request *request = (struct dlm_master_request *) msg->buf; 1316 struct dlm_master_request *request = (struct dlm_master_request *) msg->buf;
1249 struct dlm_master_list_entry *mle = NULL, *tmpmle = NULL; 1317 struct dlm_master_list_entry *mle = NULL, *tmpmle = NULL;
1250 char *name; 1318 char *name;
1251 unsigned int namelen; 1319 unsigned int namelen;
1252 int found, ret; 1320 int found, ret;
1253 int set_maybe; 1321 int set_maybe;
1322 int dispatch_assert = 0;
1254 1323
1255 if (!dlm_grab(dlm)) 1324 if (!dlm_grab(dlm))
1256 return DLM_MASTER_RESP_NO; 1325 return DLM_MASTER_RESP_NO;
@@ -1287,7 +1356,6 @@ way_up_top:
1287 } 1356 }
1288 1357
1289 if (res->owner == dlm->node_num) { 1358 if (res->owner == dlm->node_num) {
1290 u32 flags = DLM_ASSERT_MASTER_MLE_CLEANUP;
1291 spin_unlock(&res->spinlock); 1359 spin_unlock(&res->spinlock);
1292 // mlog(0, "this node is the master\n"); 1360 // mlog(0, "this node is the master\n");
1293 response = DLM_MASTER_RESP_YES; 1361 response = DLM_MASTER_RESP_YES;
@@ -1300,16 +1368,7 @@ way_up_top:
1300 * caused all nodes up to this one to 1368 * caused all nodes up to this one to
1301 * create mles. this node now needs to 1369 * create mles. this node now needs to
1302 * go back and clean those up. */ 1370 * go back and clean those up. */
1303 mlog(0, "%u is the owner of %.*s, cleaning everyone else\n", 1371 dispatch_assert = 1;
1304 dlm->node_num, res->lockname.len, res->lockname.name);
1305 ret = dlm_dispatch_assert_master(dlm, res, 1,
1306 request->node_idx,
1307 flags);
1308 if (ret < 0) {
1309 mlog(ML_ERROR, "failed to dispatch assert "
1310 "master work\n");
1311 response = DLM_MASTER_RESP_ERROR;
1312 }
1313 goto send_response; 1372 goto send_response;
1314 } else if (res->owner != DLM_LOCK_RES_OWNER_UNKNOWN) { 1373 } else if (res->owner != DLM_LOCK_RES_OWNER_UNKNOWN) {
1315 spin_unlock(&res->spinlock); 1374 spin_unlock(&res->spinlock);
@@ -1357,9 +1416,13 @@ way_up_top:
1357 } 1416 }
1358 } else if (tmpmle->master != DLM_LOCK_RES_OWNER_UNKNOWN) { 1417 } else if (tmpmle->master != DLM_LOCK_RES_OWNER_UNKNOWN) {
1359 set_maybe = 0; 1418 set_maybe = 0;
1360 if (tmpmle->master == dlm->node_num) 1419 if (tmpmle->master == dlm->node_num) {
1361 response = DLM_MASTER_RESP_YES; 1420 response = DLM_MASTER_RESP_YES;
1362 else 1421 /* this node will be the owner.
1422 * go back and clean the mles on any
1423 * other nodes */
1424 dispatch_assert = 1;
1425 } else
1363 response = DLM_MASTER_RESP_NO; 1426 response = DLM_MASTER_RESP_NO;
1364 } else { 1427 } else {
1365 // mlog(0, "this node is attempting to " 1428 // mlog(0, "this node is attempting to "
@@ -1398,8 +1461,8 @@ way_up_top:
1398 mle = (struct dlm_master_list_entry *) 1461 mle = (struct dlm_master_list_entry *)
1399 kmem_cache_alloc(dlm_mle_cache, GFP_KERNEL); 1462 kmem_cache_alloc(dlm_mle_cache, GFP_KERNEL);
1400 if (!mle) { 1463 if (!mle) {
1401 // bad bad bad... this sucks.
1402 response = DLM_MASTER_RESP_ERROR; 1464 response = DLM_MASTER_RESP_ERROR;
1465 mlog_errno(-ENOMEM);
1403 goto send_response; 1466 goto send_response;
1404 } 1467 }
1405 spin_lock(&dlm->spinlock); 1468 spin_lock(&dlm->spinlock);
@@ -1418,25 +1481,19 @@ way_up_top:
1418 // mlog(0, "mle was found\n"); 1481 // mlog(0, "mle was found\n");
1419 set_maybe = 1; 1482 set_maybe = 1;
1420 spin_lock(&tmpmle->spinlock); 1483 spin_lock(&tmpmle->spinlock);
1484 if (tmpmle->master == dlm->node_num) {
1485 mlog(ML_ERROR, "no lockres, but an mle with this node as master!\n");
1486 BUG();
1487 }
1421 if (tmpmle->type == DLM_MLE_BLOCK) 1488 if (tmpmle->type == DLM_MLE_BLOCK)
1422 response = DLM_MASTER_RESP_NO; 1489 response = DLM_MASTER_RESP_NO;
1423 else if (tmpmle->type == DLM_MLE_MIGRATION) { 1490 else if (tmpmle->type == DLM_MLE_MIGRATION) {
1424 mlog(0, "migration mle was found (%u->%u)\n", 1491 mlog(0, "migration mle was found (%u->%u)\n",
1425 tmpmle->master, tmpmle->new_master); 1492 tmpmle->master, tmpmle->new_master);
1426 if (tmpmle->master == dlm->node_num) {
1427 mlog(ML_ERROR, "no lockres, but migration mle "
1428 "says that this node is master!\n");
1429 BUG();
1430 }
1431 /* real master can respond on its own */ 1493 /* real master can respond on its own */
1432 response = DLM_MASTER_RESP_NO; 1494 response = DLM_MASTER_RESP_NO;
1433 } else { 1495 } else
1434 if (tmpmle->master == dlm->node_num) { 1496 response = DLM_MASTER_RESP_MAYBE;
1435 response = DLM_MASTER_RESP_YES;
1436 set_maybe = 0;
1437 } else
1438 response = DLM_MASTER_RESP_MAYBE;
1439 }
1440 if (set_maybe) 1497 if (set_maybe)
1441 set_bit(request->node_idx, tmpmle->maybe_map); 1498 set_bit(request->node_idx, tmpmle->maybe_map);
1442 spin_unlock(&tmpmle->spinlock); 1499 spin_unlock(&tmpmle->spinlock);
@@ -1449,6 +1506,24 @@ way_up_top:
1449 dlm_put_mle(tmpmle); 1506 dlm_put_mle(tmpmle);
1450 } 1507 }
1451send_response: 1508send_response:
1509
1510 if (dispatch_assert) {
1511 if (response != DLM_MASTER_RESP_YES)
1512 mlog(ML_ERROR, "invalid response %d\n", response);
1513 if (!res) {
1514 mlog(ML_ERROR, "bad lockres while trying to assert!\n");
1515 BUG();
1516 }
1517 mlog(0, "%u is the owner of %.*s, cleaning everyone else\n",
1518 dlm->node_num, res->lockname.len, res->lockname.name);
1519 ret = dlm_dispatch_assert_master(dlm, res, 0, request->node_idx,
1520 DLM_ASSERT_MASTER_MLE_CLEANUP);
1521 if (ret < 0) {
1522 mlog(ML_ERROR, "failed to dispatch assert master work\n");
1523 response = DLM_MASTER_RESP_ERROR;
1524 }
1525 }
1526
1452 dlm_put(dlm); 1527 dlm_put(dlm);
1453 return response; 1528 return response;
1454} 1529}
@@ -1471,8 +1546,11 @@ static int dlm_do_assert_master(struct dlm_ctxt *dlm, const char *lockname,
1471 int to, tmpret; 1546 int to, tmpret;
1472 struct dlm_node_iter iter; 1547 struct dlm_node_iter iter;
1473 int ret = 0; 1548 int ret = 0;
1549 int reassert;
1474 1550
1475 BUG_ON(namelen > O2NM_MAX_NAME_LEN); 1551 BUG_ON(namelen > O2NM_MAX_NAME_LEN);
1552again:
1553 reassert = 0;
1476 1554
1477 /* note that if this nodemap is empty, it returns 0 */ 1555 /* note that if this nodemap is empty, it returns 0 */
1478 dlm_node_iter_init(nodemap, &iter); 1556 dlm_node_iter_init(nodemap, &iter);
@@ -1504,9 +1582,17 @@ static int dlm_do_assert_master(struct dlm_ctxt *dlm, const char *lockname,
1504 "got %d.\n", namelen, lockname, to, r); 1582 "got %d.\n", namelen, lockname, to, r);
1505 dlm_dump_lock_resources(dlm); 1583 dlm_dump_lock_resources(dlm);
1506 BUG(); 1584 BUG();
1585 } else if (r == EAGAIN) {
1586 mlog(0, "%.*s: node %u create mles on other "
1587 "nodes and requests a re-assert\n",
1588 namelen, lockname, to);
1589 reassert = 1;
1507 } 1590 }
1508 } 1591 }
1509 1592
1593 if (reassert)
1594 goto again;
1595
1510 return ret; 1596 return ret;
1511} 1597}
1512 1598
@@ -1528,6 +1614,8 @@ int dlm_assert_master_handler(struct o2net_msg *msg, u32 len, void *data)
1528 char *name; 1614 char *name;
1529 unsigned int namelen; 1615 unsigned int namelen;
1530 u32 flags; 1616 u32 flags;
1617 int master_request = 0;
1618 int ret = 0;
1531 1619
1532 if (!dlm_grab(dlm)) 1620 if (!dlm_grab(dlm))
1533 return 0; 1621 return 0;
@@ -1642,11 +1730,22 @@ ok:
1642 // mlog(0, "woo! got an assert_master from node %u!\n", 1730 // mlog(0, "woo! got an assert_master from node %u!\n",
1643 // assert->node_idx); 1731 // assert->node_idx);
1644 if (mle) { 1732 if (mle) {
1645 int extra_ref; 1733 int extra_ref = 0;
1734 int nn = -1;
1646 1735
1647 spin_lock(&mle->spinlock); 1736 spin_lock(&mle->spinlock);
1648 extra_ref = !!(mle->type == DLM_MLE_BLOCK 1737 if (mle->type == DLM_MLE_BLOCK || mle->type == DLM_MLE_MIGRATION)
1649 || mle->type == DLM_MLE_MIGRATION); 1738 extra_ref = 1;
1739 else {
1740 /* MASTER mle: if any bits set in the response map
1741 * then the calling node needs to re-assert to clear
1742 * up nodes that this node contacted */
1743 while ((nn = find_next_bit (mle->response_map, O2NM_MAX_NODES,
1744 nn+1)) < O2NM_MAX_NODES) {
1745 if (nn != dlm->node_num && nn != assert->node_idx)
1746 master_request = 1;
1747 }
1748 }
1650 mle->master = assert->node_idx; 1749 mle->master = assert->node_idx;
1651 atomic_set(&mle->woken, 1); 1750 atomic_set(&mle->woken, 1);
1652 wake_up(&mle->wq); 1751 wake_up(&mle->wq);
@@ -1677,10 +1776,15 @@ ok:
1677 } 1776 }
1678 1777
1679done: 1778done:
1779 ret = 0;
1680 if (res) 1780 if (res)
1681 dlm_lockres_put(res); 1781 dlm_lockres_put(res);
1682 dlm_put(dlm); 1782 dlm_put(dlm);
1683 return 0; 1783 if (master_request) {
1784 mlog(0, "need to tell master to reassert\n");
1785 ret = EAGAIN; // positive. negative would shoot down the node.
1786 }
1787 return ret;
1684 1788
1685kill: 1789kill:
1686 /* kill the caller! */ 1790 /* kill the caller! */
@@ -1713,6 +1817,10 @@ int dlm_dispatch_assert_master(struct dlm_ctxt *dlm,
1713 item->u.am.request_from = request_from; 1817 item->u.am.request_from = request_from;
1714 item->u.am.flags = flags; 1818 item->u.am.flags = flags;
1715 1819
1820 if (ignore_higher)
1821 mlog(0, "IGNORE HIGHER: %.*s\n", res->lockname.len,
1822 res->lockname.name);
1823
1716 spin_lock(&dlm->work_lock); 1824 spin_lock(&dlm->work_lock);
1717 list_add_tail(&item->list, &dlm->work_list); 1825 list_add_tail(&item->list, &dlm->work_list);
1718 spin_unlock(&dlm->work_lock); 1826 spin_unlock(&dlm->work_lock);
@@ -1775,6 +1883,61 @@ static void dlm_assert_master_worker(struct dlm_work_item *item, void *data)
1775 mlog(0, "finished with dlm_assert_master_worker\n"); 1883 mlog(0, "finished with dlm_assert_master_worker\n");
1776} 1884}
1777 1885
1886/* SPECIAL CASE for the $RECOVERY lock used by the recovery thread.
1887 * We cannot wait for node recovery to complete to begin mastering this
1888 * lockres because this lockres is used to kick off recovery! ;-)
1889 * So, do a pre-check on all living nodes to see if any of those nodes
1890 * think that $RECOVERY is currently mastered by a dead node. If so,
1891 * we wait a short time to allow that node to get notified by its own
1892 * heartbeat stack, then check again. All $RECOVERY lock resources
1893 * mastered by dead nodes are purged when the hearbeat callback is
1894 * fired, so we can know for sure that it is safe to continue once
1895 * the node returns a live node or no node. */
1896static int dlm_pre_master_reco_lockres(struct dlm_ctxt *dlm,
1897 struct dlm_lock_resource *res)
1898{
1899 struct dlm_node_iter iter;
1900 int nodenum;
1901 int ret = 0;
1902 u8 master = DLM_LOCK_RES_OWNER_UNKNOWN;
1903
1904 spin_lock(&dlm->spinlock);
1905 dlm_node_iter_init(dlm->domain_map, &iter);
1906 spin_unlock(&dlm->spinlock);
1907
1908 while ((nodenum = dlm_node_iter_next(&iter)) >= 0) {
1909 /* do not send to self */
1910 if (nodenum == dlm->node_num)
1911 continue;
1912 ret = dlm_do_master_requery(dlm, res, nodenum, &master);
1913 if (ret < 0) {
1914 mlog_errno(ret);
1915 if (!dlm_is_host_down(ret))
1916 BUG();
1917 /* host is down, so answer for that node would be
1918 * DLM_LOCK_RES_OWNER_UNKNOWN. continue. */
1919 }
1920
1921 if (master != DLM_LOCK_RES_OWNER_UNKNOWN) {
1922 /* check to see if this master is in the recovery map */
1923 spin_lock(&dlm->spinlock);
1924 if (test_bit(master, dlm->recovery_map)) {
1925 mlog(ML_NOTICE, "%s: node %u has not seen "
1926 "node %u go down yet, and thinks the "
1927 "dead node is mastering the recovery "
1928 "lock. must wait.\n", dlm->name,
1929 nodenum, master);
1930 ret = -EAGAIN;
1931 }
1932 spin_unlock(&dlm->spinlock);
1933 mlog(0, "%s: reco lock master is %u\n", dlm->name,
1934 master);
1935 break;
1936 }
1937 }
1938 return ret;
1939}
1940
1778 1941
1779/* 1942/*
1780 * DLM_MIGRATE_LOCKRES 1943 * DLM_MIGRATE_LOCKRES
diff --git a/fs/ocfs2/dlm/dlmrecovery.c b/fs/ocfs2/dlm/dlmrecovery.c
index 1e232000f3f7..805cbabac051 100644
--- a/fs/ocfs2/dlm/dlmrecovery.c
+++ b/fs/ocfs2/dlm/dlmrecovery.c
@@ -58,7 +58,7 @@ static void dlm_do_local_recovery_cleanup(struct dlm_ctxt *dlm, u8 dead_node);
58static int dlm_recovery_thread(void *data); 58static int dlm_recovery_thread(void *data);
59void dlm_complete_recovery_thread(struct dlm_ctxt *dlm); 59void dlm_complete_recovery_thread(struct dlm_ctxt *dlm);
60int dlm_launch_recovery_thread(struct dlm_ctxt *dlm); 60int dlm_launch_recovery_thread(struct dlm_ctxt *dlm);
61static void dlm_kick_recovery_thread(struct dlm_ctxt *dlm); 61void dlm_kick_recovery_thread(struct dlm_ctxt *dlm);
62static int dlm_do_recovery(struct dlm_ctxt *dlm); 62static int dlm_do_recovery(struct dlm_ctxt *dlm);
63 63
64static int dlm_pick_recovery_master(struct dlm_ctxt *dlm); 64static int dlm_pick_recovery_master(struct dlm_ctxt *dlm);
@@ -78,15 +78,9 @@ static int dlm_send_mig_lockres_msg(struct dlm_ctxt *dlm,
78 u8 send_to, 78 u8 send_to,
79 struct dlm_lock_resource *res, 79 struct dlm_lock_resource *res,
80 int total_locks); 80 int total_locks);
81static int dlm_lockres_master_requery(struct dlm_ctxt *dlm,
82 struct dlm_lock_resource *res,
83 u8 *real_master);
84static int dlm_process_recovery_data(struct dlm_ctxt *dlm, 81static int dlm_process_recovery_data(struct dlm_ctxt *dlm,
85 struct dlm_lock_resource *res, 82 struct dlm_lock_resource *res,
86 struct dlm_migratable_lockres *mres); 83 struct dlm_migratable_lockres *mres);
87static int dlm_do_master_requery(struct dlm_ctxt *dlm,
88 struct dlm_lock_resource *res,
89 u8 nodenum, u8 *real_master);
90static int dlm_send_finalize_reco_message(struct dlm_ctxt *dlm); 84static int dlm_send_finalize_reco_message(struct dlm_ctxt *dlm);
91static int dlm_send_all_done_msg(struct dlm_ctxt *dlm, 85static int dlm_send_all_done_msg(struct dlm_ctxt *dlm,
92 u8 dead_node, u8 send_to); 86 u8 dead_node, u8 send_to);
@@ -165,7 +159,7 @@ void dlm_dispatch_work(void *data)
165 * RECOVERY THREAD 159 * RECOVERY THREAD
166 */ 160 */
167 161
168static void dlm_kick_recovery_thread(struct dlm_ctxt *dlm) 162void dlm_kick_recovery_thread(struct dlm_ctxt *dlm)
169{ 163{
170 /* wake the recovery thread 164 /* wake the recovery thread
171 * this will wake the reco thread in one of three places 165 * this will wake the reco thread in one of three places
@@ -750,10 +744,12 @@ static void dlm_request_all_locks_worker(struct dlm_work_item *item, void *data)
750 dlm->name, dlm->reco.dead_node, dlm->reco.new_master, 744 dlm->name, dlm->reco.dead_node, dlm->reco.new_master,
751 dead_node, reco_master); 745 dead_node, reco_master);
752 mlog(ML_ERROR, "%s: name=%.*s master=%u locks=%u/%u flags=%u " 746 mlog(ML_ERROR, "%s: name=%.*s master=%u locks=%u/%u flags=%u "
753 "entry[0]={c=%"MLFu64",l=%u,f=%u,t=%d,ct=%d,hb=%d,n=%u}\n", 747 "entry[0]={c=%u:%llu,l=%u,f=%u,t=%d,ct=%d,hb=%d,n=%u}\n",
754 dlm->name, mres->lockname_len, mres->lockname, mres->master, 748 dlm->name, mres->lockname_len, mres->lockname, mres->master,
755 mres->num_locks, mres->total_locks, mres->flags, 749 mres->num_locks, mres->total_locks, mres->flags,
756 mres->ml[0].cookie, mres->ml[0].list, mres->ml[0].flags, 750 dlm_get_lock_cookie_node(mres->ml[0].cookie),
751 dlm_get_lock_cookie_seq(mres->ml[0].cookie),
752 mres->ml[0].list, mres->ml[0].flags,
757 mres->ml[0].type, mres->ml[0].convert_type, 753 mres->ml[0].type, mres->ml[0].convert_type,
758 mres->ml[0].highest_blocked, mres->ml[0].node); 754 mres->ml[0].highest_blocked, mres->ml[0].node);
759 BUG(); 755 BUG();
@@ -1316,9 +1312,8 @@ leave:
1316 1312
1317 1313
1318 1314
1319static int dlm_lockres_master_requery(struct dlm_ctxt *dlm, 1315int dlm_lockres_master_requery(struct dlm_ctxt *dlm,
1320 struct dlm_lock_resource *res, 1316 struct dlm_lock_resource *res, u8 *real_master)
1321 u8 *real_master)
1322{ 1317{
1323 struct dlm_node_iter iter; 1318 struct dlm_node_iter iter;
1324 int nodenum; 1319 int nodenum;
@@ -1360,8 +1355,10 @@ static int dlm_lockres_master_requery(struct dlm_ctxt *dlm,
1360 ret = dlm_do_master_requery(dlm, res, nodenum, real_master); 1355 ret = dlm_do_master_requery(dlm, res, nodenum, real_master);
1361 if (ret < 0) { 1356 if (ret < 0) {
1362 mlog_errno(ret); 1357 mlog_errno(ret);
1363 BUG(); 1358 if (!dlm_is_host_down(ret))
1364 /* TODO: need to figure a way to restart this */ 1359 BUG();
1360 /* host is down, so answer for that node would be
1361 * DLM_LOCK_RES_OWNER_UNKNOWN. continue. */
1365 } 1362 }
1366 if (*real_master != DLM_LOCK_RES_OWNER_UNKNOWN) { 1363 if (*real_master != DLM_LOCK_RES_OWNER_UNKNOWN) {
1367 mlog(0, "lock master is %u\n", *real_master); 1364 mlog(0, "lock master is %u\n", *real_master);
@@ -1372,9 +1369,8 @@ static int dlm_lockres_master_requery(struct dlm_ctxt *dlm,
1372} 1369}
1373 1370
1374 1371
1375static int dlm_do_master_requery(struct dlm_ctxt *dlm, 1372int dlm_do_master_requery(struct dlm_ctxt *dlm, struct dlm_lock_resource *res,
1376 struct dlm_lock_resource *res, 1373 u8 nodenum, u8 *real_master)
1377 u8 nodenum, u8 *real_master)
1378{ 1374{
1379 int ret = -EINVAL; 1375 int ret = -EINVAL;
1380 struct dlm_master_requery req; 1376 struct dlm_master_requery req;
@@ -1519,9 +1515,11 @@ static int dlm_process_recovery_data(struct dlm_ctxt *dlm,
1519 /* lock is always created locally first, and 1515 /* lock is always created locally first, and
1520 * destroyed locally last. it must be on the list */ 1516 * destroyed locally last. it must be on the list */
1521 if (!lock) { 1517 if (!lock) {
1518 u64 c = ml->cookie;
1522 mlog(ML_ERROR, "could not find local lock " 1519 mlog(ML_ERROR, "could not find local lock "
1523 "with cookie %"MLFu64"!\n", 1520 "with cookie %u:%llu!\n",
1524 ml->cookie); 1521 dlm_get_lock_cookie_node(c),
1522 dlm_get_lock_cookie_seq(c));
1525 BUG(); 1523 BUG();
1526 } 1524 }
1527 BUG_ON(lock->ml.node != ml->node); 1525 BUG_ON(lock->ml.node != ml->node);
@@ -1739,6 +1737,13 @@ static void dlm_finish_local_lockres_recovery(struct dlm_ctxt *dlm,
1739 } else 1737 } else
1740 continue; 1738 continue;
1741 1739
1740 if (!list_empty(&res->recovering)) {
1741 mlog(0, "%s:%.*s: lockres was "
1742 "marked RECOVERING, owner=%u\n",
1743 dlm->name, res->lockname.len,
1744 res->lockname.name, res->owner);
1745 list_del_init(&res->recovering);
1746 }
1742 spin_lock(&res->spinlock); 1747 spin_lock(&res->spinlock);
1743 dlm_change_lockres_owner(dlm, res, new_master); 1748 dlm_change_lockres_owner(dlm, res, new_master);
1744 res->state &= ~DLM_LOCK_RES_RECOVERING; 1749 res->state &= ~DLM_LOCK_RES_RECOVERING;
@@ -2258,7 +2263,10 @@ int dlm_begin_reco_handler(struct o2net_msg *msg, u32 len, void *data)
2258 mlog(0, "%u not in domain/live_nodes map " 2263 mlog(0, "%u not in domain/live_nodes map "
2259 "so setting it in reco map manually\n", 2264 "so setting it in reco map manually\n",
2260 br->dead_node); 2265 br->dead_node);
2261 set_bit(br->dead_node, dlm->recovery_map); 2266 /* force the recovery cleanup in __dlm_hb_node_down
2267 * both of these will be cleared in a moment */
2268 set_bit(br->dead_node, dlm->domain_map);
2269 set_bit(br->dead_node, dlm->live_nodes_map);
2262 __dlm_hb_node_down(dlm, br->dead_node); 2270 __dlm_hb_node_down(dlm, br->dead_node);
2263 } 2271 }
2264 spin_unlock(&dlm->spinlock); 2272 spin_unlock(&dlm->spinlock);
diff --git a/fs/ocfs2/dlm/dlmunlock.c b/fs/ocfs2/dlm/dlmunlock.c
index c95f08d2e925..7b1a27542674 100644
--- a/fs/ocfs2/dlm/dlmunlock.c
+++ b/fs/ocfs2/dlm/dlmunlock.c
@@ -244,8 +244,10 @@ leave:
244 if (actions & DLM_UNLOCK_FREE_LOCK) { 244 if (actions & DLM_UNLOCK_FREE_LOCK) {
245 /* this should always be coupled with list removal */ 245 /* this should always be coupled with list removal */
246 BUG_ON(!(actions & DLM_UNLOCK_REMOVE_LOCK)); 246 BUG_ON(!(actions & DLM_UNLOCK_REMOVE_LOCK));
247 mlog(0, "lock %"MLFu64" should be gone now! refs=%d\n", 247 mlog(0, "lock %u:%llu should be gone now! refs=%d\n",
248 lock->ml.cookie, atomic_read(&lock->lock_refs.refcount)-1); 248 dlm_get_lock_cookie_node(lock->ml.cookie),
249 dlm_get_lock_cookie_seq(lock->ml.cookie),
250 atomic_read(&lock->lock_refs.refcount)-1);
249 dlm_lock_put(lock); 251 dlm_lock_put(lock);
250 } 252 }
251 if (actions & DLM_UNLOCK_CALL_AST) 253 if (actions & DLM_UNLOCK_CALL_AST)
@@ -493,8 +495,9 @@ int dlm_unlock_lock_handler(struct o2net_msg *msg, u32 len, void *data)
493not_found: 495not_found:
494 if (!found) 496 if (!found)
495 mlog(ML_ERROR, "failed to find lock to unlock! " 497 mlog(ML_ERROR, "failed to find lock to unlock! "
496 "cookie=%"MLFu64"\n", 498 "cookie=%u:%llu\n",
497 unlock->cookie); 499 dlm_get_lock_cookie_node(unlock->cookie),
500 dlm_get_lock_cookie_seq(unlock->cookie));
498 else { 501 else {
499 /* send the lksb->status back to the other node */ 502 /* send the lksb->status back to the other node */
500 status = lksb->status; 503 status = lksb->status;
diff --git a/fs/ocfs2/dlmglue.c b/fs/ocfs2/dlmglue.c
index e971ec2f8407..64cd52860c87 100644
--- a/fs/ocfs2/dlmglue.c
+++ b/fs/ocfs2/dlmglue.c
@@ -231,9 +231,9 @@ static void ocfs2_build_lock_name(enum ocfs2_lock_type type,
231 231
232 BUG_ON(type >= OCFS2_NUM_LOCK_TYPES); 232 BUG_ON(type >= OCFS2_NUM_LOCK_TYPES);
233 233
234 len = snprintf(name, OCFS2_LOCK_ID_MAX_LEN, "%c%s%016"MLFx64"%08x", 234 len = snprintf(name, OCFS2_LOCK_ID_MAX_LEN, "%c%s%016llx%08x",
235 ocfs2_lock_type_char(type), OCFS2_LOCK_ID_PAD, blkno, 235 ocfs2_lock_type_char(type), OCFS2_LOCK_ID_PAD,
236 generation); 236 (long long)blkno, generation);
237 237
238 BUG_ON(len != (OCFS2_LOCK_ID_MAX_LEN - 1)); 238 BUG_ON(len != (OCFS2_LOCK_ID_MAX_LEN - 1));
239 239
@@ -533,8 +533,8 @@ static void ocfs2_inode_ast_func(void *opaque)
533 533
534 inode = ocfs2_lock_res_inode(lockres); 534 inode = ocfs2_lock_res_inode(lockres);
535 535
536 mlog(0, "AST fired for inode %"MLFu64", l_action = %u, type = %s\n", 536 mlog(0, "AST fired for inode %llu, l_action = %u, type = %s\n",
537 OCFS2_I(inode)->ip_blkno, lockres->l_action, 537 (unsigned long long)OCFS2_I(inode)->ip_blkno, lockres->l_action,
538 ocfs2_lock_type_string(lockres->l_type)); 538 ocfs2_lock_type_string(lockres->l_type));
539 539
540 BUG_ON(!ocfs2_is_inode_lock(lockres)); 540 BUG_ON(!ocfs2_is_inode_lock(lockres));
@@ -544,8 +544,8 @@ static void ocfs2_inode_ast_func(void *opaque)
544 lksb = &(lockres->l_lksb); 544 lksb = &(lockres->l_lksb);
545 if (lksb->status != DLM_NORMAL) { 545 if (lksb->status != DLM_NORMAL) {
546 mlog(ML_ERROR, "ocfs2_inode_ast_func: lksb status value of %u " 546 mlog(ML_ERROR, "ocfs2_inode_ast_func: lksb status value of %u "
547 "on inode %"MLFu64"\n", lksb->status, 547 "on inode %llu\n", lksb->status,
548 OCFS2_I(inode)->ip_blkno); 548 (unsigned long long)OCFS2_I(inode)->ip_blkno);
549 spin_unlock_irqrestore(&lockres->l_lock, flags); 549 spin_unlock_irqrestore(&lockres->l_lock, flags);
550 mlog_exit_void(); 550 mlog_exit_void();
551 return; 551 return;
@@ -646,10 +646,9 @@ static void ocfs2_inode_bast_func(void *opaque, int level)
646 inode = ocfs2_lock_res_inode(lockres); 646 inode = ocfs2_lock_res_inode(lockres);
647 osb = OCFS2_SB(inode->i_sb); 647 osb = OCFS2_SB(inode->i_sb);
648 648
649 mlog(0, "BAST fired for inode %"MLFu64", blocking = %d, level = %d " 649 mlog(0, "BAST fired for inode %llu, blocking %d, level %d type %s\n",
650 "type = %s\n", OCFS2_I(inode)->ip_blkno, level, 650 (unsigned long long)OCFS2_I(inode)->ip_blkno, level,
651 lockres->l_level, 651 lockres->l_level, ocfs2_lock_type_string(lockres->l_type));
652 ocfs2_lock_type_string(lockres->l_type));
653 652
654 ocfs2_generic_bast_func(osb, lockres, level); 653 ocfs2_generic_bast_func(osb, lockres, level);
655 654
@@ -1104,7 +1103,7 @@ int ocfs2_create_new_inode_locks(struct inode *inode)
1104 1103
1105 mlog_entry_void(); 1104 mlog_entry_void();
1106 1105
1107 mlog(0, "Inode %"MLFu64"\n", OCFS2_I(inode)->ip_blkno); 1106 mlog(0, "Inode %llu\n", (unsigned long long)OCFS2_I(inode)->ip_blkno);
1108 1107
1109 /* NOTE: That we don't increment any of the holder counts, nor 1108 /* NOTE: That we don't increment any of the holder counts, nor
1110 * do we add anything to a journal handle. Since this is 1109 * do we add anything to a journal handle. Since this is
@@ -1149,8 +1148,8 @@ int ocfs2_rw_lock(struct inode *inode, int write)
1149 1148
1150 mlog_entry_void(); 1149 mlog_entry_void();
1151 1150
1152 mlog(0, "inode %"MLFu64" take %s RW lock\n", 1151 mlog(0, "inode %llu take %s RW lock\n",
1153 OCFS2_I(inode)->ip_blkno, 1152 (unsigned long long)OCFS2_I(inode)->ip_blkno,
1154 write ? "EXMODE" : "PRMODE"); 1153 write ? "EXMODE" : "PRMODE");
1155 1154
1156 lockres = &OCFS2_I(inode)->ip_rw_lockres; 1155 lockres = &OCFS2_I(inode)->ip_rw_lockres;
@@ -1173,8 +1172,8 @@ void ocfs2_rw_unlock(struct inode *inode, int write)
1173 1172
1174 mlog_entry_void(); 1173 mlog_entry_void();
1175 1174
1176 mlog(0, "inode %"MLFu64" drop %s RW lock\n", 1175 mlog(0, "inode %llu drop %s RW lock\n",
1177 OCFS2_I(inode)->ip_blkno, 1176 (unsigned long long)OCFS2_I(inode)->ip_blkno,
1178 write ? "EXMODE" : "PRMODE"); 1177 write ? "EXMODE" : "PRMODE");
1179 1178
1180 ocfs2_cluster_unlock(OCFS2_SB(inode->i_sb), lockres, level); 1179 ocfs2_cluster_unlock(OCFS2_SB(inode->i_sb), lockres, level);
@@ -1193,8 +1192,8 @@ int ocfs2_data_lock_full(struct inode *inode,
1193 1192
1194 mlog_entry_void(); 1193 mlog_entry_void();
1195 1194
1196 mlog(0, "inode %"MLFu64" take %s DATA lock\n", 1195 mlog(0, "inode %llu take %s DATA lock\n",
1197 OCFS2_I(inode)->ip_blkno, 1196 (unsigned long long)OCFS2_I(inode)->ip_blkno,
1198 write ? "EXMODE" : "PRMODE"); 1197 write ? "EXMODE" : "PRMODE");
1199 1198
1200 /* We'll allow faking a readonly data lock for 1199 /* We'll allow faking a readonly data lock for
@@ -1278,8 +1277,8 @@ void ocfs2_data_unlock(struct inode *inode,
1278 1277
1279 mlog_entry_void(); 1278 mlog_entry_void();
1280 1279
1281 mlog(0, "inode %"MLFu64" drop %s DATA lock\n", 1280 mlog(0, "inode %llu drop %s DATA lock\n",
1282 OCFS2_I(inode)->ip_blkno, 1281 (unsigned long long)OCFS2_I(inode)->ip_blkno,
1283 write ? "EXMODE" : "PRMODE"); 1282 write ? "EXMODE" : "PRMODE");
1284 1283
1285 if (!ocfs2_is_hard_readonly(OCFS2_SB(inode->i_sb))) 1284 if (!ocfs2_is_hard_readonly(OCFS2_SB(inode->i_sb)))
@@ -1462,9 +1461,9 @@ static int ocfs2_meta_lock_update(struct inode *inode,
1462 1461
1463 spin_lock(&oi->ip_lock); 1462 spin_lock(&oi->ip_lock);
1464 if (oi->ip_flags & OCFS2_INODE_DELETED) { 1463 if (oi->ip_flags & OCFS2_INODE_DELETED) {
1465 mlog(0, "Orphaned inode %"MLFu64" was deleted while we " 1464 mlog(0, "Orphaned inode %llu was deleted while we "
1466 "were waiting on a lock. ip_flags = 0x%x\n", 1465 "were waiting on a lock. ip_flags = 0x%x\n",
1467 oi->ip_blkno, oi->ip_flags); 1466 (unsigned long long)oi->ip_blkno, oi->ip_flags);
1468 spin_unlock(&oi->ip_lock); 1467 spin_unlock(&oi->ip_lock);
1469 status = -ENOENT; 1468 status = -ENOENT;
1470 goto bail; 1469 goto bail;
@@ -1485,8 +1484,8 @@ static int ocfs2_meta_lock_update(struct inode *inode,
1485 ocfs2_extent_map_trunc(inode, 0); 1484 ocfs2_extent_map_trunc(inode, 0);
1486 1485
1487 if (ocfs2_meta_lvb_is_trustable(lockres)) { 1486 if (ocfs2_meta_lvb_is_trustable(lockres)) {
1488 mlog(0, "Trusting LVB on inode %"MLFu64"\n", 1487 mlog(0, "Trusting LVB on inode %llu\n",
1489 oi->ip_blkno); 1488 (unsigned long long)oi->ip_blkno);
1490 ocfs2_refresh_inode_from_lvb(inode); 1489 ocfs2_refresh_inode_from_lvb(inode);
1491 } else { 1490 } else {
1492 /* Boo, we have to go to disk. */ 1491 /* Boo, we have to go to disk. */
@@ -1514,15 +1513,16 @@ static int ocfs2_meta_lock_update(struct inode *inode,
1514 } 1513 }
1515 mlog_bug_on_msg(inode->i_generation != 1514 mlog_bug_on_msg(inode->i_generation !=
1516 le32_to_cpu(fe->i_generation), 1515 le32_to_cpu(fe->i_generation),
1517 "Invalid dinode %"MLFu64" disk generation: %u " 1516 "Invalid dinode %llu disk generation: %u "
1518 "inode->i_generation: %u\n", 1517 "inode->i_generation: %u\n",
1519 oi->ip_blkno, le32_to_cpu(fe->i_generation), 1518 (unsigned long long)oi->ip_blkno,
1519 le32_to_cpu(fe->i_generation),
1520 inode->i_generation); 1520 inode->i_generation);
1521 mlog_bug_on_msg(le64_to_cpu(fe->i_dtime) || 1521 mlog_bug_on_msg(le64_to_cpu(fe->i_dtime) ||
1522 !(fe->i_flags & cpu_to_le32(OCFS2_VALID_FL)), 1522 !(fe->i_flags & cpu_to_le32(OCFS2_VALID_FL)),
1523 "Stale dinode %"MLFu64" dtime: %"MLFu64" " 1523 "Stale dinode %llu dtime: %llu flags: 0x%x\n",
1524 "flags: 0x%x\n", oi->ip_blkno, 1524 (unsigned long long)oi->ip_blkno,
1525 le64_to_cpu(fe->i_dtime), 1525 (unsigned long long)le64_to_cpu(fe->i_dtime),
1526 le32_to_cpu(fe->i_flags)); 1526 le32_to_cpu(fe->i_flags));
1527 1527
1528 ocfs2_refresh_inode(inode, fe); 1528 ocfs2_refresh_inode(inode, fe);
@@ -1581,8 +1581,8 @@ int ocfs2_meta_lock_full(struct inode *inode,
1581 1581
1582 mlog_entry_void(); 1582 mlog_entry_void();
1583 1583
1584 mlog(0, "inode %"MLFu64", take %s META lock\n", 1584 mlog(0, "inode %llu, take %s META lock\n",
1585 OCFS2_I(inode)->ip_blkno, 1585 (unsigned long long)OCFS2_I(inode)->ip_blkno,
1586 ex ? "EXMODE" : "PRMODE"); 1586 ex ? "EXMODE" : "PRMODE");
1587 1587
1588 status = 0; 1588 status = 0;
@@ -1716,8 +1716,8 @@ void ocfs2_meta_unlock(struct inode *inode,
1716 1716
1717 mlog_entry_void(); 1717 mlog_entry_void();
1718 1718
1719 mlog(0, "inode %"MLFu64" drop %s META lock\n", 1719 mlog(0, "inode %llu drop %s META lock\n",
1720 OCFS2_I(inode)->ip_blkno, 1720 (unsigned long long)OCFS2_I(inode)->ip_blkno,
1721 ex ? "EXMODE" : "PRMODE"); 1721 ex ? "EXMODE" : "PRMODE");
1722 1722
1723 if (!ocfs2_is_hard_readonly(OCFS2_SB(inode->i_sb))) 1723 if (!ocfs2_is_hard_readonly(OCFS2_SB(inode->i_sb)))
@@ -2017,7 +2017,7 @@ out:
2017 return ret; 2017 return ret;
2018} 2018}
2019 2019
2020static struct file_operations ocfs2_dlm_debug_fops = { 2020static const struct file_operations ocfs2_dlm_debug_fops = {
2021 .open = ocfs2_dlm_debug_open, 2021 .open = ocfs2_dlm_debug_open,
2022 .release = ocfs2_dlm_debug_release, 2022 .release = ocfs2_dlm_debug_release,
2023 .read = seq_read, 2023 .read = seq_read,
@@ -2686,8 +2686,8 @@ static void ocfs2_data_convert_worker(struct ocfs2_lock_res *lockres,
2686 mapping = inode->i_mapping; 2686 mapping = inode->i_mapping;
2687 2687
2688 if (filemap_fdatawrite(mapping)) { 2688 if (filemap_fdatawrite(mapping)) {
2689 mlog(ML_ERROR, "Could not sync inode %"MLFu64" for downconvert!", 2689 mlog(ML_ERROR, "Could not sync inode %llu for downconvert!",
2690 OCFS2_I(inode)->ip_blkno); 2690 (unsigned long long)OCFS2_I(inode)->ip_blkno);
2691 } 2691 }
2692 sync_mapping_buffers(mapping); 2692 sync_mapping_buffers(mapping);
2693 if (blocking == LKM_EXMODE) { 2693 if (blocking == LKM_EXMODE) {
@@ -2717,7 +2717,8 @@ int ocfs2_unblock_data(struct ocfs2_lock_res *lockres,
2717 inode = ocfs2_lock_res_inode(lockres); 2717 inode = ocfs2_lock_res_inode(lockres);
2718 osb = OCFS2_SB(inode->i_sb); 2718 osb = OCFS2_SB(inode->i_sb);
2719 2719
2720 mlog(0, "unblock inode %"MLFu64"\n", OCFS2_I(inode)->ip_blkno); 2720 mlog(0, "unblock inode %llu\n",
2721 (unsigned long long)OCFS2_I(inode)->ip_blkno);
2721 2722
2722 status = ocfs2_generic_unblock_lock(osb, 2723 status = ocfs2_generic_unblock_lock(osb,
2723 lockres, 2724 lockres,
@@ -2726,8 +2727,8 @@ int ocfs2_unblock_data(struct ocfs2_lock_res *lockres,
2726 if (status < 0) 2727 if (status < 0)
2727 mlog_errno(status); 2728 mlog_errno(status);
2728 2729
2729 mlog(0, "inode %"MLFu64", requeue = %d\n", 2730 mlog(0, "inode %llu, requeue = %d\n",
2730 OCFS2_I(inode)->ip_blkno, *requeue); 2731 (unsigned long long)OCFS2_I(inode)->ip_blkno, *requeue);
2731 2732
2732 mlog_exit(status); 2733 mlog_exit(status);
2733 return status; 2734 return status;
@@ -2767,14 +2768,15 @@ int ocfs2_unblock_meta(struct ocfs2_lock_res *lockres,
2767 2768
2768 inode = ocfs2_lock_res_inode(lockres); 2769 inode = ocfs2_lock_res_inode(lockres);
2769 2770
2770 mlog(0, "unblock inode %"MLFu64"\n", OCFS2_I(inode)->ip_blkno); 2771 mlog(0, "unblock inode %llu\n",
2772 (unsigned long long)OCFS2_I(inode)->ip_blkno);
2771 2773
2772 status = ocfs2_do_unblock_meta(inode, requeue); 2774 status = ocfs2_do_unblock_meta(inode, requeue);
2773 if (status < 0) 2775 if (status < 0)
2774 mlog_errno(status); 2776 mlog_errno(status);
2775 2777
2776 mlog(0, "inode %"MLFu64", requeue = %d\n", 2778 mlog(0, "inode %llu, requeue = %d\n",
2777 OCFS2_I(inode)->ip_blkno, *requeue); 2779 (unsigned long long)OCFS2_I(inode)->ip_blkno, *requeue);
2778 2780
2779 mlog_exit(status); 2781 mlog_exit(status);
2780 return status; 2782 return status;
@@ -2893,12 +2895,13 @@ void ocfs2_dump_meta_lvb_info(u64 level,
2893 lockres->l_name, function, line); 2895 lockres->l_name, function, line);
2894 mlog(level, "version: %u, clusters: %u\n", 2896 mlog(level, "version: %u, clusters: %u\n",
2895 be32_to_cpu(lvb->lvb_version), be32_to_cpu(lvb->lvb_iclusters)); 2897 be32_to_cpu(lvb->lvb_version), be32_to_cpu(lvb->lvb_iclusters));
2896 mlog(level, "size: %"MLFu64", uid %u, gid %u, mode 0x%x\n", 2898 mlog(level, "size: %llu, uid %u, gid %u, mode 0x%x\n",
2897 be64_to_cpu(lvb->lvb_isize), be32_to_cpu(lvb->lvb_iuid), 2899 (unsigned long long)be64_to_cpu(lvb->lvb_isize),
2898 be32_to_cpu(lvb->lvb_igid), be16_to_cpu(lvb->lvb_imode)); 2900 be32_to_cpu(lvb->lvb_iuid), be32_to_cpu(lvb->lvb_igid),
2899 mlog(level, "nlink %u, atime_packed 0x%"MLFx64", " 2901 be16_to_cpu(lvb->lvb_imode));
2900 "ctime_packed 0x%"MLFx64", mtime_packed 0x%"MLFx64"\n", 2902 mlog(level, "nlink %u, atime_packed 0x%llx, ctime_packed 0x%llx, "
2901 be16_to_cpu(lvb->lvb_inlink), be64_to_cpu(lvb->lvb_iatime_packed), 2903 "mtime_packed 0x%llx\n", be16_to_cpu(lvb->lvb_inlink),
2902 be64_to_cpu(lvb->lvb_ictime_packed), 2904 (long long)be64_to_cpu(lvb->lvb_iatime_packed),
2903 be64_to_cpu(lvb->lvb_imtime_packed)); 2905 (long long)be64_to_cpu(lvb->lvb_ictime_packed),
2906 (long long)be64_to_cpu(lvb->lvb_imtime_packed));
2904} 2907}
diff --git a/fs/ocfs2/export.c b/fs/ocfs2/export.c
index 5810160d92a8..ec55ab3c1214 100644
--- a/fs/ocfs2/export.c
+++ b/fs/ocfs2/export.c
@@ -95,8 +95,8 @@ static struct dentry *ocfs2_get_parent(struct dentry *child)
95 mlog_entry("(0x%p, '%.*s')\n", child, 95 mlog_entry("(0x%p, '%.*s')\n", child,
96 child->d_name.len, child->d_name.name); 96 child->d_name.len, child->d_name.name);
97 97
98 mlog(0, "find parent of directory %"MLFu64"\n", 98 mlog(0, "find parent of directory %llu\n",
99 OCFS2_I(dir)->ip_blkno); 99 (unsigned long long)OCFS2_I(dir)->ip_blkno);
100 100
101 status = ocfs2_meta_lock(dir, NULL, NULL, 0); 101 status = ocfs2_meta_lock(dir, NULL, NULL, 0);
102 if (status < 0) { 102 if (status < 0) {
@@ -115,7 +115,8 @@ static struct dentry *ocfs2_get_parent(struct dentry *child)
115 115
116 inode = ocfs2_iget(OCFS2_SB(dir->i_sb), blkno); 116 inode = ocfs2_iget(OCFS2_SB(dir->i_sb), blkno);
117 if (IS_ERR(inode)) { 117 if (IS_ERR(inode)) {
118 mlog(ML_ERROR, "Unable to create inode %"MLFu64"\n", blkno); 118 mlog(ML_ERROR, "Unable to create inode %llu\n",
119 (unsigned long long)blkno);
119 parent = ERR_PTR(-EACCES); 120 parent = ERR_PTR(-EACCES);
120 goto bail_unlock; 121 goto bail_unlock;
121 } 122 }
@@ -160,8 +161,8 @@ static int ocfs2_encode_fh(struct dentry *dentry, __be32 *fh, int *max_len,
160 blkno = OCFS2_I(inode)->ip_blkno; 161 blkno = OCFS2_I(inode)->ip_blkno;
161 generation = inode->i_generation; 162 generation = inode->i_generation;
162 163
163 mlog(0, "Encoding fh: blkno: %"MLFu64", generation: %u\n", 164 mlog(0, "Encoding fh: blkno: %llu, generation: %u\n",
164 blkno, generation); 165 (unsigned long long)blkno, generation);
165 166
166 len = 3; 167 len = 3;
167 fh[0] = cpu_to_le32((u32)(blkno >> 32)); 168 fh[0] = cpu_to_le32((u32)(blkno >> 32));
@@ -186,8 +187,8 @@ static int ocfs2_encode_fh(struct dentry *dentry, __be32 *fh, int *max_len,
186 len = 6; 187 len = 6;
187 type = 2; 188 type = 2;
188 189
189 mlog(0, "Encoding parent: blkno: %"MLFu64", generation: %u\n", 190 mlog(0, "Encoding parent: blkno: %llu, generation: %u\n",
190 blkno, generation); 191 (unsigned long long)blkno, generation);
191 } 192 }
192 193
193 *max_len = len; 194 *max_len = len;
@@ -220,16 +221,17 @@ static struct dentry *ocfs2_decode_fh(struct super_block *sb, __be32 *fh,
220 parent.ih_blkno |= (u64)le32_to_cpu(fh[4]); 221 parent.ih_blkno |= (u64)le32_to_cpu(fh[4]);
221 parent.ih_generation = le32_to_cpu(fh[5]); 222 parent.ih_generation = le32_to_cpu(fh[5]);
222 223
223 mlog(0, "Decoding parent: blkno: %"MLFu64", generation: %u\n", 224 mlog(0, "Decoding parent: blkno: %llu, generation: %u\n",
224 parent.ih_blkno, parent.ih_generation); 225 (unsigned long long)parent.ih_blkno,
226 parent.ih_generation);
225 } 227 }
226 228
227 handle.ih_blkno = (u64)le32_to_cpu(fh[0]) << 32; 229 handle.ih_blkno = (u64)le32_to_cpu(fh[0]) << 32;
228 handle.ih_blkno |= (u64)le32_to_cpu(fh[1]); 230 handle.ih_blkno |= (u64)le32_to_cpu(fh[1]);
229 handle.ih_generation = le32_to_cpu(fh[2]); 231 handle.ih_generation = le32_to_cpu(fh[2]);
230 232
231 mlog(0, "Encoding fh: blkno: %"MLFu64", generation: %u\n", 233 mlog(0, "Encoding fh: blkno: %llu, generation: %u\n",
232 handle.ih_blkno, handle.ih_generation); 234 (unsigned long long)handle.ih_blkno, handle.ih_generation);
233 235
234 ret = ocfs2_export_ops.find_exported_dentry(sb, &handle, &parent, 236 ret = ocfs2_export_ops.find_exported_dentry(sb, &handle, &parent,
235 acceptable, context); 237 acceptable, context);
diff --git a/fs/ocfs2/extent_map.c b/fs/ocfs2/extent_map.c
index e6f207eebab4..4601fc256f11 100644
--- a/fs/ocfs2/extent_map.c
+++ b/fs/ocfs2/extent_map.c
@@ -182,10 +182,10 @@ static int ocfs2_extent_map_find_leaf(struct inode *inode,
182 if (rec_end > OCFS2_I(inode)->ip_clusters) { 182 if (rec_end > OCFS2_I(inode)->ip_clusters) {
183 mlog_errno(ret); 183 mlog_errno(ret);
184 ocfs2_error(inode->i_sb, 184 ocfs2_error(inode->i_sb,
185 "Extent %d at e_blkno %"MLFu64" of inode %"MLFu64" goes past ip_clusters of %u\n", 185 "Extent %d at e_blkno %llu of inode %llu goes past ip_clusters of %u\n",
186 i, 186 i,
187 le64_to_cpu(rec->e_blkno), 187 (unsigned long long)le64_to_cpu(rec->e_blkno),
188 OCFS2_I(inode)->ip_blkno, 188 (unsigned long long)OCFS2_I(inode)->ip_blkno,
189 OCFS2_I(inode)->ip_clusters); 189 OCFS2_I(inode)->ip_clusters);
190 goto out_free; 190 goto out_free;
191 } 191 }
@@ -233,11 +233,11 @@ static int ocfs2_extent_map_find_leaf(struct inode *inode,
233 if (blkno) { 233 if (blkno) {
234 mlog_errno(ret); 234 mlog_errno(ret);
235 ocfs2_error(inode->i_sb, 235 ocfs2_error(inode->i_sb,
236 "Multiple extents for (cpos = %u, clusters = %u) on inode %"MLFu64"; e_blkno %"MLFu64" and rec %d at e_blkno %"MLFu64"\n", 236 "Multiple extents for (cpos = %u, clusters = %u) on inode %llu; e_blkno %llu and rec %d at e_blkno %llu\n",
237 cpos, clusters, 237 cpos, clusters,
238 OCFS2_I(inode)->ip_blkno, 238 (unsigned long long)OCFS2_I(inode)->ip_blkno,
239 blkno, i, 239 (unsigned long long)blkno, i,
240 le64_to_cpu(rec->e_blkno)); 240 (unsigned long long)le64_to_cpu(rec->e_blkno));
241 goto out_free; 241 goto out_free;
242 } 242 }
243 243
@@ -251,9 +251,9 @@ static int ocfs2_extent_map_find_leaf(struct inode *inode,
251 ret = -EBADR; 251 ret = -EBADR;
252 if (!blkno) { 252 if (!blkno) {
253 ocfs2_error(inode->i_sb, 253 ocfs2_error(inode->i_sb,
254 "No record found for (cpos = %u, clusters = %u) on inode %"MLFu64"\n", 254 "No record found for (cpos = %u, clusters = %u) on inode %llu\n",
255 cpos, clusters, 255 cpos, clusters,
256 OCFS2_I(inode)->ip_blkno); 256 (unsigned long long)OCFS2_I(inode)->ip_blkno);
257 mlog_errno(ret); 257 mlog_errno(ret);
258 goto out_free; 258 goto out_free;
259 } 259 }
@@ -288,10 +288,10 @@ static int ocfs2_extent_map_find_leaf(struct inode *inode,
288 ret = -EBADR; 288 ret = -EBADR;
289 mlog_errno(ret); 289 mlog_errno(ret);
290 ocfs2_error(inode->i_sb, 290 ocfs2_error(inode->i_sb,
291 "Extent %d at e_blkno %"MLFu64" of inode %"MLFu64" goes past ip_clusters of %u\n", 291 "Extent %d at e_blkno %llu of inode %llu goes past ip_clusters of %u\n",
292 i, 292 i,
293 le64_to_cpu(rec->e_blkno), 293 (unsigned long long)le64_to_cpu(rec->e_blkno),
294 OCFS2_I(inode)->ip_blkno, 294 (unsigned long long)OCFS2_I(inode)->ip_blkno,
295 OCFS2_I(inode)->ip_clusters); 295 OCFS2_I(inode)->ip_clusters);
296 return ret; 296 return ret;
297 } 297 }
@@ -557,9 +557,9 @@ static int ocfs2_extent_map_insert(struct inode *inode,
557 ret = -EBADR; 557 ret = -EBADR;
558 mlog_errno(ret); 558 mlog_errno(ret);
559 ocfs2_error(inode->i_sb, 559 ocfs2_error(inode->i_sb,
560 "Zero e_clusters on non-tail extent record at e_blkno %"MLFu64" on inode %"MLFu64"\n", 560 "Zero e_clusters on non-tail extent record at e_blkno %llu on inode %llu\n",
561 le64_to_cpu(rec->e_blkno), 561 (unsigned long long)le64_to_cpu(rec->e_blkno),
562 OCFS2_I(inode)->ip_blkno); 562 (unsigned long long)OCFS2_I(inode)->ip_blkno);
563 return ret; 563 return ret;
564 } 564 }
565 565
@@ -660,10 +660,10 @@ int ocfs2_extent_map_append(struct inode *inode,
660 mlog_bug_on_msg((le32_to_cpu(rec->e_cpos) + 660 mlog_bug_on_msg((le32_to_cpu(rec->e_cpos) +
661 le32_to_cpu(rec->e_clusters)) != 661 le32_to_cpu(rec->e_clusters)) !=
662 (em->em_clusters + new_clusters), 662 (em->em_clusters + new_clusters),
663 "Inode %"MLFu64":\n" 663 "Inode %llu:\n"
664 "rec->e_cpos = %u + rec->e_clusters = %u = %u\n" 664 "rec->e_cpos = %u + rec->e_clusters = %u = %u\n"
665 "em->em_clusters = %u + new_clusters = %u = %u\n", 665 "em->em_clusters = %u + new_clusters = %u = %u\n",
666 OCFS2_I(inode)->ip_blkno, 666 (unsigned long long)OCFS2_I(inode)->ip_blkno,
667 le32_to_cpu(rec->e_cpos), le32_to_cpu(rec->e_clusters), 667 le32_to_cpu(rec->e_cpos), le32_to_cpu(rec->e_clusters),
668 le32_to_cpu(rec->e_cpos) + le32_to_cpu(rec->e_clusters), 668 le32_to_cpu(rec->e_cpos) + le32_to_cpu(rec->e_clusters),
669 em->em_clusters, new_clusters, 669 em->em_clusters, new_clusters,
diff --git a/fs/ocfs2/file.c b/fs/ocfs2/file.c
index 8a4048b55fdc..34e903a6a46b 100644
--- a/fs/ocfs2/file.c
+++ b/fs/ocfs2/file.c
@@ -220,8 +220,9 @@ static int ocfs2_truncate_file(struct inode *inode,
220 struct ocfs2_super *osb = OCFS2_SB(inode->i_sb); 220 struct ocfs2_super *osb = OCFS2_SB(inode->i_sb);
221 struct ocfs2_truncate_context *tc = NULL; 221 struct ocfs2_truncate_context *tc = NULL;
222 222
223 mlog_entry("(inode = %"MLFu64", new_i_size = %"MLFu64"\n", 223 mlog_entry("(inode = %llu, new_i_size = %llu\n",
224 OCFS2_I(inode)->ip_blkno, new_i_size); 224 (unsigned long long)OCFS2_I(inode)->ip_blkno,
225 (unsigned long long)new_i_size);
225 226
226 truncate_inode_pages(inode->i_mapping, new_i_size); 227 truncate_inode_pages(inode->i_mapping, new_i_size);
227 228
@@ -233,23 +234,26 @@ static int ocfs2_truncate_file(struct inode *inode,
233 } 234 }
234 235
235 mlog_bug_on_msg(le64_to_cpu(fe->i_size) != i_size_read(inode), 236 mlog_bug_on_msg(le64_to_cpu(fe->i_size) != i_size_read(inode),
236 "Inode %"MLFu64", inode i_size = %lld != di " 237 "Inode %llu, inode i_size = %lld != di "
237 "i_size = %"MLFu64", i_flags = 0x%x\n", 238 "i_size = %llu, i_flags = 0x%x\n",
238 OCFS2_I(inode)->ip_blkno, 239 (unsigned long long)OCFS2_I(inode)->ip_blkno,
239 i_size_read(inode), 240 i_size_read(inode),
240 le64_to_cpu(fe->i_size), le32_to_cpu(fe->i_flags)); 241 (unsigned long long)le64_to_cpu(fe->i_size),
242 le32_to_cpu(fe->i_flags));
241 243
242 if (new_i_size > le64_to_cpu(fe->i_size)) { 244 if (new_i_size > le64_to_cpu(fe->i_size)) {
243 mlog(0, "asked to truncate file with size (%"MLFu64") " 245 mlog(0, "asked to truncate file with size (%llu) to size (%llu)!\n",
244 "to size (%"MLFu64")!\n", 246 (unsigned long long)le64_to_cpu(fe->i_size),
245 le64_to_cpu(fe->i_size), new_i_size); 247 (unsigned long long)new_i_size);
246 status = -EINVAL; 248 status = -EINVAL;
247 mlog_errno(status); 249 mlog_errno(status);
248 goto bail; 250 goto bail;
249 } 251 }
250 252
251 mlog(0, "inode %"MLFu64", i_size = %"MLFu64", new_i_size = %"MLFu64"\n", 253 mlog(0, "inode %llu, i_size = %llu, new_i_size = %llu\n",
252 le64_to_cpu(fe->i_blkno), le64_to_cpu(fe->i_size), new_i_size); 254 (unsigned long long)le64_to_cpu(fe->i_blkno),
255 (unsigned long long)le64_to_cpu(fe->i_size),
256 (unsigned long long)new_i_size);
253 257
254 /* lets handle the simple truncate cases before doing any more 258 /* lets handle the simple truncate cases before doing any more
255 * cluster locking. */ 259 * cluster locking. */
@@ -378,8 +382,8 @@ int ocfs2_do_extend_allocation(struct ocfs2_super *osb,
378 } 382 }
379 383
380 block = ocfs2_clusters_to_blocks(osb->sb, bit_off); 384 block = ocfs2_clusters_to_blocks(osb->sb, bit_off);
381 mlog(0, "Allocating %u clusters at block %u for inode %"MLFu64"\n", 385 mlog(0, "Allocating %u clusters at block %u for inode %llu\n",
382 num_bits, bit_off, OCFS2_I(inode)->ip_blkno); 386 num_bits, bit_off, (unsigned long long)OCFS2_I(inode)->ip_blkno);
383 status = ocfs2_insert_extent(osb, handle, inode, fe_bh, block, 387 status = ocfs2_insert_extent(osb, handle, inode, fe_bh, block,
384 num_bits, meta_ac); 388 num_bits, meta_ac);
385 if (status < 0) { 389 if (status < 0) {
@@ -449,9 +453,9 @@ static int ocfs2_extend_allocation(struct inode *inode,
449restart_all: 453restart_all:
450 BUG_ON(le32_to_cpu(fe->i_clusters) != OCFS2_I(inode)->ip_clusters); 454 BUG_ON(le32_to_cpu(fe->i_clusters) != OCFS2_I(inode)->ip_clusters);
451 455
452 mlog(0, "extend inode %"MLFu64", i_size = %lld, fe->i_clusters = %u, " 456 mlog(0, "extend inode %llu, i_size = %lld, fe->i_clusters = %u, "
453 "clusters_to_add = %u\n", 457 "clusters_to_add = %u\n",
454 OCFS2_I(inode)->ip_blkno, i_size_read(inode), 458 (unsigned long long)OCFS2_I(inode)->ip_blkno, i_size_read(inode),
455 fe->i_clusters, clusters_to_add); 459 fe->i_clusters, clusters_to_add);
456 460
457 handle = ocfs2_alloc_handle(osb); 461 handle = ocfs2_alloc_handle(osb);
@@ -569,8 +573,8 @@ restarted_transaction:
569 } 573 }
570 } 574 }
571 575
572 mlog(0, "fe: i_clusters = %u, i_size=%"MLFu64"\n", 576 mlog(0, "fe: i_clusters = %u, i_size=%llu\n",
573 fe->i_clusters, fe->i_size); 577 fe->i_clusters, (unsigned long long)fe->i_size);
574 mlog(0, "inode: ip_clusters=%u, i_size=%lld\n", 578 mlog(0, "inode: ip_clusters=%u, i_size=%lld\n",
575 OCFS2_I(inode)->ip_clusters, i_size_read(inode)); 579 OCFS2_I(inode)->ip_clusters, i_size_read(inode));
576 580
@@ -865,8 +869,8 @@ static int ocfs2_write_remove_suid(struct inode *inode)
865 struct ocfs2_super *osb = OCFS2_SB(inode->i_sb); 869 struct ocfs2_super *osb = OCFS2_SB(inode->i_sb);
866 struct ocfs2_dinode *di; 870 struct ocfs2_dinode *di;
867 871
868 mlog_entry("(Inode %"MLFu64", mode 0%o)\n", oi->ip_blkno, 872 mlog_entry("(Inode %llu, mode 0%o)\n",
869 inode->i_mode); 873 (unsigned long long)oi->ip_blkno, inode->i_mode);
870 874
871 handle = ocfs2_start_trans(osb, NULL, OCFS2_INODE_UPDATE_CREDITS); 875 handle = ocfs2_start_trans(osb, NULL, OCFS2_INODE_UPDATE_CREDITS);
872 if (handle == NULL) { 876 if (handle == NULL) {
@@ -1172,7 +1176,7 @@ struct inode_operations ocfs2_special_file_iops = {
1172 .getattr = ocfs2_getattr, 1176 .getattr = ocfs2_getattr,
1173}; 1177};
1174 1178
1175struct file_operations ocfs2_fops = { 1179const struct file_operations ocfs2_fops = {
1176 .read = do_sync_read, 1180 .read = do_sync_read,
1177 .write = do_sync_write, 1181 .write = do_sync_write,
1178 .sendfile = generic_file_sendfile, 1182 .sendfile = generic_file_sendfile,
@@ -1184,7 +1188,7 @@ struct file_operations ocfs2_fops = {
1184 .aio_write = ocfs2_file_aio_write, 1188 .aio_write = ocfs2_file_aio_write,
1185}; 1189};
1186 1190
1187struct file_operations ocfs2_dops = { 1191const struct file_operations ocfs2_dops = {
1188 .read = generic_read_dir, 1192 .read = generic_read_dir,
1189 .readdir = ocfs2_readdir, 1193 .readdir = ocfs2_readdir,
1190 .fsync = ocfs2_sync_file, 1194 .fsync = ocfs2_sync_file,
diff --git a/fs/ocfs2/file.h b/fs/ocfs2/file.h
index a5ea33b24060..740c9e7ca599 100644
--- a/fs/ocfs2/file.h
+++ b/fs/ocfs2/file.h
@@ -26,8 +26,8 @@
26#ifndef OCFS2_FILE_H 26#ifndef OCFS2_FILE_H
27#define OCFS2_FILE_H 27#define OCFS2_FILE_H
28 28
29extern struct file_operations ocfs2_fops; 29extern const struct file_operations ocfs2_fops;
30extern struct file_operations ocfs2_dops; 30extern const struct file_operations ocfs2_dops;
31extern struct inode_operations ocfs2_file_iops; 31extern struct inode_operations ocfs2_file_iops;
32extern struct inode_operations ocfs2_special_file_iops; 32extern struct inode_operations ocfs2_special_file_iops;
33struct ocfs2_alloc_context; 33struct ocfs2_alloc_context;
diff --git a/fs/ocfs2/inode.c b/fs/ocfs2/inode.c
index 315472a5c192..327a5b7b86ed 100644
--- a/fs/ocfs2/inode.c
+++ b/fs/ocfs2/inode.c
@@ -95,7 +95,7 @@ struct inode *ocfs2_iget(struct ocfs2_super *osb, u64 blkno)
95 struct super_block *sb = osb->sb; 95 struct super_block *sb = osb->sb;
96 struct ocfs2_find_inode_args args; 96 struct ocfs2_find_inode_args args;
97 97
98 mlog_entry("(blkno = %"MLFu64")\n", blkno); 98 mlog_entry("(blkno = %llu)\n", (unsigned long long)blkno);
99 99
100 /* Ok. By now we've either got the offsets passed to us by the 100 /* Ok. By now we've either got the offsets passed to us by the
101 * caller, or we just pulled them off the bh. Lets do some 101 * caller, or we just pulled them off the bh. Lets do some
@@ -134,8 +134,8 @@ struct inode *ocfs2_iget(struct ocfs2_super *osb, u64 blkno)
134 134
135bail: 135bail:
136 if (!IS_ERR(inode)) { 136 if (!IS_ERR(inode)) {
137 mlog(0, "returning inode with number %"MLFu64"\n", 137 mlog(0, "returning inode with number %llu\n",
138 OCFS2_I(inode)->ip_blkno); 138 (unsigned long long)OCFS2_I(inode)->ip_blkno);
139 mlog_exit_ptr(inode); 139 mlog_exit_ptr(inode);
140 } else 140 } else
141 mlog_errno(PTR_ERR(inode)); 141 mlog_errno(PTR_ERR(inode));
@@ -219,7 +219,8 @@ int ocfs2_populate_inode(struct inode *inode, struct ocfs2_dinode *fe,
219 struct ocfs2_super *osb; 219 struct ocfs2_super *osb;
220 int status = -EINVAL; 220 int status = -EINVAL;
221 221
222 mlog_entry("(0x%p, size:%"MLFu64")\n", inode, fe->i_size); 222 mlog_entry("(0x%p, size:%llu)\n", inode,
223 (unsigned long long)fe->i_size);
223 224
224 sb = inode->i_sb; 225 sb = inode->i_sb;
225 osb = OCFS2_SB(sb); 226 osb = OCFS2_SB(sb);
@@ -228,9 +229,10 @@ int ocfs2_populate_inode(struct inode *inode, struct ocfs2_dinode *fe,
228 * today. change if needed. */ 229 * today. change if needed. */
229 if (!OCFS2_IS_VALID_DINODE(fe) || 230 if (!OCFS2_IS_VALID_DINODE(fe) ||
230 !(fe->i_flags & cpu_to_le32(OCFS2_VALID_FL))) { 231 !(fe->i_flags & cpu_to_le32(OCFS2_VALID_FL))) {
231 mlog(ML_ERROR, "Invalid dinode: i_ino=%lu, i_blkno=%"MLFu64", " 232 mlog(ML_ERROR, "Invalid dinode: i_ino=%lu, i_blkno=%llu, "
232 "signature = %.*s, flags = 0x%x\n", 233 "signature = %.*s, flags = 0x%x\n",
233 inode->i_ino, le64_to_cpu(fe->i_blkno), 7, 234 inode->i_ino,
235 (unsigned long long)le64_to_cpu(fe->i_blkno), 7,
234 fe->i_signature, le32_to_cpu(fe->i_flags)); 236 fe->i_signature, le32_to_cpu(fe->i_flags));
235 goto bail; 237 goto bail;
236 } 238 }
@@ -268,8 +270,9 @@ int ocfs2_populate_inode(struct inode *inode, struct ocfs2_dinode *fe,
268 270
269 if (OCFS2_I(inode)->ip_blkno != le64_to_cpu(fe->i_blkno)) 271 if (OCFS2_I(inode)->ip_blkno != le64_to_cpu(fe->i_blkno))
270 mlog(ML_ERROR, 272 mlog(ML_ERROR,
271 "ip_blkno %"MLFu64" != i_blkno %"MLFu64"!\n", 273 "ip_blkno %llu != i_blkno %llu!\n",
272 OCFS2_I(inode)->ip_blkno, fe->i_blkno); 274 (unsigned long long)OCFS2_I(inode)->ip_blkno,
275 (unsigned long long)fe->i_blkno);
273 276
274 OCFS2_I(inode)->ip_clusters = le32_to_cpu(fe->i_clusters); 277 OCFS2_I(inode)->ip_clusters = le32_to_cpu(fe->i_clusters);
275 OCFS2_I(inode)->ip_orphaned_slot = OCFS2_INVALID_SLOT; 278 OCFS2_I(inode)->ip_orphaned_slot = OCFS2_INVALID_SLOT;
@@ -278,8 +281,8 @@ int ocfs2_populate_inode(struct inode *inode, struct ocfs2_dinode *fe,
278 inode->i_ino = ino_from_blkno(inode->i_sb, 281 inode->i_ino = ino_from_blkno(inode->i_sb,
279 le64_to_cpu(fe->i_blkno)); 282 le64_to_cpu(fe->i_blkno));
280 283
281 mlog(0, "blkno = %"MLFu64", ino = %lu, create_ino = %s\n", 284 mlog(0, "blkno = %llu, ino = %lu, create_ino = %s\n",
282 fe->i_blkno, inode->i_ino, create_ino ? "true" : "false"); 285 (unsigned long long)fe->i_blkno, inode->i_ino, create_ino ? "true" : "false");
283 286
284 inode->i_nlink = le16_to_cpu(fe->i_links_count); 287 inode->i_nlink = le16_to_cpu(fe->i_links_count);
285 288
@@ -371,8 +374,8 @@ static int ocfs2_read_locked_inode(struct inode *inode,
371 374
372 fe = (struct ocfs2_dinode *) bh->b_data; 375 fe = (struct ocfs2_dinode *) bh->b_data;
373 if (!OCFS2_IS_VALID_DINODE(fe)) { 376 if (!OCFS2_IS_VALID_DINODE(fe)) {
374 mlog(ML_ERROR, "Invalid dinode #%"MLFu64": signature = %.*s\n", 377 mlog(ML_ERROR, "Invalid dinode #%llu: signature = %.*s\n",
375 fe->i_blkno, 7, fe->i_signature); 378 (unsigned long long)fe->i_blkno, 7, fe->i_signature);
376 make_bad_inode(inode); 379 make_bad_inode(inode);
377 goto bail; 380 goto bail;
378 } 381 }
@@ -386,8 +389,8 @@ static int ocfs2_read_locked_inode(struct inode *inode,
386 389
387 status = -EINVAL; 390 status = -EINVAL;
388 if (ocfs2_populate_inode(inode, fe, 0) < 0) { 391 if (ocfs2_populate_inode(inode, fe, 0) < 0) {
389 mlog(ML_ERROR, "populate inode failed! i_blkno=%"MLFu64", " 392 mlog(ML_ERROR, "populate failed! i_blkno=%llu, i_ino=%lu\n",
390 "i_ino=%lu\n", fe->i_blkno, inode->i_ino); 393 (unsigned long long)fe->i_blkno, inode->i_ino);
391 make_bad_inode(inode); 394 make_bad_inode(inode);
392 goto bail; 395 goto bail;
393 } 396 }
@@ -675,8 +678,8 @@ static int ocfs2_inode_is_valid_to_delete(struct inode *inode)
675 * never get here as system file inodes should always have a 678 * never get here as system file inodes should always have a
676 * positive link count. */ 679 * positive link count. */
677 if (oi->ip_flags & OCFS2_INODE_SYSTEM_FILE) { 680 if (oi->ip_flags & OCFS2_INODE_SYSTEM_FILE) {
678 mlog(ML_ERROR, "Skipping delete of system file %"MLFu64".\n", 681 mlog(ML_ERROR, "Skipping delete of system file %llu\n",
679 oi->ip_blkno); 682 (unsigned long long)oi->ip_blkno);
680 goto bail_unlock; 683 goto bail_unlock;
681 } 684 }
682 685
@@ -715,16 +718,16 @@ static int ocfs2_query_inode_wipe(struct inode *inode,
715 * ocfs2_delete_inode, another node might have asked to delete 718 * ocfs2_delete_inode, another node might have asked to delete
716 * the inode. Recheck our flags to catch this. */ 719 * the inode. Recheck our flags to catch this. */
717 if (!ocfs2_inode_is_valid_to_delete(inode)) { 720 if (!ocfs2_inode_is_valid_to_delete(inode)) {
718 mlog(0, "Skipping delete of %"MLFu64" because flags changed\n", 721 mlog(0, "Skipping delete of %llu because flags changed\n",
719 oi->ip_blkno); 722 (unsigned long long)oi->ip_blkno);
720 goto bail; 723 goto bail;
721 } 724 }
722 725
723 /* Now that we have an up to date inode, we can double check 726 /* Now that we have an up to date inode, we can double check
724 * the link count. */ 727 * the link count. */
725 if (inode->i_nlink) { 728 if (inode->i_nlink) {
726 mlog(0, "Skipping delete of %"MLFu64" because nlink = %u\n", 729 mlog(0, "Skipping delete of %llu because nlink = %u\n",
727 oi->ip_blkno, inode->i_nlink); 730 (unsigned long long)oi->ip_blkno, inode->i_nlink);
728 goto bail; 731 goto bail;
729 } 732 }
730 733
@@ -734,9 +737,11 @@ static int ocfs2_query_inode_wipe(struct inode *inode,
734 /* for lack of a better error? */ 737 /* for lack of a better error? */
735 status = -EEXIST; 738 status = -EEXIST;
736 mlog(ML_ERROR, 739 mlog(ML_ERROR,
737 "Inode %"MLFu64" (on-disk %"MLFu64") not orphaned! " 740 "Inode %llu (on-disk %llu) not orphaned! "
738 "Disk flags 0x%x, inode flags 0x%x\n", 741 "Disk flags 0x%x, inode flags 0x%x\n",
739 oi->ip_blkno, di->i_blkno, di->i_flags, oi->ip_flags); 742 (unsigned long long)oi->ip_blkno,
743 (unsigned long long)di->i_blkno, di->i_flags,
744 oi->ip_flags);
740 goto bail; 745 goto bail;
741 } 746 }
742 747
@@ -753,8 +758,8 @@ static int ocfs2_query_inode_wipe(struct inode *inode,
753 * disk and let them worry about deleting it. */ 758 * disk and let them worry about deleting it. */
754 if (status == -EBUSY) { 759 if (status == -EBUSY) {
755 status = 0; 760 status = 0;
756 mlog(0, "Skipping delete of %"MLFu64" because it is in use on" 761 mlog(0, "Skipping delete of %llu because it is in use on"
757 "other nodes\n", oi->ip_blkno); 762 "other nodes\n", (unsigned long long)oi->ip_blkno);
758 goto bail; 763 goto bail;
759 } 764 }
760 if (status < 0) { 765 if (status < 0) {
@@ -768,13 +773,13 @@ static int ocfs2_query_inode_wipe(struct inode *inode,
768 * into. This may happen during node death and 773 * into. This may happen during node death and
769 * recovery knows how to clean it up so we can safely 774 * recovery knows how to clean it up so we can safely
770 * ignore this inode for now on. */ 775 * ignore this inode for now on. */
771 mlog(0, "Nobody knew where inode %"MLFu64" was orphaned!\n", 776 mlog(0, "Nobody knew where inode %llu was orphaned!\n",
772 oi->ip_blkno); 777 (unsigned long long)oi->ip_blkno);
773 } else { 778 } else {
774 *wipe = 1; 779 *wipe = 1;
775 780
776 mlog(0, "Inode %"MLFu64" is ok to wipe from orphan dir %d\n", 781 mlog(0, "Inode %llu is ok to wipe from orphan dir %d\n",
777 oi->ip_blkno, oi->ip_orphaned_slot); 782 (unsigned long long)oi->ip_blkno, oi->ip_orphaned_slot);
778 } 783 }
779 spin_unlock(&oi->ip_lock); 784 spin_unlock(&oi->ip_lock);
780 785
@@ -788,8 +793,8 @@ bail:
788static void ocfs2_cleanup_delete_inode(struct inode *inode, 793static void ocfs2_cleanup_delete_inode(struct inode *inode,
789 int sync_data) 794 int sync_data)
790{ 795{
791 mlog(0, "Cleanup inode %"MLFu64", sync = %d\n", 796 mlog(0, "Cleanup inode %llu, sync = %d\n",
792 OCFS2_I(inode)->ip_blkno, sync_data); 797 (unsigned long long)OCFS2_I(inode)->ip_blkno, sync_data);
793 if (sync_data) 798 if (sync_data)
794 write_inode_now(inode, 1); 799 write_inode_now(inode, 1);
795 truncate_inode_pages(&inode->i_data, 0); 800 truncate_inode_pages(&inode->i_data, 0);
@@ -897,8 +902,8 @@ void ocfs2_clear_inode(struct inode *inode)
897 if (!inode) 902 if (!inode)
898 goto bail; 903 goto bail;
899 904
900 mlog(0, "Clearing inode: %"MLFu64", nlink = %u\n", 905 mlog(0, "Clearing inode: %llu, nlink = %u\n",
901 OCFS2_I(inode)->ip_blkno, inode->i_nlink); 906 (unsigned long long)OCFS2_I(inode)->ip_blkno, inode->i_nlink);
902 907
903 mlog_bug_on_msg(OCFS2_SB(inode->i_sb) == NULL, 908 mlog_bug_on_msg(OCFS2_SB(inode->i_sb) == NULL,
904 "Inode=%lu\n", inode->i_ino); 909 "Inode=%lu\n", inode->i_ino);
@@ -919,8 +924,8 @@ void ocfs2_clear_inode(struct inode *inode)
919 ocfs2_checkpoint_inode(inode); 924 ocfs2_checkpoint_inode(inode);
920 925
921 mlog_bug_on_msg(!list_empty(&oi->ip_io_markers), 926 mlog_bug_on_msg(!list_empty(&oi->ip_io_markers),
922 "Clear inode of %"MLFu64", inode has io markers\n", 927 "Clear inode of %llu, inode has io markers\n",
923 oi->ip_blkno); 928 (unsigned long long)oi->ip_blkno);
924 929
925 ocfs2_extent_map_drop(inode, 0); 930 ocfs2_extent_map_drop(inode, 0);
926 ocfs2_extent_map_init(inode); 931 ocfs2_extent_map_init(inode);
@@ -936,20 +941,20 @@ void ocfs2_clear_inode(struct inode *inode)
936 ocfs2_metadata_cache_purge(inode); 941 ocfs2_metadata_cache_purge(inode);
937 942
938 mlog_bug_on_msg(oi->ip_metadata_cache.ci_num_cached, 943 mlog_bug_on_msg(oi->ip_metadata_cache.ci_num_cached,
939 "Clear inode of %"MLFu64", inode has %u cache items\n", 944 "Clear inode of %llu, inode has %u cache items\n",
940 oi->ip_blkno, oi->ip_metadata_cache.ci_num_cached); 945 (unsigned long long)oi->ip_blkno, oi->ip_metadata_cache.ci_num_cached);
941 946
942 mlog_bug_on_msg(!(oi->ip_flags & OCFS2_INODE_CACHE_INLINE), 947 mlog_bug_on_msg(!(oi->ip_flags & OCFS2_INODE_CACHE_INLINE),
943 "Clear inode of %"MLFu64", inode has a bad flag\n", 948 "Clear inode of %llu, inode has a bad flag\n",
944 oi->ip_blkno); 949 (unsigned long long)oi->ip_blkno);
945 950
946 mlog_bug_on_msg(spin_is_locked(&oi->ip_lock), 951 mlog_bug_on_msg(spin_is_locked(&oi->ip_lock),
947 "Clear inode of %"MLFu64", inode is locked\n", 952 "Clear inode of %llu, inode is locked\n",
948 oi->ip_blkno); 953 (unsigned long long)oi->ip_blkno);
949 954
950 mlog_bug_on_msg(!mutex_trylock(&oi->ip_io_mutex), 955 mlog_bug_on_msg(!mutex_trylock(&oi->ip_io_mutex),
951 "Clear inode of %"MLFu64", io_mutex is locked\n", 956 "Clear inode of %llu, io_mutex is locked\n",
952 oi->ip_blkno); 957 (unsigned long long)oi->ip_blkno);
953 mutex_unlock(&oi->ip_io_mutex); 958 mutex_unlock(&oi->ip_io_mutex);
954 959
955 /* 960 /*
@@ -957,19 +962,19 @@ void ocfs2_clear_inode(struct inode *inode)
957 * kernel 1, world 0 962 * kernel 1, world 0
958 */ 963 */
959 mlog_bug_on_msg(!down_write_trylock(&oi->ip_alloc_sem), 964 mlog_bug_on_msg(!down_write_trylock(&oi->ip_alloc_sem),
960 "Clear inode of %"MLFu64", alloc_sem is locked\n", 965 "Clear inode of %llu, alloc_sem is locked\n",
961 oi->ip_blkno); 966 (unsigned long long)oi->ip_blkno);
962 up_write(&oi->ip_alloc_sem); 967 up_write(&oi->ip_alloc_sem);
963 968
964 mlog_bug_on_msg(oi->ip_open_count, 969 mlog_bug_on_msg(oi->ip_open_count,
965 "Clear inode of %"MLFu64" has open count %d\n", 970 "Clear inode of %llu has open count %d\n",
966 oi->ip_blkno, oi->ip_open_count); 971 (unsigned long long)oi->ip_blkno, oi->ip_open_count);
967 mlog_bug_on_msg(!list_empty(&oi->ip_handle_list), 972 mlog_bug_on_msg(!list_empty(&oi->ip_handle_list),
968 "Clear inode of %"MLFu64" has non empty handle list\n", 973 "Clear inode of %llu has non empty handle list\n",
969 oi->ip_blkno); 974 (unsigned long long)oi->ip_blkno);
970 mlog_bug_on_msg(oi->ip_handle, 975 mlog_bug_on_msg(oi->ip_handle,
971 "Clear inode of %"MLFu64" has non empty handle pointer\n", 976 "Clear inode of %llu has non empty handle pointer\n",
972 oi->ip_blkno); 977 (unsigned long long)oi->ip_blkno);
973 978
974 /* Clear all other flags. */ 979 /* Clear all other flags. */
975 oi->ip_flags = OCFS2_INODE_CACHE_INLINE; 980 oi->ip_flags = OCFS2_INODE_CACHE_INLINE;
@@ -991,8 +996,8 @@ void ocfs2_drop_inode(struct inode *inode)
991 996
992 mlog_entry_void(); 997 mlog_entry_void();
993 998
994 mlog(0, "Drop inode %"MLFu64", nlink = %u, ip_flags = 0x%x\n", 999 mlog(0, "Drop inode %llu, nlink = %u, ip_flags = 0x%x\n",
995 oi->ip_blkno, inode->i_nlink, oi->ip_flags); 1000 (unsigned long long)oi->ip_blkno, inode->i_nlink, oi->ip_flags);
996 1001
997 /* Testing ip_orphaned_slot here wouldn't work because we may 1002 /* Testing ip_orphaned_slot here wouldn't work because we may
998 * not have gotten a delete_inode vote from any other nodes 1003 * not have gotten a delete_inode vote from any other nodes
@@ -1069,8 +1074,8 @@ int ocfs2_inode_revalidate(struct dentry *dentry)
1069 struct inode *inode = dentry->d_inode; 1074 struct inode *inode = dentry->d_inode;
1070 int status = 0; 1075 int status = 0;
1071 1076
1072 mlog_entry("(inode = 0x%p, ino = %"MLFu64")\n", inode, 1077 mlog_entry("(inode = 0x%p, ino = %llu)\n", inode,
1073 inode ? OCFS2_I(inode)->ip_blkno : 0ULL); 1078 inode ? (unsigned long long)OCFS2_I(inode)->ip_blkno : 0ULL);
1074 1079
1075 if (!inode) { 1080 if (!inode) {
1076 mlog(0, "eep, no inode!\n"); 1081 mlog(0, "eep, no inode!\n");
@@ -1114,7 +1119,8 @@ int ocfs2_mark_inode_dirty(struct ocfs2_journal_handle *handle,
1114 int status; 1119 int status;
1115 struct ocfs2_dinode *fe = (struct ocfs2_dinode *) bh->b_data; 1120 struct ocfs2_dinode *fe = (struct ocfs2_dinode *) bh->b_data;
1116 1121
1117 mlog_entry("(inode %"MLFu64")\n", OCFS2_I(inode)->ip_blkno); 1122 mlog_entry("(inode %llu)\n",
1123 (unsigned long long)OCFS2_I(inode)->ip_blkno);
1118 1124
1119 status = ocfs2_journal_access(handle, inode, bh, 1125 status = ocfs2_journal_access(handle, inode, bh,
1120 OCFS2_JOURNAL_ACCESS_WRITE); 1126 OCFS2_JOURNAL_ACCESS_WRITE);
diff --git a/fs/ocfs2/journal.c b/fs/ocfs2/journal.c
index 4be801f4559b..6a610ae53583 100644
--- a/fs/ocfs2/journal.c
+++ b/fs/ocfs2/journal.c
@@ -377,7 +377,7 @@ int ocfs2_journal_access(struct ocfs2_journal_handle *handle,
377 BUG_ON(!bh); 377 BUG_ON(!bh);
378 BUG_ON(!(handle->flags & OCFS2_HANDLE_STARTED)); 378 BUG_ON(!(handle->flags & OCFS2_HANDLE_STARTED));
379 379
380 mlog_entry("bh->b_blocknr=%llu, type=%d (\"%s\"), bh->b_size = %hu\n", 380 mlog_entry("bh->b_blocknr=%llu, type=%d (\"%s\"), bh->b_size = %zu\n",
381 (unsigned long long)bh->b_blocknr, type, 381 (unsigned long long)bh->b_blocknr, type,
382 (type == OCFS2_JOURNAL_ACCESS_CREATE) ? 382 (type == OCFS2_JOURNAL_ACCESS_CREATE) ?
383 "OCFS2_JOURNAL_ACCESS_CREATE" : 383 "OCFS2_JOURNAL_ACCESS_CREATE" :
@@ -503,8 +503,8 @@ static void ocfs2_handle_cleanup_locks(struct ocfs2_journal *journal,
503 ocfs2_meta_unlock(inode, 1); 503 ocfs2_meta_unlock(inode, 1);
504 if (atomic_read(&inode->i_count) == 1) 504 if (atomic_read(&inode->i_count) == 1)
505 mlog(ML_ERROR, 505 mlog(ML_ERROR,
506 "Inode %"MLFu64", I'm doing a last iput for!", 506 "Inode %llu, I'm doing a last iput for!",
507 OCFS2_I(inode)->ip_blkno); 507 (unsigned long long)OCFS2_I(inode)->ip_blkno);
508 iput(inode); 508 iput(inode);
509 kmem_cache_free(ocfs2_lock_cache, lock); 509 kmem_cache_free(ocfs2_lock_cache, lock);
510 } 510 }
@@ -582,7 +582,8 @@ int ocfs2_journal_init(struct ocfs2_journal *journal, int *dirty)
582 } 582 }
583 583
584 mlog(0, "inode->i_size = %lld\n", inode->i_size); 584 mlog(0, "inode->i_size = %lld\n", inode->i_size);
585 mlog(0, "inode->i_blocks = %lu\n", inode->i_blocks); 585 mlog(0, "inode->i_blocks = %llu\n",
586 (unsigned long long)inode->i_blocks);
586 mlog(0, "inode->ip_clusters = %u\n", OCFS2_I(inode)->ip_clusters); 587 mlog(0, "inode->ip_clusters = %u\n", OCFS2_I(inode)->ip_clusters);
587 588
588 /* call the kernels journal init function now */ 589 /* call the kernels journal init function now */
@@ -640,8 +641,9 @@ static int ocfs2_journal_toggle_dirty(struct ocfs2_super *osb,
640 /* This is called from startup/shutdown which will 641 /* This is called from startup/shutdown which will
641 * handle the errors in a specific manner, so no need 642 * handle the errors in a specific manner, so no need
642 * to call ocfs2_error() here. */ 643 * to call ocfs2_error() here. */
643 mlog(ML_ERROR, "Journal dinode %"MLFu64" has invalid " 644 mlog(ML_ERROR, "Journal dinode %llu has invalid "
644 "signature: %.*s", fe->i_blkno, 7, fe->i_signature); 645 "signature: %.*s", (unsigned long long)fe->i_blkno, 7,
646 fe->i_signature);
645 status = -EIO; 647 status = -EIO;
646 goto out; 648 goto out;
647 } 649 }
@@ -849,8 +851,9 @@ static int ocfs2_force_read_journal(struct inode *inode)
849 851
850 memset(bhs, 0, sizeof(struct buffer_head *) * CONCURRENT_JOURNAL_FILL); 852 memset(bhs, 0, sizeof(struct buffer_head *) * CONCURRENT_JOURNAL_FILL);
851 853
852 mlog(0, "Force reading %lu blocks\n", 854 mlog(0, "Force reading %llu blocks\n",
853 (inode->i_blocks >> (inode->i_sb->s_blocksize_bits - 9))); 855 (unsigned long long)(inode->i_blocks >>
856 (inode->i_sb->s_blocksize_bits - 9)));
854 857
855 v_blkno = 0; 858 v_blkno = 0;
856 while (v_blkno < 859 while (v_blkno <
@@ -934,8 +937,8 @@ void ocfs2_complete_recovery(void *data)
934 937
935 la_dinode = item->lri_la_dinode; 938 la_dinode = item->lri_la_dinode;
936 if (la_dinode) { 939 if (la_dinode) {
937 mlog(0, "Clean up local alloc %"MLFu64"\n", 940 mlog(0, "Clean up local alloc %llu\n",
938 la_dinode->i_blkno); 941 (unsigned long long)la_dinode->i_blkno);
939 942
940 ret = ocfs2_complete_local_alloc_recovery(osb, 943 ret = ocfs2_complete_local_alloc_recovery(osb,
941 la_dinode); 944 la_dinode);
@@ -947,8 +950,8 @@ void ocfs2_complete_recovery(void *data)
947 950
948 tl_dinode = item->lri_tl_dinode; 951 tl_dinode = item->lri_tl_dinode;
949 if (tl_dinode) { 952 if (tl_dinode) {
950 mlog(0, "Clean up truncate log %"MLFu64"\n", 953 mlog(0, "Clean up truncate log %llu\n",
951 tl_dinode->i_blkno); 954 (unsigned long long)tl_dinode->i_blkno);
952 955
953 ret = ocfs2_complete_truncate_log_recovery(osb, 956 ret = ocfs2_complete_truncate_log_recovery(osb,
954 tl_dinode); 957 tl_dinode);
@@ -1473,11 +1476,11 @@ static int ocfs2_queue_orphans(struct ocfs2_super *osb,
1473 if (de->file_type > OCFS2_FT_MAX) { 1476 if (de->file_type > OCFS2_FT_MAX) {
1474 mlog(ML_ERROR, 1477 mlog(ML_ERROR,
1475 "block %llu contains invalid de: " 1478 "block %llu contains invalid de: "
1476 "inode = %"MLFu64", rec_len = %u, " 1479 "inode = %llu, rec_len = %u, "
1477 "name_len = %u, file_type = %u, " 1480 "name_len = %u, file_type = %u, "
1478 "name='%.*s'\n", 1481 "name='%.*s'\n",
1479 (unsigned long long)bh->b_blocknr, 1482 (unsigned long long)bh->b_blocknr,
1480 le64_to_cpu(de->inode), 1483 (unsigned long long)le64_to_cpu(de->inode),
1481 le16_to_cpu(de->rec_len), 1484 le16_to_cpu(de->rec_len),
1482 de->name_len, 1485 de->name_len,
1483 de->file_type, 1486 de->file_type,
@@ -1494,8 +1497,8 @@ static int ocfs2_queue_orphans(struct ocfs2_super *osb,
1494 if (IS_ERR(iter)) 1497 if (IS_ERR(iter))
1495 continue; 1498 continue;
1496 1499
1497 mlog(0, "queue orphan %"MLFu64"\n", 1500 mlog(0, "queue orphan %llu\n",
1498 OCFS2_I(iter)->ip_blkno); 1501 (unsigned long long)OCFS2_I(iter)->ip_blkno);
1499 /* No locking is required for the next_orphan 1502 /* No locking is required for the next_orphan
1500 * queue as there is only ever a single 1503 * queue as there is only ever a single
1501 * process doing orphan recovery. */ 1504 * process doing orphan recovery. */
@@ -1588,7 +1591,7 @@ static int ocfs2_recover_orphans(struct ocfs2_super *osb,
1588 1591
1589 while (inode) { 1592 while (inode) {
1590 oi = OCFS2_I(inode); 1593 oi = OCFS2_I(inode);
1591 mlog(0, "iput orphan %"MLFu64"\n", oi->ip_blkno); 1594 mlog(0, "iput orphan %llu\n", (unsigned long long)oi->ip_blkno);
1592 1595
1593 iter = oi->ip_next_orphan; 1596 iter = oi->ip_next_orphan;
1594 1597
diff --git a/fs/ocfs2/localalloc.c b/fs/ocfs2/localalloc.c
index 149b35181666..0d1973ea32b0 100644
--- a/fs/ocfs2/localalloc.c
+++ b/fs/ocfs2/localalloc.c
@@ -143,8 +143,8 @@ int ocfs2_load_local_alloc(struct ocfs2_super *osb)
143 143
144 if (!(le32_to_cpu(alloc->i_flags) & 144 if (!(le32_to_cpu(alloc->i_flags) &
145 (OCFS2_LOCAL_ALLOC_FL|OCFS2_BITMAP_FL))) { 145 (OCFS2_LOCAL_ALLOC_FL|OCFS2_BITMAP_FL))) {
146 mlog(ML_ERROR, "Invalid local alloc inode, %"MLFu64"\n", 146 mlog(ML_ERROR, "Invalid local alloc inode, %llu\n",
147 OCFS2_I(inode)->ip_blkno); 147 (unsigned long long)OCFS2_I(inode)->ip_blkno);
148 status = -EINVAL; 148 status = -EINVAL;
149 goto bail; 149 goto bail;
150 } 150 }
@@ -493,9 +493,9 @@ int ocfs2_reserve_local_alloc_bits(struct ocfs2_super *osb,
493 493
494 if (le32_to_cpu(alloc->id1.bitmap1.i_used) != 494 if (le32_to_cpu(alloc->id1.bitmap1.i_used) !=
495 ocfs2_local_alloc_count_bits(alloc)) { 495 ocfs2_local_alloc_count_bits(alloc)) {
496 ocfs2_error(osb->sb, "local alloc inode %"MLFu64" says it has " 496 ocfs2_error(osb->sb, "local alloc inode %llu says it has "
497 "%u free bits, but a count shows %u", 497 "%u free bits, but a count shows %u",
498 le64_to_cpu(alloc->i_blkno), 498 (unsigned long long)le64_to_cpu(alloc->i_blkno),
499 le32_to_cpu(alloc->id1.bitmap1.i_used), 499 le32_to_cpu(alloc->id1.bitmap1.i_used),
500 ocfs2_local_alloc_count_bits(alloc)); 500 ocfs2_local_alloc_count_bits(alloc));
501 status = -EIO; 501 status = -EIO;
@@ -753,10 +753,11 @@ static int ocfs2_sync_local_to_main(struct ocfs2_super *osb,
753 ocfs2_clusters_to_blocks(osb->sb, 753 ocfs2_clusters_to_blocks(osb->sb,
754 start - count); 754 start - count);
755 755
756 mlog(0, "freeing %u bits starting at local " 756 mlog(0, "freeing %u bits starting at local alloc bit "
757 "alloc bit %u (la_start_blk = %"MLFu64", " 757 "%u (la_start_blk = %llu, blkno = %llu)\n",
758 "blkno = %"MLFu64")\n", count, start - count, 758 count, start - count,
759 la_start_blk, blkno); 759 (unsigned long long)la_start_blk,
760 (unsigned long long)blkno);
760 761
761 status = ocfs2_free_clusters(handle, main_bm_inode, 762 status = ocfs2_free_clusters(handle, main_bm_inode,
762 main_bm_bh, blkno, count); 763 main_bm_bh, blkno, count);
diff --git a/fs/ocfs2/namei.c b/fs/ocfs2/namei.c
index f6b77ff1d2bf..0673862c8bdd 100644
--- a/fs/ocfs2/namei.c
+++ b/fs/ocfs2/namei.c
@@ -161,8 +161,8 @@ static struct dentry *ocfs2_lookup(struct inode *dir, struct dentry *dentry,
161 goto bail; 161 goto bail;
162 } 162 }
163 163
164 mlog(0, "find name %.*s in directory %"MLFu64"\n", dentry->d_name.len, 164 mlog(0, "find name %.*s in directory %llu\n", dentry->d_name.len,
165 dentry->d_name.name, OCFS2_I(dir)->ip_blkno); 165 dentry->d_name.name, (unsigned long long)OCFS2_I(dir)->ip_blkno);
166 166
167 status = ocfs2_meta_lock(dir, NULL, NULL, 0); 167 status = ocfs2_meta_lock(dir, NULL, NULL, 0);
168 if (status < 0) { 168 if (status < 0) {
@@ -180,7 +180,8 @@ static struct dentry *ocfs2_lookup(struct inode *dir, struct dentry *dentry,
180 180
181 inode = ocfs2_iget(OCFS2_SB(dir->i_sb), blkno); 181 inode = ocfs2_iget(OCFS2_SB(dir->i_sb), blkno);
182 if (IS_ERR(inode)) { 182 if (IS_ERR(inode)) {
183 mlog(ML_ERROR, "Unable to create inode %"MLFu64"\n", blkno); 183 mlog(ML_ERROR, "Unable to create inode %llu\n",
184 (unsigned long long)blkno);
184 ret = ERR_PTR(-EACCES); 185 ret = ERR_PTR(-EACCES);
185 goto bail_unlock; 186 goto bail_unlock;
186 } 187 }
@@ -310,8 +311,8 @@ static int ocfs2_mknod(struct inode *dir,
310 osb = OCFS2_SB(dir->i_sb); 311 osb = OCFS2_SB(dir->i_sb);
311 312
312 if (S_ISDIR(mode) && (dir->i_nlink >= OCFS2_LINK_MAX)) { 313 if (S_ISDIR(mode) && (dir->i_nlink >= OCFS2_LINK_MAX)) {
313 mlog(ML_ERROR, "inode %"MLFu64" has i_nlink of %u\n", 314 mlog(ML_ERROR, "inode %llu has i_nlink of %u\n",
314 OCFS2_I(dir)->ip_blkno, dir->i_nlink); 315 (unsigned long long)OCFS2_I(dir)->ip_blkno, dir->i_nlink);
315 status = -EMLINK; 316 status = -EMLINK;
316 goto leave; 317 goto leave;
317 } 318 }
@@ -562,9 +563,9 @@ static int ocfs2_mknod_locked(struct ocfs2_super *osb,
562 563
563 if (ocfs2_populate_inode(inode, fe, 1) < 0) { 564 if (ocfs2_populate_inode(inode, fe, 1) < 0) {
564 mlog(ML_ERROR, "populate inode failed! bh->b_blocknr=%llu, " 565 mlog(ML_ERROR, "populate inode failed! bh->b_blocknr=%llu, "
565 "i_blkno=%"MLFu64", i_ino=%lu\n", 566 "i_blkno=%llu, i_ino=%lu\n",
566 (unsigned long long) (*new_fe_bh)->b_blocknr, 567 (unsigned long long) (*new_fe_bh)->b_blocknr,
567 fe->i_blkno, inode->i_ino); 568 (unsigned long long)fe->i_blkno, inode->i_ino);
568 BUG(); 569 BUG();
569 } 570 }
570 571
@@ -765,7 +766,7 @@ static int ocfs2_unlink(struct inode *dir,
765 766
766 BUG_ON(dentry->d_parent->d_inode != dir); 767 BUG_ON(dentry->d_parent->d_inode != dir);
767 768
768 mlog(0, "ino = %"MLFu64"\n", OCFS2_I(inode)->ip_blkno); 769 mlog(0, "ino = %llu\n", (unsigned long long)OCFS2_I(inode)->ip_blkno);
769 770
770 if (inode == osb->root_inode) { 771 if (inode == osb->root_inode) {
771 mlog(0, "Cannot delete the root directory\n"); 772 mlog(0, "Cannot delete the root directory\n");
@@ -799,9 +800,9 @@ static int ocfs2_unlink(struct inode *dir,
799 if (OCFS2_I(inode)->ip_blkno != blkno) { 800 if (OCFS2_I(inode)->ip_blkno != blkno) {
800 status = -ENOENT; 801 status = -ENOENT;
801 802
802 mlog(0, "ip_blkno (%"MLFu64") != dirent blkno (%"MLFu64") " 803 mlog(0, "ip_blkno %llu != dirent blkno %llu ip_flags = %x\n",
803 "ip_flags = %x\n", OCFS2_I(inode)->ip_blkno, blkno, 804 (unsigned long long)OCFS2_I(inode)->ip_blkno,
804 OCFS2_I(inode)->ip_flags); 805 (unsigned long long)blkno, OCFS2_I(inode)->ip_flags);
805 goto leave; 806 goto leave;
806 } 807 }
807 808
@@ -946,8 +947,9 @@ static int ocfs2_double_lock(struct ocfs2_super *osb,
946 struct buffer_head **tmpbh; 947 struct buffer_head **tmpbh;
947 struct inode *tmpinode; 948 struct inode *tmpinode;
948 949
949 mlog_entry("(inode1 = %"MLFu64", inode2 = %"MLFu64")\n", 950 mlog_entry("(inode1 = %llu, inode2 = %llu)\n",
950 oi1->ip_blkno, oi2->ip_blkno); 951 (unsigned long long)oi1->ip_blkno,
952 (unsigned long long)oi2->ip_blkno);
951 953
952 BUG_ON(!handle); 954 BUG_ON(!handle);
953 955
@@ -1187,9 +1189,9 @@ static int ocfs2_rename(struct inode *old_dir,
1187 if (OCFS2_I(new_inode)->ip_blkno != newfe_blkno) { 1189 if (OCFS2_I(new_inode)->ip_blkno != newfe_blkno) {
1188 status = -EACCES; 1190 status = -EACCES;
1189 1191
1190 mlog(0, "Inode blkno (%"MLFu64") and dir (%"MLFu64") " 1192 mlog(0, "Inode %llu and dir %llu disagree. flags = %x\n",
1191 "disagree. ip_flags = %x\n", 1193 (unsigned long long)OCFS2_I(new_inode)->ip_blkno,
1192 OCFS2_I(new_inode)->ip_blkno, newfe_blkno, 1194 (unsigned long long)newfe_blkno,
1193 OCFS2_I(new_inode)->ip_flags); 1195 OCFS2_I(new_inode)->ip_flags);
1194 goto bail; 1196 goto bail;
1195 } 1197 }
@@ -1215,9 +1217,9 @@ static int ocfs2_rename(struct inode *old_dir,
1215 1217
1216 newfe = (struct ocfs2_dinode *) newfe_bh->b_data; 1218 newfe = (struct ocfs2_dinode *) newfe_bh->b_data;
1217 1219
1218 mlog(0, "aha rename over existing... new_de=%p " 1220 mlog(0, "aha rename over existing... new_de=%p new_blkno=%llu "
1219 "new_blkno=%"MLFu64" newfebh=%p bhblocknr=%llu\n", 1221 "newfebh=%p bhblocknr=%llu\n", new_de,
1220 new_de, newfe_blkno, newfe_bh, newfe_bh ? 1222 (unsigned long long)newfe_blkno, newfe_bh, newfe_bh ?
1221 (unsigned long long)newfe_bh->b_blocknr : 0ULL); 1223 (unsigned long long)newfe_bh->b_blocknr : 0ULL);
1222 1224
1223 if (S_ISDIR(new_inode->i_mode) || (new_inode->i_nlink == 1)) { 1225 if (S_ISDIR(new_inode->i_mode) || (new_inode->i_nlink == 1)) {
@@ -1354,8 +1356,8 @@ static int ocfs2_rename(struct inode *old_dir,
1354 if (new_dir_nlink != new_dir->i_nlink) { 1356 if (new_dir_nlink != new_dir->i_nlink) {
1355 if (!new_dir_bh) { 1357 if (!new_dir_bh) {
1356 mlog(ML_ERROR, "need to change nlink for new " 1358 mlog(ML_ERROR, "need to change nlink for new "
1357 "dir %"MLFu64" from %d to %d but bh is " 1359 "dir %llu from %d to %d but bh is NULL\n",
1358 "NULL\n", OCFS2_I(new_dir)->ip_blkno, 1360 (unsigned long long)OCFS2_I(new_dir)->ip_blkno,
1359 (int)new_dir_nlink, new_dir->i_nlink); 1361 (int)new_dir_nlink, new_dir->i_nlink);
1360 } else { 1362 } else {
1361 struct ocfs2_dinode *fe; 1363 struct ocfs2_dinode *fe;
@@ -1372,10 +1374,9 @@ static int ocfs2_rename(struct inode *old_dir,
1372 if (old_dir_nlink != old_dir->i_nlink) { 1374 if (old_dir_nlink != old_dir->i_nlink) {
1373 if (!old_dir_bh) { 1375 if (!old_dir_bh) {
1374 mlog(ML_ERROR, "need to change nlink for old dir " 1376 mlog(ML_ERROR, "need to change nlink for old dir "
1375 "%"MLFu64" from %d to %d but bh is NULL!\n", 1377 "%llu from %d to %d but bh is NULL!\n",
1376 OCFS2_I(old_dir)->ip_blkno, 1378 (unsigned long long)OCFS2_I(old_dir)->ip_blkno,
1377 (int)old_dir_nlink, 1379 (int)old_dir_nlink, old_dir->i_nlink);
1378 old_dir->i_nlink);
1379 } else { 1380 } else {
1380 struct ocfs2_dinode *fe; 1381 struct ocfs2_dinode *fe;
1381 status = ocfs2_journal_access(handle, old_dir, 1382 status = ocfs2_journal_access(handle, old_dir,
@@ -1443,8 +1444,9 @@ static int ocfs2_create_symlink_data(struct ocfs2_super *osb,
1443 * write i_size + 1 bytes. */ 1444 * write i_size + 1 bytes. */
1444 blocks = (bytes_left + sb->s_blocksize - 1) >> sb->s_blocksize_bits; 1445 blocks = (bytes_left + sb->s_blocksize - 1) >> sb->s_blocksize_bits;
1445 1446
1446 mlog_entry("i_blocks = %lu, i_size = %llu, blocks = %d\n", 1447 mlog_entry("i_blocks = %llu, i_size = %llu, blocks = %d\n",
1447 inode->i_blocks, i_size_read(inode), blocks); 1448 (unsigned long long)inode->i_blocks,
1449 i_size_read(inode), blocks);
1448 1450
1449 /* Sanity check -- make sure we're going to fit. */ 1451 /* Sanity check -- make sure we're going to fit. */
1450 if (bytes_left > 1452 if (bytes_left >
@@ -1634,9 +1636,9 @@ static int ocfs2_symlink(struct inode *dir,
1634 NULL); 1636 NULL);
1635 if (status < 0) { 1637 if (status < 0) {
1636 if (status != -ENOSPC && status != -EINTR) { 1638 if (status != -ENOSPC && status != -EINTR) {
1637 mlog(ML_ERROR, "Failed to extend file to " 1639 mlog(ML_ERROR,
1638 "%"MLFu64"\n", 1640 "Failed to extend file to %llu\n",
1639 newsize); 1641 (unsigned long long)newsize);
1640 mlog_errno(status); 1642 mlog_errno(status);
1641 status = -ENOSPC; 1643 status = -ENOSPC;
1642 } 1644 }
@@ -1716,10 +1718,11 @@ int ocfs2_check_dir_entry(struct inode * dir,
1716 error_msg = "directory entry across blocks"; 1718 error_msg = "directory entry across blocks";
1717 1719
1718 if (error_msg != NULL) 1720 if (error_msg != NULL)
1719 mlog(ML_ERROR, "bad entry in directory #%"MLFu64": %s - " 1721 mlog(ML_ERROR, "bad entry in directory #%llu: %s - "
1720 "offset=%lu, inode=%"MLFu64", rec_len=%d, name_len=%d\n", 1722 "offset=%lu, inode=%llu, rec_len=%d, name_len=%d\n",
1721 OCFS2_I(dir)->ip_blkno, error_msg, offset, 1723 (unsigned long long)OCFS2_I(dir)->ip_blkno, error_msg,
1722 le64_to_cpu(de->inode), rlen, de->name_len); 1724 offset, (unsigned long long)le64_to_cpu(de->inode), rlen,
1725 de->name_len);
1723 return error_msg == NULL ? 1 : 0; 1726 return error_msg == NULL ? 1 : 0;
1724} 1727}
1725 1728
@@ -2021,8 +2024,8 @@ static int ocfs2_blkno_stringify(u64 blkno, char *name)
2021 2024
2022 mlog_entry_void(); 2025 mlog_entry_void();
2023 2026
2024 namelen = snprintf(name, OCFS2_ORPHAN_NAMELEN + 1, "%016"MLFx64, 2027 namelen = snprintf(name, OCFS2_ORPHAN_NAMELEN + 1, "%016llx",
2025 blkno); 2028 (long long)blkno);
2026 if (namelen <= 0) { 2029 if (namelen <= 0) {
2027 if (namelen) 2030 if (namelen)
2028 status = namelen; 2031 status = namelen;
@@ -2167,8 +2170,8 @@ static int ocfs2_orphan_add(struct ocfs2_super *osb,
2167 OCFS2_I(inode)->ip_orphaned_slot = osb->slot_num; 2170 OCFS2_I(inode)->ip_orphaned_slot = osb->slot_num;
2168 spin_unlock(&OCFS2_I(inode)->ip_lock); 2171 spin_unlock(&OCFS2_I(inode)->ip_lock);
2169 2172
2170 mlog(0, "Inode %"MLFu64" orphaned in slot %d\n", 2173 mlog(0, "Inode %llu orphaned in slot %d\n",
2171 OCFS2_I(inode)->ip_blkno, osb->slot_num); 2174 (unsigned long long)OCFS2_I(inode)->ip_blkno, osb->slot_num);
2172 2175
2173leave: 2176leave:
2174 if (orphan_dir_inode) 2177 if (orphan_dir_inode)
@@ -2202,8 +2205,9 @@ int ocfs2_orphan_del(struct ocfs2_super *osb,
2202 goto leave; 2205 goto leave;
2203 } 2206 }
2204 2207
2205 mlog(0, "removing '%s' from orphan dir %"MLFu64" (namelen=%d)\n", 2208 mlog(0, "removing '%s' from orphan dir %llu (namelen=%d)\n",
2206 name, OCFS2_I(orphan_dir_inode)->ip_blkno, OCFS2_ORPHAN_NAMELEN); 2209 name, (unsigned long long)OCFS2_I(orphan_dir_inode)->ip_blkno,
2210 OCFS2_ORPHAN_NAMELEN);
2207 2211
2208 /* find it's spot in the orphan directory */ 2212 /* find it's spot in the orphan directory */
2209 target_de_bh = ocfs2_find_entry(name, OCFS2_ORPHAN_NAMELEN, 2213 target_de_bh = ocfs2_find_entry(name, OCFS2_ORPHAN_NAMELEN,
diff --git a/fs/ocfs2/ocfs2.h b/fs/ocfs2/ocfs2.h
index e89de9b6e491..da1093039c01 100644
--- a/fs/ocfs2/ocfs2.h
+++ b/fs/ocfs2/ocfs2.h
@@ -357,8 +357,8 @@ static inline int ocfs2_is_soft_readonly(struct ocfs2_super *osb)
357#define OCFS2_RO_ON_INVALID_DINODE(__sb, __di) do { \ 357#define OCFS2_RO_ON_INVALID_DINODE(__sb, __di) do { \
358 typeof(__di) ____di = (__di); \ 358 typeof(__di) ____di = (__di); \
359 ocfs2_error((__sb), \ 359 ocfs2_error((__sb), \
360 "Dinode # %"MLFu64" has bad signature %.*s", \ 360 "Dinode # %llu has bad signature %.*s", \
361 (____di)->i_blkno, 7, \ 361 (unsigned long long)(____di)->i_blkno, 7, \
362 (____di)->i_signature); \ 362 (____di)->i_signature); \
363} while (0); 363} while (0);
364 364
@@ -368,8 +368,8 @@ static inline int ocfs2_is_soft_readonly(struct ocfs2_super *osb)
368#define OCFS2_RO_ON_INVALID_EXTENT_BLOCK(__sb, __eb) do { \ 368#define OCFS2_RO_ON_INVALID_EXTENT_BLOCK(__sb, __eb) do { \
369 typeof(__eb) ____eb = (__eb); \ 369 typeof(__eb) ____eb = (__eb); \
370 ocfs2_error((__sb), \ 370 ocfs2_error((__sb), \
371 "Extent Block # %"MLFu64" has bad signature %.*s", \ 371 "Extent Block # %llu has bad signature %.*s", \
372 (____eb)->h_blkno, 7, \ 372 (unsigned long long)(____eb)->h_blkno, 7, \
373 (____eb)->h_signature); \ 373 (____eb)->h_signature); \
374} while (0); 374} while (0);
375 375
@@ -379,8 +379,8 @@ static inline int ocfs2_is_soft_readonly(struct ocfs2_super *osb)
379#define OCFS2_RO_ON_INVALID_GROUP_DESC(__sb, __gd) do { \ 379#define OCFS2_RO_ON_INVALID_GROUP_DESC(__sb, __gd) do { \
380 typeof(__gd) ____gd = (__gd); \ 380 typeof(__gd) ____gd = (__gd); \
381 ocfs2_error((__sb), \ 381 ocfs2_error((__sb), \
382 "Group Descriptor # %"MLFu64" has bad signature %.*s", \ 382 "Group Descriptor # %llu has bad signature %.*s", \
383 (____gd)->bg_blkno, 7, \ 383 (unsigned long long)(____gd)->bg_blkno, 7, \
384 (____gd)->bg_signature); \ 384 (____gd)->bg_signature); \
385} while (0); 385} while (0);
386 386
diff --git a/fs/ocfs2/suballoc.c b/fs/ocfs2/suballoc.c
index c46c164aefbb..195523090c87 100644
--- a/fs/ocfs2/suballoc.c
+++ b/fs/ocfs2/suballoc.c
@@ -157,8 +157,9 @@ static int ocfs2_block_group_fill(struct ocfs2_journal_handle *handle,
157 mlog_entry_void(); 157 mlog_entry_void();
158 158
159 if (((unsigned long long) bg_bh->b_blocknr) != group_blkno) { 159 if (((unsigned long long) bg_bh->b_blocknr) != group_blkno) {
160 ocfs2_error(alloc_inode->i_sb, "group block (%"MLFu64") " 160 ocfs2_error(alloc_inode->i_sb, "group block (%llu) != "
161 "!= b_blocknr (%llu)", group_blkno, 161 "b_blocknr (%llu)",
162 (unsigned long long)group_blkno,
162 (unsigned long long) bg_bh->b_blocknr); 163 (unsigned long long) bg_bh->b_blocknr);
163 status = -EIO; 164 status = -EIO;
164 goto bail; 165 goto bail;
@@ -280,8 +281,8 @@ static int ocfs2_block_group_alloc(struct ocfs2_super *osb,
280 281
281 /* setup the group */ 282 /* setup the group */
282 bg_blkno = ocfs2_clusters_to_blocks(osb->sb, bit_off); 283 bg_blkno = ocfs2_clusters_to_blocks(osb->sb, bit_off);
283 mlog(0, "new descriptor, record %u, at block %"MLFu64"\n", 284 mlog(0, "new descriptor, record %u, at block %llu\n",
284 alloc_rec, bg_blkno); 285 alloc_rec, (unsigned long long)bg_blkno);
285 286
286 bg_bh = sb_getblk(osb->sb, bg_blkno); 287 bg_bh = sb_getblk(osb->sb, bg_blkno);
287 if (!bg_bh) { 288 if (!bg_bh) {
@@ -382,8 +383,8 @@ static int ocfs2_reserve_suballoc_bits(struct ocfs2_super *osb,
382 goto bail; 383 goto bail;
383 } 384 }
384 if (!(fe->i_flags & cpu_to_le32(OCFS2_CHAIN_FL))) { 385 if (!(fe->i_flags & cpu_to_le32(OCFS2_CHAIN_FL))) {
385 ocfs2_error(alloc_inode->i_sb, "Invalid chain allocator " 386 ocfs2_error(alloc_inode->i_sb, "Invalid chain allocator %llu",
386 "# %"MLFu64, le64_to_cpu(fe->i_blkno)); 387 (unsigned long long)le64_to_cpu(fe->i_blkno));
387 status = -EIO; 388 status = -EIO;
388 goto bail; 389 goto bail;
389 } 390 }
@@ -829,9 +830,10 @@ static int ocfs2_relink_block_group(struct ocfs2_journal_handle *handle,
829 goto out; 830 goto out;
830 } 831 }
831 832
832 mlog(0, "In suballoc %"MLFu64", chain %u, move group %"MLFu64" to " 833 mlog(0, "Suballoc %llu, chain %u, move group %llu to top, prev = %llu\n",
833 "top, prev = %"MLFu64"\n", 834 (unsigned long long)fe->i_blkno, chain,
834 fe->i_blkno, chain, bg->bg_blkno, prev_bg->bg_blkno); 835 (unsigned long long)bg->bg_blkno,
836 (unsigned long long)prev_bg->bg_blkno);
835 837
836 fe_ptr = le64_to_cpu(fe->id2.i_chain.cl_recs[chain].c_blkno); 838 fe_ptr = le64_to_cpu(fe->id2.i_chain.cl_recs[chain].c_blkno);
837 bg_ptr = le64_to_cpu(bg->bg_next_group); 839 bg_ptr = le64_to_cpu(bg->bg_next_group);
@@ -974,8 +976,9 @@ static int ocfs2_search_chain(struct ocfs2_alloc_context *ac,
974 struct ocfs2_group_desc *bg; 976 struct ocfs2_group_desc *bg;
975 977
976 chain = ac->ac_chain; 978 chain = ac->ac_chain;
977 mlog(0, "trying to alloc %u bits from chain %u, inode %"MLFu64"\n", 979 mlog(0, "trying to alloc %u bits from chain %u, inode %llu\n",
978 bits_wanted, chain, OCFS2_I(alloc_inode)->ip_blkno); 980 bits_wanted, chain,
981 (unsigned long long)OCFS2_I(alloc_inode)->ip_blkno);
979 982
980 status = ocfs2_read_block(OCFS2_SB(alloc_inode->i_sb), 983 status = ocfs2_read_block(OCFS2_SB(alloc_inode->i_sb),
981 le64_to_cpu(cl->cl_recs[chain].c_blkno), 984 le64_to_cpu(cl->cl_recs[chain].c_blkno),
@@ -1027,8 +1030,8 @@ static int ocfs2_search_chain(struct ocfs2_alloc_context *ac,
1027 goto bail; 1030 goto bail;
1028 } 1031 }
1029 1032
1030 mlog(0, "alloc succeeds: we give %u bits from block group %"MLFu64"\n", 1033 mlog(0, "alloc succeeds: we give %u bits from block group %llu\n",
1031 tmp_bits, bg->bg_blkno); 1034 tmp_bits, (unsigned long long)bg->bg_blkno);
1032 1035
1033 *num_bits = tmp_bits; 1036 *num_bits = tmp_bits;
1034 1037
@@ -1092,8 +1095,8 @@ static int ocfs2_search_chain(struct ocfs2_alloc_context *ac,
1092 goto bail; 1095 goto bail;
1093 } 1096 }
1094 1097
1095 mlog(0, "Allocated %u bits from suballocator %"MLFu64"\n", 1098 mlog(0, "Allocated %u bits from suballocator %llu\n", *num_bits,
1096 *num_bits, fe->i_blkno); 1099 (unsigned long long)fe->i_blkno);
1097 1100
1098 *bg_blkno = le64_to_cpu(bg->bg_blkno); 1101 *bg_blkno = le64_to_cpu(bg->bg_blkno);
1099bail: 1102bail:
@@ -1134,9 +1137,9 @@ static int ocfs2_claim_suballoc_bits(struct ocfs2_super *osb,
1134 } 1137 }
1135 if (le32_to_cpu(fe->id1.bitmap1.i_used) >= 1138 if (le32_to_cpu(fe->id1.bitmap1.i_used) >=
1136 le32_to_cpu(fe->id1.bitmap1.i_total)) { 1139 le32_to_cpu(fe->id1.bitmap1.i_total)) {
1137 ocfs2_error(osb->sb, "Chain allocator dinode %"MLFu64" has %u" 1140 ocfs2_error(osb->sb, "Chain allocator dinode %llu has %u used "
1138 "used bits but only %u total.", 1141 "bits but only %u total.",
1139 le64_to_cpu(fe->i_blkno), 1142 (unsigned long long)le64_to_cpu(fe->i_blkno),
1140 le32_to_cpu(fe->id1.bitmap1.i_used), 1143 le32_to_cpu(fe->id1.bitmap1.i_used),
1141 le32_to_cpu(fe->id1.bitmap1.i_total)); 1144 le32_to_cpu(fe->id1.bitmap1.i_total));
1142 status = -EIO; 1145 status = -EIO;
@@ -1479,10 +1482,9 @@ static int ocfs2_free_suballoc_bits(struct ocfs2_journal_handle *handle,
1479 } 1482 }
1480 BUG_ON((count + start_bit) > ocfs2_bits_per_group(cl)); 1483 BUG_ON((count + start_bit) > ocfs2_bits_per_group(cl));
1481 1484
1482 mlog(0, "suballocator %"MLFu64": freeing %u bits from group %"MLFu64 1485 mlog(0, "%llu: freeing %u bits from group %llu, starting at %u\n",
1483 ", starting at %u\n", 1486 (unsigned long long)OCFS2_I(alloc_inode)->ip_blkno, count,
1484 OCFS2_I(alloc_inode)->ip_blkno, count, bg_blkno, 1487 (unsigned long long)bg_blkno, start_bit);
1485 start_bit);
1486 1488
1487 status = ocfs2_read_block(osb, bg_blkno, &group_bh, OCFS2_BH_CACHED, 1489 status = ocfs2_read_block(osb, bg_blkno, &group_bh, OCFS2_BH_CACHED,
1488 alloc_inode); 1490 alloc_inode);
@@ -1592,10 +1594,10 @@ int ocfs2_free_clusters(struct ocfs2_journal_handle *handle,
1592 ocfs2_block_to_cluster_group(bitmap_inode, start_blk, &bg_blkno, 1594 ocfs2_block_to_cluster_group(bitmap_inode, start_blk, &bg_blkno,
1593 &bg_start_bit); 1595 &bg_start_bit);
1594 1596
1595 mlog(0, "want to free %u clusters starting at block %"MLFu64"\n", 1597 mlog(0, "want to free %u clusters starting at block %llu\n",
1596 num_clusters, start_blk); 1598 num_clusters, (unsigned long long)start_blk);
1597 mlog(0, "bg_blkno = %"MLFu64", bg_start_bit = %u\n", 1599 mlog(0, "bg_blkno = %llu, bg_start_bit = %u\n",
1598 bg_blkno, bg_start_bit); 1600 (unsigned long long)bg_blkno, bg_start_bit);
1599 1601
1600 status = ocfs2_free_suballoc_bits(handle, bitmap_inode, bitmap_bh, 1602 status = ocfs2_free_suballoc_bits(handle, bitmap_inode, bitmap_bh,
1601 bg_start_bit, bg_blkno, 1603 bg_start_bit, bg_blkno,
@@ -1616,18 +1618,22 @@ static inline void ocfs2_debug_bg(struct ocfs2_group_desc *bg)
1616 printk("bg_free_bits_count: %u\n", bg->bg_free_bits_count); 1618 printk("bg_free_bits_count: %u\n", bg->bg_free_bits_count);
1617 printk("bg_chain: %u\n", bg->bg_chain); 1619 printk("bg_chain: %u\n", bg->bg_chain);
1618 printk("bg_generation: %u\n", le32_to_cpu(bg->bg_generation)); 1620 printk("bg_generation: %u\n", le32_to_cpu(bg->bg_generation));
1619 printk("bg_next_group: %"MLFu64"\n", bg->bg_next_group); 1621 printk("bg_next_group: %llu\n",
1620 printk("bg_parent_dinode: %"MLFu64"\n", bg->bg_parent_dinode); 1622 (unsigned long long)bg->bg_next_group);
1621 printk("bg_blkno: %"MLFu64"\n", bg->bg_blkno); 1623 printk("bg_parent_dinode: %llu\n",
1624 (unsigned long long)bg->bg_parent_dinode);
1625 printk("bg_blkno: %llu\n",
1626 (unsigned long long)bg->bg_blkno);
1622} 1627}
1623 1628
1624static inline void ocfs2_debug_suballoc_inode(struct ocfs2_dinode *fe) 1629static inline void ocfs2_debug_suballoc_inode(struct ocfs2_dinode *fe)
1625{ 1630{
1626 int i; 1631 int i;
1627 1632
1628 printk("Suballoc Inode %"MLFu64":\n", fe->i_blkno); 1633 printk("Suballoc Inode %llu:\n", (unsigned long long)fe->i_blkno);
1629 printk("i_signature: %s\n", fe->i_signature); 1634 printk("i_signature: %s\n", fe->i_signature);
1630 printk("i_size: %"MLFu64"\n", fe->i_size); 1635 printk("i_size: %llu\n",
1636 (unsigned long long)fe->i_size);
1631 printk("i_clusters: %u\n", fe->i_clusters); 1637 printk("i_clusters: %u\n", fe->i_clusters);
1632 printk("i_generation: %u\n", 1638 printk("i_generation: %u\n",
1633 le32_to_cpu(fe->i_generation)); 1639 le32_to_cpu(fe->i_generation));
@@ -1645,7 +1651,7 @@ static inline void ocfs2_debug_suballoc_inode(struct ocfs2_dinode *fe)
1645 fe->id2.i_chain.cl_recs[i].c_free); 1651 fe->id2.i_chain.cl_recs[i].c_free);
1646 printk("fe->id2.i_chain.cl_recs[%d].c_total: %u\n", i, 1652 printk("fe->id2.i_chain.cl_recs[%d].c_total: %u\n", i,
1647 fe->id2.i_chain.cl_recs[i].c_total); 1653 fe->id2.i_chain.cl_recs[i].c_total);
1648 printk("fe->id2.i_chain.cl_recs[%d].c_blkno: %"MLFu64"\n", i, 1654 printk("fe->id2.i_chain.cl_recs[%d].c_blkno: %llu\n", i,
1649 fe->id2.i_chain.cl_recs[i].c_blkno); 1655 (unsigned long long)fe->id2.i_chain.cl_recs[i].c_blkno);
1650 } 1656 }
1651} 1657}
diff --git a/fs/ocfs2/super.c b/fs/ocfs2/super.c
index 8dd3aafec499..949b3dac30f1 100644
--- a/fs/ocfs2/super.c
+++ b/fs/ocfs2/super.c
@@ -950,16 +950,18 @@ static void ocfs2_inode_init_once(void *data,
950static int ocfs2_initialize_mem_caches(void) 950static int ocfs2_initialize_mem_caches(void)
951{ 951{
952 ocfs2_inode_cachep = kmem_cache_create("ocfs2_inode_cache", 952 ocfs2_inode_cachep = kmem_cache_create("ocfs2_inode_cache",
953 sizeof(struct ocfs2_inode_info), 953 sizeof(struct ocfs2_inode_info),
954 0, SLAB_HWCACHE_ALIGN|SLAB_RECLAIM_ACCOUNT, 954 0,
955 ocfs2_inode_init_once, NULL); 955 (SLAB_HWCACHE_ALIGN|SLAB_RECLAIM_ACCOUNT|
956 SLAB_MEM_SPREAD),
957 ocfs2_inode_init_once, NULL);
956 if (!ocfs2_inode_cachep) 958 if (!ocfs2_inode_cachep)
957 return -ENOMEM; 959 return -ENOMEM;
958 960
959 ocfs2_lock_cache = kmem_cache_create("ocfs2_lock", 961 ocfs2_lock_cache = kmem_cache_create("ocfs2_lock",
960 sizeof(struct ocfs2_journal_lock), 962 sizeof(struct ocfs2_journal_lock),
961 0, 963 0,
962 SLAB_NO_REAP|SLAB_HWCACHE_ALIGN, 964 SLAB_HWCACHE_ALIGN,
963 NULL, NULL); 965 NULL, NULL);
964 if (!ocfs2_lock_cache) 966 if (!ocfs2_lock_cache)
965 return -ENOMEM; 967 return -ENOMEM;
@@ -1426,8 +1428,9 @@ static int ocfs2_initialize_super(struct super_block *sb,
1426 osb->fs_generation = le32_to_cpu(di->i_fs_generation); 1428 osb->fs_generation = le32_to_cpu(di->i_fs_generation);
1427 mlog(0, "vol_label: %s\n", osb->vol_label); 1429 mlog(0, "vol_label: %s\n", osb->vol_label);
1428 mlog(0, "uuid: %s\n", osb->uuid_str); 1430 mlog(0, "uuid: %s\n", osb->uuid_str);
1429 mlog(0, "root_blkno=%"MLFu64", system_dir_blkno=%"MLFu64"\n", 1431 mlog(0, "root_blkno=%llu, system_dir_blkno=%llu\n",
1430 osb->root_blkno, osb->system_dir_blkno); 1432 (unsigned long long)osb->root_blkno,
1433 (unsigned long long)osb->system_dir_blkno);
1431 1434
1432 osb->osb_dlm_debug = ocfs2_new_dlm_debug(); 1435 osb->osb_dlm_debug = ocfs2_new_dlm_debug();
1433 if (!osb->osb_dlm_debug) { 1436 if (!osb->osb_dlm_debug) {
@@ -1470,8 +1473,8 @@ static int ocfs2_initialize_super(struct super_block *sb,
1470 osb->bitmap_cpg = le16_to_cpu(di->id2.i_chain.cl_cpg); 1473 osb->bitmap_cpg = le16_to_cpu(di->id2.i_chain.cl_cpg);
1471 osb->num_clusters = le32_to_cpu(di->id1.bitmap1.i_total); 1474 osb->num_clusters = le32_to_cpu(di->id1.bitmap1.i_total);
1472 brelse(bitmap_bh); 1475 brelse(bitmap_bh);
1473 mlog(0, "cluster bitmap inode: %"MLFu64", clusters per group: %u\n", 1476 mlog(0, "cluster bitmap inode: %llu, clusters per group: %u\n",
1474 osb->bitmap_blkno, osb->bitmap_cpg); 1477 (unsigned long long)osb->bitmap_blkno, osb->bitmap_cpg);
1475 1478
1476 status = ocfs2_init_slot_info(osb); 1479 status = ocfs2_init_slot_info(osb);
1477 if (status < 0) { 1480 if (status < 0) {
@@ -1529,8 +1532,9 @@ static int ocfs2_verify_volume(struct ocfs2_dinode *di,
1529 OCFS2_MINOR_REV_LEVEL); 1532 OCFS2_MINOR_REV_LEVEL);
1530 } else if (bh->b_blocknr != le64_to_cpu(di->i_blkno)) { 1533 } else if (bh->b_blocknr != le64_to_cpu(di->i_blkno)) {
1531 mlog(ML_ERROR, "bad block number on superblock: " 1534 mlog(ML_ERROR, "bad block number on superblock: "
1532 "found %"MLFu64", should be %llu\n", 1535 "found %llu, should be %llu\n",
1533 di->i_blkno, (unsigned long long)bh->b_blocknr); 1536 (unsigned long long)di->i_blkno,
1537 (unsigned long long)bh->b_blocknr);
1534 } else if (le32_to_cpu(di->id2.i_super.s_clustersize_bits) < 12 || 1538 } else if (le32_to_cpu(di->id2.i_super.s_clustersize_bits) < 12 ||
1535 le32_to_cpu(di->id2.i_super.s_clustersize_bits) > 20) { 1539 le32_to_cpu(di->id2.i_super.s_clustersize_bits) > 20) {
1536 mlog(ML_ERROR, "bad cluster size found: %u\n", 1540 mlog(ML_ERROR, "bad cluster size found: %u\n",
diff --git a/fs/ocfs2/super.h b/fs/ocfs2/super.h
index c564177dfbdc..783f5270f2a1 100644
--- a/fs/ocfs2/super.h
+++ b/fs/ocfs2/super.h
@@ -33,12 +33,16 @@ int ocfs2_publish_get_mount_state(struct ocfs2_super *osb,
33 33
34void __ocfs2_error(struct super_block *sb, 34void __ocfs2_error(struct super_block *sb,
35 const char *function, 35 const char *function,
36 const char *fmt, ...); 36 const char *fmt, ...)
37 __attribute__ ((format (printf, 3, 4)));
38
37#define ocfs2_error(sb, fmt, args...) __ocfs2_error(sb, __PRETTY_FUNCTION__, fmt, ##args) 39#define ocfs2_error(sb, fmt, args...) __ocfs2_error(sb, __PRETTY_FUNCTION__, fmt, ##args)
38 40
39void __ocfs2_abort(struct super_block *sb, 41void __ocfs2_abort(struct super_block *sb,
40 const char *function, 42 const char *function,
41 const char *fmt, ...); 43 const char *fmt, ...)
44 __attribute__ ((format (printf, 3, 4)));
45
42#define ocfs2_abort(sb, fmt, args...) __ocfs2_abort(sb, __PRETTY_FUNCTION__, fmt, ##args) 46#define ocfs2_abort(sb, fmt, args...) __ocfs2_abort(sb, __PRETTY_FUNCTION__, fmt, ##args)
43 47
44#endif /* OCFS2_SUPER_H */ 48#endif /* OCFS2_SUPER_H */
diff --git a/fs/ocfs2/uptodate.c b/fs/ocfs2/uptodate.c
index 300b5bedfb21..04a684dfdd96 100644
--- a/fs/ocfs2/uptodate.c
+++ b/fs/ocfs2/uptodate.c
@@ -119,8 +119,8 @@ void ocfs2_metadata_cache_purge(struct inode *inode)
119 tree = !(oi->ip_flags & OCFS2_INODE_CACHE_INLINE); 119 tree = !(oi->ip_flags & OCFS2_INODE_CACHE_INLINE);
120 to_purge = ci->ci_num_cached; 120 to_purge = ci->ci_num_cached;
121 121
122 mlog(0, "Purge %u %s items from Inode %"MLFu64"\n", to_purge, 122 mlog(0, "Purge %u %s items from Inode %llu\n", to_purge,
123 tree ? "array" : "tree", oi->ip_blkno); 123 tree ? "array" : "tree", (unsigned long long)oi->ip_blkno);
124 124
125 /* If we're a tree, save off the root so that we can safely 125 /* If we're a tree, save off the root so that we can safely
126 * initialize the cache. We do the work to free tree members 126 * initialize the cache. We do the work to free tree members
@@ -136,8 +136,8 @@ void ocfs2_metadata_cache_purge(struct inode *inode)
136 * easily detect counting errors. Unfortunately, this is only 136 * easily detect counting errors. Unfortunately, this is only
137 * meaningful for trees. */ 137 * meaningful for trees. */
138 if (tree && purged != to_purge) 138 if (tree && purged != to_purge)
139 mlog(ML_ERROR, "Inode %"MLFu64", count = %u, purged = %u\n", 139 mlog(ML_ERROR, "Inode %llu, count = %u, purged = %u\n",
140 oi->ip_blkno, to_purge, purged); 140 (unsigned long long)oi->ip_blkno, to_purge, purged);
141} 141}
142 142
143/* Returns the index in the cache array, -1 if not found. 143/* Returns the index in the cache array, -1 if not found.
@@ -186,8 +186,9 @@ static int ocfs2_buffer_cached(struct ocfs2_inode_info *oi,
186 186
187 spin_lock(&oi->ip_lock); 187 spin_lock(&oi->ip_lock);
188 188
189 mlog(0, "Inode %"MLFu64", query block %llu (inline = %u)\n", 189 mlog(0, "Inode %llu, query block %llu (inline = %u)\n",
190 oi->ip_blkno, (unsigned long long) bh->b_blocknr, 190 (unsigned long long)oi->ip_blkno,
191 (unsigned long long) bh->b_blocknr,
191 !!(oi->ip_flags & OCFS2_INODE_CACHE_INLINE)); 192 !!(oi->ip_flags & OCFS2_INODE_CACHE_INLINE));
192 193
193 if (oi->ip_flags & OCFS2_INODE_CACHE_INLINE) 194 if (oi->ip_flags & OCFS2_INODE_CACHE_INLINE)
@@ -293,12 +294,12 @@ static void ocfs2_expand_cache(struct ocfs2_inode_info *oi,
293 struct ocfs2_caching_info *ci = &oi->ip_metadata_cache; 294 struct ocfs2_caching_info *ci = &oi->ip_metadata_cache;
294 295
295 mlog_bug_on_msg(ci->ci_num_cached != OCFS2_INODE_MAX_CACHE_ARRAY, 296 mlog_bug_on_msg(ci->ci_num_cached != OCFS2_INODE_MAX_CACHE_ARRAY,
296 "Inode %"MLFu64", num cached = %u, should be %u\n", 297 "Inode %llu, num cached = %u, should be %u\n",
297 oi->ip_blkno, ci->ci_num_cached, 298 (unsigned long long)oi->ip_blkno, ci->ci_num_cached,
298 OCFS2_INODE_MAX_CACHE_ARRAY); 299 OCFS2_INODE_MAX_CACHE_ARRAY);
299 mlog_bug_on_msg(!(oi->ip_flags & OCFS2_INODE_CACHE_INLINE), 300 mlog_bug_on_msg(!(oi->ip_flags & OCFS2_INODE_CACHE_INLINE),
300 "Inode %"MLFu64" not marked as inline anymore!\n", 301 "Inode %llu not marked as inline anymore!\n",
301 oi->ip_blkno); 302 (unsigned long long)oi->ip_blkno);
302 assert_spin_locked(&oi->ip_lock); 303 assert_spin_locked(&oi->ip_lock);
303 304
304 /* Be careful to initialize the tree members *first* because 305 /* Be careful to initialize the tree members *first* because
@@ -316,8 +317,8 @@ static void ocfs2_expand_cache(struct ocfs2_inode_info *oi,
316 tree[i] = NULL; 317 tree[i] = NULL;
317 } 318 }
318 319
319 mlog(0, "Expanded %"MLFu64" to a tree cache: flags 0x%x, num = %u\n", 320 mlog(0, "Expanded %llu to a tree cache: flags 0x%x, num = %u\n",
320 oi->ip_blkno, oi->ip_flags, ci->ci_num_cached); 321 (unsigned long long)oi->ip_blkno, oi->ip_flags, ci->ci_num_cached);
321} 322}
322 323
323/* Slow path function - memory allocation is necessary. See the 324/* Slow path function - memory allocation is necessary. See the
@@ -332,8 +333,9 @@ static void __ocfs2_set_buffer_uptodate(struct ocfs2_inode_info *oi,
332 struct ocfs2_meta_cache_item *tree[OCFS2_INODE_MAX_CACHE_ARRAY] = 333 struct ocfs2_meta_cache_item *tree[OCFS2_INODE_MAX_CACHE_ARRAY] =
333 { NULL, }; 334 { NULL, };
334 335
335 mlog(0, "Inode %"MLFu64", block %llu, expand = %d\n", 336 mlog(0, "Inode %llu, block %llu, expand = %d\n",
336 oi->ip_blkno, (unsigned long long) block, expand_tree); 337 (unsigned long long)oi->ip_blkno,
338 (unsigned long long)block, expand_tree);
337 339
338 new = kmem_cache_alloc(ocfs2_uptodate_cachep, GFP_KERNEL); 340 new = kmem_cache_alloc(ocfs2_uptodate_cachep, GFP_KERNEL);
339 if (!new) { 341 if (!new) {
@@ -414,8 +416,9 @@ void ocfs2_set_buffer_uptodate(struct inode *inode,
414 if (ocfs2_buffer_cached(oi, bh)) 416 if (ocfs2_buffer_cached(oi, bh))
415 return; 417 return;
416 418
417 mlog(0, "Inode %"MLFu64", inserting block %llu\n", oi->ip_blkno, 419 mlog(0, "Inode %llu, inserting block %llu\n",
418 (unsigned long long) bh->b_blocknr); 420 (unsigned long long)oi->ip_blkno,
421 (unsigned long long)bh->b_blocknr);
419 422
420 /* No need to recheck under spinlock - insertion is guarded by 423 /* No need to recheck under spinlock - insertion is guarded by
421 * ip_io_mutex */ 424 * ip_io_mutex */
@@ -504,8 +507,9 @@ void ocfs2_remove_from_cache(struct inode *inode,
504 struct ocfs2_caching_info *ci = &oi->ip_metadata_cache; 507 struct ocfs2_caching_info *ci = &oi->ip_metadata_cache;
505 508
506 spin_lock(&oi->ip_lock); 509 spin_lock(&oi->ip_lock);
507 mlog(0, "Inode %"MLFu64", remove %llu, items = %u, array = %u\n", 510 mlog(0, "Inode %llu, remove %llu, items = %u, array = %u\n",
508 oi->ip_blkno, (unsigned long long) block, ci->ci_num_cached, 511 (unsigned long long)oi->ip_blkno,
512 (unsigned long long) block, ci->ci_num_cached,
509 oi->ip_flags & OCFS2_INODE_CACHE_INLINE); 513 oi->ip_flags & OCFS2_INODE_CACHE_INLINE);
510 514
511 if (oi->ip_flags & OCFS2_INODE_CACHE_INLINE) { 515 if (oi->ip_flags & OCFS2_INODE_CACHE_INLINE) {
diff --git a/fs/ocfs2/vote.c b/fs/ocfs2/vote.c
index 021978e0576b..53049a204197 100644
--- a/fs/ocfs2/vote.c
+++ b/fs/ocfs2/vote.c
@@ -190,20 +190,21 @@ static int ocfs2_process_delete_request(struct inode *inode,
190 OCFS2_INVALID_SLOT && 190 OCFS2_INVALID_SLOT &&
191 OCFS2_I(inode)->ip_orphaned_slot != 191 OCFS2_I(inode)->ip_orphaned_slot !=
192 (*orphaned_slot), 192 (*orphaned_slot),
193 "Inode %"MLFu64": This node thinks it's " 193 "Inode %llu: This node thinks it's "
194 "orphaned in slot %d, messaged it's in %d\n", 194 "orphaned in slot %d, messaged it's in %d\n",
195 OCFS2_I(inode)->ip_blkno, 195 (unsigned long long)OCFS2_I(inode)->ip_blkno,
196 OCFS2_I(inode)->ip_orphaned_slot, 196 OCFS2_I(inode)->ip_orphaned_slot,
197 *orphaned_slot); 197 *orphaned_slot);
198 198
199 mlog(0, "Setting orphaned slot for inode %"MLFu64" to %d\n", 199 mlog(0, "Setting orphaned slot for inode %llu to %d\n",
200 OCFS2_I(inode)->ip_blkno, *orphaned_slot); 200 (unsigned long long)OCFS2_I(inode)->ip_blkno,
201 *orphaned_slot);
201 202
202 OCFS2_I(inode)->ip_orphaned_slot = *orphaned_slot; 203 OCFS2_I(inode)->ip_orphaned_slot = *orphaned_slot;
203 } else { 204 } else {
204 mlog(0, "Sending back orphaned slot %d for inode %"MLFu64"\n", 205 mlog(0, "Sending back orphaned slot %d for inode %llu\n",
205 OCFS2_I(inode)->ip_orphaned_slot, 206 OCFS2_I(inode)->ip_orphaned_slot,
206 OCFS2_I(inode)->ip_blkno); 207 (unsigned long long)OCFS2_I(inode)->ip_blkno);
207 208
208 *orphaned_slot = OCFS2_I(inode)->ip_orphaned_slot; 209 *orphaned_slot = OCFS2_I(inode)->ip_orphaned_slot;
209 } 210 }
@@ -226,8 +227,8 @@ static int ocfs2_process_delete_request(struct inode *inode,
226 } 227 }
227 228
228 if (filemap_fdatawrite(inode->i_mapping)) { 229 if (filemap_fdatawrite(inode->i_mapping)) {
229 mlog(ML_ERROR, "Could not sync inode %"MLFu64" for delete!\n", 230 mlog(ML_ERROR, "Could not sync inode %llu for delete!\n",
230 OCFS2_I(inode)->ip_blkno); 231 (unsigned long long)OCFS2_I(inode)->ip_blkno);
231 goto done; 232 goto done;
232 } 233 }
233 sync_mapping_buffers(inode->i_mapping); 234 sync_mapping_buffers(inode->i_mapping);
@@ -302,8 +303,8 @@ static void ocfs2_process_dentry_request(struct inode *inode,
302 struct list_head *p; 303 struct list_head *p;
303 struct ocfs2_inode_info *oi = OCFS2_I(inode); 304 struct ocfs2_inode_info *oi = OCFS2_I(inode);
304 305
305 mlog(0, "parent %"MLFu64", namelen = %u, name = %.*s\n", parent_blkno, 306 mlog(0, "parent %llu, namelen = %u, name = %.*s\n",
306 namelen, namelen, name); 307 (unsigned long long)parent_blkno, namelen, namelen, name);
307 308
308 spin_lock(&dcache_lock); 309 spin_lock(&dcache_lock);
309 310
@@ -370,9 +371,10 @@ static void ocfs2_process_vote(struct ocfs2_super *osb,
370 if (request == OCFS2_VOTE_REQ_DELETE) 371 if (request == OCFS2_VOTE_REQ_DELETE)
371 orphaned_slot = be32_to_cpu(msg->md1.v_orphaned_slot); 372 orphaned_slot = be32_to_cpu(msg->md1.v_orphaned_slot);
372 373
373 mlog(0, "processing vote: request = %u, blkno = %"MLFu64", " 374 mlog(0, "processing vote: request = %u, blkno = %llu, "
374 "generation = %u, node_num = %u, priv1 = %u\n", request, 375 "generation = %u, node_num = %u, priv1 = %u\n", request,
375 blkno, generation, node_num, be32_to_cpu(msg->md1.v_generic1)); 376 (unsigned long long)blkno, generation, node_num,
377 be32_to_cpu(msg->md1.v_generic1));
376 378
377 if (!ocfs2_is_valid_vote_request(request)) { 379 if (!ocfs2_is_valid_vote_request(request)) {
378 mlog(ML_ERROR, "Invalid vote request %d from node %u\n", 380 mlog(ML_ERROR, "Invalid vote request %d from node %u\n",
@@ -419,11 +421,12 @@ static void ocfs2_process_vote(struct ocfs2_super *osb,
419 * we had not found an inode in the first place. */ 421 * we had not found an inode in the first place. */
420 if (inode->i_generation != generation) { 422 if (inode->i_generation != generation) {
421 mlog(0, "generation passed %u != inode generation = %u, " 423 mlog(0, "generation passed %u != inode generation = %u, "
422 "ip_flags = %x, ip_blkno = %"MLFu64", msg %"MLFu64", " 424 "ip_flags = %x, ip_blkno = %llu, msg %llu, i_count = %u, "
423 "i_count = %u, message type = %u\n", 425 "message type = %u\n", generation, inode->i_generation,
424 generation, inode->i_generation, OCFS2_I(inode)->ip_flags, 426 OCFS2_I(inode)->ip_flags,
425 OCFS2_I(inode)->ip_blkno, blkno, 427 (unsigned long long)OCFS2_I(inode)->ip_blkno,
426 atomic_read(&inode->i_count), request); 428 (unsigned long long)blkno, atomic_read(&inode->i_count),
429 request);
427 iput(inode); 430 iput(inode);
428 inode = NULL; 431 inode = NULL;
429 goto respond; 432 goto respond;
@@ -830,8 +833,9 @@ static void ocfs2_delete_response_cb(void *priv,
830 833
831 orphaned_slot = be32_to_cpu(resp->r_orphaned_slot); 834 orphaned_slot = be32_to_cpu(resp->r_orphaned_slot);
832 node = be32_to_cpu(resp->r_hdr.h_node_num); 835 node = be32_to_cpu(resp->r_hdr.h_node_num);
833 mlog(0, "node %d tells us that inode %"MLFu64" is orphaned in slot " 836 mlog(0, "node %d tells us that inode %llu is orphaned in slot %d\n",
834 "%d\n", node, OCFS2_I(inode)->ip_blkno, orphaned_slot); 837 node, (unsigned long long)OCFS2_I(inode)->ip_blkno,
838 orphaned_slot);
835 839
836 /* The other node may not actually know which slot the inode 840 /* The other node may not actually know which slot the inode
837 * is orphaned in. */ 841 * is orphaned in. */
@@ -845,9 +849,9 @@ static void ocfs2_delete_response_cb(void *priv,
845 spin_lock(&OCFS2_I(inode)->ip_lock); 849 spin_lock(&OCFS2_I(inode)->ip_lock);
846 mlog_bug_on_msg(OCFS2_I(inode)->ip_orphaned_slot != orphaned_slot && 850 mlog_bug_on_msg(OCFS2_I(inode)->ip_orphaned_slot != orphaned_slot &&
847 OCFS2_I(inode)->ip_orphaned_slot 851 OCFS2_I(inode)->ip_orphaned_slot
848 != OCFS2_INVALID_SLOT, "Inode %"MLFu64": Node %d " 852 != OCFS2_INVALID_SLOT, "Inode %llu: Node %d says it's "
849 "says it's orphaned in slot %d, we think it's in %d\n", 853 "orphaned in slot %d, we think it's in %d\n",
850 OCFS2_I(inode)->ip_blkno, 854 (unsigned long long)OCFS2_I(inode)->ip_blkno,
851 be32_to_cpu(resp->r_hdr.h_node_num), 855 be32_to_cpu(resp->r_hdr.h_node_num),
852 orphaned_slot, OCFS2_I(inode)->ip_orphaned_slot); 856 orphaned_slot, OCFS2_I(inode)->ip_orphaned_slot);
853 857
@@ -869,8 +873,8 @@ int ocfs2_request_delete_vote(struct inode *inode)
869 delete_cb.rc_cb = ocfs2_delete_response_cb; 873 delete_cb.rc_cb = ocfs2_delete_response_cb;
870 delete_cb.rc_priv = inode; 874 delete_cb.rc_priv = inode;
871 875
872 mlog(0, "Inode %"MLFu64", we start thinking orphaned slot is %d\n", 876 mlog(0, "Inode %llu, we start thinking orphaned slot is %d\n",
873 OCFS2_I(inode)->ip_blkno, orphaned_slot); 877 (unsigned long long)OCFS2_I(inode)->ip_blkno, orphaned_slot);
874 878
875 status = -ENOMEM; 879 status = -ENOMEM;
876 request = ocfs2_new_vote_request(osb, OCFS2_I(inode)->ip_blkno, 880 request = ocfs2_new_vote_request(osb, OCFS2_I(inode)->ip_blkno,
@@ -895,8 +899,8 @@ static void ocfs2_setup_unlink_vote(struct ocfs2_vote_msg *request,
895 * d_delete against it. Parent directory block and full name 899 * d_delete against it. Parent directory block and full name
896 * should suffice. */ 900 * should suffice. */
897 901
898 mlog(0, "unlink/rename request: parent: %"MLFu64" name: %.*s\n", 902 mlog(0, "unlink/rename request: parent: %llu name: %.*s\n",
899 OCFS2_I(parent)->ip_blkno, dentry->d_name.len, 903 (unsigned long long)OCFS2_I(parent)->ip_blkno, dentry->d_name.len,
900 dentry->d_name.name); 904 dentry->d_name.name);
901 905
902 request->v_unlink_parent = cpu_to_be64(OCFS2_I(parent)->ip_blkno); 906 request->v_unlink_parent = cpu_to_be64(OCFS2_I(parent)->ip_blkno);
@@ -1082,7 +1086,8 @@ static int ocfs2_handle_response_message(struct o2net_msg *msg,
1082 mlog(0, "received response message:\n"); 1086 mlog(0, "received response message:\n");
1083 mlog(0, "h_response_id = %u\n", response_id); 1087 mlog(0, "h_response_id = %u\n", response_id);
1084 mlog(0, "h_request = %u\n", be32_to_cpu(resp->r_hdr.h_request)); 1088 mlog(0, "h_request = %u\n", be32_to_cpu(resp->r_hdr.h_request));
1085 mlog(0, "h_blkno = %"MLFu64"\n", be64_to_cpu(resp->r_hdr.h_blkno)); 1089 mlog(0, "h_blkno = %llu\n",
1090 (unsigned long long)be64_to_cpu(resp->r_hdr.h_blkno));
1086 mlog(0, "h_generation = %u\n", be32_to_cpu(resp->r_hdr.h_generation)); 1091 mlog(0, "h_generation = %u\n", be32_to_cpu(resp->r_hdr.h_generation));
1087 mlog(0, "h_node_num = %u\n", node_num); 1092 mlog(0, "h_node_num = %u\n", node_num);
1088 mlog(0, "r_response = %d\n", response_status); 1093 mlog(0, "r_response = %d\n", response_status);
@@ -1138,8 +1143,8 @@ static int ocfs2_handle_vote_message(struct o2net_msg *msg,
1138 mlog(0, "h_response_id = %u\n", 1143 mlog(0, "h_response_id = %u\n",
1139 be32_to_cpu(work->w_msg.v_hdr.h_response_id)); 1144 be32_to_cpu(work->w_msg.v_hdr.h_response_id));
1140 mlog(0, "h_request = %u\n", be32_to_cpu(work->w_msg.v_hdr.h_request)); 1145 mlog(0, "h_request = %u\n", be32_to_cpu(work->w_msg.v_hdr.h_request));
1141 mlog(0, "h_blkno = %"MLFu64"\n", 1146 mlog(0, "h_blkno = %llu\n",
1142 be64_to_cpu(work->w_msg.v_hdr.h_blkno)); 1147 (unsigned long long)be64_to_cpu(work->w_msg.v_hdr.h_blkno));
1143 mlog(0, "h_generation = %u\n", 1148 mlog(0, "h_generation = %u\n",
1144 be32_to_cpu(work->w_msg.v_hdr.h_generation)); 1149 be32_to_cpu(work->w_msg.v_hdr.h_generation));
1145 mlog(0, "h_node_num = %u\n", 1150 mlog(0, "h_node_num = %u\n",