

Course Title: **Computer Architecture and Organization** Program: **BICTE**

Course No. : ICT. Ed. 436

Nature of course: Theoretical + Practical

Level: Bachelor.

Credit Hour: 3 hours (2T+1P)

Semester: Third

Teaching Hour: 64 hours (32+32)

---

## 1. Course Description

This course is an introduction to Computer Architecture and its Organization. It covers topics in physical design of the computer (i.e. computer organization). This course discusses the basic structure of a digital computer and deals with the detail study of data representation in computer system, Register transfer language and microoperations, and organization of the Control unit, the Arithmetic and Logic unit, the Memory unit and the I/O unit.

## 2. General Objectives

The general objectives of this course are as follows:

- To provide the students with the knowledge of data representation, register transfer language and microoperations
- To provide the organization and designing concept of computer system including processor, computer arithmetic, memory organization and I/O organization.
- To discuss in detail, the operation of the arithmetic unit including the algorithm to add, subtract and multiply signed magnitude data and signed 2's complement data.
- To study the multiprocessors and pipelining.
- To study the different ways of communicating with I/O devices and standard I/O interfaces

## 3. Course Outlines:

| Specific Objectives                                                                                                                                     | Contents                                                                                                                                                                                                                                                                                                                                                                                           | LH       |
|---------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| <ul style="list-style-type: none"><li>• Explain different data types representation</li><li>• Define the requirement of complement numbers</li></ul>    | <p><b>Unit 1: Data Representation</b></p> <p>1.1 Data Types<br/>1.2 Complements<br/>1.3 Fixed Point Representation<br/>1.4 Floating Point Representation</p> <p><b>Practical Works</b></p> <p><b>1.1 Computer Program:</b> Write program to visualize the representation of complement numbers, integers, floating point numbers and character data, overflow detection while adding integers.</p> | <b>4</b> |
| <ul style="list-style-type: none"><li>• Explain register transfer language</li><li>• Apply different microoperations to perform specific task</li></ul> | <p><b>Unit 2: Register Transfer and Microoperations</b></p> <p>2.1 Register and Register Transfer Language<br/>2.2 Bus and Memory Transfers<br/>2.3 Arithmetic, Logic and Shift Micro-operations<br/>2.4 Arithmetic Logic Shift Unit</p>                                                                                                                                                           | <b>8</b> |

|                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| <ul style="list-style-type: none"> <li>• Explain instruction codes</li> <li>• Describe instruction format and instruction cycle</li> <li>• Design component organization in basic computer.</li> </ul>                                                             | <p><b>Unit 3: Basic Computer Organization and Design</b></p> <p>3.1 Instruction Codes<br/>3.2 Computer Registers<br/>3.3 Computer Instructions<br/>3.4 Timing and Control<br/>3.5 Instruction Cycle<br/>3.6 Input Output and Interrupt</p> <p><b>Practical Works</b></p> <p><b>3.1 Circuit Design:</b> Design of Basic Computer</p> <p><b>3.2 Computer Program:</b> Write program to illustrate fetch, decode and execute instructions.</p>                                                                   | 8 |
| <ul style="list-style-type: none"> <li>• Describe control memory and its usage</li> <li>• Apply address sequencing concept</li> <li>• Identify microinstruction format</li> </ul>                                                                                  | <p><b>Unit 4: Microprogrammed Control</b></p> <p>4.1 Control Memory<br/>4.2 Address Sequencing<br/>4.3 Computer Configuration<br/>4.4 Microinstruction Format</p>                                                                                                                                                                                                                                                                                                                                             | 6 |
| <ul style="list-style-type: none"> <li>• Explain different CPU organizations</li> <li>• Describe the requirement of different instruction formats</li> <li>• Understand and apply addressing modes</li> </ul>                                                      | <p><b>Unit 5: Central Processing Unit</b></p> <p>5.1 CPU Organizations<br/>5.2 Instruction Formats<br/>5.3 Addressing Modes</p> <p><b>Practical Works</b></p> <p><b>5.1 Computer Program:</b> Write program to illustrate the use of different addressing modes.</p>                                                                                                                                                                                                                                          | 6 |
| <ul style="list-style-type: none"> <li>• Define different types of computers</li> <li>• Explain pipelining</li> <li>• Utilizing different types of pipelining to improve performance</li> <li>• Understand pipeline hazards and suggest their solutions</li> </ul> | <p><b>Unit 6: Pipelining</b></p> <p>6.1 Parallel Processing, Flynn's Classification of Computers<br/>6.2 Pipelining<br/>6.3 Arithmetic Pipeline<br/>6.4 Instruction Pipeline<br/>6.5 Pipeline Hazards and their Solutions<br/>6.6 Array and Vector Processing</p> <p><b>Practical Works</b></p> <p><b>6.1 Case Study:</b> Available array and vector processors and their application domain<br/><b>6.2 Computer Program:</b> write program which simulates instruction pipeline and arithmetic pipeline.</p> | 8 |
| <ul style="list-style-type: none"> <li>• Demonstrate the addition and subtraction of signed magnitude</li> </ul>                                                                                                                                                   | <p><b>Unit 7: Computer Arithmetic</b></p> <p>7.1 Addition and Subtraction of Signed Magnitude Data</p>                                                                                                                                                                                                                                                                                                                                                                                                        | 8 |

|                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                    |          |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| <ul style="list-style-type: none"> <li>• data and signed 2's complement data</li> <li>• Trace Multiplication algorithms to multiply signed magnitude and signed 2's complement data.</li> </ul>                             | <p>7.2 Addition and Subtraction of Signed 2's Complement Data<br/>     7.3 Multiplication of Signed Magnitude Data<br/>     7.4 Multiplication of Signed 2's Complement Data</p> <p><b>Practical Works</b></p> <p><b>7.1 Computer Program:</b> Implement all algorithms learned in this chapter in high level language.</p>                                        |          |
| <ul style="list-style-type: none"> <li>• Explain I/O interface, async. data transfer, modes of transfer</li> <li>• Demonstrate interrupt handling and DMA transfer</li> <li>• Identify the need of IOP</li> </ul>           | <p><b>Unit 8: Input and Output Organization</b></p> <p>8.1 I/O Interface<br/>     8.2 Asynchronous Data Transfer<br/>     8.3 Modes of Transfer<br/>     8.4 Priority Interrupt<br/>     8.5 Direct Memory Access<br/>     8.6 I/O Processor</p> <p><b>Practical Works</b></p> <p><b>8.1 Case Study:</b> USB (universal serial bus)</p>                            | <b>6</b> |
| <ul style="list-style-type: none"> <li>• Describe the concept of memory hierarchy</li> <li>• Explain associative memory organization and cache mapping techniques</li> </ul>                                                | <p><b>Unit 9: Memory Organization</b></p> <p>9.1 Memory Hierarchy<br/>     9.2 Main Memory<br/>     9.3 Associative Memory<br/>     9.4 Cache Memory</p> <p><b>Practical Works</b></p> <p><b>9.1 Computer Program:</b> write program to simulate associative memory (key value pair mapping) implementation.</p>                                                   | <b>5</b> |
| <ul style="list-style-type: none"> <li>• Specify the use of multiprocessor</li> <li>• Demonstrate interconnection structures of processors and IPC</li> <li>• Identify cache coherence problem with its solution</li> </ul> | <p><b>Unit 10: Multiprocessors</b></p> <p>10.1 Characteristics of Multiprocessor<br/>     10.2 Interconnection Structures<br/>     10.3 Inter Processor Communication and Synchronization<br/>     10.4 Cache Coherence</p> <p><b>Practical Works</b></p> <p><b>10.1 Computer Program:</b> write program to simulate cache coherence problem and its solution.</p> | <b>5</b> |

## 6 Instructional Techniques

The instructional techniques for this course are divided into two groups. First group consists of general instructional techniques applicable to most of the units. The second group consists of specific instructional techniques applicable to particular units.

### 4.1 General Techniques

Reading materials will be provided to students in each unit. Lecture, Discussion, use of multi-media projector, brain storming are used in all units.

#### **4.2 Specific Instructional Techniques**

Demonstration is an essential instructional technique for all units in this course during teaching learning process. Specifically, demonstration with practical works will be specific instructional technique in this course. The details of suggested instructional techniques are presented below:

**Unit 2 and 4:** Lecture, Discussion

**Unit 1, 3, 5, 6, 7, 8, 9 and 10 :** Lecture, Discussion, Practical

### **7 Evaluation**

Evaluation of students' performance is divided into parts: Internal assessment (theory and practical) and external examinations (theory and practical). The distribution of points is given below:

| Internal Assessment Theory | Internal Assessment Practical | Semester Examination (Theoretical exam) | External Practical Exam/Viva | Total Points |
|----------------------------|-------------------------------|-----------------------------------------|------------------------------|--------------|
| 25 Points                  | 15 Points                     | 40 Points                               | 20 Points                    | 100 Points   |

*Note: Students must pass separately in internal assessment, external practical exam and semester examination.*

#### **7.1 Internal Assessment (25 Points) of Theoretical Part**

Internal assessment will be conducted by subject teacher based on following criteria:

|                                                     |           |
|-----------------------------------------------------|-----------|
| Attendance and learning Activities                  | 5 points  |
| First assignment (Written assignment)               | 5 points  |
| Second assignment (Project work with presentation ) | 10 points |
| Third assignment/written examination                | 5 point   |
| Total                                               | 25 points |

#### **7.2 Internal Assessment (15 Points) of practical part**

Internal practical assessment will be conducted by subject teacher based on following criteria:

|                                      |           |
|--------------------------------------|-----------|
| Attendance and learning Activities   | 5 points  |
| Practical work/project work/lab work | 10 points |
| Total                                | 15 points |

#### **7.3 Semester Final Examination (40 Points) theoretical part**

Examination Division, Dean office will conduct final examination at the end of semester.

Objective question (Multiple choice questions 10 x 1 point) 10 Points

Subjective questions (6 questions x 5 marks with

'OR' two questions) 30 Points

---

|       |           |
|-------|-----------|
| Total | 40 points |
|-------|-----------|

---

#### **7.4 Practical Exam/Viva (20 Points)**

Examination Division, Office of the Dean will appoint an external examiner (ICT teachers working another campus) for conducting practical examination

| Items                                               | Points |
|-----------------------------------------------------|--------|
| Evaluation of Record Book                           | 4      |
| Project work/practical work presentation/skill test | 10     |
| Viva                                                | 6      |
| Total                                               | 20     |

**8 Recommended books and References materials (including relevant published articles in national and international journals)**

**Recommended books:**

1. Mano, M. M. (2003), *Computer System Architecture*, (3<sup>rd</sup> Ed.), Prentice Hall of India.
2. Stallings, W. (2016), *Computer Organization and Architecture: designing for performance* (10<sup>th</sup> Ed.), Pearson Education.
3. Tanenbaum, A.S. (2013), *Structured Computer Organization*, (6<sup>th</sup> Ed.), Pearson Education.