【裸机开发】GPT 定时器(一) —— GPT的功能、寄存器解析

news2024/9/22 9:39:03

后续需要使用 GPT 计数器实现中断以及延时,这里我们需要先了解一下GPT的功能以及相关寄存器。


目录

一、GPT 定时器的功能

1、计数器

2、输入捕获

3、输出比较(GPT的两种工作模式)

二、寄存器解析

1、GPTx_CR

2、GPTx_PR

3、GPTx_SR

4、GPTx_IR

5、GPTx_OCRn

6、GPTx_ICRn

7、GPTx_CNT


一、GPT 定时器的功能

gpt 定时器的主要包含以下三个功能:

  • 计数器
  • 输入捕获(可产生捕获中断)
  • 输出比较(可产生比较中断)—— 注意 GPT 的模式

1、计数器

根据图中路线,可以大致了解配置计数器的顺序:

  • 第一步,选择时钟源,这里我们依然 ipg_clk (66MHz)
  • 第二步,选择分频数(1~4096)

因为计数器是向上计数的,也就是说,每过一个时钟周期就会自增 1。 

2、输入捕获

输入捕获(Input Capture,ICR)可以捕获到时钟源产生的上升沿或者下降沿,并产生中断。GPT 定时器有两个输入捕获通道

3、输出比较(GPT的两种工作模式)

输出比较(Output Compare,OCR)包含三个输出通道GPT_COMPARE1~3 ,通道的使用和触发中断的机制都取决于 GPT 的工作模式:

  • Restart Mode:需要预设 Output Regx ,当计数器的值 == Output Regx时,会产生比较中断(仅适用于GPT_COMPARE1)
  • Free-Run Mode:计数器从 0 开始自增,自增到 0xFFFFFFFF 以后溢出,重新从 0 开始计数

二、寄存器解析

1、GPTx_CR

GPT 控制寄存器,可以控制时钟源、输入通道使能、输出通道使能等。下面主要解析后面需要用到的一些位。

bit 0:GPT 使能(启动 / 关闭GPT定时器),一般等到配置完其他寄存器再设置该字段。

bit 1:设置当定时器启动时的初始值。0 表示从上一次关闭时计数器的值开始计数,1 表示重新从0开始计数。

bit 8-6:选择时钟源。我们选择 ipg_clk(66MHz)

bit 9:选择 GPT 的工作模式。一般选 Restart Mode。(上面已经介绍了)

bit 15:设置软件复位状态。

  • 设为复位状态后,只要还在复位,该位会一直置 1 。除了bit 0、1、2、3、5外,其他位都会被重置为默认值。
  • 复位完毕后,会自动清零,即置 0 

补充:

  • IM1~2 设置的是捕获状态,即上升沿还是下降沿捕获
  • OM1~3 设置的是输出状态,即不输出、输出反转等。
寄存器: GPT1_CR
基地址: 0x2098000
初始化操作:
    // 禁用GPT定时器
    GPT1_CR &= ~(1 << 0);
    // 复位
    GPT1_CR |= (1 << 15);
    while((GPT1_CR >> 15) & 0x1);    // 等待复位结束

    /* 
     * 配置GPT定时器
     * bit 1: 1
     * bit 8-6: 001
     * bit 9: 0
     */
    GPT1_CR |= (1 << 1);
    GPT1_CR &= ~((7 << 6) | (1 << 9));
    GPT1_CR |= (1 << 6);
    
    // ... 其他初始化操作

    // 启动定时器
    GPT1_CR |= (1 << 0);

2、GPTx_PR

GPT 分频器,可以设置时钟源的分频数。bit 11-0 设置的是分频数(1~4096)

寄存器: GPT1_PR
基地址: 0x2098004
初始化操作:
    // 66 分频
    GPT1_PR &= ~(0xFFF << 0);    // 低 12 bit 清零
    GPT1_PR |= (66 << 0);        // 66 分频

3、GPTx_SR

GPT状态寄存器,是一个可读寄存器,无需设置。主要保存如下内容:

  • 输出比较的中断触发状态 OF1~3
  • 输入捕获的中断触发状态 IF1~2
  • 溢出状态(即计数器的值是否和比较器的值相等 或者 是否计数到 0xFFFFFFFF)
​寄存器: GPT1_SR
基地址: 0x2098008

4、GPTx_IR

GPT 中断寄存器,主要控制输入 / 输出通道的中断使能。上面GPT的工作模式已经设为 Restart Mode,所以我们需要 使能输出比较通道 1。

寄存器: GPT1_IR
基地址: 0x209800C
初始化操作:
    GPT1_IR |= (1 << 0);    // 输出比较通道1 使能

5、GPTx_OCRn

GPT 输出比较寄存器,保存的是比较值,Restart 模式下,当计数器的值 == 比较值时,触发中断。假设延时 10 ms,时钟源为 66 MHz,分频数为 66。

由此可以知道时钟周期为 1/1M,延时10ms对应的比较值 = 1M * 0.01 = 10000

寄存器: GPT1_OCR1
基地址: 0x2098010
初始化操作:
    GPT1_OCR1 |= (10000 << 0);    // 设置通道1 的比较值为10000

6、GPTx_ICRn

GPT 输入捕获寄存器,保存的是当捕获中断触发时,计数器的值。

​寄存器: GPT1_ICR1
基地址: 0x209801C

7、GPTx_CNT

GPT 计数寄存器,保存的是当前时刻计数器的值。

​寄存器: GPT1_CNT
基地址: 0x2098024

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

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

相关文章

Jetson Nano烧写系统镜像

Jetson Nano是一款形状和接口类似于树莓派的嵌入式主板&#xff0c;搭载了四核Cortex-A57处理器&#xff0c;GPU则是拥有128个NVIDIA CUDA核心的NVIDIA Maxwell架构显卡&#xff0c;内存为4GB的LPDDR4&#xff0c;60Hz视频解码。 1.烧录前准备 电源线&#xff08;必备&#xf…

游戏陪玩语音聊天系统3.0商业升级独立版本源码

首发价值29800元的最新商业版游戏陪玩语音聊天系统3.0商业升级独立版本源码 1、增加人气店员轮播 2、优化ui界面丨优化游戏图标展示丨优化分类展示 3、增加动态礼物打赏功能 4、增加礼物墙功能 增加店员满足业绩&#xff0c;才能升级功能 5、增加店员等级不同&#xff0c;可接…

操作系统第4章习题

B 一个目录文件包含多个目录项 B. 在打开文件的时候还不用 只有在读文件的时候 才需要把数据读到内存中 C 不完整 D 在外存中 FCB不是文件控制块吗 为什么是文件目录项 文件属性&#xff1a;有的文件是只读的 访问控制的灵活性较高

【前端2】jquary,bootstrap,vue

文章目录 1.jquary&#xff1a;选择器1.1 jquery框架引入&#xff1a;$("mydiv") 当成id选择器1.2 jquery版本/对象&#xff1a;$(js对象) -> jquery对象1.3 jquery的页面加载事件&#xff1a;$ 想象成 window.onload 1.4 jquery的基本选择器&#xff1a;$()里内容…

7 拓展中断_事件控制器(EXTI)(STM32HAL库 )

目录 EXTI-扩展中断和事件控制器 事件的概念 EXTI-扩展中断和事件控制器 EXTI外设框图 F1/F4/F7&#xff08;看懂与或门&#xff09; H7 STM32CubeMX中的EXTI配置 EXTI-扩展中断和事件控制器 事件的概念 STM32上许许多多的外设&#xff0c;是通过内部信号来协同工作的。…

Android Compose Button defaultButtonColors

Android Compose Button defaultButtonColors 本文最新更新地址 https://gitee.com/chenjim/chenjimblog 发现问题 最近看 Android Compose 相关资料发现如下代码 colors defaultButtonColors( backgroundColor if (count > 5) Color.Green else Color.White )原文地…

从C语言到C++_23(多态)抽象类+虚函数表VTBL+多态的面试题

目录 1. 多态&#xff08;polymorphism&#xff09; 1.1 构成多态的两个条件 1.2 虚函数重写(覆盖) 1.3 协变构成多态 1.4 父虚子非虚构成多态 1.5 析构函数的重写 1.6 final 和 override 关键字&#xff08;C11&#xff09; 1.7 重载、覆盖、隐藏的对比 2. 抽象类&am…

通信接口和通信方式总结

通信接口和通信方式总结 一、通信接口主要的5种类型二、通信方式2.1 并行和串行2.2 单工、半双工及全双工通信2.3 串行通信分类 - 同步\异步2.4 波特率 Baud Rate 三、串联设备的接口类型 - 网口和串口3.1 串口 - COM口3.1.1 基本介绍及应用3.1.2 接线方式 - 232、422、485接线…

时序预测 | MATLAB实现PSO-GRU(粒子群优化门控循环单元)时间序列预测

时序预测 | MATLAB实现PSO-GRU(粒子群优化门控循环单元)时间序列预测 目录 时序预测 | MATLAB实现PSO-GRU(粒子群优化门控循环单元)时间序列预测预测效果基本介绍模型介绍PSO模型GRU模型PSO-GRU模型 程序设计参考资料致谢 预测效果 基本介绍 Matlab基于PSO-GRU粒子群算法优化门…

【vue3-element-admin 】基于 Vue3 + Vite4 + TypeScript5+ Element-Plus 从0到1搭建企业级后台管理系统(前后端开源)

vue3-element-admin 是基于 vue-element-admin 升级的 Vue3 Element Plus 版本的后台管理前端解决方案&#xff0c;技术栈为 Vue3 Vite4 TypeScript Element Plus Pinia Vue Router 等当前主流框架。 相较于其他管理前端框架&#xff0c;vue3-element-admin 的优势在于一…

Docker中安装Nginx

查看可以安装的Nginx版本: docker search nginx 下载最新版本: docker pull nginx :latest 可以省略 运行容器: docker run -itd --name my_nginx -p 80:80 nginx 在主机通过 https://localhost:80或者 http://192.168.40.100:80可以访问 如果之前创…

Java阶段四Day10

Java阶段四Day10 文章目录 Java阶段四Day10关于RedisRedis的数据类型Redis中的list类型Redis的常用命令关于Key的格式Redis编程使用Redis时的数据一致性问题 关于ApplicationRunnerLoadCacheRunnerContentCategoryServiceImpl 计划任务ScheduleConfigurationCategoryCacheSched…

已烧写过的镜像重新烧镜像教程

本教程是已经烧录过镜像的SD卡&#xff0c;无法被电脑识别盘符导致无法重新烧录镜像的教程。一般是win7系统无法识别烧录过的Ubuntu系统盘符。win10可以使用SDformat软件格式化。 1.确定读卡器是否识别到SD卡。 点击计算机右键选择“管理”&#xff0c;选择磁盘管理&#xff0…

Vue3中Vuex的基本使用

src/store/uuidState.js const uuidState {namespaced: true,state: {uuid: "",state_tag: "",},// 要想改变state中的数据必须使用mutations的方法mutations: {changeUuid(state, value) {state.uuid value;},changeTag(state, value) {state.state_ta…

如何通过空号检测,验证电话号码数据的准确性

引言 空号检测 API 接口通常与电话号码数据库或相关的电话服务提供商进行交互&#xff0c;使用验证算法和查询技术来确定电话号码的状态。通过该接口&#xff0c;开发者可以通过编程方式对电话号码进行验证&#xff0c;帮助验证号码的有效性&#xff0c;确保数据的准确性和可靠…

HJ76 尼科彻斯定理

描述 验证尼科彻斯定理&#xff0c;即&#xff1a;任何一个整数m的立方都可以写成m个连续奇数之和。 例如&#xff1a; 1^31 2^335 3^37911 4^313151719 输入一个正整数m&#xff08;m≤100&#xff09;&#xff0c;将m的立方写成m个连续奇数之和的形式输出。 数…

vmware17安装群辉6.2懒人包

懒人包下载 链接&#xff1a;https://pan.baidu.com/s/1onGpM3BLIKUuxs10lLM83A?pwdcmdr 提取码&#xff1a;cmdr --来自百度网盘超级会员V5的分享 解压安装 如果已经安装了vmware软件的话&#xff0c;直接双击打开即可 上图说明安装成功 点击搜索 &#xff0c; 会出现服务…

0-1BFS 双端队列 广度优先搜索

一. BFS及0-1BFS的简单介绍 深度优先搜索DFS和广度优先搜索BFS是经常使用的搜索算法&#xff0c;在各类题目中都有广泛的应用。 深度优先搜索算法&#xff08;英语&#xff1a;Depth-First-Search&#xff0c;DFS&#xff09;是一种用于遍历或搜索树或图的算法。其过程简要来说…

pwn学习day3——函数调用约定

文章目录 x32 cdecl调用约定x64 System V AMD64 ABI调用约定 规定函数调用时如何传递参数&#xff0c;如何返回值&#xff0c;如何进行栈管理 x32 cdecl调用约定 参数从右往左依次压入栈中&#xff0c;返回值存入eax寄存器中,由调用者清理栈上的参数。 测试程序&#xff1a; …

转载-【AI思维空间】Chat2DB 一款开源数据库客户单工具

卸载 Navicat&#xff0c; xxx 又开源了一款数据库神器&#xff0c;太炸了 Chat2DB 是一款有开源免费的多数据库客户端工具&#xff0c;支持windows、mac本地安装&#xff0c;也支持服务器端部署&#xff0c;web网页访问。和传统的数据库客户端软件Navicat、DBeaver 相比Chat2D…