1995-02-18 01:27:10 +00:00
|
|
|
/* Special .init and .fini section support.
|
1996-06-03 04:46:40 +00:00
|
|
|
Copyright (C) 1995, 1996 Free Software Foundation, Inc.
|
1995-02-18 01:27:10 +00:00
|
|
|
This file is part of the GNU C Library.
|
|
|
|
|
|
|
|
The GNU C Library is free software; you can redistribute it and/or
|
|
|
|
modify it under the terms of the GNU Library General Public License as
|
|
|
|
published by the Free Software Foundation; either version 2 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
|
|
|
|
Library General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Library General Public
|
|
|
|
License along with the GNU C Library; see the file COPYING.LIB. If
|
|
|
|
not, write to the Free Software Foundation, Inc., 675 Mass Ave,
|
|
|
|
Cambridge, MA 02139, USA. */
|
|
|
|
|
|
|
|
/* This file is compiled into assembly code which is then surrounded by the
|
|
|
|
lines `cat > crtcommon.tmp <<\EOF_common' and `EOF_common' and thus
|
|
|
|
becomes a shell script which creates three files of assembly code.
|
|
|
|
|
|
|
|
* The first file is crti.s-new; this puts a function prologue at the
|
|
|
|
beginning of the .init and .fini sections and defines global symbols for
|
|
|
|
those addresses, so they can be called as functions.
|
|
|
|
|
|
|
|
* The second file is crtn.s-new; this puts the corresponding function
|
|
|
|
epilogues in the .init and .fini sections.
|
|
|
|
|
|
|
|
* The third file is crtcommon.tmp, which is whatever miscellaneous cruft
|
|
|
|
the compiler generated at the end; it should be appended to both crti.s-new
|
|
|
|
and crtn.s-new. */
|
|
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
1995-08-07 18:24:47 +00:00
|
|
|
|
|
|
|
#ifdef HAVE_ELF
|
1995-02-18 01:27:10 +00:00
|
|
|
/* These declarations make the functions go in the right sections when
|
|
|
|
we define them below. GCC syntax does not allow the attribute
|
|
|
|
specifications to be in the function definitions themselves. */
|
1995-07-26 14:04:19 +00:00
|
|
|
void _init (void) __attribute__ ((section (".init")));
|
|
|
|
void _fini (void) __attribute__ ((section (".fini")));
|
1995-02-18 01:27:10 +00:00
|
|
|
|
1995-08-07 18:24:47 +00:00
|
|
|
#define SECTION(x) /* Put nothing extra before the defn. */
|
|
|
|
|
|
|
|
#else
|
|
|
|
/* Some non-ELF systems support .init and .fini sections,
|
|
|
|
but the __attribute__ syntax only works for ELF. */
|
|
|
|
#define SECTION(x) asm (".section " x);
|
|
|
|
#endif
|
|
|
|
|
1995-02-18 01:27:10 +00:00
|
|
|
/* End the here document containing the initial common code.
|
|
|
|
Then move the output file crtcommon.tmp to crti.s-new and crtn.s-new. */
|
|
|
|
asm ("\nEOF_common\n\
|
1995-10-11 05:53:53 +00:00
|
|
|
rm -f crti.s-new crtn.s-new\n\
|
|
|
|
mv crtcommon.tmp crti.s-new\n\
|
|
|
|
cp crti.s-new crtn.s-new");
|
1995-02-18 01:27:10 +00:00
|
|
|
|
|
|
|
/* Append the .init prologue to crti.s-new. */
|
|
|
|
asm ("cat >> crti.s-new <<\\EOF.crti.init");
|
1996-01-24 01:34:10 +00:00
|
|
|
|
1995-08-07 18:24:47 +00:00
|
|
|
SECTION (".init")
|
1995-07-26 14:04:19 +00:00
|
|
|
void
|
1995-02-18 01:27:10 +00:00
|
|
|
_init (void)
|
|
|
|
{
|
1996-01-17 02:29:57 +00:00
|
|
|
/* 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. */
|
1996-07-08 06:17:09 +00:00
|
|
|
extern void __gmon_start__ (void); weak_extern (__gmon_start__)
|
1996-02-19 23:25:15 +00:00
|
|
|
if (__gmon_start__)
|
|
|
|
__gmon_start__ ();
|
1996-01-17 02:29:57 +00:00
|
|
|
|
1995-02-18 01:27:10 +00:00
|
|
|
/* 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. */
|
|
|
|
asm ("\nEOF.crti.init
|
|
|
|
\n\
|
|
|
|
fgrep .init crti.s-new >>crtn.s-new\n\
|
|
|
|
cat >> crtn.s-new <<\\EOF.crtn.init");
|
|
|
|
}
|
|
|
|
|
|
|
|
/* End the here document containing the .init epilogue code.
|
|
|
|
Then append the .fini prologue to crti.s-new. */
|
|
|
|
asm ("\nEOF.crtn.init\
|
|
|
|
\n\
|
|
|
|
cat >> crti.s-new <<\\EOF.crti.fini");
|
|
|
|
|
1995-08-07 18:24:47 +00:00
|
|
|
SECTION (".fini")
|
1995-07-26 14:04:19 +00:00
|
|
|
void
|
1995-02-18 01:27:10 +00:00
|
|
|
_fini (void)
|
|
|
|
{
|
|
|
|
/* End the here document containing the .fini prologue code.
|
|
|
|
Then fetch the .section directive just written and append that
|
|
|
|
to crtn.s-new, followed by the function epilogue. */
|
|
|
|
asm ("\nEOF.crti.fini\
|
Wed May 29 00:57:37 1996 David Mosberger-Tang <davidm@azstarnet.com>
* time/Makefile (tests): Add test-tz.
* time/test-tz.c: New test.
* time/clocktest.c: Rewrite to test more meaningfully.
* sysdeps/unix/sysv/linux/syscalls.list: Add bdflush,
create_module, delete_module, get_kernel_syms, init_module,
klogctl.
* sysdeps/unix/sysv/linux/sys/param.h (MAXSYMLINKS): Define as 5
instead of SYMLOOP_MAX, which is nowhere to be found.
* sysdeps/unix/sysv/linux/sys/msq_buf.h,
sysdeps/unix/sysv/linux/sys/sem_buf.h,
sysdeps/unix/sysv/linux/sys/shm_buf.h [__USE_MISC]: Add more
control ops and datastructures.
* sysdeps/unix/sysv/linux/sys/io.h: New file declaring low-level
I/O related functions.
* sysdeps/unix/sysv/linux/sys/kdaemon.h: New file declaring kernel
daemon related functions/operations.
* sysdeps/unix/sysv/linux/sys/klog.h: New file declaring kernel
logging related functions/operations.
* sysdeps/unix/sysv/linux/sys/module.h: New file declaring kernel
module related functions/operations.
* sysdeps/unix/sysv/linux/speed.c: Only do "mention this twice" hack
for non-Alpha based Linux systems.
* sysdeps/unix/sysv/linux/alpha/speed.c: Remove.
* sysdeps/unix/sysv/linux/Makefile (headers): Add sys/module.h,
sys/io.h, sys/klog.h, and sys/kdaemon.h.
* sysdeps/unix/sysdep.h (END): Define empty END macro for
platforms that don't need some sort of end directive at the
end of functions.
* sysdeps/unix/make-syscalls.sh: Emit END($strong) at end of
syscall wrapper to allow correct generation of debugging
information.
* sysdeps/unix/alpha/sysdep.h (END): Redefine to use .end
directive for both ELF and ECOFF.
(ret): Delete macro. It was a dangerous macro and unnecessary
since the Alpha assemblers recognizes "ret" as a macro themselves.
* sysdeps/gnu/utmpbits.h (struct utmp): Move ut_tv behind
ut_session to guarantee long alignment. This is important for
Linux/Alpha since ut_tv.tv_sec is 32 bits and time_t is 64 bits.
This will all get cleaned up as programs start to use ut_tv
instead ut_time.
* sysdeps/alpha/divrem.h: Include <sysdep.h> instead of <*/regdef.h>.
* sysdeps/alpha/bsd-_setjmp.S (setjmp): Renamed entry point to
_setjmp.
* sysdeps/alpha/_mcount.S, sysdeps/alpha/bb_init_func.S,
sysdeps/alpha/bsd-_setjmp.S, sysdeps/alpha/bsd-setjmp.S,
sysdeps/alpha/copysign.S, sysdeps/alpha/divrem.h,
sysdeps/alpha/fabs.S, sysdeps/alpha/ffs.S, sysdeps/alpha/htonl.S,
sysdeps/alpha/htons.S, sysdeps/alpha/memchr.S,
sysdeps/alpha/setjmp.S, sysdeps/alpha/strlen.S,
sysdeps/unix/sysv/linux/alpha/ieee_get_fp_control.S,
sysdeps/unix/sysv/linux/alpha/ieee_set_fp_control.S,
sysdeps/unix/sysv/linux/alpha/llseek.S,
sysdeps/unix/sysv/linux/alpha/pipe.S,
sysdeps/unix/sysv/linux/alpha/sigsuspend.S,
sysdeps/unix/sysv/linux/alpha/sysdep.S: Use END macro instead of
.end directive.
* csu/initfini.c (_fini): Tell gcc that _fini is not a leaf
function by having it contain a dummy function call.
* configure.in (config_machine): Don't make ELF the default for
Linux/Alpha just yet (use --with-elf instead).
(.init/.fini check): Generate .text to ensure function start and
end are in same section.
* sysdeps/unix/bsd/osf/alpha/brk.S,
sysdeps/unix/sysv/linux/alpha/brk.S (__curbrk): Store the entire
break value, not just the low 32 bits to accomodate large
memories.
Tue May 28 10:46:04 1996 Richard Henderson <rth@tamu.edu>
* sysdeps/unix/sysv/linux/alpha/brk.S: Rather than attempt to
dynamically resolve _end for initializing __curbrk, support the
brk(0) query idiom.
* sysdeps/alpha/bb_init_func.S: Don't make `init' an external symbol.
* sysdeps/alpha/bsd-_setjmp.S: The function is _setjmp not setjmp.
Sun May 26 22:17:38 1996 Richard Henderson <rth@tamu.edu>
* stdlib/lcong48_r.c, stdlib/seed48_r.c, stdlib/strtod.c,
stdlib/strtol.c: Include <string.h> for mem* and str* fns used.
Thu May 23 02:15:56 1996 David Mosberger-Tang <davidm@azstarnet.com>
* sysdeps/unix/sysv/linux/Makefile (headers): Add sys/io.h,
sys/klog.h, and sys/kdaemon.h.
* sysdeps/unix/sysv/linux/sys/io.h: New file.
* sysdeps/unix/sysv/linux/sys/klog.h: Ditto.
* sysdeps/unix/sysv/linux/sys/kdaemon.h: Ditto.
* sysdeps/unix/alpha/sysdep.h (ret): Remove macro. It is
dangerous and unnecessary since both OSF/1 as and gas define "ret"
as a pseudo-instruction.
Sat Jun 1 17:18:21 1996 Roland McGrath <roland@delasyd.gnu.ai.mit.edu>
* time/tzset.c (__tzset): Clear tz_rules name pointers after freeing
them. Bug found by David Mosberger-Tang.
* sysdeps/posix/tempname.c (__stdio_gen_tempname): Use __ptr_t instead
of PTR.
* extra-lib.mk (extra-objs): Use patsubst intead of $(A:=B) syntax
to work around Make bug when A contains var ref.
Fri May 31 18:27:52 1996 Roland McGrath <roland@delasyd.gnu.ai.mit.edu>
* string/string.h [__USE_MISC]: Declare basename; OSF/1 puts it here.
* sysdeps/unix/sysv/linux/syscalls.list (getpgid, setpgid): Define __
strong names and [gs]etpgid as weak aliases.
* math/math_private.h (GET_LDOUBLE_EXP): Add missing backslash.
1996-06-02 18:50:07 +00:00
|
|
|
\n\
|
|
|
|
cat > /dev/null <<\\EOF.fini.skip");
|
|
|
|
|
1996-06-03 04:46:40 +00:00
|
|
|
{
|
|
|
|
/* Let GCC know that _fini is not a leaf function by having a dummy
|
|
|
|
function call here. We arrange for this call to be omitted from
|
|
|
|
either crt file. */
|
|
|
|
extern void i_am_not_a_leaf (void);
|
|
|
|
i_am_not_a_leaf ();
|
|
|
|
}
|
Wed May 29 00:57:37 1996 David Mosberger-Tang <davidm@azstarnet.com>
* time/Makefile (tests): Add test-tz.
* time/test-tz.c: New test.
* time/clocktest.c: Rewrite to test more meaningfully.
* sysdeps/unix/sysv/linux/syscalls.list: Add bdflush,
create_module, delete_module, get_kernel_syms, init_module,
klogctl.
* sysdeps/unix/sysv/linux/sys/param.h (MAXSYMLINKS): Define as 5
instead of SYMLOOP_MAX, which is nowhere to be found.
* sysdeps/unix/sysv/linux/sys/msq_buf.h,
sysdeps/unix/sysv/linux/sys/sem_buf.h,
sysdeps/unix/sysv/linux/sys/shm_buf.h [__USE_MISC]: Add more
control ops and datastructures.
* sysdeps/unix/sysv/linux/sys/io.h: New file declaring low-level
I/O related functions.
* sysdeps/unix/sysv/linux/sys/kdaemon.h: New file declaring kernel
daemon related functions/operations.
* sysdeps/unix/sysv/linux/sys/klog.h: New file declaring kernel
logging related functions/operations.
* sysdeps/unix/sysv/linux/sys/module.h: New file declaring kernel
module related functions/operations.
* sysdeps/unix/sysv/linux/speed.c: Only do "mention this twice" hack
for non-Alpha based Linux systems.
* sysdeps/unix/sysv/linux/alpha/speed.c: Remove.
* sysdeps/unix/sysv/linux/Makefile (headers): Add sys/module.h,
sys/io.h, sys/klog.h, and sys/kdaemon.h.
* sysdeps/unix/sysdep.h (END): Define empty END macro for
platforms that don't need some sort of end directive at the
end of functions.
* sysdeps/unix/make-syscalls.sh: Emit END($strong) at end of
syscall wrapper to allow correct generation of debugging
information.
* sysdeps/unix/alpha/sysdep.h (END): Redefine to use .end
directive for both ELF and ECOFF.
(ret): Delete macro. It was a dangerous macro and unnecessary
since the Alpha assemblers recognizes "ret" as a macro themselves.
* sysdeps/gnu/utmpbits.h (struct utmp): Move ut_tv behind
ut_session to guarantee long alignment. This is important for
Linux/Alpha since ut_tv.tv_sec is 32 bits and time_t is 64 bits.
This will all get cleaned up as programs start to use ut_tv
instead ut_time.
* sysdeps/alpha/divrem.h: Include <sysdep.h> instead of <*/regdef.h>.
* sysdeps/alpha/bsd-_setjmp.S (setjmp): Renamed entry point to
_setjmp.
* sysdeps/alpha/_mcount.S, sysdeps/alpha/bb_init_func.S,
sysdeps/alpha/bsd-_setjmp.S, sysdeps/alpha/bsd-setjmp.S,
sysdeps/alpha/copysign.S, sysdeps/alpha/divrem.h,
sysdeps/alpha/fabs.S, sysdeps/alpha/ffs.S, sysdeps/alpha/htonl.S,
sysdeps/alpha/htons.S, sysdeps/alpha/memchr.S,
sysdeps/alpha/setjmp.S, sysdeps/alpha/strlen.S,
sysdeps/unix/sysv/linux/alpha/ieee_get_fp_control.S,
sysdeps/unix/sysv/linux/alpha/ieee_set_fp_control.S,
sysdeps/unix/sysv/linux/alpha/llseek.S,
sysdeps/unix/sysv/linux/alpha/pipe.S,
sysdeps/unix/sysv/linux/alpha/sigsuspend.S,
sysdeps/unix/sysv/linux/alpha/sysdep.S: Use END macro instead of
.end directive.
* csu/initfini.c (_fini): Tell gcc that _fini is not a leaf
function by having it contain a dummy function call.
* configure.in (config_machine): Don't make ELF the default for
Linux/Alpha just yet (use --with-elf instead).
(.init/.fini check): Generate .text to ensure function start and
end are in same section.
* sysdeps/unix/bsd/osf/alpha/brk.S,
sysdeps/unix/sysv/linux/alpha/brk.S (__curbrk): Store the entire
break value, not just the low 32 bits to accomodate large
memories.
Tue May 28 10:46:04 1996 Richard Henderson <rth@tamu.edu>
* sysdeps/unix/sysv/linux/alpha/brk.S: Rather than attempt to
dynamically resolve _end for initializing __curbrk, support the
brk(0) query idiom.
* sysdeps/alpha/bb_init_func.S: Don't make `init' an external symbol.
* sysdeps/alpha/bsd-_setjmp.S: The function is _setjmp not setjmp.
Sun May 26 22:17:38 1996 Richard Henderson <rth@tamu.edu>
* stdlib/lcong48_r.c, stdlib/seed48_r.c, stdlib/strtod.c,
stdlib/strtol.c: Include <string.h> for mem* and str* fns used.
Thu May 23 02:15:56 1996 David Mosberger-Tang <davidm@azstarnet.com>
* sysdeps/unix/sysv/linux/Makefile (headers): Add sys/io.h,
sys/klog.h, and sys/kdaemon.h.
* sysdeps/unix/sysv/linux/sys/io.h: New file.
* sysdeps/unix/sysv/linux/sys/klog.h: Ditto.
* sysdeps/unix/sysv/linux/sys/kdaemon.h: Ditto.
* sysdeps/unix/alpha/sysdep.h (ret): Remove macro. It is
dangerous and unnecessary since both OSF/1 as and gas define "ret"
as a pseudo-instruction.
Sat Jun 1 17:18:21 1996 Roland McGrath <roland@delasyd.gnu.ai.mit.edu>
* time/tzset.c (__tzset): Clear tz_rules name pointers after freeing
them. Bug found by David Mosberger-Tang.
* sysdeps/posix/tempname.c (__stdio_gen_tempname): Use __ptr_t instead
of PTR.
* extra-lib.mk (extra-objs): Use patsubst intead of $(A:=B) syntax
to work around Make bug when A contains var ref.
Fri May 31 18:27:52 1996 Roland McGrath <roland@delasyd.gnu.ai.mit.edu>
* string/string.h [__USE_MISC]: Declare basename; OSF/1 puts it here.
* sysdeps/unix/sysv/linux/syscalls.list (getpgid, setpgid): Define __
strong names and [gs]etpgid as weak aliases.
* math/math_private.h (GET_LDOUBLE_EXP): Add missing backslash.
1996-06-02 18:50:07 +00:00
|
|
|
|
|
|
|
asm ("\nEOF.fini.skip\
|
1995-02-18 01:27:10 +00:00
|
|
|
\n\
|
|
|
|
fgrep .fini crti.s-new >>crtn.s-new\n\
|
|
|
|
cat >> crtn.s-new <<\\EOF.crtn.fini");
|
|
|
|
}
|
|
|
|
|
|
|
|
/* End the here document containing the .fini epilogue code.
|
|
|
|
Finally, put the remainder of the generated assembly into crtcommon.tmp. */
|
|
|
|
asm ("\nEOF.crtn.fini\
|
|
|
|
\n\
|
|
|
|
cat > crtcommon.tmp <<\\EOF_common");
|