first cut at making GPROF work on Leopard

based on Ocaml macport.
This commit is contained in:
Vitor Santos Costa 2008-09-18 17:34:46 +01:00
parent 821cc384a3
commit 5db95de67d
2 changed files with 32 additions and 4 deletions

View File

@ -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

View File

@ -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));
} }