|The size of reads attempted first. The middle pass is roughly the logarithmic average of the bigsize and the sectorsize.|
|Read the list of blocks and block sizes to read from the specified file.|
|How often we should update the writelist file while things go OK. The default is 60 and the unit is "progress messages" so if things go well, this is the same as once per minute.|
|Write the list of remaining blocks to read to the specified file if recoverdisk is aborted via SIGINT.|
The -r and -w options can be specified together. Especially, they can point to the same file, which will be updated on abort.
The recoverdisk utility prints several columns, detailing the progress
start Starting offset of the current block. size Read size of the current block. len Length of the current block. state Is increased for every failed read. done Number of bytes already read. remaining Number of bytes remaining. % done Percent complete.
# recover data from failing hard drive ada3 recoverdisk /dev/ada3 /data/disk.img
# clone a hard disk recoverdisk /dev/ada3 /dev/ada4
# read an ISO image from a CD-ROM recoverdisk /dev/cd0 /data/cd.iso
# continue reading from a broken CD and update the existing worklist recoverdisk -r worklist -w worklist /dev/cd0 /data/cd.iso
# recover a single file from the unreadable media recoverdisk /cdrom/file.avi file.avi
# If the disk hangs the system on read-errors try: recoverdisk -b 0 /dev/ada3 /somewhere
The recoverdisk utility first appeared in
.Fx 7.0 .
.An -nosplit The original implementation was done by
.An Poul-Henning Kamp Aq phk@FreeBSD.org with minor improvements from
.An Ulrich Sprlein Aq uqs@FreeBSD.org .
This manual page was written by
.An Ulrich Sprlein .
Reading from media where the sectorsize is not a power of 2 will make all 1 MB reads fail. This is due to the DMA reads being split up into blocks of at most 128kB. These reads then fail if the sectorsize is not a divisor of 128kB. When reading a full raw audio CD, this leads to roughly 700 error messages flying by. This is harmless and can be avoided by setting -b to no more than 128kB.
recoverdisk needs to know about read errors as fast as possible, i.e. retries by lower layers will usually slow down the operation. When using cam(4) attached drives, you may want to set kern.cam.XX.retry_count to zero, e.g.:# sysctl kern.cam.ada.retry_count=0 # sysctl kern.cam.cd.retry_count=0 # sysctl kern.cam.da.retry_count=0