summaryrefslogtreecommitdiff
path: root/includes
diff options
context:
space:
mode:
authorSimon Marlow <marlowsd@gmail.com>2009-02-19 10:31:42 +0000
committerSimon Marlow <marlowsd@gmail.com>2009-02-19 10:31:42 +0000
commit7ed3f7556f46b957f7efb97ed7ebdc92db2f8ab7 (patch)
tree8ea698123bfac74c5881bc5f62b5de6a145bdb84 /includes
parent77b7c34fa24860c91f56250defa91b2d1a7a1c00 (diff)
downloadhaskell-7ed3f7556f46b957f7efb97ed7ebdc92db2f8ab7.tar.gz
Rewrite of signal-handling (ghc patch; see also base and unix patches)
The API is the same (for now). The new implementation has the capability to define signal handlers that have access to the siginfo of the signal (#592), but this functionality is not exposed in this patch. #2451 is the ticket for the new API. The main purpose of bringing this in now is to fix race conditions in the old signal handling code (#2858). Later we can enable the new API in the HEAD. Implementation differences: - More of the signal-handling is moved into Haskell. We store the table of signal handlers in an MVar, rather than having a table of StablePtrs in the RTS. - In the threaded RTS, the siginfo of the signal is passed down the pipe to the IO manager thread, which manages the business of starting up new signal handler threads. In the non-threaded RTS, the siginfo of caught signals is stored in the RTS, and the scheduler starts new signal handler threads.
Diffstat (limited to 'includes')
-rw-r--r--includes/RtsExternal.h2
1 files changed, 1 insertions, 1 deletions
diff --git a/includes/RtsExternal.h b/includes/RtsExternal.h
index 31cae1a45a..2272b2a429 100644
--- a/includes/RtsExternal.h
+++ b/includes/RtsExternal.h
@@ -94,7 +94,7 @@ extern HpcModuleInfo *hs_hpc_rootModule(void);
extern int rts_InstallConsoleEvent ( int action, StgStablePtr *handler );
extern void rts_ConsoleHandlerDone ( int ev );
#else
-extern int stg_sig_install (int, int, StgStablePtr *, void *);
+extern int stg_sig_install (int, int, void *);
#endif
#if defined(mingw32_HOST_OS)