这VHDL代码什么意思,求大神给予详细说明!急!!

LIBRARY IEEE;
USE IEEE.std_logic_1164.ALL;
USE IEEE.std_logic_arith.ALL;
USE IEEE.std_logic_unsigned.ALL;
ENTITY clk_div10 IS
port(clk:IN std_logic;
clk_div:OUT std_logic);
END clk_div10;
ARCHITECTURE rtl OF clk_div10 IS
SIGNAL count:std_logic_vector(2 DOWNTO 0 );
SIGNAL clk_tmp:std_logic;
BEGIN
PROCESS(clk)
BEGIN
IF ( clk'event AND clk ='1') THEN ---上升沿触发;
IF ( count ="100" )THEN ----当count记过五个时钟周期时,clk_tmp反相;
count <= (OTHERS => '0' );
clk_tmp <= NOT clk_tmp;
ELSE
count <= count +1;
END IF;
END IF;
END PROCESS;
clk_div <= clk_tmp;
END rtl;
还没打完,下面还有,

你的问题在于对EVENT属性的运用,这个属性只对PS2INTERUPTION的变化沿敏感,而且不能同时和其他并列,因为沿是一个瞬间,其他可以等效成永远,这种选择关系本身就矛盾,所以无法综合。

你可以用你当前部分的时钟缓冲两拍PS2INTERUPTION,然后用时钟沿触发动作;

FL:PROCESS(clk)
BEGIN
IF (clk'EVENT AND clk='1') THEN
    PS2INTERUPTION2<=PS2INTERUPTION;
    PS2INTERUPTION_REG<=PS2INTERUPTION2;
    if PS2INTERUPTION_REG='0' and PS2INTERUPTION2='1' then
        LITTLED<='1';
    ELSif  PS2INTERUPTION_REG='1' and PS2INTERUPTION2='0' then
       LITTLED<='0';
    END IF;
END IF;
END PROCESS;



当然,针对你这种特殊情况,你也可以直接时钟下:LITTLED <= PS2INTERUPTION2;亦可避免亚稳态;

追问

接下来还有呢 你留下邮箱 我给你发 你帮帮忙呗

温馨提示:内容为网友见解,仅供参考
第1个回答  2015-05-24
对输入的时钟进行分频吧。追问

接下来还有呢 你留下邮箱 我给你发 你帮帮忙呗

相似回答