| CS 61C      | I/O                          |
|-------------|------------------------------|
| Spring 2021 | Discussion 11: April 5, 2021 |

## 1 Pre-Check

This section is designed as a conceptual check for you to determine if you conceptually understand and have any misconceptions about this topic. Please answer true/false to the following questions, and include an explanation:

1.1 Polling and interrupts are only relevant concepts for low level programming.

False. Similar concepts apply to almost all types of applications, including web apps, mobile apps, distributed systems, and so on.

1.2 Memory-mapped IO only works with polling.

False. The implementation backing the memory mapping can use interrupt-driven IO (for example, reading files).

2 I/O

## 2 Polling & Interrupts

[2.1] Fill out this table that compares polling and interrupts.

| Operation  | Definition                                                                                                                                                             | Pro/Good for                                                                                                                                                                                                                                             | Con                                                                                                                                                                                                                                      |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Polling    | Forces the hardware to<br>wait on ready bit (alter-<br>natively, if timing of de-<br>vice is known, the ready<br>bit can be polled at the<br>frequency of the device). | <ul> <li>Low Latency</li> <li>Low overhead when data is available</li> <li>Good For: devices that are always busy or when you can't make progress until the device replies</li> </ul>                                                                    | <ul> <li>Can't do anything else<br/>while polling</li> <li>Can't sleep while<br/>polling (CPU<br/>always at full<br/>speed)</li> </ul>                                                                                                   |
| Interrupts | Hardware fires an "excep-<br>tion" when it becomes<br>ready. CPU changes PC<br>register to execute code<br>in the interrupt handler<br>when this occurs.               | <ul> <li>Can do useful work<br/>while waiting for re-<br/>sponse</li> <li>Can wait on many<br/>things at once</li> <li>Good for: Devices that<br/>take a long time to<br/>respond, especially<br/>if you can do other<br/>work while waiting.</li> </ul> | <ul> <li>Nondeterministic when<br/>interrupt occurs</li> <li>interrupt handler has<br/>some overhead (e.g.<br/>saves all registers,<br/>flush pipeline, etc.)</li> <li>Higher latency per<br/>event</li> <li>Worse throughput</li> </ul> |

## 3 Memory Mapped I/O

3.1

## For this question, the following addresses correspond to registers in some I/O devices

and not regular user memory.

- 0xFFFF0000—Receiver Control: LSB is the ready bit (in the context of polling), there may be other bits set that we don't need right now.
- $\bullet~0xFFFF0004\mbox{--Receiver Data:}$  Received data stored at lowest byte.
- 0xFFFF0008—Transmitter Control: LSB is the ready bit (in the context of polling), there may be other bit set that we don't need right now.
- $\bullet~0xFFFF000C--Transmitter Data:$  Transmitted data stored at lowest byte.

Recall that receiver will only have data for us when the corresponding ready bit is 1, and that we can only write data to the transmitter when its ready bit is 1. Write RISC-V code that reads byte from the receiver (busy-waiting if necessary) and writes that byte to the transmitter (busy-waiting if necessary).

|                          | lui t0 0xffff0                    |                                        |
|--------------------------|-----------------------------------|----------------------------------------|
| <pre>receive_wait:</pre> | lw t1 0(t0)                       |                                        |
|                          | andi t1 t1 1                      | <pre># poll on ready of receiver</pre> |
|                          | <pre>beq t1 x0 receive_wait</pre> |                                        |
|                          | lb t2 4(t0)                       | # load data                            |

transmit\_wait: lw t1 8(t0) # poll on ready of transmitter andi t1 t1 1 beq t1 x0 transmit\_wait # write to transmitter sb t2 12(t0)