From 5f3d5c2bbb4757e9cc5b30bc66b1d7555739bc4a Mon Sep 17 00:00:00 2001 From: Roland McGrath Date: Wed, 17 Jan 1996 02:29:57 +0000 Subject: * csu/initfini.c (_init): Call __gmon_start__ if defined (weak ref). * csu/gmon-start.c (__gmon_start__): Renamed from gmon_start, made global. [! HAVE_INITFINI]: Only make it a constructor in this case. --- csu/gmon-start.c | 16 ++++++++++++---- csu/initfini.c | 11 +++++++++++ 2 files changed, 23 insertions(+), 4 deletions(-) (limited to 'csu') diff --git a/csu/gmon-start.c b/csu/gmon-start.c index c9d51b113b..2ebbbf1704 100644 --- a/csu/gmon-start.c +++ b/csu/gmon-start.c @@ -1,5 +1,5 @@ /* Code to enable profiling at program startup. -Copyright (C) 1995 Free Software Foundation, Inc. +Copyright (C) 1995, 1996 Free Software Foundation, Inc. This file is part of the GNU C Library. The GNU C Library is free software; you can redistribute it and/or @@ -30,12 +30,20 @@ extern void _start (), etext (); extern void monstartup (u_long, u_long); extern void _mcleanup (void); +#ifndef HAVE_INITFINI /* This function gets called at startup by the normal constructor mechanism. We link this file together with start.o to produce gcrt1.o, so this constructor will be first in the list. */ -static void gmon_start (void) __attribute__ ((constructor)); -static void -gmon_start (void) + +void __gmon_start__ (void) __attribute__ ((constructor)); +#else +/* In ELF and COFF, we cannot use the normal constructor mechanism to call + __gmon_start__ because gcrt1.o appears before crtbegin.o in the link. + Instead crti.o calls it specially (see initfini.c). */ +#endif + +void +__gmon_start__ (void) { /* Start keeping profiling records. */ monstartup ((u_long) &_start, (u_long) &etext); diff --git a/csu/initfini.c b/csu/initfini.c index b0d0e68cbd..a3c3b3b7bc 100644 --- a/csu/initfini.c +++ b/csu/initfini.c @@ -63,6 +63,17 @@ SECTION (".init") void _init (void) { + /* We cannot use the normal constructor mechanism in gcrt1.o because it + appears before crtbegin.o in the link, so the header elt of .ctors + would come after the elt for __gmon_start__. One approach is for + gcrt1.o to reference a symbol which would be defined by some library + module which has a constructor; but then user code's constructors + would come first, and not be profiled. */ + extern void __gmon_start__ (void) __attribute__ ((weak)); + weak_symbol (__gmon_start__) + if (&__gmon_start__) + __gmon_start__ (); + /* End the here document containing the .init prologue code. Then fetch the .section directive just written and append that to crtn.s-new, followed by the function epilogue. */ -- cgit 1.4.1