.\" $FreeBSD$ .\" .Dd Nov 23, 1997 .Dt TRUSS 1 .Os FreeBSD .Sh NAME .Nm truss .Nd trace system calls .Sh SYNOPSIS .Nm .Op Fl S .Op Fl o Ar file .Fl p Ar pid .Nm .Op Fl S .Op Fl o Ar file command .Op args .Sh DESCRIPTION .Nm Truss traces the system calls called by the specified process or program. Output is to the specified output file, or standard error by default. It does this by stopping and restarting the process being monitored via .Xr procfs 5 . .Pp The options are as follows: .Bl -tag -width indent .It Fl S Do not display information about signals received by the process. (Normally, .Nm displays signal as well as system call events.) .It Fl o Ar file Print the output to the specified .Ar file instead of standard error. .It Fl p Ar pid Follow the process specified by .Ar pid instead of a new command. .It Ar command Op args Execute .Ar command and trace the system calls of it. (The .Fl p and .Ar command options are mutually exclusive.) .Sh EXAMPLES # Follow the system calls used in echoing "hello" .Dl $ truss /bin/echo hello # Do the same, but put the output into a file .Dl $ truss -o /tmp/truss.out /bin/echo hello # Follow an already-running process .Dl $ truss -p 1 .Sh SEE ALSO .Xr kdump 1 , .Xr ktrace 1 , .Xr procfs 5 .Sh HISTORY The .Nm command was written by .An Sean Eric Fagan for .Fx . It was modeled after similar commands available for System V Release 4 and SunOS.