1
ECE 18-447: Introduction to Computer Architecture (Spring 2015, Carnegie Mellon Univ.). Instructor: Professor Onur Mutlu. Computer architecture is the science and art of selecting and interconnecting hardware components and designing the hardware/software interface to create a computer that meets functional, performance, energy consumption, cost, and other specific goals.
916 years, 6 months
33
This course introduces the basic hardware structure of a modern programmable computer, including the basic laws underlying performance evaluation. We will learn, for example, how to design the control and data path hardware for a ARM-like processor, how to make machine instructions execute simultaneously through pipelining and simple superscalar execution, and how to design fast memory and storage systems. The principles presented in the lecture are reinforced in the laboratory through the design and simulation of a register transfer level (RTL) implementation of a MIPS-like pipelined processor in Verilog. In addition, we will develop a cycle-accurate simulator of this processor in C, and we will use this simulator to explore processor design options. (from ece.cmu.edu)
Course Currilcum
- Lecture 01 – Introduction and Basics Unlimited
- Lecture 02 – Fundamental Concepts and ISA Unlimited
- Lecture 03 – ISA Tradeoffs Unlimited
- Lecture 04 – ISA Tradeoffs and MIPS ISA Unlimited
- Lecture 05 – Intro to Microarchitecture Unlimited
- Lecture 06 – Microarchitecture II Unlimited
- Lecture 07 – Pipelining Unlimited
- Lecture 08 – Pipelining II: Data and Control Dependence Handling Unlimited
- Lecture 09 – Branch Prediction I Unlimited
- Lecture 10 – Branch Prediction II Unlimited
- Lecture 11 – Precise Exceptions, State Maintenance and Recovery Unlimited
- Lecture 12 – Out of Order Exception Unlimited
- Lecture 13 – Out of Order Exception II and Data Flow Unlimited
- Lecture 14 – SIMD (Vector Processors) Unlimited
- Lecture 15 – GPUs, VLIW, Exception Models Unlimited
- Lecture 16 – Static Instruction Scheduling Unlimited
- Lecture 17 – Memory Hierarchy and Caches Unlimited
- Lecture 18 – Caches Unlimited
- Lecture 19 – High Performance Caches Unlimited
- Lecture 20 – Virtual Memory Unlimited
- Lecture 21 – Main Memory and the DRAM System Unlimited
- Lecture 22 – Memory Controllers Unlimited
- Lecture 23 – Memory Management Unlimited
- Lecture 24 – Simulation and Memory Latency Tolerance Unlimited
- Lecture 25 – Prefetching Unlimited
- Lecture 26 – More Prefetching and Emerging Memory Technologies Unlimited
- Lecture 27 – Multiprocessors Unlimited
- Lecture 28 – Memory Consistency and Cache Coherence Unlimited
- Lecture 29 – Cache Coherence Unlimited
- Lecture 30 – In-memory Processing Unlimited
- Lecture 31 – Predictable Performance Unlimited
- Lecture 32 – Heterogeneous Systems Unlimited
- Lecture 33 – Interconnection Networks Unlimited