Computer Architectures
Code | Completion | Credits | Range | Language |
---|---|---|---|---|
BE5B35APO | Z,ZK | 6 | 2P+2L | English |
- Relations:
- It is not possible to register for the course BE5B35APO if the student is concurrently registered for or has already completed the course B0B35APO (mutually exclusive courses).
- During a review of study plans, the course B0B35APO can be substituted for the course BE5B35APO.
- It is not possible to register for the course BE5B35APO if the student is concurrently registered for or has previously completed the course B0B35APO (mutually exclusive courses).
- Course guarantor:
- Pavel Píša, Richard Šusta
- Lecturer:
- Pavel Píša, Richard Šusta
- Tutor:
- Jan Kaisrlík, Karel Kočí, Pavel Píša, Richard Šusta, Martin Vajnar, Jiří Vlasák
- Supervisor:
- Department of Control Engineering
- Synopsis:
-
Subject provides overview of basic building blocks of computer systems. Explanation starts from hardware side where it extends knowledge presented in the previous lectures of Structures of computer systems.
Topics cover building blocks description, CPU structure, multiple processors interconnections, input/output subsystem and basic overview of network and buses topologies. Emphasis is placed on clarification of interconnection of hardware components with software support, mainly lower levels of operating systems, device drivers and virtualization techniques. General principles are more elaborated during presentation of examples of multiple standard CPU architectures. Exercises are more focused on the software view to the contrary. Students are lead from basic programming on CPU level to the interaction with raw hardware.
- Requirements:
-
Basic knowledge of C language and area of combinatorial and sequential
logic circuits. Basic knowledge of command line and compilers use
in POSIX standard conformant environment (i.e. Linux) is invited.
- Syllabus of lectures:
-
1. Architecture, structure and organization of computers and its subsystems.
Data and numbers representation and storage in computer systems (signed integer numbers, IEEE-754).
2. Central Processing Unit (CPU) - arithmetic logic unit (ALU), von Neumann architecture, instruction set and encoding, single cycle processor, control unit (CU)
3. Memory - Hierarchical concept, storage technologies, memory management, MMU, data caching, data consistency
4. Pipelined instruction execution, hazards, stages balancing, super-scalar systems
5. Input output subsystem of the computer, shared bus, point-to-point connections, networks, PCI and PCI express, burst mode
6. Industrial computers buses (VME), MULTIBUS, PCIe protocol, reasons to replace parallel buses by multi-lane serial buses, disc storage, data protection and RAID
7. External events processing (interrupts), exceptions, real time clocks, direct memory access, bus master peripherals
8. Processors and computers networks - Topologies, communication, categories LAN, MAN, WAN, networks of control computers
9. Parameters passing to subroutines and operating system implemented virtual instructions. Stack frames, register windows, privilege modes switching and system calls implementation.
10. Classic register memory-oriented CISC architecture.
Principles demonstrated on FreeScale M68xxx/ColdFire architecture. MMU implementation, cache, busses etc.
11. INTEL x86 processor family from 8086 to EMT64, main focus on 32-bit and 64-bit operating modes supplemented with compatibility dictated 16-bit 8086 mode and 80286 segmented approach and why it is used minimally by todays OSes. SIMD instruction examples (MMX, SSE).
12. Short overview of CPU architectures and concepts development (RISC/CISC) - CPU examples ARM, ColdFire, SPARC, PowerPC and CPUs optimized for embedded applications
13. Multi-level computer organization, virtual machines.
Conventional (ISA) architecture and implementation dependent microarchitecture. Portable bytecode and virtual programming environments (Java, C#/.Net). Virtualization techniques (i.e. XEN, VMWARE) and paravirtualization.
14. Analog and digital I/O interfacing, data acquisition and processing
system.
- Syllabus of tutorials:
-
1. Introduction to the labs, computer number formats, numeral systems, entrance test
2. Integer and floating point number representation and operations
3. Basic processor structure and instruction set
4. Hierarchical memory concept, cache
5. Pipeline and hazards
6. Branch prediction and code optimization
7. Memory mapped I/O regions
8. I/O buses and peripherals implementation
9. Mid-term test. Introduction to low level C programming
10. Semester project assignment
11. Independent solving of main task
12. Independent solving of main task
13. Main task hand in and presentation
14. Assessment
- Study Objective:
-
The course gives an overview of computer architecture and teaches students the operation of a typical computer system.
- Study materials:
-
[1] Hennessy, J. L., and D. A. Patterson. Computer Architecture: A
Quantitative Approach, 3rd ed. San Mateo, CA: Morgan Kaufman, 2002.
ISBN: 1558605967.
[2] Patterson, D. A., and J. L. Hennessy. Computer Organization and
Design: The Hardware/Software Interface, 3rd ed. San Mateo, CA: Morgan
Kaufman, 2004. ISBN: 1558606041.
[3] Andrew S. Tanenbaum: Structured Computer Organization. Printice Hall, 2006. ISBN-10:0131485210.
[4] Andrew S. Tanenbaum: Computer Networks. Prentice Hall 2003. ISBN-10:0-13-066102-3.
[5] Andrew S. Tanenbaum: Modern Operating Systems. Prentice Hall 2001
[6] Hyde, R.: The Art of Assembly Language, 2003, 928 pp.
ISBN-10 1-886411-97-2
ISBN-13 978-1-886411-97
http://webster.cs.ucr.edu/AoA/
[7] Bach., M., J.: The Design of the UNIX Operating System,
Prentice Hall, 1986
[8] Bayko., J.: Great Microprocessors of the Past and Present
- Note:
- Further information:
- https://cw.fel.cvut.cz/wiki/courses/b35apo/en/
- Time-table for winter semester 2024/2025:
- Time-table is not available yet
- Time-table for summer semester 2024/2025:
-
06:00–08:0008:00–10:0010:00–12:0012:00–14:0014:00–16:0016:00–18:0018:00–20:0020:00–22:0022:00–24:00
Mon Tue Wed Thu Fri - The course is a part of the following study plans:
-
- Electrical Engineering and Computer Science (EECS) (compulsory elective course)
- Open Informatics - Computer Science 2016 (compulsory course in the program)
- Open Informatics - Internet of Things 2016 (compulsory course in the program)
- Open Informatics - Software 2016 (compulsory course in the program)
- Open Informatics - Computer Games and Graphics 2016 (compulsory course in the program)
- Open Informatics (compulsory course in the program)
- Open Informatics (compulsory elective course)
- Open Informatics - Artificial Intelligence and Computer Science 2018 (compulsory elective course)
- Open Informatics - Internet of Things 2018 (compulsory elective course)
- Open Informatics - Software 2018 (compulsory elective course)
- Open Informatics - Computer Games and Graphics 2018 (compulsory elective course)
- Electrical Engineering and Computer Science (EECS) (compulsory elective course)