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

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

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 5994|回复: 2

[求助] vhdl中conv_unsigned函数怎么使用呢?

[复制链接]
发表于 2012-3-8 19:48:30 | 显示全部楼层 |阅读模式

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

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

x
我定义的cnt变量是unsigned,但是我想它根据n的变化自动变化长度,在复位的时候赋初始值1.怎么做呢?

library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;
use ieee.numeric_std.all;
entity seris_gen is
    generic(n : NATURAL := 3);
    port(clk  : in  std_logic;
         reset: in  std_logic;
         q    : out std_logic);
end seris_gen;
architecture behave of seris_gen is
    signal q_n  : std_logic;
    signal count: std_logic_vector(n-1 downto 0);
begin
    p0: process (clk, reset, count) is
    variable cnt : unsigned(n-1 downto 0);
    begin
if reset = '1' then
--     cnt := (others => '0');  -- or use sxt
--     cnt := "001";  -- or use sxt
--     cnt := conv_unsigned(1,n);
     cnt := conv_unsigned("001",3);
elsif rising_edge(clk) then
     cnt := cnt + 1;
    end if;
    count <= std_logic_vector(cnt);
    end process p0;
    p1: process(clk, reset, count, q_n) is
    begin
        if (reset = '1') then
            q_n <= '1';
        elsif rising_edge(clk) then
            if (count(2) and (not count(0))) = '1' then
                q_n <= '0';
     else
  q_n <= '1';
            end if;
        end if;
    end process p1;
    q <= q_n;
end behave;
发表于 2012-3-9 10:45:43 | 显示全部楼层
已改,你看看。 写VHDL,尽量不要用variable。

----------------------------------------------
library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_arith.all;
use ieee.std_logic_unsigned.all;

entity seris_gen is
    generic(n : NATURAL := 3);
    port(clk  : in  std_logic;
         reset: in  std_logic;
         q    : out std_logic);
end seris_gen;
architecture behave of seris_gen is
    signal q_n  : std_logic;
    signal count: std_logic_vector(n-1 downto 0);
begin
    p0: process (clk, reset, count) is
    begin
        if reset = '1' then
              count   <= conv_std_logic_vector(1,n);
        elsif rising_edge(clk) then
              count <= count + 1;
        end if;
    end process p0;
       
    p1: process(clk, reset) is
    begin
        if (reset = '1') then
            q_n <= '1';
        elsif rising_edge(clk) then
            if (count(2) and (not count(0))) = '1' then
                q_n <= '0';
            else
                q_n <= '1';
            end if;
        end if;
    end process p1;
       
    q <= q_n;
end behave;
 楼主| 发表于 2012-3-9 21:22:55 | 显示全部楼层
谢谢你啊,受益匪浅。我现在还弄不清几种类型该用哪一种
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

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

X

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

GMT+8, 2025-6-9 02:29 , Processed in 0.028807 second(s), 9 queries , Gzip On, MemCached On.

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