Back to Main page of KG
dd_rescue
Data recovery and data protection tool
Like dd, dd_rescue does copy data from one file or block
device to another. You can specify file positions (called seek and
Skip in dd).
There are several differences:
- dd_rescue does not provide character conversions.
- The command syntax is different. Call dd_rescue -h.
- dd_rescue does not abort on errors on the input file, unless you
specify a maximum error number. Then dd_rescue will abort when
this number is reached.
- dd_rescue does not truncate the output file, unless asked to.
- You can tell dd_rescue to start from the end of a file and move backwards.
- It uses two block sizes, a large (soft) block size and a small (hard) block
size. In case of errors, the size falls back to the small one and is
promoted again after a while without errors.
Purpose of dd_rescue
The latter three features make it suitable for rescuing data from a medium
with errors, i.e. a hard disk with some bad sectors.
Why?
- Imagine, one of your partitions is crashed, and as there are some hard
errors, you don't want to write to this hard disk any more. Just getting
all the data off it and retiring it seems to be suitable. However, you
can't access the files, as the file system is damaged.
- Now, you want to copy the whole partition into a file. You burn it on
CD-Rom, just to never lose it again.
You can setup a loop device, and repair (fsck) it and hopefully are able
to mount it.
- Copying this partition with normal Un*x tools like cat or dd will fail, as
those tools abort on error. dd_rescue instead will try to read and if it
fails, it will go on with the next sectors. The output file naturally will
have holes in it, of course. You can write a log file, to see, where all
these errors are located.
- The data rate drops very low, when errors are encountered. If you
interrupt the process of copying, you don't lose anything. You can just
continue at any position later. The output file will just be filled in
further and not truncated as with other Un*x tools.
- If you have one spot of bad sectors within the partition, it might be a
good idea, to approach this spot from both sides. Reverse direction copy
is your friend.
- The two block sizes are a performance optimization. Large block sizes
result in superior performance, but in case of errors, you want to try
to salvage every single sector. So hardbs is best be set to the hardware
sector size (most often 512 bytes) and softbs to a large value, such as
the default 16k.
- For automating data recovery, the script
dd _rhelp
is useful (and included in the binary builds).
Meanwhile, the tool
GNU ddrescue
has been developed and provides an easier way for many data recovery
scenarios than the combination of dd_rhelp and dd_rescue.
dd_rescue on the other hand is still worthwhile because it has a number of
special features, such as direct IO, sparse copies, splice copies,
preallocation ...
Noteworthy are the data protection functions that have been introduced
since 1.29 to allow safe deletion of files and storage devices by overwriting
with data from a fast userspace pseudo random number generator.
In addition, since 1.42, there is a plugin interface that allows you to
analyze or transform data. A (secure) hash calculation plugin exists
as well as an LZO (de)compression plugin and an encryption plugin.
An LZMA (xz) pluging is there as well.
The plugins have a varying level of support for some of the
special dd_rescue features, but where possible, they support things like
reverse direction copy or sparse files (files with holes) etc. and you
can store additional properties (such as a hash value or a salt) in
extended attributes of the file.
More info can be found in the README file
included in the package.
I have also put the man pages for dd_rescue (1) and the
ddr_crypt (1) and ddr_lzo (1)
plugins online.
Just one note: It does work. I unfortunately did not just create this
program for fun ...
Warning
If your data is very valuable and you consider sending your crashed hard
disk to a data recovery company, you might be better off not using
an imaging tool like dd_rescue.
The reason is that your drive may have mechanical damage e.g. due to
having been dropped. Continuing to use the disk will cause further
damage, as the head might hit the surface again and again. So trying
to get data off with imaging tools might reduce the ability of the data
recovery company to get data recovered.
It is recommended to look at the
SMART
errors. If they are raising quickly or if you hear a clicking noise,
you might be in a situation where you better stop using your disk
immediately and send it in to a data recovery company.
History / News
Latest version is 1.99.20 (2025-01-20)
Improvements in version 1.99.20:
- Bugfixes:
- dd_rescue: find_nonzero() could overrun and fail.
So we may have missed sparse blocks in corner cases.
- ddr_lzo: There was an off-by-one error in buffer handling,
corrupting the memory allocator's data -- fortunately
harmless on most architectures, but leading to failures
on s390x.
- Cleanup:
- Cleaner design for handling holes in a chain of plugins,
documenting the design and simplifying it, reducing the
potential for screwup.
- Output the sequence number of plugins correctly in case one
plugin occurs multiple times in a chain.
- Many more test cases for sparse files, also in comabination
with plugin chains. We test e.g. a sparse file with
sparse ends and
hash->compress->hash->encrypt->hash
and the reverse (with hashes being validated and
file contents of course).
- Features:
- Official support for somewhat complex plugin chains,
even with sparse files. Some limitations remain:
Encryption requires no plugin after it to change
the file size/offsets, decryption does not allow
file size/offset changes ahead of it.
Previous version was 1.99.19 (2025-01-06)
Improvements in version 1.99.19:
- New features:
- dd_rescue: Support creating sparse output files when
decryption/decompression results in holes.
- ddr_crypt: Clean support for holes. This was only
handled with skiphole before.
- Bugfixes:
- ddr_lzma: Fix handling of holes at the end for lzma plugin.
- ddr_crypt: Ensure that encrypted files are identical on reverse
direction copy.
- ddr_lzma: Warn on buf error (was debug msg only).
- Optimizations:
- Adjust lzma preset to default to 3
- Cleanup:
- More testcases for sparse files with odd sizes and holes at beginning
and end of the file.
- Review use of types int vs ssize_t vs loff_t,
use loff_t += int * -1ULL to avoid nt woes.
- ddr_null: optional unsparse flag for testing.
Previous version was 1.99.18 (2024-12-29)
Improvements in version 1.99.18:
- New features:
- libddr_lzma.so: Supports sparse input now.
- Option -a will cause a sparse detection before writeout
after transformations from plugins that have the unsparse property
set. This allows creating sparse files after decompression or
decryption.
- Bugfixes:
- Set the correct plugin flags for libddr_lzma, so it won't break
when combined with other plugins.
- Fix calchmac.py to work with Python 3.12, so HMAC test are
performed again.
- Optimizations:
- libddr_lzma was overeager in copying output bytes around; avoid
this.
- Adjust lzma preset to default to 4
- Do cache prefetching from main dd_rescue and remove it from plugins.
- Cleanup:
- Testcase for sparse files being compressed.
- Rationalize log level handling (and allow to set using -E).
Previous version was 1.99.17 (2024-11-02)
Improvements in version 1.99.17:
- New features:
- libddr_lzma.so: De/Compression plugin to do LZMA2 (xz) compression.
This was contributed by Dmitrii Ivanov. This allows us to cover the
other end of the spectrum: High compression at high CPU cost for
compression, which is the opposite of LZO, which has minimal CPU
cost with moderate compression ratios. (Decompression is cheap
on both.)
- I did some cleanup to better align the code with how the rest of
dd_rescue behaves and it took me some extra time to carefully
review the plugin code before integrating it. This process
is supposed to continue. More code review is welcome and
looking how to ensure the code deals well with holes (sparse
files) and with corruption of compressed data (as much as
this is possible) is on the to do list. Help is very
much welcome!
Latest version was 1.99.16 (2024-09-30)
Improvements in version 1.99.16:
- Build improvements:
- Centralize CPU feature detection in archdep.
- Bugfixes:
- Allow passing in password into crypt plugin via pipe and passfd=
- Improvements and optimization:
- Optimized SHA2 (sha256/sha224) routines using CPU acceleration on x86-64 and armv8
Previous version 1.99.15 (2024-09-17)
Improvements in version 1.99.15:
- Build improvements:
- Detect availability of pread64() and pwrite64() separately and replace
individually. (Thanks David Geiger for reporting on Mageia.)
- Automatically set -target linux-arm/aarch64-android28 if needed (Termux)
- Bugfixes:
- printstatus() would not be called with odd offsets, resulting in missing progress
report and missing sync (-y) and write throttling (-C).
- Improvements and optimization:
- Some unrolling for the hash functions gives up to 10% better performance (on Zen4).
- Rationalize prefetching for hash functions and clear memory after using (avoid cleartext data on the stack).
- Save function calls for fault injection and for graph updates when unneeded.
- Better handle progress update frequency.
Previous version was 1.99.14 (2024-08-22)
Improvements in version 1.99.14:
- Address a few issues around compilation on musl systems (e.g. Alpine):
- Detection of LFS64 functions by compiling not just library symbol search (linking)
- Include more headers to have all definitions, most notably fcntl.h
- More consistently define _LARGEFILE64_SOURCE and _GNU_SOURCE
- Thanks go to Erhard F., see sf issue #7
- Avoid lack of reasonable semantics of POSIX basename() by providing reasonable mybasename.h
- Prefetching of constants for hash functions
- Do more fuzzing in testing lzo, hoping in liblzo no longer accepting broken input,
but problem on Fedora lblzo2 persists.
- Bugfix: Fix verbose output on fallback to small block sizes
- Bugfix: Consistently clear errno before new read attempts (broke on musl in specific scenarios)
- Bugfix: Avoid breakage on option -u without output file name
- Bugfix: Support openssl3, has a struct change of (private) struct _evp_cipher_ctx_st
since 3.0.6, broke on 32bit systems. (Alignment rules hide it on 64bit.)
- Bugfix: On ARMv7, unaligned support test is not reliable, manually override
Version 1.99.13 (2023-02-24)
Improvements in version 1.99.13:
- Better optimization of aes.c
- Better fuzz testing of lzo
- Allow overriding strip binary (contributed by Anton Samsonov)
- ddr_hash: Support checksums reading/writing from stdin.stdout "-"
- Some -fanalyzer inspired improvements: Check for failed mem allocations
- Fix aliasing issue with XORN in aes (thanks Martin Liska, Jakub Jelinek)
Latest version is 1.99.12 (2022-07-26)
Version 1.99.12 has a few improvements:
- Works with openssl-3.0:
- Using EVP_Cipher_Init() to set IV
- Option nosalthdr to match missing Salted__ header
- ARMv7 fixes:
- AES assembly works with clang now
- Ensure we use bytewise access for potentially unaligned data
- Providing builds against Android API28 (Android 9+)
Version 1.99.11 (2021-04-29)
Version 1.99.11 has a few improvements:
- AES performance tuning:
- Significant tuning of ARMv8 (and v7 on v8) crypto by better insn scheduling.
- Extra tuning for ARMv8 CTR mode (full asm), significantly beating OpenSSL. (x2 encryption not done yet, let me know if this is important for you.)
- Extra tuning for ARMv8 CBC mode (full asm), beating OpenSSL on decryption, slightly behind on encryption.
- Minor improvements for AESNI (x86-64)
- Support for 256bit VAES (Zen3, IceLake) for ECB and CTR. This required compiling aesni twice, once with and once without avx insn encoding (VEX).
Results in impressive scores on AES128-ECB/-CTR scores (in cycles per byte): 0.23 (Zen3, VAES),
0.33 (Zen 3, AESNI), 0.40 (Cortex-A78), 0.66 (Haswell/Skylake).
- test_aes: Better parameter handling in test_aes.
- test_aes: Compare IV after encryption routines; ensure we always return the IV for the next (full) block.
- test_crypt.sh: Systematically test lengths 0 -- 130 bytes.
- Make OpenSSL AES wrappers safe against len=0.
- The fuzz_lzo program now reports when it can't tweak a compressed checksum due to the block being uncompressible. This allows retrying and avoiding a test case failure.
Version 1.99.10 (2021-03-08)
Version 1.99.10 has a few improvements:
- Resolve all warnings from deprecated autoconf usage.
- More precise arm64 crypto asm memory dependency statements.
- Significant speedup by optimizing insn scheduling and avoiding
dependencies in AES CTR mode.
- Port arm64 crypto asm improvements and fixes also to arm32 (with ARMv8 crypto)
Version 1.99.9 (2021-02-27)
Version 1.99.9 has a few fixes:
- Newer systems have xattr.h included under sys/, so support xattrs also there.
- Newest compilers on Arm64 could miscompile the aes code due to aliasing issues and
missing clobbers. This has been fixed. Thanks go to Dirk Müller.
- A few minor cleanups ensuring we free everything before exiting etc. and checking
return values of all memory allocations.
- Quiesced a few warnings with -q
- One bugfix for handling filenames with spaces
Version 1.99.8 (2017-12-03)
Version 1.99.8 brings compatibility with OpenSSL-1.1.
Trouble was that the EVP interface has significantly changed.
Thanks got to Marcus Meissner for contributing the patch.
I used the opportunity to structure the AES plugins a bit better;
also the test_aes program now uses CPU detection and can thus
be used in the check target.
Version 1.99.7 (2017-11-10)
Version 1.99.7 fixes a number of issues: The double/triple overwrite
was broken due to the ratecontrol changes and has been fixed. (Thanks
go to Egger Clemens for reporting and analyzing this one.) Testcase
has been addded for it as well.
Added openssl11 compatible Salted__ header using SHA256 hash for one-round
KDF and document it.
Some Makefile and test tweaks to survive strange environments, such as emulated
PPC (which is slower than ratecontrol tests) and gentoo broken dash echo -n
(sd ticket 3, thanks to "whissi".)
1.99.6 already has a few improvements for compilation (thanks go to Michael
Matz). It also features multipart support in the hash module, so we can calculate
and validate S3 style multipart checksums.
Version 1.99.5 (2016-12-29)
Version 1.99.5 has two compiler fixes and a better estimation (and thus
better progress reporting) of the transfer length.
It also has a new ratecontrol feature, allowing to throttle the speed
with which data gets copied.
Version 1.99.4 (2016-08-25)
Version 1.99.4 has a couple of fixes on top of 1.99: A memory corruption
was resolved when using fmt_int() improperly, which was the case when
a list of bad blocks was written out with -b. Thanks to Marc Thomas
for reporting and debugging. A segfault with the graph with reverse
direction copies was also fixed as well as improved flexibility to
compile ddr_crypt plugin with incomplete support for new insns.
Version 1.99 (2015-09-09)
Version 1.99 brings updates to the ddr_crypt plugin: It adds
hardware acceleration for ARMv8 CPUs/SOCs (even if in
32bit mode) -- this is a 10x speedup on AES en/decryption operations.
(An Cortex-A57 at 2.1GHz (Exy7420) does ~1GB/s with AES128-CTR.)
The ddr_crypt plugin xattr support has been extended and it has an
option to process openSSL compatible Salted__ files. A bug in CTR
initialization has been fixed.
The main program sees improved write error retry logic and better
fault injection logic (support for ranges, using absolute positions).
There are now more variants of Android binaries, see below in the i
download section.
Version 1.98 (2015-05-30)
It has a few improvements such as a few cleanups, a fault injection framework
for testing and significantly improved speed of the pseudo RNG. But the
important feature is the addtion of a crypt plugin. You can insert it into
the plugin chain to de/encrypt data using the AES family of algorithms.
(More are planned for the future.) You can use 128/192/256 bit keys and
optionally use a higher number of rounds to have an increased security
margin. Keys (and IVs) can be generated, saved, retrieved or generated
from password and salt. Please be aware that despite diligent testing
this is a new plugin -- so be prepared that there will be some changes and
bugfixes to it in the near future.
Sourceforge (2014-04-14)
The source code is in git on SourceForge now.
It's actively developed, expect to see a 1.47 with an encryption plugin soon.
Version 1.46 (2014-08-09)
ddr_hash now supports calculating HMACS instead of plain hashes.
The hash calculation has been cleaned up a bit.
When a seed val of 0 is passed on the command line, additional
randomness is created using the rdrand() command on x86/x86-64
(if available).
Note that I switched to creating .bz2 instead of .gz tarballs
and using my new stronger GnuPG key 2bffc5bf instead of the
old 1c98774e. This time, I offer the old .gz with old
Gkey in addition, but I won't do this in the future.
(2014-06-27) A vulnerability in most implementations of lzo
decompression has been reported. The liblzo2 library (up to and
including v 2.06) used by
the ddr_lzo plugin (until dd_rescue-1.45) is affected. You need i
to feed specially crafted
compressed data in blocks of 16MB or larger to the decompressor
on 32bit platforms to exploit it, see
the report
for more details. (This issue has ID LMS-20140616-1/
CVE-2014-4607.)
The man page ddr_lzo advises to be careful when feeding data from untrusted sources to the decompressor;
it seems that this advice has been wise. Fortunately, ddr_lzo does not normally feed such large blocks
to the decompressor; you'd need to manually increase the soft block size to at least 8MB and ignore
a warning to trigger this issue with dd_rescue. But it is possible.
So here's my advice:
- Update liblzo2 to 2.07 (or a fixed 2.06 version) which has this issue fixed (your Linux
distributor should provide this very soon). This is enough to fix the issue, as the ddr_lzo
plugin of dd_rescue does dynamically link against liblzo2, except for Android.
- If using my provided Android binaries, redownload and reinstall the
libddr_lzo.so binary (now with version
number 1.45a), which has been compiled against liblzo2.a v 2.07 or better use the binaries
from 1.46.
- Be careful with media consumption -- ffmpeg/mplayer seems to be badly affected by this issue,
even on 64bit platforms.
Version 1.45 (2014-05-27)
ddr_hash received a bugfix (sha512/sha384 could overflow a buffer).
It gained support for sha1 hash. ddr_hash can now conveniently
retrieve (and check) and store hashes in xattrs and
md5sum/sha256sum/... style files. A new null plugin (ddr_null)
was added.
Previous version was 1.44 (2014-05-23)
The plugin libddr_MD5.so (short ddr_MD5) has been renamed to ddr_hash,
reflecting that we also support sha1, sha256, sha224, sha512, sha384 now.
Checks have been added to the test suite and the documentation been
updated accordingly.
Previous version was 1.43 (2014-05-20)
The main feature of 1.43 is the new lzo plugin. It de/compresses data
using the lzo algorithms, which are very fast to decompress and most
versions are also fast to compress (at somewhat moderate compression
levels). The plugin supports many of dd_rescue's features, such as
skipping bad blocks (encoding sparseness/holes into the output) as
well as appending. It also continues on errors (skipping a whole
block if nodiscard is NOT given) and allows to search for valid
lzo block headers if sync is lost. fuzz testing has been done to
support reliability. A man page ddr_lzo(1) has been created.
The plugin interface has been enhanced to support ddr_lzo; the MD5
plugin has also seen some work beyond just refactoring: It supports
the parameter output/outfd= now and supports all type of holes that
can be generated in a chain with ddr_lzo now.
Some minor improvements (docu, messages) and bug fixes have been applied.
There also is a new ARMv8 (AArch64 aka ARM64) optimized routine to detect
zero-blocks.
Version 1.42.1 (2014-03-06)
1.42.1 contains a fix for a
sublety how we set up a handler for SIGILL and return with longjmp to
detect the supported instruction sets of the CPU -- we need to manually
reset the process' signal mask, otherwise a second failed probe would
abort.
Version 1.42 (2014-03-03)
1.42 brings the possibility to load plugins to analyze or transform
data before it's written to the output file(s). A plugin to calculate
the MD5 hash is provided. posix_fadvise() is used if available (optimization)
and dd_rescue now only provides a short usage info rather than the long
help text on wrong parameters.
Version 1.41 (2014-02-25)
There has been a lot of internal refactoring that improves the detection
of CPU features (at runtime) and libc/compiler features (at build time).
One result is that this version supports building against the Android NDK.
(armv7l binaries built against Android API 17 (aka 4.2) libc can be found
below in the download section.)
Another consequence is that AVX2 support is now enabled (for saving CPU
cycles on sparse block detection).
A few minor bugs have been addressed (the most serious one a harmless
off-by-one on determining the size of a block device).
Number formatting is more consistent now.
There also a new option -u/--rmvtrim that deletes the created file
again and issues a fstrim on the filesystem -- good if you filled the
empty space of a filesystem with zeros for data protection and SSD
refreshment.
Version 1.40.1 (2014-02-15)
It just has one patch to fix the
SSE2 detection on i386 -- the old code would end in an endless loop ...
Version 1.40 (2013-08-18)
It brings copying of extended attributes (with -p/--preserve). It doubles the
default soft block size for buffered IO, but brings sparse write optimization
for half-empty blocks. It also optimizes copying by using the first write
to get rid off odd file offsets. It also adds a lot more test cases to make check.
Previous version was 1.39 (2013-08-08)
It fixes an issue where a copied file could be appended zeros if hardblocksize copy
was used (e.g. b/c hardbs==softbs, bnc #833765). There's also a bit better ARM
asm optimization, yielding a ~15% performance increase.
There's also a help/manpage clarification that syncfreq actually is a size.
And we use autoconf now to determine the target system features. Default build
target now uses libdl.
Previous version was 1.38 (2013-08-02); improving SSE sparse detection performance
(by 40%), adding a testcase for the 1.35/1.36 bug and run it in make check.
There's even an AVX version, but it's not enabled by default, as it's untested.
--force/-f now allows to ignore a non-zero output position on non-seekable
output and the curr.rate and ETA calculations have improved a bit.
Version 1.37 (2013-08-01) was fixing an issue with SSE2 sparse detection,
which could spuriously detect zero-filled blocks and thus result in corrupted
copies if option -a was used. (This would happen for blocks that had no bytes with
the uppermost bit set, such as e.g. ASCII text.) Embarassing!
Also fixed issues on big-endian machines (although these were inconsequential for dd_rescue).
Older version history ...
The previous version is 1.36, released 2013-07-24.
It fixes an overflow issue with the number output for long running dd_rescue processes.
SSE2 is now also enabled in x86 (32bit, with runtime detection) and an optimized ARM
version (assembler yeah!) to find zero blocks was added.
The previous version was 1.35, released 2013-07-17.
It had some improvements on the output that it prints -- beyond internal improvements
it introduces colours to the output unless the terminal type is clearly dumb; there is
also an option to control this. Numbers are highlighted for readability. Output is rate limited (10/s).
1.35 also brings a simple rewrite logic for handling write errors. There's an
SSE2 optimized version to find zero blocks for sparse writing.
The previous version was 1.34, released 2013-07-04,
It brought better support for various *nix systems (specifically had a few fixes for FreeBSD), better compatibility with compilers (clang and g++ and clang++).
It can now also load libfallocate at runtime (libdl) and detects a few more fatl write errors as such.
Previous version was 1.33 (2013-03-30)
and brought long options, a new double overwrite mode (-2) and a man page.
Version 1.32 has a new option -x to append to the output file and you can specify -Y (multiple
times if you wish so) to write the same data to secondary output files.
Version 1.31 (2013-02-03)
brought a few tiny improvements in the output (such as displaying the
total elapsed time in the summary as opposed to ETA of 0, and the amount of data
really written with option -W). But importantly, it has the new mode of triple
overwriting of data (options -3 and -4), with random numbers, inverse random numbers,
new random numbers (only for -4) and zeros, this way allowing paranoia-safe
deletion of information.
Version 1.30 (2013-01-25)
brought a fix for outputting data to stdout and a fix for a possible double
free operation (introduced in 1.29). The message formatting has been streamlined a bit.
The PRNG can now be initialized from a file (e.g. -Z /dev/urandom). The program now
can also avoid writing to a target block if the target block already has the same
data (option -W). Think of SSDs or other devices where you want to avoid writes.
In Version 1.29 (2013-01-22) a bug was fixed, where the last bytes where not copied
corrected if hardbs == softbs.
1.29 also brings a number of new features; the ability to write the same (softbs sized)
block again and again (option -R, automatically set if infile is /dev/zero), the
ability to limit transfer size such that the outfile won't be enlarged (-M) and
the possibility to use userspace random numbers (libc/frandom) to fill files
with random data (options -z and -Z). Last not least, OBS also builds .deb binaries
for Ubu12.04 / Deb6 now.
Version is 1.28 (released 2012-05-19) uses better defaults for hard and softblock
sizes (4k/64k for buffered I/O, 512/1M for direct IO), as suggested by Jan Kara.
Also the copying of access times with the option -p was fixed.
Version 1.27 allowed to do 512b direct IO (which is possible in latest Linux kernels)
-- idea and patch from Jan Kara. Change posix_memalign() variable assignment.
It has a number of fixes from Valentin Lab; most importantly, when exiting
because of an error, it updates the variables that are output. dd_rescue
now avoid specal characters in the logfile. It handles situations gracefully,
where wrong positions resulted in the progress graph causing faults. Some
come from illegal input (negative offset ...), which is nw detected.
Version 1.25 contains a fix for spurious "Success" messages that resulted
from overwritten (cleared) errno. Bad blocks are formatted in a way that
they are not overwritten on screen and block numbers are output as unsigned.
Version 1.24 contains a compile fix for Linux versions that contain the splice syscall
but not the other definitions. I also allows for specifying a directory (such as ".")
as output filename in which case dd_rescue just appends the input file basename to
it, just like cp does. Maybe most importantly, the RPM now contains the latest
version of dd_rhelp (0.1.2).
In version 1.23, the default to not sync every 512 soft blocks is now really
changed to only sync at the end (documented for 1.18, but mostly ineffective,
ouch). More importantly, a short read because of EOF is now not considered
an error any more and thus neither triggers messages (with quiet) nor does
it cause a confusing exit code any more.
Version 1.22 contains a number of little improvements: Display of compiler,
compile time, enabled options, don't repeat copy attempts if hardbs == softbs,
fix FPE in progress bar for non-seekable input reverse copy, and make the code
more digestable for non-GCC compilers, optional fallbacks for strsignal,
pread, pwrite. Last not least, the documentation has a few notes on the
goodies now.
Version 1.21 issues warnings when writing in a sparse mode into existing files
or to block devices.
In version 1.20, there's also a progress estimation if input file size is unknown,
but transfer size is limited with -m.
Version 1.19 brings the support for fallocate.
In version 1.18, we have changed the default to -y0 (no fsync), the avg.
speed is calculated in a meaningful way nevertheless now.
In version 1.17, a progress bar, completion percentage and ETA has been added.
In version 1.16, the work was done to determine and display the total amount of data that will be copied.
Version 1.15 brings support for the Linux splice() mechanism to avoid copying data to a userspace bugffer.
In version 1.14, a bug is fixed that could lead to a target file not
having the correct size when copied in sparse (-a) mode.
In version 1.13, a bug with read-errors and non-seekable output has been
fixed.
In version 1.12, the ability to log bad blocks to a ASCII file has been
added. The option -y can be used to set the fsync frequency which
can speed up the copy significantly.
Since 1.10, it has support for non-seekable input and output (so you can write
to pipes, e.g. stdout). Since 1.04, dd_rescue uses a larger default soft block
size (64k instead of 16k), has support for O_DIRECT, for copying the permissions,
and some minor issues fixed.
RPMs since 1.04 also include dd_rhelp.
Since version 1.03, it includes a patch from LAB Valentin which is
needed to properly support his dd_rhelp script
from his dd_rescue page.
See the RPM change log for a more detailed list
of changes.
Roadmap
Here's an unsorted list of things I'd like to do to dd_rescue when I find some time ...
- Par2 module to add error correcting Reed-Solomon/Erasure Code
- Support for more de/compression algorithms in .lzo module
- More compressed file formats (.gz, .xz, lzip)
- More stream cipher modes (GCM, XTS) in crypt plugin.
- Keep track of successfully copied blocks in dd_rescue itself to ease dd_rhelp's job ...
- Some more optimization is possible on the hash implementations, especially for ARMv8.
- Addition of SHA-3 (and SKEIN?) algorithm to ddr_hash.
- Addition of a networking plugin, e.g. to do a simple S3 put/get.
I'm open to more suggestions.
I'm even more open to contributions -- please let me know if you intend to work on improving
dd_rescue. It lives on sourceforge
and I'm happy to move to github if people want to have it
there to more easily contribute. I can also provide some guidance on e.g. the plugin API.
Downloads
Please use the RPM and DEB repository public key to validate the
RPMs/DEBs. Import it if you trust the packages from my OBS repositories. You can validate the other
files (android binaries, source tarballs) using my public gpg keys
(fingerprint 94DD 1125 CDFB AB48 6573 28EF C662 E1EA 1C98 774E). Starting from July 2014 (and dd_rescue
version 1.46), I started creating .tar.bz2 instead of .tar.gz and using my new, stronger key with
fingerprint 6669 F734 0D31 E95E C556 5490 DE4F 1B3A 2BFF C5BF for the .bz2 tarballs and Android
binaries. (Note: It's better to get my keys from public key servers ... if someone can attack this
site to put bad files up here, s/he will also change the keys and fingerprints ...)
Note that the source code is available on the sourceforge
git
(DD_RESCUE_1_99_BRANCH)
and can best be retrieved from there.
You can download
- Version 1.99.20
- Source tar ball (1.99.20, bz2) and signature (new key)
- Find binaries
on open BuildService for various distributions and architectures.
- Android binaries (ARMv5/v7, API9 => Android 2.3.4+ GB)
- Android binaries (ARMv7, API16 => Android 4.1+ JB, PIE)
- Android binaries (ARMv8(64bit), API21 => Android 5.0+ L, PIE)
- Android binaries (ARMv7, API28 => Android 9.0+ P, PIE)
- Android binaries (ARMv8(64bit), API28 => Android 9.0+ P, PIE)
- Version 1.99.19
- Source tar ball (1.99.19, bz2) and signature (new key)
- Find binaries
on open BuildService for various distributions and architectures.
- Android binaries (ARMv5/v7, API9 => Android 2.3.4+ GB)
- Android binaries (ARMv7, API16 => Android 4.1+ JB, PIE)
- Android binaries (ARMv8(64bit), API21 => Android 5.0+ L, PIE)
- Android binaries (ARMv7, API28 => Android 9.0+ P, PIE)
- Android binaries (ARMv8(64bit), API28 => Android 9.0+ P, PIE)
- Version 1.99.18
- Source tar ball (1.99.18, bz2) and signature (new key)
- Find binaries
on open BuildService for various distributions and architectures.
- Android binaries (ARMv5/v7, API9 => Android 2.3.4+ GB)
- Android binaries (ARMv7, API16 => Android 4.1+ JB, PIE)
- Android binaries (ARMv8(64bit), API21 => Android 5.0+ L, PIE)
- Android binaries (ARMv7, API28 => Android 9.0+ P, PIE)
- Android binaries (ARMv8(64bit), API28 => Android 9.0+ P, PIE)
- Version 1.99.17
- Source tar ball (1.99.17, bz2) and signature (new key)
- Find binaries
on open BuildService for various distributions and architectures.
- Android binaries (ARMv5/v7, API9 => Android 2.3.4+ GB)
- Android binaries (ARMv7, API16 => Android 4.1+ JB, PIE)
- Android binaries (ARMv8(64bit), API21 => Android 5.0+ L, PIE)
- Android binaries (ARMv7, API28 => Android 9.0+ P, PIE)
- Android binaries (ARMv8(64bit), API28 => Android 9.0+ P, PIE)
- Version 1.99.16
- Source tar ball (1.99.16, bz2) and signature (new key)
- Patch for armv7 build (using .arch armv8-a instead of armv8)
- Find binaries
on open BuildService for various distributions and architectures.
- Android binaries (ARMv5/v7, API9 => Android 2.3.4+ GB)
- Android binaries (ARMv7, API16 => Android 4.1+ JB, PIE)
- Android binaries (ARMv8(64bit), API21 => Android 5.0+ L, PIE)
- Android binaries (ARMv7, API28 => Android 9.0+ P, PIE)
- Android binaries (ARMv8(64bit), API28 => Android 9.0+ P, PIE)
- Version 1.99.15
- Source tar ball (1.99.15, bz2) and signature (new key)
- Find binaries
on open BuildService for various distributions and architectures.
- Android binaries (ARMv5/v7, API9 => Android 2.3.4+ GB)
- Android binaries (ARMv7, API16 => Android 4.1+ JB, PIE)
- Android binaries (ARMv8(64bit), API21 => Android 5.0+ L, PIE)
- Android binaries (ARMv7, API28 => Android 9.0+ P, PIE)
- Android binaries (ARMv8(64bit), API28 => Android 9.0+ P, PIE)
- Version 1.99.14
- Source tar ball (1.99.14, bz2) and signature (new key)
- Find binaries
on open BuildService for various distributions and architectures.
- Android binaries (ARMv5/v7, API9 => Android 2.3.4+ GB)
- Android binaries (ARMv7, API16 => Android 4.1+ JB, PIE)
- Android binaries (ARMv8(64bit), API21 => Android 5.0+ L, PIE)
- Android binaries (ARMv7, API28 => Android 9.0+ P, PIE)
- Android binaries (ARMv8(64bit), API28 => Android 9.0+ P, PIE)
- Version 1.99.13
- Source tar ball (1.99.13, bz2) and signature (new key)
- Find binaries
on open BuildService for various distributions and architectures.
- Android binaries (ARMv5/v7, API9 => Android 2.3.4+ GB)
- Android binaries (ARMv7, API16 => Android 4.1+ JB, PIE)
- Android binaries (ARMv8(64bit), API21 => Android 5.0+ L, PIE)
- Android binaries (ARMv7, API28 => Android 9.0+ P, PIE)
- Android binaries (ARMv8(64bit), API28 => Android 9.0+ P, PIE)
- Version 1.99.12
- Source tar ball (1.99.12, bz2) and signature (new key)
- Find binaries
on open BuildService for various distributions and architectures.
- Android binaries (ARMv5/v7, API9 => Android 2.3.4+ GB)
- Android binaries (ARMv7, API16 => Android 4.1+ JB, PIE)
- Android binaries (ARMv8(64bit), API21 => Android 5.0+ L, PIE)
- Android binaries (ARMv7, API28 => Android 9.0+ P, PIE)
- Android binaries (ARMv8(64bit), API28 => Android 9.0+ P, PIE)
- Version 1.99.11
- Version 1.99.10
- Version 1.99.9
- Version 1.99.8
-
- Version 1.99.7
-
- Version 1.99.6
-
- Version 1.99.5
-
A note on the binaries for Android above: You only really need dd_rescue and libddr_*.so plugins (and the ddr_MD5 plugin
is a symlink to ddr_hash), the rest are test programs. Choose the right ones, download and put them in a
directory in your search $PATH (/system/xbin on rooted phones, the ones from your terminal emulator or
sshd otherwise). Make them executable (chmod 0755). Best refer to the plugins using the full filenames or
append the directory in LD_LIBRARY_PATH.
- Version 1.99.4
-
A note on the binaries for Android above: You only really need dd_rescue and libddr_*.so plugins (and the ddr_MD5 plugin
is a symlink to ddr_hash), the rest are test programs. Choose the right ones, download and put them in a
directory in your search $PATH (/system/xbin on rooted phones, the ones from your terminal emulator or
sshd otherwise). Make them executable (chmod 0755). Best refer to the plugins using the full filenames or
append the directory in LD_LIBRARY_PATH.
- Version 1.98
- Version 1.46
- Version 1.45
- Version 1.44
- Version 1.43
- Version 1.42.1
- Version 1.42
- Version 1.41
- Version 1.40.1
- Version 1.40
- Version 1.39
- Version 1.38
- Version 1.37
- Version 1.36
- Version 1.35
- Version 1.34
- Version 1.33
- Version 1.32
- Version 1.31
- Version 1.30
- Version 1.29
- Version 1.28
- Version 1.27
- Version 1.25
- Version 1.24
- Version 1.23
- Version 1.22
- Version 1.21
- Version 1.20
- Version 1.18
- Version 1.15
- Version 1.14
- Version 1.13
- Version 1.12
- Version 1.11
- Older versions
-
Installation and compilation follows the standard ways. If you use Linux,
using rpm --recompile on the source RPM may be your best option.
Copyright
The program is protected by the GNU
GPL (v2 or v3).
(w) by KG, last changed 2015-09-09