- 1. Assume that a particular device transfers data at an average of 32 kB/s on a continuous basis. Determine what fraction of the processor time is consumed by this I/O device using interrupt-driven I/O in each of the following cases.
  - (a) First assume that the device interrupts for every byte and that interrupt processing takes 20 µs. This includes the overhead of setting up the interrupt service procedure (ISP) and returning from the ISP, as well as the 4 µs it takes to transfer one byte from the controller of the device.

```
32\,000\,\mathrm{B/s} = 32\,\mathrm{kB/s} = \mathrm{Average\ data\ transfer}
2 \times 10^{-5}\,\mathrm{s} = 20\,\mathrm{\mu s} = \mathrm{Interrupt\ time}
```

$$32000 \times (2 \times 10^{-5}) = 0.64$$
  
 $0.64 = 64\% = \frac{64}{100} = \frac{16}{25}$ 

(b) Next assume that the controller of the device has two 16-byte buffers and it interrupts the processor whenever one of the buffers is full.

```
32000 \,\mathrm{B/s} = 32 \,\mathrm{kB/s} = \mathrm{Average} \,\mathrm{transfer}
4 \times 10^{-6} \,\mathrm{s} = 4 \,\mu\mathrm{s} = \mathrm{transfer\ time\ for\ 1\ byte}
1.6 \times 10^{-5} \,\mathrm{s} = 16 \,\mathrm{\mu s} = \mathrm{ISP} \,\mathrm{time}
16 B = Buffer size
2 = \# of buffers
(Average buffer transfer) = (Average transfer) \div (# of buffers)
16000 = 32000 \div 2
(interrupts per buffer) = (Average buffer transfer) \div (Buffer size)
1000 = 16000 \div 16
(\# \text{ of interrupts}) = (\# \text{ of interrupts for a buffer}) \times (\# \text{ of buffers})
2000 = 1000 \times 2
(time to load a buffer) = (transfer time for 1 byte) \times (Buffer size)
64 = 4 \times 16
(interrupt time) = (time to load a buffer) + (ISP time)
8 \times 10^{-5} = 80 = 64 + 16
(percentage for interrupt) = (\# of interrupts) \times (interrupt time)
0.16 = 2000 \times (8 \times 10^{-5})
0.16 = 16\% = \frac{16}{100} = \frac{4}{25}
```

(c) Assume, in addition to the buffers, that the processor is equipped with a block transfer I/O instruction which speeds up the transfer of a byte to  $2\,\mu s$ .

```
32000 \,\mathrm{B/s} = 32 \,\mathrm{kB/s} = \mathrm{Average} \,\mathrm{transfer}
2 \times 10^{-6} \,\mathrm{s} = 2 \,\mathrm{\mu s} = \mathrm{transfer \ time \ for} \ 1 \ \mathrm{byte}
1.6 \times 10^{-5} \,\mathrm{s} = 16 \,\mathrm{\mu s} = \mathrm{ISP} \,\mathrm{time}
16 B = Buffer size
2 = \# of buffers
(Average buffer transfer) = (Average transfer) \div (# of buffers)
16000 = 32000 \div 2
(interrupts per buffer) = (Average buffer transfer) \div (Buffer size)
1000 = 16000 \div 16
(\# \text{ of interrupts}) = (\# \text{ of interrupts for a buffer}) \times (\# \text{ of buffers})
2000 = 1000 \times 2
(time to load a buffer) = (transfer time for 1 byte) \times (Buffer size)
32 = 2 \times 16
(interrupt time) = (time to load a buffer) + (ISP time)
4.8 \times 10^{-5} = 48 = 32 + 16
(percentage for interrupt) = (\# of interrupts) \times (interrupt time)
0.096 = 2000 \times (4.8 \times 10^{-5})
0.096 = 9.6\% = \frac{9.6}{100} = \frac{12}{125}
```

- 2. A 2 GHz processor provides an instruction for loading a string of bytes from memory to an internal cache. The fetching and decoding of the instruction takes 10 clock cycles. Thereafter, it takes 5 clock cycles to transfer each byte.
  - (a) Determine the length (in seconds) of the instruction cycle for the case of a string of 64 bytes.

```
cycles/s = Hz

2 \times 10^9 \,\mathrm{Hz} = 2\,000\,000\,000\,\mathrm{Hz} = 2\,\mathrm{GHz}

10\,\mathrm{Hz} = \mathrm{fetching} and decoding instruction

5\,\mathrm{Hz} = \mathrm{byte} transfer

64\,\mathrm{B} = \mathrm{string}

(# of cycles for string) = (byte transfer) × (bytes)

320 = 64 \times 5

(total cycles) = (fetching and decoding) + (# of cycles for string)

330 = 10 + 320

(length (in seconds)) = (total cycles) ÷ (2\,\mathrm{GHz})

1.65 \times 10^{-7} \,\mathrm{s} = 0.00000001.65 = 330 \div (2 \times 10^9)
```

(b) What is the worst-case delay for acknowledging an interrupt if the instruction is non-interruptable?

The worst case delay before acknowledging and interrupt, if the the instruction is non-interrupable, is the length of the instruction. So, it is  $1.65 \times 10^{-7}$  s assuming that it is 64 B.

(c) Repeat the previous item assuming that the instruction can be interrupted at the beginning of each byte transfer.

The worst case delay case delay for servicing an interrupt if it can happen at the beginning of each byte transfer is immediately after the fetch and decode procedure.

```
2 \times 10^9 \, \mathrm{Hz} = 2\,000\,000\,000 \, \mathrm{Hz} = 2 \, \mathrm{GHz}
10 \, \mathrm{Hz} = \mathrm{fetching} and decoding instruction
```

```
length (in seconds)) = (fetching and decoding) \div (2 GHz) 5 \times 10^{-9} \,\mathrm{s} = 0.000000005 = 10 \div (2 \times 10^9)
```