11. EPIC定时器

11. EPIC定时器

  • EPIT定时器简介
    • EPIT定时器结构分析
    • EPIT 定时器相关寄存器
      • EPITx_CR
      • EPITx_SR
      • EPITx_LR 加载寄存器
      • EPITx_CMPR 比较寄存器
      • EPITx_CNR 计数寄存器
    • EPIT 配置步骤
  • 例程代码编写
    • bsp_epittimer.h
    • bsp_epittimer.c
    • main.c

EPIT定时器简介

EPIT定时器是增强的周期中断定时器,主要是完成周期性中断定时。EPIT是一个 32 位定时器,在处理器几乎不用介入的情况下提供精准的定时中断,软件使能后EPIT就会开始运行。EPIT有以下特点:

  • 时钟源可选的 32 位向下计数器
  • 12 位的分频值
  • 当计数值和比较值相等的时候产生中断

EPIT定时器结构分析

在这里插入图片描述

  1. 这是一个多路选择器,用来选择 EPIT 定时器的时钟源
  2. 这是一个 12 位的分频器,负责对时钟源进行分频,12 位对应的值是 0 ~ 4095,对应 1 ~ 4096分频
  3. 经过分频的时钟进入到 EPIT 内部,在内部有 3 个重要的寄存器:计数寄存器、加载寄存器和比较寄存器。这 3 个寄存器都是 32 位的。EPIT 计数器是一个向下的计数器,也就是说给它一个初值,它就会从这个初值开始递减,直到减为 0,计数寄存器保存的就是当前的计数器。如果EPIT工作在 set-and-forget 模式下,当计数寄存器里面的值减到0,EPIT 就会重新从加载寄存器读取数值到计数寄存器里面,重新开始向下计数。比较寄存器里保存的数值用于和计数寄存器的计数值比较,如果相等就会产生一个比较事件。
  4. 比较器
  5. EPIT 可以设置引脚输出,如果设置了的话就会通过指定的引脚输出信号
  6. 产生比较中断,也就是定时中断
  7. EPIT 定时器有两种工作模式:set-and-forget 和 free-running
    set-and-forget 模式: EPITx_CR(x=1,2)寄存器的 RLD 位置为 1 的时候 EPIT 工作在此模式下,在此模式下 EPIT 的计数器从加载寄存器 EPITx_LR 中获取初始值,而不能直接向计数器寄存器写入数据。不管什么时候,只要计数器计数到 0,那么就会从加载寄存器 EPITx_LR 中重新加载数据到计数器中。
    free-running 模式: EPITx_CR 寄存器的RLD 位清零的时候 EPIT 工作在此模式下,当计数器计数到 0 后会重新从 0xFFFFFFFF 开始计数,并不是从加载计数器中获取数据。

EPIT 定时器相关寄存器

EPITx_CR

在这里插入图片描述

  • CLKSRC(bit25:24): EPIT 时钟源选择位,为 0 的时候关闭时钟源,为 1 的时候选择ipg_clk 时钟,为 2 的时候选择 ipg_clk_highfreq,为 3 的时候选择 ipg_clk_32k。本例程中,选择ipg_clk = 66MHz
  • PRESCALAR(bit15:4): 时钟源分频值,可设置范围0 ~ 4095,对应1 ~ 4096 分频
  • RLD(bit3): EPIT 工作模式,为 0 的时候工作在 free-running 模式,为 1 的时候工作在 set-and-forget 模式,本例程为 1
  • OCIEN(bit2): 比较中断使能位,为 0 的时候关闭比较中断,为 1 的时候使能比较中断,这里我们要使能比较中断
  • ENMOD(bit1): 设置计数器初始值,为 0 的时候初始值等于上次关闭 EPIT 定时器以后计数器里面的值,为 1 的时候来源于加载寄存器或者0xFFFFFFFF(由工作模式决定)
  • EN(bit0): EPIT 使能位,为 0 的时候关闭 EPIT,为 1 的时候使能 EPIT

EPITx_SR

在这里插入图片描述
OCIF: 比较中断标志位,为 0 的时候表示没有比较事件发生,为 1 的时候表示有比较事件发生。当比较事件发生以后需要手动清除此位,此位是写1清零

EPITx_LR 加载寄存器

用于保存计数器的当前值,以供下一次计数使用。当计数器每次计时达到 0 以后,会重新加载此寄存器中的值,并且计数器重新开始计数

EPITx_CMPR 比较寄存器

当计数器的值和 CMPR 寄存器的值相等的时候就会产生中断

EPITx_CNR 计数寄存器

通入时钟,每一个时钟周期它的值就会减 1

EPIT 配置步骤

  1. 设置 EPIT1 的时钟源
    设置寄存器 EPIT1_CR 寄存器的 CLKSRC(bit25:24) 位
  2. 设置分频值
    设置寄存器 EPIT1_CR 寄存器的 PRESCALAR(bit 5:4) 位
  3. 设置工作模式
    设置寄存器 EPIT1_CR 寄存器的 RLD(bit3) 位
  4. 设置计数器的初始值来源
    设置寄存器 EPIT1_CR 寄存器的 ENMOD(bit1) 位
  5. 使能比较中断
    设置寄存器 EPIT1_CR 寄存器的 OCIEN(bit2) 位
  6. 设置加载值和比较值
    设置 EPIT1_LR 寄存器的加载值和 EPIT1_CMPR 比较值
  7. EPIT1 中断设置和中断服务函数编写
    使能GIC 中对应的 EPIT1 中断,注册中断服务函数,还可以设置中断优先级,最后编写中断服务函数
  8. 使能 EPIT1 定时器
    通过寄存器 EPIT1_CR 的 EN(bit0) 位来设置

例程代码编写

bsp_epittimer.h

#pragma once
#include "imx6ul.h"
void epit1_init(unsigned int frac, unsigned int value);
void epit_irqhandler();

bsp_epittimer.c

#include "bsp_epittimer.h"
#include "bsp_int.h"
#include "bsp_led.h"

void epit1_init(unsigned int frac, unsigned int value)
{
	if(frac > 0xFFF)
		frac = 0xFFF;
	EPIT1->CR = 0; // 先清零 CR 寄存器
	// 先将 EPIT 配置好之后再使能
	// CR 寄存器:24-25位配置时钟源,选择Peripheral clock=66;4-15位配置frac分频值
	// 3位当计数器到0的话从LR重新加载数值,也就是工作在set-and-forger 模式;
	// 2位比较中断使能;1位设置计数器初始值来自LR 寄存器;0位先关闭EPIT1
	EPIT1->CR = (1<<24|frac<<4|1<<3|1<<2|1<<1);
	EPIT1->LR = value;
	EPIT1->CMPR = 0;
	
	// 使能 GIC 中对应的中断
	GIC_EnableIRQ(EPIT1_IRQn);

	// 注册中断服务函数
	system_register_irqhandler(EPIT1_IRQn, (system_irq_handler_t)epit1_irqhandler, NULL);
	EPIT1->CR |= 1<<0; // 使能EPIT1
}
void epit1_irqhandler()
{
	static unsigned char state = 0;
	state = !state;
	if(EPIT1->SR & (1<<0)) // 判断比较事件发生
	{
		led_switch(LED0, state);	// 定时器周期到,反转LED
	}
	EPIT1->SR |= 1<<0;		// 清除中断标志位
}

分频值和 value 就可以决定中断频率,公式为:EPIT 溢出时间=((分频值+1)*value)/输入时钟频率

main.c

int main()
{
	int_init();			// 初始化中断
	imx6u_clkinit();	// 初始化系统时钟
	clk_enable();		// 使能所有时钟
	led_init();			// 初始化LED
	beep_init();		// 初始化beep
	key_init();
	epit1_init(0, 66000000/2);	// 初始化EPIT1定时器,1分频,计数器值为66000000/2 也就是500ms
	while(1)
	{
		delay(500);
	}
	return 0;
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

人工智能基础_机器学习024_梯度下降进阶_L1正则可视化图形---人工智能工作笔记0064

然后我们就来用代码实现一下L1正则的可视化,我们来看看 首先导入 import numpy as np 数学计算 import matplotlib.pyplot as plt 画图用的 然后我们把L1正则的公式写出来 可以看到L1的正则 其实就是w1和w2的绝对值相加对吧 然后这里我们写一个公式: f(x,y) = |x|+|y| …

NL2SQL学习

在学习NL2SQL之前先要进行三W提问&#xff1a; 即what 是什么 &#xff1b; why 为什么使用&#xff1b; how 如何使用 NL2SQL是什么&#xff1f; NL2SQL&#xff08;NLP Natural Language To SQL&#xff09;是自然语言处理的新兴研究热点&#xff0c;顾名思义&#xff0…

15 # 手写 throttle 节流方法

什么是节流 节流是限制事件触发的频率&#xff0c;当持续触发事件时&#xff0c;在一定时间内只执行一次事件&#xff0c;这个效果跟英雄联盟里的闪现技能释放差不多。 函数防抖关注一定时间连续触发的事件只在最后执行一次&#xff0c;而函数节流侧重于一段时间内只执行一次…

【基础算法模板梳理】再也不想学算法了!(待更新)

目录 1、【二分】 &#xff08;1&#xff09;rmid —— 大于等于某数的最小值 &#xff08;2&#xff09;lmid —— 小于等于某数的最大值 2、【前缀和】 &#xff08;1&#xff09;一维前缀和 &#xff08;2&#xff09;二维前缀和 3、【差分】 &#xff08;1&#x…

Mac代码文本编辑器Sublime Text 4

Sublime Text 4 for Mac拥有快速响应的功能&#xff0c;可以快速加载文件和执行命令&#xff0c;并提供多种语言支持&#xff0c;包括C 、Java、Python、HTML、CSS等。此外&#xff0c;该编辑器还支持LaTeX、Markdown、JSON、XML等技术领域。 Sublime Text 4 for Mac的插件丰富…

Ubuntu18.04.6共享文件夹的创建,以及在哪打开共享文件夹

目录 1、打开虚拟机的设置页面 2、设置共享文件夹 3、确认是否成功设置共享文件夹 4、完成后在进入到/mnt/hgfs ls查看&#xff0c;发现共享文件夹已经出现可以使用 1、打开虚拟机的设置页面 两种方式&#xff1a; &#xff08;1&#xff09;直接点击“编辑虚拟机设置” …

YOLO目标检测——海洋目标检测数据集下载分享【含对应voc、coco和yolo三种格式标签】

实际项目应用&#xff1a;海洋监管、海洋资源开发、海洋科学研究数据集说明&#xff1a;海洋目标检测数据集&#xff0c;真实场景的高质量图片数据&#xff0c;数据场景丰富&#xff0c;含有“金属”、“未知”、“橡胶”、“平台”、“塑料”、“木材”、“布”、“纸张”、“…

SAP S4后的一些注意点(一)(更新中)

SAP 此外&#xff0c;我们必须确保 P10 中所有新的 Unicore 代码都是云就绪的。因此&#xff0c;在 ATC 中增加了一项新的检查&#xff08;自定义&#xff09;&#xff0c;以证明代码的云就绪性。此外&#xff0c;我们还在 ADT 中安装了一个名为 ABAP Cleaner 的新插件&#xf…

初探SVG

SVG&#xff0c;可缩放矢量图形&#xff08;Scalable Vector Graphics&#xff09;。使用XML格式定义图像。SVG有以下优点&#xff1a;1&#xff09;可被非常多的工具读取和修改&#xff1b;2&#xff09;比JPEG和GIF尺寸更小&#xff0c;可压缩性更强&#xff1b;3&#xff09…

多门店民宿预定系统酒店预订管理系统源码/公寓/农家乐小程序源码

技术栈&#xff1a; thinkphpuniappmysql 支持H5APP小程序 主要功能介绍&#xff1a; 在线预订 支持在线支付或到店付&#xff0c;支持配置免费取消订单时长&#xff0c;支持到店付保留时长设置 房间搜索 支持按日期搜索房间状态&#xff0c;支持按日期区间搜索房间状态…

置换环算法

参考该博客大佬的讲解 置换环 - TTS-S - 博客园 (cnblogs.com) 置换环&#xff1a;一般用于解决数组排序元素间所需最小交换次数这类问题。 置换环思想&#xff1a;置换环是将每个元素指向其应在的位置&#xff0c;最终相连成一个环(若元素就在其应在的位置&#xff0c;则自身…

乡村振兴 品牌引领 “盘锦碱地柿子”亮相第二十届中国国际农产品交易会

2023年11月9日&#xff0c;为期4天的第二十届中国国际农产品交易会在山东青岛成功举办。本次大会以“奋进新征程强农促振兴”为主题。农交会是经党中央、国务院批准&#xff0c;农业农村部主办的大型农业行业盛会&#xff0c;在宣传“三农”政策、展示农业农村发展成就、活跃农…

OSG练习:模仿Ventsim制作三维矿井智能通风系统

1、效果 2、计划内容 1) 三维场景的加载显示;已实现 2)矿井巷道建模及纹理;已实现 3)矿井基础数据采集及修正;已实现 4)通风网络解算算法;已实现 5)通风设备及设施模型制作;未实现 6)风流模拟效果 ;进行中 7)火灾模拟效果;未实现 8)巷道属性查看栏;未实现 9)…

【Linux网络】系统调优之时间同步,搭建内网时间同步服务器

目录 一、时间同步是什么 二、时间同步实验 pc1的chrony配置修改&#xff1a; pc2和pc3时间同步配置一样 关于时间调整再同步回来&#xff1a;ntpdate命令 最后&#xff0c;再总结一下&#xff08;关于服务端口&#xff09;&#xff1a; 三、命令记录 一、时间同步是什…

[极客大挑战 2019]Upload 1

题目环境&#xff1a; 根据题目和环境可知此题目是一道文件上传漏洞 编写一句话木马脚本<?php eval($_POST[shell]);?>将脚本文件更改为jpg图片文件我这里是flag.jpg上传文件并burpsuite抓包Repeater重放 报错一句话木马里面有<?字符 换一种一句话木马继续编写木马…

【JAVA学习笔记】 68 - 网络——TCP编程、UDP编程

项目代码 https://github.com/yinhai1114/Java_Learning_Code/tree/main/IDEA_Chapter21/src 网络 一、网络相关概念 1.网络通讯 1.概念:两台设备之间通过网络实现数据传输 2.网络通信:将数据通过网络从一台设备传输到另一台设备 3. java.net包下提供了一系列的类或接口&a…

简单得令人尴尬的FSQ:“四舍五入”超越了VQ-VAE

©PaperWeekly 原创 作者 | 苏剑林 单位 | 月之暗面 研究方向 | NLP、神经网络 正如 “XXX is all you need” 一样&#xff0c;有不少论文都以“简单得令人尴尬”命名&#xff08;An Embarrassingly Simple XXX&#xff09;&#xff0c;但在笔者看来&#xff0c;这些论文…

Oracle(16)Managing Privileges

目录 一、基础知识 1、Managing Privileges管理权限 2、System Privileges 系统特权 3、System Privileges : Example系统权限&#xff1a;示例 4、Who Can Grant or Revoke? 谁可以授予或撤销权限&#xff1f; 5、The PUBLIC 6、SYSDBA and SYSOPER 7、Revoke with A…

3D模型人物换装系统

3D模型人物换装系统 介绍遇到的问题问题修复具体实现换装1.准备所有模型部位和模型骨骼部位准备材质准备模型根骨骼准备创建文件夹将上述模型拖成预制体创建一个动画状态机给他们附上待机动画 2.脚本驱动Mesh合并代码 UCombineSkinnedMgr.cs创建Mesh以及实例化对象的代码 UChar…

一文带你了解栈的基本概念以及栈的实现

✏️✏️✏️今天给大家分享一下栈的基本概念、线性栈的自定义实现&#xff0c;以及栈的应用题目。 清风的CSDN博客 &#x1f61b;&#x1f61b;&#x1f61b;希望我的文章能对你有所帮助&#xff0c;有不足的地方还请各位看官多多指教&#xff0c;大家一起学习交流&#xff01…