Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 11 Jul 2003 18:23:33 -0700 (PDT)
From:      Dan Strick <strick@covad.net>
To:        questions@freebsd.org
Cc:        dan@ice.nodomain
Subject:   Re: Advise on data recovery from failed drive
Message-ID:  <200307120123.h6C1NXBI001008@ice.nodomain>

next in thread | raw e-mail | index | archive | help
On Friday July 12, 2003 (PST) Per olof Ljungmark wrote:
>>>>>>>>>>>>>>>>>>>
> I've had a drive crash where the spindle motor bearings overheated and
> got stuck.
> Using mild violence I now have the drive spinning again and need to do
> some data recovery.
>
> It has to be something that is able to handle read errors without stopping,
> I am thinking dd, any other suggestions?
>>>>>>>>>>>>>>>>>>>>>

I have an ancient program that I once wrote to make copies of disk drives
with bad sectors.  It normally reads/writes in large units, but goes back
and rereads a section of the input disk one 512 byte sector at a time if
it gets a read error.  It will retry a single sector read several times before
giving up.  Unreadable sectors are "assumed" to be zero.

This program was intended to be used with raw disk devices (drivers)
doing unbuffered "physical" I/O with simple error recovery procedures
(perhaps a limited number of read retries).  I have not "ported" it to
FreeBSD or even looked at it in many years, but it ought to work ok as is.

The traditional dd program has a few problems if you use it with the
"conv=noerror" option to copy sick disks.  One problem is that you
must specify "bs=512" (i.e. copy only one sector at a time) to avoid
losing good disk sectors adjacent to a bad disk sector.  This makes
for a slow copy.

Another problem is that is that if you tell dd to ignore input errors,
it skips the bad blocks on input but not on output so that after a read
error blocks are copied to a wrong disk address.  I just did a man on the
FreeBSD 4.8-RELEASE dd command and discovered a new option that avoids
this problem.  Specify "conv=noerror,sync" if you use the dd command.

Dan Strick



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200307120123.h6C1NXBI001008>