Forum: FPGA, VHDL & Co. vhdl Frage, aggregat


von daniel (Gast)


Lesenswert?

Hallo,
1
        -- in architecture declatation
2
  type enum1 is (A,B,C);
3
  type enum2 is (A,B,C);
4
  signal x1 : enum1 := A;
5
  signal x2 : enum2 := A;
6
7
  signal n: integer range 0 to 31;
8
  signal m: integer range 0 to 63;
9
10
        -- in architecture body
11
12
  (x1,x2) <= (B,B);
13
  (n,m) <= (1,1);    -- syntax error

vhdl hat im Gegensatz zu meisten Sprachen eine andere Bedeutung von
Literalen. zB kann von einem '0' nicht auf Typ bit oder std_logic
geschlossen werden, wohingegen in C++ zB 1 immer den Typ int hat.
Ebenso kann im oberen Code vom (benutzerdefiniertem) Literal A
nicht auf typ enum1 oder enum2 geschlossen werden.
Um die explizit Literal zu einem Typ zu konvertieren kann man ja
enum1'(A) oder enum2'(A) ausschreiben. Das braucht man zb in dieser
Situation.

  procedure x(a: enum1) is
  begin
  end;

  procedure x(a: enum2) is
  begin
  end;

Aufruf x(A) ist doppeldeutig!

Nun zu meinem Problem mit dem obigen Code:
Ich wundere mich warum in dem obigen Code, die concurrent assignment
(n,m) <= (1,1)  nicht funktioniert, dafür aber (x1,x2) <= (B,B)

grüsse, daniel

von Gast (Gast)


Lesenswert?

nur mal so geraten: integer'(1)?

Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.