#include "sm/Storage.h"
#include "RtsUtils.h"
+#include "Prelude.h"
#include "Schedule.h" /* initScheduler */
#include "Stats.h" /* initStats */
#include "STM.h" /* initSTM */
#include "sm/BlockAlloc.h"
#include "Trace.h"
#include "Stable.h"
-#include "eventlog/EventLog.h"
#include "Hash.h"
#include "Profiling.h"
#include "Timer.h"
#include "Globals.h"
+void exitLinker( void ); // there is no Linker.h file to include
#if defined(RTS_GTK_FRONTPANEL)
#include "FrontPanel.h"
static int hs_init_count = 0;
/* -----------------------------------------------------------------------------
- Initialise floating point unit on x86 (currently disabled. why?)
- (see comment in ghc/compiler/nativeGen/MachInstrs.lhs).
+ Initialise floating point unit on x86 (currently disabled; See Note
+ [x86 Floating point precision] in compiler/nativeGen/X86/Instr.hs)
-------------------------------------------------------------------------- */
#define X86_INIT_FPU 0
*/
stat_startInit();
-#if defined(DEBUG)
- /* Start off by initialising the allocator debugging so we can
- * use it anywhere */
- initAllocator();
-#endif
-
/* Set the RTS flags to default values. */
initRtsFlagsDefaults();
#endif
/* initTracing must be after setupRtsFlags() */
-#ifdef DEBUG
+#ifdef TRACING
initTracing();
#endif
+ /* Dtrace events are always enabled
+ */
+ dtraceEventStartup();
/* initialise scheduler data structures (needs to be done before
* initStorage()).
* knows about. We don't know whether these turn out to be CAFs
* or refer to CAFs, but we have to assume that they might.
*/
- getStablePtr((StgPtr)base_GHCziTopHandler_runIO_closure);
- getStablePtr((StgPtr)base_GHCziTopHandler_runNonIO_closure);
+ getStablePtr((StgPtr)runIO_closure);
+ getStablePtr((StgPtr)runNonIO_closure);
+
+ getStablePtr((StgPtr)runFinalizerBatch_closure);
+
getStablePtr((StgPtr)stackOverflow_closure);
getStablePtr((StgPtr)heapOverflow_closure);
- getStablePtr((StgPtr)runFinalizerBatch_closure);
getStablePtr((StgPtr)unpackCString_closure);
getStablePtr((StgPtr)blockedIndefinitelyOnMVar_closure);
getStablePtr((StgPtr)nonTermination_closure);
getStablePtr((StgPtr)blockedIndefinitelyOnSTM_closure);
+ getStablePtr((StgPtr)nestedAtomically_closure);
+
+ getStablePtr((StgPtr)runSparks_closure);
+ getStablePtr((StgPtr)ensureIOManagerIsRunning_closure);
+#ifndef mingw32_HOST_OS
+ getStablePtr((StgPtr)runHandlers_closure);
+#endif
/* initialise the shared Typeable store */
initGlobalStore();
initProfiling1();
-#ifdef EVENTLOG
- if (RtsFlags.EventLogFlags.doEventLogging) {
- initEventLogging();
- }
-#endif
-
/* start the virtual timer 'subsystem'. */
initTimer();
startTimer();
OnExitHook();
+ // sanity check
+#if defined(DEBUG)
+ checkFPUStack();
+#endif
+
+ // Free the full argv storage
+ freeFullProgArgv();
+
#if defined(THREADED_RTS)
ioManagerDie();
#endif
/* stop the ticker */
stopTimer();
- exitTimer();
+ exitTimer(wait_foreign);
// set the terminal settings back to what they were
#if !defined(mingw32_HOST_OS)
/* free shared Typeable store */
exitGlobalStore();
+ /* free linker data */
+ exitLinker();
+
/* free file locking tables, if necessary */
#if !defined(mingw32_HOST_OS)
freeFileLocking();
if (prof_file != NULL) fclose(prof_file);
#endif
-#ifdef EVENTLOG
- if (RtsFlags.EventLogFlags.doEventLogging) {
- endEventLogging();
- freeEventLogging();
- }
+#ifdef TRACING
+ endTracing();
+ freeTracing();
#endif
#if defined(TICKY_TICKY)
/* free hash table storage */
exitHashTable();
- // Finally, free all our storage
- freeStorage();
-
-#if defined(DEBUG)
- /* and shut down the allocator debugging */
- shutdownAllocator();
-#endif
+ // Finally, free all our storage. However, we only free the heap
+ // memory if we have waited for foreign calls to complete;
+ // otherwise a foreign call in progress may still be referencing
+ // heap memory (e.g. by being passed a ByteArray#).
+ freeStorage(wait_foreign);
}