













| <ul> <li>Suppose two CPU cores share a physical<br/>address space         <ul> <li>Write-through caches</li> </ul> </li> </ul> |                     |               |               |        |  |  |
|--------------------------------------------------------------------------------------------------------------------------------|---------------------|---------------|---------------|--------|--|--|
| Time<br>step                                                                                                                   | Event               | CPU A's cache | CPU B's cache | Memory |  |  |
| 0                                                                                                                              |                     |               |               | 0      |  |  |
| 1                                                                                                                              | CPU A reads X       | 0             |               | 0      |  |  |
| 2                                                                                                                              | CPU B reads X       | 0             | 0             | 0      |  |  |
| 3                                                                                                                              | CPU A writes 1 to X | 1             | 0             | 1      |  |  |
| 5                                                                                                                              | CFU A WIItes T to A | <b>I</b>      | 0             | I      |  |  |







| Invalida                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ating Snoo                                                                     | ping P                     | rotocol                   | S                     |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|----------------------------|---------------------------|-----------------------|
| <ul> <li>Cache gets</li> <li>when it is t</li> <li>Broadcas</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | s exclusive<br>to be writter<br>ts an invalida                                 | access                     | to a blo<br>age on th     | ock<br>ne bus         |
| - Subseque<br>• Owning                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | cache supplies                                                                 | updated                    | value                     |                       |
| Owning     CPU activity                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Cache supplies                                                                 | CPU A's<br>cache           | Value<br>CPU B's<br>cache | Memory                |
| Owning     CPU activity                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Bus activity                                                                   | CPU A's<br>cache           | CPU B's<br>cache          | Memory<br>0           |
| Owning     CPU activity     CPU A reads X                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Bus activity<br>Cache miss for X                                               | CPU A's<br>cache           | CPU B's<br>cache          | Memory<br>0<br>0      |
| Owning     CPU activity     CPU A reads X     CPU B reads X                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Cache supplies Bus activity Cache miss for X Cache miss for X                  | CPU A's<br>cache<br>0<br>0 | CPU B's<br>cache          | Memory<br>0<br>0      |
| Owning     Over the second secon | Cache supplies Bus activity Cache miss for X Cache miss for X Invalidate for X | CPU A's<br>cache<br>0<br>1 | CPU B's<br>cache          | Memory<br>0<br>0<br>0 |

## Writing Write-back policies for bandwidth Write-invalidate coherence policy First invalidate all other copies of data Then write it in cache line Anybody else can read it Permits one writer, multiple readers In reality: many coherence protocols Snooping doesn't scale Directory-based protocols Caches and memory record sharing status of blocks in a directory

















© Kavita Bala, Computer Science, Cornell University



## Example

```
main(int argc, char **argv)
{
    char *myName = argv[1];
    int cpid = fork();
    if (cpid == 0) {
        printf("The child of %s is %d\n", myName, getpid());
        exit(0);
    } else {
        printf("My child is %d\n", cpid);
        exit(0);
    }
}
What does this program print?
    @ Kavita Bala, Computer Science, Cornell University
```















## Threads

```
#include <pthread.h>
int hits = 0;
void *PrintHello(void *threadid) {
  int tid; tid = (int)threadid;
  printf("Hello World! It's me, thread #%d! hits %d\n",
  tid, ++hits);
 pthread_exit(NULL);
}
int main (int argc, char *argv[]) {
 pthread_t threads[5];
 int t;
 for(t=0; t<NUM_THREADS; t++){</pre>
    printf("In main: creating thread d\n", t);
    pthread_create(&threads[t],NULL,PrintHello,(void *)t);
   }
   pthread_exit(NULL);
}
                   © Kavita Bala, Computer Science, Cornell University
```





| Goals                                                                                                     |
|-----------------------------------------------------------------------------------------------------------|
| <ul> <li>Concurrency poses challenges for:</li> </ul>                                                     |
| Correctness                                                                                               |
| <ul> <li>Threads accessing shared memory should not<br/>interfere with each other</li> </ul>              |
| Liveness                                                                                                  |
| <ul> <li>Threads should not get stuck, should make forward<br/>progress</li> </ul>                        |
| Efficiency                                                                                                |
| <ul> <li>Program should make good use of available<br/>computing resources (e.g., processors).</li> </ul> |
| Fairness                                                                                                  |
| <ul> <li>Resources apportioned fairly between threads</li> </ul>                                          |
| © Kavita Bala, Computer Science, Cornell University                                                       |













