Computer Organization & Architecture (BTES 401-18) - Theory

Course Objectives

The main objective of this course is to provide students with a comprehensive understanding of the internal structure and functionality of a computer system. The course will cover the following concepts:

Course Outcomes

Upon completion of this course, students will be able to:

  1. Understand the basic organization and architecture of computer systems.
  2. Write and analyze assembly language programs.
  3. Design and analyze memory systems and their interaction with the CPU.
  4. Understand the principles of CPU control unit design and implementation.
  5. Analyze the performance of pipelined processors and understand the challenges of parallel processing.

Detailed Syllabus

Module 1: Functional blocks of a computer

CPU, memory, input-output subsystems, control unit. Instruction set architecture of a CPU – registers, instruction execution cycle, RTL interpretation of instructions, addressing modes, instruction set. Case study – instruction set of 8085 processor.

Data representation: signed number representation, fixed and floating point representations, character representation. Computer arithmetic – integer addition and subtraction, ripple carry adder, carry look-ahead adder, etc. multiplication – shift-and-add, Booth multiplier, carry save multiplier, etc. Division restoring and non-restoring techniques, floating point arithmetic.

[10 hrs] (CO1, CO2)

Module 2: Introduction to x86 architecture

CPU control unit design: Hardwired and micro-programmed design approaches. Case study – design of a simple hypothetical CPU. Memory system design: semiconductor memory technologies, memory organization. Peripheral devices and their characteristics: Input-output subsystems, I/O device interface, I/O transfers – program controlled, interrupt driven and DMA, privileged and non-privileged instructions, software interrupts and exceptions. Programs and processes –role of interrupts in process state transitions, I/O device interfaces – SCII, USB.

[12 hrs] (CO2, CO4)

Module 3: Pipelining

Basic concepts of pipelining, throughput and speedup, pipeline hazards. Parallel Processors: Introduction to parallel processors, Concurrent access to memory and cache coherency.

[10 hrs] (CO5)

Module 4: Memory Organization

Memory interleaving, concept of hierarchical memory organization, cache memory, cache size vs. block size, mapping functions, replacement algorithms, write policies.

[10 hrs] (CO3)

Suggested Books

Reference Books

Course Outcomes

The student will be able to:

  1. Understand functional block diagram of microprocessor
  2. Apply instruction set for Writing assembly language programs
  3. Design a memory module and analyze its operation by interfacing with the CPU
  4. Classify hardwired and microprogrammed control units
  5. Understand the concept of pipelining and its performance metrics

Computer Organization & Architecture Lab (BTES 402-18)

List of Experiments

  1. Computer Anatomy- Memory, Ports, Motherboard and add-on cards
  2. Dismantling and assembling PC
  3. Introduction to 8085 kit
  4. Addition of two 8 bit numbers, sum 8 bit
  5. Subtraction of two 8 bit numbers
  6. Find 1's complement of 8-bit number
  7. Find 2's complement of 8-bit number
  8. Shift an 8-bit no. by one bit
  9. Find Largest of two 8 bit numbers
  10. Find Largest among an array of ten numbers (8 bit)
  11. Sum of series of 8 bit numbers
  12. Introduction to 8086 kit
  13. Addition and subtraction of two 16 bit numbers, sum 16 bit
  14. Implement of Booth's algorithm for arithmetic operations
  15. Find 1's and 2's complement of 16-bit number
  16. Implement simple programs using I/O based interface

Lab Outcomes

The student will be able to:

  1. Assemble personal computer
  2. Implement the various assembly language programs for basic arithmetic and logical operations
  3. Demonstrate the functioning of microprocessor/microcontroller based systems with I/O interface

Reference Books