[BACK]Return to ktrace.1 CVS log [TXT][DIR] Up to [local] / src / usr.bin / ktrace

Annotation of src/usr.bin/ktrace/ktrace.1, Revision 1.1

1.1     ! deraadt     1: .\" Copyright (c) 1990, 1993
        !             2: .\"    The Regents of the University of California.  All rights reserved.
        !             3: .\"
        !             4: .\" Redistribution and use in source and binary forms, with or without
        !             5: .\" modification, are permitted provided that the following conditions
        !             6: .\" are met:
        !             7: .\" 1. Redistributions of source code must retain the above copyright
        !             8: .\"    notice, this list of conditions and the following disclaimer.
        !             9: .\" 2. Redistributions in binary form must reproduce the above copyright
        !            10: .\"    notice, this list of conditions and the following disclaimer in the
        !            11: .\"    documentation and/or other materials provided with the distribution.
        !            12: .\" 3. All advertising materials mentioning features or use of this software
        !            13: .\"    must display the following acknowledgement:
        !            14: .\"    This product includes software developed by the University of
        !            15: .\"    California, Berkeley and its contributors.
        !            16: .\" 4. Neither the name of the University nor the names of its contributors
        !            17: .\"    may be used to endorse or promote products derived from this software
        !            18: .\"    without specific prior written permission.
        !            19: .\"
        !            20: .\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
        !            21: .\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
        !            22: .\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
        !            23: .\" ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
        !            24: .\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
        !            25: .\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
        !            26: .\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
        !            27: .\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
        !            28: .\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
        !            29: .\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
        !            30: .\" SUCH DAMAGE.
        !            31: .\"
        !            32: .\"    from: @(#)ktrace.1      8.1 (Berkeley) 6/6/93
        !            33: .\"    $Id: ktrace.1,v 1.3 1995/07/19 15:14:00 christos Exp $
        !            34: .\"
        !            35: .Dd June 6, 1993
        !            36: .Dt KTRACE 1
        !            37: .Os BSD 4.4
        !            38: .Sh NAME
        !            39: .Nm ktrace
        !            40: .Nd enable kernel process tracing
        !            41: .Sh SYNOPSIS
        !            42: .Nm ktrace
        !            43: .Op Fl aCcdi
        !            44: .Op Fl f Ar trfile
        !            45: .Op Fl g Ar pgrp
        !            46: .Op Fl p Ar pid
        !            47: .Op Fl t Ar trstr
        !            48: .Nm ktrace
        !            49: .Op Fl adi
        !            50: .Op Fl f Ar trfile
        !            51: .Op Fl t Ar trstr
        !            52: command
        !            53: .Sh DESCRIPTION
        !            54: .Nm Ktrace
        !            55: enables kernel trace logging for the specified processes.
        !            56: Kernel trace data is logged to the file
        !            57: .Pa ktrace.out .
        !            58: The kernel operations that are traced include system calls, namei
        !            59: translations, signal processing, and
        !            60: .Tn I/O .
        !            61: .Pp
        !            62: Once tracing is enabled on a process, trace data will be logged until
        !            63: either the process exits or the trace point is cleared.
        !            64: A traced process can generate enormous amounts of log data quickly;
        !            65: It is strongly suggested that users memorize how to disable tracing before
        !            66: attempting to trace a process.
        !            67: The following command is sufficient to disable tracing on all user owned
        !            68: processes, and, if executed by root, all processes:
        !            69: .Pp
        !            70: .Dl \&$ trace -C
        !            71: .Pp
        !            72: The trace file is not human readable; use
        !            73: .Xr kdump 1
        !            74: to decode it.
        !            75: .Pp
        !            76: The options are as follows:
        !            77: .Bl -tag -width indent
        !            78: .It Fl a
        !            79: Append to the trace file instead of truncating it.
        !            80: .It Fl C
        !            81: Disable tracing on all user owned processes, and, if executed by root, all
        !            82: processes in the system.
        !            83: .It Fl c
        !            84: Clear the trace points associated with the specified file or processes.
        !            85: .It Fl d
        !            86: Descendants; perform the operation for all current children of the
        !            87: designated processes.
        !            88: .It Fl f Ar file
        !            89: Log trace records to
        !            90: .Ar file
        !            91: instead of
        !            92: .Pa ktrace.out .
        !            93: .It Fl g Ar pgid
        !            94: Enable (disable) tracing on all processes in the process group (only one
        !            95: .Fl g
        !            96: flag is permitted).
        !            97: .It Fl i
        !            98: Inherit; pass the trace flags to all future children of the designated
        !            99: processes.
        !           100: .It Fl p Ar pid
        !           101: Enable (disable) tracing on the indicated process id (only one
        !           102: .Fl p
        !           103: flag is permitted).
        !           104: .It Fl t Ar trstr
        !           105: The string argument represents the kernel trace points, one per letter.
        !           106: The following table equates the letters with the tracepoints:
        !           107: .Pp
        !           108: .Bl -tag -width flag -compact
        !           109: .It Cm c
        !           110: trace system calls
        !           111: .It Cm e
        !           112: trace emulation changes
        !           113: .It Cm n
        !           114: trace namei translations
        !           115: .It Cm i
        !           116: trace
        !           117: .Tn I/O
        !           118: .It Cm s
        !           119: trace signal processing
        !           120: .El
        !           121: .It Ar command
        !           122: Execute
        !           123: .Ar command
        !           124: with the specified trace flags.
        !           125: .El
        !           126: .Pp
        !           127: The
        !           128: .Fl p ,
        !           129: .Fl g ,
        !           130: and
        !           131: .Ar command
        !           132: options are mutually exclusive.
        !           133: .Sh EXAMPLES
        !           134: # trace all kernel operations of process id 34
        !           135: .Dl $ ktrace -p 34
        !           136: .Pp
        !           137: # trace all kernel operations of processes in process group 15 and
        !           138: # pass the trace flags to all current and future children
        !           139: .Dl $ ktrace -idg 15
        !           140: .Pp
        !           141: # disable all tracing of process 65
        !           142: .Dl $ ktrace -cp 65
        !           143: .Pp
        !           144: # disable tracing signals on process 70 and all current children
        !           145: .Dl $ ktrace -t s -cdp 70
        !           146: .Pp
        !           147: # enable tracing of
        !           148: .Tn I/O
        !           149: on process 67
        !           150: .Dl $ ktrace -ti -p 67
        !           151: .Pp
        !           152: # run the command "w", tracing only system calls
        !           153: .Dl $ ktrace -tc w
        !           154: .Pp
        !           155: # disable all tracing to the file "tracedata"
        !           156: .Dl $ ktrace -c -f tracedata
        !           157: .Pp
        !           158: # disable tracing of all processes owned by the user
        !           159: .Dl $ ktrace -C
        !           160: .Sh SEE ALSO
        !           161: .Xr kdump 1
        !           162: .Sh HISTORY
        !           163: The
        !           164: .Nm ktrace
        !           165: command appears in
        !           166: .Bx 4.4 .