## KING FAHD UNIVERSITY OF PETROLEUM & MINERALS COLLEGE OF COMPUTER SCIENCES & ENGINEERING

## ICS 233 Computer Architecture & Assembly Language Term 081 Lecture Breakdown

|   | Date       | Topics                                                                                                                                                                                                                                                                                                                                        | Ref.                                                                                                            |
|---|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| 1 | S          | Syllabus introduction.                                                                                                                                                                                                                                                                                                                        |                                                                                                                 |
|   | 11/10      |                                                                                                                                                                                                                                                                                                                                               |                                                                                                                 |
| 2 | M<br>13/10 | Assembly and Machine Language, Compiler and<br>Assembler, Instructions and Machine Language,<br>Instruction Fields, Advantages of High-Level<br>Languages, Why Learn Assembly Language?                                                                                                                                                       | Chapter 1: Computer<br>Abstractions and<br>Technology                                                           |
| 3 | W<br>15/10 | Assembly vs. High-Level Languages, Assembly<br>Language Programming Tools, Assemble and<br>Link Process, Components of a Computer System,<br>Input Devices, Output Devices, Memory, Address<br>Space. Address, Data, and Control Bus, Memory<br>Devices: RAM, DRAM, SRAM, ROM, Magnetic<br>Disk Storage, Processor-Memory Performance<br>Gap. | Chapter 1: Computer<br>Abstractions and<br>Technology                                                           |
| 4 | S<br>18/10 | Memory Hierarchy, Processor: Datapath, Control,<br>Program Counter, Instruction Register, Fetch-<br>Execute Cycle. Manufacturing Process.                                                                                                                                                                                                     | Chapter 1: Computer<br>Abstractions and<br>Technology                                                           |
| 5 | M<br>20/10 | Effect of Die Size on Yield, Technology<br>Improvements, Programmer's View of a<br>Computer System. Positional Number Systems,<br>Binary and Hexadecimal Numbers, Base<br>Conversions. Integer Storage Sizes.                                                                                                                                 | Chapter 1: Computer<br>Abstractions and<br>Technology &<br>Chapter 3: Arithmetic<br>for Computers (3.1-<br>3.3) |
| 6 | W<br>22/10 | Binary and Hexadecimal Addition, Signed<br>Integers and 2's Complement Notation, Sign<br>Extension. Two's Complement of a Hexadecimal,<br>Binary & Hexadecimal Subtraction, Ranges of<br>Signed Integers.                                                                                                                                     | Chapter 3: Arithmetic<br>for Computers (3.1-<br>3.3) & Chapter 3:<br>Number Systems<br>(Britton Book)           |
| 7 | S<br>25/10 | Carry and Overflow. (Quiz#1).                                                                                                                                                                                                                                                                                                                 | Chapter 3: Arithmetic<br>for Computers (3.1-<br>3.3) & Chapter 3:<br>Number Systems<br>(Britton Book)           |
| 8 | M<br>27/10 | No Class.                                                                                                                                                                                                                                                                                                                                     |                                                                                                                 |
| 9 | W<br>29/10 | Character Storage, ASCII Code. Instruction Set<br>Architecture (ISA). Overview of the MIPS<br>Processor, MIPS, General-Purpose Registers,                                                                                                                                                                                                     | Chapter 2:<br>Instructions:<br>Language of the                                                                  |

|    | 12/11      | Design, Assembly Language Statements,<br>Instructions, Comments, Program Template,<br>.DATA, .TEXT, & .GLOBL Directives, Data | Instructions:<br>Language of the<br>Computer (2.9) |
|----|------------|-------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|
| 15 | 11/11<br>W | PC-Relative Addressing. Summary of RISC                                                                                       | Chapter 2:                                         |
|    | Т          | Midterm Warning                                                                                                               |                                                    |
|    |            |                                                                                                                               | (Britton Book)                                     |
|    |            |                                                                                                                               | Development in<br>Pseudocode                       |
|    |            |                                                                                                                               | Chapter 2: Algorithm                               |
|    |            |                                                                                                                               | (2.6, 2.8, 2.9)                                    |
|    |            | Jump and Branch Limits, PC-Relative Addressing.                                                                               | Language of the<br>Computer                        |
|    | 10/11      | Addressing Modes, Branch / Jump Addressing                                                                                    | Instructions:                                      |
| 14 | М          | Copying a String, Summing an Integer Array,                                                                                   | Chapter 2:                                         |
|    |            |                                                                                                                               | Book)                                              |
|    |            |                                                                                                                               | Pseudocode (Britton                                |
|    |            |                                                                                                                               | Chapter 2: Algorithm<br>Development in             |
|    |            | Loop. Using Pointers to Traverse Arrays.                                                                                      | (2.6, 2.8, 2.9)                                    |
|    |            | Store Byte and Halfword, Translating a WHILE                                                                                  | Computer                                           |
|    |            | Instructions: Load and Store Word, Load and                                                                                   | Language of the                                    |
| 15 | 8/11       | Unsigned Comparison. Load and Store                                                                                           | Instructions:                                      |
| 13 | S          | Compound Expression with OR, Signed &                                                                                         | Chapter 2:                                         |
|    |            |                                                                                                                               | Book)                                              |
|    |            |                                                                                                                               | Pseudo code &<br>Appendix A (Britton               |
|    |            |                                                                                                                               | Development in                                     |
|    |            |                                                                                                                               | Chapter 2: Algorithm                               |
|    |            | Compound Expression with AND.                                                                                                 | Computer (2.6) &                                   |
|    |            | Instructions. Translating an IF Statement,                                                                                    | Language of the                                    |
|    | 5/11       | Set on Less Than Instructions, Pseudo-                                                                                        | Instructions:                                      |
| 12 | W          | J-Type Format, Conditional Branch Instructions,                                                                               | Chapter 2:                                         |
|    |            | of logical instructions. (Quiz#2)                                                                                             | Computer (2.1-2.6)                                 |
|    | 3/11       | ALU Instructions, 32-bit Constants, Applications                                                                              | Language of the                                    |
| 11 | M          | Use of shift instructions in performing multiplication and division. I-Type Format, I-Type                                    | Chapter 2:<br>Instructions:                        |
|    |            | division.                                                                                                                     | Book)                                              |
|    |            | shift instructions in performing multiplication and                                                                           | Architecture (Britton                              |
|    |            | Instructions: sll, srl sra, sllv, srlv, srav. Use of                                                                          | Chapter 1: The MIPS                                |
|    |            | Instructions: AND, OR, XOR, NOR, Shift                                                                                        | Computer (2.1-2.5) &                               |
|    | 1/11       | /Subtract Instructions. Logical Bitwise                                                                                       | Language of the                                    |
| 10 | 3<br>1/11  | Logical, and Shift Instructions, Integer Add                                                                                  | Instructions:                                      |
| 10 | S          | Instruction Categories. R-Type Arithmetic,                                                                                    | Chapter 2:                                         |
|    |            |                                                                                                                               | Book)                                              |
|    |            | Formats.                                                                                                                      | Chapter 1: The MIPS<br>Architecture (Britton       |
|    |            | MIPS Registers, Conventions, Instruction                                                                                      | 1 ( /                                              |

|    |             | Definition Statement, Data Directives: .Byte,<br>.Half, .Word, .Float, .double, String Directives:<br>.Ascii, .Aciiz, .Space, Examples of Data<br>Definitions, Memory Alignment, Byte Ordering,<br>Big & Little Endians.                              | Appendix A.9-A.10<br>& Appendix A<br>(Britton Book)                                                                |
|----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|
|    | Th<br>13/11 | Major Exam I                                                                                                                                                                                                                                          |                                                                                                                    |
| 16 | S<br>15/11  | System Calls, Reading and Printing an Integer,<br>Reading and Printing a String, Reading and<br>Printing a Character, Sum of Three Integers<br>Program. Case Conversion Program.                                                                      | Appendix A.9-A.10<br>& Appendix A<br>(Britton Book)                                                                |
| 17 | M<br>17/11  | Procedures, Call / Return Sequence, Instructions<br>for Procedures: JAL, JR, JALR. Parameter<br>Passing.                                                                                                                                              | Chapter 2:<br>Instructions:<br>Language of the<br>Computer (2.7)                                                   |
|    | T<br>18/11  | Last day dropping with W                                                                                                                                                                                                                              |                                                                                                                    |
| 18 | W<br>19/11  | Parameter Passing, Stack Frame, Preserving<br>Registers, Selection Sort Procedure.                                                                                                                                                                    | Chapter 2:<br>Instructions:<br>Language of the<br>Computer (2.7)                                                   |
| 19 | S<br>22/11  | Recursive Procedures: factorial. Unsigned<br>Multiplication, Unsigned Multiplication<br>Hardware.                                                                                                                                                     | Chapter 2:<br>Instructions:<br>Language of the<br>Computer (2.7) &<br>Chapter 3: Arithmetic<br>for Computers (3.4) |
| 20 | M<br>24/11  | Unsigned Multiplication Hardware, Signed<br>Multiplication, Signed Multiplication Hardware.<br>Unsigned Division.                                                                                                                                     | Chapter 3: Arithmetic<br>for Computers (3.4 &<br>3.5)                                                              |
| 21 | W<br>26/11  | Division Algorithm & Hardware (Quiz#3).                                                                                                                                                                                                               | Chapter 3: Arithmetic for Computers (3.5)                                                                          |
| 22 | S<br>29/11  | Signed Division, Multiplication and Division in<br>MIPS. Integer to String Procedure, Floating-Point<br>Numbers, Floating-Point Representation.                                                                                                       | Chapter 3: Arithmetic<br>for Computers (3.5 &<br>3.6)                                                              |
| 23 | M<br>1/12   | IEEE 754 Floating-Point Standard, Normalized<br>Floating Point Numbers, Biased Exponent<br>Representation, Converting FP Decimal to Binary,<br>Largest Normalized Float.                                                                              | Chapter 3: Arithmetic<br>for Computers (3.6)                                                                       |
|    |             | Eid Adha Holiday                                                                                                                                                                                                                                      |                                                                                                                    |
| 24 | M<br>15/12  | Review of IEEE 754 Floating-Point Standard,<br>Largest & Smallest Normalized Float, Zero,<br>Infinity, and NaN, Denormalized Numbers,<br>Floating-Point Comparison, Simple 6-bit Floating<br>Point Example, Floating Point Addition /<br>Subtraction. | Chapter 3: Arithmetic<br>for Computers (3.6)                                                                       |
| 25 | W           | Floating Point Addition / Subtraction, Floating                                                                                                                                                                                                       | Chapter 3: Arithmetic                                                                                              |

|    | 17/12      | Point Adder Block Diagram.                                                             | for Computers (3.6)                   |
|----|------------|----------------------------------------------------------------------------------------|---------------------------------------|
| 26 |            | Floating Point Multiplication, Extra Bits to                                           |                                       |
| 26 | Th         | Maintain Precision, Guard Bit, Round and Sticky                                        | Chapter 3: Arithmetic                 |
|    | 18/12      | bits.                                                                                  | for Computers (3.6)                   |
| 27 | S          | IEEE 754 Rounding Modes. Illustration of                                               | Chapter 2. Arithmetic                 |
| 21 | 3<br>20/12 | Rounding Modes. (Quiz#4)                                                               | Chapter 3: Arithmetic                 |
|    |            |                                                                                        | for Computers (3.6)                   |
| 28 | M          | Floating Point Subtraction Example, Advantages<br>of IEEE 754 Standard, Floating Point | Chapter 3: Arithmetic                 |
|    | 22/12      | Complexities, MIPS Floating-Point Instructions:                                        | for Computers (3.6)                   |
|    |            | Arithmetic Instructions, Load/Store Instructions,                                      |                                       |
|    |            | Data Movement Instructions, Convert                                                    |                                       |
|    |            | Instructions, Compare and Branch Instructions, FP                                      |                                       |
|    |            | Data Directives, FP Syscall Services. Example:                                         |                                       |
|    |            | Area of a circle.                                                                      |                                       |
| 29 | W          | What is Performance? Response Time and                                                 | Chapter 4: Assessing                  |
|    | 24/12      | Throughput, Definition of Performance, CPU                                             | and Understanding                     |
|    |            | Execution Time, Improving Performance. Clock                                           | Performance                           |
|    |            | Cycles per Instruction (CPI), Performance                                              | (4.1, 4.2)                            |
|    |            | Equation. Factors Impacting Performance.                                               | (,)                                   |
| 30 | S          | Clock Cycles per Instruction (CPI), Performance                                        | Chapter 4: Assessing                  |
|    | 27/12      | Equation, Determining the CPI. (Quiz#5)                                                | and Understanding                     |
|    |            |                                                                                        | Performance                           |
|    |            |                                                                                        | (4.1, 4.2, 4.5)                       |
| 31 | Μ          | Determining the CPI, MIPS as a Performance                                             | Chapter 4: Assessing                  |
|    | 29/12      | Measure. Drawbacks of MIPS, Amdahl's Law.                                              | and Understanding                     |
|    |            |                                                                                        | Performance                           |
|    |            |                                                                                        | (4.3-4.6)                             |
|    | Т          | Last day dropping all courses with W                                                   |                                       |
|    | 30/12      |                                                                                        |                                       |
| 32 | W          | Amdahl's Law, Benchmarks, The SPEC CPU2000                                             | Chapter 4: Assessing                  |
|    | 31/12      | Benchmarks, SPEC 2000 Ratings (Pentium III &                                           | and Understanding                     |
|    |            | 4), Performance and Power. Single Cycle                                                | Performance                           |
|    |            | Processor Design: Designing a Processor: Step-<br>by-Step.                             | (4.3-4.6)                             |
|    |            | by-step.                                                                               | Chapter 5: The                        |
|    |            |                                                                                        | Processor: Datapath                   |
|    |            |                                                                                        | & Control (5.1)                       |
| 33 | S          | Designing a Processor: Step-by-Step, Review of                                         | Chapter 5: The                        |
|    | 3/1        | MIPS Instruction Formats, Register Transfer                                            | Processor: Datapath                   |
|    |            | Level (RTL), Instructions Executed in Steps,                                           | & Control (5.1)                       |
|    |            | Requirements of the Instruction Set. Components                                        |                                       |
|    |            | of the Datapath.                                                                       |                                       |
| 34 | M          | Register Element, MIPS Register File, Tri-State                                        | Chapter 5: The                        |
|    | 5/1        | Buffers. Designing the MIPS Register File.                                             | Processor: Datapath                   |
| 07 |            | Building a Multifunction ALLL Instruction and                                          | & Control (5.2-5.3)                   |
| 35 | W<br>7/1   | Building a Multifunction ALU. Instruction and Data Memories, Clocking Methodology,     | Chapter 5: The<br>Processor: Datapath |
|    | 7/1        | Determining the Clock Cycle, Clock Skew,                                               | & Control (5.2-5.4)                   |
|    | l          | Determining the Clock Cycle, Clock Skew,                                               | & Control (3.2-3.4)                   |

|    |            | Instruction Fetching Datapath, Datapath for R-<br>type Instructions                                                                                                                                                                                                          |                                                                                                                                 |
|----|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|
|    | Th.<br>8/1 | Major Exam II                                                                                                                                                                                                                                                                |                                                                                                                                 |
| 36 | S<br>10/1  | Datapath for I-type ALU, Instructions, Combining<br>R-type & I-type Datapaths. Controlling ALU<br>Instructions, Details of the Extender, Controlling<br>the Execution of Load & Store, Adding Jump and<br>Branch to Datapath.                                                | Chapter 5: The<br>Processor: Datapath<br>& Control (5.2-5.4)                                                                    |
| 37 | M<br>12/1  | Controlling the Execution of Jump & Branch,<br>Main Control. ALU Control, Drawbacks of Single<br>Cycle Processor.                                                                                                                                                            | Chapter 5: The<br>Processor: Datapath<br>& Control (5.3-5.4)                                                                    |
| 38 | W<br>14/1  | Multicycle Implementation, Single-cycle vs.<br>Multicycle Performance, Worst Case Timing<br>(Load Instruction), Pipelined Processor Design:<br>Pipelining Example. Serial execution versus<br>Pipelining, Synchronous Pipeline, Pipeline<br>Performance, Pipelined Datapath. | Chapter 5: The<br>Processor: Datapath<br>& Control (5.3-5.4)<br>Chapter 6: Enhancing<br>Performance with<br>Pipelining(6.1-6.3) |
| 39 | S<br>17/1  | Instruction–Time Diagram, Single-Cycle vs.<br>Pipelined Performance, Pipelined Control.<br>Pipeline Hazards, Structural Hazards, Resolving<br>Structural Hazards, Data Hazards.                                                                                              | Chapter 6: Enhancing<br>Performance with<br>Pipelining(6.1, 6.4)                                                                |
| 40 | M<br>19/1  | Implementing Forwarding, RAW Hazard<br>Detection, Forwarding Unit. Load Delay,<br>Detecting RAW Hazard after Load, Hazard<br>Detection and Stall Unit.                                                                                                                       |                                                                                                                                 |
|    | T<br>20/1  | Dropping all courses with WP/WF                                                                                                                                                                                                                                              |                                                                                                                                 |
| 41 | W<br>21/1  | Compiler Scheduling. WAR Hazard, WAW<br>Hazard, Control Hazards, Reducing the Delay of<br>Branches, Branch Hazard Alternatives, Delayed<br>Branch. Zero-Delayed Branch, Branch Target and<br>Prediction Buffer, Dynamic Branch Prediction, 2-<br>bit Prediction Scheme.      | Performance with                                                                                                                |
| 42 | S<br>24/1  | Random Access Memory, Typical Memory<br>Structure, Static RAM Storage Cell, Dynamic<br>RAM Storage Cell, DRAM Refresh Cycles Trends<br>in DRAM, Expanding the Data Bus Width,<br>Increasing Memory Capacity by 2 <sup>k</sup> , Processor-                                   | Chapter 7: Exploiting<br>Memory Hierarchy<br>(7.1)<br>Appendix B.9 (CD)                                                         |
|    |            | Memory Performance Gap, The Need for a<br>Memory Hierarchy. Typical Memory Hierarchy,<br>Principle of Locality of Reference.                                                                                                                                                 |                                                                                                                                 |
| 43 | M<br>26/1  |                                                                                                                                                                                                                                                                              | Chapter 7: Exploiting<br>Memory Hierarchy<br>(7.2, 7.3)                                                                         |

|    |      | Memory Stall Cycles, CPU Time with Memory       | (7.2, 7.3, 7.5) |
|----|------|-------------------------------------------------|-----------------|
|    |      | Stall Cycles, Designing Memory to Support       |                 |
|    |      | Caches: Memory Interleaving, Improving Cache    |                 |
|    |      | Performance: Average Memory Access Time,        |                 |
|    |      | Small and Simple Caches, Larger Size and Higher |                 |
|    |      | Associativity, Larger Block Size.               |                 |
| 45 | S    | NO CLASS.                                       |                 |
|    | 31/1 |                                                 |                 |