0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

Firefly关于TIMER 使用简介

firefly 来源:firefly 作者:firefly 2019-11-20 11:17 次阅读
TIMER 使用

RK3399有12 个Timers (timer0-timer11),有12 个Secure Timers(stimer0~stimer11) 和 2 个Timers(pmutimer0~pmutimer1), 我们主要用到的是Timers(timer0-timer11)时钟频率为24MHZ ,工作模式有 free-running 和 user-defined count 模式

框架图

工作模式

user-defined count:Timer 先载入初始值到 TIMERn_LOAD_COUNT3 和 TIMER_LOADn_COUNT2寄存器, 当时间累加的值在寄存器TIMERn_LOAD_COUNT1和TIMERn_LOAD_COUNT0时,将不会自动载入到计数寄存器。 用户需要重新关闭计数器和然后重新设置计数器相关才能继续工作。

free-running:Timer先载入初始值到TIMER_LOAD_COUNT3 和 TIMER_LOAD_COUNT2寄存器, 当时间累加的值在寄存器TIMERn_LOAD_COUNT1和TIMERn_LOAD_COUNT0时,Timer将一直自动加载计数寄存器。

软件配置

1.在 dts 文件中定义 Timer 的相关配置 kernel/arch/arm64/boot/dts/rockchip/rk3399.dtsi

rktimer: rktimer@ff850000 { compatible = "rockchip,rk3399-timer"; reg = <0x0 0xff850000 0x0 0x1000>; interrupts = <GIC_SPI 81 IRQ_TYPE_LEVEL_HIGH 0>; clocks = <&cru PCLK_TIMER0>, <&cru SCLK_TIMER00>; clock-names = "pclk", "timer"; };

其中定义的Timer0 的寄存器和中断号和时钟等

其他Timer 对应的中断号可看如下图片

2.对应的驱动文件Kernel/drivers/clocksource/rockchip_timer.c

对应寄存器和使用

1.寄存器如下图片

2.使用方式 查看对应寄存器

root@rk3399_firefly_box:/ # io -4 0xff85001c //查看当前控制寄存器的状态 ff85001c: 00000007 root@rk3399_firefly_box:/ # io -4 0xff850000 //查看寄存器时时的值 ff850000: 0001639f

控制对应寄存器

root@rk3399_firefly_box:/ # io -4 -w 0xff85001c 0x06 //关闭时间计数功能

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 嵌入式主板
    +关注

    关注

    7

    文章

    6064

    浏览量

    34614
  • Firefly
    +关注

    关注

    2

    文章

    534

    浏览量

    6757
收藏 人收藏

    评论

    相关推荐

    NanoSync Timer 介绍

    Timer
    橙群微电子
    发布于 :2023年11月02日 10:07:13

    STM32的Timer简介

    1.STM32的Timer简介STM32中一共有11个定时器,其中2个高级控制定时器,4个普通定时器和2个基本定时器,以及2个看门狗定时器和1个系统嘀嗒定时器。其中系统嘀嗒定时器是前文中所描述
    发表于 08-18 06:14

    firefly多窗口显示简介

    Firefly-RK3288平台拥有强大的多线程运算和图像处理能力,基于Firefly-RK3288可以实现多窗口显示的功能,用户可以在Android系统下同时运行不同的应用,也可以对当前多个窗口进行打开、关闭、放大、缩小、最大化、最小化等操作。
    的头像 发表于 11-01 15:13 1294次阅读
    <b class='flag-5'>firefly</b>多窗口显示<b class='flag-5'>简介</b>

    firefly双屏互动简介

    基于Firefly-RK3288高性能开源平台,可以做双屏互动功能,Firefly-RK3288同时接MIPI
    的头像 发表于 11-01 15:31 1293次阅读
    <b class='flag-5'>firefly</b>双屏互动<b class='flag-5'>简介</b>

    Firefly-RK3399--FAQs简介

    Firefly-RK3399 的 HDMI 能自动识别显示的分辨率。
    的头像 发表于 11-19 15:27 2736次阅读
    <b class='flag-5'>Firefly</b>-RK3399--FAQs<b class='flag-5'>简介</b>

    Firefly关于的屏幕模组简介

    Firefly
    的头像 发表于 11-20 10:47 1253次阅读
    <b class='flag-5'>Firefly</b><b class='flag-5'>关于</b>的屏幕模组<b class='flag-5'>简介</b>

    Firefly关于UART接口使用介绍

    Firefly-RK3399 支持五路UART:UART0, UART1, UART2, UART3, UART4,都拥有两个64字节的FIFO缓冲区,用于数据接收和发送。
    的头像 发表于 11-20 11:01 2534次阅读
    <b class='flag-5'>Firefly</b><b class='flag-5'>关于</b>UART接口使用介绍

    Firefly关于-RTC 使用简介

    Firefly-RK3399 开发板上有 一个集成于RK808上的RTC(Real Time Clock),主要功能有时钟,日历,闹钟,周期性中断,双通道32KHz时钟输出。
    的头像 发表于 11-20 11:14 2160次阅读
    <b class='flag-5'>Firefly</b><b class='flag-5'>关于</b>-RTC 使用<b class='flag-5'>简介</b>

    Firefly关于SPI简介

    SPI是一种高速的,全双工,同步串行通信接口,用于连接微控制器、传感器、存储设备等。 Firefly-RK3399 开发板提供了 SPI1 (单片选)接口,
    的头像 发表于 11-20 11:21 1408次阅读
    <b class='flag-5'>Firefly</b><b class='flag-5'>关于</b>SPI<b class='flag-5'>简介</b>

    Firefly关于RK3288电源适配器简介

    firefly电源适配器 5V-3A电源适配器
    的头像 发表于 11-25 10:01 2165次阅读
    <b class='flag-5'>Firefly</b><b class='flag-5'>关于</b>RK3288电源适配器<b class='flag-5'>简介</b>

    Firefly-RK3128主板ADC简介

    Firefly-RK3128 开发板有一个 3 通道(0/1/2)、10 比特精度的 SAR ADC (Successive Approximation Register,逐次逼近寄存器),
    的头像 发表于 11-28 17:17 3103次阅读
    <b class='flag-5'>Firefly</b>-RK3128主板ADC<b class='flag-5'>简介</b>

    Firefly-RK3128主板启动模式简介

    Firefly-RK3128 有灵活的启动方式。
    的头像 发表于 11-29 09:27 4638次阅读

    Firefly-PX3-SE--WIFI模块及以太网简介

    关于Firefly-PX3-SE网络的使用,目前在设置app里面只能使用WiFi以及WIFI热点功能,以太网功能暂时还没添加。
    的头像 发表于 12-02 16:56 1225次阅读

    fireflyAIO-3399J主板TIMER使用简介

    RK3399有12 个Timers (timer0-timer11),有12 个Secure Timers(stimer0~stimer11) 和 2 个Timers(pmutimer0
    的头像 发表于 12-24 10:25 1168次阅读
    fireflyAIO-3399J主板<b class='flag-5'>TIMER</b>使用<b class='flag-5'>简介</b>

    EV_HC32F460_Timer之正交编码器调试

    5.EV_HC32F460_Timer之正交编码器调试简介TimerHC32F460 中与 PWM 相关的外设有– 3 个多功能 16bit PWM TimerTimer6)– 3
    发表于 11-24 12:21 15次下载
    EV_HC32F460_<b class='flag-5'>Timer</b>之正交编码器调试