Forum: FPGA, VHDL & Co. Funktion mit mehreren Rückgabewerten


von Nico B. (Firma: Hochschule Bonn-Rhein-Sieg) (jacetms)


Lesenswert?

Hallo zusammen,

gibt es eine Möglichkeit mehrere Rückgabewerte aus Funktionen zu 
erhalten oder ein Array eines bestimmten Typs zurück zu geben?.

Habe jetzt folgenden Code:

Funktionskopf:
1
function test (...) return std_logic;

Funktion:
1
function test (...) return std_logic is 
2
    type arraytype is array (0 to 1) of std_logic;
3
    variable output : arraytype;
4
--...
5
      return output;
6
    end test;

Ich bekomme dabei immer folgende Fehlermeldung:
HDLCompiler:1728
Type error near output ; current type arraytype; expected type std_logic

Wenn ich den Typ-Namen als Rückgabewert im Kopf und Körper der Funktion 
nehme also,
1
function test (...) return arraytype;
dann bekomme ich die Fehlermeldung, dass arraytype nicht deklariert ist.

Was kann ich machen, um den Fehler zu beheben?

Ich hoffe ihr könnt mir weiter helfen und bedanke mich schon mal an 
dieser Stelle für die Hilfe

VG

Nico Brinkmann

von Ben S. (theben)


Lesenswert?

schaue dir mal den dateityp struct an

von MarioStinkt (Gast)


Lesenswert?

>function test (...) return arraytype;
<
>dann bekomme ich die Fehlermeldung, dass arraytype nicht deklariert ist.

Da deklarier doch einfach Funktion und Typ (außerhalb der Funktion) in
einem Package

von Lothar M. (Firma: Titel) (lkmiller) (Moderator) Benutzerseite


Lesenswert?

Nico Brinkmann schrieb:
> gibt es eine Möglichkeit mehrere Rückgabewerte aus Funktionen zu
> erhalten oder ein Array eines bestimmten Typs zurück zu geben?.
Es gibt auch Prozeduren, die können mehrere Werte gleichzeititg 
bearbeiten.

> dann bekomme ich die Fehlermeldung, dass arraytype nicht deklariert ist.
Klar, die Deklaration ist ja auch komplett unterschiedlich. Ein 
arraytype ist kein std_logic:
1
 ... return std_logic is
2
3
 variable output : arraytype;
4
 ... return output;


Probiers einfach mal so:
1
function test (...) return std_logic_vector;
2
3
...
4
5
function test (...) return std_logic_vector is 
6
    variable output : std_logic_vector(1 downto 0);
7
      
8
    return output;
9
end test;

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.