ELECTRICAL ENGINEERING DEPARTMENT COMPUTER ENGINEERING AND SYSTEMS BRANCH 2<sup>ND</sup> YEAR FINAL EXAM OF 2<sup>ND</sup> SEMESTER 2015 - 2016 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. Instructions to the candidates: KAFR-ELSHIEKH UNIVERSITY FACULTY OF ENGINEERING TIME ALLOWED: 3 HOURS - Clarify your answer with the suitable sketches as you can. - Please use a pen or heavy pencil to ensure legibility. - Please attempt all questions. ## **QUESTION NUMBER ONE [15 MARKS]** - Explain what the SBB [DI 4], DX accomplishes. If AL=F3, BH=72 and DH =FF, list the contents of each register and the contents of each flags after the following tasks: - a) XADD BH, DH - b) CMPXCHG BH, DH [4 Marks] - 2. Select the correct instruction to perform each of the following tasks: - a) Shift DI three places, with zeros moved into the leftmost bit; - b) Invert the leftmost 10 bits of the BX register without changing the rightmost 6 bits. - c) Move the DH register right one place, making sure that the sign of the result is the same as the sign of the original number [5 Marks] 3. What is done with the remainder after a division? Afterward, write a short sequence of instructions that divides the number in AX by the number in BL and then round the unsigned result. Then, write a short sequence of instructions that divides the number in BL by the number in CL and then multiplies the result by 2. The final answer must be a 16-bit number stored in the DX register. [6 Marks] ## QUESTION NUMBER TWO [15 MARKS] - 1. Contrast the operation of JMP [DI] with JMP FAR PTR [DI]. Which type of JMP instruction (short, near, or far) assembles for the following: - a) If the distance is 0210H bytes - b) If the distance is 0020H bytes - c) If the distance is 10000H bytes [5 Marks] Write a complete assembly program that uses while loop to read data from the keyboard and store it into an extra memory segment array called BUF until CR key "OD<sub>H</sub>" is typed. [5 Marks] 3. Explain the purpose of the trap flag. Write a procedure that clears the TF to disable trapping. [5 Marks] ## QUESTION NUMBER THREE [15 MARKS] 1. Where are the interrupt vectors located in the microprocessor's memory? Then describe the differences between a protected and real mode interrupt. After that, list the events that occur when an interrupt becomes active. [4 Marks] 2. When a hardware interrupt occurs, how does the microprocessor determine the interrupt vector type number? In your explanation, I expect to see a circuit diagram that applies any interrupt vector type number in response to INTA pin. [6 Marks] 3. Explain the operation of the IRET. When will the BOUND instruction interrupt a program? What is the purpose of interrupt vector type number 3? [5 Marks] ## QUESTION NUMBER FOUR [15 MARKS] 1. Show the contents in hexadecimal of registers PC, AR, DR, IR, and SC of the basic computer when an ISZ indirect instruction is fetched from memory and executed. The initial content of PC is 7FF. The content of memory at address 7FF is EA9F. The content of memory at address A9F is 0C35. The content of memory at address C35 is FFFF. Give the answer in a table with five columns, one for each register and a row for each timing signal. Show the contents of the registers after the positive transition of each clock pulse. [5 Marks] 2. Show the gate structure associated with the control inputs of AR. In similar fashion derive the control gates for the read & write inputs of the memory in the basic computer. [5 Marks] - 3. The following register transfers are to be executed in basic computer. For each transfer, Specify: - A. The binary value that must be applied to bus select inputs S2, S1, and S0; - B. The register whose LD control input must be activate (if any); - C. A memory read or write operation (if needed); and - D. The operation in the adder and logic circuit (if any). - AR ← PC - 2. $IR \leftarrow M[AR]$ - 3. $M[AR] \leftarrow TR$ - 4. $AC \leftarrow AC + DR$ [3 Marks] 4. Derive the Boolean expression for X2. [2 Marks] ``` Q ``` ``` AR \leftarrow PC R'T0: \label{eq:local_local_local_local} \begin{array}{l} \text{IR} \leftarrow \text{M[AR], PC} \leftarrow \text{PC} + 1 \\ \text{D0, ..., D7} \leftarrow \text{Decode IR} (12 \sim 14), \text{AR} \leftarrow \text{IR} (0 \sim 11), \text{I} \leftarrow \text{IR} (15) \\ \end{array} Fetch R'T1: R'T2: Decode AR \leftarrow M[AR] D7'IT3: Indirect Interrupt: R \leftarrow 1 AR \leftarrow 0, TR \leftarrow PC M[AR] \leftarrow TR, PC \leftarrow 0 PC \leftarrow PC + 1, IEN \leftarrow 0, R \leftarrow 0, SC \leftarrow 0 RT0: RT1: \begin{array}{l} \mathsf{DR} \leftarrow \mathsf{M}[\mathsf{AR}] \\ \mathsf{AC} \leftarrow \mathsf{AC} \cdot \mathsf{DR}, \mathsf{SC} \leftarrow 0 \\ \mathsf{DR} \leftarrow \mathsf{M}[\mathsf{AR}] \\ \mathsf{AC} \leftarrow \mathsf{AC} + \mathsf{DR}, \mathsf{E} \leftarrow \mathsf{Cout}, \mathsf{SC} \leftarrow 0 \\ \mathsf{DR} \leftarrow \mathsf{M}[\mathsf{AR}] \\ \mathsf{AC} \leftarrow \mathsf{DR}, \mathsf{SC} \leftarrow 0 \\ \mathsf{M}[\mathsf{AR}] \leftarrow \mathsf{AC}, \mathsf{SC} \leftarrow 0 \\ \mathsf{PC} \leftarrow \mathsf{AR}, \mathsf{SC} \leftarrow 0 \\ \mathsf{M}[\mathsf{AR}] \leftarrow \mathsf{PC}, \mathsf{AR} \leftarrow \mathsf{AR} + 1 \\ \mathsf{PC} \leftarrow \mathsf{AR}, \mathsf{SC} \leftarrow 0 \\ \mathsf{DR} \leftarrow \mathsf{M}[\mathsf{AR}] \\ \mathsf{DR} \leftarrow \mathsf{DR} + 1 \\ \mathsf{M}[\mathsf{AR}] \leftarrow \mathsf{DR}. \text{ if}(\mathsf{DR} = 0) \text{ then } (\mathsf{PC} \leftarrow \mathsf{M}[\mathsf{AR}]) \\ \mathsf{M}[\mathsf{AR}] \leftarrow \mathsf{DR}. \text{ if}(\mathsf{DR} = 0) \text{ then } (\mathsf{PC} \leftarrow \mathsf{M}[\mathsf{AR}]) \\ \mathsf{M}[\mathsf{AR}] \leftarrow \mathsf{DR}. \text{ if}(\mathsf{DR} = 0) \text{ then } (\mathsf{PC} \leftarrow \mathsf{M}[\mathsf{AR}]) \\ \mathsf{M}[\mathsf{AR}] \leftarrow \mathsf{DR}. \text{ if}(\mathsf{DR} = 0) \text{ then } (\mathsf{PC} \leftarrow \mathsf{M}[\mathsf{AR}]) \\ \mathsf{M}[\mathsf{AR}] \leftarrow \mathsf{DR}. \text{ if}(\mathsf{DR} = 0) \text{ then } (\mathsf{PC} \leftarrow \mathsf{M}[\mathsf{AR}]) \\ \mathsf{M}[\mathsf{AR}] \leftarrow \mathsf{DR}. \text{ if}(\mathsf{DR} = 0) \text{ then } (\mathsf{PC} \leftarrow \mathsf{M}[\mathsf{AR}]) \\ \mathsf{M}[\mathsf{AR}] \leftarrow \mathsf{DR}. \text{ if}(\mathsf{DR} = 0) \text{ then } (\mathsf{PC} \leftarrow \mathsf{M}[\mathsf{AR}]) \\ \mathsf{M}[\mathsf{AR}] \leftarrow \mathsf{DR}. \text{ if}(\mathsf{DR} = 0) \text{ then } (\mathsf{PC} \leftarrow \mathsf{M}[\mathsf{AR}]) \\ \mathsf{M}[\mathsf{AR}] \leftarrow \mathsf{DR}. \text{ if}(\mathsf{DR} = 0) \text{ then } (\mathsf{PC} \leftarrow \mathsf{M}[\mathsf{AR}]) \\ \mathsf{M}[\mathsf{AR}] \leftarrow \mathsf{DR}. \text{ if}(\mathsf{DR} = 0) \text{ then } (\mathsf{PC} \leftarrow \mathsf{M}[\mathsf{AR}]) \\ \mathsf{M}[\mathsf{AR}] \leftarrow \mathsf{DR}. \text{ if}(\mathsf{DR} = 0) \text{ then } (\mathsf{PC} \leftarrow \mathsf{M}[\mathsf{AR}]) \\ \mathsf{M}[\mathsf{AR}] \leftarrow \mathsf{DR}. \text{ if}(\mathsf{DR} = 0) \text{ then } (\mathsf{PC} \leftarrow \mathsf{M}[\mathsf{AR}]) \\ \mathsf{M}[\mathsf{AR}] \leftarrow \mathsf{DR}. \text{ if}(\mathsf{DR} = 0) \text{ then } (\mathsf{PC} \leftarrow \mathsf{M}[\mathsf{AR}]) \\ \mathsf{M}[\mathsf{AR}] \leftarrow \mathsf{DR}. \text{ if}(\mathsf{DR} = 0) \text{ then } (\mathsf{PC} \leftarrow \mathsf{M}[\mathsf{AR}]) \\ \mathsf{M}[\mathsf{AR}] \leftarrow \mathsf{DR} + \mathsf{DR} + \mathsf{DR}[\mathsf{AR}] \\ \mathsf{M}[\mathsf{AR}] \leftarrow \mathsf{DR}[\mathsf{AR}] \\ \mathsf{M}[\mathsf{AR}] \leftarrow \mathsf{DR}[\mathsf{AR}] \\ \mathsf{M}[\mathsf{AR}] \leftarrow \mathsf{DR}[\mathsf{AR}] \\ \mathsf{M}[\mathsf{AR}] \leftarrow \mathsf{DR}[\mathsf{AR}] \\ \mathsf{M}[\mathsf{AR}] \leftarrow \mathsf{DR}[\mathsf{AR}] \\ \mathsf{M}[\mathsf{AR}] \\ \mathsf{M}[\mathsf{AR}] \leftarrow \mathsf{DR}[\mathsf{AR}] \\ \mathsf{M}[\mathsf{AR}] Memory-Reference: D0T4: AND D0T5: D1T4: ADD D1T5: D2T4: LDA D2T5: D3T4: STA D4T4: BUN D5T4: BSA D5T5: D6T4: ISZ D6T5: M[AR] \leftarrow DR, if(DR=0) then (PC \leftarrow PC + 1), SC \leftarrow 0 D6T6: Register-Reference: (Common to all register-reference instructions) D7l'T3 = r IR(i) = Bi (i = 0,1,2,...,11) SC ← 0 AC \leftarrow 0 CLA rB11: rB10: E \leftarrow 0 CLE AC ← AC' E ← E' rB9: CMA rB8: CME AC \leftarrow shr AC, AC(15) \leftarrow E, E \leftarrow AC(0) rB7: CIR AC \leftarrow shl AC, AC(0) \leftarrow E, E \leftarrow AC(15) rB6: CIL AC ← AC + 1 rB5: INC If(AC(15) =0) then (PC \leftarrow PC + 1) rB4: If(AC(15) =1) then (PC ← PC + 1) SPA SNA rB3: If (AC = 0) then (PC \leftarrow PC + 1) rB2: SZA If (E=0) then (PC \leftarrow PC + 1) rB1: SZE s \leftarrow 0 rB0: HLT Input-Output: (Common to all input-output instructions) D7IT3 = p (i = 6,7,8,9,10,11) IR(i) = Bi SC \leftarrow 0 AC(0-7) \leftarrow INPR, FGI \leftarrow 0 pB11: INP OUTR \leftarrow AC(0-7), FGO \leftarrow 0 If(FGI=1) then (PC \leftarrow PC + 1) pB10: OUT pB9: SKI If(FGO=1) then (PC ← PC + 1) pB8: SKO IEN ← 1 pB7: ION ``` IEN ← 0 pB6: **IOF**