EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
256bits 数据串行输入后,经过一个16位寄存器后输出。现在我相对其中的一个16位数据进行修改然后输出。 我用VHDL这么写的 $ r9 h( q5 k6 U1 ]" ?# M
if (s16_register = x"0088") then --判断都进来的数是我寻找的,就对这个数值进行相应的修改 s16_register (15 downto 8) <= s16_register (15 downto 8) + "00000001"; else s16_register <= s16_register (14 downto 0) & data_input; --其他都进来的数不做任何处理, 直接进入寄存器,然后输出 end if; data_output <= s16_register (15);--输出信号
$ e: _+ |/ D( ]0 X1 I: A我感觉这里有点儿矛盾, 我既希望 所有输入的数都去 s16_register, 然后找到要改的值进行改变后, 然后再继续输出。在我对 s16_register里这个特定的值进行修改时,程序总是忽略这个修改, 只执行中间那句,输入信号进入寄存器, 然后直接输出了。 完全没理会我的条件和修改。 我该怎么做, 才能实现这种该值呢?
2 |! {$ I" Z3 k+ u |