共2条
1/1 1 跳转至页
vhdl 请教关于vhdl进程的问题
问
据资料介绍,VHDL中进程的触发是靠敏感信号表中的敏感信号的变化来实现的,进程被触发后执行一次,然后退出,直到下一个敏感信号跳变才再次执行。
但我用quartus进行仿真的时候发现,即使不是敏感信号(即未在敏感信号表中列出),只要该信号在进程中被读取,它同样也可以触发进程。例如:
process(reset)
begin
if(sgn_in='0') then
sgn_out<='1';
else
sgn_out<='0';
end if;
end process;
上面的进程中,只有一个敏感信号reset,但当我保持reset的值不变,仅将sgn_in的值由1变到0,此时输出信号sgn_out也会由0变到1,表明该进程被信号sgn_in触发执行了,而sgn_in并非敏感信号!
请问这是为什么?是不是当某信号在进程中被读取时,它就被默认为敏感信号了?
另外,我用CPLD是altera Max7000s系列的EPM7128STC100,仿真软件是quartusⅡ5.0,是不是芯片或仿真软件的问题???
答 1: 郁闷咋就没人来看呢??? 答 2: 应该是这样吧你的reset都没有用到啊。你不写sgn_in为敏感信号,但是你又在里面用了他做敏感信号,他肯定是识别它为敏感信号咯。你的运行结果是对的 答 3: 回楼上的也就是只要再进程中读取了它,就自动识别为敏感信号了?是这样吗?
但我用quartus进行仿真的时候发现,即使不是敏感信号(即未在敏感信号表中列出),只要该信号在进程中被读取,它同样也可以触发进程。例如:
process(reset)
begin
if(sgn_in='0') then
sgn_out<='1';
else
sgn_out<='0';
end if;
end process;
上面的进程中,只有一个敏感信号reset,但当我保持reset的值不变,仅将sgn_in的值由1变到0,此时输出信号sgn_out也会由0变到1,表明该进程被信号sgn_in触发执行了,而sgn_in并非敏感信号!
请问这是为什么?是不是当某信号在进程中被读取时,它就被默认为敏感信号了?
另外,我用CPLD是altera Max7000s系列的EPM7128STC100,仿真软件是quartusⅡ5.0,是不是芯片或仿真软件的问题???
答 1: 郁闷咋就没人来看呢??? 答 2: 应该是这样吧你的reset都没有用到啊。你不写sgn_in为敏感信号,但是你又在里面用了他做敏感信号,他肯定是识别它为敏感信号咯。你的运行结果是对的 答 3: 回楼上的也就是只要再进程中读取了它,就自动识别为敏感信号了?是这样吗?
共2条
1/1 1 跳转至页
回复
我要赚赏金打赏帖 |
|
|---|---|
| 【FreeRtos】FreeRtos + MPU模块的配置使用被打赏¥32元 | |
| 【分享开发笔记,赚取电动螺丝刀】墨水屏文本显示器被打赏¥25元 | |
| 【STEVAL-STWINKT1B】:结合STMcubeMX软件读取HTS221温湿度被打赏¥22元 | |
| M5PAPERESP32EINKDEVKIT评测|使用MicroPython开发M5Paper被打赏¥15元 | |
| OK1126B-S开发板下以导航按键控制云台/机械臂姿态调整被打赏¥29元 | |
| 【树莓派5】便携热成像仪被打赏¥36元 | |
| 【树莓派5】环境监测仪被打赏¥35元 | |
| OK1126B-S开发板下多时段语音提示型电子时钟被打赏¥27元 | |
| OK1126B-S开发板下函数构建及步进电机驱动控制被打赏¥25元 | |
| 【S32K3XX】LPI2C 参数配置说明被打赏¥20元 | |
我要赚赏金
