HFS+ Rescue - HfsprescueTable of Contents1. IntroductionHFS+ (HFS Plus, Hierarchical File System Plus) is a file system, developed and used by Apple®. hfsprescue is a program to recover files from a HFS+ formatted partition. You can restore your files and directories even when it's not possible to mount it with your operating system. As side effect, the program also restores deleted files. Your files and directories will be recovered to the directory 'restored/' in the directory where you start hfsprescue. The damaged HFS+ file system will be opened as read only to not change the data on the damaged drive. So you need enough space to copy out the files from the HFS+ file system. This program has no graphical user interface. You have to run it from the command line. hfsprescue runs under Linux, Mac OS X and FreeBSD. hfsprescue supports HFS+ compression (resource fork). Latest version: 3.6, 07/Apr/2023 2. Downloadhfsprescue-3.6.tar.gz (07/04/2023) Source code hfsprescue-3.6-precompiled.tar.gz Precompiled for Linux, Mac OS X, FreeBSD Outdated, should not be used anymore. hfsprescue-3.5.tar.gz (26/04/2020) Source codehfsprescue-3.5-precompiled.tar.gz Precompiled for Linux, Mac OS X, FreeBSD hfsprescue-3.4.tar.gz (16/02/2018) Source code hfsprescue-3.4-precompiled.tar.gz Precompiled for Linux, Mac OS X, FreeBSD hfsprescue-3.3.tar.gz (31/03/2017) Source code hfsprescue-3.3-precompiled.tar.gz Precompiled for Linux, Mac OS X, FreeBSD hfsprescue-3.2.tar.gz (29/11/2016) Source code hfsprescue-3.2-precompiled.tar.gz Precompiled for Linux, Mac OS X, FreeBSD hfsprescue-3.1.tar.gz (14/09/2016) Source code hfsprescue-3.1-precompiled.tar.gz Precompiled for Linux, Mac OS X, FreeBSD hfsprescue-3.0.tar.gz (26/07/2016) Source code hfsprescue-3.0-precompiled.tar.gz Precompiled for Linux, Mac OS X, FreeBSD hfsprescue-2.2.tar.gz (19/12/2015) Source code hfsprescue-2.2-precompiled.tar.gz (19/12/2015) Precompiled for Linux, Mac OS X, FreeBSD hfsprescue-2.1.tar.gz (19/11/2015) Source code hfsprescue-2.1-precompiled.tar.gz (19/11/2015) Precompiled for Linux, Mac OS X, FreeBSD hfsprescue-2.0.tar.gz (01/09/2015) Source code hfsprescue-2.0-precompiled.zip (01/09/2015) Precompiled for Linux, Mac OS X, FreeBSD hfsprescue-1.1.tar.gz (02/02/2015) hfsprescue-1.0.tar.gz (12/01/2015) hfsprescue-0.3.tar.gz (30/01/2013) hfsprescue-0.2.tar.gz (25/11/2011) hfsprescue-0.1-patched.tar.gz (05/10/2011) hfsprescue-0.1.tar.gz (30/11/2010) 3. Recover your filesYou have to complete 6 steps to restore your files:
hfsprescue will guide you through every step and is telling you the command for the next step. A simple example for the 6 steps:
hfsprescue -s1 /dev/sdb2 4. Additional featureshfsprescue has some additional features to help you • Search Unicode string (useful on damaged/lost partition table). 5. Command line parametershfsprescue [-h|--help] [--version]
hfsprescue -s1 <device node|image file> hfsprescue -s2 [--utf8len <value 1 to 5>] [--future-days <days>]
hfsprescue -s3 <device node|image file> hfsprescue -s4 [-d <working directory>] hfsprescue -s5 [-d <working directory>] hfsprescue -s6 [-d <working directory>] [-k]
hfsprescue --find <device node|image file> hfsprescue --list [--slash] [-d <working directory>] hfsprescue --csv <file name> [--slash] [-d <working directory>]
hfsprescue --one-file <device node|image file> <file number>
hfsprescue --find-eof
hfsprescue --extract-eof <device node|image file>
hfsprescue --find-vh
hfsprescue --find-avh
hfsprescue --extract-vh <device node|image file> <LBA sector>
hfsprescue --remove-empty-dirs Parameter descriptionDisplay help
Step 1 '-s1'Scan for your files.
Step 2 '-s2'Cleanup file database.
Step 3 '-s3'Restore your files.
Step 4 '-s4'Restore your directory structure.
Step 5 '-s5'Move the restored files to the correct directories.
Step 6 '-s6'Last step, finalize and cleanup.
Find file bytes and/or an unicode string '--find'Find data on sectors. See here for details.
List files '--list'List found files. See here for details.
CSV export of file list '--csv'Export list to a CSV file. See here for details.
Restore one file '--one-file'Restore just one file instead of all files that have been found. You can run this after you completed Step 2. See here for details.
Find the Extents Overflow File '--find-eof'Scan the device for possible start blocks. See here for details. Extract the Extents Overflow File '--extract-eof'See here for details.
Find the HFS+ Volume Header '--find-vh'Scan the device for possible Volume Headers and shows the start of the partition. See here for details.
Find the HFS+ Alternate Volume Header '--find-vh'Scan the device for possible Alternate Volume Headers. See here for details.
Extract the Volume Header'--extract-vh'See here for details.
Remove empty directories '--remove-empty-dirs'See here for details.
The '--alternative' parameterDuring the restore process, it's possible that files have the same name in the same directory. This happens because of deleted files or older versions of files. The default behavior is, that hfsprescue will keep only the latest version of the file, depending on the file date/time. But sometimes its needed to restore deleted and older versions of a file too. You can do this with the '--alternative' parameter. With this parameter, hfsprescue creates an alternative name, which is a combination of the original name and the Catalog ID of the file (+ if needed an additional number), when there is already a file in the directory. Note: Older versions of a file or deleted files may be corrupted. 6. List found filesYou can display a list of files that have been found, after you completed Step 2 '-s2'. List fields: File Number: File Name, File Size, File RAW Time, File Date/Time, File Start Block
Note: • Files that need the Extents Overflow File are marked with '_F_EOF_'. Use '--list' with 'grep' to get the file number when you want to restore a single file.
7. CSV export of file listYou can export a list of files that have been found to a CSV file, after you completed Step 2 '-s2'. The fields are separated by semicolon ';'. Fields: Number, File Name, Parent ID, Catalog ID, File Size, File RAW Time, File Time, Start block, HFS+ Compressed, EOF (ExtentsOverflowFile)
8. Restore one fileYou can restore just one file instead of all files that have been found. This feature can be used after you completed Step 2 '-s2'. hfsprescue --one-file <device node|image file> <file number> [-b <block size>] [-o <offset in bytes>] [-d <working directory>] [--vh-file <file name>] [--eof-file <file name>] [--alternative] You need the file number to restore a file. You get this number with using 'hfsprescue --list' or from the CSV export file. Example to restore a file called 'mynotes.txt':
9. Restore files with a listWhen you don't want to restore all files in step 3, then you can use a list of files that you want to restore. Use the parameter '--file-list <file name>' for a simple list or '--file-list-csv <file name>' for a list in CSV format. Simple list: --file-list <file name>The list file has a simple format. At the beginning of the line is the file number (from --list), then comes a colon. After the colon can be any text. The text after the colon will be ignored. Sample file with 10 files to restore: 1003: 283: 553: 18: live.1.shadowIndexHead, 4096 bytes, 1438688946, Tue Aug 4 13:49:06 2015, Start block 589824 19: live.2.directoryStoreFile, 4096 bytes, 1438688943, Tue Aug 4 13:49:03 2015, Start block 524338 20: live.2.directoryStoreFile.shadow, 1088 bytes, 1438688947, Tue Aug 4 13:49:07 2015, Start block 524374 21: live.2.indexArrays, 4096 bytes, 1438688947, Tue Aug 4 13:49:07 2015, Start block 524322 22: live.2.indexCompactDirectory, 1024 bytes, 1438688947, Tue Aug 4 13:49:07 2015, Start block 524321 450: 451: With this function its easy to select files to restore or exclude files from restoring. As step 4 restores the whole directory structure (even when you restore only a few files), can you use at the end after '-s6' the command 'hfsprescue --remove-empty-dirs' to remove the empty directories. Example: Exclude filesThis example shows how to exclude files with the extensions '.download' and '.part' from restoring. hfsprescue --list | grep -v ".download, " | grep -v ".part, " > files.list
• 'grep' is used with '-v' to exclude the pattern from the output. The command of step 3: hfsprescue -s3 /dev/sdb1 --file-list files.list Example: Restore files with modification datesThis example creates a list with files that have a modification date of 4., 5. and 12. August 2015.
hfsprescue --list | grep " Aug 4 " | grep " 2015, " > files.list
• 'grep' is used get the text with the pattern. The command of step 3: hfsprescue -s3 /dev/sdb1 --file-list files.list Example: Exclude files with 0 bytesThis example creates a list with files that are bigger than 0 bytes. hfsprescue --list | grep -v ", 0 bytes, " > files.list
• 'grep' is used with '-v' to exclude the pattern from the output. The command of step 3: hfsprescue -s3 /dev/sdb1 --file-list files.list CSV: --file-list-csv <file name>To accomplish a more complex filter for files, use some kind of Excel/Spreadsheet software. Export the file list with '--csv'. Import the file in your spreadsheet program and do the modfications. Then export/save the data to a new CSV file. The delimiter must be a semicolon. The header line (first line) will be ignored by hfsprescue. Sample file: "Number";"File Name";"Parent ID";"Catalog ID";"File Size";"File RAW Time";"File Time";"Start block";"HFS+ Compressed";"EOF" 14;"fseventsd-uuid";28;29;36;1438141708;"Wed Jul 29 05:48:28 2015";393217;"No";"No" 15;"reverseStore.updates";26;96;1;1438688947;"Tue Aug 4 13:49:07 2015";622602;"No";"No" 16;"store.updates";26;95;3;1438688947;"Tue Aug 4 13:49:07 2015";622601;"No";"No" 17;"live.1.shadowIndexGroups";26;132;6;1438688945;"Tue Aug 4 13:49:05 2015";163913;"No";"No" 18;"live.1.shadowIndexHead";26;221;4096;1438688946;"Tue Aug 4 13:49:06 2015";589824;"No";"No" 19;"live.2.directoryStoreFile";26;194;4096;1438688943;"Tue Aug 4 13:49:03 2015";524338;"No";"No" 10. Find the HFS+ Volume Header or Alternate Volume Header and the partition start offsetThe Volume Header and Alternate Volume Header have important information about the HFS+ file system. Both can be used to find the start of a partition. Parameter: --find-vh / --find-avh The Volume HeaderThe location of the Volume Header is 1024 bytes after the partition start. Finding the Volume Header is a good way to find the partition start. The Volume Header has also important information like the location and size of the Extents Overflow File. When you lost the partition table or you are working with a hard disk image then it's required to know the start offset of the partition with your HFS+ file system. One solution to get the partition start offset is to find the HFS+ Volume Header with the '--find-vh' parameter. A HFS+ file system has a backup of the Volume Header (the Alternate Volume header). This means that hfsprescue will report a few hits. When you had only one HFS+ partition on the drive, then the first hit should be the right one. You can use the '--first' parameter to limit the output to the first detected HFS+ Volume Header. A valid HFS+ Volume Header criteria of hfsprescue is the 'lastMountedVersion' field. This field is set by the operating system that mounts the partition. Only Mac OS X and Linux is seen as valid by hfsprescue. When the last mount of the partition has been done by another OS, then use '-f' to ignore the OS limitation. If you need more details during the search process then use the '-v' verbose parameter. When you use '-o <offset in bytes>' then the search begins at the offset and skips the bytes before. The result of the search will be logged in the file 'hfsprescue-data/find-vh.log'. hfsprescue --find-vh [-o <offset in bytes>] [--first] [-f|--force] [-v|--verbose] Example: Show only the first HFS+ Volume Header.
You can extract the Volume Header. See here.
The Alternate Volume HeaderThe Alternate Volume Header is a backup of the Volume Header and is stored 1024 bytes before the end of the partition. When you know the location of the Alternate Volume Header, the block size and total blocks, then its possible to calculate the partition start. The search for the Alternate Volume Header goes from the end of the hard disk to the beginning. The resultof the search is stored in 'hfsprescue-data/find-avh.log'. hfsprescue --find-avh [--first] [-f|--force] [-v|--verbose] Example: Stop after the first HFS+ Alternate Volume Header.
You can extract the Volume Header. See here.
11. Extract the HFS+ Volume HeaderYou can extract the Volume Header from the drive to a file with the '--extract-vh' parameter. hfsprescue --extract-vh <device node|image file> <LBA sector> [--vh-file <output file>] Beside the device node or image file is the LBA sector number required to extract the Volume Header. When you don't know the LBA sector number, then it's possible to find the Volume Header. See Find the HFS+ Volume Header or Alternate Volume Header and the partition start offset. You can use the Volume Header file in program modes like '-s1', '-s3', '--one-file' and others. The default output file is './restored/VolumeHeader'. You can specify another output file name with '--vh-file'. Sample command: hfsprescue --extract-vh /dev/sdb 409642 12. Find the Extents Overflow FileThe Extents Overflow File is used to store the positions of file fragments when a file is split into more that 8 fragments on the file system. When the Volume Header is destroyed or has a wrong entry for the Extents Overflow File, then its not possible to restore strong fragmented files. You can use '--find-eof' to search for possible positions of the Extents Overflow File. hfsprescue will report possible start blocks. I found no way to reduce the possible positions and exactly identify the Extents Overflow File. It should be one of the first 7 values. hfsprescue --find-eof [-b <block size>] [-o <offset in bytes>] [--vh-file <file name>] Note: When you use the '-o <offset in bytes>' parameter, then the reported start blocks are relative to the offset value. Note: When the Volume Header is defect and you have a backup, then specify the file name with '--vh-file'. When you found positions, then you can extract the Extents Overflow File to a file. See Extract the Extents Overflow File. Example:
Info: When you have strong fragmented files, then • those files will be reported in the log file of Step 3. Search for the text '_has_extents_overflows_'. 13. Extract the Extents Overflow FileThe Extents Overflow File is required to restore heavy fragmented files. The Extents Overflow File is extracted automatically to a file by hfsprescue when the Volume Header is valid and you use '-s3' or '--one-file'. You can extract the Extents Overflow File on demand with '--extract-eof'. hfsprescue --extract-eof <device node|image file> [ [--start-block <number>] < [--last-block <number>] | [--num-blocks <number>] > ] [--eof-file <output file>] [--vh-file <file name>] The default output file is './restored/ExtentsOverflowFile'. You can set another file name with '--eof-file <output file>'. Note: When you formatted the partition, then the Extents Overflow File is lost in the most cases. Valid Volume HeaderWhen your Volume Header is valid, then '--extract-eof' does not need any additional parameters to extract the Extents Overflow File. Example: 'hfsprescue --extract-eof /dev/sdb1' Signature: 0x2b48, H+ LastMountedVersion: H+Lx, last mount by Linux. FileCount: 4362 DirCount: 144 BlockSize: 4096 TotalBlocks: 244190208 AllocationFile StartBlock: 1 ExtentsOverflowFile StartBlock: 7454 CatalogFile StartBlock: 10270 Total size: 931 GB Extracting the ExtentsOverflowFile to 'restored/ExtentsOverflowFile'. Size: 11534336 bytes, 11.00 MB Clump Size: 11534336 bytes Total Blocks: 2816 Extent 0: Start 7454, Num 2816 Extent 1: Start 0, Num 0 Extent 2: Start 0, Num 0 Extent 3: Start 0, Num 0 Extent 4: Start 0, Num 0 Extent 5: Start 0, Num 0 Extent 6: Start 0, Num 0 Extent 7: Start 0, Num 0 File created. Extract with Volume Header problemsWhen your Volume Header is defect, then you can use '--find-eof' to locate possible positions of the Extents Overflow File. You can use those possible positions and try to extract the Extents Overflow File. When you extract with '--start-block' and '--last-block' / '--num-blocks' then only the given range will be extracted. When the Extents Overflow File itself has fragments, then its not possible to restore the whole file without a Volume Header. You can use a Volume Header file with '--vh-file <file name>' when the partition Volume Header is defect. A simple example: • At first, search for possible locations. hfsprescue --find-eof /dev/sdb -b 4096 *** Force block size: 4096 Signature: 0x00, (Unknown) LastMountedVersion: , last mount was not done by Mac OS X. FileCount: 0 DirCount: 0 BlockSize: 4096 TotalBlocks: 0 AllocationFile StartBlock: 0 ExtentsOverflowFile StartBlock: 0 CatalogFile StartBlock: 0 Total size: 931 GB Searching block positions of the Extents Overflow File... 1. Possible block: 7710 | File position: 0x1e1e000 2. Possible block: 10526 | File position: 0x291e000 maybe ExtentsOverflowFile or CatalogFile • Then extract the Extents Overflow File. We use as start block the first entry and as last block the second entry value -1. hfsprescue --extract-eof /dev/sdb -b 4096 --start-block 7710 --last-block 10525 *** Force block size: 4096 Signature: 0x00, (Unknown) LastMountedVersion: , last mount was not done by Mac OS X. FileCount: 0 DirCount: 0 BlockSize: 4096 TotalBlocks: 0 AllocationFile StartBlock: 0 ExtentsOverflowFile StartBlock: 0 CatalogFile StartBlock: 0 Total size: 931 GB Extracting the ExtentsOverflowFile to 'restored/ExtentsOverflowFile'. *** Warning. No extents of the ExtentsOverflowFile will be restored. Extracting blocks from 7710 to 10525. 2816 blocks. File created. You have to test the extracted Extents Overflow File with restoring a strong fragmented file.
Use 'hfsprescue --list | grep _F_EOF_' to find an affected file. When you find more possible positions, then you have to test them until you find the correct start/end of the Extents Overflow File. 14. Remove empty directoriesThe whole directory structure will be recovered in step 4. Even, when you recover only a few files ins step 3. Now, you have a lot of empty directories at the end of step 6 '-s6'. You can remove them with '--remove-empty-dirs'. hfsprescue --remove-empty-dirs [--dir <directory>] [-f|--force] The standard start directory is './restored'. You can set a directory with '--dir'. Before the program removes the empty directores, it shows the full start path and ask you to continue. You have to enter 'y' and the program starts. You can skip the question with the parameter '-f' or '--force'. 15. Find bytes from a file and/or an Unicode stringAn additional debug/search feature is to find bytes from a file and/or Unicode strings. -ff and -fi can be used with the same command. hfsprescue --find <device node|image file> [-ff <num bytes> <file1> [file2] [...]] [-fs <string>] [-o <offset in bytes>] • Find bytes of one or more files -ff You can find the bytes of a file. This can be very useful when you lost the partition table and you have to calculate the offset of the partition. It makes no sense to search for the whole file. It can be fragmented and you will never get a hit. The file size of the source file is not limited by hfsprescue. Regardless to the file size is the maximum search buffer size 1MB. This this is really large. I suggest to use the block size as maximum search length. The result of the search will be logged in the file 'hfsprescue-data/find.log'. When you use '-o <offset in bytes>' then the search begins at the offset and skips the bytes before. Find bytes example 1:
Find bytes example 2: Multiple files
• Find string -fs This can be used to find an Unicode string. File names are encoded in Unicode. Its possible to find directory entries with this feature. The search string will be converted to Unicode by hfsprescue. The result of the search will be logged in the file 'hfsprescue-data/find.log'. When you use '-o <offset in bytes>' then the search begins at the offset and skips the bytes before. Find string example:
16. Files & Logs of hfsprescuehfsprescue stores it's files in the directory './hfsprescue-data/' or the directory you sett with '-d'.
Note: Logs are appended when you restart an action. Its uppon the user to truncate/remove the log files. 17. The 'restored' directoryThe 'restored' directory will be created in the directory where you start hfsprescue or you set with the '-d' parameter. Your files and directories will be recovered to this directory. When you use '--one-file', then the restored file will be written directly to the 'recovered' directory without any path. After step 6 has been completed, there are also a few additional files and directories, created by hfsprescue. Directory: restored/newroot/recovered/ You find your recovered files here. Directory: restored/newroot/x_directory_problem/ It was not possible to link the files and directories to their parent directory. You will find here files too. Directory: restored/newroot/x_unknown/ No valid parent directory has been found. Maybe you will find here already deleted files. The files in this directories can be invalid. Files in restored/newroot/ INFO.TXTJust an info file for you.recovered-files.txt, x_directory_problem-files.txt, x_unknown-files.txtThe contents of those files is just a list of the files in the corresponding directory. Useful when you need an overview of the restored files. 18. Problems / FAQThe following articles are about why files are defect recovered and what you can do against it. Mostly its a problem because of a wrong access to the partition data. You will also see how you can find the start of a partition. Overview: • Restored files are invalid/defect! Why? 19. Restored files are invalid/defect! Why?Reasons for invalid/defect files can be
The most cases are a wrong partition start. See here how to get the correct partition start offset. 20. Partition table damaged, lost or not usable! How do I find the correct partition offset?HFS+ Rescue can help you to find the correct partition offset when • you are working with a real drive and - the partition table has been damaged.OR • you are working with a complete hard disk image and - you are unable to use the program kpartx. When do I need the partition start offset? When you are unable to access the partition then hfsprescue cannot read the block size and the start block of the Extents Overflow File. Also it's not possible to successful restore the files, because they are stored relative to the partition start. There are 2 ways to find the partition start offset with hfsprescue.
21. How do I find the correct partition offset with a reference fileBefore you can start, it's required that you completed the file restore Steps 1 & 2. When you did that some time ago then continue. You should know the block size of the damaged file system. Usually it's 4096. When the partition is bigger than 2 TB, then the usual block size is 8192. You need a file that was on the drive. It can be any type of file. Maybe the executable file of a program (get it from another computer) or a picture file (maybe from an old backup). I prefer a picture file. Choose a file that was nearly only once on the drive to reduce false hits. 1) At first check if the file has been found during -s1 and -s2. For this example I am using a picture file called 'PerfectPicture.jpg'. hfsprescue --list | grep PerfectPicture.jpg Sample output: 77: PerfectPicture.jpg, 892187 bytes, Sun May 10 18:21:18 2015, Start block 131074 Great, the 'PerfectPicture.jpg' file has been found. And we have luck, it was only once on the drive ;). When you have a file that has been found more than once, then either choose another file or you have to test various offset values at the end of the process until you have the right one. 2) The next step is to do a byte search for the file on the drive. hfsprescue --find /dev/sdb -ff 4096 PerfectPicture.jpg Sample output: File bytes found at offset 746586112 + 28672 = 746614784 (0x2c800000 + 0x7000 = 0x2c807000) Great, the bytes of our file have been found and what a surprise, the bytes have been found also only once. When the bytes have been found more than once, then you have to calculate offset values with the other found offsets too. 3) The formula. offset = byte_search_result - list_start_block * block_size With our values it looks like offset = 746614784 - 131074 * 4096 When you doesn't have a calculator then use the shell for the calculation. echo $((746614784 - 131074 * 4096)) The result is 209735680 A simple check if it could be a correct result is to modulo the value with 512. echo $((209735680 % 512)) the result must be 0. 4) Check if the calculated offset is correct. Restore the file with '--one-file' and the file number from '--list' and the calculated offset value. hfsprescue --one-file /dev/sdb 77 -b 4096 -o 209735680 This command restored the file to restored/PerfectPicture.jpg. Now compare the reference file with the restored file. diff PerfectPicture.jpg restored/PerfectPicture.jpg When 'diff' doesn't report a difference, then the offset value for the partition is correct. Remove the old 'restored/' directory and restart with Step 3 '-s3' and use the calculated offset value with '-o'. Example: hfsprescue -s3 /dev/sdb -b 4096 -o 209735680 22. Unusual block sizeThe correct block size is required to restore files. The block size is stored in the HFS+ Volume Header. When this header is corrupt or not available, then its not possible for hfsprescue to determine the correct block size. There can be many reasons for a corrupt header. Either it is really overwritten by some data or you do not access the partition from it's beginning (Common mistake when you work with a complete hard disk image). Solutions:
Usually, the value for the block size is '4096'. When the partition is bigger than 2 TB, then the usual block size is '8192'. 23. Extents Overflow File problemsWhen you have strong fragmented files, then its required to access the Extents Overflow File which is an area on the HFS+ partition. When this area has been overwritten, then there is no chance to restore files that have information stored in the affected area. With '--find-eof' you can search for possible start blocks of the Extents Overflow File. With '--extract-eof' its posbbile to save the Extents Overflow File into a file. This file can be used for the restore process. 24. Permission deniedWhen you try to access a device, then you need root permissions. Just use 'sudo'. Example: sudo hfsprescue -s1 /dev/sdb2 or change to the root user with 'su'. It's also possible that the device is mounted. Unmount the device before you run hfsprescue. For Mac OS X see here. 25. sudo: hfsprescue: command not foundWhen you start hfsprescue with 'sudo' and the program is not in your PATH, then you have to set a path. Example: hfsprescue is in the current directory: sudo ./hfsprescue 26. Precompiled - FATAL: kernel too oldThe x86 Linux versions are compiled against LibC 2.11. When your Linux distribution is using an older version then you will see the error 'FATAL: kernel too old'. You have to compile the source code on your computer. You need the GCC (GNU Compiler Collection) installed to compile hfsprescue. 27. File name accent troublesThis is related for other operating systems than Mac OS X. The unicode to UTF-8 file name conversion is not fully supported. There are problems with accents on non Mac OS X systems. A fix: The accents should be corrected when you copy the restored files to a HFS+ file system. This bug will be fixed maybe in a further version. 28. Asian file namesWhen you have files with asian file names, then you have to set '--utf8len 2' on step 2. Example: hfsprescue -s2 --utf8len 2 When you don't set the utf8len, then all files with asian chars will be seen as false file name and filtered. Note: You don't have to run again -s1 to change the utf8len. Just run again -s2 with the required setting. 29. Mac OS X notesWhen you try to restore data from a drive that is automatically mounted when you connect it, then unmount it with 'diskutil'. This situation can happen when you connect a drive with a valid file system. Maybe after an unwanted fresh formatting. Just figure out the device name with 'mount'. Sample output: /dev/disk0s2 on / (hfs, local, journaled) devfs on /dev (devfs, local, nobrowse) map -hosts on /net (autofs, nosuid, automounted, nobrowse) map auto_home on /home (autofs, automounted, nobrowse) /dev/disk6s2 on /Volumes/Untitled (hfs, local, nodev, nosuid, journaled, noowners)The affected partition is '/dev/disk6s2 (/Volumes/Untitled)'. Unmount the partition with 'sudo diskutil umount /dev/disk6s2'. Now you are able to access the partition with hfsprescue. Example: sudo hfsprescue -s1 /dev/disk6s2 30. Personal notesI wrote the first version of this tool for my neighbour. He was unable to mount the HFS+ partition. He got the error 'hfs: failed to load catalog file' and some other errors about the B-Tree. I was able to restore the most files. Meanwhile, my program became very sophisticated with many features. When there are still problems then just contact me, but don't forget a friendly "hello". © 2025 by
Elmar Hanlhofer |