# Quick learning guide

Dedicated systems

Teacher: Giuseppe Scollo

University of Catania Department of Mathematics and Computer Science Graduate Course in Computer Science, 2018-19



DMI - Graduate Course in Computer Science

Copyleft @ 2019 Giuseppe Scollo

1 di 12

## Table of Contents

- 1. Quick learning guide
- 2. Educational goals
- 3. Course organization
- 4. Educational activities
- 5. Exams and evaluation
- 6. Lecture Program
- 7. Lab Tutorial Program
- 8. Recommended readings
- 9. Supplementary readings
- 10. Laboratory
- 11. Interaction

DMI - Graduate Course in Computer Science



# To acquire and develop the following capabilities:

- model, design and optimal implementation of application-specific information processing systems
- use of harware and software tools, such as development platforms for embedded systems, to design and to implement embedded systems for highperformance applications

DMI - Graduate Course in Computer Science

Copyleft @ 2019 Giuseppe Scollo

3 di 12

## Course organization

The course is organized in two modules: 24-hour lecture and 24-hour codesign lab (lecture room 24, on mondays and wednesdays, 5-7 pm)

Acquisition of the subject concepts and methods is supported by:

- attendance to lectures and problem solving
- participation to lab experiences
- study of reference readings
- > consultation of supplementary readings
- experience with software tools and development platforms for embedded systems
- working out solutions to proposed problems and exercises, see Test area
- writing reports on lab experiences, in the same area
- > interaction with teacher, weekly schedule:
  - G. Scollo: room 325 (I block, II floor) [phone]ext.: [095738]3007 on mondays and wednesdays, 2:30-4:30 pm
- on monaays and weanesdays, 2:50-4:50 pm

  collaborative interaction with colleagues and teacher

DMI — Graduate Course in Computer Science

#### Educational activities

Lectures: the study of the recommended readings sets the methodological grounds for effective application of a technology-transverse, result-unitary design approach:

versatile design of systems with optimal figure of merit that are dedicated to perform highly specialized tasks

Exercises: starting from a specification of the abstract functionalities of the system, the first problem which is often faced with is to select an architecture wherein to map them out, in order to further proceed to the synthesis of all components: hardware, software, communication interfaces. The proposed exercises deal with the different parts of this process.

Codesign lab: it is envisaged the use of development boards and platforms to implement embedded applications, ranging from on-board configuration to FPGA-based synthesis of components, up to System-on-chip (SoC) implementation. Reports on lab experiences may be outcomes of collaborative group work.

Seminars: as an experimental feature, some lectures (max. 1/5 of the total) take the form of seminars that are prepared and delivered by students; planning of the seminars is carried out as part of a lab tutorial.

DMI - Graduate Course in Computer Science

Copyleft @ 2019 Giuseppe Scollo

5 di 12

## Exams and evaluation

# Oral exam, project (optional)

- evaluation objectives
- > oral exam:
  - assessment of the achievement of educational goals
- optional project:
  - assessment of conceptual and scientific maturity exhibited in the practice of the subject
- ⋟ 🛮 oral colloquies
- assessment of critical learning of the subject
- > evaluation of individual contribution to lab experience reports
- (optional) colloquy on individual use of subject concepts and methods within an <u>original</u> lab project, previously agreed with the teacher, that may be the outcome of a collaborative group effort
- exam schedule

Exam success yields the acquisition of 6 credits.

DMI — Graduate Course in Computer Science

#### Lecture Program

legenda: r = reference readings, s = supplementary readings, rn.# = reference lecture note, sn.# = supplementary lecture note #

- 1. Course goals and organization. Introduction to dedicated systems codesign L01: 01/10/2018, r: 5.01(1.1.4-1.4,1.1.6); s: VG.01(1.1-1.4), BF.01
- 2. Architectures and design process of dedicated systems LO2: 08/10/2018, r: 5.01(1.5,1.7), Z.01(1.1); s: NG.01(1.5-1.6)
- 3. Dataflow models, control flow
- L03: 15/10/2018, r: 5.02; s: L5.06(6.3), M.02(2.5), sn.3, sn.4

  4. Software implementations of dataflow models
- L04: 24/10/2018, r: 5.03(3.1); s: 5.04
- 5. Synchronous systems as finite state machines with datapath (FSMD) L05: 31/10/2018, r: 5.05(5.3-5.4.3,5.6); s: 5.05(5.7)
- 6. Microprogramming: architectures, control, microprogrammed interpreters L06: 07/11/2018, r: 5.06(6.1-6.4); s: 5.06(6.6-6.8)
- 7. Program design and analysis for dedicated systems L07: 14/11/2018, r: 5.07(7.1,7.3); s: 5.07(7.2,7.5), sn.7
- 8. System-on-Chip (SoC) design L08: 21/11/2018, r: 5.08(8.1-8.3); s: 5.08(8.4), R.01
- 9. HW/SW communication, on-chip bus systems L09: 28/11/2018, r: 5.09(9.1-9.4), 5.10(10.1); s: 5.10(10.2-10.4), sn.11
- 10. Microprocessor interfaces
  L10: 12/12/2018, r: 5.11(11.1.1-11.1.5,11.2.0,11.3.0-11.3.1,11.3.3); s: 511(11.1.6,11.2.1-11.2.2,11.3.2,11.3.4)
- 11. Hardware interfaces
  L11: 19/12/2018, r: 5.12(12.1-12.3.1,12.4); s: 5.12(12.3.2)
- 12. Design and implementation of a memory-mapped multicore coprocessor L12: 09/01/2019, lab project

DMI - Graduate Course in Computer Science

Copyleft @ 2019 Giuseppe Scolla

7 di 12

## Lab Tutorial Program

legenda: r = reference readings, s = supplementary readings, rn.# = reference lecture note, sn.# = supplementary lecture note #

- 1. Introduction to the combined use of Gezel with a VHDL simulator E01: 03/10/2018, r: 5.01(1.1.1), S.A(A.1), rn.1, rn.2; s: S.A(A.2)
- 2. Introduction to design of hardware systems using FPGA E02: 10/10/2018, r: Z.01(1.3), rn.3; s: rn.4
- 3. Hardware description languages: Gezel, VHDL, Verilog, SystemC E03: 17/10/2018, r: 5.05(5.1-5.2), Z.03(3.1-3.7, 4.1-4.3); s: HH.4(4.1-4.4,4.7), BF.aB, Z.aB, M.2(2.7), sn.1, sn.2
- 4. Combinational network examples in VHDL E04: 22/10/2018, r: Z.04(4.4-4.6); s: HH.4(4.5,4.8), rn.6(App.A)
- 5. Sequential network examples in VHDL, hardware implementation of dataflow models E05: 29/10/2018, r: Z.06(6.1-6.5.1), S.03(3.2); s: HH4(4.6), S.03(3.3)
- 6. FSMD examples in Gezel and in VHDL E06: 05/11/2018, r: 5.05(5.4.4-5.5); s: Z.07(7.1-7.2), sn.5, sn.6
- 7. Microprocessor design example in Gezel and VHDL E07: 12/11/2018, r: 5.06(6.5); s: Z.07(7.3-7.5)
- 8. Program analysis tools and examples of their use E08: 19/11/2018, r: 5.07(7.4); s: 5.07(7.5,7.6), sn.7, sn.8, sn.9, sn.10
- 9. Component development on FPGA. Planning of student seminars E09: 26/11/2018, , r: rn.5, rn.6
- 10. SoC development on FPGA with application profiling E10: 10/12/2018, r: rn.7; s: sn.12
- 11. FPGA implementation of a memory-mapped coprocessor E11: 17/12/2018, r: lab project
- 12. Design and implementation of a a speaker recognition system E12: 16/01/2019, lab project (student seminar)

DMI - Graduate Course in Computer Science

## Recommended readings

## Reference textbooks

N.B. The recommended parts are displayed in the lecture program, for each lecture, in the short form A.C(S), where: A = initials of textbook author(s), C = chapter, S = section(s)

P.R. Schaumont: A Practical Introduction to Hardware/Software Codesign 2nd Edition. Springer (2012)

with textbook corrections made starting from the 2013-2014 course edition

M. Zwoliński: Digital System Design With VHDL 2nd Edition, Pearson (2004)

#### Reference lecture notes

- Quartus Prime Introduction Using VHDL Designs For Quartus Prime 16.1, Intel Corp. FPGA University Program, November 2016 1.
- Using TimeQuest Timing Analyzer For Quartus Prime 16.1, Intel Corp. FPGA University Program, November 2016
- Quartus Prime Introduction Using Schematic Designs For Quartus Prime 16.1, Intel Corp. FPGA University Program, November 2016
- Using Library Modules in VHDL Designs For Quartus Prime 16.1, Intel Corp. FPGA University Program, November 2016
- Introduction to the Osys System Integration Tool For Quartus Prime 16.1, Intel Corp. FPGA University Program, November 2016
- 6. Making Osys Components - For Quartus Prime 16.1, Intel Corp. - FPGA University Program, November 2016
- Performance Counter Unit Core, Ch. 36 in: Embedded Peripherals IP User Guide, Intel Corp., UG-01085 | 2018.09.24

DMI - Graduate Course in Computer Science

Copyleft @ 2019 Giuseppe Scollo

9 di 12

## Supplementary readings

#### Textbooks

- C. Brandolese, W. Fornaciari: Sistemi embedded: sviluppo hardware e software per sistemi dedicati Pearson, Milano (2007)
- S.L. Harris, D.M. Harris: Digital Design and Computer Architecture, ARM Edition, Morgan Kaufmann (2016)
- E.A. Lee & S.A. Seshia: Introduction to Embedded Systems A Cyber-Physical Systems Approach

2nd Ed., MIT Press (2017)

P. Marwedel: Embedded System Design: Embedded Systems Foundations of Cyber-Physical Systems 2nd Edition. Springer (2011)

- C. Rowen: iEngineering the Complex SOC Fast, Flexible Design with Configurable Processors Prentice-Hall (2004)
- F. Nahid & T. Givargis: Embedded System Design: A Unified Hardware/Software Introduction, Wiley (2002)
- M. Wolf: Computers as components: Principles of embedded computing system design

3rd Edition, Morgan Kaufmann (2012)

#### Supplementary lecture notes

- 1. F. Vahid (2006): Digital Design, Ch. 9, Hardware Description Languages (PDF slides)
- D.J. Smith (1996): VHDL & Verilog Compared & Contrasted 2.
- Ghamarian et al. (2007): Latency minimization for Synchronous Data Flow Graphs
- Stuijk et al. (2006): Exploring trade-offs in buffer requirements and throughput constraints for Synchronous Dataflow Graphs
- 5. C. Brandolese, Introduzione al linguaggio VHDL, Politecnico di Milano
- Note sul VHDL, Corso di Architettura dei Sistemi Integrati 6.
- Introduction to the ARM® Processor Using Intel FPGA Toolchain For Quartus Prime 16.1, Intel Corp. FPGA University Program, November 2016
- Introduction to the Intel Nios II Soft Processor For Quartus Prime 16.1, Intel Corp. FPGA University Program, November 2016 8.
- Intel FPGA Monitor Program Tutorial for ARM For Quartus Prime 16.1, Intel Corp. FPGA University Program, November 2016
- Intel FPGA Monitor Program Tutorial for Nios II For Quartus Prime 16.1, Intel Corp. FPGA University Program, November 2016 1٥.
- 11. Avalon® Interface Specifications, MNL-AVABUSREF, Intel Corp., 2018.09.26
- Profiling Nios II Systems, AN-391-3.0, Altera Corp., July 2011 12.

DMI - Graduate Course in Computer Science

#### Laboratory

Lab activities consist of a series of experiences with the following topics:

- codesign and cosimulation in Gezel and VHDL
- > program optimization in C and assembly languages
- > FPGA programming in VHDL
- codesign, simulation and performance evaluation on SoC development boards with FPGA

DMI - Graduate Course in Computer Science

Copyleft @ 2019 Giuseppe Scollo

11 di 12

## Interaction

# Forum, Moodle, Galileo: what goes where?

- > Forum: discussions about
  - ⋟ 🛾 course organization, news, FAQ
  - problems with use of on-line services, software tools etc.
  - proposals of *ideas* of dedicated system projects
- Moodle (restricted access services):
  - access to educational support materials
  - development of proposed problems and exercises
  - discussions about topics relating to lectures, lab experiences and learning materials
  - group collaboration, delivery of lab experience reports
  - discussions about project proposals and their development
  - discovery and discussion of errors in educational materials (this may award bonus points
     !)
- 🦠 Galileo
  - development of hardware/software projects with documentation and dissemination of results in the public domain

DMI - Graduate Course in Computer Science