CSE 451: Operating Systems Autumn 2003 Lecture 5 Threads

Slides:



Advertisements
Similar presentations
Operating Systems ECE344 Lecture 4: Threads Ding Yuan.
Advertisements

Threads. Announcements Cooperating Processes Last time we discussed how processes can be independent or work cooperatively Cooperating processes can.
Processes CSCI 444/544 Operating Systems Fall 2008.
Chapter 4: Threads. 2 What’s in a process? A process consists of (at least): –an address space –the code for the running program –the data for the running.
Threads vs. Processes April 7, 2000 Instructor: Gary Kimura Slides courtesy of Hank Levy.
Threads 1 CS502 Spring 2006 Threads CS-502 Spring 2006.
Threads CSCI 444/544 Operating Systems Fall 2008.
Threads CS 416: Operating Systems Design, Spring 2001 Department of Computer Science Rutgers University
CS 3013 & CS 502 Summer 2006 Threads1 CS-3013 & CS-502 Summer 2006.
Chapter 51 Threads Chapter 5. 2 Process Characteristics  Concept of Process has two facets.  A Process is: A Unit of resource ownership:  a virtual.
CSE 451: Operating Systems Autumn 2013 Module 6 Review of Processes, Kernel Threads, User-Level Threads Ed Lazowska 570 Allen.
CS 153 Design of Operating Systems Spring 2015
Silberschatz, Galvin and Gagne ©2009Operating System Concepts – 8 th Edition Chapter 4: Threads.
Threads, Thread management & Resource Management.
Chapter 2 Processes and Threads Introduction 2.2 Processes A Process is the execution of a Program More specifically… – A process is a program.
IT 344: Operating Systems Winter 2010 Module 5 Process and Threads
CSE 451: Operating Systems Winter 2015 Module 5 1 / 2 User-Level Threads & Scheduler Activations Mark Zbikowski 476 Allen Center.
CSE 451: Operating Systems Winter 2014 Module 5 Threads Mark Zbikowski Allen Center 476 © 2013 Gribble, Lazowska, Levy, Zahorjan.
Lecture 5: Threads process as a unit of scheduling and a unit of resource allocation processes vs. threads what to program with threads why use threads.
Operating Systems CSE 411 CPU Management Sept Lecture 10 Instructor: Bhuvan Urgaonkar.
Department of Computer Science and Software Engineering
CSE 153 Design of Operating Systems Winter 2015 Lecture 4: Threads.
Threads, SMP, and Microkernels Chapter 4. Processes and Threads Operating systems use processes for two purposes - Resource allocation and resource ownership.
Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition, Chapter 4: Threads.
Processes and threads.
CS 6560: Operating Systems Design
CSE 120 Principles of Operating
CSE 451: Operating Systems Winter 2011 Threads
CS399 New Beginnings Jonathan Walpole.
Chapter 2 Processes and Threads Today 2.1 Processes 2.2 Threads
CSE 451: Operating Systems Spring 2013 Module 5 Threads
Chapter 4: Multithreaded Programming
Threads.
Chapter 4 Threads.
Operating Systems ECE344 Lecture 4: Threads Ding Yuan.
Threads & multithreading
Chapter 4: Threads.
IT 344: Operating Systems Module 5 Process and Threads
CSE 451: Operating Systems Winter 2010 Module 5 Threads
CSE 451: Operating Systems Winter 2007 Module 5 Threads
CSE 451: Operating Systems Autumn 2004 Module 5 Threads
CSE 451: Operating Systems Spring 2012 Module 6 Review of Processes, Kernel Threads, User-Level Threads Ed Lazowska 570 Allen.
CSE 451: Operating Systems Spring 2008 Module 5 Threads
CSE 153 Design of Operating Systems Winter 2018
Thread Implementation Issues
Lecture Topics: 11/1 General Operating System Concepts Processes
Threads Chapter 4.
CSE 451: Operating Systems Winter 2007 Module 5 Threads
Processes Hank Levy 1.
CSE 451: Operating Systems Winter 2003 Lecture 5 Threads
Threads Chapter 5 2/17/2019 B.Ramamurthy.
Threads Chapter 5 2/23/2019 B.Ramamurthy.
CSE 451: Operating Systems Winter 2009 Module 5 Threads
CSE 451: Operating Systems Spring 2005 Module 5 Threads
Still Chapter 2 (Based on Silberchatz’s text and Nachos Roadmap.)
October 9, 2002 Gary Kimura Lecture #5 October 9, 2002
CSE 451: Operating Systems Winter 2012 Threads
CSE 451: Operating Systems Autumn 2009 Module 5 Threads
CSE 451: Operating Systems Winter 2003 Lecture 4 Processes
Threads vs. Processes Hank Levy 1.
CS510 Operating System Foundations
CSE 451: Operating Systems Autumn 2004 Module 4 Processes
CSE 153 Design of Operating Systems Winter 2019
Processes Hank Levy 1.
CS703 – Advanced Operating Systems
CSE451 Introduction to Operating Systems Spring 2007
CSE 451: Operating Systems Winter 2006 Module 5 Threads
CSE 451: Operating Systems Winter 2001 Lecture 5 Threads
Threads.
Threads.
Presentation transcript:

CSE 451: Operating Systems Autumn 2003 Lecture 5 Threads Hank Levy levy@cs.washington.edu Allen Center 596 1

Processes A process includes many things: an address space (all the code and data pages) protection boundary OS resources (e.g., open files) and accounting info hardware execution state (PC, SP, regs) Creating a new process is costly, because of all of the data structures that must be allocated/initialized Linux: over 95 fields in task_struct on a 700 MHz pentium, fork+exit = 251 microseconds, fork+exec = 1024 microseconds Interprocess communication is costly, since it must usually go through the OS overhead of system calls 0.46 microseconds on 700 MHz pentium 1/3/2019 © 2003 Hank Levy

Parallel Programs Imagine a web server, which forks off copies of itself to handle multiple simultaneous tasks or, imagine we have any parallel program on a multiprocessor To execute these, we need to: create several processes that execute in parallel cause each to map to the same address space to share data see the shmget() system call for one way to do this (kind of) have the OS schedule them in parallel multiprogramming or true parallel processing on an SMP This is really inefficient space: PCB, page tables, etc. time: creating OS structures, fork and copy addr space, etc. 1/3/2019 © 2003 Hank Levy

Can we do better? What’s similar in these processes? What’s different? they all share the same code and data (address space) they all share the same privileges they all share the same resources (files, sockets, etc.) What’s different? each has its own hardware execution state PC, registers, stack pointer, and stack Key idea: separate the concept of a process (address space, etc.) from that of a minimal “thread of control” (execution state: PC, etc.) this execution state is usually called a thread, or sometimes, a lightweight process 1/3/2019 © 2003 Hank Levy

Threads and processes Most modern OS’s (Mach, Chorus, NT, modern Unix) therefore support two entities: the process, which defines the address space and general process attributes (such as open files, etc.) the thread, which defines a sequential execution stream within a process A thread is bound to a single process processes, however, can have multiple threads executing within them sharing data between threads is cheap: all see same address space Threads become the unit of scheduling processes are just containers in which threads execute 1/3/2019 © 2003 Hank Levy

Thread Design Space older UNIXes MS/DOS address space one thread/process one thread/process one process many processes thread Java Mach, NT, Chorus, Linux, … many threads/process many threads/process one process many processes 1/3/2019 © 2003 Hank Levy

(old) Process address space 0xFFFFFFFF stack (dynamic allocated mem) SP heap (dynamic allocated mem) address space static data (data segment) code (text segment) PC 0x00000000 1/3/2019 © 2003 Hank Levy

(new) Address space with threads thread 1 stack SP (T1) 0xFFFFFFFF thread 2 stack SP SP (T2) thread 3 stack SP (T3) address space heap (dynamic allocated mem) static data (data segment) 0x00000000 PC code (text segment) PC (T2) PC (T1) PC (T3) 1/3/2019 © 2003 Hank Levy

Process/Thread Separation Separating threads and processes makes it easier to support multi-threaded applications creating concurrency does not require creating new processes Concurrency (multithreading) is useful for: improving program structure (the Java argument) handling concurrent events (e.g., web servers) building parallel programs (e.g., raytracer) So, multithreading is useful even on a uniprocessor even though only one thread can run at a time 1/3/2019 © 2003 Hank Levy

Kernel thread and user-level threads Who is responsible for creating/managing threads? Two answers, in general: the OS (kernel threads) thread creation and management requires system calls the user-level process (user-level threads) a library linked into the program manages the threads Why is user-level thread management possible? threads share the same address space therefore the thread manager doesn’t need to manipulate address spaces threads only differ in hardware contexts (roughly) PC, SP, registers these can be manipulated by the user-level process itself! 1/3/2019 © 2003 Hank Levy

Kernel Threads OS now manages threads and processes all thread operations are implemented in the kernel OS schedules all of the threads in a system if one thread in a process blocks (e.g. on I/O), the OS knows about it, and can run other threads from that process possible to overlap I/O and computation inside a process Kernel threads are cheaper than processes less state to allocate and initialize But, they can still be too expensive thread operations are all system calls OS must perform all of the usual argument checks but want them to be as fast as a procedure call! must maintain kernel state for each thread can place limit on # of simultaneous threads, typically ~1000 1/3/2019 © 2003 Hank Levy

User-Level Threads To make threads cheap and fast, they need to be implemented at the user level managed entirely by user-level library, e.g. libpthreads.a User-level threads are small and fast each thread is represented simply by a PC, registers, a stack, and a small thread control block (TBC) creating a thread, switching between threads, and synchronizing threads are done via procedure calls no kernel involvement is necessary! user-level thread operations can be 10-100x faster than kernel threads as a result 1/3/2019 © 2003 Hank Levy

Performance example On a 700MHz Pentium running Linux 2.2.16: Processes fork/exit: 251 ms Kernel threads pthread_create()/pthread_join(): 94 ms User-level threads pthread_create()/pthread_join: 4.5 ms 1/3/2019 © 2003 Hank Levy

User-level Thread Limitations But, user-level threads aren’t perfect tradeoff, as with everything else User-level threads are invisible to the OS there is no integration with the OS As a result, the OS can make poor decisions scheduling a process with only idle threads blocking a process whose thread initiated I/O, even though the process has other threads that are ready to run unscheduling a process with a thread holding a lock Solving this requires coordination between the kernel and the user-level thread manager 1/3/2019 © 2003 Hank Levy

Coordinating K/L and U/L Threads Another possibility: use both K/L and U/L threads in a single system can associate a user-level thread with a kernel-level thread or, can multiplex user-level threads on top of kernel threads “scheduler activations” a research paper from UW with huge effect on industry each process can request one or more kernel threads process is given responsibility for mapping user-level threads onto kernel threads kernel promises to notify user-level before it suspends or destroys a kernel thread pop question: why would a process have more user-level threads than kernel threads? 1/3/2019 © 2003 Hank Levy

Thread Interface This is taken from the POSIX pthreads API: t = pthread_create(attributes, start_procedure) creates a new thread of control new thread begins executing at start_procedure pthread_cond_wait(condition_variable) the calling thread blocks, sometimes called thread_block() pthread_signal(condition_variable) starts the thread waiting on the condition variable pthread_exit() terminates the calling thread pthread_wait(t) waits for the named thread to terminate 1/3/2019 © 2003 Hank Levy

User-level thread implementation a thread scheduler determines when a thread runs it uses queues to keep track of what threads are doing just like the OS and processes but, implemented at user-level as a library run queue: threads currently running ready queue: threads ready to run wait queue: threads blocked for some reason maybe blocked on I/O, maybe blocked on a lock how can you prevent a thread from hogging the CPU? how did the OS handle this? 1/3/2019 © 2003 Hank Levy

Preemptive vs. non-preemptive Strategy 1: force everybody to cooperate a thread willingly gives up the CPU by calling yield() yield() calls into the scheduler, which context switches to another ready thread what happens if a thread never calls yield()? Stategy 2: use preemption scheduler requests that a timer interrupt be delivered by the OS periodically usually delivered as a UNIX signal (man signal) signals are just like software interrupts, but delivered to user-level by the OS instead of delivered to OS by hardware at each timer interrupt, scheduler gains control and context switches as appropriate 1/3/2019 © 2003 Hank Levy

Thread context switch Very simple for user-level threads: save context of currently running thread push machine state onto thread stack restore context of the next thread pop machine state from next thread’s stack return to caller as the new thread execution resumes at PC of next thread This is all done by assembly language it works at the level of the procedure calling convention thus, it cannot be implemented using procedure calls 1/3/2019 © 2003 Hank Levy