## CS 271Computer Architecture and Assembly Language

Self-Check for Lecture#2

## Solutions are posted

1. Terms / Definitions

a. "caching" is \_\_\_\_\_.

b. A "bus" is \_\_\_\_\_.

c. "vonNeumann architecture" refers to computer architectures that \_\_\_\_\_\_.

2. Inside the computer, machine instructions, memory addresses, numbers, characters, etc., are all represented as \_\_\_\_\_\_.

3. In the simple CISC architecture discussed in Lecture, which register holds

a. the current machine instruction?\_\_\_\_\_\_.

b. the current micro-instruction?\_\_\_\_\_.

4. Number the order of steps in the instruction execution cycle.

\_\_\_\_\_ Decode the instruction in the Instruction Register.

\_\_\_\_\_ If the instruction requires memory access, determine the memory address, and fetch the operand from memory into a CPU register, or send the operand from a CPU register to memory.

\_\_\_\_\_ Increment the Instruction Pointer to point to next instruction.

\_\_\_\_\_ Execute the instruction.

\_\_\_\_\_ Fetch the instruction at the address in the Instruction Pointer into the Instruction Register.

\_\_\_\_\_ Repeat from step 1.

5.Consider the virtual machine levels in the diagram at the right. At each level (except 0 and 5), an interpreter accepts an instruction from the level above, converts the instruction to its own language, and passes the resulting instructions to the level below. Note that Level-0 has no interpreter; the instructions from the Micro-architecture level are sent directly to the hardware.

Suppose that the interpreters at each level (levels 1 - 4) generate n instructions in order to represent one instruction from the level above. Suppose also that each Level-0 instruction executes in c nanoseconds.

Assembly LanguageLevel 4Operating SystemLevel 3Instruction Set<br/>ArchitectureLevel 2MicroarchitectureLevel 1Digital LogicLevel 0

Level 5

High-Level Language

- a. How long does it take to execute a Level-3 instruction? \_\_\_\_\_ ns.
- b. How long does it take to execute a Level-5 instruction? \_\_\_\_\_ ns.

6. How many bits in 35 MiB?\_\_\_\_\_ bits

## Questions 7-10 refer to the IA-32architecture discussed in Lecture.

7. What is the width of the internal bus?\_\_\_\_\_

8. What is the size of the general-purpose registers?\_\_\_\_\_

9. Which of the following are valid 8-bit register references?

\_\_\_\_\_ AL

\_\_\_\_DH

\_\_\_\_SH

\_\_\_\_\_EL

10. Why does protected mode prevent programs from changing the EIP register directly?

11. True / False:

a.\_\_\_\_\_ A MASM program must have a procedure named "main".

b.\_\_\_\_ END main is a directive that tells the operating system where to begin execution of the program.