找回密码
 注册
关于网站域名变更的通知
查看: 210|回复: 3
打印 上一主题 下一主题

VHDL如何实现对串行输入的数据改值后输出?

[复制链接]
  • TA的每日心情
    开心
    2022-1-29 15:04
  • 签到天数: 1 天

    [LV.1]初来乍到

    跳转到指定楼层
    1#
    发表于 2022-4-22 13:48 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

    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
  • TA的每日心情
    开心
    2022-1-24 15:10
  • 签到天数: 1 天

    [LV.1]初来乍到

    2#
    发表于 2022-4-22 14:53 | 只看该作者
    输入是什么数据?16位数据的话,可以先转换成成并行数据,判断修改好后再转成串行数据!
    8 {5 u8 ]8 @8 W3 O: j2 ]/ _6 O/ m% l+ P6 K* [/ r

    该用户从未签到

    3#
    发表于 2022-4-22 15:01 | 只看该作者
    先说一下你程序的问题:所有的代码都是并行的,我没有猜错的化,你的状态机是在数据进入16为寄存器后就开始向输出脚开始输出了。你虽然加入和这个组合逻辑,这个逻辑和状态机发送开始时是同时的,所以你的组合逻辑就不会被执行。# p% X% L: S' Z9 k1 ~
    建议:你在数据进入16位寄存器后,先不要发送。在启动发送前增加一个状态机状态,判断数据是否需要改变,在开始发送状态。这样判断和发送不是同时进行的。而是判断在发送前。
  • TA的每日心情
    开心
    2022-1-21 15:08
  • 签到天数: 1 天

    [LV.1]初来乍到

    4#
    发表于 2022-4-22 15:20 | 只看该作者
    因为我没有看到你的完整代码。时刻牢记组合逻辑是在每时每刻都在执行的,因为这是电路不是程序。
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

    推荐内容上一条 /1 下一条

    EDA365公众号

    关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

    GMT+8, 2025-7-27 11:52 , Processed in 0.109375 second(s), 23 queries , Gzip On.

    深圳市墨知创新科技有限公司

    地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

    快速回复 返回顶部 返回列表