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. |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|