# Modélisation Transactionnelle des Systèmes sur Puce avec SystemC Ensimag 3A — filière SEOC Grenoble-INP

TLM Avancé & Conclusion

Frédéric Pétrot

frederic.petrot@univ-grenoble-alpes.fr

2020-2021





## Planning des séances

```
Introduction: systèmes sur puce et modélisation au niveau transactionnel
09/10 (FP) Introduction au C++
15/10 (FP) Présentation de SystemC, éléments de base
16/10 (FP) Communications haut-niveau en SystemC
22/10 (FP) Modélisation TLM en SystemC
23/10 (FP) Intervenant extérieur : Laurent Maillet-Contoz (STMicroelectronics)
05/11 (FP) TP1 (1/1): Première plateforme SystemC/TLM
12/11 (FP) Utilisations des plateformes TLM
13/11 (FP) TP2 (1/3): Intégration du logiciel embarqué
26/11 (FP) TP2 (2/3): Intégration du logiciel embarqué
27/11 (FP) TP2 (3/3): Intégration du logiciel embarqué
03/12 (OM) Synthèse d'architecture
04/12 (OM) TP3 (1/2): Synthèse de haut niveau et génération de circuits numériques
```

- 17/12 (FP) Notions Avancées en SystemC/TLM
- 18/12 (FP) Perspectives et conclusion



11/12 (OM) TP3 (2/2): Synthèse de haut niveau et génération de circuits numériques

- Quelques mots sur l'examen
- Récapitulatif sur les TPs
- Écosystème TLM



- Quelques mots sur l'examen
- Récapitulatif sur les TPs
- Écosystème TLM



### Préparer l'examen

- Annales disponibles (répertoire exam/)
- Documents interdits
- Une feuille A4 recto-verso manuscrite autorisée



## Sujet d'examen

- Questions de cours C++, SystemC/TLM, intervenant extérieur
- 1 exercice sur le temps simulé/wall-clock (cf. années précédentes)
- 1 problème : extension de la plateforme « TP2 ». Cette année (2018-2019) : composant matériel pour calculer le nombre de voisin à 1 d'un point dans une image bitmap



# À savoir impérativement

- C++
- Bases de SystemC : SC\_MODULE, SC\_THREAD, SC\_METHOD, wait, notify,
- Les principes de TLM 2.0
- L'API EnsitIm : read, write, map, bind
- L'API hal: hal\_read32, hal\_write32, hal\_cpu\_relax, hal\_wait\_for\_irq.



### Ce qui énerve le correcteur ...

- Confusion entre hardware et software (e.g. écrire du SystemC dans le soft embarqué, ou utiliser hal.h dans le modèle de matériel)
- « Justifiez brièvement » mal lu
- Les erreurs sur les points répétés N fois en TP/cours.



- Quelques mots sur l'examen
- Récapitulatif sur les TPs
- Écosystème TLM



### TP n°1, début

- Prise en main de SystemC/GCC
- Écriture d'un générateur de transactions
  - Outil de test de plateforme
  - Représente les accès que ferait un processeur (par ex)
- Écriture d'une mémoire
  - Mécanisme d'adresse locale (offset)
  - Implémentation du comportement (tableau dynamique C++)
- Comportement global





### TP n°1, fin

- Lecture de documentation technique : contrat d'utilisation du LCDC
- Modélisation de registres
  - Utilisation des événements SystemC
  - Correspondance avec la documentation
- Gestion des interruptions
- Fabrication d'images en mémoire, ...



# TP n°1 - Figure





### TP n°2

- Intégration du logiciel embarqué.
  - Avec ISS
  - En simulation native
- Correspondance entre plateforme physique (FPGA) et TLM
  - Même registres, même addressmap, même comportement
  - ► RAM programme gérée différemment
  - Protocole de bus non modélisé en TLM
- Logiciel portable via hal.h:
  - Une implémentation en simulation native
  - ▶ Une implémentation pour RISC-V (ISS ou FPGA tbc –)



### TP n°2: Chaînes de compilation

#### Native:

- ▶ g++/gcc, comme d'habitude
- extern "C" pour faire communiquer le C et le C++ (problème de mangling et d'ABI)
- Édition de liens entre plateforme et logiciel

#### Croisée:

- riscv64-unknown-elf-{gcc,ld,objdump}: tourne sur x86\_64, génère du code pour RISC-V
- Logiciel embarqué compilé en un fichier ELF ...
- ... chargé dynamiquement en RAM par la plateforme
- ▶ boot.s: adresse de boot, vecteur d'interruption, ...
- it.s: routine d'interruption (sauvegarde/restauration de registres avant d'appeler une fonction C)
- ► ldscript: utilisé par riscv64-unknown-elf-ld pour décider des adresses des symboles.
- printf: marche sur FPGA via une UART, trivial en simu native, composant UART en simu ISS.



## TP n°2 : ce à quoi vous avez échappé...

- Fait pour vous:
  - Écriture des composants TLM (Giovanni Funchal)
  - ▶ ISS RISC-V, boot.s, it.s (votre serviteur, riscv-probe)
- Non géré:
  - gdb-server: pour déboguer le logiciel avec gdb comme s'il tournait sur une machine physique distante.
  - Temps précis
  - Transaction bloc (entre RAM et VGA en particulier)
  - Conflits sur le bus entre RAM ↔ VGA et fetch.
  - Contrôleur d'interruption évolué (le notre est essentiellement une porte « ou »)



- Quelques mots sur l'examen
- Récapitulatif sur les TPs
- Écosystème TLM



### Réutilisation de composants

Piloté par le consortium Accellera (https://www.accellera.org)

- Point de vue d'un industriel :
  - Écriture de modèles TLM réutilisables de composants maisons
  - ▶ Modèles TLM de composants d'entreprises tierces ?
- Idée : chaque fabricant de composant fournit plusieurs modèles
  - RTL ou netlist
  - Modèle TLM, etc.
  - etc.
- Problème : mettre tout le monde d'accord sur l'écriture de modèles TLM



#### **Documentation**

Piloté par le consortium Accellera (https://www.accellera.org)

- Besoin d'informations organisées sur chaque composant
  - Ensemble de registres
  - Nombre de ports
  - Technologies de fabrication supportées
  - Consommation électrique
  - Surface, ...



#### **Documentation**

Piloté par le consortium Accellera (https://www.accellera.org)

- Besoin d'informations organisées sur chaque composant
  - Ensemble de registres
  - Nombre de ports
  - Technologies de fabrication supportées
  - Consommation électrique
  - Surface, ...
- Création d'un consortium d'industriels pour standardiser les informations associées à un composant
  - Consortium SPIRIT : Structure for Packaging, Integrating and Re-using IP within Tool-flows Standard IP-XACT.



- Exemple de document : fichier XML conforme à un schéma
- Création d'outils exploitant ces informations



#### Conclusion

#### SystemC

- « Langage » de modélisation niveau système
- Utilisation par les industriels
- Nombre conséquent d'outils
  - ★ Dédiés (CAD Vendors)
  - ★ Provenant de C++ (GCC, gdb, gprof, valgrind, etc.)

#### TLM

- Niveau émergent de modélisation de composants électroniques
- Utilisation de SystemC
- Existence d'outils spécifiques TLM (Cadence, Synopsys, GreenSocs, ...)

