2474|5

1

帖子

0

TA的资源

一粒金砂(初级)

楼主
 

VHDL如何实现对串行输入的数据改值后输出? [复制链接]

256bits 数据串行输入后,经过一个16位寄存器后输出。现在我相对其中的一个16位数据进行修改然后输出。

我用VHDL这么写的

 

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);--输出信号

 

我感觉这里有点儿矛盾, 我既希望 所有输入的数都去 s16_register, 然后找到要改的值进行改变后, 然后再继续输出。在我对 s16_register里这个特定的值进行修改时,程序总是忽略这个修改, 只执行中间那句,输入信号进入寄存器, 然后直接输出了。 完全没理会我的条件和修改。

我该怎么做, 才能实现这种该值呢?

此帖出自FPGA/CPLD论坛

最新回复

如果不用状态机隔开的话,你这个if走完下一个clk周期又去执行else了   详情 回复 发表于 2023-2-24 11:20
点赞 关注
 

回复
举报

2万

帖子

71

TA的资源

管理员

沙发
 

楼主问题解决了吧?可以来总结下经验:)

此帖出自FPGA/CPLD论坛
加EE小助手好友,
入技术交流群
EE服务号
精彩活动e手掌握
EE订阅号
热门资讯e网打尽
聚焦汽车电子软硬件开发
认真关注技术本身
个人签名

加油!在电子行业默默贡献自己的力量!:)

 
 

回复

1

帖子

0

TA的资源

一粒金砂(初级)

板凳
 

输入是什么数据?16位数据的话,可以先转换成成并行数据,判断修改好后再转成串行数据!

此帖出自FPGA/CPLD论坛
 
 
 

回复

2933

帖子

4

TA的资源

五彩晶圆(中级)

4
 

先说一下你程序的问题:所有的代码都是并行的,我没有猜错的化,你的状态机是在数据进入16为寄存器后就开始向输出脚开始输出了。你虽然加入和这个组合逻辑,这个逻辑和状态机发送开始时是同时的,所以你的组合逻辑就不会被执行。

建议:你在数据进入16位寄存器后,先不要发送。在启动发送前增加一个状态机状态,判断数据是否需要改变,在开始发送状态。这样判断和发送不是同时进行的。而是判断在发送前。

此帖出自FPGA/CPLD论坛
 
 
 

回复

2933

帖子

4

TA的资源

五彩晶圆(中级)

5
 

以上我只是猜测,因为我没有看到你的完整代码。时刻牢记组合逻辑是在每时每刻都在执行的,因为这是电路不是程序。

此帖出自FPGA/CPLD论坛
 
 
 

回复

2

帖子

0

TA的资源

一粒金砂(初级)

6
 

如果不用状态机隔开的话,你这个if走完下一个clk周期又去执行else了

此帖出自FPGA/CPLD论坛
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/9 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表