summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEric Andersen <andersen@codepoet.org>2003-03-03 20:58:42 +0000
committerEric Andersen <andersen@codepoet.org>2003-03-03 20:58:42 +0000
commit67eff66438688fddebe41f77fd252a3b2b135271 (patch)
tree18dbee3e9afe50d27095140198e2aa34df1de061
parent2229d0fa131387b9b8ad16ac88347350a080aeb5 (diff)
Initial effort at adding profiling support.
-rw-r--r--extra/Configs/Config.in37
-rw-r--r--extra/gcc-uClibc/Makefile5
-rw-r--r--extra/gcc-uClibc/gcc-uClibc.c32
-rwxr-xr-xextra/scripts/get-needed-libgcc-objects.sh2
-rwxr-xr-xextra/scripts/initfini.awk9
-rw-r--r--include/sys/gmon.h201
-rw-r--r--include/sys/gmon_out.h80
-rw-r--r--libc/sysdeps/linux/alpha/bits/atomicity.h102
-rw-r--r--libc/sysdeps/linux/alpha/bits/machine-gmon.h26
-rw-r--r--libc/sysdeps/linux/alpha/bits/sigcontextinfo.h (renamed from libpthread/linuxthreads/sysdeps/alpha/sigcontextinfo.h)0
-rw-r--r--libc/sysdeps/linux/alpha/bits/stackinfo.h (renamed from libpthread/linuxthreads/sysdeps/alpha/stackinfo.h)0
-rw-r--r--libc/sysdeps/linux/arm/bits/armsigctx.h (renamed from libpthread/linuxthreads/sysdeps/arm/bits/armsigctx.h)0
-rw-r--r--libc/sysdeps/linux/arm/bits/atomicity.h87
-rw-r--r--libc/sysdeps/linux/arm/bits/machine-gmon.h67
-rw-r--r--libc/sysdeps/linux/arm/bits/profil-counter.h32
-rw-r--r--libc/sysdeps/linux/arm/bits/sigcontextinfo.h35
-rw-r--r--libc/sysdeps/linux/arm/bits/stackinfo.h (renamed from libpthread/linuxthreads/sysdeps/arm/stackinfo.h)0
-rw-r--r--libc/sysdeps/linux/common/.cvsignore1
-rw-r--r--libc/sysdeps/linux/common/Makefile6
-rw-r--r--libc/sysdeps/linux/common/bits/atomicity.h54
-rw-r--r--libc/sysdeps/linux/common/bits/machine-gmon.h54
-rw-r--r--libc/sysdeps/linux/common/bits/profil-counter.h27
-rw-r--r--libc/sysdeps/linux/common/bits/sigcontextinfo.h27
-rw-r--r--libc/sysdeps/linux/common/bits/stackinfo.h34
-rw-r--r--libc/sysdeps/linux/common/gmon-start.c58
-rw-r--r--libc/sysdeps/linux/common/gmon.c641
-rw-r--r--libc/sysdeps/linux/common/initfini.c5
-rw-r--r--libc/sysdeps/linux/cris/bits/machine-gmon.h28
-rw-r--r--libc/sysdeps/linux/cris/bits/profil-counter.h26
-rw-r--r--libc/sysdeps/linux/cris/bits/stackinfo.h (renamed from libpthread/linuxthreads/sysdeps/cris/stackinfo.h)0
-rw-r--r--libc/sysdeps/linux/i386/Makefile13
-rw-r--r--libc/sysdeps/linux/i386/bits/atomicity.h57
-rw-r--r--libc/sysdeps/linux/i386/bits/machine-gmon.h41
-rw-r--r--libc/sysdeps/linux/i386/bits/profil-counter.h27
-rw-r--r--libc/sysdeps/linux/i386/bits/sigcontextinfo.h (renamed from libpthread/linuxthreads/sysdeps/i386/sigcontextinfo.h)0
-rw-r--r--libc/sysdeps/linux/i386/bits/stackinfo.h (renamed from libpthread/linuxthreads/sysdeps/i386/stackinfo.h)0
-rw-r--r--libc/sysdeps/linux/i386/crt0.S7
-rw-r--r--libc/sysdeps/linux/i386/mcount.S54
-rw-r--r--libc/sysdeps/linux/m68k/bits/atomicity.h64
-rw-r--r--libc/sysdeps/linux/m68k/bits/sigcontextinfo.h (renamed from libpthread/linuxthreads/sysdeps/m68k/sigcontextinfo.h)0
-rw-r--r--libc/sysdeps/linux/m68k/bits/stackinfo.h (renamed from libpthread/linuxthreads/sysdeps/m68k/stackinfo.h)0
-rw-r--r--libc/sysdeps/linux/mips/bits/atomicity.h98
-rw-r--r--libc/sysdeps/linux/mips/bits/machine-gmon.h68
-rw-r--r--libc/sysdeps/linux/mips/bits/sigcontextinfo.h (renamed from libpthread/linuxthreads/sysdeps/mips/sigcontextinfo.h)0
-rw-r--r--libc/sysdeps/linux/mips/bits/stackinfo.h (renamed from libpthread/linuxthreads/sysdeps/mips/stackinfo.h)0
-rw-r--r--libc/sysdeps/linux/powerpc/bits/atomicity.h104
-rw-r--r--libc/sysdeps/linux/powerpc/bits/machine-gmon.h31
-rw-r--r--libc/sysdeps/linux/powerpc/bits/profil-counter.h28
-rw-r--r--libc/sysdeps/linux/powerpc/bits/sigcontextinfo.h (renamed from libpthread/linuxthreads/sysdeps/powerpc/sigcontextinfo.h)0
-rw-r--r--libc/sysdeps/linux/powerpc/bits/stackinfo.h (renamed from libpthread/linuxthreads/sysdeps/powerpc/stackinfo.h)0
-rw-r--r--libc/sysdeps/linux/sh/bits/machine-gmon.h32
-rw-r--r--libc/sysdeps/linux/sh/bits/profil-counter.h28
-rw-r--r--libc/sysdeps/linux/sh/bits/sigcontextinfo.h (renamed from libpthread/linuxthreads/sysdeps/sh/sigcontextinfo.h)0
-rw-r--r--libc/sysdeps/linux/sh/bits/stackinfo.h (renamed from libpthread/linuxthreads/sysdeps/sh/stackinfo.h)0
-rw-r--r--libc/sysdeps/linux/sparc/bits/atomicity.h98
-rw-r--r--libc/sysdeps/linux/sparc/bits/profil-counter.h26
-rw-r--r--libc/sysdeps/linux/sparc/bits/sigcontextinfo.h (renamed from libpthread/linuxthreads/sysdeps/sparc/sigcontextinfo.h)0
-rw-r--r--libc/sysdeps/linux/sparc/bits/stackinfo.h (renamed from libpthread/linuxthreads/sysdeps/sparc/stackinfo.h)0
-rw-r--r--libc/sysdeps/linux/v850/bits/sigcontextinfo.h (renamed from libpthread/linuxthreads/sysdeps/v850/sigcontextinfo.h)0
-rw-r--r--libc/sysdeps/linux/v850/bits/stackinfo.h23
-rw-r--r--libpthread/linuxthreads/signals.c2
-rw-r--r--libpthread/linuxthreads/sysdeps/arm/sigcontextinfo.h108
-rw-r--r--libpthread/linuxthreads/sysdeps/cris/sigcontextinfo.h27
-rw-r--r--libpthread/linuxthreads/sysdeps/i386/i686/pt-machine.h79
-rw-r--r--libpthread/linuxthreads/sysdeps/i386/pt-machine.h48
-rw-r--r--libpthread/linuxthreads/sysdeps/unix/sysv/linux/bits/local_lim.h55
-rw-r--r--libpthread/linuxthreads/sysdeps/unix/sysv/linux/bits/posix_opt.h110
-rw-r--r--libpthread/linuxthreads/sysdeps/unix/sysv/linux/bits/sigthread.h37
68 files changed, 2517 insertions, 424 deletions
diff --git a/extra/Configs/Config.in b/extra/Configs/Config.in
index c02c28c8f..112369f7e 100644
--- a/extra/Configs/Config.in
+++ b/extra/Configs/Config.in
@@ -97,6 +97,43 @@ config UCLIBC_CTOR_DTOR
or dtors and want your binaries to be as small as possible, then
answer N.
+config UCLIBC_PROFILING
+ bool "Support gprof profiling"
+ default y
+ help
+ If you wish to build uClibc with support for application profiling
+ using the gprof tool, then you should enable this feature. Then in
+ addition to building uClibc with profiling support, you will also
+ need to recompile all your shared libraries with the profiling
+ enabled version of uClibc. To add profiling support to your
+ applications, you must compile things using the gcc options
+ "-fprofile-arcs -pg". Then when you run your applications, a
+ gmon.out file will be generated which can then be analyzed by
+ 'gprof'.
+
+ These exist a number of less invasive alternatives that do not
+ require your to specially instrument your application, and recompile
+ and relink everything.
+
+ Many people have had good results using the combination of Valgrind
+ to generate profiling information and KCachegrind for analysis:
+ http://developer.kde.org/~sewardj/
+ http://kcachegrind.sourceforge.net/
+
+ The OProfile system-wide profiler is another alternative:
+ http://oprofile.sourceforge.net/
+
+ Prospect is another alternative based on OProfile:
+ http://prospect.sourceforge.net/
+
+ And the Linux Trace Toolkit (LTT) is also a fine tool:
+ http://www.opersys.com/LTT/
+
+ If none of these tools do what you need, you can of course enable
+ this option, rebuild everything, and use 'gprof'. There is both a
+ size and performance penelty to profiling your applications this way,
+ so most people should answer N.
+
config UCLIBC_HAS_THREADS
bool "POSIX Threading Support"
default y
diff --git a/extra/gcc-uClibc/Makefile b/extra/gcc-uClibc/Makefile
index 523b10113..e312d1792 100644
--- a/extra/gcc-uClibc/Makefile
+++ b/extra/gcc-uClibc/Makefile
@@ -36,6 +36,11 @@ else
endif
ifeq ($(strip $(UCLIBC_CTOR_DTOR)),y)
@echo "#define __UCLIBC_CTOR_DTOR__ 1" >> gcc-uClibc.h
+ifeq ($(strip $(UCLIBC_PROFILING)),y)
+ @echo "#define __UCLIBC_PROFILING__ 1" >> gcc-uClibc.h
+else
+ @echo "#undef __UCLIBC_PROFILING__" >> gcc-uClibc.h
+endif
else
@echo "#undef __UCLIBC_CTOR_DTOR__" >> gcc-uClibc.h
endif
diff --git a/extra/gcc-uClibc/gcc-uClibc.c b/extra/gcc-uClibc/gcc-uClibc.c
index 8cb8a8f3c..5b002b9d2 100644
--- a/extra/gcc-uClibc/gcc-uClibc.c
+++ b/extra/gcc-uClibc/gcc-uClibc.c
@@ -149,6 +149,10 @@ int main(int argc, char **argv)
int ctor_dtor = 1, cplusplus = 0, use_nostdinc_plus = 0;
char *GPLUSPLUS_BIN = NULL;
#endif
+#ifdef __UCLIBC_PROFILING__
+ int profile = 0;
+ char *gcrt1_path[2];
+#endif
application_name = basename(argv[0]);
if (application_name[0] == '-')
@@ -208,6 +212,10 @@ int main(int argc, char **argv)
xstrcat(&(crt0_path[0]), devprefix, "/lib/crt0.o", NULL);
xstrcat(&(crt0_path[1]), builddir, "/lib/crt0.o", NULL);
#endif
+#ifdef __UCLIBC_PROFILING__
+ xstrcat(&(gcrt1_path[0]), devprefix, "/lib/gcrt1.o", NULL);
+ xstrcat(&(gcrt1_path[1]), builddir, "/lib/gcrt1.o", NULL);
+#endif
xstrcat(&(our_lib_path[0]), "-L", devprefix, "/lib", NULL);
xstrcat(&(our_lib_path[1]), "-L", builddir, "/lib", NULL);
@@ -312,13 +320,25 @@ int main(int argc, char **argv)
}
}
break;
+#ifdef __UCLIBC_PROFILING__
+ case 'p':
+ if (strcmp("-pg",argv[i]) == 0) {
+ profile = 1;
+ }
+ break;
+#endif
case 'f':
/* Check if we are doing PIC */
if (strcmp("-fPIC",argv[i]) == 0) {
use_pic = 1;
} else if (strcmp("-fpic",argv[i]) == 0) {
use_pic = 1;
+ }
+#ifdef __UCLIBC_PROFILING__
+ else if (strcmp("-fprofile-arcs",argv[i]) == 0) {
+ profile = 1;
}
+#endif
break;
case '-':
@@ -420,6 +440,11 @@ int main(int argc, char **argv)
if (linking && source_count) {
+#ifdef __UCLIBC_PROFILING__
+ if (profile) {
+ gcc_argv[i++] = gcrt1_path[use_build_dir];
+ }
+#endif
#ifdef __UCLIBC_CTOR_DTOR__
if (ctor_dtor) {
gcc_argv[i++] = crti_path[use_build_dir];
@@ -431,7 +456,12 @@ int main(int argc, char **argv)
}
#endif
if (use_start) {
- gcc_argv[i++] = crt0_path[use_build_dir];
+#ifdef __UCLIBC_PROFILING__
+ if (!profile)
+#endif
+ {
+ gcc_argv[i++] = crt0_path[use_build_dir];
+ }
}
for ( l = 0 ; l < k ; l++ ) {
if (gcc_argument[l]) gcc_argv[i++] = gcc_argument[l];
diff --git a/extra/scripts/get-needed-libgcc-objects.sh b/extra/scripts/get-needed-libgcc-objects.sh
index 04e6737f9..6aac14b4c 100755
--- a/extra/scripts/get-needed-libgcc-objects.sh
+++ b/extra/scripts/get-needed-libgcc-objects.sh
@@ -20,7 +20,7 @@ echo " partial linking..."
rm -f libc.ldr
$LD $LDFLAGS -r -o libc.ldr $CRTOBJS --whole-archive ../libc.a
-if $NM --undefined-only libc.ldr 2>&1 | grep -v "^main$" | grep -v "^_GLOBAL_OFFSET_TABLE_$" | grep -v "_gp_disp" > sym.need ; then
+if $NM --undefined-only libc.ldr 2>&1 | grep -v "^main$" | grep -v "^_GLOBAL_OFFSET_TABLE_$" | grep -v "_gp_disp" | grep -v "^etext$" | grep -v "^__gmon_start__$" > sym.need ; then
EXIT_WITH_ERROR=0
rm -f obj.need
touch obj.need
diff --git a/extra/scripts/initfini.awk b/extra/scripts/initfini.awk
index 818cfa26f..ef183db6c 100755
--- a/extra/scripts/initfini.awk
+++ b/extra/scripts/initfini.awk
@@ -12,6 +12,7 @@ BEGIN \
system("/bin/rm -f crt[in].S");
omitcrti=0;
omitcrtn=0;
+ do_sh_specials = 0;
glb_idx = 0;
while(getline < "initfini.S")
{ if(/\.endp/) {endp=1}
@@ -30,11 +31,11 @@ BEGIN \
close("initfini.S");
}
# special rules for the SuperH targets (They do nothing on other targets)
-/SH_GLB_BEGINS/ && glb_idx==0 {omitcrti +=1}
+/SH_GLB_BEGINS/ && glb_idx==0 {omitcrti +=1;do_sh_specials++}
/_init_SH_GLB/ && glb_idx>=1 {print glb_label[0] glb >> "crti.S"}
/_fini_SH_GLB/ && glb_idx>=2 {print glb_label[1] glb >> "crti.S"}
/SH_GLB_ENDS/ && glb_idx==0 {omitcrti -=1}
-/SH_GLB/ || /_GLOBAL_OFFSET_TABLE_/{getline}
+/SH_GLB/ || /_GLOBAL_OFFSET_TABLE_/ && do_sh_specials>=1 {getline}
# special rules for H8/300 (sorry quick hack)
/.h8300h/ {end=0}
@@ -49,6 +50,10 @@ BEGIN \
/EPILOG_BEGINS/{omitcrtn=0;getline}
/EPILOG_ENDS/{omitcrtn=1;getline}
/TRAILER_BEGINS/{omitcrti=0;omitcrtn=0;getline}
+/GMON_STUFF_BEGINS/{omitcrtn=1;getline}
+/GMON_STUFF_PAUSES/{omitcrtn=0;getline}
+/GMON_STUFF_UNPAUSES/{omitcrtn=1;getline}
+/GMON_STUFF_ENDS/{omitcrtn=0;getline}
/END_INIT/ \
{ if(endp)
diff --git a/include/sys/gmon.h b/include/sys/gmon.h
new file mode 100644
index 000000000..c02f8316d
--- /dev/null
+++ b/include/sys/gmon.h
@@ -0,0 +1,201 @@
+/*-
+ * Copyright (c) 1982, 1986, 1992, 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.
+ * 4. Neither the name of the University nor the names of its contributors
+ * 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.
+ *
+ * @(#)gmon.h 8.2 (Berkeley) 1/4/94
+ */
+
+#ifndef _SYS_GMON_H
+#define _SYS_GMON_H 1
+
+#include <features.h>
+
+#include <sys/types.h>
+
+/*
+ * See gmon_out.h for gmon.out format.
+ */
+
+/* structure emitted by "gcc -a". This must match struct bb in
+ gcc/libgcc2.c. It is OK for gcc to declare a longer structure as
+ long as the members below are present. */
+struct __bb
+{
+ long zero_word;
+ const char *filename;
+ long *counts;
+ long ncounts;
+ struct __bb *next;
+ const unsigned long *addresses;
+};
+
+extern struct __bb *__bb_head;
+
+/*
+ * histogram counters are unsigned shorts (according to the kernel).
+ */
+#define HISTCOUNTER unsigned short
+
+/*
+ * fraction of text space to allocate for histogram counters here, 1/2
+ */
+#define HISTFRACTION 2
+
+/*
+ * Fraction of text space to allocate for from hash buckets.
+ * The value of HASHFRACTION is based on the minimum number of bytes
+ * of separation between two subroutine call points in the object code.
+ * Given MIN_SUBR_SEPARATION bytes of separation the value of
+ * HASHFRACTION is calculated as:
+ *
+ * HASHFRACTION = MIN_SUBR_SEPARATION / (2 * sizeof(short) - 1);
+ *
+ * For example, on the VAX, the shortest two call sequence is:
+ *
+ * calls $0,(r0)
+ * calls $0,(r0)
+ *
+ * which is separated by only three bytes, thus HASHFRACTION is
+ * calculated as:
+ *
+ * HASHFRACTION = 3 / (2 * 2 - 1) = 1
+ *
+ * Note that the division above rounds down, thus if MIN_SUBR_FRACTION
+ * is less than three, this algorithm will not work!
+ *
+ * In practice, however, call instructions are rarely at a minimal
+ * distance. Hence, we will define HASHFRACTION to be 2 across all
+ * architectures. This saves a reasonable amount of space for
+ * profiling data structures without (in practice) sacrificing
+ * any granularity.
+ */
+#define HASHFRACTION 2
+
+/*
+ * Percent of text space to allocate for tostructs.
+ * This is a heuristic; we will fail with a warning when profiling programs
+ * with a very large number of very small functions, but that's
+ * normally OK.
+ * 2 is probably still a good value for normal programs.
+ * Profiling a test case with 64000 small functions will work if
+ * you raise this value to 3 and link statically (which bloats the
+ * text size, thus raising the number of arcs expected by the heuristic).
+ */
+#define ARCDENSITY 3
+
+/*
+ * Always allocate at least this many tostructs. This
+ * hides the inadequacy of the ARCDENSITY heuristic, at least
+ * for small programs.
+ */
+#define MINARCS 50
+
+/*
+ * The type used to represent indices into gmonparam.tos[].
+ */
+#define ARCINDEX u_long
+
+/*
+ * Maximum number of arcs we want to allow.
+ * Used to be max representable value of ARCINDEX minus 2, but now
+ * that ARCINDEX is a long, that's too large; we don't really want
+ * to allow a 48 gigabyte table.
+ * The old value of 1<<16 wasn't high enough in practice for large C++
+ * programs; will 1<<20 be adequate for long? FIXME
+ */
+#define MAXARCS (1 << 20)
+
+struct tostruct {
+ u_long selfpc;
+ long count;
+ ARCINDEX link;
+};
+
+/*
+ * a raw arc, with pointers to the calling site and
+ * the called site and a count.
+ */
+struct rawarc {
+ u_long raw_frompc;
+ u_long raw_selfpc;
+ long raw_count;
+};
+
+/*
+ * general rounding functions.
+ */
+#define ROUNDDOWN(x,y) (((x)/(y))*(y))
+#define ROUNDUP(x,y) ((((x)+(y)-1)/(y))*(y))
+
+/*
+ * The profiling data structures are housed in this structure.
+ */
+struct gmonparam {
+ long int state;
+ u_short *kcount;
+ u_long kcountsize;
+ ARCINDEX *froms;
+ u_long fromssize;
+ struct tostruct *tos;
+ u_long tossize;
+ long tolimit;
+ u_long lowpc;
+ u_long highpc;
+ u_long textsize;
+ u_long hashfraction;
+ long log_hashfraction;
+};
+
+/*
+ * Possible states of profiling.
+ */
+#define GMON_PROF_ON 0
+#define GMON_PROF_BUSY 1
+#define GMON_PROF_ERROR 2
+#define GMON_PROF_OFF 3
+
+/*
+ * Sysctl definitions for extracting profiling information from the kernel.
+ */
+#define GPROF_STATE 0 /* int: profiling enabling variable */
+#define GPROF_COUNT 1 /* struct: profile tick count buffer */
+#define GPROF_FROMS 2 /* struct: from location hash bucket */
+#define GPROF_TOS 3 /* struct: destination/count structure */
+#define GPROF_GMONPARAM 4 /* struct: profiling parameters (see above) */
+
+__BEGIN_DECLS
+
+/* Set up data structures and start profiling. */
+extern void __monstartup (u_long __lowpc, u_long __highpc) __THROW;
+extern void monstartup (u_long __lowpc, u_long __highpc) __THROW;
+
+/* Clean up profiling and write out gmon.out. */
+extern void _mcleanup (void) __THROW;
+
+__END_DECLS
+
+#endif /* sys/gmon.h */
diff --git a/include/sys/gmon_out.h b/include/sys/gmon_out.h
new file mode 100644
index 000000000..6fa09e864
--- /dev/null
+++ b/include/sys/gmon_out.h
@@ -0,0 +1,80 @@
+/* Copyright (C) 1996, 1997 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+ Contributed by David Mosberger <davidm@cs.arizona.edu>.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, write to the Free
+ Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
+ 02111-1307 USA. */
+
+/* This file specifies the format of gmon.out files. It should have
+ as few external dependencies as possible as it is going to be included
+ in many different programs. That is, minimize the number of #include's.
+
+ A gmon.out file consists of a header (defined by gmon_hdr) followed by
+ a sequence of records. Each record starts with a one-byte tag
+ identifying the type of records, followed by records specific data. */
+
+#ifndef _SYS_GMON_OUT_H
+#define _SYS_GMON_OUT_H 1
+
+#include <features.h>
+
+#define GMON_MAGIC "gmon" /* magic cookie */
+#define GMON_VERSION 1 /* version number */
+
+/* For profiling shared object we need a new format. */
+#define GMON_SHOBJ_VERSION 0x1ffff
+
+__BEGIN_DECLS
+
+/*
+ * Raw header as it appears on file (without padding). This header
+ * always comes first in gmon.out and is then followed by a series
+ * records defined below.
+ */
+struct gmon_hdr
+ {
+ char cookie[4];
+ char version[4];
+ char spare[3 * 4];
+ };
+</