xref: /freebsd/usr.bin/fstat/fstat.1 (revision e50022797f5236493e7f80c3ba8cbc088b7627a7)
19b50d902SRodney W. Grimes.\" Copyright (c) 1987, 1991, 1993
29b50d902SRodney W. Grimes.\"	The Regents of the University of California.  All rights reserved.
39b50d902SRodney W. Grimes.\"
49b50d902SRodney W. Grimes.\" Redistribution and use in source and binary forms, with or without
59b50d902SRodney W. Grimes.\" modification, are permitted provided that the following conditions
69b50d902SRodney W. Grimes.\" are met:
79b50d902SRodney W. Grimes.\" 1. Redistributions of source code must retain the above copyright
89b50d902SRodney W. Grimes.\"    notice, this list of conditions and the following disclaimer.
99b50d902SRodney W. Grimes.\" 2. Redistributions in binary form must reproduce the above copyright
109b50d902SRodney W. Grimes.\"    notice, this list of conditions and the following disclaimer in the
119b50d902SRodney W. Grimes.\"    documentation and/or other materials provided with the distribution.
129b50d902SRodney W. Grimes.\" 3. All advertising materials mentioning features or use of this software
139b50d902SRodney W. Grimes.\"    must display the following acknowledgement:
149b50d902SRodney W. Grimes.\"	This product includes software developed by the University of
159b50d902SRodney W. Grimes.\"	California, Berkeley and its contributors.
169b50d902SRodney W. Grimes.\" 4. Neither the name of the University nor the names of its contributors
179b50d902SRodney W. Grimes.\"    may be used to endorse or promote products derived from this software
189b50d902SRodney W. Grimes.\"    without specific prior written permission.
199b50d902SRodney W. Grimes.\"
209b50d902SRodney W. Grimes.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
219b50d902SRodney W. Grimes.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
229b50d902SRodney W. Grimes.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
239b50d902SRodney W. Grimes.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
249b50d902SRodney W. Grimes.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
259b50d902SRodney W. Grimes.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
269b50d902SRodney W. Grimes.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
279b50d902SRodney W. Grimes.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
289b50d902SRodney W. Grimes.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
299b50d902SRodney W. Grimes.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
309b50d902SRodney W. Grimes.\" SUCH DAMAGE.
319b50d902SRodney W. Grimes.\"
329b50d902SRodney W. Grimes.\"     @(#)fstat.1	8.3 (Berkeley) 2/25/94
33c3aac50fSPeter Wemm.\" $FreeBSD$
349b50d902SRodney W. Grimes.\"
35e5002279SEdward Tomasz Napierala.Dd July 9, 2009
369b50d902SRodney W. Grimes.Dt FSTAT 1
3762500372SRuslan Ermilov.Os
389b50d902SRodney W. Grimes.Sh NAME
399b50d902SRodney W. Grimes.Nm fstat
4090eca7b6SGarrett Wollman.Nd identify active files
419b50d902SRodney W. Grimes.Sh SYNOPSIS
428fe908efSRuslan Ermilov.Nm
43d0482be8SBrian Feldman.Op Fl fmnv
449b50d902SRodney W. Grimes.Op Fl M Ar core
459b50d902SRodney W. Grimes.Op Fl N Ar system
469b50d902SRodney W. Grimes.Op Fl p Ar pid
479b50d902SRodney W. Grimes.Op Fl u Ar user
4891966d21SPhilippe Charnier.Op Ar
499b50d902SRodney W. Grimes.Sh DESCRIPTION
50e8937ba0SPhilippe CharnierThe
51e8937ba0SPhilippe Charnier.Nm
52e8937ba0SPhilippe Charnierutility identifies open files.
539b50d902SRodney W. GrimesA file is considered open by a process if it was explicitly opened,
546b020622SPoul-Henning Kampis the working directory, root directory, jail root directory,
556b020622SPoul-Henning Kampactive executable text, or kernel trace file for that process.
569b50d902SRodney W. GrimesIf no options are specified,
578fe908efSRuslan Ermilov.Nm
589b50d902SRodney W. Grimesreports on all open files in the system.
599b50d902SRodney W. Grimes.Pp
602a00e8eaSPhilippe CharnierThe following options are available:
612a00e8eaSPhilippe Charnier.Bl -tag -width indent
629b50d902SRodney W. Grimes.It Fl f
639b50d902SRodney W. GrimesRestrict examination to files open in the same file systems as
649b50d902SRodney W. Grimesthe named file arguments, or to the file system containing the
659b50d902SRodney W. Grimescurrent directory if there are no additional filename arguments.
669b50d902SRodney W. GrimesFor example, to find all files open in the file system where the
679b50d902SRodney W. Grimesdirectory
689b50d902SRodney W. Grimes.Pa /usr/src
699b50d902SRodney W. Grimesresides, type
709b50d902SRodney W. Grimes.Dq Li fstat -f /usr/src .
719b50d902SRodney W. Grimes.It Fl M
729b50d902SRodney W. GrimesExtract values associated with the name list from the specified core
739b50d902SRodney W. Grimesinstead of the default
749b50d902SRodney W. Grimes.Pa /dev/kmem .
759b50d902SRodney W. Grimes.It Fl N
76376d460cSRuslan ErmilovExtract the name list from the specified system instead of the default,
77376d460cSRuslan Ermilovwhich is the kernel image the system has booted from.
78d0482be8SBrian Feldman.It Fl m
79d0482be8SBrian FeldmanInclude memory-mapped files in the listing; normally these are excluded
80d0482be8SBrian Feldmandue to the extra processing required.
819b50d902SRodney W. Grimes.It Fl n
826a3e8b0aSRuslan ErmilovNumerical format.
836a3e8b0aSRuslan ErmilovPrint the device number (maj,min) of the file system
849b50d902SRodney W. Grimesthe file resides in rather than the mount point name; for special
859b50d902SRodney W. Grimesfiles, print the
869b50d902SRodney W. Grimesdevice number that the special device refers to rather than the filename
879b50d902SRodney W. Grimesin
889b50d902SRodney W. Grimes.Pa /dev ;
899b50d902SRodney W. Grimesand print the mode of the file in octal instead of symbolic form.
909b50d902SRodney W. Grimes.It Fl p
919b50d902SRodney W. GrimesReport all files open by the specified process.
929b50d902SRodney W. Grimes.It Fl u
939b50d902SRodney W. GrimesReport all files open by the specified user.
949b50d902SRodney W. Grimes.It Fl v
956a3e8b0aSRuslan ErmilovVerbose mode.
966a3e8b0aSRuslan ErmilovPrint error messages upon failures to locate particular
976a3e8b0aSRuslan Ermilovsystem data structures rather than silently ignoring them.
986a3e8b0aSRuslan ErmilovMost of
999b50d902SRodney W. Grimesthese data structures are dynamically created or deleted and it is
1009b50d902SRodney W. Grimespossible for them to disappear while
1018fe908efSRuslan Ermilov.Nm
1026a3e8b0aSRuslan Ermilovis running.
1036a3e8b0aSRuslan ErmilovThis
1049b50d902SRodney W. Grimesis normal and unavoidable since the rest of the system is running while
1058fe908efSRuslan Ermilov.Nm
1069b50d902SRodney W. Grimesitself is running.
10791966d21SPhilippe Charnier.It Ar
1089b50d902SRodney W. GrimesRestrict reports to the specified files.
1099b50d902SRodney W. Grimes.El
1109b50d902SRodney W. Grimes.Pp
1119b50d902SRodney W. GrimesThe following fields are printed:
1129b50d902SRodney W. Grimes.Bl -tag -width MOUNT
1139b50d902SRodney W. Grimes.It Li USER
1149b50d902SRodney W. GrimesThe username of the owner of the process (effective uid).
1159b50d902SRodney W. Grimes.It Li CMD
1169b50d902SRodney W. GrimesThe command name of the process.
1179b50d902SRodney W. Grimes.It Li PID
1189b50d902SRodney W. GrimesThe process id.
1199b50d902SRodney W. Grimes.It Li FD
1209b50d902SRodney W. GrimesThe file number in the per-process open file table or one of the following
1219b50d902SRodney W. Grimesspecial names:
1229b50d902SRodney W. Grimes.Pp
1239b88faecSRuslan Ermilov.Bd -literal -offset indent -compact
1246b020622SPoul-Henning Kampjail	- jail root directory
125d0482be8SBrian Feldmanmmap	- memory-mapped file
1266b020622SPoul-Henning Kamproot	- root inode
1276b020622SPoul-Henning Kamptext	- executable text inode
1286b020622SPoul-Henning Kamptr	- kernel trace file
1296b020622SPoul-Henning Kampwd 	- current working directory
1309b50d902SRodney W. Grimes.Ed
1319b50d902SRodney W. Grimes.Pp
1329b50d902SRodney W. GrimesIf the file number is followed by an asterisk (``*''), the file is
1339b50d902SRodney W. Grimesnot an inode, but rather a socket,
1349b50d902SRodney W. Grimes.Tn FIFO ,
1359b50d902SRodney W. Grimesor there is an error.
1360227791bSRuslan ErmilovIn this case the remainder of the line does not
1379b50d902SRodney W. Grimescorrespond to the remaining headers -- the format of the line
1389b50d902SRodney W. Grimesis described later under
1396e679990SPawel Jakub Dawidek.Sx SOCKETS .
1409b50d902SRodney W. Grimes.It Li MOUNT
1419b50d902SRodney W. GrimesIf the
1429b50d902SRodney W. Grimes.Fl n
1430227791bSRuslan Ermilovflag was not specified, this header is present and is the
1449b50d902SRodney W. Grimespathname that the file system the file resides in is mounted on.
1459b50d902SRodney W. Grimes.It Li DEV
1469b50d902SRodney W. GrimesIf the
1479b50d902SRodney W. Grimes.Fl n
1489b50d902SRodney W. Grimesflag is specified, this header is present and is the
1499b50d902SRodney W. Grimesmajor/minor number of the device that this file resides in.
1509b50d902SRodney W. Grimes.It Li INUM
1519b50d902SRodney W. GrimesThe inode number of the file.
1529b50d902SRodney W. Grimes.It Li MODE
1536a3e8b0aSRuslan ErmilovThe mode of the file.
1546a3e8b0aSRuslan ErmilovIf the
1559b50d902SRodney W. Grimes.Fl n
1560227791bSRuslan Ermilovflag is not specified, the mode is printed
1579b50d902SRodney W. Grimesusing a symbolic format (see
1589b50d902SRodney W. Grimes.Xr strmode 3 ) ;
1599b50d902SRodney W. Grimesotherwise, the mode is printed
1609b50d902SRodney W. Grimesas an octal number.
1619b50d902SRodney W. Grimes.It Li SZ\&|DV
1629b50d902SRodney W. GrimesIf the file is not a character or block special, prints the size of
1636a3e8b0aSRuslan Ermilovthe file in bytes.
1646a3e8b0aSRuslan ErmilovOtherwise, if the
1659b50d902SRodney W. Grimes.Fl n
1669b50d902SRodney W. Grimesflag is not specified, prints
1679b50d902SRodney W. Grimesthe name of the special file as located in
1689b50d902SRodney W. Grimes.Pa /dev .
1699b50d902SRodney W. GrimesIf that cannot be
1709b50d902SRodney W. Grimeslocated, or the
1719b50d902SRodney W. Grimes.Fl n
1729b50d902SRodney W. Grimesflag is specified, prints the major/minor device
1739b50d902SRodney W. Grimesnumber that the special device refers to.
1749b50d902SRodney W. Grimes.It Li R/W
1759b50d902SRodney W. GrimesThis column describes the access mode that the file allows.
1769b50d902SRodney W. GrimesThe letter ``r'' indicates open for reading;
1779b50d902SRodney W. Grimesthe letter ``w'' indicates open for writing.
1789b50d902SRodney W. GrimesThis field is useful when trying to find the processes that are
1799b50d902SRodney W. Grimespreventing a file system from being down graded to read-only.
1809b50d902SRodney W. Grimes.It Li NAME
1819b50d902SRodney W. GrimesIf filename arguments are specified and the
1829b50d902SRodney W. Grimes.Fl f
1839b50d902SRodney W. Grimesflag is not, then
1849b50d902SRodney W. Grimesthis field is present and is the name associated with the given file.
1859b50d902SRodney W. GrimesNormally the name cannot be determined since there is no mapping
1869b50d902SRodney W. Grimesfrom an open file back to the directory entry that was used to open
1876a3e8b0aSRuslan Ermilovthat file.
1886a3e8b0aSRuslan ErmilovAlso, since different directory entries may reference
1899b50d902SRodney W. Grimesthe same file (via
190906c1e27SMike Pritchard.Xr ln 1 ) ,
1919b50d902SRodney W. Grimesthe name printed may not be the actual
1929b50d902SRodney W. Grimesname that the process originally used to open that file.
1939b50d902SRodney W. Grimes.El
1949b50d902SRodney W. Grimes.Sh SOCKETS
1959b50d902SRodney W. GrimesThe formating of open sockets depends on the protocol domain.
1969b50d902SRodney W. GrimesIn all cases the first field is the domain name, the second field
1979b50d902SRodney W. Grimesis the socket type (stream, dgram, etc), and the third is the socket
1989b50d902SRodney W. Grimesflags field (in hex).
1999b50d902SRodney W. GrimesThe remaining fields are protocol dependent.
2009b50d902SRodney W. GrimesFor tcp, it is the address of the tcpcb, and for udp, the inpcb (socket pcb).
2019b50d902SRodney W. GrimesFor unix domain sockets, its the address of the socket pcb and the address
2029b50d902SRodney W. Grimesof the connected pcb (if connected).
2039b50d902SRodney W. GrimesOtherwise the protocol number and address of the socket itself are printed.
2049b50d902SRodney W. GrimesThe attempt is to make enough information available to
2059b50d902SRodney W. Grimespermit further analysis without duplicating
2069b50d902SRodney W. Grimes.Xr netstat 1 .
2079b50d902SRodney W. Grimes.Pp
2089b50d902SRodney W. GrimesFor example, the addresses mentioned above are the addresses which the
2099b50d902SRodney W. Grimes.Dq Li netstat -A
2109b50d902SRodney W. Grimescommand would print for tcp, udp, and unixdomain.
2119b50d902SRodney W. GrimesNote that since pipes are implemented using sockets, a pipe appears as a
2129b50d902SRodney W. Grimesconnected unix domain stream socket.
2139b50d902SRodney W. GrimesA unidirectional unix domain socket indicates the direction of flow with
2149b50d902SRodney W. Grimesan arrow (``<-'' or ``->''), and a full duplex socket shows a double arrow
2159b50d902SRodney W. Grimes(``<->'').
2169b50d902SRodney W. Grimes.Sh SEE ALSO
2179b50d902SRodney W. Grimes.Xr netstat 1 ,
2189b50d902SRodney W. Grimes.Xr nfsstat 1 ,
219e5002279SEdward Tomasz Napierala.Xr procstat 1 ,
2209b50d902SRodney W. Grimes.Xr ps 1 ,
2215ff829fdSSheldon Hearn.Xr sockstat 1 ,
2229b50d902SRodney W. Grimes.Xr systat 1 ,
2235ff829fdSSheldon Hearn.Xr tcp 4 ,
2245ff829fdSSheldon Hearn.Xr unix 4 ,
2259b50d902SRodney W. Grimes.Xr iostat 8 ,
226270d3d75SMike Pritchard.Xr pstat 8 ,
227270d3d75SMike Pritchard.Xr vmstat 8
2289b50d902SRodney W. Grimes.Sh HISTORY
2299b50d902SRodney W. GrimesThe
2309b50d902SRodney W. Grimes.Nm
2319b50d902SRodney W. Grimescommand appeared in
2329b50d902SRodney W. Grimes.Bx 4.3 tahoe .
2336c7216dfSRuslan Ermilov.Sh BUGS
2346c7216dfSRuslan ErmilovSince
2356c7216dfSRuslan Ermilov.Nm
2366c7216dfSRuslan Ermilovtakes a snapshot of the system, it is only correct for a very short period
2376c7216dfSRuslan Ermilovof time.
238