first cut at making GPROF work on Leopard
based on Ocaml macport.
This commit is contained in:
parent
821cc384a3
commit
5db95de67d
33
C/gprof.c
33
C/gprof.c
@ -61,7 +61,11 @@ static char SccsId[] = "%W% %G%";
|
|||||||
#include <signal.h>
|
#include <signal.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
|
#ifdef __APPLE__
|
||||||
|
#include <sys/ucontext.h>
|
||||||
|
#else
|
||||||
#include <ucontext.h>
|
#include <ucontext.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
static Int ProfCalls, ProfGCs, ProfHGrows, ProfSGrows, ProfMallocs, ProfOn, ProfOns;
|
static Int ProfCalls, ProfGCs, ProfHGrows, ProfSGrows, ProfMallocs, ProfOn, ProfOns;
|
||||||
|
|
||||||
@ -908,11 +912,26 @@ showprofres(UInt type) {
|
|||||||
|
|
||||||
#define TestMode (GCMode | GrowHeapMode | GrowStackMode | ErrorHandlingMode | InErrorMode | AbortMode | MallocMode)
|
#define TestMode (GCMode | GrowHeapMode | GrowStackMode | ErrorHandlingMode | InErrorMode | AbortMode | MallocMode)
|
||||||
|
|
||||||
|
#ifdef __APPLE__
|
||||||
|
#include <sys/ucontext.h>
|
||||||
|
|
||||||
|
#if MAC_OS_X_VERSION_MIN_REQUIRED < MAC_OS_X_VERSION_10_5
|
||||||
|
#define CONTEXT_STATE (((ucontext_t *)context)->uc_mcontext->ss)
|
||||||
|
#define CONTEXT_PC (CONTEXT_STATE.eip)
|
||||||
|
#define CONTEXT_BP (CONTEXT_STATE.ebp)
|
||||||
|
#else
|
||||||
|
#define CONTEXT_STATE (((ucontext_t *)scv)->uc_mcontext->__ss)
|
||||||
|
#define CONTEXT_PC (CONTEXT_STATE.__eip)
|
||||||
|
#define CONTEXT_BP (CONTEXT_STATE.__ebp)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
static void
|
static void
|
||||||
prof_alrm(int signo, siginfo_t *si, void *scv)
|
prof_alrm(int signo, siginfo_t *si, void *scv)
|
||||||
{
|
{
|
||||||
|
|
||||||
#if __linux__
|
#ifdef __linux__
|
||||||
ucontext_t *sc = (ucontext_t *)scv;
|
ucontext_t *sc = (ucontext_t *)scv;
|
||||||
#if (defined(i386) || defined(__amd64__))
|
#if (defined(i386) || defined(__amd64__))
|
||||||
void * oldpc=(void *) sc->uc_mcontext.gregs[14]; /* 14= REG_EIP */
|
void * oldpc=(void *) sc->uc_mcontext.gregs[14]; /* 14= REG_EIP */
|
||||||
@ -920,9 +939,13 @@ prof_alrm(int signo, siginfo_t *si, void *scv)
|
|||||||
void * oldpc= NULL;
|
void * oldpc= NULL;
|
||||||
#endif
|
#endif
|
||||||
#else
|
#else
|
||||||
#if __POWERPC__ || _POWER
|
#ifdef __APPLE__
|
||||||
|
#ifdef __darwin__
|
||||||
ucontext_t *sc = (ucontext_t *)scv;
|
ucontext_t *sc = (ucontext_t *)scv;
|
||||||
void * oldpc=(void *) sc->uc_mcontext->ss.srr0; /* 14= POWER PC */
|
void * oldpc=(void *) sc->uc_mcontext->ss.srr0; /* 14= POWER PC */
|
||||||
|
#else
|
||||||
|
void * oldpc=(void *) CONTEXT_PC;
|
||||||
|
#endif
|
||||||
#else
|
#else
|
||||||
void *NULL;
|
void *NULL;
|
||||||
#endif
|
#endif
|
||||||
@ -968,7 +991,11 @@ prof_alrm(int signo, siginfo_t *si, void *scv)
|
|||||||
if (oldpc>(void *) &Yap_absmi && oldpc <= (void *) &Yap_absmiEND) {
|
if (oldpc>(void *) &Yap_absmi && oldpc <= (void *) &Yap_absmiEND) {
|
||||||
/* we are running emulator code */
|
/* we are running emulator code */
|
||||||
#if BP_FREE
|
#if BP_FREE
|
||||||
current_p =(yamop *) sc->uc_mcontext.gregs[6]; /* 6= REG_EBP */
|
#ifdef __APPLE__
|
||||||
|
current_p =(yamop *) CONTEXT_BP;
|
||||||
|
#else
|
||||||
|
current_p =(amop *) sc->uc_mcontext.gregs[6]; /* 6= REG_EBP */
|
||||||
|
#endif
|
||||||
#else
|
#else
|
||||||
current_p = P;
|
current_p = P;
|
||||||
#endif
|
#endif
|
||||||
|
3
H/Yap.h
3
H/Yap.h
@ -215,7 +215,7 @@ typedef long int YAP_LONG_LONG;
|
|||||||
typedef unsigned long int YAP_ULONG_LONG;
|
typedef unsigned long int YAP_ULONG_LONG;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if HAVE_SIGPROF && (defined(__linux__) || defined(__POWERPC__))
|
#if HAVE_SIGPROF && (defined(__linux__) || defined(__APPLE__))
|
||||||
#define LOW_PROF 1
|
#define LOW_PROF 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -1034,6 +1034,7 @@ inline EXTERN Int IntegerOfTerm (Term);
|
|||||||
inline EXTERN Int
|
inline EXTERN Int
|
||||||
IntegerOfTerm (Term t)
|
IntegerOfTerm (Term t)
|
||||||
{
|
{
|
||||||
|
|
||||||
return (Int) (IsIntTerm (t) ? IntOfTerm (t) : LongIntOfTerm (t));
|
return (Int) (IsIntTerm (t) ? IntOfTerm (t) : LongIntOfTerm (t));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user