mikrocontroller.net

Forum: FPGA, VHDL & Co. Nutzung von "Shared variables"


Autor: mässig erfahrener FPGA Wüstling (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Habe einen Fremd-Code un integrieren, in dem "SHARED VARIABLES" benutzt 
werden, deren Funktion sich mir nicht erschließt.

Die Deklaration lautet:
SHARED VARIABLE arm_address : STD_LOGIC_VECTOR (31 DOWNTO 0) := (OTHERS => '0');
SHARED VARIABLE arm_read_en : STD_LOGIC := '0';
SHARED VARIABLE avm_write   : STD_LOGIC := '0';
SHARED VARIABLE test_vector : STD_LOGIC_VECTOR(7 DOWNTO 0)  := (OTHERS => '0');
Wennn ich in ModelSIM compiliere, kommt :

** Warning: C:\Multiplx\Eggenberg\armsim_sim\armsim.vhd(120): 
(vcom-1236) Shared variables must be of a protected type.

Wie ist das zu lesen / zu nutzen ?

Autor: Joko (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Hi Wüstling,

Regel: Variablen dürfen i.A. nur lokal in einem Prozeß verwendet werden 
!

aber keine Regel ohne Außnahme:

deklariert man eine Variabel als 'shared' s.o., so kann man sie auch 
dort deklarieren, wo man normalerweise ein Signal deklariert.

Dies benötigt man z.B., wenn man "Speicher" beschreiben möchte

aber

'Man' (wer auch immer) hat festgestellt, daß man in der Simulation auf 
Multiprozessor-Systemen in Probleme laufen KANN (nicht muß), weshalb im 
VHDL-Standard 2003 (nur zu diesem Zweck gibts diese neue VHDL-Version) 
den Typ 'protected' eingeführt hat...
(den willst Du aber nicht wirklich verwenden - viel zu komplizert)

Besser:
a) schreib (wenn möglich) den Code um, so daß er "signal" statt 
"variable" verwendet.

b) wenn es nur um's Verständnis geht: ignorier die ModelSim-Warnung und 
erinnere Dich ggf. bei Simulations-Problemen an diese Antwort...

Gruß
Jochen

Autor: mässig erfahrener FPGA Wüstling (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Danke ! super !

Antwort schreiben

Die Angabe einer E-Mail-Adresse ist freiwillig. Wenn Sie automatisch per E-Mail über Antworten auf Ihren Beitrag informiert werden möchten, melden Sie sich bitte an.

Wichtige Regeln - erst lesen, dann posten!

  • Groß- und Kleinschreibung verwenden
  • Längeren Sourcecode nicht im Text einfügen, sondern als Dateianhang

Formatierung (mehr Informationen...)

  • [c]C-Code[/c]
  • [avrasm]AVR-Assembler-Code[/avrasm]
  • [vhdl]VHDL-Code[/vhdl]
  • [code]Code in anderen Sprachen, ASCII-Zeichnungen[/code]
  • [math]Formel in LaTeX-Syntax[/math]
  • [[Titel]] - Link zu Artikel
  • Verweis auf anderen Beitrag einfügen: Rechtsklick auf Beitragstitel,
    "Adresse kopieren", und in den Text einfügen




Bild automatisch verkleinern, falls nötig
Bitte das JPG-Format nur für Fotos und Scans verwenden!
Zeichnungen und Screenshots im PNG- oder
GIF-Format hochladen. Siehe Bildformate.
Hinweis: der ursprüngliche Beitrag ist mehr als 6 Monate alt.
Bitte hier nur auf die ursprüngliche Frage antworten,
für neue Fragen einen neuen Beitrag erstellen.

Mit dem Abschicken bestätigst du, die Nutzungsbedingungen anzuerkennen.