Ich habe einen VHDL-Code. Modelsim gibt Fehler mirUnsigned in VHDL
„Länge der erwarteten 32; Länge der tatsächlichen 31“
Wie Code zu schreiben, dass es richtig war, und mir nicht Länge von Vektoren zu schreiben. Ich möchte, das wie in Verilog funktioniert: Verilog
reg [30:0] smth1 = 2735*12;
reg [15:0] smth2 = 12*11;
reg [31:0] smth1_s;
always (*)
begin
smth1_s <= smth1+smth2;
end
VHDL:
library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;
use ieee.numeric_std.all;
entity top is
end entity;
architecture top of top is
signal smth1 : unsigned(30 downto 0) := to_unsigned(2735,16) * to_unsigned(12,15); --reg [31:0] smth1 = 12'hAAF * 12;
signal smth2 : unsigned(15 downto 0) := to_unsigned(12,16)/to_unsigned(11,16); --reg [15:0] smth2 = 12*11;
signal smth1_s : unsigned(31 downto 0);
begin
smth1_s <= smth1 + smth2;
end architecture;
'" + "' an Unsigned nimmt Eingaben und gibt eine Ausgabe der gleichen Länge zurück. Ein Ansatz besteht darin, die Eingaben zu erweitern: Für Unsigned bedeutet das einfach 'smth1_s <=' 0 '& smth1 +' 0 '& smth2; ' –