我想获取作为输入参数传递的 float32 值的整数值,我正在使用 to_integer() 函数。但我在编译步骤中得到错误:
Warning (10445): VHDL Subtype or Type Declaration warning at float_pkg_c.vhdl(1022): subtype or type has null range
Warning (10036): Verilog HDL or VHDL warning at teste.vhd(13): object "my_integer" assigned a value but never read
Error (10779): VHDL error at float_pkg_c.vhdl(4314): expression is not constant
Error (10657): VHDL Subprogram error at float_pkg_c.vhdl(4314): failed to elaborate call to subprogram "TO_INTEGER"
Error (10657): VHDL Subprogram error at teste.vhd(19): failed to elaborate call to subprogram "to_integer"
Error (12153): Can't elaborate top-level user hierarchy
Error: Quartus II 64-Bit Analysis & Synthesis was unsuccessful. 4 errors, 6 warnings
Error: Peak virtual memory: 537 megabytes
Error: Processing ended: Sat Oct 05 12:23:02 2013
Error: Elapsed time: 00:00:01
Error: Total CPU time (on all processors): 00:00:01
Error (293001): Quartus II Full Compilation was unsuccessful. 6 errors, 6 warnings
如果我声明一个变量,分配一个值并在 to_integer 函数中使用它可以正常工作。但我需要将用于转换的 float32 值作为参数传递。
我使用 VHDL-2008 支持库 ( http://www.eda.org/fphdl/fpfaq.html ) 和 Altera Quartus II 13.0。
我的代码:
LIBRARY ieee;
use ieee.float_pkg.all;
entity teste is
PORT ( my_input : float32 );
end entity;
architecture arquitetura_teste of teste is
begin
process(my_input) is
variable my_float_a : float32;
variable my_float_b : float32;
variable my_integer : integer;
begin
my_float_a := my_input;
my_float_b := to_float(3.14, my_float_b);
my_integer := to_integer(my_float_b);
my_integer := to_integer(my_float_a); -- Error!
end process;
end arquitetura_teste;