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

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

3天内不再提示

fireflyAIO-3399J主板TIMER使用简介

firefly 来源:firefly 作者:firefly 2019-12-24 10:25 次阅读

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

    评论

    相关推荐

    fireflyAIO-3399J主板简介

    AIO-3399J 的标准套装包含以下配件
    的头像 发表于 11-05 15:52 1236次阅读
    <b class='flag-5'>fireflyAIO-3399J</b><b class='flag-5'>主板</b><b class='flag-5'>简介</b>

    fireflyAIO-3399C主板TIMER介绍

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

    fireflyAIO-3399J主板介绍

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

    fireflyAIO-3399J主板散热套件简介

    散热套件 铝制散热片 产品参数 适配:AIO-3399J 尺寸:43mm (L)* 39.5mm(W)*11mm(H)
    的头像 发表于 12-24 10:01 1019次阅读
    <b class='flag-5'>fireflyAIO-3399J</b><b class='flag-5'>主板</b>散热套件<b class='flag-5'>简介</b>

    fireflyAIO-3399J主板红外遥控器简介

    红外遥控器 产品参数 产品:12键红外遥控器 版本:Firefly定制版 电源:两节7号电池 适配:AIO-3399J 描述:支持AIO-3399J开发板的遥控开机功能
    的头像 发表于 12-24 10:07 1299次阅读

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

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

    fireflyAIO-3399J主板UART使用介绍

    AIO-3399J 支持SPI桥接/扩展4个增强功能串口(UART)的功能,分别为UART1,UART2,RS232,RS485。
    的头像 发表于 12-24 10:18 1824次阅读
    <b class='flag-5'>fireflyAIO-3399J</b><b class='flag-5'>主板</b>UART使用介绍

    fireflyAIO-3399J主板RTC使用简介

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

    fireflyAIO-3399J主板PWM使用介绍

    AIO-3399J开发板上有 4 路 PWM 输出,分别为 PWM0 ~ PWM3,4路 PWM 分别使用在eDP背光、MIPI背光、VDDLOG供电、红外IR。 本章主要描述如何配置 PWM。
    的头像 发表于 12-24 10:37 1969次阅读

    fireflyAIO-3399J主板MIPI CSI使用简介

    AIO-3399J 开发板分别带有两个MIPI,一个DVP摄像头接口,MIPI最高支持支持4K拍照,并支持1080P 30FPS以上视频录制。
    的头像 发表于 12-24 10:22 4701次阅读
    <b class='flag-5'>fireflyAIO-3399J</b><b class='flag-5'>主板</b>MIPI CSI使用<b class='flag-5'>简介</b>

    fireflyAIO-3399J主板LED使用介绍

    AIO-3399J 开发板上有 2 个 LED 灯
    的头像 发表于 12-24 10:31 2652次阅读
    <b class='flag-5'>fireflyAIO-3399J</b><b class='flag-5'>主板</b>LED使用介绍

    fireflyAIO-3399J主板IR使用简介

    AIO-3399J 开发板上使用红外收发传感器 IR (在 mic 接口和喇叭接口之间)实现遥控功能,在IR接口处接上红外接收器。
    的头像 发表于 12-24 10:32 1807次阅读
    <b class='flag-5'>fireflyAIO-3399J</b><b class='flag-5'>主板</b>IR使用<b class='flag-5'>简介</b>

    fireflyAIO-3399J主板I2C使用介绍

    AIO-3399J 开发板上有 9 个片上 I2C 控制器,
    的头像 发表于 12-24 10:34 1579次阅读
    <b class='flag-5'>fireflyAIO-3399J</b><b class='flag-5'>主板</b>I2C使用介绍

    fireflyAIO-3399J主板ADC使用介绍

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

    fireflyAIO-3399J启动模式说明主板

    AIO-3399J 有灵活的启动方式。一般情况下,除非硬件损坏,AIO-3399J 开发板是不会变砖的。
    的头像 发表于 12-25 16:28 1172次阅读