PLEY SCAN

# Synchronization

Today: Implementation issues

- A common variant for mutual exclusion
  - One writer at a time, if no readers
  - Many readers, if no writer
- How might we implement this?
  - ReaderAcquire(), ReaderRelease()
  - WriterAcquire(), WriterRelease()
  - Need a lock to keep track of shared state
  - Need condition variables for waiting if readers/ writers are in progress
  - Some state variables

```
Lock lock = FREE
CV okToRead = nil
CV okToWrite = nil
AW = 0 //active writers
AR = 0 // active readers
WW = 0 // waiting writers
WR = 0 // waiting readers
```

```
lock.Acquire();
                    lock.Acquire();
Lock lock = FREE
                                                 while (AW > 0 | | AR > 0) {
                    while (AW > 0 | | WW > 0) {
                                                   WW++; Write
                      WR++;
CV okToRead = nil
                                                   okToRead.wait(&lock);
                      okToRead.wait(&lock);
CV okToWrite = nil
                      WR--;
                                                   WW--;
AW = 0
                                                 AW++;
AR = 0
                    AR++;
                    lock.Release();
                                                 lock.Release();
WW = 0
WR = 0
                                                 Write data
                    Read data
                                                 lock.Acquire();
                    lock.Acquire();
                                                 AW--;
                    AR--;
                    if (AR == 0 \&\& WW > 0)
                                                 if (WW > 0)
                                                  okToWrite.Signal();
                     okToWrite.Signal();
                    lock.Release();
                                                 else if (WR > 0)
                                                  okToRead.Broadcast();
                                                 lock.Release();
```

- Can readers starve?
  - Yes: writers take priority
- Can writers starve?
  - Yes: a waiting writer may not be able to proceed, if another writer slips in between signal and wakeup

## Readers/Writers Lock, w/o Writer Starvation Take 1

```
Writer() {
 lock.Acquire();
 // check if another thread is already waiting
while ((AW + AR + WW) > 0) {
    WW++;
    okToWrite.Wait(&lock);
    WW--;
 AW++;
 lock.Release();
```

## Readers/Writers Lock w/o Writer Starvation Take 2

```
// check in
                              // check out
lock.Acquire();
                              lock.Acquire();
myPos = numWriters++;
                              AW--;
while ((AW + AR > 0))
                              nextToGo++;
      myPos > nextToGo) {
                              if (WW > 0) {
                                okToWrite.Signal(&lock);
   WW++;
   okToWrite.Wait(&lock);
                              } else if (WR > 0)
                                okToRead.Bcast(&lock);
   WW--;
                              lock.Release();
AW++;
lock.Release();
```

w/o Writer Starvation Take 3

```
// check in
                                  // check out
lock.Acquire();
                                  lock.Acquire();
myPos = numWriters++;
                                  AW--;
myCV = new CV;
                                  nextToGo++;
                                    if (WW > 0) {
writers.Append(myCV);
while ((AW + AR > 0))
                                       cv = writers.RemoveFront();
        myPos > nextToGo) {
                                       cv.Signal(&lock);
                                    } else if (WR > 0)
   WW++;
   myCV.Wait(&lock);
                                       okToRead.Broadcast(&lock);
                                   lock.Release();
   WW--;
AW++;
```

delete myCV;

lock.Release();

#### Mesa vs. Hoare semantics

- Mesa
  - Signal puts waiter on ready list
  - Signaller keeps lock and processor
- Hoare
  - Signal gives processor and lock to waiter
  - When waiter finishes, processor/lock goes back to signaller
- All systems you will use are Mesa

## FIFO Bounded Buffer (Hoare semantics)

```
get() {
                                 put(item) {
  lock.acquire();
                                   lock.acquire();
  if (front == tail) {
                                   if((tail - front) == MAX) {
    empty.wait(&lock);
                                     full.wait(&lock);
  item = buf[front % MAX];
                                   buf[last % MAX] = item;
  front++;
                                   last++;
  full.signal(&lock);
                                   empty.signal(&lock);
  lock.release();
                                  // CAREFUL: someone else ran
                                   lock.release();
  return item;
```

Initially: front = tail = 0; MAX is buffer capacity empty/full are condition variables

## FIFO Bounded Buffer (Mesa semantics)

- Create a condition variable for every waiter
- Queue condition variables (in FIFO order)
- Signal picks the front of the queue to wake up
- CAREFUL if spurious wakeups!

- Easily extends to case where queue is LIFO, priority, priority donation, ...
  - With Hoare semantics, not as easy

# FIFO Bounded Buffer (Mesa semantics, put() is similar)

```
delete cv;
get() {
  lock.acquire();
                                  item = buf[front % MAX];
  myPosition = numGets++;
                                  front++;
                                   if (next = nextPut.remove()) {
  cv = new CV;
  nextGet.append(cv);
                                     next->signal(&lock);
  while (front < myPosition
       | | front == tail) {
                                  lock.release();
    cv.wait(&lock);
                                   return item;
```

Initially: front = tail = numGets = 0; MAX is buffer capacity nextGet, nextPut are queues of Condition Variables

CACHE COMERENCE

## Implementing Synchronization

**Concurrent Applications** 

Semaphores

Locks

**Condition Variables** 

Interrupt Disable

Atomic Read/Modify/Write Instructions

**Multiple Processors** 

Hardware Interrupts

| LIES JUZIERICHOUS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |            | Ic. Xr.35  | Tead-only (X:1 | CPC |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|------------|----------------|-----|
| Sign to the Most of the state o | merory bus | Condition  | Abblications   |     |
| imotA slassio                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |            | No. Locks  | Write X - 2    |     |
| write-back                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |            | Semaphores | 1 real-only    |     |

Hardware interrupts

Multiple Processo

## Implementing Threads: Roadmap

- Kernel threads
  - Thread abstraction only available to kernel
  - To the kernel, a kernel thread and a single threaded user process look quite similar
- Multithreaded processes using kernel threads (Linux, MacOS, Windows)
  - Kernel thread operations available via syscall
- User-level threads (Windows)
  - Thread operations without system calls

#### Multithreaded OS Kernel



#### **Thread Context Switch**

- Voluntary
  - Thread\_yield
  - Thread\_join (if child is not done yet)
- Lock Acquire - lock is busy
  - Condition West

- Involuntary
  - Interrupt or exception
  - Some other thread is higher priority

#### Voluntary thread context switch

- Called by old thread
- Save registers on old stack
- Switch to new stack, new thread
- Restore registers from new stack
- Return to new thread

Exactly the same with kernel threads or user threads

#### x86 swtch

push %rbp

push %rbx

push %r11

push %r12

push %r13

push %r14

push %r15

pop %r15

pop %r14

pop %r13

pop %r12

pop %r11

pop %rbx

pop %rbp

mov %rsp, (%rdi)

mov %rsi, %rsp

ret

// save/restore callee save registers, not caller save

#### A Subtlety

forleret

- Thread\_create puts new thread on ready list
- Some thread calls switch, picks that thread to run next
  - Saves old thread state to stack
  - Restores new thread state from stack
- What does the new thread stack contain so this will work?
  - Set up thread's stack as if it had saved its state in switch
  - "returns" to PC saved at base of stack to run thread

#### Two Threads Call Yield

Thread 1's instructions

"return" from thread\_switch
into stub
call go
call thread\_yield
choose another thread
call thread\_switch

save thread 1 state to TCB

load thread 2 state

Thread 2's instructions

"return" from thread\_switch
into stub
call go
call thread\_yield
choose another thread
call thread\_switch
save thread 2 state to TCB
load thread 1 state

return from thread\_switch return from thread\_yield call thread\_yield choose another thread call thread switch **Processor's instructions** "return" from thread\_switch into stub call go call thread yield choose another thread call thread switch save thread 1 state to TCB load thread 2 state "return" from thread switch into stub call go call thread yield choose another thread call thread switch save thread 2 state to TCB load thread 1 state return from thread switch return from thread yield call thread yield choose another thread call thread switch





# Involuntary Thread/Process Switch (Simple, Slow Version)

- Timer or I/O interrupt
  - Tells OS some other thread/process should run
- End of interrupt handler calls switch, before resuming the trapframe
- When thread is switched back in, resumes the handler
- Handler restores the trapframe to resume the user process



# Involuntary Thread/Process Switch (Fast Version)

- Interrupt handler saves state of interrupted thread on trapframe
- At end of handler, switch to a new thread
- We don't need to come back to the interrupt handler!
- Instead: change switch so that it can restore directly from the trapframe
- On resume, pop trapframe to restore directly to the interrupted thread

De Pult Sched () E pncess COST VERSION thre. & STRETT CALL SUBSTREET S witch

#### Multithreaded User Processes (Take 1)

- User thread = kernel thread (Linux, MacOS)
  - System calls for thread fork, join, exit (and lock, unlock,...)
  - Kernel does context switch
  - Simple, but a lot of transitions between user and kernel mode

# Multithreaded User Processes (Take 1)



#### Multithreaded User Processes (Take 2)

- Green threads (early Java)
  - User-level library, within a single-threaded process
  - Library does thread context switch
  - Preemption via upcall/UNIX signal on timer interrupt
  - Use multiple processes for parallelism
    - Shared memory region mapped into each process

#### Multithreaded User Processes (Take 3)

- Scheduler activations (Windows 8)
  - Kernel allocates processors to user-level library
  - Thread library implements context switch
  - Thread library decides what thread to run next
- Upcall whenever kernel needs a user-level scheduling decision
  - Process assigned a new processor
  - Processor removed from process
  - System call blocks in kernel