Advanced Architectures (ADA)

Description

The objective of the Advanced Architectures course is to provide a general vision of the issues that must be addressed in the design of high-performance architectures. The architecture of the general-purpose microprocessors ( instruction parallelism, pipeline, memory hierarchy, speculative execution, thread parallelism, ..) as well as the challenges for the design of next generation of processors will be presented. The second part of the module will address the design of specialized hardware platforms and architectures used in Systems on a Chip (SoC), that are ubiquitous in mobile and embedded computing. This part of the course will focus on three areas: the approaches and tools used for designing SoCs, the modeling and optimization of power consumption, and finally the design of specialized hardware accelerators.

Keywords

Processor architectures, specialized architectures

Prerequisites

Basics in processor architecture, compilation and systems

Course structure

Microarchitecture:
  • Basic principles (instruction set, pipeline, VLIW instructional parallelism, superscalar, speculative execution, ..)
  • Memory hierarchies
  • Memory coherence
Systems on Chip (SoC) and hardware accelerators:
  • Structure of a SoC: components, interconnection systems, etc.
  • Methodologies and design techniques "low power"
  • Synthesis of dedicated hardware accelerators (High Level Synthesis)

Acquired skills

Complexity of processors:
  • why the running time of a program is not just its instruction number
  • understand the design challenges of future processors
Broad view of synthesis and programming of hardware accelerators:
  • which applications can be targeted by hardware accelerators
  • what techniques should be used and developed for designing/programming hardware accelerators

Teachers

Andre Seznec (responsible), Caroline Collange, Simon Rokicki