2614|2

1071

帖子

7

TA的资源

纯净的硅(中级)

楼主
 

关于VHDL语法 [复制链接]

        是这样,我原来用的芯片是Spartan-3AN 系列的XC3S700AN,现在换成了Spartan6 系列的XC6SLX16。换了之后原来在
XC3S700AN的跑的好好的程序现在编译不过去了,出现了如下图所示的错误:

        acc0 和 val10 这两个变量都是std_logic_vector类型的,不同的是acc0 是32位的,而val10是16位的,所以这个错误是不是
由于我把32位的数据赋值给了一个16位的变量造成的,如果是该怎么修改呢。
此帖出自FPGA/CPLD论坛

最新回复

你这程序好高大上。std_logic_vector函数还是第一次见。 不知道哪个库,试不了。 但如果像你说的想把32位的数赋给16位的val10的话,那么你可以定义个32位的中间信号量val10_temp,赋完值后取val10_temp的低16位赋给val10即可。 signal  val10_temp  :   std_logic_vector(31 downto 0); val10_temp   详情 回复 发表于 2017-4-1 11:32
点赞 关注
 

回复
举报

664

帖子

104

TA的资源

纯净的硅(中级)

沙发
 
你这程序好高大上。std_logic_vector函数还是第一次见。
不知道哪个库,试不了。

但如果像你说的想把32位的数赋给16位的val10的话,那么你可以定义个32位的中间信号量val10_temp,赋完值后取val10_temp的低16位赋给val10即可。

signal  val10_temp  :   std_logic_vector(31 downto 0);

val10_temp <= 32位的数;
val10 <= val10_temp(15 downto 0);
此帖出自FPGA/CPLD论坛

点评

代码是上一个工程师留下来的。 std_logic_vector 不是关键词而已吗,std_logic_vector(x) 这种用法我的理解是强制转换类型(C语言的思维方式),不懂对不对。 “但如果像你说的想把32位的数赋给16位的val10的话,那  详情 回复 发表于 2017-4-5 09:59
 
 

回复

1071

帖子

7

TA的资源

纯净的硅(中级)

板凳
 
gs001588 发表于 2017-4-1 11:32
你这程序好高大上。std_logic_vector函数还是第一次见。
不知道哪个库,试不了。

但如果像你说的想把32 ...

代码是上一个工程师留下来的。
std_logic_vector  不是关键词而已吗,std_logic_vector(x) 这种用法我的理解是强制转换类型(C语言的思维方式),不懂对不对。
“但如果像你说的想把32位的数赋给16位的val10的话,那么你可以定义个32位的中间信号量val10_temp,赋完值后取val10_temp的低16位赋给val10即可。
” 我试试,不过感觉能行。
谢谢了
此帖出自FPGA/CPLD论坛
 
 
 

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

查找数据手册?

EEWorld Datasheet 技术支持

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

 
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
快速回复 返回顶部 返回列表