

# Universidad Nacional de Colombia (UNAL) Sede Manizales

# Undergraduate Program in Information Systems SILABO

# CS221. Computer Architecture (Mandatory)

#### 2022-II

| : | Sistemas de Información                               |
|---|-------------------------------------------------------|
| : | CS221. Computer Architecture                          |
| : | $3^{er}$ Semestre.                                    |
| : | CS1D2. Discrete Structures II. $(2^{nd} \text{ Sem})$ |
| : | Mandatory                                             |
| : | Face to face                                          |
| : | 2 HT; 2 HL;                                           |
| : | 3                                                     |
|   |                                                       |

#### 2. Professors

# 3. Course foundation

A computer scientist must have a solid knowledge of the organization and design principles of diverse computer systems, by understanding the limitations of modern systems they could propose next-gen paradigms. This course teaches the basics and principles of Computer Architecture. This class addreses digital logic design, basics of Computer Architecture and processor design (Instruction Set architecture, microarchitecture, out-of-order execution, branch prediction), execution paradigms (superscalar, dataflow, VLIW, SIMD, GPUs, systolic, multithreading) and memory system organization.

# 4. Summary

- 1. Digital logic and digital systems 2. Machine level representation of data 3. Assembly level machine organization
- 4. Functional organization 5. Memory system organization and architecture 6. Interfacing and communication 7. Multiprocessing and alternative architectures 8. Performance enhancements

# 5. Generales Goals

- Provide a first approach in Computer Architecture.
- Study the design and evolution of computer architectures, which lead to modern approaches and implementations in computing systems.
- Provide fine-grained details of computer hardware, and its relation with software execution.
- Implement a simple microprocessor using Verilog language.

### 6. Contribution to Outcomes

This discipline contributes to the achievement of the following outcomes:

- 1) Analyze a complex computing problem and to apply principles of computing and other relevant disciplines to identify solutions. (Usage)
- 6) Apply computer science theory and software development fundamentals to produce computing-based solutions. (Assessment)

#### 7. Content.

| 7. Content                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |
| Competences:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | UNIT 1: Digital logic and digital systems (18)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Generales Goals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |
| <ul> <li>Overview and history of computer architecture</li> <li>Combinational and sequential logic/Field programmable gate arrays as a fundamental combinational + sequential logic building block</li> <li>Abstraction models</li> <li>Computer-aided design tools that process hardware and architectural representations</li> <li>Register transfer notation/Hardware Description Language (Verilog/VHDL)</li> <li>Physical constraints (gate delays, fan-in, fan-out, energy/power)</li> </ul> | <ul> <li>Describe the progression of technology devices from vacuum tubes to VLSI, from mainframe computer architectures to the organization of warehouse-scale computers [Familiarity]</li> <li>Comprehend the trend of modern computer architectures towards multi-core and that parallelism is inherent in all hardware systems [Usage]</li> <li>Explain the implications of the "power wall" in terms of further processor performance improvements and the drive towards harnessing parallelism [Usage]</li> <li>Articulate that there are many equivalent representations of computer functionality, including logical expressions and gates, and be able to use mathematical expressions to describe the functions of simple combinational and sequential circuits [Familiarity]</li> </ul> |  |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | • Design the basic building blocks of a computer:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |

to evaluate simple building blocks (eg, arithmeticlogic unit, registers, movement between registers) of a simple computer design [Familiarity]

• Use CAD tools for capture, synthesis, and simulation

arithmetic-logic unit (gate-level), registers (gate-level), central processing unit (register transfer-level), memory (register transfer-level) [Usage]

• Evaluate the functional and timing diagram behavior of a simple processor implemented at the logic circuit level [Assessment]

Readings: D. Harris and S. Harris (2012), Patt and Patel (2005), Patterson and Hennessy (2004), J.Ashenden (2007), Hennessy and Patterson (2006), Parhami (2005), Stalings (2010), P.Chu (2006)

| UNIT 2: Machine level representation of data (8)                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Competences:                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
| Content                                                                                                                                                                                                                                                                                                                       | Generales Goals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
| <ul> <li>Bits, bytes, and words</li> <li>Numeric data representation and number bases</li> <li>Fixed- and floating-point systems</li> <li>Signed and twos-complement representations</li> <li>Representation of non-numeric data (character codes, graphical data)</li> <li>Representation of registers and arrays</li> </ul> | <ul> <li>Explain why everything is data, including instructions, in computers [Assessment]</li> <li>Explain the reasons for using alternative formats to represent numerical data [Familiarity]</li> <li>Describe how negative integers are stored in sign-magnitude and twos-complement representations [Usage]</li> <li>Explain how fixed-length number representations affect accuracy and precision [Usage]</li> <li>Describe the internal representation of non-numeric data, such as characters, strings, records, and arrays [Usage]</li> <li>Convert numerical data from one format to another [Usage]</li> </ul> |  |  |  |  |  |  |
| Readings: D. Harris and S. Harris (2012), Patt J.Ashenden (2007), Hennessy and Patterson (2006), Parha                                                                                                                                                                                                                        | and Patel (2005), Patterson and Hennessy (2004),<br>mi (2005), Stalings (2010), P.Chu (2006)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |

| UNIT 3: Assembly level machine organization (8)                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Competences:                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| Content                                                                                                                                                                                                                                                                                                                                                                                                                                       | Generales Goals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| <ul> <li>Basic organization of the von Neumann machine</li> <li>Control unit; instruction fetch, decode, and execution</li> <li>Instruction sets and types (data manipulation, control, I/O)</li> <li>Assembly/machine language programming</li> <li>Instruction formats</li> <li>Addressing modes</li> <li>Subroutine call and return mechanisms</li> <li>I/O and interrupts</li> <li>Heap vs. Static vs. Stack vs. Code segments</li> </ul> | <ul> <li>Explain the organization of the classical von Neumann machine and its major functional units [Familiarity]</li> <li>Describe how an instruction is executed in a classical von Neumann machine, with extensions for threads, multiprocessor synchronization, and SIMD execution [Familiarity]</li> <li>Describe instruction level parallelism and hazards, and how they are managed in typical processor pipelines [Familiarity]</li> <li>Summarize how instructions are represented at both the machine level and in the context of a symbolic assembler [Familiarity]</li> <li>Demonstrate how to map between high-level language patterns into assembly/machine language notations [Usage]</li> <li>Explain different instruction formats, such as addresses per instruction and variable length vs fixed length formats [Usage]</li> <li>Explain how subroutine calls are handled at the assembly level [Usage]</li> <li>Explain the basic concepts of interrupts and I/O operations [Familiarity]</li> <li>Write simple assembly language program segments [Usage]</li> </ul> |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                               | • Show how fundamental high-level programming constructs are implemented at the machine-language level [Usage]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
| <b>Readings:</b> D. Harris and S. Harris (2012), Patt J.Ashenden (2007), Hennessy and Patterson (2006), Parha                                                                                                                                                                                                                                                                                                                                 | and Patel (2005), Patterson and Hennessy (2004),<br>mi (2005), Stalings (2010), P.Chu (2006)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |

| UNIT 4: Functional organization (8)                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Competences:                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
| Content                                                                                                                                                                                                                                                       | Generales Goals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
| <ul> <li>Implementation of simple datapaths, including instruction pipelining, hazard detection and resolution</li> <li>Control unit: microprogrammed</li> <li>Instruction pipelining</li> <li>Introduction to instruction-level parallelism (ILP)</li> </ul> | <ul> <li>Compare alternative implementation of datapaths [Assessment]</li> <li>Discuss the concept of control points and the generation of control signals using hardwired or microprogrammed implementations [Familiarity]</li> <li>Explain basic instruction level parallelism using pipelining and the major hazards that may occur [Usage]</li> <li>Design and implement a complete processor, including datapath and control [Usage]</li> <li>Determine, for a given processor and memory system implementation, the average cycles per instruction [Assessment]</li> </ul> |  |  |  |  |  |
| Readings: D. Harris and S. Harris (2012), Patt J.Ashenden (2007), Hennessy and Patterson (2006), Parham                                                                                                                                                       | and Patel (2005), Patterson and Hennessy (2004), mi (2005), Stalings (2010), P.Chu (2006)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |

| UNIT 5: Memory system organization and architecture (8)  Competences:                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Content                                                                                                                                                                                                                                                                                                                        | Generales Goals                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
| <ul> <li>Storage systems and their technology</li> <li>Memory hierarchy: importance of temporal and spatial locality</li> <li>Main memory organization and operations</li> <li>Latency, cycle time, bandwidth, and interleaving</li> <li>Cache memories (address mapping, block size, replacement and store policy)</li> </ul> | <ul> <li>Identify the main types of memory technology (eg, SRAM, DRAM, Flash, magnetic disk) and their relative cost and performance [Familiarity]</li> <li>Explain the effect of memory latency on running time [Familiarity]</li> <li>Describe how the use of memory hierarchy (cache, virtual memory) is used to reduce the effective memory latency [Usage]</li> </ul> |  |  |  |  |  |
| <ul> <li>Multiprocessor cache consistency/Using the memory<br/>system for inter-core synchronization/atomic mem-<br/>ory operations</li> <li>Virtual memory (page table, TLB)</li> </ul>                                                                                                                                       | <ul> <li>Describe the principles of memory management [Usage]</li> <li>Explain the workings of a system with virtual memory management [Usage]</li> </ul>                                                                                                                                                                                                                  |  |  |  |  |  |
| <ul><li>Fault handling and reliability</li><li>Error coding, data compression, and data integrity</li></ul>                                                                                                                                                                                                                    | • Compute Average Memory Access Time under a variety of cache and memory configurations and mixes of instruction and data references [Assessment]                                                                                                                                                                                                                          |  |  |  |  |  |

Readings: D. Harris and S. Harris (2012), Patt and Patel (2005), Patterson and Hennessy (2004), J.Ashenden (2007), Hennessy and Patterson (2006), Parhami (2005), Stalings (2010), P.Chu (2006)

| Readings:    | υ.   | Harris   | and     | 5.   | Harris ( | 2012),  | Patt  | and   | Patel (2005),  | Patterson    | and    | Hennessy (2004 | .), |
|--------------|------|----------|---------|------|----------|---------|-------|-------|----------------|--------------|--------|----------------|-----|
| J.Ashenden ( | 2007 | ), Henne | essy ai | nd F | atterson | (2006), | Parha | mi (2 | 005), Stalings | (2010), P.Ch | u (200 | 6)             |     |

| UNIT 7: Multiprocessing and alternative architectures (8)                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Competences:                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
| Content                                                                                                                                                                                                                                                                                      | Generales Goals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
| <ul> <li>Power Law</li> <li>Example SIMD and MIMD instruction sets and architectures</li> <li>Interconnection networks (hypercube, shuffle-exchange, mesh, crossbar)</li> <li>Shared multiprocessor memory systems and memory consistency</li> <li>Multiprocessor cache coherence</li> </ul> | <ul> <li>Discuss the concept of parallel processing beyond the classical von Neumann model [Assessment]</li> <li>Describe alternative parallel architectures such as SIMD and MIMD [Familiarity]</li> <li>Explain the concept of interconnection networks and characterize different approaches [Usage]</li> <li>Discuss the special concerns that multiprocessing systems present with respect to memory management and describe how these are addressed [Familiarity]</li> <li>Describe the differences between memory backplane, processor memory interconnect, and remote memory via networks, their implications for access latency and impact on program performance [Assessment]</li> </ul> |  |  |  |  |  |  |
| Readings: D. Harris and S. Harris (2012), Patt J.Ashenden (2007), Hennessy and Patterson (2006), Parha                                                                                                                                                                                       | and Patel (2005), Patterson and Hennessy (2004),                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| 5. Homondon (2001), Homnessy and Laurenson (2000), Lama                                                                                                                                                                                                                                      | an (2000), Stamings (2010), 1. One (2000)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |

### UNIT 8: Performance enhancements (8) Competences: Content Generales Goals • Superscalar architecture • Describe superscalar architectures and their advantages [Familiarity] • Branch prediction, Speculative execution, Out-oforder execution • Explain the concept of branch prediction and its utility [Usage] • Prefetching • Characterize the costs and benefits of prefetching • Vector processors and GPUs [Assessment] • Hardware support for multithreading • Explain speculative execution and identify the conditions that justify it [Assessment] Scalability • Discuss the performance advantages that multi-• Alternative architectures, such as VLIW/EPIC, and threading offered in an architecture along with the Accelerators and other kinds of Special-Purpose Profactors that make it difficult to derive maximum bencessors efits from this approach [Assessment] • Describe the relevance of scalability to performance [Assessment] D. Harris and S. Harris (2012), Patt and Patel (2005), Patterson and Hennessy (2004), Readings: J.Ashenden (2007), Hennessy and Patterson (2006), Parhami (2005), Stalings (2010), P.Chu (2006)

# 8. Methodology

El profesor del curso presentará clases teóricas de los temas señalados en el programa propiciando la intervención de los alumnos.

El profesor del curso presentará demostraciones para fundamentar clases teóricas.

El profesor y los alumnos realizarán prácticas

Los alumnos deberán asistir a clase habiendo leído lo que el profesor va a presentar. De esta manera se facilitará la comprensión y los estudiantes estarán en mejores condiciones de hacer consultas en clase.

### 9. Assessment

Continuous Assessment 1 : 20 %

Partial Exam: 30 %

Continuous Assessment 2 : 20 %

Final exam : 30 %

# References

Harris, David and Sarah Harris (2012). Digital Design and Computer Architecture. 2nd. Morgan Kaufmann. ISBN: 978-0123944245.

Hennessy, J. L. and D. A. Patterson (2006). Computer Architecture: A Quantitative Approach. 4th. Morgan Kaufman: San Mateo, CA.

J.Ashenden, Peter (2007). Digital Design (Verilog): An Embedded Systems Approach Using Verilog. Morgan Kaufmann. ISBN: 978-0123695277.

P.Chu, Pong (2006). RTL Hardware Design Using VHDL. 1st. Wiley-Interscience.

Parhami, Behrooz (2005). Computer Architecture: From Microprocessors to Supercomputers. Oxford Univ. Press: New York. ISBN: ISBN 0-19-515455-X.

Patt, Yale N and Sanjay J Patel (2005). Introduction to Computing Systems. 2nd. McGraw Hill.

- Patterson, D. A. and J. L. Hennessy (2004). Computer Organization and Design: The Hardware/Software Interface. 3rd ed. Morgan Kaufman: San Mateo, CA.
- Stalings, William (2010). Computer Organization and Architecture: Designing for Performance. 8th. Prentice Hall: Upper Saddle River, NJ.