## KING FAHD UNIVERSITY OF PETROLEUM & MINERALS COMPUTER ENGINEERING DEPARTMENT

## COE 205 Computer Organization & Assembly Language Term 052 Lecture Breakdown

| Lec<br># | Date    | Topics                                                                                                                                                                                                                                                                               | Ref.                                                                                       | Lab                         |
|----------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|-----------------------------|
|          | S 10/9  |                                                                                                                                                                                                                                                                                      |                                                                                            | Introduction,<br>using MASM |
| 1        | M 13/2  | Syllabus. <b>Introduction</b> . Computer System,<br>CPU, Memory, CPU-Memory Interface,<br>Data Bus, Address Bus, Control Bus.<br>Machine Type. Memory Hierarchy: RAM,<br>ROM.                                                                                                        | Chapter1<br>(Organization)<br>& Chapter 1<br>(Assembly)                                    |                             |
| 2        | W 15/2  | Cache, Registers. Machine Language,<br>Assembly Language. Instruction Formats,<br>Opcode, Operands. Stored Program<br>Concept,                                                                                                                                                       | Chapter1<br>(Organization)<br>& Chapter 1<br>(Assembly)                                    |                             |
| 3        | Th 16/2 | Fetch-Execute Cycle, Instruction Pointer.<br>Instruction Register. Why assembly<br>language programming. Data Typing in<br>High Level and Assembly Language,<br>Assembler, Linker, Debugger.<br>Programmer's view of the computer,<br>Instruction Set Architecture (ISA).            | Chapter1<br>(Organization)<br>& Chapter 1<br>(Assembly)                                    |                             |
|          | S 18/2  |                                                                                                                                                                                                                                                                                      |                                                                                            | Introduction,<br>using MASM |
| 4        | S 18/2  | ISA of i8086 processor. Interfacing the CPU<br>to memory & I/O. Types of Buses. One and<br>Two-bus Architectures. <b>Number</b><br><b>representation</b> .                                                                                                                           | Chapter1<br>(Organization)<br>& Chapter 1<br>(Assembly)<br>Appendix A &<br>E<br>(Assembly) |                             |
| 5        | M 20/2  | Number representation: Binary, Octal,<br>Hex. base conversion, fraction<br>representation, unsigned and signed<br>numbers Signed Number Representation:<br>Sign-magnitude, 1's complement, 2's<br>complement. Sign Extension. Overflow<br>detection for unsigned and signed numbers. | Appendix A &<br>E<br>(Assembly)                                                            |                             |
| 6        | W 22/2  | Character Representation. ASCII Code.<br>Even and Odd Parity. (Quiz#1)                                                                                                                                                                                                               | Appendix A &<br>E<br>(Assembly)                                                            |                             |

|    | S 25/2 |                                                                                                                                     |                                           | Assembly<br>Format &Data<br>Representation          |
|----|--------|-------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|-----------------------------------------------------|
| 7  | S 25/2 | Assembly language syntax & Program<br>Structure. Instruction types. Assembler<br>directives.                                        | Chapter 3<br>(Assembly)                   |                                                     |
| 8  | M 27/2 | Variable Declaration: DB, DW, DD. PTR<br>operator. Offset operator. Constant<br>declaration using EQU.                              | Chapter 3<br>(Assembly)                   |                                                     |
| 9  | W 1/3  | DUP operator. Input/Output using INT<br>21H.: Reading character, Displaying<br>character, Displaying a string. LOOP<br>Instruction. | Chapter 3 &<br>Section 12.5<br>(Assembly) |                                                     |
|    | S 4/3  |                                                                                                                                     |                                           | Input/Output                                        |
| 10 | S 4/3  | Input/Output using INT 21H.: Reading<br>character, Displaying character, Displaying<br>a string, Reading a string.                  | Chapter 3 &<br>Section 12.5<br>(Assembly) |                                                     |
|    | U 5/3  | Replacing CR with '\$' character , <b>8086</b><br>registers. Memory Segmentation, Logical<br>& Physical Address.                    | Chapter 3 & 5<br>(Assembly)               |                                                     |
| 11 | M 6/3  | (Quiz#2)                                                                                                                            |                                           |                                                     |
| 12 | W 8/3  | No class.                                                                                                                           |                                           |                                                     |
|    | S 11/3 |                                                                                                                                     |                                           | Segment. &<br>Addressing<br>Modes                   |
| 13 | S 11/3 | Memory Segmentation, Logical & Physical<br>Address. 8086 Addressing Modes:<br>Immediate, Register, Direct, Register-<br>Indirect.   | Chapter 3 & 5<br>(Assembly)               |                                                     |
| 14 | M 13/3 | <b>8086 Addressing Modes</b> : Based, Indexed, Based-Indexed.                                                                       | Chapter 3 & 5<br>(Assembly)               |                                                     |
| 15 | W 15/3 | <b>Pentium Registers</b> . <b>Pentium Addressing</b><br><b>Modes</b> . (Quiz#3).                                                    | Chapter 3 & 5<br>(Assembly)               |                                                     |
|    | S 18/3 |                                                                                                                                     |                                           | Array<br>indexing &<br>Pentium<br>Address.<br>Modes |
| 16 | S 18/3 | Status & Flags Register. <b>Basic Pentium</b><br><b>Instructions</b> : MOV, XCHG.                                                   | Chapter 3 & 5<br>& 6<br>(Assembly)        |                                                     |
| 17 | M 20/3 | <b>Basic Pentium Instructions</b> : XCHG, LEA, MOVZX, MOVSX, XLATB, ADD, INC.                                                       | Chapter 3 & 5<br>& 6<br>(Assembly)        |                                                     |
| 18 | W 22/3 | <b>Basic Pentium Instructions</b> : SUB, DEC, NEG. CMP instruction, Introduction to flow control instructions.                      | Chapter 3 & 5<br>& 6<br>(Assembly)        |                                                     |

|    | S 25/3 |                                                                                                                                                                                                     |                                    | Arithmetic<br>Instructions           |
|----|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|--------------------------------------|
| 19 | S 25/3 | ADC, SBB. Review for Exam I.                                                                                                                                                                        | Chapter 3 & 5<br>& 6<br>(Assembly) |                                      |
|    | U 26/3 | MAJOR EXAM I                                                                                                                                                                                        |                                    |                                      |
| 20 | M 27/3 | Multiplication Instructions: MUL, IMUL.<br>Pentium IMUL instructions. Division<br>Instructions: DIV, IDIV. Sign Extension<br>Instructions: CBW, CWD, CDQ.                                           | Chapter 3 & 5<br>& 6<br>(Assembly) |                                      |
| 21 | W 29/3 | Applications of Multiplication & Division<br>instruction. Logical Instructions: NOT,<br>AND, OR, XOR, Test. Applications of logic<br>instructions.                                                  | Chapter 3 & 6<br>& 8<br>(Assembly) |                                      |
|    | S 1/4  |                                                                                                                                                                                                     |                                    | Logical &<br>Bitwise<br>Instructions |
| 22 | M 3/4  | <b>Shift Instructions</b> : SHL, SAL, SHR, SAR.<br>Applications of using shift instructions in<br>performing multiplication. Applications of<br>using shift instructions in performing<br>division. | Chapter 3 & 6<br>& 8<br>(Assembly) |                                      |
| 23 | W 4/4  | HLD, SHRD. <b>Rotate Instructions</b> : ROL,<br>ROR, RCL, RCR. Applications of rotate<br>instructions.                                                                                              | Chapter 3 & 6<br>& 8<br>(Assembly) |                                      |
|    | S 8/4  |                                                                                                                                                                                                     | • · · · · ·                        | Flow Control<br>Instructions         |
| 24 | S 8/4  | <b>Flow Control Instructions</b> : Unconditional JMP. Types of jump target: Short, Near, Far. ( <b>Quiz#4</b> ).                                                                                    | Chapter 7 & 4<br>(Assembly)        |                                      |
| 25 | M 10/4 | Conditional Jump instructions: Signed and<br>Unsigned. Single-flag jump instructions.<br>Loop Instructions: Loop, Loope/Loopz,<br>Loopne/Loopnz.                                                    | Chapter 7 & 4<br>(Assembly)        |                                      |
| 26 | W 12/4 | High-Level Decision Control Structures: IF-<br>Then-Else, For Loop, Case. While Loop,<br>Repeat Until. Indirect Jump Example. <b>The</b><br><b>Stack</b> : PUSH and POP instructions.               | Chapter 7 & 4<br>(Assembly)        |                                      |
|    | S 15/4 |                                                                                                                                                                                                     |                                    | Procedures &<br>Macros               |
| 27 | S 15/4 | Stack instructions: PUSHA, POPA,<br>PUSHAD, POPAD, PUSHF, POPF,<br>PUSHFD, POPFD. <b>Introduction to</b><br><b>Procedures</b> : CALL and RET                                                        | Chapter 7 &<br>4&10<br>(Assembly)  |                                      |
| 28 | M 17/4 | Procedure Definition, Near and Far<br>Procedures, RET n instruction. Passing<br>Parameters to Procedures.                                                                                           | Chapter 7 &<br>4&10<br>(Assembly)  |                                      |

| 29 | W 19/4          | <b>Introduction to Macros</b> . Macro Definition & Expansion. Pseudo parameters in macros. Macros versus procedures.                                                                                                                                  | Chapter 10<br>(Assembly)        |                        |
|----|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|------------------------|
|    | S 22/4          |                                                                                                                                                                                                                                                       |                                 | String<br>Instructions |
| 30 | S 22/4          | Macro Library. Examples of Macros. REP macros. (Quiz#5)                                                                                                                                                                                               | Chapter 10<br>(Assembly)        |                        |
| 31 | M 24/4          | REP and IRP macros. Conditional assembly.                                                                                                                                                                                                             | Chapter 10<br>(Assembly)        |                        |
| 32 | W 26/4          | <b>String Instructions</b> : MOVS, MOVSB,<br>MOVSW, MOVSD. REP Prefix.<br>CMPS, CMPSB, CMPSW, CMPSD.                                                                                                                                                  | Chapter 9<br>(Assembly)         |                        |
|    | S 29/4          |                                                                                                                                                                                                                                                       |                                 | Interrupts             |
| 33 | S 29/4          | SCAS, SCASB, SCASW, SCASD, LODS,<br>LODSB, LODSW, LODSD, STOS, STOSB,<br>STOSW, STOSD, REPE, REPNE.<br>Applications of string instructions.<br><b>Input/Output</b> : IN and OUT instructions,<br>Direct and Indirect I/O. String I/O<br>instructions. | Chapter 9 &<br>12<br>(Assembly) |                        |
| 34 | M 1/5           | <b>Introduction to Interrupts</b> . Difference<br>between interrupts and procedures. Types of<br>Interrupts: Hardware. Software, Exceptions.<br>Maskable and non-maskable Interrupts,<br>Interrupt Flag. ( <b>Quiz#6</b> )                            | Chapter 12<br>(Assembly)        |                        |
| 35 | W 3/5           | Interrupt Processing, IVT, Trap Flag, Bios and DOS interrupts.                                                                                                                                                                                        | Chapter 12<br>(Assembly)        |                        |
|    | S 6/5           |                                                                                                                                                                                                                                                       |                                 | Video<br>Memory        |
| 36 | S 6/5           | Register Transfer. <b>Data-Path Design</b> .<br>Connecting Registers using Muxs.<br>Connecting Registers using a tri-state bus.                                                                                                                       | Chapter 2 & 4<br>(Organization) |                        |
| 37 | M 8/5<br>(Ext.) | Examples of register transfer: MOV,<br>XCHG, ADD. Register Transfer Timing:<br>Estimating<br>Minimum Clock Period <b>Single-Bus CPU</b><br><b>Data path design</b> . Single-Bus CPU design:<br>Fetch Control Sequence.                                | Chapter 2 & 4<br>(Organization) |                        |
| 38 | W 10/5          | Single-Bus CPU Data path design. Single-<br>Bus CPU design: Synchronous vs.<br>Asynchronous Memory Transfer, Execution<br>Control Sequence for MOV, XCHG, ADD,<br>INC, ADD with register indirect addressing<br>mode, unconditional Jump.             | Chapter 2 & 4<br>(Organization) |                        |
|    | Th 11/5         | MAJOR EXAM II                                                                                                                                                                                                                                         |                                 |                        |
|    | S 13/5          |                                                                                                                                                                                                                                                       |                                 | Using the<br>Mouse     |

| 39                   | S 13/5                               | <b>Single-Bus CPU</b> : Execution control sequence for Conditional JMP. Loop. CMP.                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                     |             |
|----------------------|--------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|-------------|
|                      |                                      | PUSH instructions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                     |             |
| 40                   | M 15/5                               | Performance Considerations. Two-Bus                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Chapter 2 & 4                                                       |             |
| _                    | (Ext.)                               | CPU: Fetch Control Sequence, Execution                                                                                                                                                                                                                                                                                                                                                                                                                                                               | (Organization)                                                      |             |
|                      | (2.1.1.)                             | Control Sequence for ADD with register                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                     |             |
|                      |                                      | indirect addressing mode, unconditional and                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                     |             |
|                      |                                      | conditional Jump. Three-Bus CPU: Fetch                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                     |             |
|                      |                                      | Control Sequence, Execution Control<br>Sequence for ADD unconditional and                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                     |             |
|                      |                                      | conditional lump Instructions Control Unit                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                     |             |
|                      |                                      | Design: Hardwired Control Unit General                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                     |             |
|                      |                                      | Hardwired Control Unit Organization.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                     |             |
|                      |                                      | Generation of Control Signals.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                     |             |
| 41                   | W 17/5                               | Deriving Rout & Rin Signals. CPU-                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                     |             |
|                      | (Ext.)                               | Memory Interface Circuit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                     |             |
|                      | S 20/5                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                     | Serial Port |
| 12                   | S 20/5                               | Microprogrammed Control Unit Design                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Chapter 2 & 4                                                       |             |
| 1 74                 | 5 20/5                               | miler oprogrammed control cint Design                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $\operatorname{Chapter} 2  \mathrm{cm}$                             |             |
| 72                   | 5 20/5                               | Control Word, Control Store,                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | (Organization)                                                      |             |
| +2                   | 5 20/5                               | Control Word, Control Store,<br>Microinstruction, Microroutine. General                                                                                                                                                                                                                                                                                                                                                                                                                              | (Organization)                                                      |             |
| 72                   | 5 20/5                               | Control Word, Control Store,<br>Microinstruction, Microroutine. General<br>Organization of Microprogrammed Control                                                                                                                                                                                                                                                                                                                                                                                   | (Organization)                                                      |             |
| 72                   | 5 20/5                               | Control Word, Control Store,<br>Microinstruction, Microroutine. General<br>Organization of Microprogrammed Control<br>Unit, Micro Program Counter, Micro                                                                                                                                                                                                                                                                                                                                             | (Organization)                                                      |             |
|                      | 5 20/3                               | Control Word, Control Store,<br>Microinstruction, Microroutine. General<br>Organization of Microprogrammed Control<br>Unit, Micro Program Counter, Micro<br>Instruction Register, Branching Address,<br>Sequencer                                                                                                                                                                                                                                                                                    | (Organization)                                                      |             |
| 42                   | M 22/5                               | Control Word, Control Store,<br>Microinstruction, Microroutine. General<br>Organization of Microprogrammed Control<br>Unit, Micro Program Counter, Micro<br>Instruction Register, Branching Address,<br>Sequencer.<br>No class.                                                                                                                                                                                                                                                                      | (Organization)                                                      |             |
| 42                   | M 22/5                               | Control Word, Control Store,<br>Microinstruction, Microroutine. General<br>Organization of Microprogrammed Control<br>Unit, Micro Program Counter, Micro<br>Instruction Register, Branching Address,<br>Sequencer.<br>No class.                                                                                                                                                                                                                                                                      | (Organization)                                                      |             |
| 42                   | M 22/5<br>W 24/5                     | Control Word, Control Store,<br>Microinstruction, Microroutine. General<br>Organization of Microprogrammed Control<br>Unit, Micro Program Counter, Micro<br>Instruction Register, Branching Address,<br>Sequencer.<br>No class.<br>No class.                                                                                                                                                                                                                                                         | (Organization)                                                      |             |
| 42                   | M 22/5<br>W 24/5<br>S 27/5           | Control Word, Control Store,<br>Microinstruction, Microroutine. General<br>Organization of Microprogrammed Control<br>Unit, Micro Program Counter, Micro<br>Instruction Register, Branching Address,<br>Sequencer.<br>No class.                                                                                                                                                                                                                                                                      | (Organization)                                                      | Project     |
| 42<br>42<br>44<br>45 | M 22/5<br>W 24/5<br>S 27/5<br>S 27/5 | Control Word, Control Store,<br>Microinstruction, Microroutine. General<br>Organization of Microprogrammed Control<br>Unit, Micro Program Counter, Micro<br>Instruction Register, Branching Address,<br>Sequencer.<br>No class.<br>No class.                                                                                                                                                                                                                                                         | Chapter 2 & 4                                                       | Project     |
| 42<br>44<br>45       | M 22/5<br>W 24/5<br>S 27/5<br>S 27/5 | Control Word, Control Store,<br>Microinstruction, Microroutine. General<br>Organization of Microprogrammed Control<br>Unit, Micro Program Counter, Micro<br>Instruction Register, Branching Address,<br>Sequencer.<br>No class.<br>No class.<br>Control Unit Design: Sequencer, Horizontal,<br>Field-encoded and vertical control store.                                                                                                                                                             | Chapter 2 & 4<br>(Organization)                                     | Project     |
| 42 42 44 45          | M 22/5<br>W 24/5<br>S 27/5<br>S 27/5 | Control Word, Control Store,<br>Microinstruction, Microroutine. General<br>Organization of Microprogrammed Control<br>Unit, Micro Program Counter, Micro<br>Instruction Register, Branching Address,<br>Sequencer.<br>No class.<br>No class.<br>No class.<br>Control Unit Design: Sequencer, Horizontal,<br>Field-encoded and vertical control store.<br>Microroutine for Add instruction with 8<br>addressing modes. Wide branch addressing                                                         | (Organization)<br>(Organization)<br>Chapter 2 & 4<br>(Organization) | Project     |
| 42<br>44<br>45       | M 22/5<br>W 24/5<br>S 27/5<br>S 27/5 | Control Word, Control Store,<br>Microinstruction, Microroutine. General<br>Organization of Microprogrammed Control<br>Unit, Micro Program Counter, Micro<br>Instruction Register, Branching Address,<br>Sequencer.<br>No class.<br>No class.<br>Control Unit Design: Sequencer, Horizontal,<br>Field-encoded and vertical control store.<br>Microroutine for Add instruction with 8<br>addressing modes. Wide branch addressing<br>and Multiway branching. Bit Oring                                 | (Organization)<br>Chapter 2 & 4<br>(Organization)                   | Project     |
| 42 42 44 45          | M 22/5<br>W 24/5<br>S 27/5<br>S 27/5 | Control Word, Control Store,<br>Microinstruction, Microroutine. General<br>Organization of Microprogrammed Control<br>Unit, Micro Program Counter, Micro<br>Instruction Register, Branching Address,<br>Sequencer.<br>No class.<br>No class.<br>Control Unit Design: Sequencer, Horizontal,<br>Field-encoded and vertical control store.<br>Microroutine for Add instruction with 8<br>addressing modes. Wide branch addressing<br>and Multiway branching. Bit Oring.<br>Comparison of Hardwired vs. | (Organization)<br>Chapter 2 & 4<br>(Organization)                   | Project     |