Computer Architecture I
Undergraduate course, Uppsala University, Department of IT, 2024
TL;DR Introduction to Computer Architecture using MIPS ISA and introduces ideas/thoughts behind the micro-architecture that implements the ISA.
I have been the course responsible since 2021
Course’s webpage at Uppsala University
Introduction to Computer Architecture
Course Overview
This course provides an introduction to the fundamental principles of computer architecture, focusing on the design, operation, and performance of modern computer systems. Using the MIPS architecture as a foundation, students will explore how computers execute programs at the lowest level, how hardware components interact, and how performance can be optimized through various architectural techniques.
Course Content
The course covers the following key topics:
- Understanding the MIPS Instruction Set Architecture (ISA)
- Assembly instructions and how they map to hardware execution
- Logic-level components
- Logic design, processor datapath, and control logic
- Instruction-level components
- Pipelining, hazards, branch prediction, caches, and parallelism
- System-level components
- Virtual memory, input/output mechanisms
Learning Objectives
By the end of this course, students will be able to:
- Understand the core components of a computer system, including the processor, memory, and input/output devices.
- Analyze and reason about first-order performance metrics.
- Understand the hardware/software interface and its role in system design.
- Write and debug assembly language programs.
Teaching Methodology: Flipped Classroom
This course adopts a flipped classroom approach:
- Students watch video lectures at home to learn theoretical concepts.
- Classroom sessions focus on problem-solving exercises, discussions, and hands-on activities.
Benefits of the Flipped Classroom
- Encourages active learning and student engagement.
- Provides more opportunities for collaborative problem-solving.
- Enhances conceptual understanding through guided practice.
Prerequisites
- Basic understanding of digital logic and programming is recommended.
Assessment
- Homework assignments and quizzes
- Programming tasks in assembly language
- Final exam assessing theoretical and practical understanding