2005-04-15 01:29:29 +04:00
|
|
|
.\" $NetBSD: fsck_lfs.8,v 1.20 2005/04/14 21:29:29 wiz Exp $
|
1999-03-18 05:02:18 +03:00
|
|
|
.\"
|
|
|
|
.\" Copyright (c) 1980, 1989, 1991, 1993
|
|
|
|
.\" The Regents of the University of California. All rights reserved.
|
|
|
|
.\"
|
|
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
|
|
.\" modification, are permitted provided that the following conditions
|
|
|
|
.\" are met:
|
|
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
|
|
.\" documentation and/or other materials provided with the distribution.
|
2003-08-07 14:04:22 +04:00
|
|
|
.\" 3. Neither the name of the University nor the names of its contributors
|
1999-03-18 05:02:18 +03:00
|
|
|
.\" may be used to endorse or promote products derived from this software
|
|
|
|
.\" without specific prior written permission.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
.\" ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
|
|
|
.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
.\" SUCH DAMAGE.
|
|
|
|
.\"
|
|
|
|
.\" @(#)fsck.8 8.3 (Berkeley) 11/29/94
|
|
|
|
.\"
|
2005-04-15 01:26:11 +04:00
|
|
|
.Dd April 14, 2005
|
1999-03-18 05:02:18 +03:00
|
|
|
.Dt FSCK_LFS 8
|
2001-06-05 15:22:41 +04:00
|
|
|
.Os
|
1999-03-18 05:02:18 +03:00
|
|
|
.Sh NAME
|
|
|
|
.Nm fsck_lfs
|
1999-03-19 20:29:44 +03:00
|
|
|
.Nd Log-structured File System consistency check and interactive repair
|
1999-03-18 05:02:18 +03:00
|
|
|
.Sh SYNOPSIS
|
|
|
|
.Nm fsck_lfs
|
2005-04-15 01:15:59 +04:00
|
|
|
.Op Fl dfpq
|
2004-07-06 20:51:18 +04:00
|
|
|
.Op Fl b Ar block
|
|
|
|
.Op Fl m Ar mode
|
2005-04-15 01:15:59 +04:00
|
|
|
.Op Fl y | n
|
1999-03-18 05:02:18 +03:00
|
|
|
.Ar filesystem
|
|
|
|
.Ar ...
|
|
|
|
.Sh DESCRIPTION
|
2000-11-07 09:43:24 +03:00
|
|
|
.Nm
|
2005-04-15 01:26:11 +04:00
|
|
|
performs interactive filesystem consistency checks and repair for
|
|
|
|
each of the filesystems specified on the command line.
|
2002-10-01 17:40:23 +04:00
|
|
|
It is normally invoked from
|
1999-03-18 05:02:18 +03:00
|
|
|
.Xr fsck 8 .
|
|
|
|
.Pp
|
|
|
|
The design of LFS takes care that no filesystem inconsistencies can
|
|
|
|
happen unless hardware or software failures intervene.
|
2000-11-07 09:43:24 +03:00
|
|
|
.Nm
|
1999-03-18 05:02:18 +03:00
|
|
|
will report and optionally correct any such inconsistencies.
|
|
|
|
.Pp
|
|
|
|
For each corrected inconsistency one or more lines will be printed
|
|
|
|
identifying the filesystem on which the correction will take place,
|
2002-10-01 17:40:23 +04:00
|
|
|
and the nature of the correction.
|
|
|
|
After successfully correcting a filesystem,
|
2000-11-07 09:43:24 +03:00
|
|
|
.Nm
|
1999-03-18 05:02:18 +03:00
|
|
|
will print the number of files on that filesystem,
|
|
|
|
the number of used and free blocks,
|
|
|
|
and the percentage of fragmentation.
|
|
|
|
.Pp
|
|
|
|
If sent a
|
|
|
|
.Dv QUIT
|
|
|
|
signal,
|
2000-11-07 09:43:24 +03:00
|
|
|
.Nm
|
1999-03-18 05:02:18 +03:00
|
|
|
will finish the filesystem checks, then exit with an abnormal return status.
|
|
|
|
.Pp
|
|
|
|
Without the
|
|
|
|
.Fl p
|
|
|
|
option,
|
2000-11-07 09:43:24 +03:00
|
|
|
.Nm
|
2001-04-03 15:07:50 +04:00
|
|
|
audits and interactively repairs inconsistent conditions for filesystems.
|
2005-04-15 01:26:11 +04:00
|
|
|
If the filesystem is inconsistent, the operator is prompted for concurrence
|
1999-03-18 05:02:18 +03:00
|
|
|
before each correction is attempted.
|
|
|
|
It should be noted that some of the corrective actions will result in
|
|
|
|
some loss of data.
|
|
|
|
The amount and severity of data lost may be determined from the diagnostic
|
|
|
|
output.
|
|
|
|
The default action for each consistency correction
|
|
|
|
is to wait for the operator to respond
|
|
|
|
.Li yes
|
|
|
|
or
|
|
|
|
.Li no .
|
|
|
|
If the operator does not have write permission on the filesystem
|
2000-11-07 09:43:24 +03:00
|
|
|
.Nm
|
2001-04-03 15:07:50 +04:00
|
|
|
will default to a
|
1999-03-18 05:02:18 +03:00
|
|
|
.Fl n
|
|
|
|
action.
|
|
|
|
.Pp
|
|
|
|
The following flags are interpreted by
|
2005-04-15 01:26:11 +04:00
|
|
|
.Nm :
|
2005-04-15 01:29:29 +04:00
|
|
|
.Bl -tag -width XbXblockXX
|
2004-07-06 20:51:18 +04:00
|
|
|
.It Fl b Ar block
|
|
|
|
Use
|
|
|
|
.Ar block
|
|
|
|
as the super block for the filesystem.
|
1999-03-18 05:02:18 +03:00
|
|
|
.It Fl d
|
|
|
|
Print debugging output.
|
2005-04-15 01:15:59 +04:00
|
|
|
.It Fl f
|
2005-04-15 01:26:11 +04:00
|
|
|
Force checking of file systems.
|
|
|
|
Normally, if a file system is cleanly unmounted, the kernel will
|
|
|
|
set a
|
2005-04-15 01:15:59 +04:00
|
|
|
.Dq clean flag
|
|
|
|
in the file system superblock, and
|
|
|
|
.Nm
|
2005-04-15 01:26:11 +04:00
|
|
|
will not check the file system.
|
|
|
|
This option forces
|
2005-04-15 01:15:59 +04:00
|
|
|
.Nm
|
|
|
|
to check the file system, regardless of the state of the clean flag.
|
2004-07-06 20:51:18 +04:00
|
|
|
.It Fl m Ar mode
|
|
|
|
Use
|
|
|
|
.Ar mode
|
|
|
|
specified in octal as the permission bits to use when creating the
|
2004-07-06 20:49:10 +04:00
|
|
|
.Pa lost+found
|
|
|
|
directory rather than the default 1700.
|
|
|
|
In particular, systems that do not wish to have lost files accessible
|
|
|
|
by all users on the system should use a more restrictive
|
|
|
|
set of permissions such as 700.
|
1999-03-18 05:02:18 +03:00
|
|
|
.It Fl n
|
2001-04-03 15:07:50 +04:00
|
|
|
Assume a no response to all questions asked by
|
2000-11-07 09:43:24 +03:00
|
|
|
.Nm
|
1999-03-18 05:02:18 +03:00
|
|
|
except for
|
|
|
|
.Ql CONTINUE? ,
|
|
|
|
which is assumed to be affirmative;
|
|
|
|
do not open the filesystem for writing.
|
|
|
|
.It Fl p
|
2005-04-15 01:26:11 +04:00
|
|
|
Specify
|
|
|
|
.Dq preen
|
|
|
|
mode.
|
2002-10-01 17:40:23 +04:00
|
|
|
Currently, in this mode
|
2000-11-07 09:43:24 +03:00
|
|
|
.Nm
|
2003-03-28 11:09:52 +03:00
|
|
|
rolls forward from the older checkpoint, and performs no other action.
|
2005-04-15 01:15:59 +04:00
|
|
|
.It Fl q
|
|
|
|
Quiet mode, do not output any messages for clean filesystems.
|
1999-03-18 05:02:18 +03:00
|
|
|
.It Fl y
|
2001-04-03 15:07:50 +04:00
|
|
|
Assume a yes response to all questions asked by
|
2003-02-25 13:34:36 +03:00
|
|
|
.Nm ;
|
1999-03-18 05:02:18 +03:00
|
|
|
this should be used with great caution as this is a free license
|
|
|
|
to continue after essentially unlimited trouble has been encountered.
|
|
|
|
.El
|
|
|
|
.Pp
|
2002-02-07 06:15:06 +03:00
|
|
|
.Bl -enum -offset indent -compact
|
1999-03-18 05:02:18 +03:00
|
|
|
Inconsistencies checked are as follows:
|
|
|
|
.It
|
2000-05-16 08:55:58 +04:00
|
|
|
Blocks claimed by more than one inode.
|
1999-03-18 05:02:18 +03:00
|
|
|
.It
|
|
|
|
Blocks claimed by an inode outside the range of the filesystem.
|
|
|
|
.It
|
|
|
|
Incorrect link counts.
|
|
|
|
.It
|
|
|
|
Size checks:
|
2002-02-07 06:15:06 +03:00
|
|
|
.Bl -item -offset indent -compact
|
2001-04-03 15:07:50 +04:00
|
|
|
.It
|
1999-03-18 05:02:18 +03:00
|
|
|
Directory size not a multiple of DIRBLKSIZ.
|
|
|
|
.It
|
|
|
|
Partially truncated file.
|
|
|
|
.El
|
|
|
|
.It
|
|
|
|
Bad inode format.
|
|
|
|
.It
|
|
|
|
Directory checks:
|
2002-02-07 06:15:06 +03:00
|
|
|
.Bl -item -offset indent -compact
|
2001-04-03 15:07:50 +04:00
|
|
|
.It
|
1999-03-18 05:02:18 +03:00
|
|
|
File pointing to unallocated inode.
|
|
|
|
.It
|
|
|
|
Inode number out of range.
|
|
|
|
.It
|
|
|
|
Dot or dot-dot not the first two entries of a directory
|
|
|
|
or having the wrong inode number.
|
|
|
|
.El
|
|
|
|
.It
|
|
|
|
Super Block checks:
|
2002-02-07 06:15:06 +03:00
|
|
|
.Bl -item -offset indent -compact
|
2001-04-03 15:07:50 +04:00
|
|
|
.It
|
1999-03-18 05:02:18 +03:00
|
|
|
More blocks for inodes than there are in the filesystem.
|
2003-03-28 11:09:52 +03:00
|
|
|
.El
|
|
|
|
.It
|
|
|
|
Index File checks:
|
|
|
|
.Bl -item -offset indent -compact
|
|
|
|
.It
|
2005-04-15 01:29:29 +04:00
|
|
|
.Dq \&In use
|
2005-04-15 01:26:11 +04:00
|
|
|
inodes on free list, or free inodes not on free list.
|
1999-03-18 05:02:18 +03:00
|
|
|
.It
|
2005-04-15 01:26:11 +04:00
|
|
|
Segment block counts incorrect, or
|
|
|
|
.Dq clean
|
|
|
|
segments containing live data.
|
1999-03-18 05:02:18 +03:00
|
|
|
.El
|
|
|
|
.El
|
|
|
|
.Pp
|
|
|
|
Orphaned files and directories (allocated but unreferenced) are,
|
|
|
|
with the operator's concurrence, reconnected by
|
2001-04-03 15:07:50 +04:00
|
|
|
placing them in the
|
1999-03-18 05:02:18 +03:00
|
|
|
.Pa lost+found
|
|
|
|
directory.
|
|
|
|
The name assigned is the inode number.
|
|
|
|
If the
|
|
|
|
.Pa lost+found
|
|
|
|
directory does not exist, it is created.
|
|
|
|
If there is insufficient space its size is increased.
|
|
|
|
.Pp
|
|
|
|
Because of inconsistencies between the block device and the buffer cache,
|
|
|
|
the raw device should always be used.
|
|
|
|
.Sh DIAGNOSTICS
|
2001-04-03 15:07:50 +04:00
|
|
|
The diagnostics produced by
|
2000-11-07 09:43:24 +03:00
|
|
|
.Nm
|
1999-03-18 05:02:18 +03:00
|
|
|
are fully enumerated and explained in Appendix A of
|
|
|
|
.Rs
|
|
|
|
.%T "Fsck \- The UNIX File System Check Program"
|
|
|
|
.Re
|
2001-11-16 14:26:53 +03:00
|
|
|
.Sh SEE ALSO
|
|
|
|
.Xr fstab 5 ,
|
|
|
|
.Xr fsck 8 ,
|
|
|
|
.Xr newfs_lfs 8 ,
|
|
|
|
.Xr reboot 8
|
1999-03-18 05:02:18 +03:00
|
|
|
.Sh HISTORY
|
|
|
|
The
|
|
|
|
.Nm
|
|
|
|
program was first made available in
|
|
|
|
.Nx 1.4 .
|
2001-11-16 14:26:53 +03:00
|
|
|
.Sh AUTHORS
|
1999-03-18 05:02:18 +03:00
|
|
|
Most of the
|
|
|
|
.Nm
|
|
|
|
program was taken from
|
|
|
|
.Xr fsck_ffs 8 ;
|
2002-10-01 18:23:38 +04:00
|
|
|
what was not was written by
|
2005-04-15 01:26:11 +04:00
|
|
|
.An Konrad Schroder Aq perseant@NetBSD.org .
|