mirror of
git://sourceware.org/git/glibc.git
synced 2025-01-18 12:16:13 +08:00
* sysdeps/mips/machine-gmon.h (MCOUNT): Define for N32 and N64 as well.
* sysdeps/mips/machine-gmon.h (MCOUNT): Define for N32 and N64 as well.
This commit is contained in:
parent
c27d68482c
commit
c3b519b7eb
@ -1,5 +1,8 @@
|
|||||||
2003-03-17 Alexandre Oliva <aoliva@redhat.com>
|
2003-03-17 Alexandre Oliva <aoliva@redhat.com>
|
||||||
|
|
||||||
|
* sysdeps/mips/machine-gmon.h (MCOUNT): Define for N32 and N64 as
|
||||||
|
well.
|
||||||
|
|
||||||
* sysdeps/unix/sysv/linux/mips/configure.in: New. Pre-process
|
* sysdeps/unix/sysv/linux/mips/configure.in: New. Pre-process
|
||||||
asm/unistd.h into asm-unistd.h.
|
asm/unistd.h into asm-unistd.h.
|
||||||
* sysdeps/unix/sysv/linux/mips/configure: Generated.
|
* sysdeps/unix/sysv/linux/mips/configure: Generated.
|
||||||
@ -9,8 +12,6 @@
|
|||||||
* sysdeps/unix/sysv/linux/mips/clone.S: Don't include
|
* sysdeps/unix/sysv/linux/mips/clone.S: Don't include
|
||||||
asm/unistd.h.
|
asm/unistd.h.
|
||||||
|
|
||||||
2003-03-17 Alexandre Oliva <aoliva@redhat.com>
|
|
||||||
|
|
||||||
* sysdeps/unix/sysv/linux/mips/sys/ptrace.h: New file.
|
* sysdeps/unix/sysv/linux/mips/sys/ptrace.h: New file.
|
||||||
* sysdeps/unix/sysv/linux/mips/ptrace.c: New file. Use long
|
* sysdeps/unix/sysv/linux/mips/ptrace.c: New file. Use long
|
||||||
long type for registers on n32.
|
long type for registers on n32.
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
/* Machine-specific calling sequence for `mcount' profiling function. MIPS
|
/* Machine-specific calling sequence for `mcount' profiling function. MIPS
|
||||||
Copyright (C) 1996, 1997, 2000, 2001, 2002 Free Software Foundation, Inc.
|
Copyright (C) 1996, 1997, 2000, 2001, 2002, 2003
|
||||||
|
Free Software Foundation, Inc.
|
||||||
This file is part of the GNU C Library.
|
This file is part of the GNU C Library.
|
||||||
|
|
||||||
The GNU C Library is free software; you can redistribute it and/or
|
The GNU C Library is free software; you can redistribute it and/or
|
||||||
@ -20,8 +21,11 @@
|
|||||||
#define _MCOUNT_DECL(frompc,selfpc) \
|
#define _MCOUNT_DECL(frompc,selfpc) \
|
||||||
static void __attribute_used__ __mcount (u_long frompc, u_long selfpc)
|
static void __attribute_used__ __mcount (u_long frompc, u_long selfpc)
|
||||||
|
|
||||||
/* Call __mcount with our the return PC for our caller,
|
/* Call __mcount with the return PC for our caller,
|
||||||
and the return PC our caller will return to. */
|
and the return PC our caller will return to. */
|
||||||
|
|
||||||
|
#if _MIPS_SIM == _MIPS_SIM_ABI32
|
||||||
|
|
||||||
#ifdef __PIC__
|
#ifdef __PIC__
|
||||||
# define CPLOAD ".cpload $25;"
|
# define CPLOAD ".cpload $25;"
|
||||||
# define CPRESTORE ".cprestore 44\n\t"
|
# define CPRESTORE ".cprestore 44\n\t"
|
||||||
@ -66,3 +70,70 @@ static void __attribute_used__ __mcount (u_long frompc, u_long selfpc)
|
|||||||
".set reorder;\n\t" \
|
".set reorder;\n\t" \
|
||||||
".set at\n\t" \
|
".set at\n\t" \
|
||||||
".end _mcount");
|
".end _mcount");
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
#ifdef __PIC__
|
||||||
|
# define CPSETUP ".cpsetup $25, 88, _mcount;"
|
||||||
|
# define CPRETURN ".cpreturn;"
|
||||||
|
#else
|
||||||
|
# define CPSETUP
|
||||||
|
# define CPRETURN
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined _ABIN32 && _MIPS_SIM == _ABIN32
|
||||||
|
# define PTR_ADDU_STRING "add" /* no u */
|
||||||
|
# define PTR_SUBU_STRING "sub" /* no u */
|
||||||
|
#elif defined _ABI64 && _MIPS_SIM == _ABI64
|
||||||
|
# define PTR_ADDU_STRING "daddu"
|
||||||
|
# define PTR_SUBU_STRING "dsubu"
|
||||||
|
#else
|
||||||
|
# error "Unknown ABI"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define MCOUNT asm(\
|
||||||
|
".globl _mcount;\n\t" \
|
||||||
|
".align 3;\n\t" \
|
||||||
|
".type _mcount,@function;\n\t" \
|
||||||
|
".ent _mcount\n\t" \
|
||||||
|
"_mcount:\n\t" \
|
||||||
|
".frame $sp,88,$31\n\t" \
|
||||||
|
".set noreorder;\n\t" \
|
||||||
|
".set noat;\n\t" \
|
||||||
|
PTR_SUBU_STRING " $29,$29,96;\n\t" \
|
||||||
|
CPSETUP \
|
||||||
|
"sd $4,24($29);\n\t" \
|
||||||
|
"sd $5,32($29);\n\t" \
|
||||||
|
"sd $6,40($29);\n\t" \
|
||||||
|
"sd $7,48($29);\n\t" \
|
||||||
|
"sd $8,56($29);\n\t" \
|
||||||
|
"sd $9,64($29);\n\t" \
|
||||||
|
"sd $10,72($29);\n\t" \
|
||||||
|
"sd $11,80($29);\n\t" \
|
||||||
|
"sd $2,16($29);\n\t" \
|
||||||
|
"sd $1,0($29);\n\t" \
|
||||||
|
"sd $31,8($29);\n\t" \
|
||||||
|
"move $5,$31;\n\t" \
|
||||||
|
"move $4,$1;\n\t" \
|
||||||
|
"jal __mcount;\n\t" \
|
||||||
|
"nop;\n\t" \
|
||||||
|
"ld $4,24($29);\n\t" \
|
||||||
|
"ld $5,32($29);\n\t" \
|
||||||
|
"ld $6,40($29);\n\t" \
|
||||||
|
"ld $7,48($29);\n\t" \
|
||||||
|
"ld $8,56($29);\n\t" \
|
||||||
|
"ld $9,64($29);\n\t" \
|
||||||
|
"ld $10,72($29);\n\t" \
|
||||||
|
"ld $11,80($29);\n\t" \
|
||||||
|
"ld $2,16($29);\n\t" \
|
||||||
|
"ld $31,8($29);\n\t" \
|
||||||
|
"ld $1,0($29);\n\t" \
|
||||||
|
CPRETURN \
|
||||||
|
PTR_ADDU_STRING " $29,$29,96;\n\t" \
|
||||||
|
"j $31;\n\t" \
|
||||||
|
"move $31,$1;\n\t" \
|
||||||
|
".set reorder;\n\t" \
|
||||||
|
".set at\n\t" \
|
||||||
|
".end _mcount");
|
||||||
|
|
||||||
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user