

Spring 2023

COMP 300 - Computer Organization and Assembly Language

(3 Credit Hours) Section – A and B Course Outline and Lesson Plan

#### **Instructor Information:**

Name: Dr. Ayesha Khan

Contact: <a href="mailto:ayesha.khan@fccu.edu.pk">ayesha.khan@fccu.edu.pk</a>
Office Hours: Wednesday 8am to 9am
Friday 10am to 1 pm

### **NOTE:**

• There will be no retake for the quiz.

- Students are advised to attend all lectures. It is entirely the students' responsibility to recover any information or announcements presented in lectures from which they were absent.
- All work that you submit in this course must be your own.
- Unauthorized group efforts are considered academic dishonesty.
- Cheating, plagiarism and other forms of academic fraud are taken very seriously. University Policy of plagiarism will be applicable.
- Cheating or violation of academic integrity in any exam will result in an 'F' grade.

Course Code: COMP300

Course Title: Computer Organization and Assembly Language

#### **Catalog Description:**

Computer Organization and Assembly Language is offered as a core course for BS degree in Computer Science. This course introduces the organization of computer systems and usage of assembly language. The architecture being followed is MIPS. The students should have prior knowledge of any programming language and Digital Logic. It's a 2+2 credit hour course that includes lab. T

### **Grading Policy:**

| Oracing roncy    |     |
|------------------|-----|
| Final            | 35% |
| Midterm          | 20% |
| Assignments      | 10% |
| Quizzes          | 15% |
| Lab              | 15% |
| Class Activities | 5%  |



# Spring 2023

## COMP 300 - Computer Organization and Assembly Language

## (3 Credit Hours) Section – A and B Course Outline and Lesson Plan



Spring 2023

COMP 300 - Computer Organization and Assembly Language

## (3 Credit Hours) Section - A and B Course Outline and Lesson Plan

### **Textbooks and References:**

| Textbook Name + Edition             | Author             | Publisher           |
|-------------------------------------|--------------------|---------------------|
| Computer Organization and           | David A. Patterson | Morgan Kaufmann     |
| Design; The Hardware /              | John L. Hennessy   |                     |
| Software Interface 5 <sup>th</sup>  |                    |                     |
| Edition                             |                    |                     |
| Introduction to MIPS                | Charles W. Kann    | Charles W. Kann III |
| Assembly Language                   |                    |                     |
| Programming 2 <sup>nd</sup> Edition |                    |                     |

### Syllabus breakdown in lectures:

| Week | Topic           | Content Breakdown                                          |
|------|-----------------|------------------------------------------------------------|
| no.  |                 |                                                            |
| 1    | Why Computer    | <ul> <li>Power Trends</li> </ul>                           |
|      | Organization    | <ul><li>Moore's Law</li></ul>                              |
|      |                 | <ul> <li>Power Equation</li> </ul>                         |
| 2    | Introduction to | o Binary Numbers                                           |
|      | Logic Design    | <ul> <li>Decoders</li> </ul>                               |
|      |                 | o MUXs                                                     |
|      |                 | <ul> <li>Flips Flops</li> </ul>                            |
|      |                 | o Memory (RAM) Design                                      |
|      |                 | o Data Bus Design                                          |
|      |                 | <ul><li>Registers</li></ul>                                |
| 3    | Design of ALU   | <ul> <li>Adder circuit in conjunction with MUXs</li> </ul> |
|      |                 | and logic gates to implement arithmetic                    |
|      |                 | and logic operations                                       |
| 4-5  | MIPS            | o Introduction to MARS(MIPS Assembler                      |
|      |                 | and Runtime Simulator) environment                         |
|      |                 | o Hello World program in MIPS                              |
|      |                 | (Microprocessor without Interlocked                        |
|      |                 | Pipeline Stages)                                           |



# Spring 2023

## COMP 300 - Computer Organization and Assembly Language

### (3 Credit Hours) Section - A and B Course Outline and Lesson Plan

|       |                     | T |                                           |
|-------|---------------------|---|-------------------------------------------|
|       |                     | 0 | Reading integers, characters, strings and |
|       |                     |   | floats                                    |
|       |                     | 0 | Arithmetic and Logic Operators in MIPS    |
|       |                     | 0 | Instruction types and its format in MIPS  |
|       |                     | 0 | Translating assembly language into        |
|       |                     |   | machine code.                             |
| 6-7   | Design and          | 0 | Von Neumann Vs Harvard Architecture       |
|       | Implementation of a | 0 | Data and Code Memories                    |
|       | Single Cycle MIPS   | 0 | Fetching an instruction                   |
|       | Processor           | 0 | Execution of R-type and I-Type            |
|       |                     |   | instructions.                             |
|       |                     | 0 | Execution of a branch instruction.        |
|       |                     | 0 | The complete single cycle data path.      |
| 8-10  | Programming in      | 0 | Functions without any input parameters    |
|       | MIPS                |   | and return values.                        |
|       |                     | 0 | Functions with input parameters only.     |
|       |                     | 0 | Functions with return values only.        |
|       |                     | 0 | Functions with both input parameters and  |
|       |                     |   | return values.                            |
|       |                     | 0 | Accessing memory in MIPS                  |
|       |                     | 0 | Register offset access                    |
|       |                     | 0 | Control Structures and Loops in MIPS      |
|       |                     | 0 | Arrays in MIPS                            |
|       |                     | 0 | Stack data structure                      |
|       |                     |   |                                           |
| 11-12 | Pipelining          |   |                                           |
|       |                     | 0 | Five Phases                               |
|       |                     | 0 | Making 5-stage pipeline work              |
|       |                     | 0 | Pipeline performance                      |
|       |                     | 0 | Pipeline data path                        |
|       |                     | 0 | Datapath and Control Signals              |
|       |                     | 0 | Pipeline Hazard                           |
|       |                     |   |                                           |
| 13-14 | Cache               |   |                                           |
|       |                     | 0 | Introduction                              |
|       |                     | 0 | Principle of Locality                     |
|       |                     | 0 | Cache Design                              |
|       |                     | 0 | Direct Mapped Cache                       |
|       |                     | 0 | Associativity                             |
|       |                     |   |                                           |



Spring 2023

COMP 300 - Computer Organization and Assembly Language

## (3 Credit Hours) Section - A and B Course Outline and Lesson Plan

| 15 | Introduction to | 0 | Cache miss and page fault             |
|----|-----------------|---|---------------------------------------|
|    | Virtual memory  | 0 | The page table                        |
|    | (Optional)      | 0 | Translation Look aside Buffers (TLBs) |
|    |                 |   |                                       |