News

Internship, PhD, job proposals…

Description

Implementing a data processing as a software running on a general purpose processor or on specialized processors like Graphics Processing Units (GPU) does not always provide the required level of efficiency. These solutions can be too slow, too expensive or too power hungry for a given application.

In these cases, dedicated hardware accelerators are sometimes the right solution. They are not as flexible as software, they are frequently more difficult to design, but they are also usually orders of magnitude more efficient: they do only a limited number of things but they do them extremely well.

Many computer systems around us, like our smartphones, embed hardware accelerators for wireless communications, speech, audio, image or video processing, cryptography, deep learning, etc.

This course provides an overview of the specification, design, development, and validation of digital hardware accelerators for embedded systems. It also shows how to integrate them inside a microprocessor-based computer system, and how to use them from software applications.

Teaching and learning methods: laboratory sessions, project, homework. Students are provided with industrial grade prototyping boards and design tools for the whole course duration. A hands-on approach is taken, with the aid of state-of-the-art laboratory equipment. Most of the course is dedicated to the design of hardware/software mixed systems of increasing complexity, and their test on a mini PC-like prototyping board based on an ARM microprocessor and a FPGA fabric. During the final project (21 hours) the students work in small groups to build a complete hardware and software prototype of a data processing system. Past projects were about retro-gaming, cryptography, real time video processing, pattern recognition, bitcoin mining, DES cracking, etc.

Prerequisites: binary representations of numbers (unsigned, two's complement), boolean logic, boolean operators, basic C programming, basic GNU/Linux command line interface.

Topics:

Learning Outcomes:

Evaluation

A two hours written exam, with all documents you want, accounts for 50% of the overall mark. The final project accounts for the remaining 50% Example past exams:

Please do not ask for the official answers of these past exams, there are no official answers.

Schedule

Recommendations for the lab sessions

All labs are distributed and managed using git and GitLab.

DateRoomTitleResources
2025-02-19, 2025-02-2652Lab: continuity testerDesign of a continuity tester, VHDL coding, simulation, synthesis, on-board testing Installing and using GHDL and GTKWave under macOS Simulation with Siemens Modelsim in GUI mode
2025-03-0552Lab: shift register, timerCoding challenge: a shift register Coding challenge: a timer
2025-03-1252Lab: LED blinkerCoding challenge: a LED blinker
2025-03-{19,26}52Lab: re-synchronizer and edges detector, counter, edges counter, core DHT11 controllerCoding challenge: a re-synchronizer and edges detector Coding challenge: a counter Coding challenge: an edge counter Design of the core of a DHT11 controller Moore and Mealy FSM design and VHDL coding
2025-03-26, 2024-04-0252Lab: AXI4 wrapper for the DHT11 controllerDesign of a AXI4 lite wrapper for the core DHT11 controller
2025-04-0252Lab: Linux driver for the DHT11 controllerHardware/software integration: a Linux software driver for the DHT11 AXI4 controller
2025-04-{09,16,23}, 2025-05-{07,14,21}, 2025-06-{04,11}52Project

Bibliography

You read one of these documents? Or another that is not in the list and should? Please drop me a note and give me some feedback.

Books available in EURECOM's library

La conception de systèmes avec FPGA, P. Simpson, 2014, Dunod, 304 p.
Embedded systems handbook, Zurawski R., CRC Press, 2009, 1503 p.
Embedded system design : Modeling, synthesis and verification, Gajski, Daniel D ; Abdi, Samar ; Gerstlauer, Andreas ; Shirner, Gunar, Springer-Verlag - 2009 - 352 p.
Designer's guide to VHDL, Peter J. Ashenden, 2008, Morgan Kaufmann, 936 p.
Advanced Fpga design : architecture, implementation, and optimization, S. Kilts, 2007, IEEE Computer Society Press, 352 p.

Online books

The Zynq book, Crockett, Louise H ; Elliot, Rose A ; Enderwitz, Martin A ; Stewart, Robert W, 2014, Strathclyde Academic Media, 484 p.The Zynq book
Free Range VHDL, the book, Fabrizio Tappero and Bryan Mealy, 2023, Github, 244 p.Free Range VHDL

Miscellaneous

Lecture (obsolete). Introduction: presentation of the course, digital hardware design, SoC (Systems on Chip), Renaud PacaletSlides Solutions of exercises
Lecture (obsolete). Validation: simulation, formal verification, hardware emulation, Renaud PacaletSlides Solutions of exercises
Lecture (obsolete). VHDL (Very high speed integrated circuits Hardware Description Language), Renaud PacaletSlides Animated simulation Solutions of exercises
VHDL-1993 quick reference card (the whole syntax on two pages only), QualisVHDL-1993 quick reference card
IEEE 1164 packages quick reference card (the whole syntax on two pages only), QualisIEEE 1164 packages quick reference card
The OpenCores project, OpenCoresOpenCores
Accellera, the VHDL, Verilog and SystemC standardization body, AccelleraAccellera
The Hamburg VHDL archive (FAQ, VHDL models...), University of HamburgThe Hamburg VHDL archive

Tools

GHDL, a free software VHDL simulator, Tristan GingoldGHDL
gEDA, free software CAD tools, including GTKWave (waveform viewer), and Icarus (Verilog simulation-synthesis)gEDA
Yosys, a free software Verilog logic synthesizer, Clifford WolfYosys
Chisel, an open-source hardware construction language, UC BerkeleyChisel