use private memory for yapor's alloc
This commit is contained in:
parent
e41851e9d9
commit
e19a910152
10
C/alloc.c
10
C/alloc.c
@ -251,6 +251,7 @@ Yap_InitPreAllocCodeSpace(int wid)
|
|||||||
char *ptr;
|
char *ptr;
|
||||||
UInt sz = REMOTE_ScratchPad(wid).msz;
|
UInt sz = REMOTE_ScratchPad(wid).msz;
|
||||||
|
|
||||||
|
|
||||||
if (REMOTE_ScratchPad(wid).ptr == NULL) {
|
if (REMOTE_ScratchPad(wid).ptr == NULL) {
|
||||||
#if USE_DL_MALLOC
|
#if USE_DL_MALLOC
|
||||||
LOCK(DLMallocLock);
|
LOCK(DLMallocLock);
|
||||||
@ -261,7 +262,13 @@ Yap_InitPreAllocCodeSpace(int wid)
|
|||||||
tmalloc += sz;
|
tmalloc += sz;
|
||||||
sz += sizeof(CELL);
|
sz += sizeof(CELL);
|
||||||
#endif
|
#endif
|
||||||
while (!(ptr = my_malloc(sz))) {
|
while (!(ptr =
|
||||||
|
#ifdef YAPOR_COPY
|
||||||
|
malloc(sz)
|
||||||
|
#else
|
||||||
|
my_malloc(sz)
|
||||||
|
#endif
|
||||||
|
)) {
|
||||||
REMOTE_PrologMode(wid) &= ~MallocMode;
|
REMOTE_PrologMode(wid) &= ~MallocMode;
|
||||||
#if USE_DL_MALLOC
|
#if USE_DL_MALLOC
|
||||||
UNLOCK(DLMallocLock);
|
UNLOCK(DLMallocLock);
|
||||||
@ -290,6 +297,7 @@ Yap_InitPreAllocCodeSpace(int wid)
|
|||||||
}
|
}
|
||||||
AuxBase = (ADDR)(ptr);
|
AuxBase = (ADDR)(ptr);
|
||||||
AuxSp = (CELL *)(AuxTop = AuxBase+REMOTE_ScratchPad(wid).sz);
|
AuxSp = (CELL *)(AuxTop = AuxBase+REMOTE_ScratchPad(wid).sz);
|
||||||
|
printf("wid=%d %p %p %p--%p\n", wid, AuxBase, AuxSp, Yap_HeapBase, H);
|
||||||
return ptr;
|
return ptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user