SEm/labore/06 apb

From FSI
Revision as of 22:10, 19 June 2013 by Guo (Talk | contribs)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to: navigation, search

Contents

APB Komponent

Einleitung

Dieses Labor zeigt die Erstellung eines APB Komponenten basierend auf der GRLib. Dieser Komponent wird gebraucht um Taster zu lesen und LEDs zu steuern.

Analyse des APB Busses

Schaltung

Die Analyse des APB-Busses basiert auf folgender Schaltung.

Schaltung zur Analyse des APB Busses

Das System wird durch die serielle Schnittstelle ahbuart gesteuert, welches ein Master des AMBA Busses ist. Damit kann auf die andere serielle Schnittstelle, apbuart, zugegriffen werden.

Initialisierung des Masters AHBUART

View-pim-tasks.png

Initialisieren Sie die Schaltung indem Sie den Charakter 55 h auf der RS232 Linie senden. Der ahbuart nützt es, um das Baudrate der seriellen Schnittstelle herauszufinden.

Initializierung des Komponenten APBUART

View-pim-tasks.png

Initialisieren Sie das Steuer- und das Baudrate-Register bei den Adressen 8000.0208 h und 8000.020C h. Dies wird mit Hilfe von der Sequenz C1 80000208 80001003 00000008 durchgeführt.


View-pim-tasks.png

In der Simulation folgen Sie den Änderungen der Register r.rxen und r.brate des Komponenten apbuart.

Übertragung mit Hilfe des Komponenten APBUART

View-pim-tasks.png

Starten Sie das Senden eines Charakters auf der seriellen Schnittstelle, indem Sie dessen ASCII-Code zur Adresse 8000.0200 h schreiben.


View-pim-tasks.png

In der Simulation, stellen Sie die Senden des Charakters auf der seriellen Linie fest und folgen Sie den Änderungen der Register r.tcnt und r.thold des Komponenten apbuart.

Lesen des Status des dem Komponenten APBUART

View-pim-tasks.png

Lesen Sie das Statusregister des Komponenten, indem sie ein Wort bei Adresse 8000.0204 h lesen. Dies wird mit Hilfe der Sequenz 80 80000204 durchgeführt.


View-pim-tasks.png

Analysieren Sie in der Simulation den zurückgelesenen Wert.


View-pim-tasks.png

Senden Sie einige Charakter auf der Linie rxd1, d.h. auf dem seriellen Eingang des Komponenten apbuart.


View-pim-tasks.png

Folgen Sie in der Simulation den Änderungen der Register r.rcnt und r.rhold des Komponenten apbuart.


View-pim-tasks.png

Lesen Sie erneut das Statusregister des Komponenten und erklären Sie den Unterschied mit dem ersten Leseergebnis.

Signale des APB Busses

View-pim-tasks.png

Folgen Sie in der Simulation dem Datentransfer auf dem APB Bus.


View-pim-tasks.png

Erstellen Sie die Liste der Signale in den Typen apbi und apbo.


View-pim-tasks.png

Zeichen Sie einen Lese- und einen Schreibe-Zyklus eines APB Komponentes.

Index und Adressen

View-pim-tasks.png

Untersuchen Sie den VHDL-Code des Komponenten apbuart und finden Sie die Übereinstimmungen von pconfig. Bestimmen Sie, wozu dieses dient.


View-pim-tasks.png

Untersuchen Sie den VHDL-Code des Komponenten apbuart und finden Sie die Übereinstimmungen von pindex. Erklären Sie, wie der Komponent der AHB/APB Brücke (apbctrl) seinen Index übermittelt.

Der Teil report_version erlaubt es, eine Mitteilung am Anfang der Simulation anzuzeigen. Der Code zwischen den Pragmas translate_off und translate_on wird vom Synthese-Tool ignoriert und nicht synthetisiert.

Erstellung des APB Komponenten

Der zu erstellende Komponent wird dazu dienen, auf der Testplatte Schalter zu lesen und LEDs zu steuern..

Registerplan

Der Komponent hat 2 Register:

  • Das Register mit dem Zustand der Schalter bei Adresse 0x0
  • Das Register mit dem Steuerwert der LEDs bei Adresse 0x4

Die LSBs von jedem Register geben den Zustand oder den Steuerwert der jeweiligen Ein- und Ausgänge (Schalter oder LEDs).

Schaltung

Der Komponent hat folgende generischen Parameter:

  • pindex: seinen Index auf dem APB Bus
  • paddr und pmask: die Parameter, welche bestimmen, bei welchen Bus-Adressen sich der Komponent befindet
  • buttonnb: die Anzahl Schalter welche an den Komponenten angeschlossen sind
  • lednb: die Anzahl LEDs welche vom Komponenten gesteuert werden


View-pim-tasks.png

Erstellen Sie im Block gr_beamer einen neuen Komponenten, welcher am APB Bus angeschlossen ist.


View-pim-tasks.png

Bringen Sie die Schalter-Eingänge und die LED-Ausgänge an die Ports des gr_beamer Blocks.


View-pim-tasks.png

Schreiben Sie den VHDL-Code des neuen APB Komponenten.


View-pim-tasks.png

Im Block beamer, ziehen Sie die neuen Ein- und Ausgängen des Komponenten gr_beamer auf die Ports dieses Blocks.

Simulation

View-pim-tasks.png

Führen Sie eine Simulation des Systems durch, um die Funktionalität des neuen APB Komponenten sicherzustellen.


Navigation
Arrow left.gif 05 AMBA-Bus basiertes System Arrow up.gif Anleitung auf Deutsch 07 Oszillo Peripheriebaustein Arrow right.gif

Personal tools
Namespaces
Variants
Actions
Navigation
Modules / Projects
Browse
Toolbox