## COMPUTER ENGINEERING DEPARTMENT

COE 205

## COMPUTER ORGANIZATION \& ASSEMBLY PROGRAMMING

## Major Exam I

First Semester (091)
Time: 8:00-10:00 PM

Student Name : _KEY $\qquad$
Student ID. : $\qquad$

| Question | Max Points | Score |
| :---: | :---: | :---: |
| Q1 | 76 |  |
| Q2 | 12 |  |
| Q3 | 12 |  |
| Total | $\mathbf{1 0 0}$ |  |

(Q1) Fill the blank in each of the following:
(1) Assembly language is a programming language that uses symbolic names to represent operations, registers and memory locations.
(2) In an assembly instruction, the opcode specifies the particular operation to be performed.
(3) One of the main advantages of programming in high level language is that programs are portable.
(4) One of the main advantages of programming in assembly language is having smaller code size and faster execution.
(5) Development of a business application for multiple platforms is better done using high level language.
(6) The linker combines program's object file with other object files and libraries, and produces a single executable program.
(7) The instruction set architecture of a processor is composed of the instruction set, programmer-accessible registers, and memory.
(8) With the Pentium IV processor having a 36 bit address bus and a 64 bit data bus, the physical address space is $\underline{2^{36}=64 \mathrm{G}}$ bytes.
(9) The processor is interfaced with memory and input/output devices using data bus, address bus and control bus.
(10) The processor is composed of data path unit and control unit.
(11) Given a processor with 2 GHz clock frequency and a program executing in 1 billion clock cycles, the execution time of the program is $\left(1 / 2 \times 10^{9}\right) * 10^{9}=0.5$ sec.
(12) Cache memory is useful in reducing the memory access time, i.e. the time needed for reading instructions and data from memory (DRAM).
(13) Given a magnetic disk with the following properties: Rotation Speed $=6000$ RPM (rotations per minute), Average Seek $=5 \mathrm{~ms}$, Sector $=512$ bytes, Track = 200 sectors. The average time to access a block of 100 consecutive sectors is Average access time $=$ Seek Time + Rotation Latency + Transfer Time Rotations per second $=6000 / 60=100$ RPS Rotation time in milliseconds $=1000 / 100=10 \mathrm{~ms}$ Time to transfer 100 sectors $=(100 / 200)^{*} 10=5 \mathrm{~ms}$ Average access time $=5+5+5=15 \mathrm{~ms}$.
(14) The integer number -1500 is represented in hexadecimal using 16-bit 2's complement representation as FA24.
(15) Assuming 16-bit 2's complement representation, the hexadecimal number FE10 represents the decimal number -496 .
(16) Assuming 8-bit 2's complement representation, the largest number that can be stored is +127 in decimal and $\underline{\mathrm{F}}$ in hexadecimal and the smallest number that can be stored is $\underline{-128}$ in decimal and $\underline{80}$ in hexadecimal.
(17) Given that the number F6 is represented using 8-bit 2's complement representation, the equivalent number represented using 16-bit 2's complement representation is FFF6.
(18) Given that register $\mathrm{AL}=\mathrm{E} 5$ stores an ASCII character, then the stored character is $\underline{e}$ and the used parity is odd. Note that ' $A$ ' $=41 \mathrm{~h}$ and ' $a$ ' $=61 \mathrm{~h}$.
(19) The Pentium-IV processor contains the segment registers CS, SS, DS, ES, FS, GS.
(20) The EIP register holds the next instruction to be fetched from memory.
(21) After an instruction is fetched from memory, the EIP register is incremented by the size of the fetched instruction.
(22) During the execution phase of an instruction, the following tasks are performed: instruction decoding, operand fetch, executing the instruction, writing back the result.
(23) Given a 10 -stage pipeline where each stage executes in one clock cycle, executing 100 instructions without any pipeline stalls will require 109 cycles.
(24) A superscalar processor has multiple execution pipelines.
(25) In real addressing mode, assume that the code segment occupies the address range from 0A6F0 to 0E007. Then, the code segment number is 0 A 6 F , the size of the code segment is $3918 \mathrm{~h}=14616$ bytes and the next available free segment is 0E01.
(26) Assume that $\mathrm{DS}=1234, \mathrm{CS}=5678, \mathrm{ES}=9 \mathrm{ABC}, \mathrm{SS}=\mathrm{DEF0}, \mathrm{IP}=01 \mathrm{~F} 4, \mathrm{BX}=\mathrm{E} 678$, and $\mathrm{SP}=2314$. Based on 16 -bit real-mode addressing, the linear address of the next instruction to be fetched from memory is $56780+01 \mathrm{~F} 4=56974$.
(27) Assume that $\mathrm{DS}=1234, \mathrm{CS}=5678$, $\mathrm{ES}=9 \mathrm{ABC}, \mathrm{SS}=\mathrm{DEF0}, \mathrm{IP}=01 \mathrm{~F} 4, \mathrm{BX}=\mathrm{E} 678$, and $\mathrm{SP}=2314$. Given that offset of variable I is 001 F , based on 16 -bit real addressing mode, the linear address of the source operand in the instruction MOV AX , I is $\underline{12340+001 \mathrm{~F}=1235 \mathrm{~F}}$.
(28) In protected mode, the segment unit translates logical address to linear address while the paging unit translates linear address to physical address.
(29) In protected mode, the segment descriptor table stores the following information for each segment base address, segment limit, access rights.
(30) The assembler allocates $\underline{10 *(10+2)+1=121}$ bytes for the variable String defined below:

String Byte $10 \operatorname{dup}(10 \operatorname{dup}(0), 10,13), 0$
(31) The content of register EAX after executing the following code segment is 00000017.

I=10
MOV EAX, I
I=I +3
ADD EAX, I
(32) Assuming the following data segment, and assuming that variable X is given the linear address 00404000 h , then the linear address for variables Y and Z will be $\underline{00404004 \mathrm{~h}}$ and $\underline{0040400 \mathrm{Ch}}$.
.DATA
X BYTE 1, 2, 3
ALIGN 2
Y WORD 4, 5, 6
ALIGN 4
Z DWORD 7, 8,9
(33) Assuming the following data segment, and assuming that variable X is given the linear address 00404000 h , then the content of register EAX after executing the instruction MOV AX, Y-8 is $\underline{0001 .}$
.DATA
X BYTE "MAJOR EXAM I"
DWORD 1, 2
Y WORD 3,4
(34) Assuming the following data segment, and assuming that variable $X$ is given the linear address 00404000 h , after executing the code given below, the content of register EAX= $\underline{2}$ and $E B X=\underline{00404004 h}$.
.DATA
X WORD 1,2
Y DWORD 3, 4
.CODE
MOV EAX, TYPE X
MOV EBX, OFFSET Y
(35) After executing the code given below, the content of registers EAX and EBX will be $\underline{2}$ and 4 .
.DATA
ARRAY WORD 1,2
WORD 3, 4
WORD 5, 6
.CODE
MOV EAX, LENGTHOF ARRAY
MOV EBX, SIZEOF ARRAY
(36) After executing the code given below, the content of register EAX will be 00040003.
.DATA
ARRAY WORD 1, 2, 3, 4, 5, 6, 7, 8
.CODE
MOV EAX, DWORD PTR ARRAY+4
(37) Assuming variable ARRAY is defined as shown below:

ARRAY DWORD 1, 2, 3, 4, 5, 6, 7, 8
The content of register AX after executing the instruction MOV AX, WORD PTR ARRAY +1 will be $\underline{0000}$.
(38) Assume that $A X=A B 4 D$. Executing the instruction MOVSX EAX, AX produces the result EAX=FFFFAB4D.
(39) Assume that $\mathrm{AX}=\mathrm{EABF}$ and $\mathrm{BX}=\mathrm{FF} 6 \mathrm{~F}$. Executing the instruction $A D D A X$,
 flag $=\underline{0}$, carry flag=1, auxiliary flag=1 and parity flag=1.
(40) Assume that $\mathrm{AX}=\mathrm{EABF}$ and $\mathrm{BX}=\mathrm{FF} 6 \mathrm{~F}$. Executing the instruction $\mathrm{SUB} A X$, $B X$ produces the following results: $A X=\underline{E B 50}$, overflow flag= $\underline{0}$, sign flag=1, zero flag $=0$, carry flag $=\underline{1}$, auxiliary flag= $\underline{0}$ and parity flag $=\underline{1}$.
(Q2) Consider a program that has the following data segment assuming a flat memory model:

| $X$ | $E Q U$ | 1 |
| :--- | :--- | :--- |
| $Y$ | $E Q U$ | $A H$ |
| $Z$ | $B Y T E$ | 1,2 |
| $W$ | WORD | $X-2, X+2$ |

Indicate whether the following are valid IA-32 instructions or not. If invalid, give the reason:

1. MOV AL, $\mathrm{Z}+2$

Valid. (memory to register of the same size)
2. MOV Z, Y

Valid. (register to memory of the same size)
3. MOV DS, ES

Invalid. Segment register cannot be moved directly to another segment register.
4. MOV ES, X+1

Invalid. Immediate value cannot be moved directly to a segment register.
5. MOV W, OFFSET Z

Invalid. Size mismatch as offset is 32-bits while W is 16-bits.
6. MOVSX W, AL

Invalid. The destination in MOVSX must be a register.
7. MOV W, Word PTR Z

Invalid. Memory to memory is not allowed.
8. ADD DS, AX

Invalid. Segment registers cannot be operands for the ADD instruction.
(Q3) Suppose that the following directives are declared in the data segment with a starting linear address of 00404000. Show the linear addresses of allocated memory and their corresponding content in hexadecimal. Note that the ASCII code for character ' $a$ ' is 61 h and that of character ' A ' is 41 h . The ASCII code of character ' 0 ' is 30 h .

| I | BYTE | "EXAM I",0 |
| :--- | :--- | :--- |
|  | WORD | $15,-15$ |
| J | DWORD | $100,-100$ |
| K | EQU | 1 1Fh |
| L | BYTE | $\mathrm{K}+1$ |
|  | BYTE | $2,3$ dup( -2$)$ |


| Variable | Linear Address (Hex.) | Content (Hex.) |
| :---: | :---: | :---: |
| I | 00404000 | 'E' |
|  | 00404001 | 'X' |
|  | 00404002 | 'A' |
|  | 00404003 | 'M' |
|  | 00404004 | ' |
|  | 00404005 | 'I' |
|  | 00404006 | 0 |
|  | 00404007 | 0 F |
|  | 00404008 | 00 |
|  | 00404009 | F1 |
|  | 0040400 A | FF |
|  | 0040400 B | 64 |
|  | 0040400 C | 00 |
|  | 0040400 D | 00 |
|  | 0040400 E | 00 |
|  | 0040400 F | 9 C |
|  | 00404010 | FF |
|  | 00404011 | FF |
|  | 00404012 | FF |
|  | 00404013 | 20 |
|  | 00404014 | 02 |
|  | 00404015 | FE |
|  | 00404016 | FE |
|  | 00404017 | FE |
|  |  |  |

