一个32位DDS的可综合代码

功能描述:
    累加器32位
    频率控制字27位,高位屏蔽,内部设置为0
    输出地址宽度11位,可带2k ROM

library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;
-------------------------------------------------------
entity DDS32 is
port(
    clock         :         in  std_logic;
    FreqCtrl    :        in    std_logic_vector(26 downto 0);
    Address        :        out    std_logic_vector(10 downto 0);
    RD            :        out std_logic
    );
end;
-------------------------------------------------------
architecture behav of DDS32 is
    signal Bdata32     : std_logic_vector(31 downto 0);
    signal ACC        : std_logic_vector(31 downto 0);
begin
-------------------------------------
    Bdata32(26 downto 0)    <=    FreqCtrl;
    Bdata32(31 downto 27)    <=    "00000";
-------------------------------------
    process(clock)
    begin
        if clock'event and clock = '1' then
            ACC <= Bdata32 + ACC;
            Address <= ACC(31 downto 21);
        end if;
    end process;
-------------------------------------
    --Read signal--High available
    RD <= not clock;
end;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值