Arm通用计时器简介

12 篇文章 3 订阅

所有使用Arm处理器的系统中都会包含一个标准化的通用定时器(Generic Timer)框架。这个通用定时器系统提供了一个系统计数器(System Counter)和一组定时器(Timer)。其结构如下图:

可以看到,系统计数器是全局唯一的,并且全局共享,对系统中的所有Arm核心进行广播。这个计数器以一个固定的频率递增(频率范围通常从1MHz到50MHz不等)。同时,这个系统计数器还是一直存在的,哪怕系统处于待机状态,所有内核都被关闭了,它仍然可以工作。计数器的宽度有56位至64位,计数到达最大值后会回滚。

每一个Arm核都配备一组专门为自己服务的定时器。定时器到期了之后会通过私有的PPI(Private Peripheral Interrupt)向通用中断控制器发中断请求。按照不同的指令集扩展,每组都有最多7个定时器,但无论如何最基本的都会提供4个,它们分别是:

  • EL1 physical timer:给操作系统用的物理定时器;
  • EL1 virtual timer:给操作系统用的虚拟定时器;
  • Non-secure EL2 physical timer:给虚拟机的宿主系统用的定时器;
  • EL3 physical timer:给运行于EL3内的固件程序使用的定时器。

对于系统计数器来说,可以通过读取控制寄存器CNTPCT_EL0来获得当前的系统计数值(无论处于哪个异常级别),也就是通过以下汇编指令:

MRS Xn, CNTPCT_EL0

这条指令是可以乱序执行的,使用的时候要适当保护。确切的说,这是读取物理计数器的值,系统中其实还存在一个虚拟计数器的值,这个虚拟计数器主要也是给虚拟机的宿主系统用的。虚拟计数器的值和物理计数器的值有如下对应关系:

虚拟计数器 = 物理计数器 - 偏移

这个偏移的值是通过控制寄存器CNTVOFF_EL2设置的,看名字就知道只能在EL2或EL3层才有权限设置和访问,如果不设置的话,默认值是0,也就是虚拟计数器和物理计数器的值一致。如果想得到虚拟计数器的值,可以通过读取CNTVCT_EL0控制寄存器来获得。

系统计数器的频率主要通过控制寄存器CNTFRQ_EL0来控制。频率是可以随意设定的,但只能在EL3下设置,也就是说在系统固件程序里。在其它的异常级别里(EL2到EL0)都不能设置,但是可以通过读取这个CNTFRQ_EL0寄存器来获得在固件中设置好的频率。

对于Arm定时器来说,总体有两种工作方式:

  1. 到一个绝对时间之后就触发;
  2. 从现在开始再过一定时间间隔之后触发。

Arm定时器通过两类寄存器来实现以上两种工作方式。一类叫做比较寄存器(CVAL),还有一类叫做定时寄存器(TVAL)。

比较寄存器有64位,如果设置了之后,当系统计数器达到或超过了这个值之后(CVAL<系统计数器),就会触发定时器中断。通过这种方式来实现第一类定时任务,。

定时寄存器有32位,如果设置了之后,会将比较寄存器设置成当前系统计数器加上设置的定时寄存器的值(CVAL=系统计数器+TVAL),后面就一样了,当系统计数器达到或超过了这个值后,就会触发定时中断。通过这种方式来实现第二种定时任务。

可以看出来,无论那种类型的定时器都是单次出发的(One Shot),如果想要周期触发,必须在中断处理程序中重新设置。这也刚好满足Linux系统中对于高精度定时器的要求。

除了设置定时条件的寄存器,其实每组定时器都还有一个控制寄存器(CTL),其只有最低三位有意义,其它的60位全是保留的,设置成0:

最低三位分别是:

  • ENABLE:是否打开定时器,使其工作;
  • IMASK:中断掩码,如果设置成1,则即使定时器是工作的,仍然不会发出中断;
  • ISTATUS:如果定时器打开的话,且满足了触发条件,则将这一位设置成1。

所以很简单,如果想让定时器按照要求发出中断的话,必须将Enable位设置成1,且IMASK位必须设置成0。

定时中断满足触发条件后,其并不会自己消失。如果在中断处理程序中不做处理的话,那同一个触发条件会不停的触发中断。

前面说到了,每个Arm核都有4个私有定时器,每个定时器都有一个比较寄存器、一个定时寄存器、一个控制寄存器,所以一共应该有12个寄存器可以操作,将它们的命名总结如下:

定时器类型比较寄存器名定时寄存器名控制寄存器名访问异常级别
EL1 physical timerCNTP_CVAL_EL0CNTP_TVAL_EL0CNTP_CTL_EL0EL0和EL1
EL1 virtual timerCNTV_CVAL_EL0CNTV_TVAL_EL0CNTV_CTL_EL0EL0和EL1
Non-secure EL2 physical timerCNTHP_CVAL_EL2CNTHP_TVAL_EL2CNTHP_CTL_EL2NS.EL2
EL3 physical timerCNTPS_CVAL_EL1CNTPS_TVAL_EL1CNTPS_CTL_EL1EL3和S.EL1

 

  • 14
    点赞
  • 45
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: STM32F103C8T6是一款高性能、低功耗的单片机,它具备丰富的外设,包括多个计时器。下面我将介绍一下STM32F103C8T6的计时器功能及使用方法。 STM32F103C8T6内部集成了高级定时器(TIM1和TIM8)、波形生成器(TIM2、TIM3、TIM4、TIM5和TIM9)、通用定时器(TIM6和TIM7)以及基本定时器(TIM15和TIM16)。这些定时器可以用于测量时间间隔、产生PWM信号、定时中断等应用。 在使用STM32F103C8T6的计时器之前,首先需要对其进行初始化配置。一般情况下,需要设置计数模式、时钟分频因子、自动重装载值、预分频系数等参数。 配置完成后,可以通过编程方式启动计时器的运行。根据具体的应用需求,可以选择定时中断模式或PWM模式。在定时中断模式下,可以设置定时器的周期,并在每个周期结束时产生一个中断。此时,可以根据需要处理中断事件,比如更新数码管显示、控制外设等。在PWM模式下,可以通过调整计时器的占空比和频率,产生具有一定占空比和频率的PWM信号,用于控制马达、灯光等。 在使用计时器过程中,我们还可以通过读取计数器的当前值来实现时间测量或精确的计时功能。此外,STM32F103C8T6还提供了方便的计时器输入捕获和输出比较功能,通过这些功能可以更灵活地应对各种应用需求。 总而言之,STM32F103C8T6的计时器功能非常强大,可以广泛应用于各种定时、计时和PWM控制场景。通过合理的配置和编程,可以实现精确、稳定的计时功能,并且充分发挥单片机的高性能和低功耗特点。 ### 回答2: STM32F103C8T6是一款基于ARM Cortex-M3内核的32位微控制器,具有多个计时器功能。以下是关于STM32F103C8T6计时器的一些基本知识: 首先,STM32F103C8T6微控制器具有三个基本定时器(TIM2、TIM3和TIM4)和一个高级定时器(TIM1)。这些定时器可用于生成定时中断、PWM波形输出以及其他计时测量和控制功能。 基本定时器具有简化的功能和配置选项,适用于较简单的应用。高级定时器则具有更多功能和灵活性,适用于更复杂的应用。 每个定时器都由一个16位或32位的计数器和多个输入捕获通道和输出比较通道组成。计数器用于计算时间,而输入捕获通道用于捕获外部事件(例如脉冲信号)的时间戳。输出比较通道可以用于产生PWM波形或产生定时中断。 编程上,可以使用STM32CubeMX或STM32CubeIDE等开发工具来配置和初始化定时器。通过设置寄存器的值,可以选择计时器的模式、时钟源、预分频器、自动重载值等参数。还可以配置输入捕获和输出比较通道的工作模式和触发条件。 定时器中断是使用定时器的主要功能之一。可以通过配置定时器的预分频和自动重载值来实现所需的中断频率。当计数器达到自动重载值时,将触发中断,可以在中断服务程序中执行所需的操作。 除了定时器功能外,STM32F103C8T6还可以通过其他外设(如GPIO、UART、SPI等)与外部设备进行通信和控制。这使得它成为许多嵌入式应用的理想选择。 总而言之,STM32F103C8T6计时器具有多种功能和灵活性,适用于各种计时和控制应用。合理的配置和编程可以实现所需的定时和测量要求。 ### 回答3: STM32F103C8T6是一款基于ARM Cortex-M3内核的高性能微控制器。它内置了多个计时器,用于实现各种定时和计数功能。 STM32F103C8T6的计时器包括基本定时器(TIM2和TIM3),通用定时器(TIM1、TIM4、TIM5、TIM8),高级定时器(TIM1和TIM8)和看门狗定时器(IWDG和WWDG)。 基本定时器是一个用于生成周期性中断的简单计数器。它具有16位计数器和一个自动重载寄存器,可以设置计数器的时钟源和分频系数,实现不同的定时功能。 通用定时器是一个功能强大的定时器/计数器,可以用于多种应用,如PWM输出、脉宽测量、输入捕获等。它具有16位或32位计数器、自动重载寄存器、输入捕获寄存器和输出比较寄存器等功能。 高级定时器是通用定时器的扩展,具有更复杂的功能,如高级PWM输出、编码器接口、递减计数等。它具有16位或32位计数器和更多的输入捕获和输出比较通道。 看门狗定时器是为了防止系统在异常情况下出现死锁而设计的。IWDG用于软件监视,WWDG用于硬件监视。它们可以设置超时时间,如果系统在超时时间内没有喂狗,将会触发复位操作。 在编程上,我们可以使用STM32CubeMX工具和STM32Cube HAL库来配置和操作这些计时器。通过设置寄存器的值和中断处理函数,我们可以实现精准的定时和计数功能,满足各种应用需求。 总之,STM32F103C8T6的计时器具有丰富的功能和灵活的配置选项,可以广泛应用于各种领域,如工业自动化、通信设备、家用电器等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值