您好,欢迎来到61ic! | [登录] [注册] 忘记密码 | 设为首页 帮助
 . 网站首页 . 业界新闻 . 设计中心 . 移动技术 . TI专栏 . ADI专栏 . FPGA专栏 . 代码工厂 . 官方商城 . 
 . 活动专区 . 新品快递 . 解决方案 . 前沿科技 . TI资源 . ADI资源 . FPGA资源 . 下载中心 . 产品展示 . 
加入收藏
付款方式
联系我们
您现在的位置: 61IC电子在线 >> DSP >> Blackfin >> 正文
  BF506F中Counter和Timer协作测量脉冲的时间间隔           ★★★ 【字体:
BF506F中Counter和Timer协作测量脉冲的时间间隔
作者:skywalke…    文章来源:skywalker_leo    点击数:    更新时间:2014-7-10    
为了计算事件发生的速度和频率,很多应用希望测量两个事件之间的时间间隔。BF506F中的计数器(GP Counter)与计时器(GP Timer)模块协作可以完成这个任务。

       计数器模块会产生一个内部信号,此处简称TO,直接连接到计时器的输入(TACIx)[Counter0 TO连接到TACI0,Counter1 TO连接到TACI1]。计时器有五种工作模式:

  1. Quadrature Encoder Mode
  2. Binary Encode Mode
  3. Up/Down Counter Mode
  4. Direction Counter Mode
  5. Timed Direction Mode

        [注:详见ADSP-BF50x Blackfin Processor Hareware Reference, Chapter 13, General-Purpose Counter]

      TO信号在以上1~4模式中可以使用。为了能实现这个测量事件时间间隔的功能,相应的计时器必须设置为WDTH_CAP模式。计时器的可选捕获输入(Alternate Capture Input)由TIMER_CONFIG的TIN_SEL比特来设置。

测量连续计数器事件的时间间隔

(Capturing Time Interval Between Successive Counter Events)

[注:为了便于阅读,下文中直接称计数器为Counter,计时器为Timer]

       如果仅测量连续事件的时间间隔,相应的计时器需要设置为WDTH_CAP模式,并且PULSE_HI=1,PERIOD_CNT=1以及TIN_SEL=1。下图展示了在这个模式下Counter和Timer的操作时序。

       每当产生一个Counter事件时,TO都将产生一个脉冲。此时,Timer将“TO信号上升沿到上升沿的周期值”更新到TIMER_PERIOD寄存器。每当TO的上升沿到来的时刻,TIMER_PERIOD寄存器将被更新一次,它包含的是自前一个上升沿过后已经过去的SCLK周期数。

       顺带提一下,TIMER_WIDTH寄存器也同时被更新,但是它在这个模式下没有什么意义。如果在两个Counter事件之间,没有读CNT_COUNTER寄存器的事件发生,TIMER_WIDTH寄存器包含的是TO脉冲的宽度;如果读CNT_COUNTER寄存器的事件发生了,TIMER_WIDTH寄存器包含的是读CNT_COUNTER寄存器的时刻至下一个事件的时间。

文章录入:admin    责任编辑:admin 
  • 上一篇文章:

  • 下一篇文章: 没有了
  • 发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
    最新热点 最新推荐 相关文章
    远景蔚蓝WL-BF609开发板上运…
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)
    站长:61 湘ICP备13001086号-2