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

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

3天内不再提示

fireflyAIO-3399C主板TIMER介绍

firefly 来源:firefly 作者:firefly 2019-12-09 16:26 次阅读

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
收藏 人收藏

    评论

    相关推荐

    fireflyFace-RK3399主板TIMER介绍

    RK3399有12 个Timers (timer0-timer11),有12 个Secure Timers(stimer0~stimer11) 和 2 个Timers(pmutimer0
    的头像 发表于 12-04 09:08 2404次阅读
    fireflyFace-RK<b class='flag-5'>3399</b><b class='flag-5'>主板</b><b class='flag-5'>TIMER</b><b class='flag-5'>介绍</b>

    fireflyAIO-3399C主板接口介绍

     AIO-3399C 提供了丰富的接口,主要包括:电源接口, Type-C(OTG),1 x USB3.0,4 x USB2.0(接口×2,座子×2),HDMI,以太网,双LVDS屏幕接口,eDP
    的头像 发表于 12-04 10:26 2331次阅读
    <b class='flag-5'>fireflyAIO-3399C</b><b class='flag-5'>主板</b>接口<b class='flag-5'>介绍</b>

    fireflyAIO-3399C主板FAQs方案

    AIO-3399C默认出厂固件是支持LVDS+HDMI 1080P的双屏显示,HDMI分辨率最高只能到1080P。
    的头像 发表于 12-04 10:23 911次阅读
    <b class='flag-5'>fireflyAIO-3399C</b><b class='flag-5'>主板</b>FAQs方案

    fireflyAIO-3399C主板散热介绍

    散热套件 铝制散热片 产品参数 适配:AIO-3399C 尺寸:43mm (L)* 39.5mm(W)*11mm(H)
    的头像 发表于 12-09 15:56 959次阅读

    fireflyAIO-3399C主板屏幕模组介绍

    屏幕模组 7.85寸MIPI液晶屏模组 注意:默认的AIO-3399C主板不带mipi_dsi接口,如需要此功能需修改硬件。 详细请参考LCD驱动章节
    的头像 发表于 12-09 16:08 1552次阅读
    <b class='flag-5'>fireflyAIO-3399C</b><b class='flag-5'>主板</b>屏幕模组<b class='flag-5'>介绍</b>

    fireflyAIO-3399C主板UART介绍

    AIO-3399C 支持SPI桥接/扩展4个增强功能串口(UART)的功能,分别为UART1,UART2,RS232,RS485。每个UART都拥有256字节的FIFO缓冲区,用于数据接收和发送。
    的头像 发表于 12-09 16:12 1447次阅读
    <b class='flag-5'>fireflyAIO-3399C</b><b class='flag-5'>主板</b>UART<b class='flag-5'>介绍</b>

    fireflyAIO-3399C主板RTC介绍

    AIO-3399C开发板上有 一个集成于RK808上的RTC(Real Time Clock),主要功能有时钟,日历,闹钟,周期性中断,双通道32KHz时钟输出。
    的头像 发表于 12-09 16:19 1204次阅读
    <b class='flag-5'>fireflyAIO-3399C</b><b class='flag-5'>主板</b>RTC<b class='flag-5'>介绍</b>

    fireflyAIO-3399C主板PWM介绍

    AIO-3399C开发板上引出有 3 路 PWM 输出,
    的头像 发表于 12-09 16:20 1274次阅读

    fireflyAIO-3399C主板LED介绍

    LED 使用 AIO-3399C 开发板上有 2 个 LED 灯
    的头像 发表于 12-09 16:25 1598次阅读
    <b class='flag-5'>fireflyAIO-3399C</b><b class='flag-5'>主板</b>LED<b class='flag-5'>介绍</b>

    fireflyAIO-3399C主板LCD简介

    AIO-3399C开发板默认外置支持了两个LCD屏接口,一个是LVDS,一个是EDP,接口对应板子上的位置
    的头像 发表于 12-13 10:09 2821次阅读
    <b class='flag-5'>fireflyAIO-3399C</b><b class='flag-5'>主板</b>LCD简介

    fireflyAIO-3399C主板IR简介

    AIO-3399C 开发板上使用红外收发传感器 IR (耳机接口和recovery之间)实现遥控功能,在IR接口处接上红外接收器。本文主要描述在开发板上如何配置红外遥控器。
    的头像 发表于 12-13 10:12 1203次阅读
    <b class='flag-5'>fireflyAIO-3399C</b><b class='flag-5'>主板</b>IR简介

    fireflyAIO-3399C主板ADC介绍

    AIO-3399C 开发板上的 AD 接口有两种,分别为:温度传感器 (Temperature Sensor)、逐次逼近ADC (Successive Approximation Register)。
    的头像 发表于 12-13 10:14 1161次阅读

    fireflyAIO-3399C主板升级固件介绍

    本文介绍了如何将主机上的固件文件,通过Type-C数据线,烧录到开发板的闪存中。升级时,需要根据主机操作系统和固件类型来选择合适的升级方式。
    的头像 发表于 12-13 10:46 1510次阅读

    fireflyAIO-3399J主板屏幕模组介绍

    屏幕模组 7.85寸MIPI液晶屏模组 注意:默认的AIO-3399J主板不带mipi_dsi接口,如需要此功能需修改硬件。
    的头像 发表于 12-24 10:14 1370次阅读
    <b class='flag-5'>fireflyAIO-3399</b>J<b class='flag-5'>主板</b>屏幕模组<b class='flag-5'>介绍</b>

    fireflyAIO-3399J主板TIMER使用简介

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