CS 15-213, Spring 2004

Exam 2

April 8, 2004

Instructions:

• Make sure that your exam is not missing any sheets, then write your full name and Andrew login ID on the front.

• Write your answers in the space provided below the problem. If you make a mess, clearly indicate your final answer.

• The exam has a maximum score of 79 points and a total of 17 pages.

• The problems are of varying difficulty. The point value of each problem is indicated. Pile up the easy points quickly and then come back to the harder problems.

• This exam is OPEN BOOK. You may use any books or notes you like. You may not use a calculator, laptop or other wireless device. Good luck!

<p>| | |</p>
<table>
<thead>
<tr>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>1 (16):</td>
<td></td>
</tr>
<tr>
<td>2 (10):</td>
<td></td>
</tr>
<tr>
<td>3 (8):</td>
<td></td>
</tr>
<tr>
<td>4 (12):</td>
<td></td>
</tr>
<tr>
<td>5 (9):</td>
<td></td>
</tr>
<tr>
<td>6 (10):</td>
<td></td>
</tr>
<tr>
<td>7 (14):</td>
<td></td>
</tr>
</tbody>
</table>

TOTAL (79):
Problem 1. (16 points):
The following problem concerns basic cache lookups.

- The memory is byte addressable.
- Memory accesses are to 1-byte words (not 4-byte words).
- Physical addresses are 13 bits wide.
- The cache is 4-way set associative, with a 4-byte block size and 32 total lines.

In the following tables, all numbers are given in hexadecimal. The Index column contains the set index for each set of 4 lines. The Tag columns contain the tag value for each line. The V column contains the valid bit for each line. The Bytes 0–3 columns contain the data for each line, numbered left-to-right starting with byte 0 on the left.

The contents of the cache are as follows:

<table>
<thead>
<tr>
<th>Index</th>
<th>Tag V</th>
<th>Bytes 0–3</th>
<th>Tag V</th>
<th>Bytes 0–3</th>
<th>Tag V</th>
<th>Bytes 0–3</th>
<th>Tag V</th>
<th>Bytes 0–3</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>84 1</td>
<td>ED 32 0A A2</td>
<td>9E 0</td>
<td>BF 80 1D FC</td>
<td>10 0</td>
<td>EF 09 B6 2A</td>
<td>E8 0</td>
<td>25 44 6F 1A</td>
</tr>
<tr>
<td>1</td>
<td>18 1</td>
<td>03 3E CD 38</td>
<td>E4 0</td>
<td>16 7B ED 5A</td>
<td>02 0</td>
<td>8E 4C DF 18</td>
<td>E4 1</td>
<td>FB B7 12 02</td>
</tr>
<tr>
<td>2</td>
<td>84 0</td>
<td>54 9E 1E FA</td>
<td>84 1</td>
<td>DC 81 B2 14</td>
<td>48 0</td>
<td>B6 1F 7B 44</td>
<td>89 1</td>
<td>10 F5 B8 2E</td>
</tr>
<tr>
<td>3</td>
<td>92 0</td>
<td>2F 7E 3D A8</td>
<td>9F 0</td>
<td>27 95 A4 74</td>
<td>57 1</td>
<td>07 11 FF D8</td>
<td>93 0</td>
<td>C7 B7 AF C2</td>
</tr>
<tr>
<td>4</td>
<td>84 1</td>
<td>32 21 1C 2C</td>
<td>FA 1</td>
<td>22 C2 DC 34</td>
<td>73 0</td>
<td>BA DD 37 D8</td>
<td>28 1</td>
<td>E7 A2 39 BA</td>
</tr>
<tr>
<td>5</td>
<td>A7 1</td>
<td>A9 76 2B EE</td>
<td>73 0</td>
<td>BC 91 D5 92</td>
<td>28 1</td>
<td>80 BA 9B F6</td>
<td>68 0</td>
<td>48 16 81 0A</td>
</tr>
<tr>
<td>6</td>
<td>8B 1</td>
<td>5D 4D F7 DA</td>
<td>29 1</td>
<td>69 C2 8C 74</td>
<td>B5 1</td>
<td>A8 CE 7F DA</td>
<td>BF 0</td>
<td>FA 93 EE 4A</td>
</tr>
<tr>
<td>7</td>
<td>84 1</td>
<td>04 2A 32 6A</td>
<td>96 0</td>
<td>B1 86 56 0E</td>
<td>CC 0</td>
<td>96 30 47 F2</td>
<td>91 1</td>
<td>F8 1D 42 30</td>
</tr>
</tbody>
</table>

Part 1

The box below shows the format of a physical address. Indicate (by labeling the diagram) the fields that would be used to determine the following:

- $O$ The block offset within the cache line
- $I$ The cache index
- $T$ The cache tag

```plaintext
<table>
<thead>
<tr>
<th>12 11 10 9 8 7 6 5 4 3 2 1 0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td></td>
</tr>
</tbody>
</table>
```
Part 2

For the given physical address, indicate the cache entry accessed and the cache byte value returned in hex. Indicate whether a cache miss occurs. If there is a cache miss, enter “-” for “Cache Byte returned”.

Physical address: 0x0D74

Physical address format (one bit per box)

<table>
<thead>
<tr>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Physical memory reference

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>Cache Offset (CO)</td>
<td>0x__</td>
</tr>
<tr>
<td>Cache Index (CI)</td>
<td>0x_</td>
</tr>
<tr>
<td>Cache Tag (CT)</td>
<td>0x__</td>
</tr>
<tr>
<td>Cache Hit? (Y/N)</td>
<td>__</td>
</tr>
<tr>
<td>Cache Byte returned</td>
<td>0x__</td>
</tr>
</tbody>
</table>

Physical address: 0x0AEE

Physical address format (one bit per box)

<table>
<thead>
<tr>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Physical memory reference

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>Cache Offset (CO)</td>
<td>0x__</td>
</tr>
<tr>
<td>Cache Index (CI)</td>
<td>0x_</td>
</tr>
<tr>
<td>Cache Tag (CT)</td>
<td>0x__</td>
</tr>
<tr>
<td>Cache Hit? (Y/N)</td>
<td>__</td>
</tr>
<tr>
<td>Cache Byte returned</td>
<td>0x__</td>
</tr>
</tbody>
</table>
Part 3

For the given contents of the cache, list all of the hex physical memory addresses that will hit in Set 7. To save space, you should express contiguous addresses as a range. For example, you would write the four addresses 0x1314, 0x1315, 0x1316, 0x1317 as 0x1314--0x1317.

Answer: ______________________________________________________

The following templates are provided as scratch space:

Part 4

For the given contents of the cache, what is the probability (expressed as a percentage) of a cache hit when the physical memory address ranges between 0x1080 - 0x109F. Assume that all addresses are equally likely to be referenced.

Probability = ____________ %

The following templates are provided as scratch space:
Problem 2. (10 points):

This problem requires you to analyze the behavior of the program below which transposes the $N \times N$ int-matrix $A$. For this problem, $N = 4$. For this problem, you should assume that the loop variables $x$ and $y$ are kept in registers and do not cause memory accesses. Likewise, the temporary variable $t$ which is used to exchange two array elements is also stored in a register and does not cause any load/store from/to the memory system or the caches.

```
#define N 4 /* Array size */
...
int A[N][N] = {0};
...
{
    int x, y;
    ...
    for (y = 0; y < N; y++) {
        for (x = y + 1; x < N; x++) {
            int t;
            t = A[y][x];
            A[y][x] = A[x][y];
            A[x][y] = t;
        }
    }
...
```

You are supposed to analyze how this program will interact with a simple cache. The cache line size is 2*sizeof(int). The cache is cold when the program starts. Further more, the array $A$ is aligned so that the first two elements are stored in the same cache line.

You are supposed to fill out the tables below. For each load (ld) and store (st) operation to an element of the array $A$, you should indicate if this operation misses (M) or hits (H) in the cache. Note that this program does not touch the diagonal array elements.

1. The cache is direct mapped and has two (2) lines:

<table>
<thead>
<tr>
<th></th>
<th>ld=</th>
<th>st=</th>
<th>ld=</th>
<th>st=</th>
<th>ld=</th>
<th>st=</th>
</tr>
</thead>
<tbody>
<tr>
<td>ld=</td>
<td>st=</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ld=</td>
<td>st=</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ld=</td>
<td>st=</td>
<td>ld=</td>
<td>st=</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ld=</td>
<td>st=</td>
<td></td>
<td></td>
<td>ld=</td>
<td>st=</td>
<td></td>
</tr>
</tbody>
</table>

2. The cache is 2-way set-associative and has one set. It uses the least recently used (LRU) replacement policy:

<table>
<thead>
<tr>
<th></th>
<th>ld=</th>
<th>st=</th>
<th>ld=</th>
<th>st=</th>
<th>ld=</th>
<th>st=</th>
</tr>
</thead>
<tbody>
<tr>
<td>ld=</td>
<td>st=</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ld=</td>
<td>st=</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ld=</td>
<td>st=</td>
<td>ld=</td>
<td>st=</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ld=</td>
<td>st=</td>
<td></td>
<td></td>
<td>ld=</td>
<td>st=</td>
<td></td>
</tr>
</tbody>
</table>
Problem 3. (8 points):
Consider the following C programs. (For space reasons, we are not checking error return codes, so assume that all functions return normally.) Assume that printf is unbuffered and that each call to printf executes atomically.

/* ecf.c */
#include <stdio.h>
#include <sys/types.h>
#include <sys/wait.h>
#define MAXLEN 32

int main(int argc, char *argv[])
{
    int i, status, limit;
    char num[MAXLEN+1];
    pid_t pid;

    limit = atoi(argv[1]);

    for(i = 0; i < limit; i++) {
        if((pid = fork()) == 0) {
            snprintf(num, MAXLEN, "%d", i+10);
            execl("./kid", "/kid", num, NULL);
        }
        if(i == (limit - 2)) {
            waitpid(pid, &status, 0);
            printf("%d\n", status);
        }
    }

    return 0;
}

--------------------
/* kid.c */
#include <stdio.h>

int main(int argc, char *argv[])
{
    printf("%d\n", atoi(argv[1]));
    return 0;
}

Assume that ecf.c is compiled into ecf and kid.c is compiled into kid in the same directory. List all possible outputs (note the newlines) of the following command:

[user@host directory]$ ./ecf 3
Problem 4. (12 points):

This problem concerns the way virtual addresses are translated into physical addresses. Imagine a system has the following parameters:

- Virtual addresses are 18 bits wide.
- Physical addresses are 16 bits wide.
- The page size is 1024 bytes.
- The TLB is 4-way set associative with 16 total entries.

The contents of the TLB and the first 32 entries of the page table are shown as follows. All numbers are given in hexadecimal.

<table>
<thead>
<tr>
<th>TLB Index</th>
<th>Tag</th>
<th>PPN</th>
<th>Valid</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>05</td>
<td>13</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>1E</td>
<td>14</td>
<td>1</td>
</tr>
<tr>
<td></td>
<td>10</td>
<td>0F</td>
<td>1</td>
</tr>
<tr>
<td></td>
<td>0F</td>
<td>1E</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1F</td>
<td>01</td>
<td>1</td>
</tr>
<tr>
<td></td>
<td>11</td>
<td>1F</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>03</td>
<td>2B</td>
<td>1</td>
</tr>
<tr>
<td></td>
<td>1D</td>
<td>23</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>06</td>
<td>08</td>
<td>1</td>
</tr>
<tr>
<td></td>
<td>0F</td>
<td>19</td>
<td>1</td>
</tr>
<tr>
<td></td>
<td>0A</td>
<td>09</td>
<td>1</td>
</tr>
<tr>
<td></td>
<td>1F</td>
<td>20</td>
<td>1</td>
</tr>
<tr>
<td>3</td>
<td>03</td>
<td>13</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>13</td>
<td>12</td>
<td>1</td>
</tr>
<tr>
<td></td>
<td>0C</td>
<td>0B</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>2E</td>
<td>24</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Page Table VPN</th>
<th>PPN</th>
<th>Valid</th>
<th>VPN</th>
<th>PPN</th>
<th>Valid</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>17</td>
<td>1</td>
<td>10</td>
<td>26</td>
<td>0</td>
</tr>
<tr>
<td>01</td>
<td>28</td>
<td>1</td>
<td>11</td>
<td>17</td>
<td>0</td>
</tr>
<tr>
<td>02</td>
<td>14</td>
<td>1</td>
<td>12</td>
<td>0E</td>
<td>1</td>
</tr>
<tr>
<td>03</td>
<td>0B</td>
<td>0</td>
<td>13</td>
<td>10</td>
<td>1</td>
</tr>
<tr>
<td>04</td>
<td>26</td>
<td>0</td>
<td>14</td>
<td>2D</td>
<td>0</td>
</tr>
<tr>
<td>05</td>
<td>13</td>
<td>1</td>
<td>15</td>
<td>1B</td>
<td>0</td>
</tr>
<tr>
<td>06</td>
<td>0F</td>
<td>1</td>
<td>16</td>
<td>0C</td>
<td>0</td>
</tr>
<tr>
<td>07</td>
<td>10</td>
<td>1</td>
<td>17</td>
<td>12</td>
<td>0</td>
</tr>
<tr>
<td>08</td>
<td>1C</td>
<td>0</td>
<td>18</td>
<td>23</td>
<td>1</td>
</tr>
<tr>
<td>09</td>
<td>25</td>
<td>1</td>
<td>19</td>
<td>04</td>
<td>0</td>
</tr>
<tr>
<td>0A</td>
<td>01</td>
<td>0</td>
<td>1A</td>
<td>0C</td>
<td>1</td>
</tr>
<tr>
<td>0B</td>
<td>16</td>
<td>1</td>
<td>1B</td>
<td>12</td>
<td>1</td>
</tr>
<tr>
<td>0C</td>
<td>01</td>
<td>1</td>
<td>1C</td>
<td>1E</td>
<td>0</td>
</tr>
<tr>
<td>0D</td>
<td>15</td>
<td>1</td>
<td>1D</td>
<td>0E</td>
<td>1</td>
</tr>
<tr>
<td>0E</td>
<td>0C</td>
<td>0</td>
<td>1E</td>
<td>27</td>
<td>1</td>
</tr>
<tr>
<td>0F</td>
<td>14</td>
<td>0</td>
<td>1F</td>
<td>18</td>
<td>1</td>
</tr>
</tbody>
</table>
Part 1

1. The diagram below shows the format of a virtual address. Please indicate the following fields by labeling the diagram: (If a field does not exist, do not draw it on the diagram.)

   \[
   \begin{array}{c}
   O & \text{The virtual page offset} \\
   N & \text{The virtual page number} \\
   I & \text{The TLB index} \\
   T & \text{The TLB tag}
   \end{array}
   \]

   \[\begin{array}{cccccccccccccccc}
   17 & 16 & 15 & 14 & 13 & 12 & 11 & 10 & 9 & 8 & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0
   \end{array}\]

2. The diagram below shows the format of a physical address. Please indicate the following fields by labeling the diagram: (If a field does not exist, do not draw it on the diagram.)

   \[
   \begin{array}{c}
   O & \text{The physical page offset} \\
   N & \text{The physical page number}
   \end{array}
   \]

   \[\begin{array}{cccccccccccccccc}
   15 & 14 & 13 & 12 & 11 & 10 & 9 & 8 & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0
   \end{array}\]
Part 2

For the given virtual addresses, please indicate the TLB entry accessed and the physical address. Indicate whether the TLB misses and whether a page fault occurs. If there is a page fault, enter “-.” for “PPN” and leave the physical address blank.

**Virtual address: 0x0718F**

1. Virtual address (one bit per box)

2. Address translation

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Value</th>
<th>Parameter</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>VPN</td>
<td>0x</td>
<td>TLB Hit? (Y/N)</td>
<td></td>
</tr>
<tr>
<td>TLB Index</td>
<td>0x</td>
<td>Page Fault? (Y/N)</td>
<td></td>
</tr>
<tr>
<td>TLB Tag</td>
<td>0x</td>
<td>PPN</td>
<td>0x</td>
</tr>
</tbody>
</table>

3. Physical address (one bit per box)

**Virtual address: 0x04AA4**

1. Virtual address (one bit per box)

2. Address translation

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Value</th>
<th>Parameter</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>VPN</td>
<td>0x</td>
<td>TLB Hit? (Y/N)</td>
<td></td>
</tr>
<tr>
<td>TLB Index</td>
<td>0x</td>
<td>Page Fault? (Y/N)</td>
<td></td>
</tr>
<tr>
<td>TLB Tag</td>
<td>0x</td>
<td>PPN</td>
<td>0x</td>
</tr>
</tbody>
</table>

3. Physical address (one bit per box)
Problem 5. (9 points):

This problem tests your understanding of Unix signals. Consider the following C program. (For space reasons, we are not checking error return codes, so assume that all functions return normally.) Assume that printf is unbuffered, and that latency in receiving signals is negligible.

```c
/* signal.c */

#include <stdlib.h>
#include <stdio.h>
#include <signal.h>

sigset_t s1;
.sigset_t s2;
int i;

void handler1(int sig);
void handler2(int sig);
void func0();
void func1();
void func2();

int main(int argc, char** argv)
{
    int n = atoi(argv[1]);

    signal(SIGINT, handler1);
    signal(SIGTSTP, handler2);

    sigemptyset(&s1);
    sigaddset(&s1, SIGINT);
    sigemptyset(&s2);
    sigaddset(&s2, SIGTSTP);

    if(n == 0)
        func0();
    else if(n == 1)
        func1();
    else if(n == 2)
        func2();

    return 0;
}
```
void handler1(int sig)
{
    int j;
    printf("hello\n");
    for(j = 0; j < 3; j++)
        kill(0, SIGTSTP);
}

void handler2(int sig)
{
    printf("greetings\n");
}

void func0()
{
    sigprocmask(SIG_BLOCK, &s1, NULL);
    for(i = 0; i < 5; i++)
        kill(0, SIGINT);
    sigprocmask(SIG_UNBLOCK, &s1, NULL);
}

void func1()
{
    sigprocmask(SIG_BLOCK, &s2, NULL);
    for(i = 0; i < 5; i++)
        kill(0, SIGINT);
    sigprocmask(SIG_UNBLOCK, &s2, NULL);
}

void func2()
{
    for(i = 0; i < 5; i++)
    {
        sigprocmask(SIG_BLOCK, &s1, NULL);
        kill(0, SIGINT);
        sigprocmask(SIG_BLOCK, &s2, NULL);
        sigprocmask(SIG_UNBLOCK, &s1, NULL);
        sigprocmask(SIG_UNBLOCK, &s2, NULL);
    }
}
For each commandline listed below, write the output which would result:

unix> ./signal 0

unix> ./signal 1

unix> ./signal 2
Problem 6. (10 points):

Suppose the file foo.txt contains the text "123456", bar.txt contains the text "abcdef", and baz.txt does not yet exist. Examine the following C code, and answer the questions below. (For space reasons, we are not checking error return codes, so assume that all functions return normally.)

```c
int main() {
    int fd1, fd2, fd3, fd4, fd5, fd6;
    int status;
    pid_t pid;
    char c;

    /* foo.txt has "123456" */
    fd1 = open("foo.txt", O_RDONLY, 0);
    fd2 = open("foo.txt", O_RDONLY, 0);

    /* bar.txt has "abcdef" */
    fd3 = open("bar.txt", O_RDWR, 0);
    fd4 = open("bar.txt", O_RDWR, 0);

    /* baz.txt doesn't exist initially */
    fd5 = open("baz.txt", O_WRONLY | O_CREAT | O_TRUNC,
                S_IRUSR | S_IWUSR); /* r/w */

    fd6 = dup(STDOUT_FILENO);
    dup2(fd5, STDOUT_FILENO);

    if ((pid = fork()) == 0) {
        dup2(fd3, fd2);

        read(fd3, &c, 1); printf("%c", c);
        write(fd4, "!@#$%ˆ", 6);
        read(fd3, &c, 1); printf("%c", c);
        read(fd1, &c, 1); printf("%c", c);
        read(fd2, &c, 1); printf("%c\n", c);
        exit(0);
    }

    wait(NULL);
    read(fd1, &c, 1); printf("%c", c);
    fflush(stdout);

    dup2(fd6, STDOUT_FILENO);
    printf("done.\n");
    return 0;
}
```
A. What will the contents of `baz.txt` be after the program completes?

B. What will be printed on `stdout`?
Problem 7. (14 points):
Answer the following short answer questions with no more than 2 sentences.

A. What characteristics of a disk subsystem determine the time it takes to access a sector on disk?

B. What is the CPU-Memory gap? And, is it getting bigger or smaller over time?

C. Does the declaration “static int x;” generate an entry in the .o file? If so, what kind of entry would it be?

D. List up to two positive reasons and two negative reasons for using a mark and sweep garbage collection system instead of an explicit memory allocator in a real-time system?
E. The following two files are linked together and the program is run.

```c
main()
{
    int x;
    x = 40;
    foo();
    printf("A: %d\n", x);
}
extern int x;
bar()
{
    x = 2 * x;
    foobar();
}
int x = 2;
```

What is the output:

F. What is printed out in the following code:

```c
#include <setjmp.h>
jmp_buf buf;
int x = 0;
main()
{
    switch (setjmp(buf))
    {
    case 0: x = 2;
            foo();
            x++;
    case 1: bar();
            x++;
    case 2: printf("A: %d\n", x);
    }
}
foo()
{
    x = x + 10;
    bar();
}
foobar()
{
    extern int x;
    x += 3;
    printf("B: %d\n", x);
}
bar()
{
    extern int x;
    x += 3;
    printf("B: %d\n", x);
}
```