我正试图用VHDL创建一个ALU,我很难实现其中的几个操作。我已经实现了加、减和或操作,但是我想知道如何实现逻辑移位操作?ALU是32位,但任何设计都将不胜感激。
发布于 2014-02-03 20:37:49
numeric_std包包含逻辑移位操作,包括shift_right和shift_left。
function SHIFT_LEFT (ARG: UNSIGNED; COUNT: NATURAL) return UNSIGNED;
-- Result subtype: UNSIGNED(ARG'LENGTH-1 downto 0)
-- Result: Performs a shift-left on an UNSIGNED vector COUNT times.
-- The vacated positions are filled with '0'.
-- The COUNT leftmost elements are lost.
function SHIFT_RIGHT (ARG: UNSIGNED; COUNT: NATURAL) return UNSIGNED;
-- Result subtype: UNSIGNED(ARG'LENGTH-1 downto 0)
-- Result: Performs a shift-right on an UNSIGNED vector COUNT times.
-- The vacated positions are filled with '0'.
-- The COUNT rightmost elements are lost.因此,基于此,您可以简单地编写如下代码:
library ieee;
use ieee.numeric_std.all;
architecture syn of mdl is
signal arg : std_logic_vector(31 downto 0);
signal count : std_logic_vector( 4 downto 0);
signal res_r : std_logic_vector(31 downto 0);
signal res_l : std_logic_vector(31 downto 0);
begin
res_r <= std_logic_vector(shift_right(unsigned(arg), to_integer(unsigned(count))));
res_l <= std_logic_vector(shift_left(unsigned(arg), to_integer(unsigned(count))));
end architecture;这些操作是可综合的,并且很好地映射到FPGA资源,如果这是您的目标设备。
以前有一些关于VHDL移位/旋转操作的混乱,参见this link,但是它已经在VHDL-2008中被清理过了。然而,为了向后兼容性,上述建议是基于函数而不是操作符。
https://stackoverflow.com/questions/21535881
复制相似问题