]>
Commit | Line | Data |
---|---|---|
1 | /* | |
2 | * Copyright (c) 2008-2011 Apple Inc. All rights reserved. | |
3 | * | |
4 | * @APPLE_LICENSE_HEADER_START@ | |
5 | * | |
6 | * This file contains Original Code and/or Modifications of Original Code | |
7 | * as defined in and that are subject to the Apple Public Source License | |
8 | * Version 2.0 (the 'License'). You may not use this file except in | |
9 | * compliance with the License. Please obtain a copy of the License at | |
10 | * http://www.opensource.apple.com/apsl/ and read it before using this | |
11 | * file. | |
12 | * | |
13 | * The Original Code and all software distributed under the License are | |
14 | * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER | |
15 | * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, | |
16 | * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, | |
17 | * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. | |
18 | * Please see the License for the specific language governing rights and | |
19 | * limitations under the License. | |
20 | * | |
21 | * @APPLE_LICENSE_HEADER_END@ | |
22 | */ | |
23 | #include "fsck_messages.h" | |
24 | #include "fsck_hfs_msgnums.h" | |
25 | ||
26 | /* | |
27 | * HFS-specific status messages -- just indicating what phase fsck_hfs is in. | |
28 | * The structure is explained in fsck_strings.c | |
29 | */ | |
30 | fsck_message_t | |
31 | hfs_messages[] = { | |
32 | /* Message Number Message Type Verbosity Arguments */ | |
33 | /* 201 - 210 */ | |
34 | { hfsExtBTCheck, "Checking extents overflow file.", fsckMsgVerify, fsckLevel0, 0, }, | |
35 | { hfsCatBTCheck, "Checking catalog file.", fsckMsgVerify, fsckLevel0, 0, }, | |
36 | { hfsCatHierCheck, "Checking catalog hierarchy.", fsckMsgVerify, fsckLevel0, 0, }, | |
37 | { hfsExtAttrBTCheck, "Checking extended attributes file.", fsckMsgVerify, fsckLevel0, 0, }, | |
38 | { hfsVolBitmapCheck, "Checking volume bitmap.", fsckMsgVerify, fsckLevel0, 0, }, | |
39 | { hfsVolInfoCheck, "Checking volume information.", fsckMsgVerify, fsckLevel0, 0, }, | |
40 | { hfsHardLinkCheck, "Checking multi-linked files.", fsckMsgVerify, fsckLevel0, 0, }, | |
41 | { hfsRebuildExtentBTree, "Rebuilding extents overflow B-tree.", fsckMsgVerify, fsckLevel0, 0, }, | |
42 | { hfsRebuildCatalogBTree, "Rebuilding catalog B-tree.", fsckMsgVerify, fsckLevel0, 0, }, | |
43 | { hfsRebuildAttrBTree, "Rebuilding extended attributes B-tree.", fsckMsgVerify, fsckLevel0, 0, }, | |
44 | ||
45 | /* 211 - 217 */ | |
46 | { hfsCaseSensitive, "Detected a case-sensitive volume.", fsckMsgVerify, fsckLevel0, 0, }, | |
47 | { hfsMultiLinkDirCheck, "Checking multi-linked directories.", fsckMsgVerify, fsckLevel0, 0, }, | |
48 | { hfsJournalVolCheck, "Checking Journaled HFS Plus volume.", fsckMsgVerify, fsckLevel0, 0, }, | |
49 | { hfsLiveVerifyCheck, "Performing live verification.", fsckMsgVerify, fsckLevel0, 0, }, | |
50 | { hfsVerifyVolWithWrite, "Verifying volume when it is mounted with write access.", fsckMsgVerify, fsckLevel0, 0, }, | |
51 | { hfsCheckHFS, "Checking HFS volume.", fsckMsgVerify, fsckLevel0, 0, }, | |
52 | { hfsCheckNoJnl, "Checking non-journaled HFS Plus Volume.", fsckMsgVerify, fsckLevel0, 0, }, | |
53 | ||
54 | /* End of the array */ | |
55 | { 0, }, | |
56 | }; | |
57 | ||
58 | /* | |
59 | * HFS-specific error messages. Most are repairable; some are not, but there's no indication of | |
60 | * which is which here (see fsck_hfs_msgnums.h; negative values are non-repairable). | |
61 | * Messages need not be in any particular order, as fsckAddMessages will sort everything. | |
62 | */ | |
63 | fsck_message_t | |
64 | hfs_errors[] = { | |
65 | /* Message Number Message Type Verbosity Arguments */ | |
66 | /* 500 - 509 */ | |
67 | { E_PEOF, "Incorrect block count for file %s", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeFile } }, | |
68 | { E_LEOF, "Incorrect size for file %s", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeFile } }, | |
69 | { E_DirVal, "Invalid directory item count", fsckMsgError, fsckLevel1, 0, } , | |
70 | { E_CName, "Invalid length for file name", fsckMsgError, fsckLevel1, 0, } , | |
71 | { E_NHeight, "Invalid node height", fsckMsgError, fsckLevel1, 0, } , | |
72 | { E_NoFile, "Missing file record for file thread", fsckMsgError, fsckLevel1, 0, } , | |
73 | { E_ABlkSz, "Invalid allocation block size", fsckMsgError, fsckLevel1, 0, } , | |
74 | { E_NABlks, "Invalid number of allocation blocks", fsckMsgError, fsckLevel1, 0, }, | |
75 | { E_VBMSt, "Invalid VBM start block", fsckMsgError, fsckLevel1, 0, }, | |
76 | { E_ABlkSt, "Invalid allocation block start", fsckMsgError, fsckLevel1, 0, }, | |
77 | ||
78 | /* 510 - 519 */ | |
79 | { E_ExtEnt, "Invalid extent entry", fsckMsgError, fsckLevel1, 0, }, | |
80 | { E_OvlExt, "Overlapped extent allocation (id = %u, %s)", fsckMsgError, fsckLevel1, 2, (const int[]){ fsckTypeInt, fsckTypePath } }, | |
81 | { E_LenBTH, "Invalid BTH length", fsckMsgError, fsckLevel1, 0, } , | |
82 | { E_ShortBTM, "BT map too short during repair", fsckMsgError, fsckLevel1, 0, } , | |
83 | { E_BTRoot, "Invalid root node number", fsckMsgError, fsckLevel1, 0, }, | |
84 | { E_NType, "Invalid node type", fsckMsgError, fsckLevel1, 0, }, | |
85 | { E_NRecs, "Invalid record count", fsckMsgError, fsckLevel1, 0, }, | |
86 | { E_IKey, "Invalid index key", fsckMsgError, fsckLevel1, 0, }, | |
87 | { E_IndxLk, "Invalid index link", fsckMsgError, fsckLevel1, 0, }, | |
88 | { E_SibLk, "Invalid sibling link", fsckMsgError, fsckLevel1, 0, }, | |
89 | ||
90 | /* 520 - 529 */ | |
91 | { E_BadNode, "Invalid node structure", fsckMsgError, fsckLevel1, 0, }, | |
92 | { E_OvlNode, "Overlapped node allocation", fsckMsgError, fsckLevel1, 0, }, | |
93 | { E_MapLk, "Invalid map node linkage", fsckMsgError, fsckLevel1, 0, }, | |
94 | { E_KeyLen, "Invalid key length", fsckMsgError, fsckLevel1, 0, }, | |
95 | { E_KeyOrd, "Keys out of order", fsckMsgError, fsckLevel1, 0, }, | |
96 | { E_BadMapN, "Invalid map node", fsckMsgError, fsckLevel1, 0, }, | |
97 | { E_BadHdrN, "Invalid header node", fsckMsgError, fsckLevel1, 0, }, | |
98 | { E_BTDepth, "Exceeded maximum B-tree depth", fsckMsgError, fsckLevel1, 0, }, | |
99 | { E_CatRec, "Invalid catalog record type", fsckMsgError, fsckLevel1, 0, }, | |
100 | { E_LenDir, "Invalid directory record length", fsckMsgError, fsckLevel1, 0, }, | |
101 | ||
102 | /* 530 - 539 */ | |
103 | { E_LenThd, "Invalid thread record length", fsckMsgError, fsckLevel1, 0, }, | |
104 | { E_LenFil, "Invalid file record length", fsckMsgError, fsckLevel1, 0, }, | |
105 | { E_NoRtThd, "Missing thread record for root dir", fsckMsgError, fsckLevel1, 0, }, | |
106 | { E_NoThd, "Missing thread record (id = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt } }, | |
107 | { E_NoDir, "Missing directory record (id = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt } }, | |
108 | { E_ThdKey, "Invalid key for thread record", fsckMsgError, fsckLevel1, 0, }, | |
109 | { E_ThdCN, "Invalid parent CName in thread record", fsckMsgError, fsckLevel1, 0, }, | |
110 | { E_LenCDR, "Invalid catalog record length", fsckMsgError, fsckLevel1, 0, }, | |
111 | { E_DirLoop, "Loop in directory hierarchy", fsckMsgError, fsckLevel1, 0, }, | |
112 | { E_RtDirCnt, "Invalid root directory count", fsckMsgError, fsckLevel1, 0, }, | |
113 | ||
114 | /* 540 - 549 */ | |
115 | { E_RtFilCnt, "Invalid root file count", fsckMsgError, fsckLevel1, 0, }, | |
116 | { E_DirCnt, "Invalid volume directory count", fsckMsgError, fsckLevel1, 0, }, | |
117 | { E_FilCnt, "Invalid volume file count", fsckMsgError, fsckLevel1, 0, }, | |
118 | { E_CatPEOF, "Invalid catalog PEOF", fsckMsgError, fsckLevel1, 0, }, | |
119 | { E_ExtPEOF, "Invalid extent file PEOF", fsckMsgError, fsckLevel1, 0, }, | |
120 | { E_CatDepth, "Nesting of folders has exceeded %d folders", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt } }, | |
121 | { E_NoFThdFlg, "File thread flag not set in file record", fsckMsgError, fsckLevel1, 0, }, | |
122 | { E_CatalogFlagsNotZero, "Reserved fields in the catalog record have incorrect data", fsckMsgError, fsckLevel1, 0, }, | |
123 | { E_BadFileName, "Invalid file name", fsckMsgError, fsckLevel1, 0, }, | |
124 | { E_InvalidClumpSize, "Invalid file clump size", fsckMsgError, fsckLevel1, 0, }, | |
125 | ||
126 | /* 550 - 559 */ | |
127 | { E_InvalidBTreeHeader, "Invalid B-tree header", fsckMsgError, fsckLevel1, 0, }, | |
128 | { E_LockedDirName, "Directory name locked", fsckMsgError, fsckLevel1, 0, }, | |
129 | { E_EntryNotFound, "Catalog file entry not found for extent", fsckMsgError, fsckLevel1, 0, }, | |
130 | { E_FreeBlocks, "Invalid volume free block count", fsckMsgError, fsckLevel1, 0, }, | |
131 | { E_MDBDamaged, "Master Directory Block needs minor repair", fsckMsgError, fsckLevel1, 0, }, | |
132 | { E_VolumeHeaderDamaged, "Volume header needs minor repair", fsckMsgError, fsckLevel1, 0, }, | |
133 | { E_VBMDamaged, "Volume bitmap needs repair for under-allocation", fsckMsgError, fsckLevel0, 0, }, | |
134 | { E_InvalidNodeSize, "Invalid B-tree node size", fsckMsgError, fsckLevel1, 0, }, | |
135 | { E_LeafCnt, "Invalid leaf record count", fsckMsgError, fsckLevel1, 0, }, | |
136 | { E_BadValue, "(It should be %s instead of %s)", fsckMsgDamageInfo,fsckLevel1, 2, (const int[]){ fsckTypeString, fsckTypeString } }, | |
137 | ||
138 | /* 560 - 569 */ | |
139 | { E_InvalidID, "Invalid file or directory ID found", fsckMsgError, fsckLevel1, 0, }, | |
140 | { E_VolumeHeaderTooNew, "I can't understand this version of HFS Plus", fsckMsgError, fsckLevel1, 0, }, | |
141 | { E_DiskFull, "Disk full error", fsckMsgError, fsckLevel1, 0, }, | |
142 | { E_InternalFileOverlap, "Internal files overlap (file %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt } }, | |
143 | { E_InvalidVolumeHeader, "Invalid volume header", fsckMsgError, fsckLevel1, 0, }, | |
144 | { E_InvalidMDBdrAlBlSt, "HFS wrapper volume needs repair", fsckMsgError, fsckLevel1, 0, }, | |
145 | { E_InvalidWrapperExtents, "Wrapper catalog file location needs repair", fsckMsgError, fsckLevel1, 0, }, | |
146 | { E_InvalidLinkCount, "Indirect node %d needs link count adjustment", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt } }, | |
147 | { E_UnlinkedFile, "Orphaned open unlinked file %s", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeFile } }, | |
148 | { E_InvalidPermissions, "Invalid BSD file type", fsckMsgError, fsckLevel1, 0, }, | |
149 | ||
150 | /* 570 - 579 */ | |
151 | { E_InvalidUID_Unused, "Invalid BSD User ID", fsckMsgError, fsckLevel1, 0, }, | |
152 | { E_IllegalName, "Illegal name", fsckMsgError, fsckLevel1, 0, }, | |
153 | { E_IncorrectNumThdRcd, "Incorrect number of thread records", fsckMsgError, fsckLevel1, 0, }, | |
154 | { E_SymlinkCreate, "Cannot create links to all corrupt files", fsckMsgError, fsckLevel1, 0, }, | |
155 | { E_BadJournal, "Invalid content in journal", fsckMsgError, fsckLevel1, 0, }, | |
156 | { E_IncorrectAttrCount, "Incorrect number of extended attributes", fsckMsgError, fsckLevel1, 0, }, | |
157 | { E_IncorrectSecurityCount, "Incorrect number of Access Control Lists", fsckMsgError, fsckLevel1, 0, }, | |
158 | { E_PEOAttr, "Incorrect block count for attribute %s of file %s", fsckMsgError, fsckLevel1, 2, (const int[]){ fsckTypeString, fsckTypeFile } }, | |
159 | { E_LEOAttr, "Incorrect size for attribute %s of file %s", fsckMsgError, fsckLevel1, 2, (const int[]){ fsckTypeString, fsckTypeFile } }, | |
160 | { E_AttrRec, "Invalid attribute record", fsckMsgError, fsckLevel1, 0, }, | |
161 | ||
162 | /* 580 - 589 */ | |
163 | { E_FldCount, "Incorrect folder count in a directory (id = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt } }, | |
164 | { E_HsFldCount, "HasFolderCount flag needs to be set (id = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt } }, | |
165 | { E_BadPermPrivDir, "Incorrect permissions for private directory", fsckMsgError, fsckLevel1, 0, }, | |
166 | { E_DirInodeBadFlags, "Incorrect flags for directory inode (id = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt, } }, | |
167 | { E_DirInodeBadParent, "Invalid parent for directory inode (id = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt, } }, | |
168 | { E_DirInodeBadName, "Invalid name for directory inode (id = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt, } }, | |
169 | { E_DirHardLinkChain, "Incorrect number of directory hard links", fsckMsgError, fsckLevel1, 0, }, | |
170 | { E_DirHardLinkOwnerFlags, "Incorrect owner flags for directory hard link (id = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt } }, | |
171 | { E_DirHardLinkFinderInfo, "Invalid Finder info for directory hard link (id = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt } }, | |
172 | { E_DirLinkAncestorFlags, "Incorrect flags for directory hard link ancestor (id = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt } }, | |
173 | ||
174 | /* 590 - 599 */ | |
175 | { E_BadParentHierarchy, "Bad parent directory hierarchy (id = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt } }, | |
176 | { E_DirHardLinkNesting, "Maximum nesting of folders and directory hard links reached", fsckMsgError, fsckLevel1, 0, }, | |
177 | { E_MissingPrivDir, "Missing private directory for directory hard links", fsckMsgError, fsckLevel1, 0, }, | |
178 | { E_InvalidLinkChainPrev, "Previous ID in a hard link chain is incorrect (id = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt, } }, | |
179 | { E_InvalidLinkChainNext, "Next ID in a hard link chain is incorrect (id = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt, } }, | |
180 | { E_FileInodeBadFlags, "Incorrect flags for file inode (id = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt, } }, | |
181 | { E_FileInodeBadParent, "Invalid parent for file inode (id = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt, } }, | |
182 | { E_FileInodeBadName, "Invalid name for file inode (id = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt, } }, | |
183 | { E_FileHardLinkChain, "Incorrect number of file hard links", fsckMsgError, fsckLevel1, 0, }, | |
184 | { E_FileHardLinkFinderInfo, "Invalid Finder info for file hard link (id = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt, } }, | |
185 | ||
186 | /* 600 - 609 */ | |
187 | { E_InvalidLinkChainFirst, "Invalid first link in hard link chain (id = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt, } }, | |
188 | { E_FileLinkBadFlags, "Incorrect flags for file hard link (id = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt, } }, | |
189 | { E_DirLinkBadFlags, "Incorrect flags for directory hard link (id = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt, } }, | |
190 | { E_OrphanFileLink, "Orphaned file hard link (id = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt, } }, | |
191 | { E_OrphanDirLink, "Orphaned directory hard link (id = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt, } }, | |
192 | { E_OrphanFileInode, "Orphaned file inode (id = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt, } }, | |
193 | { E_OrphanDirInode, "Orphaned directory inode (id = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt, } }, | |
194 | { E_OvlExtID, "Overlapped extent allocation (id = %d)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt, } }, | |
195 | { E_UnusedNodeNotZeroed, "Unused node is not erased (node = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt, } }, | |
196 | { E_VBMDamagedOverAlloc, "Volume bitmap needs minor repair for orphaned blocks", fsckMsgError, fsckLevel1, 0, }, | |
197 | ||
198 | /* 610 - 619 */ | |
199 | { E_BadHardLinkDate, "Bad hard link creation date", fsckMsgError, fsckLevel1, 0, }, | |
200 | { E_DirtyJournal, "Journal need to be replayed but volume is read-only", fsckMsgError, fsckLevel1, 0, }, | |
201 | { E_LinkChainNonLink, "File record has hard link chain flag (id = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt, } }, | |
202 | { E_LinkHasData, "Hard link record has data extents (id = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt, } }, | |
203 | { E_FileLinkCountError, "File has incorrect number of links (id = %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt, } }, | |
204 | { E_BTreeSplitNode, "B-tree node is split across extents (file id %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt, } }, | |
205 | { E_BadSymLink, "Bad information for symbolic link (file id %u)", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypeInt, } }, | |
206 | { E_BadSymLinkLength, "Symbolic link (file id %u) has bad length (is %u, should be %u)", | |
207 | fsckMsgError, fsckLevel1, 3, (const int[]){ fsckTypeInt, fsckTypeInt, fsckTypeInt} }, | |
208 | { E_BadSymLinkName, "Bad symbolic link is `%s'", fsckMsgError, fsckLevel1, 1, (const int[]){ fsckTypePath, } }, | |
209 | ||
210 | /* And all-zeroes to indicate the end */ | |
211 | { 0, }, | |
212 | }; | |
213 |