Go to main content
Index
Numbers and Symbols
- 32-bit architectures
Programming with Synchronization Objects
- 64-bit environment
- /dev/kmem
Using the 64-bit Architecture
- /dev/mem
Using the 64-bit Architecture
- /proc restrictions
Using the 64-bit Architecture
- data type model
Using the 64-bit Architecture
- large file support
Using the 64-bit Architecture
- large virtual address space
Using the 64-bit Architecture
- libkvm library
Using the 64-bit Architecture
- libraries
Using the 64-bit Architecture
- registers
Using the 64-bit Architecture
A
- accessing the signal mask
Accessing the Signal Mask of the Calling Thread
- Ada programming language
Completion Semantics
- adding signals to mask
pthread_sigmask Syntax
- aio_cancel() function
Waiting for I/O Operation to Complete
- aio_error() function
Waiting for I/O Operation to Complete
- aio_read() function
Asynchronous I/O Operations
- aio_return() function
Waiting for I/O Operation to Complete
- aio_suspend() function
Waiting for I/O Operation to Complete
- aio_waitn() function
Waiting for I/O Operation to Complete
- aio_write() function
Asynchronous I/O Operations
- aiocbp control block
Asynchronous I/O Operations
- alarms
Using Alarms
- algorithms
- faster with MT
Using Multiprocessors Efficiently
- parallel
Multithreaded Cooperation Through
Barrier Synchronization
- sequential
Multithreaded Cooperation Through
Barrier Synchronization
- allocating storage from heap
- malloc
Simple Threads Example
- application-level threads
Multithreading Terms
- architecture
- multiprocessor
Underlying Architecture
- SPARC
Mutual Exclusion for Two Threads
Shared-Memory Multiprocessors
Programming with Synchronization Objects
- assert statement
Testing the Invariant With assert(3C)
The Producer and Consumer Problem: the Producer
The Producer and Consumer Problem: the Producer
- Async-Signal-Safe
- functions
- Oracle Solaris
Async-Signal-Safe Functions in Oracle Solaris Threads
- POSIX
Signal Handlers and Async-Signal Safety
- signal handlers
Signal Handlers and Async-Signal Safety
- threads
Waiting for a Specified Signal
- asynchronous
- event notification
Routines for Semaphores
- I/O
Asynchronous I/O
- semaphore use
Routines for Semaphores
- signals
Thread-Directed Signals
Asynchronous Signals
Extending Traditional Signals
- asynchronous I/O
- operations
Asynchronous I/O Operations- waiting for
Waiting for I/O Operation to Complete
- atomic, defined
Programming with Synchronization Objects
- automatic
- stack allocation
Allocating Stack Space for Threads
B
- barrier synchronization
Parallelizing a Loop on a Shared-Memory Parallel Computer
Using Barrier Synchronization
- binary semaphores
Synchronization With Semaphores
- binding
- threads to LWPs
thr_create Syntax
- values to key
Setting the Thread-Specific Data Value
- bottlenecks
Locking Guidelines
- bound threads
Multithreading Terms- defined
Multithreading Terms
C
- caching
- cache defined
Underlying Architecture
- threads data structure
Creating and Using Threads
- cancelling threads
- cancellation points
Cancellation Points
- request
Cancel a Thread
- requested
Thread Cancellation
- changing the signal mask
Access the Signal Mask of the Calling Thread
Accessing the Signal Mask of the Calling Thread
- circularly-linked list
- example
Example of Nested Locking With a Circularly-Linked List
- coarse-grained locking
Data Locking
- code lock
Invariants and Locks
Reentrant Function
- code monitor
Avoiding Deadlock
Code Locking
- compare thread identifiers
pthread_equal Syntax
- compiling a multithreaded application
Compiling a Multithreaded Application
- completion semantics
Completion Semantics
- cond_broadcast() function
Unblock All Threads
- cond_destroy() function
Destroying a Condition Variable
- cond_init() function
Example of Producer and Consumer Problem
Initialize a Condition Variable
- USYNC_THREAD
Synchronizing Across Process Boundaries
- cond_reltimedwait() function
Waiting for a Time Interval
- cond_signal() function
Unblock One Thread
- cond_timedwait() function
Wait for an Absolute Time
- cond_wait() function
Waiting for a Condition
- condition variables
The Producer and Consumer Problem: the Producer
Condition Variable Attributes
Programming with Synchronization Objects
- blocking for specified time
Blocking For a Specified Interval
- blocking on
Blocking on a Condition Variable
- blocking until specified time
Blocking Until a Specified Time
- destroying state
Destroying the Condition Variable State
- getting clock selection
Getting the Clock Selection Condition Variable
- getting scope
Getting the Scope of a Condition Variable
- initializing
Initializing a Condition Variable
- intializing attributes
Initializing a Condition Variable Attribute
- removing attribute
Removing a Condition Variable Attribute
- setting clock selection
Setting the Clock Selection Condition Variable
- setting scope
Setting the Scope of a Condition Variable
- unblocking one thread
Unblocking One Thread
- unblocking threads
Unblocking All Threads
- condition wait
- POSIX threads
Interrupted Waits on Condition Variables
- contention
Locking Guidelines
Avoiding Deadlock
- continuing execution
Continuing a Suspended Thread
- counting semaphores
Synchronization With Semaphores
Multithreading Terms
- creating
- stacks
thr_min_stack Syntax
thr_create Syntax
pthread_attr_setstack Syntax
Building Your Own Stack
- threads
Creating and Using Threads
- creating a default thread
Creating a Default Thread
- critical section
Peterson's Algorithm
- custom stack
thr_min_stack Syntax
thr_min_stack Syntax
Building Your Own Stack
D
- daemon threads
thr_create Syntax
- data
- lock
Invariants and Locks
Reentrant Function
- races
Detecting Data Races and Deadlocks Using Thread Analyzer
Common Oversights in Multithreaded Programs
Thread Safety
- shared
Producer and Consumer Problem: Shared Memory Multiprocessors
User-Level Threads State
- thread-specific
Creating a Key for Thread-Specific Data
- dbx debugger
Using dbx
Getting the Minimal Stack Size
- deadlock
- defined
Avoiding Deadlock
- detecting
Detecting Data Races and Deadlocks Using Thread Analyzer
- recursive
Avoiding Deadlock
- scheduling
Deadlocks Related to Scheduling
- debugging
Debugging a Multithreaded Program- asynchronous signals
Common Oversights in Multithreaded Programs
- dbx
Using dbx
Getting the Minimal Stack Size
- deadlocks
Common Oversights in Multithreaded Programs
- dtrace
Tracing and Debugging with DTrace
- hidden gap in synchronization
Common Oversights in Multithreaded Programs
- inadequate stack size
Common Oversights in Multithreaded Programs
- large automatic arrays
Common Oversights in Multithreaded Programs
- long-jumping without releasing mutex lock
Common Oversights in Multithreaded Programs
- mdb
Using mdb
- no synchronization of global memory
Common Oversights in Multithreaded Programs
- passing pointer to caller's stack
Common Oversights in Multithreaded Programs
- recursive deadlock
Common Oversights in Multithreaded Programs
- reevaluate conditions after return from condition wait
Common Oversights in Multithreaded Programs
- deleting signals from mask
pthread_sigmask Syntax
- destroying an existing thread-specific data key
Deleting the Thread-Specific Data Key
- detached threads
thr_create Syntax
pthread_attr_setdetachstate Syntax
- Dijkstra, E. W.
Synchronization With Semaphores
- dispatch priority
- calculation
Timeshare Scheduling
- ranges
LWPs and Scheduling Classes
- DTrace
Tracing and Debugging with DTrace
E
- errno
Global Variables and errno
Thread-Specific Data – Global But Private
- global variables
Rethinking Global Variables
- event notification
Routines for Semaphores
- examining the signal mask
Access the Signal Mask of the Calling Thread
Accessing the Signal Mask of the Calling Thread
- example
- thread pool
Extended Example: A Thread Pool
Implementation
- exec() function
Process Creation: exec and exit Issues
Virtual Forks – vfork
Fork-One Model
- exit() function
Process Creation: exec and exit Issues
- exit function
thr_create Syntax
F
- fair share scheduler (FSS) scheduling class
Fair Share Scheduling
- finding thread priority
Get the Thread Priority
- fine-grained locking
Data Locking
- fixed priority scheduling class (FX)
Fixed Priority Scheduling
- flags to thr_create function
thr_create Syntax
- flockfile() function
Alternatives to getc and putc
- fork() function
Fork-All Model
- fork1() function
Fork-All Model
Virtual Forks – vfork
- funlockfile() function
Alternatives to getc and putc
G
- getc() function
Alternatives to getc and putc
- getc() thread-safe version
Alternatives to getc and putc
- getc_unlocked() function
Alternatives to getc and putc
- gethostbyname() function
Providing for Static Local Variables
- gethostbyname_r() function
The gethostbyname Problem
- getrusage() function
Resource Limits
- getting thread-specific key binding
Getting Thread-Specific Data
- global
- data
Data Locking
- side effects
Some Basic Guidelines for Threaded Code
- state
Reentrant Function
- variables
Rethinking Global Variables
Rethinking Global Variables
Global and Private Thread-Specific Data Example
I
- I/O
- asynchronous
Asynchronous I/O
- asynchronous and synchronous
I/O as a Remote Procedure Call
- nonsequential
Shared I/O and New I/O System Calls
- standard
Alternatives to getc and putc
- synchronous
I/O as a Remote Procedure Call
- inheriting priority
thr_create Syntax
- initializing the mutex
Initializing a Mutex
- interrupt
Extending Traditional Signals
- invariants
Invariants and Locks
The Producer and Consumer Problem: the Producer
J
- joining threads
Wait for Thread Termination
pthread_attr_setdetachstate Syntax
Finishing Up a Thread
Waiting for Thread Termination
K
- keys
- binding value to key
Setting the Thread-Specific Data Value
- storing value of
Getting the Thread-Specific Data Value
- kill() function
Sending a Signal to a Specific Thread
Extending Traditional Signals
L
- libc library
Some MT-Safe Libraries
- libC library
Some MT-Safe Libraries
- libCrun library
Some MT-Safe Libraries
- libCstd library
Some MT-Safe Libraries
- libiostream library
Some MT-Safe Libraries
- libm library
Some MT-Safe Libraries
- libmalloc library
Some MT-Safe Libraries
- libmapmalloc library
Some MT-Safe Libraries
- libnsl library
Some MT-Safe Libraries
- libpthread library
Multithreading Programming in Oracle Solaris
- libraries
- C routines
Rethinking Global Variables
- MT-Safe
MT Safety Levels for Libraries
- libresolv library
Some MT-Safe Libraries
- libsocket library
Some MT-Safe Libraries
- libthread library
Multithreading Programming in Oracle Solaris
- libX11 library
Some MT-Safe Libraries
- lightweight processes
- debugging
Using mdb
- defined
Multithreading Terms
- scheduling classes
LWPs and Scheduling Classes
- limits, resources
Resource Limits
- local variable
- pointers and
The gethostbyname Problem
- lock hierarchy
Avoiding Deadlock
- locking
Code Locking- coarse grained
Locking Guidelines
Data Locking
- code
Code Locking
- conditional
Deadlock Scenarios
- data
Data Locking
- fine-grained
Locking Guidelines
Data Locking
- guidelines
Locking Guidelines
- invariants
Invariants and Locks
- locks
- mutual exclusion
Circular-Linked List Structure
Programming with Synchronization Objects
- read-write
rwlock_destroy Syntax
- readers/writer
Programming with Synchronization Objects
- longjmp() function
Completion Semantics
Nonlocal Goto: setjmp and longjmp
- lost wake-up
Lost Wake-Up Problem
- lseek() function
Shared I/O and New I/O System Calls
- LWP defined
Multithreading Terms
M
- malloc() function
Simple Threads Example
- MAP_NORESERVE parameter
Allocating Stack Space for Threads
- MAP_SHARED flag
Fork-All Model
- mdb command
Using mdb
- memory
- consistency
Working With Multiprocessors
- ordering, relaxed
Producer and Consumer Problem: Shared Memory Multiprocessors
- strongly ordered
Producer and Consumer Problem: Shared Memory Multiprocessors
- mmap() function
Fork-All Model
Allocating Stack Space for Threads
- monitor code
Avoiding Deadlock
Code Locking
- mprotect function
thr_min_stack Syntax
- MT-Safe libraries
- alternative mmap-based memory allocation library
Some MT-Safe Libraries
- C ++ runtime shared objects
- for C++ 4.0 compiler
Some MT-Safe Libraries
- C++ runtime shared objects
- for C++ 5.0 compiler
Some MT-Safe Libraries
- C++ standard library
- for Oracle C++ 5.x compilers
Some MT-Safe Libraries
- classic iostreams
- for C++
Some MT-Safe Libraries
- math library
Some MT-Safe Libraries
- network interfaces of the form getXXbyYY_r
Some MT-Safe Libraries
- socket library for making network connections
Some MT-Safe Libraries
- space-efficient memory allocation
Some MT-Safe Libraries
- thread-safe form of unsafe interfaces
Some MT-Safe Libraries
- thread-specific errno support
Some MT-Safe Libraries
- X11 Windows routines
Some MT-Safe Libraries
- multiple-readers, single-writer locks
rwlock_destroy Syntax
- multiprocessors
Working With Multiprocessors
- multithreading defined
Multithreading Terms
- mutex
- defined
Multithreading Terms
- mutual exclusion locks
Testing the Invariant With assert(3C)
- scope
Setting the Scope of a Mutex
- mutex type
- PTHREAD_MUTEX_ERRORCHECK
pthread_mutex_lock Syntax
- PTHREAD_MUTEX_NORMAL
pthread_mutex_lock Syntax
- PTHREAD_MUTEX_RECUSIVE
pthread_mutex_lock Syntax
- mutex_destroy() function
Destroy a Mutex
- mutex_init() function
Example of Producer and Consumer Problem
Initialize a Mutex
- USYNC_THREAD
Synchronizing Across Process Boundaries
- mutex_lock() function
Acquiring a Mutex
- mutex_trylock() function
Trying to Acquire a Mutex
- mutex_unlock() function
Releasing a Mutex
- mutual exclusion locks
Circular-Linked List Structure
Programming with Synchronization Objects
- attributes
pthread_mutexattr_init Syntax
- deadlock
Examples of Using Lock Hierarchies
- default attributes
Mutual Exclusion Lock Attributes
- destroying mutex
Destroying a Mutex Attribute Object
- destroying mutex state
Destroying a Mutex
- getting mutex robust attribute
Getting the Mutex's Robust Attribute
- getting mutex scope
Getting the Scope of a Mutex
- getting priority ceiling of mutex
Getting the Mutex's Priority Ceiling
- getting priority ceiling of mutex attribute
Getting the Mutex Attribute's Priority Ceiling
- getting protocol of mutex attribute
Getting the Mutex Attribute's Protocol
- initializing
Initializing a Mutex
- locking
Locking a Mutex
- locking before specified time
Locking a Mutex Before a Specified Absolute Time
- locking within time interval
Locking a Mutex Within a Specified Time Interval
- making consistent
Making a Mutex Consistent
- nonblock locking
Locking a Mutex Without Blocking
- setting mutex robust attribute
Setting the Mutex's Robust Attribute
- setting priority ceiling of mutex
Setting the Mutex's Priority Ceiling
- setting priority ceiling of mutex attribute
Setting the Mutex Attribute's Priority Ceiling
- setting protocol of mutex attribute
Setting the Mutex Attribute's Protocol
- setting type attribute
Setting the Mutex Type Attribute
- unlocking
Unlocking a Mutex
N
- NDEBUG defined
The Producer and Consumer Problem: the Producer
- netdir
Some MT-Safe Libraries
- netselect
Some MT-Safe Libraries
- nice value and class priority
Timeshare Scheduling
- nonsequential I/O
Shared I/O and New I/O System Calls
- null threads
thr_min_stack Syntax
thr_min_stack Syntax
Building Your Own Stack
P
- parallel algorithms
Multithreaded Cooperation Through
Barrier Synchronization
- PC program counter
User-Level Threads State
- PC_GETCID parameter
LWPs and Scheduling Classes
- PC_GETCLINFO parameter
LWPs and Scheduling Classes
- PC_GETPARMS parameter
LWPs and Scheduling Classes
- PC_SETPARMS parameter
LWPs and Scheduling Classes
- Performance Analyzer
Profiling with Performance Analyzer
- Peterson's Algorithm
Peterson's Algorithm
- PL/1 programming language
Continuation Semantics
- portability
Programming with Synchronization Objects
- pread() function
Shared I/O and New I/O System Calls
- printf() function
- intertwined output
Signal Handlers and Async-Signal Safety
- problem
Synchronizing Threads
- priocntl() function
- PC_GETCID
LWPs and Scheduling Classes
- PC_GETCLINFO
LWPs and Scheduling Classes
- PC_GETPARMS
LWPs and Scheduling Classes
- PC_SETPARMS
LWPs and Scheduling Classes
- setting class priority
Timeshare Scheduling
- setting scheduling class
LWPs and Scheduling Classes
- priority
User-Level Threads State- and scheduling
Realtime Scheduling
- inheritance
Get the Thread Priority
thr_create Syntax
- range
thr_setprio Syntax
- scheduling and
thr_setprio Syntax
- setting for a thread
Set the Thread Priority
- priority inversion
pthread_mutexattr_setprotocol Syntax
- producer and consumer problem
Shared-Memory Multiprocessors
Producer and Consumer Problem Example
Producer and Consumer Problem Using Semaphores
- producer/consumer problem
Example of Producer and Consumer Problem
- profiling
Profiling with Performance Analyzer- multithreaded programs
Profiling a Multithreaded Program
- programmer-allocated stack
thr_min_stack Syntax
thr_min_stack Syntax
Building Your Own Stack
- prolagen
- decrease semaphore, P operation
Synchronization With Semaphores
- pthread_atfork() function
Solution: pthread_atfork
Forking Safely
- pthread_attr_destroy() function
Destroying Attributes
- pthread_attr_getdetachstate() function
Getting the Detach State
- pthread_attr_getguardsize() function
Getting the Stack Guard Size
- pthread_attr_getinheritsched() function
Getting the Inherited Scheduling Policy
- pthread_attr_getname_np() function
Getting the Thread Name Attribute
- pthread_attr_getschedparam() function
Getting the Scheduling Parameters
- pthread_attr_getschedpolicy() function
Getting the Scheduling Policy
- pthread_attr_getscope() function
Getting the Scope
- pthread_attr_getstack() function
Getting the Stack Address and Size
- pthread_attr_getstacksize() function
Getting the Stack Size
- pthread_attr_init() function
Initializing Attributes
- pthread_attr_setdetachstate() function
Setting Detach State
- pthread_attr_setguardsize() function
Setting the Stack Guard Size
- pthread_attr_setinheritsched() function
Setting the Inherited Scheduling Policy
- pthread_attr_setname_np() function
Setting the Thread Name Attribute
- pthread_attr_setschedparam() function
Setting the Scheduling Parameters
- pthread_attr_setschedpolicy() function
Setting the Scheduling Policy
- pthread_attr_setscope() function
Setting the Scope
- pthread_attr_setstack() function
Setting the Stack Address and Size
- pthread_attr_setstacksize() function
Setting the Stack Size
- pthread_barrier_destroy() function
Destroying a Synchronization Barrier
- pthread_barrier_init() function
Initializing a Synchronization Barrier
- pthread_barrier_wait() function
Waiting for Threads to Synchronize at a Barrier
- pthread_barrier_wait function
pthread_barrier_wait Syntax
- pthread_barrierattr_destroy() function
Destroying a Barrier Attributes Object
- pthread_barrierattr_getpshared() function
Getting a Barrier Process-Shared Attribute
- pthread_barrierattr_init() function
Initializing a Barrier Attributes Object
- pthread_barrierattr_setpshared() function
Setting a Barrier Process-Shared Attribute
- pthread_cancel() function
Cancelling a Thread
- pthread_cleanup_pop() function
Pulling a Handler Off the Stack
- pthread_cleanup_push() function
Pushing a Handler Onto the Stack
- pthread_cond_broadcast() function
Extending Traditional Signals
Lost Wake-Up Problem
Unblocking All Threads
pthread_cond_wait Syntax
- pthread_cond_destroy() function
pthread_cond_destroy Syntax
Destroying the Condition Variable State
- pthread_cond_init() function
Initializing a Condition Variable
- pthread_cond_reltimedwait_np() function
Blocking For a Specified Interval
- pthread_cond_signal() function
Extending Traditional Signals
Lost Wake-Up Problem
Unblocking One Thread
pthread_cond_wait Syntax
- pthread_cond_signal function
Producer and Consumer Problem With Condition Variables
- pthread_cond_timedwait() function
Blocking Until a Specified Time
- pthread_cond_wait() function
Extending Traditional Signals
Lost Wake-Up Problem
Using pthread_cond_wait and pthread_cond_signal
Blocking on a Condition Variable
- pthread_cond_wait function
Producer and Consumer Problem With Condition Variables
- pthread_condattr_destroy() function
Removing a Condition Variable Attribute
- pthread_condattr_getclock() function
Getting the Clock Selection Condition Variable
- pthread_condattr_getpshared() function
Getting the Scope of a Condition Variable
- pthread_condattr_init() function
Initializing a Condition Variable Attribute
- pthread_condattr_setclock() function
Setting the Clock Selection Condition Variable
- pthread_condattr_setpshared() function
Setting the Scope of a Condition Variable
- pthread_create() function
Creating a Default Thread
- pthread_detach() function
Detaching a Thread
- pthread_equal() function
Comparing Thread IDs
- pthread_exit() function
Terminating a Thread
- pthread_getconcurrency() function
Getting the Thread Concurrency Level
- pthread_getname_np() function
Getting the Thread Name
- pthread_getschedparam() function
Getting the Thread Policy and Scheduling Parameters
- pthread_getspecific() function
Getting Thread-Specific Data
- pthread_join() function
Tamed Asynchrony
About Stacks
Waiting for Thread Termination
- pthread_key_create() function
Creating a Key for Thread-Specific Data
- pthread_key_delete() function
Deleting the Thread-Specific Data Key
- pthread_kill() function
Sending a Signal to a Specific Thread
Sending a Signal to a Thread
- pthread_mutex_consistent() function
Making a Mutex Consistent
- pthread_mutex_destroy function
pthread_mutex_destroy Return Values
pthread_mutex_destroy Syntax
- pthread_mutex_getprioceiling() function
Getting the Mutex's Priority Ceiling
- pthread_mutex_lock() function
Locking a Mutex
- pthread_mutex_lock function
Circular-Linked List Structure
Singly-Linked List Structure
Code Examples of Mutex Locking
- pthread_mutex_setprioceiling() function
Setting the Mutex's Priority Ceiling
- pthread_mutex_timedlock function
pthread_mutex_reltimedlock_np Return
Values
pthread_mutex_reltimedlock_np Syntax
pthread_mutex_timedlock Return Values
pthread_mutex_timedlock Syntax
- pthread_mutex_trylock() function
Avoiding Deadlock
Locking a Mutex Without Blocking
- pthread_mutex_trylock function
Conditional Locking
- pthread_mutex_unlock() function
Unlocking a Mutex
- pthread_mutex_unlock function
Circular-Linked List Structure
Singly-Linked List Structure
Code Examples of Mutex Locking
- pthread_mutexattr_destroy() function
Destroying a Mutex Attribute Object
- pthread_mutexattr_getprioceiling() function
Getting the Mutex Attribute's Priority Ceiling
- pthread_mutexattr_getprotocol() function
Getting the Mutex Attribute's Protocol
- pthread_mutexattr_getpshared() function
Getting the Scope of a Mutex
- pthread_mutexattr_getrobust() function
Getting the Mutex's Robust Attribute
- pthread_mutexattr_gettype() function
Getting the Mutex Type Attribute
- pthread_mutexattr_init() function
pthread_mutexattr_init Return Values
pthread_mutexattr_init Syntax
- pthread_mutexattr_init() function
Initializing a Mutex
- pthread_mutexattr_setprioceiling() function
Setting the Mutex Attribute's Priority Ceiling
- pthread_mutexattr_setprotocol() function
Setting the Mutex Attribute's Protocol
- pthread_mutexattr_setpshared() function
Setting the Scope of a Mutex
- pthread_mutexattr_setrobust() function
Setting the Mutex's Robust Attribute
- pthread_mutexattr_settype() function
Setting the Mutex Type Attribute
- pthread_once() function
Calling an Initialization Routine for a Thread
- PTHREAD_PRIO_INHERIT value
pthread_mutexattr_setprotocol Syntax
- PTHREAD_PRIO_NONE value
pthread_mutexattr_setprotocol Syntax
- PTHREAD_PRIO_PROTECT value
pthread_mutexattr_setprotocol Syntax
- pthread_rwlock_destroy() function
Destroying a Read-Write Lock
- pthread_rwlock_init() function
Initializing a Read-Write Lock
- pthread_rwlock_rdlock() function
Acquiring the Read Lock on Read-Write Lock
- pthread_rwlock_timedrdlock() function
Acquiring a Read Lock on a Read-Write Lock Before
a Specified Absolute Time
- pthread_rwlock_timedwrlock() function
Acquiring a Write Lock on a Read-Write Lock Before
a Specified Absolute Time
- pthread_rwlock_tryrdlock() function
Acquiring a Non-Blocking Read Lock on a Read-Write Lock
- pthread_rwlock_tryrdlock function
pthread_rwlock_tryrdlock Syntax
- pthread_rwlock_trywrlock() function
Acquiring a Non-blocking Write Lock on a Read-Write
Lock
- pthread_rwlock_trywrlock function
pthread_rwlock_trywrlock Syntax
- pthread_rwlock_unlock() function
Unlocking a Read-Write Lock
- pthread_rwlock_wrlock() function
Acquiring the Write Lock on a Read-Write Lock
- pthread_rwlockattr_destroy() function
Destroying a Read-Write Lock Attribute
- pthread_rwlockattr_getpshared() function
Getting a Read-Write Lock Attribute
- pthread_rwlockattr_init() function
Initializing a Read-Write Lock Attribute
- pthread_rwlockattr_setpshared() function
Setting a Read-Write Lock Attribute
- PTHREAD_SCOPE_PROCESS constant
Setting the Scope
Thread Scheduling
- PTHREAD_SCOPE_SYSTEM constant
Setting the Scope
Thread Scheduling
- pthread_self() function
Getting the Thread Identifier
- pthread_setcancelstate() function
Enabling or Disabling Cancellation
- pthread_setconcurrency() function
Setting the Thread Concurrency Level
- pthread_setname_np() function
Setting the Thread Name
- pthread_setschedparam() function
Setting the Thread Policy and Scheduling Parameters
- pthread_setschedprio() function
Setting the Thread Priority
- pthread_setspecific() function
Setting Thread-Specific Data
- pthread_sigmask() function
Setting the Thread's Signal Mask
Accessing the Signal Mask of the Calling Thread
- pthread_spin_destroy() function
Destroying a Spin Lock
- pthread_spin_init() function
Initializing a Spin Lock
- pthread_spin_lock() function
Acquiring a Spin Lock
- pthread_spin_trylock() function
Acquiring a Non-Blocking Spin Lock
- pthread_spin_unlock() function
Unlocking a Spin Lock
- PTHREAD_STACK_MIN macro
Building Your Own Stack
- pthread_testcancel() function
pthread_testcancel Syntax
Setting Cancellation Type
- putc() thread-safe version
Alternatives to getc and putc
- putc_unlocked() function
Alternatives to getc and putc
- pwrite() function
Shared I/O and New I/O System Calls
R
- read() function
Shared I/O and New I/O System Calls
- read-write locks
rwlock_destroy Syntax- acquiring read lock
Acquiring the Read Lock on Read-Write Lock
- acquiring write lock
pthread_rwlock_wrlock Syntax
- attributes
Read-Write Lock Attributes
- destroying
Destroying a Read-Write Lock
- destroying lock attribute
Destroying a Read-Write Lock Attribute
- getting lock attribute
Getting a Read-Write Lock Attribute
- initializing lock
Initializing a Read-Write Lock
pthread_rwlockattr_init Syntax
- locking read lock
Acquiring a Non-Blocking Read Lock on a Read-Write Lock
- locking write lock
pthread_rwlock_trywrlock Syntax
- releasing read lock
Unlocking a Read-Write Lock
- setting lock attribute
Setting a Read-Write Lock Attribute
- readers/writer locks
Programming with Synchronization Objects
- realtime
- scheduling
Realtime Scheduling
- red zone
thr_min_stack Syntax
Allocating Stack Space for Threads
- reentrant
Reentrant Function- described
Reentrant Function
- functions
Reentrant Functions for Unsafe Interfaces
Interface Safety Levels
- strategies for making
Reentrant Function
- register state
User-Level Threads State
- relaxed memory ordering
Producer and Consumer Problem: Shared Memory Multiprocessors
- remote procedure call RPC
Combining Threads and RPC
- replacing signal mask
pthread_sigmask Syntax
- resuming execution
Continuing a Suspended Thread
- RPC
Creating and Using Threads
Some MT-Safe Libraries
Combining Threads and RPC
- RT, See
realtime
- rw_rdlock() function
Acquiring a Read Lock
- rw_tryrdlock() function
Trying to Acquire a Read Lock
- rw_trywrlock() function
Trying to Acquire a Write Lock
- rw_unlock() function
Unlock a Read-Write Lock
- rw_wrlock() function
Acquiring a Write Lock
- rwlock_destroy() function
Destroying the Read-Write Lock State
- rwlock_init() function
Initialize a Read-Write Lock- USYNC_THREAD
Synchronizing Across Process Boundaries
S
- SA_RESTART
Interrupted Waits on Condition Variables
- safety, threads interfaces
Unsafe Libraries
Safe and Unsafe Interfaces
- sched_yield() function
Deadlocks Related to Scheduling
Yielding Thread Execution
- scheduling
- classes
Thread Scheduling
- policies
Thread Scheduling
- scopes
Thread Scheduling
- system class
LWPs and Scheduling Classes
- scheduling class
- fair share scheduler (FSS)
Fair Share Scheduling
- fixed priority scheduler (FX)
Fixed Priority Scheduling
- priority
LWPs and Scheduling Classes
- realtime
Realtime Scheduling
- timeshare
Timeshare Scheduling
- scope state
Thread Scheduling
- sem_destroy() function
Destroying the Semaphore State
- sem_init() function
Producer and Consumer Problem Using Semaphores
Initializing a Semaphore
- sem_post() function
Incrementing a Semaphore
Synchronization With Semaphores
- sem_trywait() function
Decrementing a Semaphore Count
Synchronization With Semaphores
- sem_wait() function
Blocking on a Semaphore Count
Synchronization With Semaphores
- sema_destroy() function
Destroy the Semaphore State
- sema_init() function
Initialize a Semaphore- USYNC_THREAD
Synchronizing Across Process Boundaries
- sema_post() function
Async-Signal-Safe Functions in Oracle Solaris Threads
Increment a Semaphore
- sema_trywait() function
Decrement a Semaphore Count
- sema_wait() function
Block on a Semaphore Count
- semaphores
Comparing Primitives
Synchronization With Semaphores
Programming with Synchronization Objects
- binary
Synchronization With Semaphores
- blocking calling thread
Blocking on a Semaphore Count
- counting
Synchronization With Semaphores
- counting, defined
Multithreading Terms
- decrement semaphore value
Synchronization With Semaphores
- decrementing count
Decrementing a Semaphore Count
- destroying state
Destroying the Semaphore State
- increment semaphore value
Synchronization With Semaphores
- incrementing
Incrementing a Semaphore
- initializing
Initializing a Semaphore
- interprocess
Initializing Semaphores With Interprocess Scope
- intraprocess
Initializing Semaphores With Intraprocess Scope
- named
Named and Unnamed Semaphores
- unnamed
Named and Unnamed Semaphores
- sending signal to thread
Sending a Signal to a Thread
- sequential algorithms
Parallelizing a Loop on a Shared-Memory Parallel Computer
- setjmp() function
Completion Semantics
Completion Semantics
Nonlocal Goto: setjmp and longjmp
- setting thread-specific key binding
Setting Thread-Specific Data
- shared data
Data Locking
User-Level Threads State
- shared-memory multiprocessor
Producer and Consumer Problem: Shared Memory Multiprocessors
- SIG_DFL flag
Extending Traditional Signals
- SIG_IGN flag
Extending Traditional Signals
- SIG_SETMASK signal
pthread_sigmask Syntax
- sigaction() function
Extending Traditional Signals
Extending Traditional Signals
- SIGFPE signal
Completion Semantics
Synchronous Signals
- SIGILL signal
Synchronous Signals
- SIGINT signal
Asynchronous Signals and sigwait(2)
Asynchronous Signals
- SIGIO signal
Asynchronous Signals
- siglongjmp() function
Completion Semantics
- signal
- handler
Extending Traditional Signals
- signal handler
Thread-Directed Signals
- signal() function
Extending Traditional Signals
- signal.h file
Send a Signal to a Thread
- signals
- access mask
Access the Signal Mask of the Calling Thread
- adding to mask
pthread_sigmask Syntax
- asynchronous
Thread-Directed Signals
Asynchronous Signals
Extending Traditional Signals
- deleting from mask
pthread_sigmask Syntax
- inheritance
thr_create Syntax
- masks
User-Level Threads State
- pending
thr_create Syntax
Continuing a Suspended Thread
- replacing current mask
pthread_sigmask Syntax
- sending to a thread
Sending a Signal to a Specific Thread
- sending to thread
Send a Signal to a Thread
Sending a Signal to a Thread
- SIG_BLOCK
pthread_sigmask Syntax
- SIG_SETMASK
pthread_sigmask Syntax
- SIG_UNBLOCK
pthread_sigmask Syntax
- SIGSEGV
About Stacks
- synchronous
Synchronous Signals
- unmasked and caught
Interrupted Waits on Condition Variables
- sigprocmask() function
Setting the Thread's Signal Mask
- sigqueue() function
Extending Traditional Signals
- SIGSEGV signal
Synchronous Signals
About Stacks
- sigsend() function
Extending Traditional Signals
- sigsetjmp() function
Completion Semantics
- sigtimedwait() function
Waiting for Specified Signal Within a Given Time
- sigwait() function
Completion Semantics
Thread-Directed Signals
Waiting for a Specified Signal
- single-threaded
- assumptions
Rethinking Global Variables
- code
Mutual Exclusion Lock Attributes
- defined
Multithreading Terms
- processes
Process Creation: exec and exit Issues
- singly-linked list
- example
Singly-Linked List Structure
- singly-linked list with nested locking
- example
Singly-Linked List Structure
- size of stack
Getting the Minimal Stack Size
thr_create Syntax
pthread_attr_setstacksize Syntax
Building Your Own Stack
- spin locks
- defined
Using Spin Locks
- spurious wakeup
Interrupted Waits on Condition Variables
- stack
Creating and Using Threads- address
thr_create Syntax
pthread_attr_setstack Syntax
- boundaries
About Stacks
- creation
thr_create Syntax
pthread_attr_setstack Syntax
- custom
thr_min_stack Syntax
- deallocation
thr_min_stack Syntax
- minimum size
Building Your Own Stack
- overflows
Allocating Stack Space for Threads
- pointer
User-Level Threads State
- programmer-allocated
thr_min_stack Syntax
thr_min_stack Syntax
Building Your Own Stack
- red zone
thr_min_stack Syntax
Allocating Stack Space for Threads
- returning a pointer to
Interface Safety Levels
- size
thr_create Syntax
pthread_attr_setstacksize Syntax
Building Your Own Stack
- stack size
- finding minimum
Getting the Minimal Stack Size
- minimum
thr_min_stack Syntax
- stack_base
thr_create Syntax
pthread_attr_setstack Syntax
- stack_size
thr_create Syntax
pthread_attr_setstacksize Syntax
- standard I/O
Alternatives to getc and putc
- standards
- UNIX
Multithreading Programming in Oracle Solaris
- start_routine() function
thr_create Syntax
- static storage
Rethinking Global Variables
- store buffer
Mutual Exclusion for Two Threads
- storing thread key value
Getting the Thread-Specific Data Value
- streaming a tape drive
Asynchronous I/O
- strongly ordered memory
Producer and Consumer Problem: Shared Memory Multiprocessors
- suspending a new thread
thr_create Syntax
- swap space
Allocating Stack Space for Threads
- synchronization objects
- condition variables
The Producer and Consumer Problem: the Producer
Condition Variable Attributes
Programming with Synchronization Objects
- mutex locks
Circular-Linked List Structure
Programming with Synchronization Objects
- read-write locks
rwlock_destroy Syntax
- semaphores
Example of Producer and Consumer Problem
Similar Synchronization Functions: Semaphores
Synchronization With Semaphores
Programming with Synchronization Objects
- synchronous I/O
- asynchronous and
I/O as a Remote Procedure Call
- synchronous signals
Synchronous Signals
- system calls
- handling errors
Rethinking Global Variables
- system scheduling class
LWPs and Scheduling Classes
T
- tape drive, streaming
Asynchronous I/O
- THR_BOUND value
thr_create Syntax
- thr_continue() function
Continuing a Suspended Thread
- thr_continue function
thr_create Syntax
- thr_create() function
Creating a Thread
- thr_create function
thr_min_stack Syntax
- THR_DAEMON value
thr_create Syntax
- THR_DETACHED value
thr_create Syntax
- thr_exit() function
Terminate a Thread
- thr_exit function
thr_create Syntax
- thr_getprio() function
Get the Thread Priority
- thr_getspecific() function
Getting the Thread-Specific Data Value
- thr_join() function
Wait for Thread Termination
- thr_keycreate() function
Creating a Thread-Specific Data Key
- thr_kill() function
Async-Signal-Safe Functions in Oracle Solaris Threads
Send a Signal to a Thread
- thr_min_stack() function
Getting the Minimal Stack Size
- thr_min_stack function
thr_create Syntax
- thr_self() function
Acquiring the Thread Identifier
- thr_setprio() function
Set the Thread Priority
- thr_setspecific() function
Setting the Thread-Specific Data Value
- thr_sigsetmask() function
Async-Signal-Safe Functions in Oracle Solaris Threads
Access the Signal Mask of the Calling Thread
- thr_suspend() function
Suspending Thread Execution
- thr_yield() function
Yield Thread Execution
- Thread Analyzer
Detecting Data Races and Deadlocks Using Thread Analyzer
- thread identifier
pthread_self Syntax
- thread lifecycle
Lifecycle of a Thread
- thread local storage
Creating a Key for Thread-Specific Data
- thread pool
- defined
What is a Thread Pool?
- thread synchronization
- condition variables
Thread Synchronization
- mutex locks
Thread Synchronization
- mutual exclusion locks
Mutual Exclusion Lock Attributes
- read-write locks
Read-Write Lock Attributes
- read/write locks
Thread Synchronization
- semaphores
Synchronization With Semaphores
Thread Synchronization
- thread-directed signal
Thread-Directed Signals
- thread-private storage
User-Level Threads State
- thread-specific data
Creating a Key for Thread-Specific Data- example
Global and Private Thread-Specific Data Example
- getting
Getting the Thread-Specific Data Value
- global into private
Thread-Specific Data – Global But Private
- new storage class
Global Variables and errno
- setting
Setting the Thread-Specific Data Value
- thread-specific keys
- creating
Creating a Thread-Specific Data Key
Creating a Key for Thread-Specific Data
- threads
- acquiring identifiers
Acquiring the Thread Identifier
- cancelling
Cancelling a Thread
Cancel a Thread
Thread Cancellation
- creating
Creating and Using Threads
thr_create Return Values
Creating a Thread
- daemon
thr_create Syntax
- detached
thr_create Syntax
pthread_attr_setdetachstate Syntax
- identifiers
thr_create Syntax
- joining
Wait for Thread Termination
- keys
Setting the Thread-Specific Data Value
- null
thr_min_stack Syntax
thr_min_stack Syntax
Building Your Own Stack
- priority
thr_create Syntax
- safety
Unsafe Libraries
Thread Safety
- sending signal to
Send a Signal to a Thread
- signals
Interrupted Waits on Condition Variables
- stack
Interface Safety Levels
- suspended
Continuing a Suspended Thread
- suspending
thr_create Syntax
- synchronization models
Thread Synchronization
- synchronizing
Comparing Primitives
Programming with Synchronization Objects
- terminating
Terminate a Thread
Terminating a Thread
- thread-specific data
Global Variables and errno
- user-level
User-Level Threads
Multithreading Terms
- yielding execution
Yield Thread Execution
- threads defined
Multithreading Terms
- time-out
- example
pthread_cond_timedwait Return Values
- timer
- per LWP
Using Timers
- timeshare scheduling class
Timeshare Scheduling
- TLI
Some MT-Safe Libraries
- tools
- dbx
Using dbx
Getting the Minimal Stack Size
- Dtrace
Tracing and Debugging with DTrace
- mdb
Using mdb
- Performance Analyzer
Profiling with Performance Analyzer
- Thread Analyzer
Detecting Data Races and Deadlocks Using Thread Analyzer
- total store order
Mutual Exclusion for Two Threads
- trap
- default action
Synchronous Signals
- handled by thread
Synchronous Signals
- TS See
timeshare scheduling class
U
- /usr/include/errno.h
Preparing for Compilation
- /usr/include/limits.h
Preparing for Compilation
- /usr/include/pthread.h
Preparing for Compilation
- /usr/include/signal.h
Preparing for Compilation
- /usr/include/thread.h
Preparing for Compilation
- /usr/include/unistd.h
Preparing for Compilation
- unbound threads
- caching
Creating and Using Threads
- defined
Multithreading Terms
- user-level threads
User-Level Threads
Multithreading Terms
- USYNC_PROCESS
- condition variable
cond_init Syntax
- mutex
mutex_init Syntax
- read-write lock
rwlock_init Syntax
- semaphore
sema_init Syntax
- USYNC_PROCESS value
Example of Producer and Consumer Problem
- USYNC_PROCESS_ROBUST
- mutex
mutex_init Syntax
- USYNC_THREAD
- condition variable
cond_init Syntax
- semaphore
sema_init Syntax
- USYNC_THREAD value
- mutex
mutex_init Syntax
- read-write lock
rwlock_init Syntax
V
- variables
- condition
Comparing Primitives
The Producer and Consumer Problem: the Producer
Condition Variable Attributes
Programming with Synchronization Objects
- global
Rethinking Global Variables
- primitive
Programming with Synchronization Objects
- verhogen
- increase semaphore, V operation
Synchronization With Semaphores
- vfork() function
Virtual Forks – vfork
W
- write() function
Shared I/O and New I/O System Calls
X
- XDR
Some MT-Safe Libraries