summaryrefslogtreecommitdiff
path: root/ghc/rts/Select.c
Commit message (Collapse)AuthorAgeFilesLines
* [project @ 2005-10-21 14:02:17 by simonmar]simonmar2005-10-211-270/+0
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Big re-hash of the threaded/SMP runtime This is a significant reworking of the threaded and SMP parts of the runtime. There are two overall goals here: - To push down the scheduler lock, reducing contention and allowing more parts of the system to run without locks. In particular, the scheduler does not require a lock any more in the common case. - To improve affinity, so that running Haskell threads stick to the same OS threads as much as possible. At this point we have the basic structure working, but there are some pieces missing. I believe it's reasonably stable - the important parts of the testsuite pass in all the (normal,threaded,SMP) ways. In more detail: - Each capability now has a run queue, instead of one global run queue. The Capability and Task APIs have been completely rewritten; see Capability.h and Task.h for the details. - Each capability has its own pool of worker Tasks. Hence, Haskell threads on a Capability's run queue will run on the same worker Task(s). As long as the OS is doing something reasonable, this should mean they usually stick to the same CPU. Another way to look at this is that we're assuming each Capability is associated with a fixed CPU. - What used to be StgMainThread is now part of the Task structure. Every OS thread in the runtime has an associated Task, and it can ask for its current Task at any time with myTask(). - removed RTS_SUPPORTS_THREADS symbol, use THREADED_RTS instead (it is now defined for SMP too). - The RtsAPI has had to change; we must explicitly pass a Capability around now. The previous interface assumed some global state. SchedAPI has also changed a lot. - The OSThreads API now supports thread-local storage, used to implement myTask(), although it could be done more efficiently using gcc's __thread extension when available. - I've moved some POSIX-specific stuff into the posix subdirectory, moving in the direction of separating out platform-specific implementations. - lots of lock-debugging and assertions in the runtime. In particular, when DEBUG is on, we catch multiple ACQUIRE_LOCK()s, and there is also an ASSERT_LOCK_HELD() call. What's missing so far: - I have almost certainly broken the Win32 build, will fix soon. - any kind of thread migration or load balancing. This is high up the agenda, though. - various performance tweaks to do - throwTo and forkProcess still do not work in SMP mode
* [project @ 2005-04-07 14:33:30 by simonmar]simonmar2005-04-071-1/+7
| | | | | | | | | Support handling signals in the threaded RTS by passing the signal number down the pipe to the IO manager. This avoids needing synchronisation in the signal handler. Signals should now work with -threaded. Since this is a bugfix, I'll merge the changes into the 6.4 branch.
* [project @ 2005-03-31 08:59:34 by simonmar]simonmar2005-03-311-2/+2
| | | | Make getourtimeofday() return lnat instead of nat, and propagate changes.
* [project @ 2004-10-14 14:58:37 by simonmar]simonmar2004-10-141-103/+0
| | | | | | | | | | | | | | | | | | | | | | | | | | | | Threaded RTS improvements: - Unix only: implement waitRead#, waitWrite# and delay# in Haskell, by having a single Haskell thread (the IO manager) performing a blocking select() operation. Threads communicate with the IO manager via channels. This is faster than doing the select() in the RTS, because we only restart the select() when a new request arrives, rather than each time around the scheduler. On Windows we just make blocking IO calls, we don't have a fancy IO manager (yet). - Simplify the scheduler for the threaded RTS, now that we don't have to wait for IO in the scheduler loop. - Remove detectBlackHoles(), which isn't used now (not sure how long this has been unused for... perhaps it was needed back when main threads used to be GC roots, so we had to check for blackholes manually rather than relying on the GC.) Signals aren't quite right in the threaded RTS. In fact, they're slightly worse than before, because the thread receiving signals might be blocked in a C call - previously there always be another thread stuck in awaitEvent() that would notice the signal, but that's not true now. I can't see an easy fix yet.
* [project @ 2004-09-12 11:27:10 by panne]panne2004-09-121-1/+0
| | | | | Removed the annoying "Id" CVS keywords, they're a real PITA when it comes to merging...
* [project @ 2004-09-03 15:28:18 by simonmar]simonmar2004-09-031-8/+6
| | | | | | | | | | | | Cleanup: all (well, most) messages from the RTS now go through the functions in RtsUtils: barf(), debugBelch() and errorBelch(). The latter two were previously called belch() and prog_belch() respectively. See the comments for the right usage of these message functions. One reason for doing this is so that we can avoid spurious uses of stdout/stderr by Haskell apps on platforms where we shouldn't be using them (eg. non-console apps on Windows).
* [project @ 2004-07-15 20:50:40 by sof]sof2004-07-151-19/+4
| | | | oops, back out rev. 1.31
* [project @ 2004-07-15 20:42:45 by sof]sof2004-07-151-4/+19
| | | | awaitEvent(): for Integrity, use socketpair() instead of pipe() to implement socket()-aborting mechanism
* [project @ 2003-10-01 10:49:07 by wolfgang]wolfgang2003-10-011-1/+17
| | | | | | | | | | | | | | | | Threaded RTS: Don't start new worker threads earlier than necessary. After this commit, a Haskell program that uses neither forkOS nor forkIO is really single-threaded (rather than using two OS threads internally). Some details: Worker threads are now only created when a capability is released, and only when (there are no worker threads) && (there are runnable Haskell threads || there are Haskell threads blocked on IO or threadDelay) awaitEvent can now be called from bound thread scheduling loops (so that we don't have to create a worker thread just to run awaitEvent)
* [project @ 2003-06-26 12:22:59 by stolz]stolz2003-06-261-1/+5
| | | | Warning Police: include unistd.h if available
* [project @ 2003-04-01 15:05:13 by sof]sof2003-04-011-1/+3
| | | | | | | Tidy up code that supports user/Haskell signal handlers. Signals.h now defines RTS_USER_SIGNALS when this is supported, which is then used elsewhere.
* [project @ 2003-03-29 00:00:41 by sof]sof2003-03-291-6/+1
| | | | win32 tidyup: exclude Select.c, Itimer.c and Signals.c from SRCS
* [project @ 2003-02-22 06:13:41 by sof]sof2003-02-221-1/+2
| | | | bring getourtimeofday() proto into scope
* [project @ 2003-02-22 04:51:50 by sof]sof2003-02-221-32/+9
| | | | | | | | | | | | | | | | | | Clean up code&interfaces that deals with timers and asynchrony: - Timer.{c,h} now defines the platform-independent interface to the timing services needed by the RTS. Itimer.{c,h} + win32/Ticker.{c,h} defines the OS-specific services that creates/destroys a timer. - For win32 plats, drop the long-standing use of the 'multimedia' API timers and implement the ticking service ourselves. Simpler and more flexible. - Select.c is now solely for platforms that use select() to handle non-blocking I/O & thread delays. win32/AwaitEvent.c provides the same API on the Win32 side. - support threadDelay on win32 platforms via worker threads. Not yet compiled up on non-win32 platforms; will do once checked in.
* [project @ 2003-02-21 05:34:12 by sof]sof2003-02-211-2/+5
| | | | | | | | | | | | | | | | | | | | | | Asynchronous / non-blocking I/O for Win32 platforms. This commit introduces a Concurrent Haskell friendly view of I/O on Win32 platforms. Through the use of a pool of worker Win32 threads, CH threads may issue asynchronous I/O requests without blocking the progress of other CH threads. The issuing CH thread is blocked until the request has been serviced though. GHC.Conc exports the primops that take care of issuing the asynchronous I/O requests, which the IO implementation now takes advantage of. By default, all Handles are non-blocking/asynchronous, but should performance become an issue, having a per-Handle flag for turning off non-blocking could easily be imagined&introduced. [Incidentally, this thread pool-based implementation could easily be extended to also allow Haskell code to delegate the execution of arbitrary pieces of (potentially blocking) external code to another OS thread. Given how relatively gnarly the locking story has turned out to be with the 'threaded' RTS, that may not be such a bad idea.]
* [project @ 2003-01-25 15:54:48 by wolfgang]wolfgang2003-01-251-2/+82
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This commit fixes many bugs and limitations in the threaded RTS. There are still some issues remaining, though. The following bugs should have been fixed: - [+] "safe" calls could cause crashes - [+] yieldToReturningWorker/grabReturnCapability - It used to deadlock. - [+] couldn't wake blocked workers - Calls into the RTS could go unanswered for a long time, and that includes ordinary callbacks in some circumstances. - [+] couldn't block on an MVar and expect to be woken up by a signal handler - Depending on the exact situation, the RTS shut down or blocked forever and ignored the signal. - [+] The locking scheme in RtsAPI.c didn't work - [+] run_thread label in wrong place (schedule()) - [+] Deadlock in GHC.Handle - if a signal arrived at the wrong time, an mvar was never filled again - [+] Signals delivered to the "wrong" thread were ignored or handled too late. Issues: *) If GC can move TSO objects (I don't know - can it?), then ghci will occasionally crash when calling foreign functions, because the parameters are stored on the TSO stack. *) There is still a race condition lurking in the code (both threaded and non-threaded RTS are affected): If a signal arrives after the check for pending signals in schedule(), but before the call to select() in awaitEvent(), select() will be called anyway. The signal handler will be executed much later than expected. *) For Win32, GHC doesn't yet support non-blocking IO, so while a thread is waiting for IO, no call-ins can happen. If the RTS is blocked in awaitEvent, it uses a polling loop on Win32, so call-ins should work (although the polling loop looks ugly). *) Deadlock detection is disabled for the threaded rts, because I don't know how to do it properly in the presence of foreign call-ins from foreign threads. This causes the tests conc031, conc033 and conc034 to fail. *) "safe" is currently treated as "threadsafe". Implementing "safe" in a way that blocks other Haskell threads is more difficult than was thought at first. I think it could be done with a few additional lines of code, but personally, I'm strongly in favour of abolishing the distinction. *) Running finalizers at program termination is inefficient - there are two OS threads passing messages back and forth for every finalizer that is run. Also (just as in the non-threaded case) the finalizers are run in parallel to any remaining haskell threads and to any foreign call-ins that might still happen.
* [project @ 2002-07-24 03:38:58 by sof]sof2002-07-241-8/+9
| | | | | | | | | | | | awaitEvent: if select() reports EBADF, always unblock all waiting threads, even if the prior invocation of select() also elicited an EBADF. The 'smart' that was there previously runs the risk of working against us (if the EBADFs are coming from different fds), so the above scheme is preferable (and simpler.)
* [project @ 2002-07-17 09:21:48 by simonmar]simonmar2002-07-171-2/+5
| | | | | | | | | | | | | | | Remove most #includes of system headers from Stg.h, and instead #include any required headers directly in each RTS source file. The idea is to (a) reduce namespace pollution from system headers that we don't need, (c) be clearer about dependencies on system things in the RTS, and (c) improve via-C compilation times (maybe). In practice though, HsBase.h #includes everything anyway, so the difference from the point of view of .hc source is minimal. However, this makes it easier to move to zero-includes if we wanted to (see discussion on the FFI list; I'm still not sure that's possible but at least this is a step in the right direction).
* [project @ 2002-07-09 20:44:24 by sof]sof2002-07-091-9/+30
| | | | | | | | | | | | | | | awaitEvent: better handling of EBADFs, i.e., don't unconditionally barf() and exit if select() reports an EBADF. See source code comments for details, but in short, we attempt to unblock all threads to handle the error condition before bailing out. If only select() would indicate which file descriptor that was the bad one. (There's no good reason why select() errors other than EBADF could also be handled this way, but let's focus on it for now..)
* [project @ 2001-11-13 13:38:02 by simonmar]simonmar2001-11-131-8/+1
| | | | Remove unused ticks_since_timestamp.
* [project @ 2001-10-31 10:34:29 by simonmar]simonmar2001-10-311-2/+2
| | | | | | | | | | | | | | Fix a problem when a Haskell process is suspended/resumed using shell job control in Unix. The shell tends to put stdin back into blocking mode before resuming the process, so we have to catch SIGCONT and put it back into O_NONBLOCK. Also: - fix a bug in the scheduler: reverse the order of the check for pending signals and the call to awaitEvent to block on I/O. - do a style sweep in Signals.c
* [project @ 2001-08-14 13:40:07 by sewardj]sewardj2001-08-141-2/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Change the story about POSIX headers in C compilation. Until now, all C code in the RTS and library cbits has by default been compiled with settings for POSIXness enabled, that is: #define _POSIX_SOURCE 1 #define _POSIX_C_SOURCE 199309L #define _ISOC9X_SOURCE If you wanted to negate this, you'd have to define NON_POSIX_SOURCE before including headers. This scheme has some bad effects: * It means that ccall-unfoldings exported via interfaces from a module compiled with -DNON_POSIX_SOURCE may not compile when imported into a module which does not -DNON_POSIX_SOURCE. * It overlaps with the feature tests we do with autoconf. * It seems to have caused borkage in the Solaris builds for some considerable period of time. The New Way is: * The default changes to not-being-in-Posix mode. * If you want to force a C file into Posix mode, #include as the **first** include the new file ghc/includes/PosixSource.h. Most of the RTS C sources have this include now. * NON_POSIX_SOURCE is almost totally expunged. Unfortunately we have to retain some vestiges of it in ghc/compiler so that modules compiled via C on Solaris using older compilers don't break.
* [project @ 2001-02-28 14:23:55 by sewardj]sewardj2001-02-281-2/+2
| | | | Correctly #include <windows.h>.
* [project @ 2001-02-27 12:43:45 by rrt]rrt2001-02-271-16/+26
| | | | | | mingwin "fixes": getourtimeofday now returns the right units, and awaitEvent fudged to use WinSock select(), so that although it doesn't work for file handles, at least it doesn't cause nasty crashes; instead it just blocks.
* [project @ 2000-08-25 13:12:07 by simonmar]simonmar2000-08-251-153/+136
| | | | | | | | Change the way threadDelay# is implemented. We now use a list of sleeping threads sorted in increasing order by the time at which they will wake up. This avoids us having to traverse the entire queue on each context switch.
* [project @ 2000-08-23 12:51:03 by simonmar]simonmar2000-08-231-2/+8
| | | | Fix a problem where ^C wasn't recognised while waiting for I/O.
* [project @ 2000-04-03 15:24:21 by rrt]rrt2000-04-031-3/+3
| | | | | | | Stopped getourtimeofday() being called under mingwin. MBlock.c: changed one instance of 128 * 1024 * 1024 into SIZE_RESERVED_POOL and added a TODO comment (bug in is_heap_alloced(), which won't work if more than one megablock is ever allocated).
* [project @ 2000-03-23 12:02:38 by simonmar]simonmar2000-03-231-4/+8
| | | | Don't wake up threads if the select() was interrupted by a signal.
* [project @ 2000-03-20 09:42:49 by andy]andy2000-03-201-10/+35
| | | | | | | | | | | | Adding an alternative to the "delay" system used for threads that are waiting for time to pass. This works on a target time basis, eliminating the need to use the ticky style counter. It is only enabled under: #if defined(INTERPRETER) && !defined(HAVE_SETITIMER)
* [project @ 2000-03-16 17:24:08 by simonmar]simonmar2000-03-161-2/+2
| | | | put a lock in the right place.
* [project @ 2000-01-17 17:33:30 by simonmar]simonmar2000-01-171-145/+153
| | | | | | | | | | | | Put a giant loop around awaitEvent, to protect against awaitEvent(rtsTrue) returning with no threads to run. This can happen if we try to delay for some time X, and select(2) decides to wait for a shorter time X-\delta instead. It appears that Solaris is more prone to doing this than Linux. This fixes the "schedule: invalid whatNext field" crashes that people may have seen.
* [project @ 2000-01-13 12:40:15 by simonmar]simonmar2000-01-131-3/+2
| | | | | | | | | | | | | | | | | | | - remove AllBlocked scheduler return code. Nobody owned up to having created it or even knowing what it was there for. - clean up fatal error condition handling somewhat. The process exit code from a GHC program now indicates the kind of failure for certain kinds of exit: general internal RTS error 254 program deadlocked 253 program interrupted (ctrl-C) 252 heap overflow 251 main thread killed 250 and we leave exit codes 1-199 for the user (as is traditional at MS, 200-249 are reserved for future expansion, and may contain undocumented extensions :-)
* [project @ 2000-01-12 15:15:17 by simonmar]simonmar2000-01-121-22/+23
| | | | Add 'par' and sparking support to the SMP implementation.
* [project @ 1999-11-24 16:39:33 by simonmar]simonmar1999-11-241-4/+10
| | | | Fix bug in threadDelay, where the delay ticks could end up negative.
* [project @ 1999-11-03 15:04:25 by simonmar]simonmar1999-11-031-3/+41
| | | | | | | | - don't hold the scheduler lock while doing the select, since we might sit in there for a long time. - don't need the gettimeofday() hack on Linux, because select already returns the unslept time.
* [project @ 1999-10-04 16:14:34 by simonmar]simonmar1999-10-041-1/+11
| | | | Service signal handlers if we get an EINTR from select(2).
* [project @ 1999-09-13 08:28:45 by sof]sof1999-09-131-1/+11
| | | | Win32 version of awaitEvent(). Easy :)
* [project @ 1999-08-25 16:37:42 by simonmar]simonmar1999-08-251-0/+174
Add select code for thread{WaitRead,WaitWrite,Delay}.