VHDL这么写,有什么错?

[复制链接]
1791|7
 楼主| entepino 发表于 2013-3-7 21:02 | 显示全部楼层 |阅读模式
VHDL这么写,有什么错?
LED1,LED2,LED3是输出端口。
    LED1       : out  std_logic;
                                 LED2       : out  std_logic;
                                 LED3       : out  std_logic;


RecData: Process
begin  
               TagRecData(3 downto 0) <=  axi_gpio_0_GPIO_IO_O_pin(30 downto 27);
                  --the data is should be judeged suitable.
                  if(TagRecData = "0001" ) then
                      LED1 <= '0';
                           LED2 <= '1';
                                LED3 <= '1';
                  else if (TagRecData = "0010" ) then
                       LED1 <= '0';
                            LED2 <= '0';
                                 LED3 <= '1';
                  else  if (TagRecData = "0011" ) then
                       LED1 <= '1';
                            LED2 <= '0';
                                 LED3 <= '1';
                        else                   
                       null;                  
                  end if;               

                  
  end process RecData;

还没编译,保存后就出现错误,Syntax error near "process".把if部分屏蔽就好了,请问为何?


 楼主| entepino 发表于 2013-3-7 21:03 | 显示全部楼层
有错吗,怎么找不出来??
resxpl 发表于 2013-3-7 21:18 | 显示全部楼层
把这个模块完整的贴出来吧.
这段貌似没问题.
resxpl 发表于 2013-3-7 21:25 | 显示全部楼层
wozuoyue 发表于 2013-3-7 21:49 | 显示全部楼层
ELSIF是一个错误,另一个个人觉得应该是敏感信号的问题,你的PROCESS()里没有敏感信号列表,而进程里也没有WAIT语句。
1003704680 发表于 2013-3-7 22:34 | 显示全部楼层
else if   ——> eslif
jlass 发表于 2013-3-8 09:27 | 显示全部楼层
请再加上两个end if

或者如楼上般处理。
GoldSunMonkey 发表于 2013-3-8 21:21 | 显示全部楼层

else if   ——> elseif
正解
您需要登录后才可以回帖 登录 | 注册

本版积分规则

214

主题

653

帖子

2

粉丝
快速回复 在线客服 返回列表 返回顶部