Я пытаюсь использовать функцию в vhdl для возврата массива из 4 целых чисел. В моем коде нет синтаксических ошибок, кроме следующих: Тип держателя несовместим с типом шифрования.
type matrix1x4 is array (0 to 3) of integer;
begin
input <= digit1 & digit2;
process(digit1,digit2)
begin
encryptFlag <= '0';
decryptFlag <= '0';
input <= digit1 & digit2;
O <= input;
end process;
process(encry)
variable holder: matrix1x4;
begin
if encryptFlag = '0' and encry = '1' then
encryptFlag <= '1';
decryptFlag <= '1';
holder := encryption(input);
Код в моем пакете, который содержит мою функцию шифрования:
type matrix1x2 is array (0 to 1) of integer;
type matrix1x4 is array (0 to 3) of integer;
type matrix2x2 is array (1 to 2, 1 to 2) of integer;
function encryption (input: std_logic_vector(7 downto 0)) return
matrix1x4;
Код в моей функции шифрования:
variable s1, s2: std_logic_vector(3 downto 0);
variable char1, char2: character;
variable int1, int2,temp1,temp2: integer;
variable inputMat: matrix1x2;
variable encodeMat: matrix2x2;
variable O: matrix1x4;
begin
s1 := input(7 downto 4);
char1 := binToChar(s1);
int1 := charToInt(char1);
s2 := input(3 downto 0);
char2 := binToChar(s2);
int2 := charToInt(char2);
inputMat:= (int1,int2);
encodeMat:= ((1,1),(3,4));
temp1 := inputMat(0) * encodeMat(1,1) + inputMat(1) * encodeMat(1,2);
temp2 := inputMat(1) * encodeMat(2,1) + inputMat(0) * encodeMat(2,2);
int1 := temp1;
int2 := temp2;
temp1 := (temp1 mod 16) + 1;
temp2 := (temp2 mod 16) + 1;
O := (int1,int2, temp1, temp2);
return O;