

### CMP SCI 2700 - Homework 4

## Complete Chapter 7 End of Chapter Review Questions

• 7.1-7.7

**Complete Chapter 8 End of Chapter Review Questions** 

• 8.1 - 8.10

## Review Questions

- 7.1 List three broad classifications of external, or peripheral, devices.
- 7.2 What is the International Reference Alphabet?
- 7.3 What are the major functions of an I/O module?
- 7.4 List and briefly define three techniques for performing I/O.
- 7.5 What is the difference between memory-mapped I/O and isolated I/O?
- 7.6 When a device interrupt occurs, how does the processor determine which device issued the interrupt?
- When a DMA module takes control of a bus, and while it retains control of the bus, 7.7 what does the processor do?

### **Problems**

- 7.1 On a typical microprocessor, a distinct I/O address is used to refer to the I/O data registers and a distinct address for the control and status registers in an I/O controller for a given device. Such registers are referred to as ports. In the Intel 8088, two I/O instruction formats are used. In one format, the 8-bit opcode specifies an I/O operation; this is followed by an 8-bit port address. Other I/O opcodes imply that the port address is in the 16-bit DX register. How many ports can the 8088 address in each I/O addressing mode?
- 7.2 A similar instruction format is used in the Zilog Z8000 microprocessor family. In this case, there is a direct port addressing capability, in which a 16-bit port address is part of the instruction, and an indirect port addressing capability, in which the instruction references one of the 16-bit general purpose registers, which contains the port address. How many ports can the Z8000 address in each I/O addressing mode?
- 7.3 The Z8000 also includes a block I/O transfer capability that, unlike DMA, is under the direct control of the processor. The block transfer instructions specify a port address register (Rp), a count register (Rc), and a destination register (Rd). Rd contains the main memory address at which the first byte read from the input port is to be stored. Rc is any of the 16-bit general purpose registers. How large a data block can be
- 7.4 Consider a microprocessor that has a block I/O transfer instruction such as that found on the Z8000. Following its first execution, such an instruction takes five clock cycles to re-execute. However, if we employ a nonblocking I/O instruction, it takes a total of 20 clock cycles for fetching and execution. Calculate the increase in speed with the block I/O instruction when transferring blocks of 128 bytes.
- 7.5 A system is based on an 8-bit microprocessor and has two I/O devices. The I/O controllers for this system use separate control and status registers. Both devices handle data on a 1-byte-at-a-time basis. The first device has two status lines and three control lines. The second device has three status lines and four control lines.
  - a. How many 8-bit I/O control module registers do we need for status reading and control of each device?
  - b. What is the total number of needed control module registers given that the first device is an output-only device?
  - c. How many distinct addresses are needed to control the two devices?
- 7.6 For programmed I/O, Figure 7.5 indicates that the processor is stuck in a wait loop doing status checking of an I/O device. To increase efficiency, the I/O software could be written so that the processor periodically checks the status of the device. If the device is not ready, the processor can jump to other tasks. After some timed interval, the processor comes back to check status again.
  - a. Consider the above scheme for outputting data one character at a time to a printer that operates at 10 characters per second (cps). What will happen if its status is scanned every 200 ms?

supports 16 domains. The domain feature allows multiple processes to use the same translation tables while maintaining some protection from each other.

Each page table entry and TLB entry contains a field that specifies which domain the entry is in. A 2-bit field in the Domain Access Control Register controls access to each domain. Each field allows the access to an entire domain to be enabled and disabled very quickly, so that whole memory areas can be swapped in and out of virtual memory very efficiently. Two kinds of domain access are supported:

- Clients: Users of domains (execute programs and access data) that must observe the access permissions of the individual sections and/or pages that make up that domain.
- Managers: Control the behavior of the domain (the current sections and pages in the domain, and the domain access), and bypass the access permissions for table entries in that domain.

One program can be a client of some domains, and a manager of some other domains, and have no access to the remaining domains. This allows very flexible memory protection for programs that access different memory resources.

# 8.6 KEY TERMS, REVIEW QUESTIONS, AND PROBLEMS

## Key Terms

batch system
demand paging
interactive operating system
interrupt
job control language (JCL)
kernel
logical address
long-term scheduling
medium-term scheduling
memory management
memory protection
multiprogramming

multitasking
nucleus
operating system (OS)
page table
paging
partitioning
physical address
privileged instruction
process
process control block
process state
real memory

resident monitor
segmentation
short-term scheduling
swapping
thrashing
time-sharing system
translation lookaside
buffer (TLB)
utility
virtual memory

## Review Questions

- 8.1 What is an operating system?
- 8.2 List and briefly define the key services provided by an OS.
- 8.3 List and briefly define the major types of OS scheduling.
- 8.4 What is the difference between a process and a program?
- 8.5 What is the purpose of swapping?
- 8.6 If a process may be dynamically assigned to different locations in main memory, what is the implication for the addressing mechanism?
- 8.7 Is it necessary for all of the pages of a process to be in main memory while the process is executing?

8.8 Must

8.9 Is it r

8.10 What

### **Problems**

8.1 Suppochara and the that a proce

Th

■ Pr Comp

perioc a. I/( b. I/(

8.2 An I/(
I/O th
short-1
time ii
yet do

8.3 A prog

of an a page si page fr memor

8.4 Consid main m a partit

8.5 Consider half as 1

8.6 Suppos the foll and all.

> Virtu nuı

- 8.8 Must the pages of a process in main memory be contiguous?
- 8.9 Is it necessary for the pages of a process in main memory to be in sequential order?
- 8.10 What is the purpose of a translation lookaside buffer?

#### **Problems**

- 8.1 Suppose that we have a multiprogrammed computer in which each job has identical characteristics. In one computation period, T, for a job, half the time is spent in I/O and the other half in processor activity. Each job runs for a total of N periods. Assume that a simple round-robin priority is used, and that I/O operations can overlap with processor operation. Define the following quantities:
  - Turnaround time = actual to complete a job.
  - Throughput = average number of jobs completed per time period T.
  - Processor utilization = percentage of time that the processor is active (not waiting). Compute these quantities for one, two, and four simultaneous jobs, assuming that the period T is distributed in each of the following ways:
  - a. I/O first half, processor second half;
  - b. I/O first and fourth quarters, processor second and third quarters.
- 8.2 An I/O-bound program is one that, if run alone, would spend more time waiting for I/O than using the processor. A processor-bound program is the opposite. Suppose a short-term scheduling algorithm favors those programs that have used little processor time in the recent past. Explain why this algorithm favors I/O-bound programs and yet does not permanently deny processor time to processor-bound programs.
- 8.3 A program computes the row sums

$$C_i = \sum_{j=1}^n a_{ij}$$

of an array A that is 100 by 100. Assume that the computer uses demand paging with a page size of 1000 words, and that the amount of main memory allotted for data is five page frames. Is there any difference in the page fault rate if A were stored in virtual memory by rows or columns? Explain.

- 8.4 Consider a fixed partitioning scheme with equal-size partitions of 2<sup>16</sup> bytes and a total main memory size of 2<sup>24</sup> bytes. A process table is maintained that includes a pointer to a partition for each resident process. How many bits are required for the pointer?
- 8.5 Consider a dynamic partitioning scheme. Show that, on average, the memory contains half as many holes as segments.
- 8.6 Suppose the page table for the process currently executing on the processor looks like the following. All numbers are decimal, everything is numbered starting from zero, and all addresses are memory byte addresses. The page size is 1024 bytes.

| Virtual page<br>number | Valid bit | Reference bit | Modify bit | Page frame<br>number |
|------------------------|-----------|---------------|------------|----------------------|
| 0                      | 1         | 1             | 0          | 4                    |
| 1                      | 1         | 1             | 1          | 7                    |
| 2                      | 0         | 0             | 0          | - 174 <u>-</u> - 1   |
| 3                      | 1         | 0             | 0          | 2                    |
| 4                      | 0         | 0             | 0          |                      |
| 5                      | 1         | 0             | 1          | 0                    |