在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 2460|回复: 0

帮忙看一下错误

[复制链接]
发表于 2007-1-11 13:59:30 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x
我是一个新手,刚编译一个乘法器程序,可总是有问题,不知怎么改,vhdl程序如下:
library IEEE;
      use IEEE.Std_logic_1164.all;
      
      ENTITY booth_multiplier IS
           GENERIC(k POSITIVE := 7);
           PORT(multiplicand, multiplier : IN BIT_VECTOR(k DOWNTO 0);
              clock : IN BIT; product : INOUT BIT_VECTOR((2*k + 1) DOWNTO 0));
      END booth_multiplier;
      
      ARCHITECTURE structural OF booth_multiplier IS
      
      SIGNAL mdreg, adderout, carries, augend, tcbuffout : BIT_VECTOR(k DOWNTO 0);
      SIGNAL mrreg : BIT_VECTOR((k + 1) DOWNTO 0);
      SIGNAL adder_ovfl : BIT;
      SIGNAL comp ,clr_mr ,load_mr ,shift_mr ,clr_md ,load_md ,clr_pp ,load_pp ,shift_pp : BIT;
      SIGNAL boostate : NATURAL RANGE 0 TO 2*(k + 1);
      
      BEGIN
      
      PROCESS
      BEGIN
              WAIT UNTIL (clock'EVENT AND clock = '1');
      
              
              IF clr_md = '1' THEN
                      mdreg <= (OTHERS => '0');
              ELSIF load_md = '1' THEN
                      mdreg <= multiplicand;
              ELSE
                      mdreg <= mdreg;
              END IF;
                     
      
              IF clr_mr = '1' THEN
                      mrreg <= (OTHERS => '0');
              ELSIF load_mr = '1' THEN
                      mrreg((k + 1) DOWNTO 1) <= multiplier;
                      mrreg(0) <= '0';
              ELSIF shift_mr = '1' THEN
                      mrreg <= mrreg SRL 1;
              ELSE
                      mrreg <= mrreg;
              END IF;
                     
              
              IF clr_pp = '1' THEN
                      product <= (OTHERS => '0');
              ELSIF load_pp = '1' THEN
                      product((2*k + 1) DOWNTO (k + 1)) <= adderout;
                      product(k DOWNTO 0) <= product(k DOWNTO 0);  
              ELSIF shift_pp = '1' THEN
                      product <= product SRA 1;
              ELSE
                      product <= product;
              END IF;
      
      END PROCESS;
      
      
      
      augend <= product((2*k+1) DOWNTO (k+1));
      addgen : FOR i IN adderout'RANGE
              GENERATE
                      lsadder : IF i = 0 GENERATE
                              adderout(i) <= tcbuffout(i) XOR augend(i) XOR comp;
                              carries(i) <= (tcbuffout(i) AND augend(i)) OR
                                            (tcbuffout(i) AND comp) OR
                                            (comp AND augend(i));
                              END GENERATE;
                      otheradder : IF i /= 0 GENERATE
                              adderout(i) <= tcbuffout(i) XOR augend(i) XOR carries(i-1);
                              carries(i) <= (tcbuffout(i) AND augend(i)) OR
                                            (tcbuffout(i) AND carries(i-1)) OR
                                            (carries(i-1) AND augend(i));
                              END GENERATE;
              END GENERATE;
            
              adder_ovfl <= carries(k-1) XOR carries(k);
      
      
      
      tcbuffout <= NOT mdreg WHEN (comp = '1') ELSE mdreg;
      
      
      
      PROCESS BEGIN  
              WAIT UNTIL (clock'EVENT AND clock = '1');
              IF boostate < 2*(k + 1) THEN boostate <= boostate + 1;
              ELSE boostate <= 0;
              END IF;
      END PROCESS;
      
      
      
      PROCESS(boostate)
      BEGIN
              
              comp <= '0';
              clr_mr <= '0';
              load_mr <= '0';
              shift_mr <= '0';
              clr_md <= '0';
              load_md <= '0';
              clr_pp <= '0';
              load_pp <= '0';
              shift_pp <= '0';
              IF boostate = 0 THEN
                      load_mr <= '1';
                      load_md <= '1';
                      clr_pp <= '1';
              ELSIF boostate MOD 2 = 0 THEN  
                      shift_mr <= '1';
                      shift_pp <= '1';
              ELSE    --boostate = 1,3,5,7......
                      IF mrreg(0) = mrreg(1) THEN
                              NULL; --refresh pp
                      ELSE
                              load_pp <= '1';         
                      END IF;
                      comp <= mrreg(1);      
              END IF;
      END PROCESS;
      
      END structural;
用max plus2编译显示错误如下:
Error:Unkown problem in e:\myproject\booth_multiplier.vhd[%SynPrep-A-UnexpectedCase,UnexpectedCase:"Unexpected value for tOpClass"in iEvalOperation at line 640 of file readexpr.c.]
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

站长推荐 上一条 /1 下一条


小黑屋| 手机版| 关于我们| 联系我们| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2025-1-12 23:16 , Processed in 0.025670 second(s), 11 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表