OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4159|回复: 7

[XILINX] 用于综合,verilog数组表示及初始化?

[复制链接]

1

主题

7

帖子

0

精华

初级会员

Rank: 2

积分
73
金钱
73
注册时间
2018-4-10
在线时间
20 小时
发表于 2021-11-15 16:09:35 | 显示全部楼层 |阅读模式
1金钱
    如题,其实是想串口输出不同的32位数,每1s切换一次;比方说第一秒发送16'h12345678,接下来16'h11223344、16'h55443322等等(并不规律但是要发送的数是已知的)。
    想过用二维数组的方式实现,但是不知道怎么定义及附初值,望指教。


最佳答案

查看完整内容[请看2#楼]

定义一个二维数组(你这个一维数组也行),然后用计数器轮询的方式给每个元素进行赋值(切记不可以对数组整体一下子赋值要一个一个元素赋值),之后你在每隔一秒从这个数组中取一个元素出来通过串口发送出去就好了。如果你要发送的数据是已知并且数量也不是特别多的情况可以参考正点原子字符图片显示实验,将所有的数据列成一个大的数据阵列去调用。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

0

主题

7

帖子

0

精华

新手上路

积分
22
金钱
22
注册时间
2020-7-7
在线时间
2 小时
发表于 2021-11-15 16:09:36 | 显示全部楼层
定义一个二维数组(你这个一维数组也行),然后用计数器轮询的方式给每个元素进行赋值(切记不可以对数组整体一下子赋值要一个一个元素赋值),之后你在每隔一秒从这个数组中取一个元素出来通过串口发送出去就好了。如果你要发送的数据是已知并且数量也不是特别多的情况可以参考正点原子字符图片显示实验,将所有的数据列成一个大的数据阵列去调用。
回复

使用道具 举报

1

主题

7

帖子

0

精华

初级会员

Rank: 2

积分
73
金钱
73
注册时间
2018-4-10
在线时间
20 小时
 楼主| 发表于 2021-11-15 16:12:07 | 显示全部楼层
各位有合适新手学习verilog的书籍还请推荐,不胜感激。
回复

使用道具 举报

2

主题

136

帖子

0

精华

高级会员

Rank: 4

积分
661
金钱
661
注册时间
2020-4-21
在线时间
85 小时
发表于 2021-11-17 09:24:19 | 显示全部楼层
可以做一个累计1s的计数器,当记到1s时,计数器加1,然后用case语句根据计数器的值对32位数进行赋值
回复

使用道具 举报

1

主题

7

帖子

0

精华

初级会员

Rank: 2

积分
73
金钱
73
注册时间
2018-4-10
在线时间
20 小时
 楼主| 发表于 2021-11-17 09:34:25 | 显示全部楼层
932904676xy 发表于 2021-11-17 09:24
可以做一个累计1s的计数器,当记到1s时,计数器加1,然后用case语句根据计数器的值对32位数进行赋值

...,不是我想要的实现方式,假如有1200个不同数,case1200次?
回复

使用道具 举报

0

主题

1

帖子

0

精华

新手上路

积分
31
金钱
31
注册时间
2018-10-18
在线时间
7 小时
发表于 2021-11-19 17:03:53 | 显示全部楼层
vivado貌似$readmemh可以综合
比如 :
reg [15:0] mem [127:0];
initial $readmemh("mem_128.hex", mem );
试试?
回复

使用道具 举报

1

主题

7

帖子

0

精华

初级会员

Rank: 2

积分
73
金钱
73
注册时间
2018-4-10
在线时间
20 小时
 楼主| 发表于 2021-11-20 21:39:27 | 显示全部楼层
xz12345 发表于 2021-11-17 09:32
定义一个二维数组(你这个一维数组也行),然后用计数器轮询的方式给每个元素进行赋值(切记不可以对数组整 ...

多谢,知道这个意思了。
回复

使用道具 举报

1

主题

7

帖子

0

精华

初级会员

Rank: 2

积分
73
金钱
73
注册时间
2018-4-10
在线时间
20 小时
 楼主| 发表于 2021-11-20 21:40:25 | 显示全部楼层
zhangyp 发表于 2021-11-19 17:03
vivado貌似$readmemh可以综合
比如 :
reg [15:0] mem [127:0];

试过了,不行,不可综合吧,说是只能放在仿真里。我用的是2018.3
回复

使用道具 举报

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

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-11-23 18:57

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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