First Name: _______________   Last Name:____________________

November 8, 2006, 1 to 1:50pm

This is an open book, open notes exam. You may put answers on the backs of the pages, but please don’t turn in any extra sheets.
(15) **Question 1.** Consider a situation where 4 microcontrollers are connected together using a CAN network. Assume for this question that each frame contains 100 bits. Also assume the baud rate is 100,000 bits/sec, therefore it takes 1ms to send a frame. Initially, the CAN controllers are initialized (i.e., all computers have previously executed `CAN_Open`).

At time = 0  computer A calls `CAN_Send` with ID=1000
At time = 300us  computer B calls `CAN_Send` with ID=800
At time = 500us  computer C calls `CAN_Send` with ID=900
At time = 700us  computer D calls `CAN_Send` with ID=600

Specify the time sequence in which the four frames occur on the CAN network. Clearly define the begin and end times when each message is visible on the CAN network.

---

(10) **Question 2.** Assume the CAN transfer rate is 100,000 bits/sec, the system uses 11-bit IDs, there are 8 nodes on the network, each node sends a message every 0.1 sec, and each message contains 5 bytes of data, what is the **actual** bandwidth of this network (in units of bytes of data per sec)? You may neglect stuff bits. The total number of bits in a CAN frame can be calculated as the number of ID bits plus the number of data bits plus 36 bits. The important part of this question is the development of the equation, and the calculation of the specific number is of secondary importance.
(25) **Question 3.** The CAN physical channel defines one bit at a time in such a way that 0 dominates over 1. In particular, if one node is attempting to drive CANH to 2.5 and a second node tries to make CANH 3.75, then the actual CANH signal goes to 3.75. Similarly, if one node is attempting to drive CANL to 2.5 and a second node tries to make CANL 1.25, then the actual CANL signal goes to 1.25. Notice also that CANH + CANL always equals 5.0 volts.

**Part a)** Define a new voltage protocol that transmits two bits at a time in such a way that 00 dominates over 01, which dominates over 10, which dominates over 11. There will still be two signals, CANH and CANL, such that CANH + CANL always equals 5.0 volts. In order for the interface to operate on a single 5 V supply, all voltages must be between 1 and 4 volts.

<table>
<thead>
<tr>
<th>Digital input</th>
<th>CANH</th>
<th>CANL</th>
<th>CANH+CANL</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 0</td>
<td></td>
<td></td>
<td>5.00 V</td>
</tr>
<tr>
<td>0 1</td>
<td></td>
<td></td>
<td>5.00 V</td>
</tr>
<tr>
<td>1 0</td>
<td></td>
<td></td>
<td>5.00 V</td>
</tr>
<tr>
<td>1 1</td>
<td></td>
<td></td>
<td>5.00 V</td>
</tr>
</tbody>
</table>

**Part b)** Demonstrate how your system will implement dominance by considering a simple case with two nodes simultaneously transmitting. You will show just the functionality of CANH, but a corresponding operation will occur on CANL. Since the system will be symmetric (fair) with respect to nodes A and B, the situations with A dominating over B were removed from the table.

<table>
<thead>
<tr>
<th>Node A⁰</th>
<th>CANH (A)²</th>
<th>Node B³</th>
<th>CANH (B)⁴</th>
<th>CANH⁵</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 0</td>
<td>0 0</td>
<td>0 0</td>
<td>A=B</td>
<td></td>
</tr>
<tr>
<td>0 1</td>
<td>0 0</td>
<td>0 0</td>
<td>B&gt;A</td>
<td></td>
</tr>
<tr>
<td>1 0</td>
<td>0 0</td>
<td>0 0</td>
<td>B&gt;A</td>
<td></td>
</tr>
<tr>
<td>1 1</td>
<td>0 0</td>
<td>0 0</td>
<td>B&gt;A</td>
<td></td>
</tr>
<tr>
<td>0 1</td>
<td>0 1</td>
<td>0 1</td>
<td>A=B</td>
<td></td>
</tr>
<tr>
<td>1 0</td>
<td>0 1</td>
<td>0 1</td>
<td>B&gt;A</td>
<td></td>
</tr>
<tr>
<td>1 1</td>
<td>0 1</td>
<td>0 1</td>
<td>B&gt;A</td>
<td></td>
</tr>
<tr>
<td>1 0</td>
<td>1 0</td>
<td>1 0</td>
<td>A=B</td>
<td></td>
</tr>
<tr>
<td>1 1</td>
<td>1 0</td>
<td>1 0</td>
<td>B&gt;A</td>
<td></td>
</tr>
<tr>
<td>1 1</td>
<td>1 1</td>
<td>1 1</td>
<td>A=B</td>
<td></td>
</tr>
</tbody>
</table>

A=B means A and B continue transmitting, and dominance occurs later
B>A means B asserts dominance over A, and A stops transmitting

---

1 This is the digital logic that Node A is attempting to send
2 Fill in with the value from your Table in part a)
3 This is the digital logic that Node B is attempting to send
4 Fill in with the value from your Table in part a)
5 This will be the actual voltage on the CANH signal
(25) Question 4. Assume the binary semaphore type is a simple 8-bit integer, e.g.,
char s1;  // binary semaphore can be 0 or 1
The following implementation of the binary spinlock semaphore is proposed.

```c
void OS_InitSemaphore(char *semaPt, char value){
    *semaPt = value;
}
void OS_bWait(char *semaPt){ // semaPt in RegD
    asm tfr d,x    // RegX->semaphore
    asm ldaa #0     // RegA=0
    asm minm 0,x    // replace memory with the smaller of 0 and memory
    // minm sets the C bit if it changes from 1 to 0
    asm bcc *-3     // execute minm until changes from 1 to 0
}
void OS_bSignal(char *semaPt){ // semaPt in RegD
    asm tfr d,x    // RegX->semaphore
    asm ldaa #1     // RegA=1
    asm staa 0,x    // semaphore is set to 1
}
```

**Part a)** Does this implementation have any critical sections? If so, identify the specific place(s) where the critical section exists.

**Part b)** In this part, assume the semaphore is initially 1, and two or more threads have started to execute `OS_bWait`. Fill in the blank:

*The first thread to execute the __________ instruction will be the one to return from `OS_bWait`, while the other thread(s) will spin in the **minm**/bcc loop.*

**Part c)** Why is this implementation better than the spinlock implement you created in Lab 18?
Consider a problem of deadlocks that can occur with semaphore synchronization. The following is a classic example that might occur if two threads need both the disk and the printer. In this example, the disk has a binary semaphore `DiskFree`, which is 1 if the disk is available, and similarly the printer has a binary semaphore `PrinterFree`, which is 1 if the printer is available. A deadlock occurs if each thread gets one resource then waits (on each other) for the other resource. In this example, we assume there is one disk and one printer.

```c
void thread1(void)
{
    OS_bWait(&DiskFree);
    OS_bWait(&PrinterFree);
    // use disk and printer
    OS_bSignal(&DiskFree);
    OS_bSignal(&PrinterFree);
}

void thread2(void)
{
    OS_bWait(&PrinterFree);
    OS_bWait(&DiskFree);
    // use printer and disk
    OS_bSignal(&PrinterFree);
    OS_bSignal(&DiskFree);
}
```

In this problem we will develop a graphical method (called a resource allocation graph) to visualize/recognize the deadlock. Draw each thread in your system as an oval, and each binary semaphore as a rectangle. If a thread calls `OS_bWait` and returns, then draw an arrow (called an allocation edge) from the semaphore to the thread. An arrow from a semaphore to a thread means that thread owns the resource. If a thread calls `OS_bSignal`, then erase the previously drawn allocation edge. If a thread calls `OS_bWait` and spins or blocks because the semaphore is not free, then draw an arrow from the thread to the semaphore (called a request edge). An arrow from a thread to a semaphore means that thread is waiting for the resource associated with the semaphore.

Part a) Draw the resource allocation graph that occurs with the deadlock sequence

1) thread1 executes `OS_bWait(&DiskFree)`;
2) thread2 executes `OS_bWait(&PrinterFree)`;
3) thread2 executes `OS_bWait(&DiskFree)`;
4) thread1 executes `OS_bWait(&PrinterFree)`;

---

Jonathan W. Valvano
Part b) This method can be generalized to detect that a deadlock has occurred with an arbitrary number of binary semaphores and threads. What shape in the resource allocation graph defines a deadlock? In other words, generalize the use of this method such that you can claim

“There is a deadlock if and only if the resource allocation graph contains a shape in the form of a ________________”.

Part c) Justify your answer by giving a deadlock example with three threads and three semaphores. In particular, give 1) the C code; 2) the execution sequence; 3) the resource allocation graph

```
void thread1(void){
    // Code
}

void thread2(void){
    // Code
}

void thread3(void){
    // Code
}
```

PrinterFree  COMFree  DiskFree

Thread1  Thread2  Thread3
MINM

Place Smaller of Two
Unsigned 8-Bit Values
in Memory

Operation: \( \text{MIN} ((A), (M)) \rightarrow M \)

Description: Subtracts an unsigned 8-bit value in memory from an unsigned 8-bit value in accumulator A to determine which is larger and leaves the smaller of the two values in the memory location. The Z status bit is set when the result of the subtraction is zero (the values are equal), and the C status bit is set when the subtraction requires a borrow (the value in memory is larger than the value in the accumulator). When \( C = 1 \), the value in accumulator A has replaced the value in memory.

The unsigned value in memory is accessed by means of indexed addressing modes, which allow a great deal of flexibility in specifying the address of the operand.

<table>
<thead>
<tr>
<th>S</th>
<th>X</th>
<th>H</th>
<th>I</th>
<th>N</th>
<th>Z</th>
<th>V</th>
<th>C</th>
</tr>
</thead>
<tbody>
<tr>
<td>-</td>
<td>-</td>
<td>-</td>
<td>Δ</td>
<td>Δ</td>
<td>Δ</td>
<td>Δ</td>
<td>Δ</td>
</tr>
</tbody>
</table>

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $00$; cleared otherwise
V: \( A7 \cdot M7 \cdot R7 + \overline{A7} \cdot M7 \cdot R7 \)
   Set if a two's complement overflow resulted from the operation; cleared otherwise
C: \( A7 \cdot M7 + M7 \cdot R7 + R7 \cdot \overline{A7} \)
   Set if the value of the content of memory is larger than the value of the accumulator; cleared otherwise

Condition codes reflect internal subtraction \((R = A - M)\)

<table>
<thead>
<tr>
<th>Source Form</th>
<th>Address Mode</th>
<th>Object Code</th>
<th>Access Detail</th>
</tr>
</thead>
<tbody>
<tr>
<td>MINM oprx0_xsp</td>
<td>IDX</td>
<td>18 1D xb</td>
<td>OfPrW</td>
</tr>
<tr>
<td>MINM oprx9_xsp</td>
<td>IDX1</td>
<td>18 1D xb ff</td>
<td>OfPrW</td>
</tr>
<tr>
<td>MINM oprx16_xsp</td>
<td>IDX2</td>
<td>18 1D xb ee ff</td>
<td>OfPrWp</td>
</tr>
<tr>
<td>MINM [D,xsp]</td>
<td>[D,IDX]</td>
<td>18 1D xb</td>
<td>OfIfPrW</td>
</tr>
<tr>
<td>MINM [opr16,xsp]</td>
<td>IDX2</td>
<td>18 1D xb ee ff</td>
<td>OfItPrW</td>
</tr>
</tbody>
</table>

Jonathan W. Valvano
BCC

**Operation:** If \( C = 0 \), then \((PC) + 0002 + \text{Rel} \Rightarrow PC\)

Simple branch

**Description:** Tests the C status bit and branches if \( C = 0 \).

LDA A

**Operation:** \((M) \Rightarrow A\)

**Description:** Loads the content of memory location \( M \) into accumulator A. The condition codes are set according to the data.

**CCR Details:**

<table>
<thead>
<tr>
<th>S</th>
<th>X</th>
<th>H</th>
<th>I</th>
<th>N</th>
<th>Z</th>
<th>V</th>
<th>C</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Δ</td>
<td>Δ</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

- **N:** Set if MSB of result is set; cleared otherwise
- **Z:** Set if result is $00$; cleared otherwise
- **V:** 0; cleared

<table>
<thead>
<tr>
<th>Source Form</th>
<th>Address Mode</th>
<th>Object Code</th>
<th>Access Detail</th>
</tr>
</thead>
<tbody>
<tr>
<td>LDA A #opr8i</td>
<td>IMM</td>
<td>86 ii</td>
<td>P</td>
</tr>
<tr>
<td>LDA A opr8a</td>
<td>DIR</td>
<td>96 dd</td>
<td>rPf</td>
</tr>
<tr>
<td>LDA A opr16a</td>
<td>EXT</td>
<td>B6 h h l l</td>
<td>rPO</td>
</tr>
<tr>
<td>LDA A oprx0,xy sp</td>
<td>IDX</td>
<td>A6 xb</td>
<td>rPf</td>
</tr>
<tr>
<td>LDA A oprx9,xy sp</td>
<td>IDX1</td>
<td>A6 xb ff</td>
<td>rPO</td>
</tr>
<tr>
<td>LDA A oprx16,xy sp</td>
<td>IDX2</td>
<td>A6 xb ee ff</td>
<td>frPP</td>
</tr>
<tr>
<td>LDA A [D,xy sp]</td>
<td>[D,IDX]</td>
<td>A6 xb</td>
<td>fIPrPf</td>
</tr>
<tr>
<td>LDA A [opr16,xy sp]</td>
<td>[IDX2]</td>
<td>A6 xb ee ff</td>
<td>fIPPrPf</td>
</tr>
</tbody>
</table>

Jonathan W. Valvano
STAA

Operation:  \((A) \Rightarrow M\)

Description: Stores the content of accumulator A in memory location M. The content of A is unchanged.

CCR Details:

\[
\begin{array}{ccccccccc}
S & X & H & I & N & Z & V & C \\
- & - & - & - & \Delta & \Delta & 0 & - \\
\end{array}
\]

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $00$; cleared otherwise
V: 0; cleared

<table>
<thead>
<tr>
<th>Source Form</th>
<th>Address Mode</th>
<th>Object Code</th>
<th>Access Detail</th>
</tr>
</thead>
<tbody>
<tr>
<td>STAA opr3a</td>
<td>DIR</td>
<td>5A dd</td>
<td>Pw</td>
</tr>
<tr>
<td>STAA opr16a</td>
<td>EXT</td>
<td>7A hh 11</td>
<td>PwO</td>
</tr>
<tr>
<td>STAA oprx0,xysp</td>
<td>IDX</td>
<td>6A xb</td>
<td>Pw</td>
</tr>
<tr>
<td>STAA oprx9,xysp</td>
<td>IDX1</td>
<td>6A xb ff</td>
<td>PwO</td>
</tr>
<tr>
<td>STAA oprx16,xysp</td>
<td>IDX2</td>
<td>6A xb ee ff</td>
<td>PwP</td>
</tr>
<tr>
<td>STAA [D,xysp]</td>
<td>[D,IDX]</td>
<td>6A xb</td>
<td>PIFw</td>
</tr>
<tr>
<td>STAA [opr16,xysp]</td>
<td>[IDX2]</td>
<td>6A xb ee ff</td>
<td>PIFPw</td>
</tr>
</tbody>
</table>

TFR

Operation: See table.

<table>
<thead>
<tr>
<th>Source Form</th>
<th>Address Mode</th>
<th>Object Code</th>
<th>Access Detail</th>
</tr>
</thead>
<tbody>
<tr>
<td>TFR abcdxys,abcdxys</td>
<td>INH</td>
<td>B7 eb</td>
<td>P</td>
</tr>
</tbody>
</table>

1. Legal coding for eb is summarized in the following table. Columns represent the high-order source digit. Rows represent the low-order destination digit (MSB is a don't-care). Values are in hexadecimal.