打印

请教VHDL高手,一个另我很头疼的问题

[复制链接]
8932|1
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
skyfcz|  楼主 | 2008-9-8 17:07 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

LIBRARY IEEE;
USE IEEE.STD_LOGIC_1164.ALL;

ENTITY encoder8_3_B IS
    PORT(
         COIN:IN STD_LOGIC_VECTOR(7 DOWNTO 0);
         SI_5:IN STD_LOGIC;
         EN,RESET:IN STD_LOGIC;
         COIN_CODE:OUT STD_LOGIC_VECTOR(3 DOWNTO 0));
END encoder8_3_B;
ARCHITECTURE behavior OF encoder8_3_B IS
    SIGNAL ADDER:INTEGER RANGE 0 TO 1;
BEGIN
    PROCESS(EN,RESET,COIN,SI_5)
    BEGIN
    IF EN='1' THEN 
 

        IF RESET='1' THEN COIN_CODE<=X"0";ADDER<=0;
        ELSIF RISING_EDGE(SI_5) THEN ADDER<=ADDER+1;
 

        IF(ADDER=0 AND SI_5='1') THEN COIN_CODE<=X"1";
        END IF;
        ELSE
        CASE COIN IS
        WHEN X"01"=> NULL;
        WHEN X"02"=> COIN_CODE<=X"1";
        WHEN X"04"=> COIN_CODE<=X"1";
        WHEN X"08"=> COIN_CODE<=X"2";
        WHEN X"10"=> COIN_CODE<=X"5";
             WHEN X"20"=> COIN_CODE<=X"A";
        WHEN OTHERS=> COIN_CODE<=X"0";
        END CASE;
        END IF;
        ELSE COIN_CODE<=X"0";ADDER<=0;
        END IF;
    END PROCESS;
END behavior;

出错信息:
Error (10818): Can't infer register for "COIN_CODE[0]" at encoder8_3_B.vhd(17) because it does not hold its value outside the clock edge
Error (10818): Can't infer register for "COIN_CODE[1]" at encoder8_3_B.vhd(17) because it does not hold its value outside the clock edge
Error (10818): Can't infer register for "COIN_CODE[2]" at encoder8_3_B.vhd(17) because it does not hold its value outside the clock edge
Error (10818): Can't infer register for "COIN_CODE[3]" at encoder8_3_B.vhd(17) because it does not hold its value outside the clock edge
Error (10822): HDL error at encoder8_3_B.vhd(18): couldn't implement registers for assignments on this clock edge
Error: Can't elaborate top-level user hierarchy
Error: Quartus II Analysis & Synthesis was unsuccessful. 6 errors, 0 warnings
    Info: Allocated 152 megabytes of memory during processing
    Error: Processing ended: Mon Sep 08 16:56:26 2008
    Error: Elapsed time: 00:00:03
Error: Quartus II Full Compilation was unsuccessful. 6 errors, 0 warnings
 
中间空出的两行为显示出错的地方,请高手赐教啊!

相关帖子

沙发
yuxyoo| | 2008-9-9 17:01 | 只看该作者

楼上真是高手哦

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

3

主题

2

帖子

0

粉丝