From owner-freebsd-fs@FreeBSD.ORG Thu Feb 24 20:19:56 2005 Return-Path: Delivered-To: freebsd-fs@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id A29B716A4CE for ; Thu, 24 Feb 2005 20:19:56 +0000 (GMT) Received: from mailout1.pacific.net.au (mailout1.pacific.net.au [61.8.0.84]) by mx1.FreeBSD.org (Postfix) with ESMTP id 109B743D55 for ; Thu, 24 Feb 2005 20:19:56 +0000 (GMT) (envelope-from bde@zeta.org.au) Received: from mailproxy1.pacific.net.au (mailproxy1.pacific.net.au [61.8.0.86])j1OKJIA6002607; Fri, 25 Feb 2005 07:19:18 +1100 Received: from katana.zip.com.au (katana.zip.com.au [61.8.7.246]) j1OKJFS5005141; Fri, 25 Feb 2005 07:19:17 +1100 Date: Fri, 25 Feb 2005 07:19:14 +1100 (EST) From: Bruce Evans X-X-Sender: bde@delplex.bde.org To: falaki@ce.sharif.edu In-Reply-To: <53844.194.225.42.20.1109263952.squirrel@ce.sharif.edu> Message-ID: <20050225065121.U251@delplex.bde.org> References: <53844.194.225.42.20.1109263952.squirrel@ce.sharif.edu> MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII cc: freebsd-fs@FreeBSD.org Subject: Re: badsect X-BeenThere: freebsd-fs@freebsd.org X-Mailman-Version: 2.1.1 Precedence: list List-Id: Filesystems List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Thu, 24 Feb 2005 20:19:56 -0000 On Thu, 24 Feb 2005 falaki@ce.sharif.edu wrote: > I have a hard disk that seems to have some limitted number of bad sectors. > I want to use badsect to avoid these errors. > > ad0: TIMEOUT - READ_DMA retrying (2 retries left) LBA=27546816 > ad0: FAILURE - READ_DMA timed out > > I tried this: > > #badsect /mnt/data 27546816 > > and got: > > block 27546816 out of range of file system > don't forget to run fsck ... > > What should I do? The usual answer is to replace the disk. If you want to try to use badsect, be aware of bugs. Accordng to badsect(1): ... (The sector numbers must be relative to the beginning of the file system, but this is not hard as the system reports relative sector numbers in its console error messages.) ... This never worked for all disk drivers in FreeBSD, and only worked for a short time in the ATA driver. Drivers were supposed to call diskerr() to report the disk block number in a uniform way that includes the subdevice and relative block number. The ATA driver used to call diskerr(), but about a year the call was replaced by a printf() that just gives the absolute LBA as above. The ATA driver still calls diskerr() in RELENG_4, but it passes a wrong block number so that the actual failing block number is even harder to untangle than for an absolute one (the result is the relative block number doubled for single 512-block accesses and sometimes a bit less than doubled for larger accesses). badsect also has a fairly fundamental limitation to sector numbers less than 2^31-1, so it will be even less useful when 1TB is a small disk. Bruce