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

后续需要使用 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.hqwc.cn/news/12899.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

3.1.cuda运行API-概述

目录 前言1. Runtime API概述总结 前言 杜老师推出的 tensorRT从零起步高性能部署 课程&#xff0c;之前有看过一遍&#xff0c;但是没有做笔记&#xff0c;很多东西也忘了。这次重新撸一遍&#xff0c;顺便记记笔记。 本次课程学习精简 CUDA 教程-Runtime API 概述 课程大纲可…

【编程的多线程学习-前章】什么是进程,PCB进程控制块抽象,cup分配,内存分配,虚拟地址,进程的通信,进程的意义

什么是进程 什么是进程/任务&#xff08;Process/Task&#xff09;进程就是一个运行起来的程序PCB 进程控制块抽象(PCB Process Control Block)pcb就是一个进程PCB具体包含的信息 CPU 分配 —— 进程调度&#xff08;Process Scheduling&#xff09;内存分配 —— 内存管理&…

简单的手机记事本app怎么查看提醒列表?

很多人平时都有随手记事的习惯&#xff0c;在记录事情的时候使用手机上的记事本app是一个不错的选择。有的记事本功能比较完善&#xff0c;不但能记事还能设置提醒&#xff0c;当有多条提醒内容存在时&#xff0c;简单的手机记事本app怎么查看提醒列表呢&#xff1f;以iPhone手…

数据结构--线索二叉树找前驱后继

数据结构–线索二叉树找前驱后继 中序线索二叉树找中序后继 在中序线索二叉树中找到指定结点*p的 中序后继 \color{red}中序后继 中序后继next ①若p->rtag 1&#xff0c;则next p->rchild ②若p->rtag 0 中序遍历――左根右 左根(左根右) 左根((左根右)根右) next …

基于matlab使用多类掩码区域的卷积神经网络对人和汽车的各个实例进行分段(附源码)

一、前言 此示例展示了如何使用基于多类掩码区域的卷积神经网络 &#xff08;R-CNN&#xff09; 对人和汽车的各个实例进行分段。实例分割是一种计算机视觉技术&#xff0c;您可以在其中检测和定位对象&#xff0c;同时为每个检测到的实例生成分割图。 此示例首先演示如何使用…

分治法求最近点对问题

目录 蛮力法 分治法 探究分治规模小于一定程度时采用暴力解法 蛮力法 算法思想 蛮力法&#xff0c;顾名思义&#xff0c;即穷举所有点与点之间的距离&#xff0c;两层循环暴力找出最近点对。算法执行可视化如图1所示&#xff0c;word文档GIF静态显示&#xff0c;附件已含动…

阿里版ChatGPT——通义千问,开箱初体验

所有行业、所有应用、所有服务都值得基于新型人工智能技术重做一遍&#xff0c;在带来创造性客户体验的同时&#xff0c;生产范式、工作范式、生活范式也将发生变化。——阿里集团董事会主席兼CEO 张勇 2023阿里云峰会上&#xff0c;通义千问大语言模型对外发布&#xff0c;宣称…

JAVA环境变量配置步骤及测试(JDK的下载 安装 环境配置教程)

目录 一&#xff1a;JDK的下载、安装和配置 JDK 压缩包版的安装 JDK 安装版的安装 二&#xff1a;环境变量配置步骤 三&#xff1a;测试 四、Eclipse安装 已对此文进行更新&#xff0c;请到新文发布地址&#xff1a;https://rej177.blog.csdn.net/article/details/131565…

SpringBoot通过获取请求参数或者Headers上的特殊标识实现i18n国际化

实现效果 我们大部分都是把i18n的标识放在Headers上面&#xff1b;而把标识放在参数上的话比较少&#xff0c;放参数上的话一般是在使用a标签下载某些文件不好配置请求头的时候才使用上 配置在Headers上面&#xff1a; 配置在params上面&#xff1a; 配置代码&#xff1a; /**…

ChatGPT Prompting开发实战(一)

第7章 ChatGPT Prompting开发实战 7.1 Prompting在LangChain框架中的应用 本节跟大家讲提示工程(Prompt Engineering),主要基于工业级的源码以及具体的项目,无论是工程人员,还是不具有技术背景的人员,大家多少都听说过提示词,或者频繁使用过,简单而言,当我们使用OpenA…

CleanMyMac X4.13中文版mac电脑优化加速工具

CleanMyMac X 可以卸掉系统的额外负担 让您的电脑明显提速 不要再因为运行缓慢的 Mac 而拖慢您的效率。CleanMyMac X已经正式发布&#xff0c;作为最新的系统清理和应用管理软件&#xff0c;可以让用户一键智能化清理Mac电脑&#xff0c;自动扫描Mac上的所有文件&#xff0c;包…

谈谈mysql——主从模式下的同步方式及半同步、MGR的部署方式

MySQL的复制模式 异步复制 MySQL的复制方式默认是异步的&#xff0c;主从复制涉及三个线程 master I/O master I/O线程负责写入Binlog&#xff0c;并将执行结果返给客户端&#xff0c;至于Binlog有没有被IO线程读取&#xff0c;读取后有没有重放&#xff0c;重放有没有成功&…