关于VHDL中ALU里的移位运算和乘法运算?

发布网友 发布时间:2022-04-22 09:28

我来回答

1个回答

热心网友 时间:2023-10-27 05:15

移位的问题 用连线来做
例如 5的时候
when "1001" =>
if(B(2 downto 0) = "000") then
Reg3 <= Reg1;
else
Reg3 <= Reg1((7-CONV_INTEGER(B)) downto 0) & Reg1(7 downto (8-CONV_INTEGER(B)));
endif

tmp不用了 直接删掉
还有shift的时候B只用3bit就能覆盖了

我没有编译 如果编译有问题继续问我追问上面这个方法没怎么看懂啊?
还有,主要是老师要求用移位运算的函数 sla 和srl来做的,这里我写的 Reg3 <= Reg1 srl 1,这样写就已经编译出错了,能解释一下为什么吗?还有conv_integer()这个函数我有错在哪里呢?

追答加上USE IEEE.STD_LOGIC_ARITH.ALL 这个library
另外 你试试看把R* 定义为std_logic_bit

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com