原创 VHDL周学习总结(四)---DAC0832控制

2010-3-27 22:47 4308 7 10 分类: FPGA/CPLD

       弄过了ADC0809当然要弄一下DAC0832了,嘻嘻,这个芯片俺印象很深,当年俺参加学习的电子大赛培训时就是用它做的一个函数发生器,呵呵,当时功能比较简单,今天俺用FPGA来控制它,嘻嘻……


        --------------------------------------------------------------------------------------------
--                         每天进步一点点,开心一大点^_^
--函数名称:DAC0832.VHD
--函数功能:用FPGA实现对DAC的简单控制,产生频率为762.9Hz的锯齿波。
--作       者:萤火虫II号
--创建日期:2010.03.24
--------------------------------------------------------------------------------------------
library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_arith.all;
use ieee.std_logic_unsigned.all;


entity DAC0832 is
 port (clk: in std_logic;  --系统时钟,这里说一下std_logic和BIT数据类型的曲别
                                  --std_logic定义为:type std_logic is ('u','x','0','1','z','w','l','h','-');
                                  --bit的定义为:type bit is ('0','1');
    rst: in std_logic;  --复位信号
    ile: out std_logic; --数据锁存允许
    cont: out std_logic; --控制信号(WR1,WR2,CS,Xfer)
    data_out: out std_logic_vector(7 downto 0)  --波形数据输出
       );
end DAC0832;


architecture behav of DAC0832 is
 
signal q: integer range 0 to 63;          --计数值
signal data: std_logic_vector(7 downto 0); --波形数据


begin
 process(clk)
 begin
  if rst='1' then q<=0;        --高电平复位,计数值清零
  elsif clk'event and clk='1' then
   if q="63" then q<=0;      --这句是产生64分频,原理很简单,只有时钟振荡64次data才变一次
    if data="11111111" then data<="00000000";  --产生锯齿波形
    else data<=data+1;
    end if;
   else q<=q+1;
   end if;
  end if;
 end process;
 ile<='1';cont<='0';data_out<=data;     --ile锁存、cont赋值;波形数据输出;
end behav;


 


     写代码时发与自己对std_logic定义  --bit的定义为不是太了解,又临时翻了一下课本,呵呵,现在终于记住了……


哦,把俺查的DAC0832的资料也弄上来:


    还是那句口号:


    每天进步一点点,开心多一点^_^

PARTNER CONTENT

文章评论3条评论)

登录后参与讨论

xucun915_925777961 2012-12-12 11:32

这是LZ上学时,初学VHDL时所做的实验,当时有好多东西都 不会,这里只是当时的学习日志,如果不当,请见谅!

用户377235 2012-11-30 23:51

为什么不用状态机写呢?

用户850068 2010-4-5 19:25

lz,我也在学VHDL,是初学,以后向你多多请教啊
相关推荐阅读
xucun915_925777961 2013-04-28 11:31
毕业后的五年拉开大家差距的原因在哪里?【转】
  有人工作,有人继续上学,大家千万不要错过这篇文章,能看到这篇文章也是一种幸运,真的受益匪浅,对我有很大启迪,这篇文章将会改变我的一生,真的太好了,希望与有缘人分享,也希望对有缘人有所帮助!...
xucun915_925777961 2013-03-31 20:28
职场大牛精彩总结:职场上,如何做人做事做管理【转】(文/张子阳)
      大道至简,越是根源和基本的问题,道理实际上越简单。关于如何做人、做事、做管理的书很多,我看得不多,但是我觉得这些书更多是侧重技术和实现细节上的,而很少从人的思想和观念去讲。实际...
xucun915_925777961 2013-03-28 14:03
介绍几种优秀的UML工具
统一建模语言(UML是 Unified Modeling Language的缩写)是用来对软件密集系统进行可视化建模的一种语言。UML为面向对象开发系统的产品进行说明、可视化、和编制文档的一种标准语言...
xucun915_925777961 2013-03-27 18:05
IAR EW FOR 8051 修改工程名称的方法
        近段时间一直在搞蓝牙4.0的开发任务,所以用到了IAR编译器,话说IAR编译器用途蛮广,可以编译MSP430,ARM,还有TI的51核芯片,当然,这要不同的版本,我现在用的是for...
xucun915_925777961 2013-03-26 16:40
Cortex-M3学习日志(八)-- TFT实验Part(a)
    自己用的LPC1768的开板带有一块2.4寸的TFT彩色液晶屏,虽然自己工作中还用不过显示屏,但是晚上闲着也是闲着,于是继续玩咱的LPC1768吧。 我的开发板上的液晶屏的用的是SPI接口,当...
xucun915_925777961 2013-03-25 20:48
说说那几款查看源代码的工具
说说那几款查看代码的工具 今天给大家介绍几款单片机工程师所喜欢的几款查看源代码的工具,这几款工具在懒猫的日常工作中可是帮了不少忙。 一、 Source Insight     Source Insig...
EE直播间
更多
我要评论
3
7
关闭 站长推荐上一条 /3 下一条