## 16.317: Microprocessor Systems Design I

Fall 2015

## Homework 2 Due **2:00 PM, Friday, 9/25/15**

## **Notes:**

- While typed solutions are preferred, handwritten solutions are acceptable.
- All solutions must be legible and contained in one file. Archive files are not acceptable.
- Electronic submissions should be e-mailed to Dr. Geiger at Michael Geiger@uml.edu.
- This assignment is worth 100 points.
- 1. (60 points) (75 points) Assume the state of an x86 processor's registers and memory are:

|                | Address |    |    |    |    |
|----------------|---------|----|----|----|----|
| EAX: 00000010H | 20100H  | 10 | 00 | 80 | 00 |
| EBX: 00000020H | 20104H  | 10 | 10 | FF | FF |
| ECX: 00000030H | 20108H  | 80 | 00 | 19 | 91 |
| EDX: 0000040H  | 2010CH  | 20 | 40 | 60 | 80 |
| CF: 1          | 20110H  | 02 | 00 | AB | 0F |
| ESI: 00020100H | 20114H  | 30 | 00 | 11 | 55 |
| EDI: 00020100H | 20118H  | 40 | 00 | 7C | EE |
|                | 2011CH  | FF | 00 | 42 | D2 |
|                | 20120H  | 30 | 00 | 30 | 90 |

What is the result produced in the destination operand by each of the instructions listed below? Assume that the instructions execute in sequence.

ADD AX, 00FFh
ADC CX, AX
INC BYTE PTR [20100h]
SUB DL, BL
SBB DL, [20114h]
DEC BYTE PTR [EDI+EBX]
NEG BYTE PTR [EDI+0018h]
MUL DX
IMUL BYTE PTR [ESI+0006h]
DIV BYTE PTR [ESI+0008h]
IDIV BYTE PTR[ESI+0010h]

ystems Design I Instructor: M. Geiger Homework 2

2. (40 points) (25 points, +1 extra credit point per correct instruction) Assume the state of an x86 processor's registers and memory are:

| EAX: 00005555H | Address            |
|----------------|--------------------|
| EBX: 00045010H | 45100H OF F0 00 FF |
| ECX: 00000010H |                    |
| EDX: 0000AAAAH | 45200H 30 00 19 91 |
| ESI: 000000F2H |                    |
| EDI: 00000200H | 45210H AA AA AB 0F |
|                |                    |
|                | 45220H 55 55 7C EE |
|                |                    |
|                | 45300H AA 55 30 90 |

What is the result produced in the destination operand by each of the instructions listed below? Assume that the instructions execute in sequence.

AND BYTE PTR [45300H], 0FH SAR DX, 8 OR [EBX+EDI], AX SHL AX, 2 XOR AX, [ESI+EBX] NOT BYTE PTR [45300H] SHR AX, 4