OpenEdv-开源电子网

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

[ALTERA] 怎样让顶层模块调用子模块里面的数据

[复制链接]

52

主题

147

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
316
金钱
316
注册时间
2019-4-1
在线时间
118 小时
发表于 2019-10-19 17:01:42 | 显示全部楼层 |阅读模式
5金钱
在子模块ADC中,dataram是定义的一个16位的内存区间,长度1024,用于保存采样到的数据。相关代码如下:
  1. module ADC(sys_clk,sys_rst_n,Addr,dataram);
  2. input        sys_clk;                        //系统时钟
  3. input        sys_rst_n                        //系统复位,低电平有效
  4. input        reg [31:0]        Addr;                //系统总线地址
  5. output        reg [15:0]  dataram[1023:0];        //采样数据存储区

  6. always @(posedge sys_clk or negedge sys_rst_n) begin
  7.          if (sys_rst_n)
  8.                 。。。。。。                        //采样过程
  9.                 dataram[channal]=dataread;                //采样数据存入对应的内存位置
  10. 。。。。。
复制代码
在上一层模块中调用了子模块ADC,希望获得dataram中的那些数据。子模块中应该怎样定义dataram,才能输出数据给顶层模块呢?望指教,谢谢!


正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

9

主题

202

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
839
金钱
839
注册时间
2018-7-29
在线时间
128 小时
发表于 2019-10-20 11:59:07 | 显示全部楼层
你这个dataram的方法是定义了一个数组,你在上一层模块中准备怎么处理这个数组中的数据呢?
回复

使用道具 举报

52

主题

147

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
316
金钱
316
注册时间
2019-4-1
在线时间
118 小时
 楼主| 发表于 2019-10-20 15:12:33 | 显示全部楼层
SunML 发表于 2019-10-20 11:59
你这个dataram的方法是定义了一个数组,你在上一层模块中准备怎么处理这个数组中的数据呢?

在上层模块需要把这个数组发到16位并行总线上。
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2024-10-3 07:20

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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