Updated PCI IDs to latest snapshot.
[tangerine.git] / workbench / libs / thread / README
blob96b785ffbff71be105bd35ebd30d7769714bad7f
1 README for thread.library
3 Author: Robert Norris <rob@cataclysm.cx>
4 Last update: 2007-11-30
6 This is trivial library to provide basic threads and synchronisation
7 primitives to higher-level libraries and applications. It currently provides
8 the following:
10  - Threads
11  - Mutexes
12  - Condition variables
14 This is a work-in-progress. Expect freakish things to happen if you use it.
15 Please let me know if something doesn't work the way you want or expect it to.
16 Both the interface and semantics are fluid, so you can get things changed if
17 you want, but on the other hand you'll need to track changes to the library in
18 your app.
20 This library is deliberately designed not to be POSIX threads. My hope is that
21 it could be used to implement them, but it won't ever be that all by itself.
22 POSIX thread semantics are more complicated than I want to deal with at this
23 level.
25 The biggest omission at this stage is a way to force a thread to exit. Its
26 hard to do because there's no way to know what resources the thread currently
27 has open in order to close them. I have some ideas, but I don't know that it
28 can be done well without proper task resource tracking.
30 In a similar vein, when your application or library closes thread.library (in
31 an app, this will typically happen when main() exits), it will wait for any
32 threads that are still running to finish. You'll get some warnings in the
33 kernel log when this happens. The main process can't be allowed to exit while
34 threads are still running as the main thread is usually holding resources that
35 the threads need that will be deallocated when the thread exits, eg the
36 program code itself. As long as the threads run in the same address space as
37 the main process there's very little that can be done about this.
39 This also makes detached threads rather meaningless. The detached thread
40 semantics are provided in the hope they can be fully implemented in the future.
42 TODO
44  - A way to gracefully ask a thread to exit (giving the thread opportunity to
45    clean up)
47  - A way to wait for all threads to finish (including detached threads, so
48    this can be used usefully to wait for threads before exiting in main()).
50  - A true way to detach running threads such that they can exist after the
51    main process exits.
53  - Can exiting the main process while threads are still running be handled
54    better?
56  - Read/write ("promotable") mutexes, where you can request to obtain a lock
57    exclusively while already holding it as a shared lock. This can avoid races
58    in some situations.