## DTP2 Code Checkliste

| Allgemein                                                                                                                                                                                               | Kommentar                                                                                                                                                                                                                |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Nur synchrone Prozesse                                                                                                                                                                                  | Keine Logik auf das Clock-Signal                                                                                                                                                                                         |
| Reset ist asynchrones Signal und darf nur im                                                                                                                                                            | Oder Synchrones Reset, aber gleich für ganzes Projekt                                                                                                                                                                    |
| getakteten Prozess verwendet werden                                                                                                                                                                     | (clock und reset strategy kurz kommentieren)                                                                                                                                                                             |
| Keine Latches (keine asynchronen Speicher)                                                                                                                                                              | Auch keine Komb-Loops, und keine offene Eingänge                                                                                                                                                                         |
| In kombinatorischen Prozessen müssen alle                                                                                                                                                               | Mit VHDL-2008 muss nur «all» in die Sensitivity liste                                                                                                                                                                    |
| Eingangssignale auf in die sensitivity Liste                                                                                                                                                            | eingetragen werden                                                                                                                                                                                                       |
| (ausser der code ist für VHDL 2008 geschrieben)                                                                                                                                                         |                                                                                                                                                                                                                          |
| Signale aus unterschiedlichen Clock Domains                                                                                                                                                             | Auch das globale reset Signal                                                                                                                                                                                            |
| (oder asynchrone Eingänge) müssen                                                                                                                                                                       |                                                                                                                                                                                                                          |
| synchronisiert werden                                                                                                                                                                                   |                                                                                                                                                                                                                          |
| Bevorzugt Moore, wenn möglich keine Mealy<br>Maschinen bauen                                                                                                                                            | Das bedeutet Eingänge gehen durch die FSM<br>Ansteuerlogik (Eingangslogik), dann durch FFs, und<br>bestimmen nicht direkt die Ausgänge. Gute Praxis ist<br>separate Prozesse für Ansteuerlogik, FF und<br>Ausgangslogik. |
| Top-Testbench (TB) pro Milesteine (oder nur<br>eigenen testcase.dat für jeden Meilenstein),<br>oder Block-TB wo sinnvoll. Die testcases decken<br>verschiedene Betriebsarten und kritische<br>Punkte ab | z.B. Einfluss von Eingangssignalen und Überlauf von<br>Zähler.                                                                                                                                                           |
| Kurz Erklärung von Testszenario für                                                                                                                                                                     | Falls self-checking TB nicht möglich, Kommentare über                                                                                                                                                                    |
| Testbenches.                                                                                                                                                                                            | Testszenario und visuelle checks.                                                                                                                                                                                        |
| Mind. eine TB / Design /Integr. pro Person                                                                                                                                                              | Jede hat alle Tätigkeiten ausprobiert                                                                                                                                                                                    |
| VHDL Style                                                                                                                                                                                              | Kommentar                                                                                                                                                                                                                |
| VHDL Code muss leserlich formatiert sein.                                                                                                                                                               | Benutzen Sie im emacs VHDL Beautify                                                                                                                                                                                      |
| (Klammern, IF-Else, Begin, End)                                                                                                                                                                         | (ctrl-c dann b)                                                                                                                                                                                                          |
| Klar getrennte Prozesse                                                                                                                                                                                 | Getrennte getaktete und kombinatorische Prozesse.                                                                                                                                                                        |
|                                                                                                                                                                                                         | Wo sinnvoll: getrennte komb. Prozesse für                                                                                                                                                                                |
|                                                                                                                                                                                                         | Eingangslogik/Ausgangslogik                                                                                                                                                                                              |
| Sinnvolle Anwendung von CASE vs IF-ELSE                                                                                                                                                                 | Check ob Logik prio oder nicht braucht                                                                                                                                                                                   |
|                                                                                                                                                                                                         | Aber nicht übertreiben: CASE/WHEN mit nur 1-bit                                                                                                                                                                          |
|                                                                                                                                                                                                         | nicht sinnvoll, besser IF-ELSE                                                                                                                                                                                           |
| Nutzung der Prioritäten von IF-ELSE um                                                                                                                                                                  | z.B. wenn in der Logik keine Ausgabe gemacht wird,                                                                                                                                                                       |
| übersichtlichen Code zu gestalten                                                                                                                                                                       | solange enable_xxx nicht wahr ist                                                                                                                                                                                        |
| Keine Funktionalität in der Strukturellen Entity                                                                                                                                                        | Hierarchische Blöcke nur mit Komponenten und                                                                                                                                                                             |
| (Top Level)                                                                                                                                                                                             | Instanziierungen Vermeidung RTL-Design und Hierarchie zu mischen. Kurzen Kommentar abgeben falls dies nicht möglich ist.                                                                                                 |
| Sinnvolle Aufteilung von logischen Prozessen                                                                                                                                                            | Packt verwandte Funktionalität, und behält Überblick<br>/ Komplexität im Griff für Code-Leser                                                                                                                            |
| Entity Ports haben std_logic oder                                                                                                                                                                       | Ausnahmen (wo wirklich sinnvoll, e.g. mid_array)                                                                                                                                                                         |
| std_logic_vector als Daten-Typ                                                                                                                                                                          | kommentieren                                                                                                                                                                                                             |
| Keine Signal forcing                                                                                                                                                                                    | Nur eine Ausnahme erwartet (clock_divider). Kommentieren warum.                                                                                                                                                          |
| Code Dokumentation                                                                                                                                                                                      | <b>Kommentar</b>                                                                                                                                                                                                         |
| Header mit Namen des Erstellers und<br>Änderungsliste. Kurze Beschreibung was der<br>Block macht                                                                                                        | Falls Sie ein Version-Management Tool benutzt haben, kann man sich in der Änderungsliste darauf beziehen.                                                                                                                |

| Sinnvolle Kommentare                     | An Code-Stellen die nicht naheliegend sind (e.g. support running status MIDI) |
|------------------------------------------|-------------------------------------------------------------------------------|
| Sinnvolle Signalnamen                    | Schlecht nur Name "State" für FSM Codierung                                   |
| Signalnamen müssen Polarität anzeigen    | z.B. reset_n falls low aktiv                                                  |
| Naming convention for ports, signals and | Uniform along the project for all blocks                                      |
| process                                  |                                                                               |
| Synthese Synthese                        | <b>Kommentar</b>                                                              |
| Warnungen                                | Bleibende Warnung checken und kommentieren                                    |
|                                          | welche akzeptabel sind                                                        |
| Check Resource Utilization               | FFs, Komb-Log, Mem-Blocks                                                     |