blob: 856536f5aa95ea98d076b5b966298abf96a06fad (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
|
/* -----------------------------------------------------------------------------
*
* (c) The GHC Team, 2005
*
* RTS entry points as mandated by the FFI section of the Haskell report
*
* ---------------------------------------------------------------------------*/
#include "PosixSource.h"
#include "HsFFI.h"
#include "Rts.h"
#include "Stable.h"
// hs_init and hs_exit are defined in RtsStartup.c
void
hs_set_argv(int argc, char *argv[])
{
setProgArgv(argc,argv);
}
void
hs_perform_gc(void)
{
/* Hmmm, the FFI spec is a bit vague, but it seems to imply a major GC... */
performMajorGC();
}
void hs_lock_stable_tables (void)
{
stableLock();
}
void hs_unlock_stable_tables (void)
{
stableUnlock();
}
void
hs_free_stable_ptr(HsStablePtr sp)
{
/* The cast is for clarity only, both HsStablePtr and StgStablePtr are
typedefs for void*. */
freeStablePtr((StgStablePtr)sp);
}
void
hs_free_stable_ptr_unsafe(HsStablePtr sp)
{
/* The cast is for clarity only, both HsStablePtr and StgStablePtr are
typedefs for void*. */
freeStablePtrUnsafe((StgStablePtr)sp);
}
void
hs_free_fun_ptr(HsFunPtr fp)
{
/* I simply *love* all these similar names... */
freeHaskellFunctionPtr(fp);
}
|