|
|
1.1 root 1: /*-
2: * Copyright (c) 1982, 1986 The Regents of the University of California.
3: * All rights reserved.
4: *
5: * Redistribution and use in source and binary forms, with or without
6: * modification, are permitted provided that the following conditions
7: * are met:
8: * 1. Redistributions of source code must retain the above copyright
9: * notice, this list of conditions and the following disclaimer.
10: * 2. Redistributions in binary form must reproduce the above copyright
11: * notice, this list of conditions and the following disclaimer in the
12: * documentation and/or other materials provided with the distribution.
13: * 3. All advertising materials mentioning features or use of this software
14: * must display the following acknowledgement:
15: * This product includes software developed by the University of
16: * California, Berkeley and its contributors.
17: * 4. Neither the name of the University nor the names of its contributors
18: * may be used to endorse or promote products derived from this software
19: * without specific prior written permission.
20: *
21: * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
22: * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23: * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24: * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
25: * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26: * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27: * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28: * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29: * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30: * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31: * SUCH DAMAGE.
32: *
33: * @(#)trace.h 7.6 (Berkeley) 5/5/91
34: */
35:
36: /*
37: * File system buffer tracing points; all trace <pack(dev, size), bn>
38: */
39: #define TR_BREADHIT 0 /* buffer read found in cache */
40: #define TR_BREADMISS 1 /* buffer read not in cache */
41: #define TR_BWRITE 2 /* buffer written */
42: #define TR_BREADHITRA 3 /* buffer read-ahead found in cache */
43: #define TR_BREADMISSRA 4 /* buffer read-ahead not in cache */
44: #define TR_XFODMISS 5 /* exe fod read */
45: #define TR_XFODHIT 6 /* exe fod read */
46: #define TR_BRELSE 7 /* brelse */
47: #define TR_BREALLOC 8 /* expand/contract a buffer */
48:
49: /*
50: * Memory allocator trace points; all trace the amount of memory involved
51: */
52: #define TR_MALL 10 /* memory allocated */
53:
54: /*
55: * Paging trace points: all are <vaddr, pid>
56: */
57: #define TR_INTRANS 20 /* page intransit block */
58: #define TR_EINTRANS 21 /* page intransit wait done */
59: #define TR_FRECLAIM 22 /* reclaim from free list */
60: #define TR_RECLAIM 23 /* reclaim from loop */
61: #define TR_XSFREC 24 /* reclaim from free list instead of drum */
62: #define TR_XIFREC 25 /* reclaim from free list instead of fsys */
63: #define TR_WAITMEM 26 /* wait for memory in pagein */
64: #define TR_EWAITMEM 27 /* end memory wait in pagein */
65: #define TR_ZFOD 28 /* zfod page fault */
66: #define TR_EXFOD 29 /* exec fod page fault */
67: #define TR_VRFOD 30 /* vread fod page fault */
68: #define TR_CACHEFOD 31 /* fod in file system cache */
69: #define TR_SWAPIN 32 /* drum page fault */
70: #define TR_PGINDONE 33 /* page in done */
71: #define TR_SWAPIO 34 /* swap i/o request arrives */
72:
73: /*
74: * System call trace points.
75: */
76: #define TR_VADVISE 40 /* vadvise occurred with <arg, pid> */
77:
78: /*
79: * Miscellaneous
80: */
81: #define TR_STAMP 45 /* user said vtrace(VTR_STAMP, value); */
82:
83: /*
84: * This defines the size of the trace flags array.
85: */
86: #define TR_NFLAGS 100 /* generous */
87:
88: #define TRCSIZ 4096
89:
90: /*
91: * Specifications of the vtrace() system call, which takes one argument.
92: */
93: #define VTRACE 64+51
94:
95: #define VTR_DISABLE 0 /* set a trace flag to 0 */
96: #define VTR_ENABLE 1 /* set a trace flag to 1 */
97: #define VTR_VALUE 2 /* return value of a trace flag */
98: #define VTR_UALARM 3 /* set alarm to go off (sig 16) */
99: /* in specified number of hz */
100: #define VTR_STAMP 4 /* user specified stamp */
101:
102: #ifdef KERNEL
103: #ifdef TRACE
104: char traceflags[TR_NFLAGS];
105: struct proc *traceproc;
106: int tracebuf[TRCSIZ];
107: unsigned tracex;
108: int tracewhich;
109: #define pack(v,b) (((v)->v_mount->mnt_stat.f_fsid.val[0])<<16)|(b)
110: #define trace(a,b,c) if (traceflags[a]) trace1(a,b,c)
111: #else
112: #define trace(a,b,c) ;
113: #endif
114: #endif
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.