Skip to content

Commit

Permalink
Julia HPC-GAP integration.
Browse files Browse the repository at this point in the history
  • Loading branch information
rbehrends committed Nov 7, 2019
1 parent 3b944e5 commit b01a691
Show file tree
Hide file tree
Showing 13 changed files with 152 additions and 10 deletions.
2 changes: 0 additions & 2 deletions Makefile.rules
Original file line number Diff line number Diff line change
Expand Up @@ -64,9 +64,7 @@ SOURCES += src/intfuncs.c
SOURCES += src/intrprtr.c
SOURCES += src/io.c
SOURCES += src/iostream.c
ifeq ($(HPCGAP),no) # we don't support a kernel API in HPC-GAP atm
SOURCES += src/libgap-api.c
endif
SOURCES += src/listfunc.c
SOURCES += src/listoper.c
SOURCES += src/lists.c
Expand Down
4 changes: 0 additions & 4 deletions lib/oper.g
Original file line number Diff line number Diff line change
Expand Up @@ -1896,8 +1896,6 @@ BIND_GLOBAL( "InstallGlobalFunction", function( arg )
od;
end );

if not IsHPCGAP then

BIND_GLOBAL( "FLUSH_ALL_METHOD_CACHES", function()
local oper,j;
for oper in OPERATIONS do
Expand All @@ -1907,8 +1905,6 @@ BIND_GLOBAL( "FLUSH_ALL_METHOD_CACHES", function()
od;
end);

fi;

if BASE_SIZE_METHODS_OPER_ENTRY <> 6 then
Error("MethodsOperation must be updated for new BASE_SIZE_METHODS_OPER_ENTRY");
fi;
Expand Down
16 changes: 16 additions & 0 deletions src/hpc/guards.h
Original file line number Diff line number Diff line change
Expand Up @@ -21,8 +21,10 @@

static ALWAYS_INLINE Bag WriteGuard(Bag bag)
{
#ifdef USE_HPC_GUARDS
if (!WriteCheck(bag))
HandleWriteGuardError(bag);
#endif
return bag;
}

Expand All @@ -34,17 +36,22 @@ EXPORT_INLINE Bag ImpliedWriteGuard(Bag bag)

EXPORT_INLINE int CheckWriteAccess(Bag bag)
{
#ifdef USE_HPC_GUARDS
Region * region;
if (!IS_BAG_REF(bag))
return 1;
region = REGION(bag);
return !(region && region->owner != GetTLS() &&
region->alt_owner != GetTLS()) ||
TLS(DisableGuards) >= 2;
#else
return 1;
#endif
}

EXPORT_INLINE int CheckExclusiveWriteAccess(Bag bag)
{
#ifdef USE_HPC_GUARDS
Region * region;
if (!IS_BAG_REF(bag))
return 1;
Expand All @@ -53,12 +60,17 @@ EXPORT_INLINE int CheckExclusiveWriteAccess(Bag bag)
return 0;
return region->owner == GetTLS() || region->alt_owner == GetTLS() ||
TLS(DisableGuards) >= 2;
#else
return 1;
#endif
}

static ALWAYS_INLINE Bag ReadGuard(Bag bag)
{
#ifdef USE_HPC_GUARDS
if (!ReadCheck(bag))
HandleReadGuardError(bag);
#endif
return bag;
}

Expand All @@ -69,6 +81,7 @@ static ALWAYS_INLINE Bag ImpliedReadGuard(Bag bag)

static ALWAYS_INLINE int CheckReadAccess(Bag bag)
{
#ifdef USE_HPC_GUARDS
Region * region;
if (!IS_BAG_REF(bag))
return 1;
Expand All @@ -77,6 +90,9 @@ static ALWAYS_INLINE int CheckReadAccess(Bag bag)
!region->readers[TLS(threadID)] &&
region->alt_owner != GetTLS()) ||
TLS(DisableGuards) >= 2;
#else
return 1;
#endif
}

#endif // GAP_HPC_GUARD_H
2 changes: 1 addition & 1 deletion src/hpc/misc.c
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ UInt SyNumGCThreads = 0;
*V SingleThreadStartup . . . . . . . . . start HPC-GAP with just one thread
**
*/
UInt SingleThreadStartup = 0;
UInt SingleThreadStartup = 1;

/****************************************************************************
**
Expand Down
5 changes: 5 additions & 0 deletions src/hpc/region.c
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,10 @@ Region * NewRegion(void)
result = GC_malloc(sizeof(Region) + (MAX_THREADS + 1));
lock = GC_malloc_atomic(sizeof(*lock));
GC_register_finalizer(lock, LockFinalizer, NULL, NULL, NULL);
#elif defined(USE_JULIA_GC)
result = AllocateMemoryBlock(sizeof(Region) + (MAX_THREADS + 1));
lock = AllocateMemoryBlock(sizeof(*lock));
// NYI: finalize locks
#else
#error Not yet implemented for this garbage collector
#endif
Expand Down Expand Up @@ -79,3 +83,4 @@ void RetypeBagIfWritable(Obj obj, UInt new_type)
if (CheckWriteAccess(obj))
RetypeBag(obj, new_type);
}

4 changes: 4 additions & 0 deletions src/hpc/thread.c
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,10 @@
# define GC_THREADS
# endif
# include <gc/gc.h>
#elif USE_JULIA_GC
# ifdef HPCGAP
# include "julia_gc.h"
# endif
#endif


Expand Down
7 changes: 6 additions & 1 deletion src/hpc/threadapi.c
Original file line number Diff line number Diff line change
Expand Up @@ -484,6 +484,7 @@ static void ThreadedInterpreter(void * funcargs)

static Obj FuncCreateThread(Obj self, Obj funcargs)
{
#ifndef USE_JULIA_GC
Int i, n;
Obj thread;
Obj templist;
Expand All @@ -503,6 +504,10 @@ static Obj FuncCreateThread(Obj self, Obj funcargs)
if (!thread)
return Fail;
return thread;
#else
ErrorMayQuit("CreateThread: disabled with Julia GC", 0, 0);
return 0; // flow control hint
#endif
}

/****************************************************************************
Expand Down Expand Up @@ -2354,7 +2359,7 @@ void InitSignals(void)
timer.it_interval.tv_usec = 10000;
timer.it_value.tv_sec = 0;
timer.it_value.tv_usec = 10000;
setitimer(ITIMER_VIRTUAL, &timer, NULL);
// setitimer(ITIMER_VIRTUAL, &timer, NULL);
}

static Obj FuncPERIODIC_CHECK(Obj self, Obj count, Obj func)
Expand Down
1 change: 1 addition & 0 deletions src/hpc/tls.h
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,7 @@ typedef struct Region Region;
typedef struct ThreadLocalStorage
{
int threadID;
int threadInit;
void *threadLock;
void *threadSignal;
void *acquiredMonitor;
Expand Down
90 changes: 89 additions & 1 deletion src/julia_gc.c
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,10 @@
#include <julia.h>
#include <julia_gcext.h>

#ifdef HPCGAP
#include "hpc/thread.h"
#endif


/****************************************************************************
**
Expand Down Expand Up @@ -198,7 +202,6 @@ static size_t max_pool_obj_size;
static UInt YoungRef;
static int FullGC;

#if !defined(SCAN_STACK_FOR_MPTRS_ONLY)
typedef struct {
void * addr;
size_t size;
Expand All @@ -222,6 +225,9 @@ static inline int CmpMemBlock(MemBlock m1, MemBlock m2)

#include "baltree.h"

static MemBlockTree * gc_roots;

#if !defined(SCAN_STACK_FOR_MPTRS_ONLY)
static size_t bigval_startoffset;
static MemBlockTree * bigvals;

Expand Down Expand Up @@ -544,6 +550,20 @@ void CHANGED_BAG(Bag bag)
jl_gc_wb_back(BAG_HEADER(bag));
}

#ifdef HPCGAP
static void ScanExtraRoots(MemBlockNode * node)
{
if (node) {
ScanExtraRoots(node->left);
MemBlock mem = node->item;
char *start = mem.addr;
char *end = start + mem.size;
TryMarkRange(start, end);
ScanExtraRoots(node->right);
}
}
#endif

static void GapRootScanner(int full)
{
// Mark our Julia module (this contains references to our custom data
Expand Down Expand Up @@ -571,6 +591,10 @@ static void GapRootScanner(int full)
// The reason is that if Julia is being initialized from GAP, it
// cannot always reliably find the top of the stack for that task,
// so we have to fall back to GAP for that.
#ifdef HPCGAP
#define IsUsingLibGap() 0
ScanExtraRoots(gc_roots->root);
#endif
if (!IsUsingLibGap() && JuliaTLS->tid == 0 &&
JuliaTLS->root_task == task) {
stackend = (char *)GapStackBottom;
Expand Down Expand Up @@ -716,6 +740,7 @@ void InitBags(UInt initial_size, Bag * stack_bottom, UInt stack_align)
}
// These callbacks need to be set before initialization so
// that we can track objects allocated during `jl_init()`.
gc_roots = MemBlockTreeMake();
#if !defined(SCAN_STACK_FOR_MPTRS_ONLY)
bigvals = MemBlockTreeMake();
jl_gc_set_cb_notify_external_alloc(alloc_bigval, 1);
Expand All @@ -725,6 +750,7 @@ void InitBags(UInt initial_size, Bag * stack_bottom, UInt stack_align)
max_pool_obj_size = jl_gc_max_internal_obj_size();
jl_gc_enable_conservative_gc_support();
jl_init();
jl_gc_enable(0);

// Import GAPTypes module to have access to GapObj abstract type.
// Needs to be done before setting any GC states
Expand Down Expand Up @@ -804,6 +830,10 @@ void InitBags(UInt initial_size, Bag * stack_bottom, UInt stack_align)
GAP_ASSERT(jl_is_datatype(datatype_bag));
GAP_ASSERT(jl_is_datatype(datatype_largebag));
StackAlignBags = stack_align;
#ifdef HPCGAP
CreateMainRegion();
AddGCRoots();
#endif
}

UInt CollectBags(UInt size, UInt full)
Expand All @@ -813,6 +843,25 @@ UInt CollectBags(UInt size, UInt full)
return 1;
}

/****************************************************************************
**
*V DSInfoBags[<type>] . . . . . . . . . . . . . . region info for bags
*/

#ifdef HPCGAP

static char DSInfoBags[NUM_TYPES];

#define DSI_TL 0
#define DSI_PUBLIC 1

void MakeBagTypePublic(int type)
{
DSInfoBags[type] = DSI_PUBLIC;
}

#endif // HPCGAP

void RetypeBag(Bag bag, UInt new_type)
{
BagHeader * header = BAG_HEADER(bag);
Expand Down Expand Up @@ -856,6 +905,13 @@ void RetypeBag(Bag bag, UInt new_type)
Panic("cannot change bag type to one requiring a 'free' callback");
}
header->type = new_type;
#ifdef HPCGAP
switch (DSInfoBags[new_type]) {
case DSI_PUBLIC:
SET_REGION(bag, NULL);
break;
}
#endif // HPCGAP
}

Bag NewBag(UInt type, UInt size)
Expand All @@ -879,7 +935,11 @@ Bag NewBag(UInt type, UInt size)
alloc_size++;

#if defined(SCAN_STACK_FOR_MPTRS_ONLY)
#ifdef HPCGAP
bag = jl_gc_alloc_typed(JuliaTLS, 2 * sizeof(void *), datatype_mptr);
#else
bag = jl_gc_alloc_typed(JuliaTLS, sizeof(void *), datatype_mptr);
#endif
SET_PTR_BAG(bag, 0);
#endif

Expand All @@ -890,6 +950,16 @@ Bag NewBag(UInt type, UInt size)
header->size = size;


#ifdef HPCGAP
switch (DSInfoBags[type]) {
case DSI_TL:
SET_REGION(bag, CurrentRegion());
break;
case DSI_PUBLIC:
SET_REGION(bag, NULL);
break;
}
#endif
#if !defined(SCAN_STACK_FOR_MPTRS_ONLY)
// allocate the new masterpointer
bag = jl_gc_alloc_typed(JuliaTLS, sizeof(void *), datatype_mptr);
Expand Down Expand Up @@ -1022,3 +1092,21 @@ void MarkJuliaWeakRef(void * p)
if (JMarkTyped(p, jl_weakref_type))
YoungRef++;
}

void *AllocateMemoryBlock(UInt size)
{
return calloc(1, size);
}


void GC_add_roots(void *start, void *end)
{
MemBlock mem = { start, (char *) end - (char *) start };
MemBlockTreeInsert(gc_roots, mem);
}

void GC_remove_roots(void *start, void *end)
{
MemBlock mem = { start, (char *) end - (char *) start };
MemBlockTreeRemove(gc_roots, mem);
}
11 changes: 11 additions & 0 deletions src/julia_gc.h
Original file line number Diff line number Diff line change
Expand Up @@ -45,4 +45,15 @@ void MarkJuliaObjSafe(void * obj);

void MarkJuliaWeakRef(void * obj);

/****************************************************************************
**
*F GC_add_roots(<start>, <end>) . . . . . . . . . . . . . . . add GC roots
*F GC_remove_roots(<start>, <end>) . . . . . . . . . . . . . remove GC roots
**
** Add or remove additional roots for the Julia GC.
*/

void GC_add_roots(void * start, void * end);
void GC_remove_roots(void * start, void * end);

#endif
16 changes: 16 additions & 0 deletions src/libgap-api.c
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,12 @@ void GAP_Initialize(int argc,
int handleSignals)
{
UsingLibGap = 1;
#ifdef HPCGAP
#if !defined(USE_NATIVE_TLS) && !defined(USE_PTHREAD_TLS)
Panic("The HPC-GAP version of libgap requires --enable-native-tls");
#endif
InitializeTLS();
#endif

InitializeGap(&argc, argv, handleSignals);
SetExtraMarkFuncBags(markBagsCallback);
Expand All @@ -64,6 +70,16 @@ void GAP_Initialize(int argc,
GAP_Fail = Fail;
}

#ifdef HPCGAP
void GAP_InitializeThread(void)
{
if (!TLS(threadInit)) {
TLS(threadInit) = 1;
InitializeTLS();
}
}
#endif


////
//// program evaluation and execution
Expand Down
Loading

0 comments on commit b01a691

Please sign in to comment.