转载 VHDL编程基础-ADC接口 ADC型号是ADS7842

本文详细介绍了使用状态机实现的FPGA控制ADS7842 ADC的VHDL程序,包括时钟管理、状态机设计、数据读取与锁存等关键环节。
VHDL编程基础-ADC接口
1
刚刚写了一个FPGA控制ADC的程序,用状态机实现的。ADC型号是ADS7842。(仅供参考)

源程序如下:
LIBRARY ieee;
USE ieee.std_logic_1164.all;
------------------------------------------------------------------------------
------------------------------------------------------------------------------
ENTITY ads7842 IS
 PORT
 (
  fclk : IN  STD_LOGIC;       --?μí3ê±?ó
  din  : IN  STD_LOGIC_VECTOR(11 DOWNTO 0); --à′×?ADS7842μ?êy?Y
  enable : IN  STD_LOGIC;      --ADC?£?éê1?üD?o? ??μ???óDD§
  rst  : IN  STD_LOGIC;      --ADC?£?é?′??D?o? ??μ???óDD§
  busy : IN  STD_LOGIC;      --ADC×a???áê?D?o? é?éy??óDD§
  start : OUT STD_LOGIC;      --ADS7842 ×a???aê?D?o? ???μ??óDD§
  brd  : OUT STD_LOGIC;      --ADS7842 RDD?o? ???μ??óDD§
  bclk : OUT STD_LOGIC;      --ADS7842 1¤×÷ê±?ó
  dout : OUT STD_LOGIC_VECTOR(11 DOWNTO 0); --?£?éê?3?êy?Y
  adc_end : OUT STD_LOGIC       --×a???áê? êy?YóDD§D?o? ??μ???óDD§
 );
END ENTITY;
------------------------------------------------------------------------------
------------------------------------------------------------------------------
ARCHITECTURE behav OF ads7842 IS
 SIGNAL count: INTEGER range 0 to 19;
 SIGNAL clk : STD_LOGIC; 
 TYPE ad_status IS(st0, st1, st2, st3, st4, st5 );
 SIGNAL adc_current_state: ad_status;
 SIGNAL adc_next_state: ad_status;
 SIGNAL lock: STD_LOGIC;
 SIGNAL adc_data:STD_LOGIC_VECTOR(11 DOWNTO 0);
BEGIN
------------------------------------------------------------------------------
------------ìá1?ADS78421¤×÷ê±?ó ???μí3ê±?ó20·??μ μ?μ?2.5MHZ-------------------
------------------------------------------------------------------------------
DCLK:PROCESS( fclk )
 BEGIN
  IF ( fclk 'EVENT AND fclk = '1') THEN
   IF count = 19 THEN
    count <= 0;
    clk <= NOT clk;
   ELSE
    count <= count + 1;
           END IF;
        ELSE
   NULL;
        END IF;
 END PROCESS DCLK;
 bclk <= clk;
------------------------------------------------------------------------------
-------------------------ADS78422é?ù????×′ì??ú--------------------------------
------------------------------------------------------------------------------
 
ADC:PROCESS( adc_current_state, busy, enable )
 BEGIN
          --×′ì??ú?′??
  IF(rst = '1' ) THEN
   adc_next_state <= st0;
  ELSE
   CASE adc_current_state IS
          --A/D×a??3?ê??ˉ
   WHEN st0 =>
    start <= '1';
    brd <= '1';
    lock <= '0';
    adc_end <= '0';
    IF(enable = '1') THEN
     adc_next_state <= st1;
    ELSE
     adc_next_state <= st0;
    END IF;
   
   WHEN st1 =>     --?aê?×a??
    start <= '0';
    brd <= '1';
    lock <= '0';
    adc_end <= '0';
    adc_next_state <= st2;
    
   WHEN st2 =>     --?astartD?o??ó3ùò???ê±?ó?ü?ú
    start <= '0';
    brd <= '1';
    lock <= '0';
    adc_end <= '0';
    IF(busy = '0') THEN
     adc_next_state <= st3;
    ELSE
     adc_next_state <= st2;
    END IF;
    
   WHEN st3 =>
    start <= '1';
    brd <= '1';
    lock <= '0';
    adc_end <= '0';
    IF(busy = '1') THEN  --×a???áê?£?×a??ò???×′ì?
     adc_next_state <= st4;
    ELSE      --?′?áê?£??ò?ìD?μè′y
     adc_next_state <= st3;
    END IF;    
          
   WHEN st4 =>     --?a??ê?3?êy?Yê1?üD?o?
    start <= '1';
    brd <= '0';
    lock <= '0';
    adc_end <= '0';
    adc_next_state <= st5; 
    
   WHEN st5 =>     --?a??êy?Y??′?D?o?£??a??×a???áê?D?o?
    start <= '1';
    brd <= '0';
    lock <= '1';
    adc_end <= '1';
    adc_next_state <= st0;
 
     WHEN OTHERS => adc_next_state <= st0;
   
   END CASE;
  END IF;
 END PROCESS ADC;
------------------------------------------------------------------------------
------------------------ADS78422é?ù????×′ì??úê±Dòμ??·-------------------------
------------------------------------------------------------------------------ 
AD_STATE:PROCESS( fclk )
 BEGIN
 
  IF( fclk'event AND fclk = '1') THEN
   adc_current_state <= adc_next_state;
  END IF;
 END PROCESS AD_STATE;
------------------------------------------------------------------------------
---------------------------ADS78422é?ùêy?Y??′?--------------------------------
------------------------------------------------------------------------------ 
DATA_LOCK:PROCESS( lock )
 BEGIN
  IF lock'event AND lock = '1' THEN
   adc_data <= din;
   --lock <= '0';
   --adc_end <= '1';
  --ELSE
   --adc_end <= '0'; 
  END IF;
 END PROCESS DATA_LOCK;
  
 dout <= adc_data;
 
END behav; 

功能仿真图:


主要信号:
adc_end:转换结束,数据有效信号,高电平有效
bclk:ADC转换时钟(2.5MHZ)
brd:ADC /RD信号,读数据使能,下降沿有效
busy:ADC转换信号,可用busy上升沿锁存数据
din:接ADC数据端口
dout:用于数据输出
enable:模块使能,高电平有效
fclk:系统时钟 50MHZ
rst:模块复位信号,高电平复位
start:ADC转换开始信号,下降沿开始,接ADC的/WR脚。

转载于:https://www.cnblogs.com/FPGA_DSP/archive/2010/01/31/1660394.html

内容概要:本文系统阐述了企业新闻发稿在生成式引擎优化(GEO)时代下的全渠道策略与效果评估体系,涵盖当前企业传播面临的预算、资源、内容与效果评估四大挑战,并深入分析2025年新闻发稿行业五大趋势,包括AI驱动的智能化转型、精准化传播、首发内容价值提升、内容资产化及数据可视化。文章重点解析央媒、地方官媒、综合门户和自媒体四类媒体资源的特性、传播优势与发稿策略,提出基于内容适配性、时间节奏、话题设计的策略制定方法,并构建涵盖品牌价值、销售转化与GEO优化的多维评估框架。此外,结合“传声港”工具实操指南,提供AI智能投放、效果监测、自媒体管理与舆情应对的全流程解决方案,并针对科技、消费、B2B、区域品牌四大行业推出定制化发稿方案。; 适合人群:企业市场/公关负责人、品牌传播管理者、数字营销从业者及中小企业决策者,具备一定媒体传播经验并希望提升发稿效率与ROI的专业人士。; 使用场景及目标:①制定科学的新闻发稿策略,实现从“流量思维”向“价值思维”转型;②构建央媒定调、门户扩散、自媒体互动的立体化传播矩阵;③利用AI工具实现精准投放与GEO优化,提升品牌在AI搜索中的权威性与可见性;④通过数据驱动评估体系量化品牌影响力与销售转化效果。; 阅读建议:建议结合文中提供的实操清单、案例分析与工具指南进行系统学习,重点关注媒体适配性策略与GEO评估指标,在实际发稿中分阶段试点“AI+全渠道”组合策略,并定期复盘优化,以实现品牌传播的长期复利效应。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值