TI RM57 如何配置RTI作为定时器使用

news2024/11/16 18:02:45

引言

最近公司要对新项目的算法进行评估,这就需要拿到RM57浮点运算能力数据,测量运算速度就要用到高精度定时器,通过查看芯片手册发现RTI可以满足这个需求,本文对RTI的配置和使用做一个详细的记录,方便以后翻看。

uint64_t evalF32Perf(){
    stopHRTimer();/*停止计时器*/
    clearHRTimer();/*清除计时器计数*/
    startHRTimer();/*开启定时器*/
    .....计算10万次浮点运算
    stopHRTimer();/*停止计时器*/
    return getHRTimeStamp();/*返回计时器计数结果*/
}

目录

引言

使用RTI定时器

理解RTI的时钟树


使用RTI定时器

主要控制寄存器有RTIGCTRL(0xFFFFFC00)RTI控制寄存器

RTIINTFLAG(0xFFFFFC88)RTI中断状态寄存器

中断控制寄存器RTISETINTENA(0xFFFFFC80)和RTICLEARENA(0xFFFFFC80)

 

//RTI1相关寄存器定义
#define portRTI_GCTRL_REG  		( * ( ( volatile uint32_t * ) 0xFFFFFC00 ) )
#define portRTI_CNT0_FRC1_REG  	( * ( ( volatile uint32_t * ) 0xFFFFFC30 ) )
#define portRTI_CNT0_UC1_REG  	( * ( ( volatile uint32_t * ) 0xFFFFFC34 ) )
#define portRTI_CNT0_CPUC1_REG  ( * ( ( volatile uint32_t * ) 0xFFFFFC38 ) )
#define portRTI_SETINTENA_REG  	( * ( ( volatile uint32_t * ) 0xFFFFFC80 ) )
#define portRTI_CLEARINTENA_REG ( * ( ( volatile uint32_t * ) 0xFFFFFC84 ) )
#define portRTI_INTFLAG_REG  	( * ( ( volatile uint32_t * ) 0xFFFFFC88 ) )

//s_timecount用于存储FRC1寄存器计时溢出的计数
static uint64_t s_timecount = 0U;
extern "C" void rtiOver1Interrupt();
void rtiOver1Interrupt(){
    s_timecount += 0x100000000;
}

void startHRTimer() {
    /* 使能定时器1计数 */
	portRTI_GCTRL_REG    |= 0x00000002U;
}

static void stopHRTimer() {
    /* 除能定时器1计数 */
	portRTI_GCTRL_REG    &= ~(uint32_t)0x00000002U;
}


void clearHRTimer(){
    /* 清除定时器1分频前计数器计数 */
	portRTI_CNT0_UC1_REG  =  0x00000000U;
    /* 清除定时器1计数器计数 */
	portRTI_CNT0_FRC1_REG =  0x00000000U;
    /* 清除定时器1溢出计数 */
	s_timecount = 0U;
}

void initHRTimer()
{
	/* 停止定时器1计数 */
    stopHRTimer();

    /* 清零定时器1 */
    clearHRTimer();

    /* 调试挂起时,定时器1停止计数*/
	portRTI_GCTRL_REG    &= ~(uint32_t)0x00000080U;

	/* 设置定时器1预分频系数为1,即2分频 */
	portRTI_CNT0_CPUC1_REG = 1; 

	/* 中断状态寄存器,对定时器1溢出中断状态位写1清零 */
	portRTI_INTFLAG_REG     =  ((uint32_t)1U<<18);

	/* 中断除能寄存器,对定时器1溢出中断开关写1除能 */
	portRTI_CLEARINTENA_REG	=  ((uint32_t)1U<<18);

	/* 中断使能寄存器,对定时器1溢出中断开关写1使能 */
	portRTI_SETINTENA_REG = (uint32_t)1U<<18;

}

/* 获取定时器1从打开到停止的定时器历时ns,等于当前FRC1寄存器计数+溢出计数 */
uint64_t getHRTimeStamp(){
    uint32_t cur_fr = portRTI_CNT0_FRC1_REG;
    return (cur_fr  + s_timecount)*20;
}

理解RTI的时钟树

配置RTI的核心在于时钟树的配置,如图1所示。

 

图1. RTI1计数器框图

由于我的RTI0用作FREERTOS的系统时钟,所以选用RTI1作为硬件计时器使用,可以通过读取RTIFRC1寄存器以获取当前计时器计数。
计时器时钟频率来源如图1所示, RTICLK由系统时钟树输出,时钟信号传递途中经过RTICPUC1,会被分频,分频系数为RTICPUC1+1。

例如RTICLK时钟100MHz,RTICPUC1配置为1,则时钟信号经过分频后传递到RTIFRC1的频率为50MHz;如果RTICPUC1配置为4,则时钟信号经过分频后传递到RTIFRC1的频率为20MHz。


        注意:

        RTICPUC1如果设置为0,则分频系数变为2^{32}+1即FR1计数器频率为\frac{RTICLK}{2^{32}+1},则RTIUC1和RTIFRC1两个寄存器可以视为一个64位的时钟定时器,其中RTIUC1为低32位计数,RTIFRC1为高32位计数。

        RTICPUC1如果设置非0值,则分频系数变为RTICPUC1+1即FR1计数频率为\frac{RTICLK}{RTICPUC1+1}


RTICLK时钟频率来源如图2所示。

图2. RTI时钟频率配置图 

 上图所示为HALCoGen.exe中GCM时钟树配置页面的截图,其中Clk_Srcs为主频300MHz,经过HCLK Devider分频后为100MHz,然后经过VCLK1 Devider分频后输出100MHz的VCLK频率。而RTICLK频率与VCLK频率相同,得出RTICLK频率为100MHz。

欢迎关注!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/73271.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Python的Socket编程

Python的Socket编程一、Socket简介二、Socket基本参数和函数介绍1. socket参数2.socket相关函数三、Python编写socket的步骤1.python编写server的步骤2.python编写client的步骤四、python socket变成实操1.server.py2.client.py3.socket更多功能五、案例1.TCP案例一&#xff1a…

推特如何解除敏感内容限制

推特如何解除敏感内容的限制&#xff0c;这里为大家分别介绍苹果、安卓、网页版的推特怎么看敏感内容&#xff0c;有需要的朋友可以看一下。 一、苹果安卓手机解除敏感内容方法&#xff08;对应中英文版&#xff09; 1.打开手机推特app&#xff0c;点击左上角的【三横】进入个…

Navicat for MySQL —— 图形化工具使用

Navicat for MySQL 下载链接&#xff1a;点击跳转 提取码&#xff1a;520H 在之前的篇目当中讲到数据库的图形化工具 —— SQLyog的使用&#xff0c;那么本篇目讲的是关于另外一款图形化工具的使用 —— Navicat for MySQL &#xff1b;下面先来安装Navicat for MySQL: Navic…

Linux权限(下)

Linux权限下file指令目录的权限x权限r权限w权限文件的默认权限umask码修改umask码粘滞位背景谁能删除设有粘滞位的目录下的文件&#xff1f;设置粘滞位的注意事项file指令 在此之前我们先了解一个指令&#xff0c;这个指令可以让我们更详细的了解文件的具体类型&#xff0c;虽…

离散数学与组合数学-01

文章目录1. 离散数学与组合数学大纲要求概述1.1 离散数学概述1.2 组合数学概述1.3. 离散数学前言第1章 数理逻辑1.1 命题与联结词1. 命题2.联结词2.集合论3.代数系统4.图论本博客内容为参考B站视频做的笔记 大家多学习&#xff0c;努力考&#x1f4af;&#x1f4af;&#x1f4a…

行业洞察 | 当数据燃尽,AI大模型出路几何?

近期&#xff0c; 自然语言处理NLP与图像方面的SOTA的模型基本都是基于大数据和大模型预训练pretrain的。当我们翱翔在搭积木垒大模型的时候&#xff0c;你可曾想过&#xff0c;也许我们垒的大模型&#xff0c;数据压根就无法完全训练好&#xff0c;换句话说也许你垒的大模型参…

BIO和NIO

前言 这段时间自己在看一些Java中BIO和NIO之类的东西&#xff0c;看了很多博客&#xff0c;发现各种关于NIO的概念说的天花乱坠头头是道&#xff0c;可以说是非常的完整&#xff0c;但是整个看下来之后&#xff0c;自己对NIO还是一知半解的状态&#xff0c;所以这篇文章不会提…

Java ssm框架 mysql实现的酒店管理系统源码+运行教程+文档

今天给大家演示一下由ssmmysql实现的一款酒店管理系统&#xff0c;教大家怎么配置运行起来&#xff0c;以及在运行过程中遇到一些小问题的解决方法。该系统实现了酒店客房预订管理的基本功能&#xff0c;还增加了图表显示统计结果的功能&#xff0c;对于Java初学者及学生来说非…

自动化测试平台(二):开发用户认证接口

一、前言 对于一个系统来讲&#xff0c;用户模块是非常基本且重要的。搭建的测试平台也需要对用户、用户权限等进行管理。下面为你讲解如何通过DRF来快速的做一个用户登录的验证接口。 二、验证登录讲解 1&#xff09;创建用户 进入django的项目目录&#xff0c;执行下面的命…

Renderbus瑞云渲染正式支持UE云渲染!离线渲染+实时渲染=渲染起飞!

2022年已经到了尾声&#xff0c;回顾今年CG圈里最具讨论性的话题&#xff0c;除了AI绘图&#xff0c;就是虚幻引擎了&#xff0c;这两者如同一股风潮&#xff0c;从概念创意到后期制作&#xff0c;一路以“席卷”之势影响到了视觉领域的各个行业。 Renderbus瑞云渲染农场作为亚…

CMake中add_custom_target的使用

CMake中的add_custom_target命令用于添加一个没有输出的target&#xff0c;以便始终构建它&#xff0c;其格式如下&#xff1a; add_custom_target(Name [ALL] [command1 [args1...]][COMMAND command2 [args2...] ...][DEPENDS depend depend depend ... ][BYPRODUCTS [files…

vue中使用visibilitychange事件来获取页面当前可见性

前言 在系统中&#xff0c;如果有打开新页面进行相关操作&#xff0c;若是有关联操作就需要通过判断页面的可见性来进行后绪的操作 一、触发visibilitychange变更的情况 页面的可见性有三个层面 页面可见时&#xff0c;用户关闭 Tab 页或浏览器窗口。页面可见时&#xff0c…

ASP.NET Zero Core系统配置工具

ASP.NET Zero Core系统配置工具 ASP。NET Zero是具有现代复杂应用程序连接的新web应用程序的起点。使用高级页面和强大的下属&#xff0c;您将能够从您的时间中受益。您可以使用ASP.NET ZERO作为基础程序&#xff0c;直接开始开发自己的代码和业务。 ASP.NET ZERO工具选项和功能…

sklearn中的特征选择feature_selection

特征选择 概念&#xff1a;就是从所有的特征中&#xff0c;选择出有意义&#xff0c;对模型有帮助的特征&#xff0c;以避免必须将所有特征都导入模型去训练的情况。特征选择常用的方法有&#xff1a;过滤法&#xff0c;嵌入法&#xff0c;包装法&#xff0c;和降维算法 过滤…

BN128曲线

1. 引言 BN系列椭圆曲线E(Fp):y2x3b&#xff0c;其中b≠0E(\mathbb{F}_p):y^2x^3b&#xff0c;其中b\neq 0E(Fp​):y2x3b&#xff0c;其中b​0&#xff0c;由Paulo S. L. M. Barreto1 和 Michael Naehrig 在2005年论文 Pairing-Friendly Elliptic Curves of Prime Order中首…

增长思维 —— 撬动企业增长的杠杆

增长一定不是只适用于互联网公司 营销&#xff1a;获客 增长&#xff1a;研究的是用户全生命周期 增长思维&#xff1a;以供需分析为基础&#xff0c;从用户全生命周期寻找增长点的方法论 这个模型的核心是啊哈时刻&#xff0c;指的是一个产品对用户价值感最强的那个点 一个…

画饼画到世界地图上:按比例呈现多组数据

地图是数据可视化的一部分&#xff0c;做群体遗传学、动物学、植物学、微生物学等的朋友经常用到世界地图&#xff0c;比如绘制不同小麦品种的世界分布。一般情况下&#xff0c;我们根据经纬度将数据标注在地图上&#xff0c;然而有些时候&#xff0c;我们会需要更高级的标注&a…

Apache doris 1.2.0 release

亲爱的社区小伙伴们&#xff0c;再一次经历数月的等候后&#xff0c;我们很高兴地宣布&#xff0c;Apache Doris 于 2022 年 12 月 7 日迎来 1.2.0 Release 版本的正式发布&#xff01;有近 118 位 Contributor 为 Apache Doris 提交了超 2400 项优化和修复&#xff0c;感谢每一…

Ubuntu 22.04 桌面美化之Mac Big Sur风格

Ubuntu 默认的桌面也是一个不错的样式&#xff0c;但千篇一律的主题很容易让人疲惫。本文描述了如何通过安装 gnome 桌面主题和动画&#xff0c;使桌面趋向于 Mac 的样式。 美化后的样式如下&#xff0c;请参考&#xff1a; 一、主题和图标美化 1.1 安装 tweaks 打开终端&…

抽奖小程序怎么做?

抽奖小程序怎么做&#xff1f;大概需要多少钱&#xff1f; 价格方面&#xff0c;平台按年收费&#xff0c;一年1498至2498元。 明码标价&#xff0c;7天退款制度&#xff0c;随时退。 抽奖小程序怎么做步骤: 1.进入第三方抽奖小程序制作平台官网注册账号并登录。 抽奖小程…