Base Address Control | An eccentricity of Solaris which allows identification of where the thread will reside in physical memory. |
Call-Once Functions | An ability to limit execution of a particular function/routine only once. Subsequent calls will return without execution and error. |
Cancellation | Killing threads from within program. |
Condition Variables | |
Detached Threads | |
Fork All Threads | A flag which forces all thread-creation calls to be forks with shared memory. Since Linux defines a fork() as a specific kind of clone() (thread), this is somewhat inherent. Other implementations have to redefine or encapsulate thread-creation calls in order to accomplish this. |
Fork Calling Thread Only | |
Forked Process | A stand-alone task that shares nothing intrinsicly with other tasks. The only communication is has is through pipes, files and explicitly shared memory. |
Joinable Threads | The ability to merge threads into a single execution context(?). |
Kernel-space Threads | Threads that are handled/scheduled by the kernel. |
Mutex | Stands for Mutual Exclusion. A mutex can lock specific sections of memory using access flags. |
Mutex Attributes | |
Per-thread Data Handling Function | |
Per-thread Signal Handling | Ability to specify sharing signals. In other words, several threads can share a signal: if the signal is raised only one thread has to respond. This is different from unshared signals: each thread has its own signal table. |
Priority Inversion Handling | As threads get I/O blocked, provide a temporary reprioritization of threads. |
Priority Scheduling | Programmatically identifying the order, priority, or next threads to execute. |
Process | Essentially the same as a Task, having it's own private data and event regions. However, often "process" defines the whole running program which may have several threads and/or tasks. Also, "process" describes a supervising program. |
Processor-specific Thread Allocation | The ability to designate a specific thread to a specific processor. This is useful for processors that handle special things like interrupts or excelerators. |
Readers/Writer Locking | In Solaris, threads can have one writer and several readers at the same time. |
Semaphores | A pair of functions that lock datasets, p() and v() (lock and unlock, respectively) |
Shared/Private Mutexes | Having separate spaces for mutexes |
Specifying Concurrency | The ability to identify which threads will be multiprocessed. |
Stack Size Control | The ability to limit, resize or check the thread's stack usage. |
Synchronization | |
Task | Like the Process, a Task has its own data and event regions, but a task often includes interaction with other parent, child or sister tasks. The task may have specific assignments to perform; whereas, the process may supervise. |
Thread | The smallest context of execution (COE). Often it is created to share data directly with the parent. |
Thread | As how Linux Torvalds defines it: a "context of execution". It basically is the minimum basic executable unit that contains shared code, data and stack. Thus it is simply a processor's context. |
Thread Attributes | |
Thread ID Comparison | |
Thread Suspension | Temporarily halting execution of a thread. In Linux kernel-space threads, this can be accomplished using SIGSTOP and SIGCONT. |
User-space Threads | Threads that are handled/scheduled within a single task by special libraries. |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |