Merge branch 'master' of git://yap.git.sourceforge.net/gitroot/yap/yap-6.3
This commit is contained in:
commit
8590ab8b8a
@ -1788,7 +1788,6 @@ YAP_ExecuteOnCut(PredEntry *pe, CPredicate exec_code, struct cut_c_str *top)
|
|||||||
PP = pe;
|
PP = pe;
|
||||||
ctx->control = FRG_CUTTED;
|
ctx->control = FRG_CUTTED;
|
||||||
ctx->engine = NULL; //(PL_local_data *)Yap_regp;
|
ctx->engine = NULL; //(PL_local_data *)Yap_regp;
|
||||||
ctx->context = NULL;
|
|
||||||
if (pe->PredFlags & CArgsPredFlag) {
|
if (pe->PredFlags & CArgsPredFlag) {
|
||||||
val = execute_cargs_back(pe, exec_code, ctx PASS_REGS);
|
val = execute_cargs_back(pe, exec_code, ctx PASS_REGS);
|
||||||
} else {
|
} else {
|
||||||
|
251
C/gprof.c
251
C/gprof.c
@ -168,12 +168,11 @@ RBfree(rb_red_blk_node *ptr)
|
|||||||
|
|
||||||
static rb_red_blk_node *
|
static rb_red_blk_node *
|
||||||
RBTreeCreate(void) {
|
RBTreeCreate(void) {
|
||||||
CACHE_REGS
|
|
||||||
rb_red_blk_node* temp;
|
rb_red_blk_node* temp;
|
||||||
|
|
||||||
/* see the comment in the rb_red_blk_tree structure in red_black_tree.h */
|
/* see the comment in the rb_red_blk_tree structure in red_black_tree.h */
|
||||||
/* for information on nil and root */
|
/* for information on nil and root */
|
||||||
temp=LOCAL_ProfilerNil= RBMalloc(sizeof(rb_red_blk_node));
|
temp=GLOBAL_ProfilerNil= RBMalloc(sizeof(rb_red_blk_node));
|
||||||
temp->parent=temp->left=temp->right=temp;
|
temp->parent=temp->left=temp->right=temp;
|
||||||
temp->pcs=0;
|
temp->pcs=0;
|
||||||
temp->red=0;
|
temp->red=0;
|
||||||
@ -181,7 +180,7 @@ RBTreeCreate(void) {
|
|||||||
temp->pe=NULL;
|
temp->pe=NULL;
|
||||||
temp->source=GPROF_NO_EVENT;;
|
temp->source=GPROF_NO_EVENT;;
|
||||||
temp = RBMalloc(sizeof(rb_red_blk_node));
|
temp = RBMalloc(sizeof(rb_red_blk_node));
|
||||||
temp->parent=temp->left=temp->right=LOCAL_ProfilerNil;
|
temp->parent=temp->left=temp->right=GLOBAL_ProfilerNil;
|
||||||
temp->key=temp->lim=NULL;
|
temp->key=temp->lim=NULL;
|
||||||
temp->pe=NULL;
|
temp->pe=NULL;
|
||||||
temp->source=GPROF_NO_EVENT;
|
temp->source=GPROF_NO_EVENT;
|
||||||
@ -211,9 +210,8 @@ RBTreeCreate(void) {
|
|||||||
|
|
||||||
static void
|
static void
|
||||||
LeftRotate(rb_red_blk_node* x) {
|
LeftRotate(rb_red_blk_node* x) {
|
||||||
CACHE_REGS
|
|
||||||
rb_red_blk_node* y;
|
rb_red_blk_node* y;
|
||||||
rb_red_blk_node* rb_nil=LOCAL_ProfilerNil;
|
rb_red_blk_node* rb_nil=GLOBAL_ProfilerNil;
|
||||||
|
|
||||||
/* I originally wrote this function to use the sentinel for */
|
/* I originally wrote this function to use the sentinel for */
|
||||||
/* nil to avoid checking for nil. However this introduces a */
|
/* nil to avoid checking for nil. However this introduces a */
|
||||||
@ -244,7 +242,7 @@ LeftRotate(rb_red_blk_node* x) {
|
|||||||
x->parent=y;
|
x->parent=y;
|
||||||
|
|
||||||
#ifdef DEBUG_ASSERT
|
#ifdef DEBUG_ASSERT
|
||||||
Assert(!LOCAL_ProfilerNil->red,"nil not red in LeftRotate");
|
Assert(!GLOBAL_ProfilerNil->red,"nil not red in LeftRotate");
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -268,9 +266,8 @@ LeftRotate(rb_red_blk_node* x) {
|
|||||||
|
|
||||||
static void
|
static void
|
||||||
RightRotate(rb_red_blk_node* y) {
|
RightRotate(rb_red_blk_node* y) {
|
||||||
CACHE_REGS
|
|
||||||
rb_red_blk_node* x;
|
rb_red_blk_node* x;
|
||||||
rb_red_blk_node* rb_nil=LOCAL_ProfilerNil;
|
rb_red_blk_node* rb_nil=GLOBAL_ProfilerNil;
|
||||||
|
|
||||||
/* I originally wrote this function to use the sentinel for */
|
/* I originally wrote this function to use the sentinel for */
|
||||||
/* nil to avoid checking for nil. However this introduces a */
|
/* nil to avoid checking for nil. However this introduces a */
|
||||||
@ -300,7 +297,7 @@ RightRotate(rb_red_blk_node* y) {
|
|||||||
y->parent=x;
|
y->parent=x;
|
||||||
|
|
||||||
#ifdef DEBUG_ASSERT
|
#ifdef DEBUG_ASSERT
|
||||||
Assert(!LOCAL_ProfilerNil->red,"nil not red in RightRotate");
|
Assert(!GLOBAL_ProfilerNil->red,"nil not red in RightRotate");
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -321,15 +318,14 @@ RightRotate(rb_red_blk_node* y) {
|
|||||||
|
|
||||||
static void
|
static void
|
||||||
TreeInsertHelp(rb_red_blk_node* z) {
|
TreeInsertHelp(rb_red_blk_node* z) {
|
||||||
CACHE_REGS
|
|
||||||
/* This function should only be called by InsertRBTree (see above) */
|
/* This function should only be called by InsertRBTree (see above) */
|
||||||
rb_red_blk_node* x;
|
rb_red_blk_node* x;
|
||||||
rb_red_blk_node* y;
|
rb_red_blk_node* y;
|
||||||
rb_red_blk_node* rb_nil=LOCAL_ProfilerNil;
|
rb_red_blk_node* rb_nil=GLOBAL_ProfilerNil;
|
||||||
|
|
||||||
z->left=z->right=rb_nil;
|
z->left=z->right=rb_nil;
|
||||||
y=LOCAL_ProfilerRoot;
|
y=GLOBAL_ProfilerRoot;
|
||||||
x=LOCAL_ProfilerRoot->left;
|
x=GLOBAL_ProfilerRoot->left;
|
||||||
while( x != rb_nil) {
|
while( x != rb_nil) {
|
||||||
y=x;
|
y=x;
|
||||||
if (x->key > z->key) { /* x.key > z.key */
|
if (x->key > z->key) { /* x.key > z.key */
|
||||||
@ -339,7 +335,7 @@ TreeInsertHelp(rb_red_blk_node* z) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
z->parent=y;
|
z->parent=y;
|
||||||
if ( (y == LOCAL_ProfilerRoot) ||
|
if ( (y == GLOBAL_ProfilerRoot) ||
|
||||||
(y->key > z->key)) { /* y.key > z.key */
|
(y->key > z->key)) { /* y.key > z.key */
|
||||||
y->left=z;
|
y->left=z;
|
||||||
} else {
|
} else {
|
||||||
@ -347,7 +343,7 @@ TreeInsertHelp(rb_red_blk_node* z) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef DEBUG_ASSERT
|
#ifdef DEBUG_ASSERT
|
||||||
Assert(!LOCAL_ProfilerNil->red,"nil not red in TreeInsertHelp");
|
Assert(!GLOBAL_ProfilerNil->red,"nil not red in TreeInsertHelp");
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -373,7 +369,6 @@ TreeInsertHelp(rb_red_blk_node* z) {
|
|||||||
|
|
||||||
static rb_red_blk_node *
|
static rb_red_blk_node *
|
||||||
RBTreeInsert(yamop *key, yamop *lim) {
|
RBTreeInsert(yamop *key, yamop *lim) {
|
||||||
CACHE_REGS
|
|
||||||
rb_red_blk_node * y;
|
rb_red_blk_node * y;
|
||||||
rb_red_blk_node * x;
|
rb_red_blk_node * x;
|
||||||
rb_red_blk_node * newNode;
|
rb_red_blk_node * newNode;
|
||||||
@ -420,12 +415,12 @@ RBTreeInsert(yamop *key, yamop *lim) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
LOCAL_ProfilerRoot->left->red=0;
|
GLOBAL_ProfilerRoot->left->red=0;
|
||||||
return newNode;
|
return newNode;
|
||||||
|
|
||||||
#ifdef DEBUG_ASSERT
|
#ifdef DEBUG_ASSERT
|
||||||
Assert(!LOCAL_ProfilerNil->red,"nil not red in RBTreeInsert");
|
Assert(!GLOBAL_ProfilerNil->red,"nil not red in RBTreeInsert");
|
||||||
Assert(!LOCAL_ProfilerRoot->red,"root not red in RBTreeInsert");
|
Assert(!GLOBAL_ProfilerRoot->red,"root not red in RBTreeInsert");
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -445,12 +440,11 @@ RBTreeInsert(yamop *key, yamop *lim) {
|
|||||||
|
|
||||||
static rb_red_blk_node*
|
static rb_red_blk_node*
|
||||||
RBExactQuery(yamop* q) {
|
RBExactQuery(yamop* q) {
|
||||||
CACHE_REGS
|
|
||||||
rb_red_blk_node* x;
|
rb_red_blk_node* x;
|
||||||
rb_red_blk_node* rb_nil=LOCAL_ProfilerNil;
|
rb_red_blk_node* rb_nil=GLOBAL_ProfilerNil;
|
||||||
|
|
||||||
if (!LOCAL_ProfilerRoot) return NULL;
|
if (!GLOBAL_ProfilerRoot) return NULL;
|
||||||
x=LOCAL_ProfilerRoot->left;
|
x=GLOBAL_ProfilerRoot->left;
|
||||||
if (x == rb_nil) return NULL;
|
if (x == rb_nil) return NULL;
|
||||||
while(x->key != q) {/*assignemnt*/
|
while(x->key != q) {/*assignemnt*/
|
||||||
if (x->key > q) { /* x->key > q */
|
if (x->key > q) { /* x->key > q */
|
||||||
@ -466,13 +460,12 @@ RBExactQuery(yamop* q) {
|
|||||||
|
|
||||||
static rb_red_blk_node*
|
static rb_red_blk_node*
|
||||||
RBLookup(yamop *entry) {
|
RBLookup(yamop *entry) {
|
||||||
CACHE_REGS
|
|
||||||
rb_red_blk_node *current;
|
rb_red_blk_node *current;
|
||||||
|
|
||||||
if (!LOCAL_ProfilerRoot)
|
if (!GLOBAL_ProfilerRoot)
|
||||||
return NULL;
|
return NULL;
|
||||||
current = LOCAL_ProfilerRoot->left;
|
current = GLOBAL_ProfilerRoot->left;
|
||||||
while (current != LOCAL_ProfilerNil) {
|
while (current != GLOBAL_ProfilerNil) {
|
||||||
if (current->key <= entry && current->lim >= entry) {
|
if (current->key <= entry && current->lim >= entry) {
|
||||||
return current;
|
return current;
|
||||||
}
|
}
|
||||||
@ -502,8 +495,7 @@ RBLookup(yamop *entry) {
|
|||||||
/***********************************************************************/
|
/***********************************************************************/
|
||||||
|
|
||||||
static void RBDeleteFixUp(rb_red_blk_node* x) {
|
static void RBDeleteFixUp(rb_red_blk_node* x) {
|
||||||
CACHE_REGS
|
rb_red_blk_node* root=GLOBAL_ProfilerRoot->left;
|
||||||
rb_red_blk_node* root=LOCAL_ProfilerRoot->left;
|
|
||||||
rb_red_blk_node *w;
|
rb_red_blk_node *w;
|
||||||
|
|
||||||
while( (!x->red) && (root != x)) {
|
while( (!x->red) && (root != x)) {
|
||||||
@ -582,10 +574,9 @@ static void RBDeleteFixUp(rb_red_blk_node* x) {
|
|||||||
|
|
||||||
static rb_red_blk_node*
|
static rb_red_blk_node*
|
||||||
TreeSuccessor(rb_red_blk_node* x) {
|
TreeSuccessor(rb_red_blk_node* x) {
|
||||||
CACHE_REGS
|
|
||||||
rb_red_blk_node* y;
|
rb_red_blk_node* y;
|
||||||
rb_red_blk_node* rb_nil=LOCAL_ProfilerNil;
|
rb_red_blk_node* rb_nil=GLOBAL_ProfilerNil;
|
||||||
rb_red_blk_node* root=LOCAL_ProfilerRoot;
|
rb_red_blk_node* root=GLOBAL_ProfilerRoot;
|
||||||
|
|
||||||
if (rb_nil != (y = x->right)) { /* assignment to y is intentional */
|
if (rb_nil != (y = x->right)) { /* assignment to y is intentional */
|
||||||
while(y->left != rb_nil) { /* returns the minium of the right subtree of x */
|
while(y->left != rb_nil) { /* returns the minium of the right subtree of x */
|
||||||
@ -621,11 +612,10 @@ TreeSuccessor(rb_red_blk_node* x) {
|
|||||||
|
|
||||||
static void
|
static void
|
||||||
RBDelete(rb_red_blk_node* z){
|
RBDelete(rb_red_blk_node* z){
|
||||||
CACHE_REGS
|
|
||||||
rb_red_blk_node* y;
|
rb_red_blk_node* y;
|
||||||
rb_red_blk_node* x;
|
rb_red_blk_node* x;
|
||||||
rb_red_blk_node* rb_nil=LOCAL_ProfilerNil;
|
rb_red_blk_node* rb_nil=GLOBAL_ProfilerNil;
|
||||||
rb_red_blk_node* root=LOCAL_ProfilerRoot;
|
rb_red_blk_node* root=GLOBAL_ProfilerRoot;
|
||||||
|
|
||||||
y= ((z->left == rb_nil) || (z->right == rb_nil)) ? z : TreeSuccessor(z);
|
y= ((z->left == rb_nil) || (z->right == rb_nil)) ? z : TreeSuccessor(z);
|
||||||
x= (y->left == rb_nil) ? y->right : y->left;
|
x= (y->left == rb_nil) ? y->right : y->left;
|
||||||
@ -674,40 +664,38 @@ RBDelete(rb_red_blk_node* z){
|
|||||||
|
|
||||||
char *set_profile_dir(char *);
|
char *set_profile_dir(char *);
|
||||||
char *set_profile_dir(char *name){
|
char *set_profile_dir(char *name){
|
||||||
CACHE_REGS
|
|
||||||
int size=0;
|
int size=0;
|
||||||
|
|
||||||
if (name!=NULL) {
|
if (name!=NULL) {
|
||||||
size=strlen(name)+1;
|
size=strlen(name)+1;
|
||||||
if (LOCAL_DIRNAME!=NULL) free(LOCAL_DIRNAME);
|
if (GLOBAL_DIRNAME!=NULL) free(GLOBAL_DIRNAME);
|
||||||
LOCAL_DIRNAME=malloc(size);
|
GLOBAL_DIRNAME=malloc(size);
|
||||||
if (LOCAL_DIRNAME==NULL) { printf("Profiler Out of Mem\n"); exit(1); }
|
if (GLOBAL_DIRNAME==NULL) { printf("Profiler Out of Mem\n"); exit(1); }
|
||||||
strcpy(LOCAL_DIRNAME,name);
|
strcpy(GLOBAL_DIRNAME,name);
|
||||||
}
|
}
|
||||||
if (LOCAL_DIRNAME==NULL) {
|
if (GLOBAL_DIRNAME==NULL) {
|
||||||
do {
|
do {
|
||||||
if (LOCAL_DIRNAME!=NULL) free(LOCAL_DIRNAME);
|
if (GLOBAL_DIRNAME!=NULL) free(GLOBAL_DIRNAME);
|
||||||
size+=20;
|
size+=20;
|
||||||
LOCAL_DIRNAME=malloc(size);
|
GLOBAL_DIRNAME=malloc(size);
|
||||||
if (LOCAL_DIRNAME==NULL) { printf("Profiler Out of Mem\n"); exit(1); }
|
if (GLOBAL_DIRNAME==NULL) { printf("Profiler Out of Mem\n"); exit(1); }
|
||||||
} while (getcwd(LOCAL_DIRNAME, size-15)==NULL);
|
} while (getcwd(GLOBAL_DIRNAME, size-15)==NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
return LOCAL_DIRNAME;
|
return GLOBAL_DIRNAME;
|
||||||
}
|
}
|
||||||
|
|
||||||
char *profile_names(int);
|
char *profile_names(int);
|
||||||
char *profile_names(int k) {
|
char *profile_names(int k) {
|
||||||
CACHE_REGS
|
|
||||||
static char *FNAME=NULL;
|
static char *FNAME=NULL;
|
||||||
int size=200;
|
int size=200;
|
||||||
|
|
||||||
if (LOCAL_DIRNAME==NULL) set_profile_dir(NULL);
|
if (GLOBAL_DIRNAME==NULL) set_profile_dir(NULL);
|
||||||
size=strlen(LOCAL_DIRNAME)+40;
|
size=strlen(GLOBAL_DIRNAME)+40;
|
||||||
if (FNAME!=NULL) free(FNAME);
|
if (FNAME!=NULL) free(FNAME);
|
||||||
FNAME=malloc(size);
|
FNAME=malloc(size);
|
||||||
if (FNAME==NULL) { printf("Profiler Out of Mem\n"); exit(1); }
|
if (FNAME==NULL) { printf("Profiler Out of Mem\n"); exit(1); }
|
||||||
strcpy(FNAME,LOCAL_DIRNAME);
|
strcpy(FNAME,GLOBAL_DIRNAME);
|
||||||
|
|
||||||
if (k==PROFILING_FILE) {
|
if (k==PROFILING_FILE) {
|
||||||
sprintf(FNAME,"%s/PROFILING_%d",FNAME,getpid());
|
sprintf(FNAME,"%s/PROFILING_%d",FNAME,getpid());
|
||||||
@ -721,8 +709,7 @@ char *profile_names(int k) {
|
|||||||
|
|
||||||
void del_profile_files(void);
|
void del_profile_files(void);
|
||||||
void del_profile_files() {
|
void del_profile_files() {
|
||||||
CACHE_REGS
|
if (GLOBAL_DIRNAME!=NULL) {
|
||||||
if (LOCAL_DIRNAME!=NULL) {
|
|
||||||
remove(profile_names(PROFPREDS_FILE));
|
remove(profile_names(PROFPREDS_FILE));
|
||||||
remove(profile_names(PROFILING_FILE));
|
remove(profile_names(PROFILING_FILE));
|
||||||
}
|
}
|
||||||
@ -730,18 +717,17 @@ void del_profile_files() {
|
|||||||
|
|
||||||
void
|
void
|
||||||
Yap_inform_profiler_of_clause__(void *code_start, void *code_end, PredEntry *pe,gprof_info index_code) {
|
Yap_inform_profiler_of_clause__(void *code_start, void *code_end, PredEntry *pe,gprof_info index_code) {
|
||||||
CACHE_REGS
|
|
||||||
buf_ptr b;
|
buf_ptr b;
|
||||||
buf_extra e;
|
buf_extra e;
|
||||||
LOCAL_ProfOn = TRUE;
|
GLOBAL_ProfOn = TRUE;
|
||||||
b.tag = '+';
|
b.tag = '+';
|
||||||
b.ptr= code_start;
|
b.ptr= code_start;
|
||||||
e.inf= index_code;
|
e.inf= index_code;
|
||||||
e.end= code_end;
|
e.end= code_end;
|
||||||
e.pe= pe;
|
e.pe= pe;
|
||||||
fwrite(&b,sizeof(b),1,LOCAL_FPreds);
|
fwrite(&b,sizeof(b),1,GLOBAL_FPreds);
|
||||||
fwrite(&e,sizeof(e),1,LOCAL_FPreds);
|
fwrite(&e,sizeof(e),1,GLOBAL_FPreds);
|
||||||
LOCAL_ProfOn = FALSE;
|
GLOBAL_ProfOn = FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
typedef struct clause_entry {
|
typedef struct clause_entry {
|
||||||
@ -756,8 +742,7 @@ static Int profend( USES_REGS1 );
|
|||||||
|
|
||||||
static void
|
static void
|
||||||
clean_tree(rb_red_blk_node* node) {
|
clean_tree(rb_red_blk_node* node) {
|
||||||
CACHE_REGS
|
if (node == GLOBAL_ProfilerNil)
|
||||||
if (node == LOCAL_ProfilerNil)
|
|
||||||
return;
|
return;
|
||||||
clean_tree(node->left);
|
clean_tree(node->left);
|
||||||
clean_tree(node->right);
|
clean_tree(node->right);
|
||||||
@ -766,20 +751,18 @@ clean_tree(rb_red_blk_node* node) {
|
|||||||
|
|
||||||
static void
|
static void
|
||||||
reset_tree(void) {
|
reset_tree(void) {
|
||||||
CACHE_REGS
|
clean_tree(GLOBAL_ProfilerRoot);
|
||||||
clean_tree(LOCAL_ProfilerRoot);
|
Yap_FreeCodeSpace((char *)GLOBAL_ProfilerNil);
|
||||||
Yap_FreeCodeSpace((char *)LOCAL_ProfilerNil);
|
GLOBAL_ProfilerNil = GLOBAL_ProfilerRoot = NULL;
|
||||||
LOCAL_ProfilerNil = LOCAL_ProfilerRoot = NULL;
|
GLOBAL_ProfCalls = GLOBAL_ProfGCs = GLOBAL_ProfHGrows = GLOBAL_ProfSGrows = GLOBAL_ProfMallocs = GLOBAL_ProfOns = 0L;
|
||||||
LOCAL_ProfCalls = LOCAL_ProfGCs = LOCAL_ProfHGrows = LOCAL_ProfSGrows = LOCAL_ProfMallocs = LOCAL_ProfOns = 0L;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
InitProfTree(void)
|
InitProfTree(void)
|
||||||
{
|
{
|
||||||
CACHE_REGS
|
if (GLOBAL_ProfilerRoot)
|
||||||
if (LOCAL_ProfilerRoot)
|
|
||||||
reset_tree();
|
reset_tree();
|
||||||
while (!(LOCAL_ProfilerRoot = RBTreeCreate())) {
|
while (!(GLOBAL_ProfilerRoot = RBTreeCreate())) {
|
||||||
if (!Yap_growheap(FALSE, 0, NULL)) {
|
if (!Yap_growheap(FALSE, 0, NULL)) {
|
||||||
Yap_Error(OUT_OF_HEAP_ERROR, TermNil, "while initialisating profiler");
|
Yap_Error(OUT_OF_HEAP_ERROR, TermNil, "while initialisating profiler");
|
||||||
return FALSE;
|
return FALSE;
|
||||||
@ -790,15 +773,14 @@ InitProfTree(void)
|
|||||||
|
|
||||||
static void RemoveCode(CODEADDR clau)
|
static void RemoveCode(CODEADDR clau)
|
||||||
{
|
{
|
||||||
CACHE_REGS
|
|
||||||
rb_red_blk_node* x, *node;
|
rb_red_blk_node* x, *node;
|
||||||
PredEntry *pp;
|
PredEntry *pp;
|
||||||
UInt count;
|
UInt count;
|
||||||
|
|
||||||
if (!LOCAL_ProfilerRoot) return;
|
if (!GLOBAL_ProfilerRoot) return;
|
||||||
if (!(x = RBExactQuery((yamop *)clau))) {
|
if (!(x = RBExactQuery((yamop *)clau))) {
|
||||||
/* send message */
|
/* send message */
|
||||||
LOCAL_ProfOn = FALSE;
|
GLOBAL_ProfOn = FALSE;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
pp = x->pe;
|
pp = x->pe;
|
||||||
@ -811,7 +793,7 @@ static void RemoveCode(CODEADDR clau)
|
|||||||
node->pe = pp;
|
node->pe = pp;
|
||||||
node->pcs = count;
|
node->pcs = count;
|
||||||
/* send message */
|
/* send message */
|
||||||
LOCAL_ProfOn = FALSE;
|
GLOBAL_ProfOn = FALSE;
|
||||||
return;
|
return;
|
||||||
} else {
|
} else {
|
||||||
node->pcs += count;
|
node->pcs += count;
|
||||||
@ -827,21 +809,21 @@ showprofres( USES_REGS1 ) {
|
|||||||
/* First part: Read information about predicates and store it on yap trail */
|
/* First part: Read information about predicates and store it on yap trail */
|
||||||
|
|
||||||
InitProfTree();
|
InitProfTree();
|
||||||
LOCAL_ProfGCs=0;
|
GLOBAL_ProfGCs=0;
|
||||||
LOCAL_ProfMallocs=0;
|
GLOBAL_ProfMallocs=0;
|
||||||
LOCAL_ProfHGrows=0;
|
GLOBAL_ProfHGrows=0;
|
||||||
LOCAL_ProfSGrows=0;
|
GLOBAL_ProfSGrows=0;
|
||||||
LOCAL_ProfIndexing=0;
|
GLOBAL_ProfIndexing=0;
|
||||||
LOCAL_FProf=fopen(profile_names(PROFILING_FILE),"r");
|
GLOBAL_FProf=fopen(profile_names(PROFILING_FILE),"r");
|
||||||
if (LOCAL_FProf==NULL) { fclose(LOCAL_FProf); return FALSE; }
|
if (GLOBAL_FProf==NULL) { fclose(GLOBAL_FProf); return FALSE; }
|
||||||
while (fread(&buf, sizeof(buf), 1, LOCAL_FProf)) {
|
while (fread(&buf, sizeof(buf), 1, GLOBAL_FProf)) {
|
||||||
switch (buf.tag) {
|
switch (buf.tag) {
|
||||||
case '+':
|
case '+':
|
||||||
{
|
{
|
||||||
rb_red_blk_node *node;
|
rb_red_blk_node *node;
|
||||||
buf_extra e;
|
buf_extra e;
|
||||||
|
|
||||||
if (fread(&e,sizeof(buf_extra),1,LOCAL_FProf) == 0)
|
if (fread(&e,sizeof(buf_extra),1,GLOBAL_FProf) == 0)
|
||||||
return FALSE;;
|
return FALSE;;
|
||||||
node = RBTreeInsert(buf.ptr, e.end);
|
node = RBTreeInsert(buf.ptr, e.end);
|
||||||
node->pe = e.pe;
|
node->pe = e.pe;
|
||||||
@ -855,13 +837,13 @@ showprofres( USES_REGS1 ) {
|
|||||||
|
|
||||||
md = (prolog_exec_mode)buf.ptr;
|
md = (prolog_exec_mode)buf.ptr;
|
||||||
if (md & GCMode) {
|
if (md & GCMode) {
|
||||||
LOCAL_ProfGCs++;
|
GLOBAL_ProfGCs++;
|
||||||
} else if (md & MallocMode) {
|
} else if (md & MallocMode) {
|
||||||
LOCAL_ProfMallocs++;
|
GLOBAL_ProfMallocs++;
|
||||||
} else if (md & GrowHeapMode) {
|
} else if (md & GrowHeapMode) {
|
||||||
LOCAL_ProfHGrows++;
|
GLOBAL_ProfHGrows++;
|
||||||
} else if (md & GrowStackMode) {
|
} else if (md & GrowStackMode) {
|
||||||
LOCAL_ProfSGrows++;
|
GLOBAL_ProfSGrows++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -888,7 +870,7 @@ showprofres( USES_REGS1 ) {
|
|||||||
case GPROF_NEW_LU_SWITCH:
|
case GPROF_NEW_LU_SWITCH:
|
||||||
case GPROF_NEW_STATIC_SWITCH:
|
case GPROF_NEW_STATIC_SWITCH:
|
||||||
case GPROF_NEW_EXPAND_BLOCK:
|
case GPROF_NEW_EXPAND_BLOCK:
|
||||||
LOCAL_ProfIndexing++;
|
GLOBAL_ProfIndexing++;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
@ -898,8 +880,8 @@ showprofres( USES_REGS1 ) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
fclose(LOCAL_FProf);
|
fclose(GLOBAL_FProf);
|
||||||
if (LOCAL_ProfCalls==0)
|
if (GLOBAL_ProfCalls==0)
|
||||||
return TRUE;
|
return TRUE;
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
@ -916,20 +898,20 @@ prof_alrm(int signo, siginfo_t *si, void *scv)
|
|||||||
yamop *current_p;
|
yamop *current_p;
|
||||||
buf_ptr b;
|
buf_ptr b;
|
||||||
|
|
||||||
LOCAL_ProfCalls++;
|
GLOBAL_ProfCalls++;
|
||||||
/* skip an interrupt */
|
/* skip an interrupt */
|
||||||
if (LOCAL_ProfOn) {
|
if (GLOBAL_ProfOn) {
|
||||||
LOCAL_ProfOns++;
|
GLOBAL_ProfOns++;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
LOCAL_ProfOn = TRUE;
|
GLOBAL_ProfOn = TRUE;
|
||||||
oldpc = (void *) CONTEXT_PC(scv);
|
oldpc = (void *) CONTEXT_PC(scv);
|
||||||
if (LOCAL_PrologMode & TestMode) {
|
if (LOCAL_PrologMode & TestMode) {
|
||||||
|
|
||||||
b.tag = '?';
|
b.tag = '?';
|
||||||
b.ptr= (void *)LOCAL_PrologMode;
|
b.ptr= (void *)LOCAL_PrologMode;
|
||||||
fwrite(&b,sizeof(b),1,LOCAL_FPreds);
|
fwrite(&b,sizeof(b),1,GLOBAL_FPreds);
|
||||||
LOCAL_ProfOn = FALSE;
|
GLOBAL_ProfOn = FALSE;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -961,34 +943,33 @@ prof_alrm(int signo, siginfo_t *si, void *scv)
|
|||||||
#if DEBUG
|
#if DEBUG
|
||||||
fprintf(stderr,"Oops: %p, %p\n", oldpc, current_p);
|
fprintf(stderr,"Oops: %p, %p\n", oldpc, current_p);
|
||||||
#endif
|
#endif
|
||||||
LOCAL_ProfOn = FALSE;
|
GLOBAL_ProfOn = FALSE;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
b.tag = '.';
|
b.tag = '.';
|
||||||
b.ptr= current_p;
|
b.ptr= current_p;
|
||||||
fwrite(&b,sizeof(b),1,LOCAL_FPreds);
|
fwrite(&b,sizeof(b),1,GLOBAL_FPreds);
|
||||||
LOCAL_ProfOn = FALSE;
|
GLOBAL_ProfOn = FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
Yap_InformOfRemoval(void *clau)
|
Yap_InformOfRemoval(void *clau)
|
||||||
{
|
{
|
||||||
CACHE_REGS
|
GLOBAL_ProfOn = TRUE;
|
||||||
LOCAL_ProfOn = TRUE;
|
if (GLOBAL_FPreds != NULL) {
|
||||||
if (LOCAL_FPreds != NULL) {
|
|
||||||
/* just store info about what is going on */
|
/* just store info about what is going on */
|
||||||
buf_ptr b;
|
buf_ptr b;
|
||||||
|
|
||||||
b.tag = '-';
|
b.tag = '-';
|
||||||
b.ptr= clau;
|
b.ptr= clau;
|
||||||
fwrite(&b,sizeof(b),1,LOCAL_FPreds);
|
fwrite(&b,sizeof(b),1,GLOBAL_FPreds);
|
||||||
LOCAL_ProfOn = FALSE;
|
GLOBAL_ProfOn = FALSE;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
LOCAL_ProfOn = FALSE;
|
GLOBAL_ProfOn = FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static Int profend( USES_REGS1 );
|
static Int profend( USES_REGS1 );
|
||||||
@ -998,25 +979,25 @@ profnode( USES_REGS1 ) {
|
|||||||
Term t1 = Deref(ARG1), tleft, tright;
|
Term t1 = Deref(ARG1), tleft, tright;
|
||||||
rb_red_blk_node *node;
|
rb_red_blk_node *node;
|
||||||
|
|
||||||
if (!LOCAL_ProfilerRoot)
|
if (!GLOBAL_ProfilerRoot)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
if (!(node = (rb_red_blk_node *)IntegerOfTerm(t1)))
|
if (!(node = (rb_red_blk_node *)IntegerOfTerm(t1)))
|
||||||
node = LOCAL_ProfilerRoot;
|
node = GLOBAL_ProfilerRoot;
|
||||||
/*
|
/*
|
||||||
if (node->key)
|
if (node->key)
|
||||||
fprintf(stderr,"%p: %p,%p,%d,%p(%d),%p,%p\n",node,node->key,node->lim,node->pcs,node->pe,node->pe->ArityOfPE,node->right,node->left);
|
fprintf(stderr,"%p: %p,%p,%d,%p(%d),%p,%p\n",node,node->key,node->lim,node->pcs,node->pe,node->pe->ArityOfPE,node->right,node->left);
|
||||||
*/
|
*/
|
||||||
if (node->left == LOCAL_ProfilerNil) {
|
if (node->left == GLOBAL_ProfilerNil) {
|
||||||
tleft = TermNil;
|
tleft = TermNil;
|
||||||
} else {
|
} else {
|
||||||
tleft = MkIntegerTerm((Int)node->left);
|
tleft = MkIntegerTerm((Int)node->left);
|
||||||
}
|
}
|
||||||
if (node->left == LOCAL_ProfilerNil) {
|
if (node->left == GLOBAL_ProfilerNil) {
|
||||||
tleft = TermNil;
|
tleft = TermNil;
|
||||||
} else {
|
} else {
|
||||||
tleft = MkIntegerTerm((Int)node->left);
|
tleft = MkIntegerTerm((Int)node->left);
|
||||||
}
|
}
|
||||||
if (node->right == LOCAL_ProfilerNil) {
|
if (node->right == GLOBAL_ProfilerNil) {
|
||||||
tright = TermNil;
|
tright = TermNil;
|
||||||
} else {
|
} else {
|
||||||
tright = MkIntegerTerm((Int)node->right);
|
tright = MkIntegerTerm((Int)node->right);
|
||||||
@ -1032,23 +1013,23 @@ profnode( USES_REGS1 ) {
|
|||||||
static Int
|
static Int
|
||||||
profglobs( USES_REGS1 ) {
|
profglobs( USES_REGS1 ) {
|
||||||
return
|
return
|
||||||
Yap_unify(ARG1,MkIntegerTerm(LOCAL_ProfCalls)) &&
|
Yap_unify(ARG1,MkIntegerTerm(GLOBAL_ProfCalls)) &&
|
||||||
Yap_unify(ARG2,MkIntegerTerm(LOCAL_ProfGCs)) &&
|
Yap_unify(ARG2,MkIntegerTerm(GLOBAL_ProfGCs)) &&
|
||||||
Yap_unify(ARG3,MkIntegerTerm(LOCAL_ProfHGrows)) &&
|
Yap_unify(ARG3,MkIntegerTerm(GLOBAL_ProfHGrows)) &&
|
||||||
Yap_unify(ARG4,MkIntegerTerm(LOCAL_ProfSGrows)) &&
|
Yap_unify(ARG4,MkIntegerTerm(GLOBAL_ProfSGrows)) &&
|
||||||
Yap_unify(ARG5,MkIntegerTerm(LOCAL_ProfMallocs)) &&
|
Yap_unify(ARG5,MkIntegerTerm(GLOBAL_ProfMallocs)) &&
|
||||||
Yap_unify(ARG6,MkIntegerTerm(LOCAL_ProfIndexing)) &&
|
Yap_unify(ARG6,MkIntegerTerm(GLOBAL_ProfIndexing)) &&
|
||||||
Yap_unify(ARG7,MkIntegerTerm(LOCAL_ProfOns)) ;
|
Yap_unify(ARG7,MkIntegerTerm(GLOBAL_ProfOns)) ;
|
||||||
}
|
}
|
||||||
|
|
||||||
static Int
|
static Int
|
||||||
do_profinit( USES_REGS1 )
|
do_profinit( USES_REGS1 )
|
||||||
{
|
{
|
||||||
// LOCAL_FPreds=fopen(profile_names(PROFPREDS_FILE),"w+");
|
// GLOBAL_FPreds=fopen(profile_names(PROFPREDS_FILE),"w+");
|
||||||
// if (LOCAL_FPreds == NULL) return FALSE;
|
// if (GLOBAL_FPreds == NULL) return FALSE;
|
||||||
LOCAL_FProf=fopen(profile_names(PROFILING_FILE),"w+");
|
GLOBAL_FProf=fopen(profile_names(PROFILING_FILE),"w+");
|
||||||
if (LOCAL_FProf==NULL) { fclose(LOCAL_FProf); return FALSE; }
|
if (GLOBAL_FProf==NULL) { fclose(GLOBAL_FProf); return FALSE; }
|
||||||
LOCAL_FPreds = LOCAL_FProf;
|
GLOBAL_FPreds = GLOBAL_FProf;
|
||||||
|
|
||||||
Yap_dump_code_area_for_profiler();
|
Yap_dump_code_area_for_profiler();
|
||||||
return TRUE;
|
return TRUE;
|
||||||
@ -1056,22 +1037,21 @@ do_profinit( USES_REGS1 )
|
|||||||
|
|
||||||
static Int profinit( USES_REGS1 )
|
static Int profinit( USES_REGS1 )
|
||||||
{
|
{
|
||||||
if (LOCAL_ProfilerOn!=0) return (FALSE);
|
if (GLOBAL_ProfilerOn!=0) return (FALSE);
|
||||||
|
|
||||||
if (!do_profinit( PASS_REGS1 ))
|
if (!do_profinit( PASS_REGS1 ))
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
LOCAL_ProfilerOn = -1; /* Inited but not yet started */
|
GLOBAL_ProfilerOn = -1; /* Inited but not yet started */
|
||||||
return(TRUE);
|
return(TRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
static Int start_profilers(int msec)
|
static Int start_profilers(int msec)
|
||||||
{
|
{
|
||||||
CACHE_REGS
|
|
||||||
struct itimerval t;
|
struct itimerval t;
|
||||||
struct sigaction sa;
|
struct sigaction sa;
|
||||||
|
|
||||||
if (LOCAL_ProfilerOn!=-1) {
|
if (GLOBAL_ProfilerOn!=-1) {
|
||||||
return FALSE; /* have to go through profinit */
|
return FALSE; /* have to go through profinit */
|
||||||
}
|
}
|
||||||
sa.sa_sigaction=prof_alrm;
|
sa.sa_sigaction=prof_alrm;
|
||||||
@ -1086,15 +1066,15 @@ static Int start_profilers(int msec)
|
|||||||
t.it_value.tv_usec=msec;
|
t.it_value.tv_usec=msec;
|
||||||
setitimer(ITIMER_PROF,&t,NULL);
|
setitimer(ITIMER_PROF,&t,NULL);
|
||||||
|
|
||||||
LOCAL_ProfilerOn = msec;
|
GLOBAL_ProfilerOn = msec;
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static Int profoff( USES_REGS1 ) {
|
static Int profoff( USES_REGS1 ) {
|
||||||
if (LOCAL_ProfilerOn>0) {
|
if (GLOBAL_ProfilerOn>0) {
|
||||||
setitimer(ITIMER_PROF,NULL,NULL);
|
setitimer(ITIMER_PROF,NULL,NULL);
|
||||||
LOCAL_ProfilerOn = -1;
|
GLOBAL_ProfilerOn = -1;
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
return FALSE;
|
return FALSE;
|
||||||
@ -1113,22 +1093,22 @@ static Int ProfOn0( USES_REGS1 ) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
static Int profison( USES_REGS1 ) {
|
static Int profison( USES_REGS1 ) {
|
||||||
return (LOCAL_ProfilerOn > 0);
|
return (GLOBAL_ProfilerOn > 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
static Int profalt( USES_REGS1 ) {
|
static Int profalt( USES_REGS1 ) {
|
||||||
if (LOCAL_ProfilerOn==0) return(FALSE);
|
if (GLOBAL_ProfilerOn==0) return(FALSE);
|
||||||
if (LOCAL_ProfilerOn==-1) return ProfOn( PASS_REGS1 );
|
if (GLOBAL_ProfilerOn==-1) return ProfOn( PASS_REGS1 );
|
||||||
return profoff( PASS_REGS1 );
|
return profoff( PASS_REGS1 );
|
||||||
}
|
}
|
||||||
|
|
||||||
static Int profend( USES_REGS1 )
|
static Int profend( USES_REGS1 )
|
||||||
{
|
{
|
||||||
if (LOCAL_ProfilerOn==0) return(FALSE);
|
if (GLOBAL_ProfilerOn==0) return(FALSE);
|
||||||
profoff( PASS_REGS1 ); /* Make sure profiler is off */
|
profoff( PASS_REGS1 ); /* Make sure profiler is off */
|
||||||
LOCAL_ProfilerOn=0;
|
GLOBAL_ProfilerOn=0;
|
||||||
fclose(LOCAL_FProf);
|
fclose(GLOBAL_FProf);
|
||||||
LOCAL_FPreds = NULL;
|
GLOBAL_FPreds = NULL;
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1178,9 +1158,8 @@ void
|
|||||||
Yap_InitLowProf(void)
|
Yap_InitLowProf(void)
|
||||||
{
|
{
|
||||||
#if LOW_PROF
|
#if LOW_PROF
|
||||||
CACHE_REGS
|
GLOBAL_ProfCalls = 0;
|
||||||
LOCAL_ProfCalls = 0;
|
GLOBAL_ProfilerOn = FALSE;
|
||||||
LOCAL_ProfilerOn = FALSE;
|
|
||||||
|
|
||||||
Yap_InitCPred("profinit",0, profinit, SafePredFlag);
|
Yap_InitCPred("profinit",0, profinit, SafePredFlag);
|
||||||
Yap_InitCPred("profend" ,0, profend, SafePredFlag);
|
Yap_InitCPred("profend" ,0, profend, SafePredFlag);
|
||||||
|
@ -194,7 +194,7 @@ char *STD_PROTO(Yap_FindExecutable,(void));
|
|||||||
void STD_PROTO(Yap_InitLowProf,(void));
|
void STD_PROTO(Yap_InitLowProf,(void));
|
||||||
#if LOW_PROF
|
#if LOW_PROF
|
||||||
void STD_PROTO(Yap_inform_profiler_of_clause__,(void *,void *,struct pred_entry *, gprof_info));
|
void STD_PROTO(Yap_inform_profiler_of_clause__,(void *,void *,struct pred_entry *, gprof_info));
|
||||||
#define Yap_inform_profiler_of_clause(CODE0,CODEF,AP,MODE) {if (LOCAL_FPreds) Yap_inform_profiler_of_clause__(CODE0,CODEF,AP,MODE);}
|
#define Yap_inform_profiler_of_clause(CODE0,CODEF,AP,MODE) {if (GLOBAL_FPreds) Yap_inform_profiler_of_clause__(CODE0,CODEF,AP,MODE);}
|
||||||
#else
|
#else
|
||||||
#define Yap_inform_profiler_of_clause(CODE0,CODEF,AP,MODE)
|
#define Yap_inform_profiler_of_clause(CODE0,CODEF,AP,MODE)
|
||||||
#endif
|
#endif
|
||||||
|
17
H/dglobals.h
17
H/dglobals.h
@ -100,3 +100,20 @@
|
|||||||
|
|
||||||
#define GLOBAL_RestoreFile Yap_global->RestoreFile_
|
#define GLOBAL_RestoreFile Yap_global->RestoreFile_
|
||||||
|
|
||||||
|
#define GLOBAL_ProfCalls Yap_global->ProfCalls_
|
||||||
|
#define GLOBAL_ProfGCs Yap_global->ProfGCs_
|
||||||
|
#define GLOBAL_ProfHGrows Yap_global->ProfHGrows_
|
||||||
|
#define GLOBAL_ProfSGrows Yap_global->ProfSGrows_
|
||||||
|
#define GLOBAL_ProfMallocs Yap_global->ProfMallocs_
|
||||||
|
#define GLOBAL_ProfIndexing Yap_global->ProfIndexing_
|
||||||
|
#define GLOBAL_ProfOn Yap_global->ProfOn_
|
||||||
|
#define GLOBAL_ProfOns Yap_global->ProfOns_
|
||||||
|
#define GLOBAL_ProfilerRoot Yap_global->ProfilerRoot_
|
||||||
|
#define GLOBAL_ProfilerNil Yap_global->ProfilerNil_
|
||||||
|
#define GLOBAL_DIRNAME Yap_global->DIRNAME_
|
||||||
|
#if LOW_PROF
|
||||||
|
#define GLOBAL_ProfilerOn Yap_global->ProfilerOn_
|
||||||
|
#define GLOBAL_FProf Yap_global->FProf_
|
||||||
|
#define GLOBAL_FPreds Yap_global->FPreds_
|
||||||
|
#endif /* LOW_PROF */
|
||||||
|
|
||||||
|
31
H/dlocals.h
31
H/dlocals.h
@ -398,37 +398,6 @@
|
|||||||
#define REMOTE_ImportDBRefHashTableNum(wid) REMOTE(wid)->ImportDBRefHashTableNum_
|
#define REMOTE_ImportDBRefHashTableNum(wid) REMOTE(wid)->ImportDBRefHashTableNum_
|
||||||
#define LOCAL_ImportFAILCODE LOCAL->ImportFAILCODE_
|
#define LOCAL_ImportFAILCODE LOCAL->ImportFAILCODE_
|
||||||
#define REMOTE_ImportFAILCODE(wid) REMOTE(wid)->ImportFAILCODE_
|
#define REMOTE_ImportFAILCODE(wid) REMOTE(wid)->ImportFAILCODE_
|
||||||
|
|
||||||
#define LOCAL_ProfCalls LOCAL->ProfCalls_
|
|
||||||
#define REMOTE_ProfCalls(wid) REMOTE(wid)->ProfCalls_
|
|
||||||
#define LOCAL_ProfGCs LOCAL->ProfGCs_
|
|
||||||
#define REMOTE_ProfGCs(wid) REMOTE(wid)->ProfGCs_
|
|
||||||
#define LOCAL_ProfHGrows LOCAL->ProfHGrows_
|
|
||||||
#define REMOTE_ProfHGrows(wid) REMOTE(wid)->ProfHGrows_
|
|
||||||
#define LOCAL_ProfSGrows LOCAL->ProfSGrows_
|
|
||||||
#define REMOTE_ProfSGrows(wid) REMOTE(wid)->ProfSGrows_
|
|
||||||
#define LOCAL_ProfMallocs LOCAL->ProfMallocs_
|
|
||||||
#define REMOTE_ProfMallocs(wid) REMOTE(wid)->ProfMallocs_
|
|
||||||
#define LOCAL_ProfIndexing LOCAL->ProfIndexing_
|
|
||||||
#define REMOTE_ProfIndexing(wid) REMOTE(wid)->ProfIndexing_
|
|
||||||
#define LOCAL_ProfOn LOCAL->ProfOn_
|
|
||||||
#define REMOTE_ProfOn(wid) REMOTE(wid)->ProfOn_
|
|
||||||
#define LOCAL_ProfOns LOCAL->ProfOns_
|
|
||||||
#define REMOTE_ProfOns(wid) REMOTE(wid)->ProfOns_
|
|
||||||
#define LOCAL_ProfilerRoot LOCAL->ProfilerRoot_
|
|
||||||
#define REMOTE_ProfilerRoot(wid) REMOTE(wid)->ProfilerRoot_
|
|
||||||
#define LOCAL_ProfilerNil LOCAL->ProfilerNil_
|
|
||||||
#define REMOTE_ProfilerNil(wid) REMOTE(wid)->ProfilerNil_
|
|
||||||
#define LOCAL_DIRNAME LOCAL->DIRNAME_
|
|
||||||
#define REMOTE_DIRNAME(wid) REMOTE(wid)->DIRNAME_
|
|
||||||
#if LOW_PROF
|
|
||||||
#define LOCAL_ProfilerOn LOCAL->ProfilerOn_
|
|
||||||
#define REMOTE_ProfilerOn(wid) REMOTE(wid)->ProfilerOn_
|
|
||||||
#define LOCAL_FProf LOCAL->FProf_
|
|
||||||
#define REMOTE_FProf(wid) REMOTE(wid)->FProf_
|
|
||||||
#define LOCAL_FPreds LOCAL->FPreds_
|
|
||||||
#define REMOTE_FPreds(wid) REMOTE(wid)->FPreds_
|
|
||||||
#endif /* LOW_PROF */
|
|
||||||
#define LOCAL_FunctorVar LOCAL->FunctorVar_
|
#define LOCAL_FunctorVar LOCAL->FunctorVar_
|
||||||
#define REMOTE_FunctorVar(wid) REMOTE(wid)->FunctorVar_
|
#define REMOTE_FunctorVar(wid) REMOTE(wid)->FunctorVar_
|
||||||
|
|
||||||
|
17
H/hglobals.h
17
H/hglobals.h
@ -99,4 +99,21 @@ typedef struct global_data {
|
|||||||
|
|
||||||
|
|
||||||
char* RestoreFile_;
|
char* RestoreFile_;
|
||||||
|
|
||||||
|
Int ProfCalls_;
|
||||||
|
Int ProfGCs_;
|
||||||
|
Int ProfHGrows_;
|
||||||
|
Int ProfSGrows_;
|
||||||
|
Int ProfMallocs_;
|
||||||
|
Int ProfIndexing_;
|
||||||
|
Int ProfOn_;
|
||||||
|
Int ProfOns_;
|
||||||
|
struct RB_red_blk_node* ProfilerRoot_;
|
||||||
|
struct RB_red_blk_node* ProfilerNil_;
|
||||||
|
char* DIRNAME_;
|
||||||
|
#if LOW_PROF
|
||||||
|
int ProfilerOn_;
|
||||||
|
FILE* FProf_;
|
||||||
|
FILE* FPreds_;
|
||||||
|
#endif /* LOW_PROF */
|
||||||
} w_shared;
|
} w_shared;
|
||||||
|
17
H/hlocals.h
17
H/hlocals.h
@ -224,23 +224,6 @@ typedef struct worker_local {
|
|||||||
UInt ImportDBRefHashTableSize_;
|
UInt ImportDBRefHashTableSize_;
|
||||||
UInt ImportDBRefHashTableNum_;
|
UInt ImportDBRefHashTableNum_;
|
||||||
yamop *ImportFAILCODE_;
|
yamop *ImportFAILCODE_;
|
||||||
|
|
||||||
Int ProfCalls_;
|
|
||||||
Int ProfGCs_;
|
|
||||||
Int ProfHGrows_;
|
|
||||||
Int ProfSGrows_;
|
|
||||||
Int ProfMallocs_;
|
|
||||||
Int ProfIndexing_;
|
|
||||||
Int ProfOn_;
|
|
||||||
Int ProfOns_;
|
|
||||||
struct RB_red_blk_node* ProfilerRoot_;
|
|
||||||
struct RB_red_blk_node* ProfilerNil_;
|
|
||||||
char* DIRNAME_;
|
|
||||||
#if LOW_PROF
|
|
||||||
int ProfilerOn_;
|
|
||||||
FILE* FProf_;
|
|
||||||
FILE* FPreds_;
|
|
||||||
#endif /* LOW_PROF */
|
|
||||||
Functor FunctorVar_;
|
Functor FunctorVar_;
|
||||||
|
|
||||||
UInt ibnds_[256];
|
UInt ibnds_[256];
|
||||||
|
17
H/iglobals.h
17
H/iglobals.h
@ -99,4 +99,21 @@ static void InitGlobal(void) {
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
GLOBAL_DIRNAME = NULL;
|
||||||
|
#if LOW_PROF
|
||||||
|
GLOBAL_ProfilerOn = FALSE;
|
||||||
|
GLOBAL_FProf = NULL;
|
||||||
|
GLOBAL_FPreds = NULL;
|
||||||
|
#endif /* LOW_PROF */
|
||||||
}
|
}
|
||||||
|
17
H/ilocals.h
17
H/ilocals.h
@ -224,23 +224,6 @@ static void InitWorker(int wid) {
|
|||||||
REMOTE_ImportDBRefHashTableSize(wid) = 0;
|
REMOTE_ImportDBRefHashTableSize(wid) = 0;
|
||||||
REMOTE_ImportDBRefHashTableNum(wid) = 0;
|
REMOTE_ImportDBRefHashTableNum(wid) = 0;
|
||||||
REMOTE_ImportFAILCODE(wid) = NULL;
|
REMOTE_ImportFAILCODE(wid) = NULL;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
REMOTE_DIRNAME(wid) = NULL;
|
|
||||||
#if LOW_PROF
|
|
||||||
REMOTE_ProfilerOn(wid) = FALSE;
|
|
||||||
REMOTE_FProf(wid) = NULL;
|
|
||||||
REMOTE_FPreds(wid) = NULL;
|
|
||||||
#endif /* LOW_PROF */
|
|
||||||
REMOTE_FunctorVar(wid) = FunctorVar;
|
REMOTE_FunctorVar(wid) = FunctorVar;
|
||||||
|
|
||||||
|
|
||||||
|
17
H/rglobals.h
17
H/rglobals.h
@ -99,4 +99,21 @@ static void RestoreGlobal(void) {
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#if LOW_PROF
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#endif /* LOW_PROF */
|
||||||
}
|
}
|
||||||
|
17
H/rlocals.h
17
H/rlocals.h
@ -224,23 +224,6 @@ static void RestoreWorker(int wid USES_REGS) {
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#if LOW_PROF
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#endif /* LOW_PROF */
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -2314,6 +2314,7 @@ X_API int PL_next_solution(qid_t qi)
|
|||||||
}
|
}
|
||||||
qi->state = 1;
|
qi->state = 1;
|
||||||
if (result == 0) {
|
if (result == 0) {
|
||||||
|
YAP_LeaveGoal(FALSE, &qi->h);
|
||||||
qi->open = 0;
|
qi->open = 0;
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
@ -2343,9 +2344,11 @@ X_API void PL_close_query(qid_t qi)
|
|||||||
|
|
||||||
X_API int PL_call_predicate(module_t ctx, int flags, predicate_t p, term_t t0)
|
X_API int PL_call_predicate(module_t ctx, int flags, predicate_t p, term_t t0)
|
||||||
{
|
{
|
||||||
|
fid_t f = PL_open_foreign_frame();
|
||||||
qid_t qi = PL_open_query(ctx, flags, p, t0);
|
qid_t qi = PL_open_query(ctx, flags, p, t0);
|
||||||
int ret = PL_next_solution(qi);
|
int ret = PL_next_solution(qi);
|
||||||
PL_cut_query(qi);
|
PL_cut_query(qi);
|
||||||
|
PL_close_foreign_frame(f);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
17
misc/GLOBALS
17
misc/GLOBALS
@ -120,6 +120,23 @@ char pwd[YAP_FILENAME_MAX] void
|
|||||||
|
|
||||||
char* RestoreFile void
|
char* RestoreFile void
|
||||||
|
|
||||||
|
//gprof.c
|
||||||
|
Int ProfCalls void
|
||||||
|
Int ProfGCs void
|
||||||
|
Int ProfHGrows void
|
||||||
|
Int ProfSGrows void
|
||||||
|
Int ProfMallocs void
|
||||||
|
Int ProfIndexing void
|
||||||
|
Int ProfOn void
|
||||||
|
Int ProfOns void
|
||||||
|
struct RB_red_blk_node* ProfilerRoot void
|
||||||
|
struct RB_red_blk_node* ProfilerNil void
|
||||||
|
char* DIRNAME =NULL
|
||||||
|
#if LOW_PROF
|
||||||
|
int ProfilerOn =FALSE
|
||||||
|
FILE* FProf =NULL
|
||||||
|
FILE* FPreds =NULL
|
||||||
|
#endif /* LOW_PROF */
|
||||||
|
|
||||||
|
|
||||||
END_GLOBAL_DATA
|
END_GLOBAL_DATA
|
||||||
|
17
misc/LOCALS
17
misc/LOCALS
@ -252,23 +252,6 @@ UInt ImportDBRefHashTableSize =0
|
|||||||
UInt ImportDBRefHashTableNum =0
|
UInt ImportDBRefHashTableNum =0
|
||||||
yamop *ImportFAILCODE =NULL
|
yamop *ImportFAILCODE =NULL
|
||||||
|
|
||||||
//gprof.c
|
|
||||||
Int ProfCalls void
|
|
||||||
Int ProfGCs void
|
|
||||||
Int ProfHGrows void
|
|
||||||
Int ProfSGrows void
|
|
||||||
Int ProfMallocs void
|
|
||||||
Int ProfIndexing void
|
|
||||||
Int ProfOn void
|
|
||||||
Int ProfOns void
|
|
||||||
struct RB_red_blk_node* ProfilerRoot void
|
|
||||||
struct RB_red_blk_node* ProfilerNil void
|
|
||||||
char* DIRNAME =NULL
|
|
||||||
#if LOW_PROF
|
|
||||||
int ProfilerOn =FALSE
|
|
||||||
FILE* FProf =NULL
|
|
||||||
FILE* FPreds =NULL
|
|
||||||
#endif /* LOW_PROF */
|
|
||||||
|
|
||||||
Functor FunctorVar =FunctorVar
|
Functor FunctorVar =FunctorVar
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user