加入收藏 设为首页 帮助中心
 
论坛首页
用户登录 | 用户注册 | 最新悬赏 | 最新贴子 | 会员中心 | 贴子搜索 | 网站地图 | 帮助中心 | 联系我们
站内搜索:
现在位置 > 维库电子开发网论坛 > EDA > VHDL自定义type的问题
帖子主题: VHDL自定义type的问题
你还没有登录,无法发表回复,请首先 登录.. [注 册]
积分:1428 mdian
发表于:2008-5-10 9:02:00 楼主
级别:二钻
积分:1428分
注册:2007年11月15日
在库文件中定义了一个类型reg_index_t:
    type reg_index_t is range 0 to 31; 然后在同一个库中定义了几个procedure,有的procedure定义了reg_index_t类型的信号,比如:

procedure instr_decode (
    signal instr : in std_logic_vector( 0 to 31 );
    signal op : out std_logic_vector( 0 to 3 );
    signal ra : out reg_index_t;
    signal rb : out reg_index_t );

用modelsim编译这个库文件的时候出现无数个错误,都和这个reg_index_t有关。一种错误是:
# ** Error: E:/Design/Courses/ESE545/Src/mylib/mylib.vhd(247): Cannot resolve slice name as type work.mypack.reg_index_t.

还有一种:
# ** Error: E:/Design/Courses/ESE545/Src/mylib/mylib.vhd(283): Aggregate expression cannot be scalar type work.mypack.reg_index_t.

对应的都是对这个类型的signal赋值语句:

L247: ra <= instr(20 to 24);
L283: ra <= ( others => '0' );

看不出这个类型的定义有什么问题,哪位达人指点一下吧。谢谢。
 
积分:1538 mengmeng
发表于:2008-5-10 9:03:00 1 楼
级别:二钻
积分:1538分
注册:2007年11月15日
类型不匹配?。。。  
积分:420 jephen
发表于:2008-6-7 18:53:00 2 楼
级别:四星
版主
积分:420分
注册:2008年05月27日

很明显单个输出不能表示成整数的啊。

为什么不用向量组呢?

 
积分:420 jephen
发表于:2008-6-14 17:26:00 3 楼
级别:四星
版主
积分:420分
注册:2008年05月27日

输出端口要使用STD_LOGIC类型的数据。

不知道楼主问题解决没有啊?

 
快速回复:
用户名: 密码:  验证码,看不清楚?请点击刷新验证码 注册新帐号?
上传图片格式(jpg/gif/png)和文件格式(rar/pdf)
 
 
网站简介s广告服务网站地图帮助信息联系方式问题报告
Copyright 2007 - 2008 bbs.weeqoo.com
Powered By weeqoo Version 8.0.0XML