KAFR-ELSHIEKH UNIVERSITY FACULTY OF ENGINEERING TIME ALLOWED: 3 HOURS # ELECTRICAL ENGINEERING DEPARTMENT COMPUTER ENGINEERING AND SYSTEMS BRANCH 2<sup>ND</sup> YEAR FINAL EXAM OF 1<sup>ST</sup> SEMESTER 2017 - 2018 MICROPROCESSOR SYSTEMS [CODE NO. ECS 2006] The maximum mark for the examination paper is 60 marks, and the mark obtainable for each part of a question is shown in brackets alongside the question. ## QUESTION NUMBER ONE [30 MARKS] Compatibility between the later and earlier microprocessors has been a successful strategy for the Intel family. Give two distinct examples of the modifications that demonstrate this compatibility. Afterwards, mention the elements which effect of microprocessor performance speed. [5 Marks] 2. Show an example of subtracting two 7-bit signed numbers that result in an overflow, thus rendering the final 7-bit difference invalid. Show both the numbers being subtracted and the resulting invalid difference. [2 Marks] 3. Write descriptive note on paging; explain how it is used for memory addressing. After that, use the descriptor definition to calculate the appropriate linear address. If the microprocessor sends this linear address to the paging mechanism, which memory segment is accessed (Assume CR3 contains 00002H)? Justify your answer. [12 Marks] 4. What is the address of next instruction for the following (justify your answer): [4 Marks] - a) 0B03:0106 7218 JC 0120H - b) If JC is replaced with JO, what is the address of the next instruction? Debug screen: OV UP EL NG NZ NA PO NC - 5. What is the use of these assembler directives? [3 Marks] - a) DB - b) .MODEL tiny - 6. Mention how the following instructions differ in their functionality: [4 Marks] - a) NEG & NOT - b) DIV & IDIV - c) AND & TEST - d) CMP & SUB ## QUESTION NUMBER TWO [30 MORKS] 1. In Intel 8086 microprecessor, why is the segment register content appended by "0" to generate the physical address? What are the maximum number of non-overlapping segment for Intel 80386 microprocessor operated in the real and protect modes? [4 Marks] 2. Which of the following instruction is a correct assembly instruction and which is not? Why? Correct if possible. [6 Marks] - a) MOV AL, [SI+DI] - b) PUSH AL - c) INC ISIT - d) ADD [0108H], [0220H] - e) MOV BL, [CX] - f) ADD BX, AL Swap the word at memory location 24000H with 25000H. Next, write an assembly language program to find the largest signed number from a set of 10 bytes stored at array. The greatest number must be stored at location RES. [7 Marks] 4. Write a single logical instruction for each of the following operations. Note that, no other changes should occur. [5 Marks] - a) Set the most significant nibble in AX to 1; - b) Clear the even numbers bits in AX to 0: - c) Invert bit number 0, 5, 10, and 15 in AX; - d) Change the sign of the content of AX, - e) Multiply the content of AX by 16. - 5. Describe how the LDS BX, NUMB instruction operates. [2 Marks] 6. Mention at least 4-types of data addressing modes (use examples to illustrate your answer). Henceforth, give the assembly instruction encoded by the following: [6 Marks] | 32-bit mode selected R/M | | | | | 16-bit mode selected R/M | | | | | | | |--------------------------|----------------|------------|-------------|-----|--------------------------|---------|------------|-------------|-----|--|--| | MOD | 00 | -01 | 10 | 11 | | 00 | 01 | 10 | W=1 | | | | B/M | | • | 216 | W=0 | W=1 | | 9: | | | | | | 900 | EAX | EAX+118 | EAX + d32 | AL | EAX | [BX+SI] | [BX+SI+d8] | [BX+SI+d16] | AX | | | | 001 | ECX | ECX+48 | EGX+d32 | CL | ECX | [BX+01] | [BX+01+d8] | [BX+DI+d16] | CX | | | | 010 | EBX | E0X+d8 | EDX + d32 | BL | EDX | [BP+SI] | (BP+SI+d6) | [BP+SI+d16] | DX | | | | Off | EBX | EBX+d8 | EBX + 432 | BL | EBX | [BP+DI] | [BP+DI+d8] | [BP+DI+d16] | BX | | | | 100 | Scale<br>index | Scale + d8 | Scale + d32 | AH | ESP | [21] | [SI+48] | [SI+d16] | SP | | | | 101 | d32 | EPB+d8 | EPB+d32 | CH | EBP | [01] | [DI + 48] | [84+49] | BP | | | | 110 | ESI | ESI+d8 | ESI+d32 | DH | ESI | d16 | [BP+d8] | [BP+d16] | SI | | | | 111 | EDI | ED1+48 | EDI + d32 | BH | EDI | [BX] | [BX+d8] | [BX+dt6] | BI | | | ### 80386/80486/Pentium/Pentium Pro descriptor | Base<br>B31 | <b>B24</b> | Đ | o ( | Limit<br>Lis Lie | Access Rights | Base<br>B23 | B16 | | |-------------|------------|---|-----|------------------|---------------|-------------|-----|--| | Base | | | | | Limit | | | | | B15 80 | | | | | L15 L6 | | | | The access rights byte for the 80286 through Core2 descriptor. ### Segment register prefix override | Segment Reg. | ES | CS | SS | DS | FS | GS | | |-----------------|-----|-----|-----|-----|-----|-----|--| | Prefix Override | 26H | 2EH | 36H | 3EH | 64H | 65H | | 11 January 2018 10:00 AM