Course Description
6.004 offers an introduction to the engineering of digital systems. Starting with MOS transistors, the course develops a series of building blocks — logic gates, combinational and sequential circuits, finite-state machines, computers and finally complete systems. Both hardware and software mechanisms are explored through a series of design examples.
6.004 is required material for any EECS undergraduate who wants to understand (and ultimately design) digital systems. A good grasp of the material is essential for later courses in digital design, computer architecture and systems. The problem sets and lab exercises are intended to give students "hands-on" experience in designing digital systems; each student completes a gate-level design for a reduced instruction set computer (RISC) processor during the semester.
Lecture Notes
Abbreviations
CMOS = complementary metal-oxide-semiconductor
ALU = arithmetic logic unit
OS = operating system
ALU = arithmetic logic unit
OS = operating system
LEC # | TOPICS | LECTURE NOTES |
1 | Course overview and mechanics, basics of information | (PDF) |
2 | Digital abstraction, combinational logic, voltage-based encoding | (PDF) |
3 | CMOS technology, gate design, timing | (PDF) |
4 | Canonical forms; synthesis, simplification | (PDF) |
5 | Sequential logic | (PDF) |
6 | Storage elements, finite state machines | (PDF) |
7 | Synchronization, metastability | (PDF) |
8 | Pipelining; throughput and latency | (PDF) |
9 | Case study: multipliers | (PDF) |
10 | Beta instruction set architecture, compilation | (PDF) |
11 | Machine language programming issues | (PDF) |
12 | Models of computation, programmable architectures | (PDF) |
13 | Stacks and procedures | (PDF) |
14 | Non-pipelined Beta implementation | (PDF) |
15 | Multilevel memories; locality, performance, caches | (PDF) |
16 | Cache design issues | (PDF) |
17 | Virtual memory: mapping, protection, contexts | (PDF) |
18 | Virtual machines: timesharing, OS kernels, supervisor calls | (PDF) |
19 | Devices and interrupt handlers, preemptive interrupts, real-time issues | (PDF) |
20 | Communication issues: busses, networks, protocols | |
21 | Communicating processes: semaphores, synchronization, atomicity, deadlock | (PDF) |
22 | Pipelined Beta implementation, bypassing | (PDF) |
23 | Pipeline issues: delay slots, annulment, exceptions | (PDF) |
24 | Parallel processing, shared memory, cache coherence, consistency criteria | (PDF) |
25 | Wrapup lecture | (PDF) |
No comments:
Post a Comment