## Tutorial für pr<br/>Magic v1.0

Maximilian Diedrich

21. September 2017

## 1 Vorraussetzungen

- $\bullet\,$  Vivado 2016.3 oder neuer
- $\bullet$  Vivado partial reconfiguration Lizenz
- prMagic v1.0 https://github.com/diedricm/prMagic/releases
- prMagic Tutorial Code https://github.com/diedricm/prMagicTutorial

Ein Projekt mit dem Ergebnis dieses Projekts befindet sich im Ordner **project**. Der für dieses Tutorial zu verwendende Code ist im Ordner **src**.

## 2 Arbeitsschritte

- 1. Lege ein neues Vivado-RTL-Projekt an.
- 2. Importiere den VHDL Beispiel Code. Die Dateien sind:
  - $\bullet$  src/blinkingLEDs.vhd
  - $\bullet$  src/downcounter.vhd
  - src/lshiftLEDs.vhd
  - src/myTopEntity.vhd
  - $\bullet$  src/rshiftLEDs.vhd
  - src/upcounter.vhd
- 3. Es müssen keine IP importiert werden.
- 4. Importiere main.xdc für die IO-constraints.
- 5. Wähle für dieses Tutorial das Zedboard Zynq Evaluation and Development Kit als Zielsystem aus.
- 6. Drücke Finish, um den wizard zu beenden.
- 7. Stelle sicher, dass myTopEntity im hierarchy-view die top-level-entity ist. Wenn das nicht der Fall ist, dann kann, wie in der Darstellung zu sehen ist, mit einem Rechtsklick auf myTopEntity die Option Set as Top ausgewählt werden.



Dies kann auch mit dem TCL-Kommando:

```
set property TOP myTopEntity [get filesets sources 1]
```

erreicht werden.

- 8. Starte die RTL-Analyse, um den Code auf syntaktische Fehler zu testen.
- 9. Definiere als nächstes die dynamischen Module. Füge dafür direkt über der component instantiation leddriver in der architecture Behavioral der entity myTopEntity die folgenden Anweisungen ein:

```
\begin{array}{ll} --prmodule & (rshiftLEDs); \\ --prmodule & (blinkingLEDs); \end{array}
```

Der Code soll danach so aussehen:

Dadurch wird eine Partition **leddriver** mit den Modulen lshiftLEDs, rshiftLEDs und blinkingLEDs erzeugt.

- 10. Füge analog dazu das dynamische Modul downcounter zu der component instantiation triggercoutnter hinzu
- 11. Stelle sicher, dass die Dateien prMagic.tcl und vhdlExtract.jar im momentanen Arbeitsverzeichnis oder im Systempfad sind. Lade das prMagic Script mit:

```
source prMagic.tcl
```

12. Führe prMagic zur automatischen Konfiguration des Projektes auf. Verwende hierfür den eben geladenen Befehl:

```
prm main
```

- 13. Starte die Synthese.
- 14. Wähle **open synthesized design** und markiere die blackboxes leddriver und triggercounter je mit einem Rechtsklick und wähle **Floorplan** > **draw pBlock**. Zeichne einen pBlock, der:
  - (a) Mindestens 20% mehr Ressourcen als das größte zu ihm gehörende Modul benötigt hat.
  - (b) Für 7Series FPGAs: Vertikal durch die Grenzen der Taktregion beschränkt wird. Für Ultrascale FPGAs gilt diese Beschränkung nicht.
  - (c) Horizontal keine Interconnect-Spalte trennt.

Setze für beide pBlocks den Parameter RESET\_AFTER\_RECONFIG auf 1 und den Parameter SNAPPING MODE auf ON.

- 15. Teste mit den Design Rule Checks durch das Klicken auf **Tools** > **Report** > **Report** DRC das Projekt auf Fehler. Wähle nur die Partial Reconfiguration Tests aus und starte die Tests.
- 16. Speicher die *constraints*.
- 17. Starte die Implementierung.
- 18. Starte die Generierung der Bitstreams.
- 19. Die fertigen bitfiles befinden sich nun unter:

  - $\bullet < project name > .runs/prm \ child \ 2 \ impl \ 1/trigger counter \ down counter \ partial. bit$
  - projectname>.runs/prm child 2 impl 1/leddriver lshiftLEDs partial.bit
  - $\bullet < project name > .runs/impl\_1/leddriver \ rshift LEDs \ partial.bit \\$
  - ctname>.runs/impl 1/triggercounter upcounter partial.bit
  - ctname>.runs/impl 1/myTopEntity.bit