Threads cont. #
How TCBs are mapped to the processes address space.
User-level threads #
Multithreading models #
The bottleneck created by the many-to-one model can be alleviated in the one-to-one model.
The M:M model maintains slightly more user threads than kernel threads.
So why do the biggest OSes use the one-to-one model? More cores in CPUs, more CPUs in general.
Thread libraries #
Implicit threading #
Issues #
Single threaded
data:image/s3,"s3://crabby-images/6cced/6cced82766665782f71b1c0425edbd54e9707b50" alt="image_2021-09-28-14-28-33"
Multi-threaded has 2 possibilities
The child can either have 1 thread (the invoking thread), or all.
data:image/s3,"s3://crabby-images/c4d2c/c4d2c818869d3beb0bed84ea5c39f491e848761b" alt="image_2021-09-28-14-32-26"
Thread local storage is stuff like
- stack allocated variables
- parameters
- return values
- other things on stack