Forum: FPGA, VHDL & Co. std_logic_vector( x downto x) dynamisch maskieren


von Holger K. (holgerkraehe)


Lesenswert?

Hallo zusammen

Ich habe einen std_logic_vector mit 96Bytes (also 96 x 8Bits)
Nun möchte ich diesen Byte für Byte per SPI hinausschieben.
Dazu habe ich folgendes Stück VHDL geschrieben:
1
 if(SPI_BUSY_FLAG = '0') then
2
            if(intSentDataByte > 0) then
3
              SPI_DATA_IN_L   <= configRegister((8 * intSentDataByte-1) downto ((8 * intSentDataByte)-1));
4
              intSentDataByte <= intSentDataByte - 1;
5
              SPI_ENABLE      <= '1';
6
            else
7
              intBusyState <= fsmSendConfig;
8
            end if;
9
          else
10
            SPI_ENABLE <= '0';
11
          end if;

configRegister ist mein 96Byte grosses register.
intSentDataByte ist mein Counter mit der anzahl gesendeter Bytes.

Leider bekomme ich die Meldung:
1
Direction of the discrete range must be the same as that of the prefix of the slice name.

Ist mein Vorhaben überhaupt möglich?
Ein Schieben von configRegister würde ich nur ungern machen, da ich 
dieses mehrmals benötige und dann immer wieder Initialisieren müsste.

Danke schonmal.

von Christoph Z. (christophz)


Lesenswert?

Holger K. schrieb:
> SPI_DATA_IN_L   <= configRegister((8 * intSentDataByte-1) downto ((8 *
> intSentDataByte)-1));

Trag hier z. B. mal 1 ein für intSentDataByte, dann steht da:
SPI_DATA_IN_L   <= configRegister(0 downto 7)

0 ist kleiner als 7, darum die Fehlermeldung.

Holger K. schrieb:
> std_logic_vector( x downto x) dynamisch maskieren
> Ist mein Vorhaben überhaupt möglich?
> Ein Schieben von configRegister würde ich nur ungern machen, da ich

Hier wird nichts maskiert, was du mit deinem Code beschreibst ist ein 
Multiplexer.

von Holger (Gast)


Lesenswert?

Stimmt. Vielen Dank :)

von Markus F. (mfro)


Lesenswert?

Christoph Z. schrieb:
> Trag hier z. B. mal 1 ein für intSentDataByte, dann steht da:
> SPI_DATA_IN_L   <= configRegister(0 downto 7)
>
> 0 ist kleiner als 7, darum die Fehlermeldung.

uuh?

Punkt vor Strich gilt auch in VHDL...

von Christoph Z. (christophz)


Lesenswert?

Hmm, stimmt.

Dann sollte da stehen 7 downto 7 für intSentDataByte = 1?

Ist auch falsch, sollte aber eine ganze andere Fehlermeldung geben, wie 
"size of left and right side of operand do not match"

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.