diff options
-rw-r--r-- | fs/xfs/xfs_log_recover.c | 20 |
1 files changed, 9 insertions, 11 deletions
diff --git a/fs/xfs/xfs_log_recover.c b/fs/xfs/xfs_log_recover.c index 629e88b38bd1..a6cbc140c330 100644 --- a/fs/xfs/xfs_log_recover.c +++ b/fs/xfs/xfs_log_recover.c | |||
@@ -739,7 +739,7 @@ xlog_find_head( | |||
739 | goto bp_err; | 739 | goto bp_err; |
740 | if (new_blk != -1) { | 740 | if (new_blk != -1) { |
741 | head_blk = new_blk; | 741 | head_blk = new_blk; |
742 | goto bad_blk; | 742 | goto validate_head; |
743 | } | 743 | } |
744 | 744 | ||
745 | /* | 745 | /* |
@@ -757,7 +757,7 @@ xlog_find_head( | |||
757 | head_blk = new_blk; | 757 | head_blk = new_blk; |
758 | } | 758 | } |
759 | 759 | ||
760 | bad_blk: | 760 | validate_head: |
761 | /* | 761 | /* |
762 | * Now we need to make sure head_blk is not pointing to a block in | 762 | * Now we need to make sure head_blk is not pointing to a block in |
763 | * the middle of a log record. | 763 | * the middle of a log record. |
@@ -864,12 +864,12 @@ xlog_find_tail( | |||
864 | if (*head_blk == 0) { /* special case */ | 864 | if (*head_blk == 0) { /* special case */ |
865 | error = xlog_bread(log, 0, 1, bp, &offset); | 865 | error = xlog_bread(log, 0, 1, bp, &offset); |
866 | if (error) | 866 | if (error) |
867 | goto bread_err; | 867 | goto done; |
868 | 868 | ||
869 | if (xlog_get_cycle(offset) == 0) { | 869 | if (xlog_get_cycle(offset) == 0) { |
870 | *tail_blk = 0; | 870 | *tail_blk = 0; |
871 | /* leave all other log inited values alone */ | 871 | /* leave all other log inited values alone */ |
872 | goto exit; | 872 | goto done; |
873 | } | 873 | } |
874 | } | 874 | } |
875 | 875 | ||
@@ -880,7 +880,7 @@ xlog_find_tail( | |||
880 | for (i = (int)(*head_blk) - 1; i >= 0; i--) { | 880 | for (i = (int)(*head_blk) - 1; i >= 0; i--) { |
881 | error = xlog_bread(log, i, 1, bp, &offset); | 881 | error = xlog_bread(log, i, 1, bp, &offset); |
882 | if (error) | 882 | if (error) |
883 | goto bread_err; | 883 | goto done; |
884 | 884 | ||
885 | if (XLOG_HEADER_MAGIC_NUM == be32_to_cpu(*(__be32 *)offset)) { | 885 | if (XLOG_HEADER_MAGIC_NUM == be32_to_cpu(*(__be32 *)offset)) { |
886 | found = 1; | 886 | found = 1; |
@@ -897,7 +897,7 @@ xlog_find_tail( | |||
897 | for (i = log->l_logBBsize - 1; i >= (int)(*head_blk); i--) { | 897 | for (i = log->l_logBBsize - 1; i >= (int)(*head_blk); i--) { |
898 | error = xlog_bread(log, i, 1, bp, &offset); | 898 | error = xlog_bread(log, i, 1, bp, &offset); |
899 | if (error) | 899 | if (error) |
900 | goto bread_err; | 900 | goto done; |
901 | 901 | ||
902 | if (XLOG_HEADER_MAGIC_NUM == | 902 | if (XLOG_HEADER_MAGIC_NUM == |
903 | be32_to_cpu(*(__be32 *)offset)) { | 903 | be32_to_cpu(*(__be32 *)offset)) { |
@@ -972,7 +972,7 @@ xlog_find_tail( | |||
972 | umount_data_blk = (i + hblks) % log->l_logBBsize; | 972 | umount_data_blk = (i + hblks) % log->l_logBBsize; |
973 | error = xlog_bread(log, umount_data_blk, 1, bp, &offset); | 973 | error = xlog_bread(log, umount_data_blk, 1, bp, &offset); |
974 | if (error) | 974 | if (error) |
975 | goto bread_err; | 975 | goto done; |
976 | 976 | ||
977 | op_head = (xlog_op_header_t *)offset; | 977 | op_head = (xlog_op_header_t *)offset; |
978 | if (op_head->oh_flags & XLOG_UNMOUNT_TRANS) { | 978 | if (op_head->oh_flags & XLOG_UNMOUNT_TRANS) { |
@@ -1018,12 +1018,10 @@ xlog_find_tail( | |||
1018 | * But... if the -device- itself is readonly, just skip this. | 1018 | * But... if the -device- itself is readonly, just skip this. |
1019 | * We can't recover this device anyway, so it won't matter. | 1019 | * We can't recover this device anyway, so it won't matter. |
1020 | */ | 1020 | */ |
1021 | if (!xfs_readonly_buftarg(log->l_mp->m_logdev_targp)) { | 1021 | if (!xfs_readonly_buftarg(log->l_mp->m_logdev_targp)) |
1022 | error = xlog_clear_stale_blocks(log, tail_lsn); | 1022 | error = xlog_clear_stale_blocks(log, tail_lsn); |
1023 | } | ||
1024 | 1023 | ||
1025 | bread_err: | 1024 | done: |
1026 | exit: | ||
1027 | xlog_put_bp(bp); | 1025 | xlog_put_bp(bp); |
1028 | 1026 | ||
1029 | if (error) | 1027 | if (error) |