中颖51芯片学习3. 定时器

2024-04-09 09:44

本文主要是介绍中颖51芯片学习3. 定时器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

中颖51芯片学习3. 定时器

  • 一、SH79F9476定时器简介
    • 1. 简介
    • 2. 定时器运行模式
  • 二、定时器2
    • 1. 说明
      • (1)时钟
      • (2)工作模式
    • 2. 寄存器
      • (1)控制寄存器 T2CON
      • (2)定时器2模式控制寄存器 T2MOD
    • 3. 工作方式0
      • (1)16位捕获说明
      • (2)代码实现
    • 4. 工作方式1
      • (1)16位自动重载定时器说明
        • 当DCEN = 0,通过在T2CON中的EXEN2位选择两个选项。
        • 设置DCEN位允许定时器2递增计数或递减计数。当DCEN = 1时,T2EX引脚控制计数的方向,而EXEN2控制无效。
      • (2)代码实现
    • 5. 工作方式2 可编程时钟输出
      • (1)功能介绍
      • (2)软件实现
  • 三、其它定时器介绍
    • 1. 定时器3
    • 2. 定时器4
      • 启用 TIMER4_OUT
      • 启用 TIMER4_EDGETRIG
    • 3. 定时器5

一、SH79F9476定时器简介

1. 简介

SH79F9476芯片具有多个定时器模块,包括定时器/计数器、PWM(脉冲宽度调制)定时器等,定时器可以配置为在计时达到特定值时触发中断,以便处理紧急事件或执行特定的任务。

2. 定时器运行模式

  1. MODE0 16位捕捉模式;
  2. MODE1 16位重载方式;
  3. MODE2 可编程时钟输出模式
  4. 上升沿多次触发模式

具体地看,SH79F9476 有定时器 2,定时器 3,定时器 4 和定时器 5 四个定时器,其中:

  • 定时器 2 可配置为 16 位捕捉功能、16 位重载方式或可编程时钟输出方式;
  • 定时器 3 可配置为 16 位自动重载定时/计数器,且可以工作在掉电模式;
  • 定时器 4 可配置为 16 位自动重载定时器或带边沿触发的 16 位自动重载定时器;两个数据寄存器TH4和TL4可作为一个16位寄存器来访问;
  • 定时器 5 可配置为 16 位的自动重载定时器。

二、定时器2

1. 说明

定时器2有两个数据寄存器TH2和TL2,可以作为一个16位寄存器来使用,由寄存器T2CON和T2MOD控制;
定时器2的中断使能位是: IEN0寄存器中的ET2位。

(1)时钟

C/T2选择系统时钟(定时器)或外部引脚 T2 (计数器)作为定时器时钟输入。通过所选的引脚设置TR2允许定时器2/计数器2数据寄存器计数。
可配置寄存器T2MOD中的TCLKP2位选择系统时钟或系统时钟的1/12作为定时器2的时钟源。

(2)工作模式

定时器2支持3种工作方式:

  • 捕获/重载
  • 带递增或递减计数器的自动重载方式
  • 可编程时钟输出

可以通过寄存器配置定时器2的工作方式:

C/T2T2OEDCENTR2CP/RL2方式描述
X0X11016位捕获
X0010116位自动重载定时器
X0110116位自动重载定时器
01X1X2可编程时钟
11X1X不推荐使用
XXX0XX定时器2停止,T2EX通路仍旧允许

2. 寄存器

(1)控制寄存器 T2CON

C8H第7 位第6 位第5 位第4 位第3 位第2 位第1 位第0 位
T2CONTF2EXF2--EXEN2TR2C/T2CP/RL2
读/ 写读/写读/写--读/写读/写读/写读/写
复位值(POR/WDT/LVR/PIN)00--0000

位功能:

位编号位符号说明
7TF2定时器2 溢出标志位
0:无溢出(必须由软件清0)
1:溢出(由硬件设1)
6EXF2T2EX 引脚外部事件输入(下降沿)被检测到的标志位
0:无外部事件输入(必须由软件清0)
1:检测到外部输入(如果EXEN2 = 1,由硬件设1)
3EXEN2T2EX 引脚上的外部事件输入(下降沿)用作重载/ 捕获触发器允许/ 禁止控制位
0:忽略T2EX引脚上的事件
1:检测到T2EX引脚上一个下降沿,产生一个捕获或重载
2TR2定时器2 开始/ 停止控制位
0:停止定时器2
1:开始定时器2
1C/T2定时器2 定时器/ 计数器方式选定位
0:定时器方式,T2引脚用作I/O端口
1:计数器方式,内部上拉电阻被打开
0CP/RL2捕获/ 重载方式选定位
0:16位带重载功能的定时器/计数器
1:16位带捕获功能的定时器/计数器

(2)定时器2模式控制寄存器 T2MOD

C9H76543210
T2MODTCLKP2----T2OEDCEN
读/写读/写读/写----读/写读/写
复位值(POR/WDT/LVR/PIN)0-----00

位定义:

位编号位符号说明
7TCLKP2分频选择控制位
0:选择系统时钟的1/12作为定时器2的时钟源
1:系统时钟作为定时器2的时钟源
1T2OE定时器2 输出允许位
0:设置P1.3/T2作为时钟输入或I/O端口
1:设置P1.3/T2作为时钟输出
0DCEN递减计数允许位
0:禁止定时器2作为递增/递减计数器,定时器2仅作为递增计数器
1:允许定时器2作为递增/递减计数器

3. 工作方式0

(1)16位捕获说明

16位的捕获模式下,T2CON按制寄存器的EXEN2位有两个选项:

  • 0:定时器2作为16位定时器或计数器,如果ET2被允许,定时器2能设置TF2溢出产生一个中断;
  • 1:定时器操作与上相同,另外在外部输入T2EX上的下降沿也能引起在TH2和TL2中的当前值分别被捕获到RCAP2H和RCAP2L中;此外,在T2EX上的下降沿也能引起在T2CON中的EXF2被设置; 如果ET2被允许,EXF2位也像TF2一样产生一个中断。

流程框图:
在这里插入图片描述

(2)代码实现

下面的测试让TIMER2工作在16位捕获模式,系统时钟 Option 选择“内部 128kHz RC 振荡器作为振荡器 1,24MHz 内部 RC 作为振荡器 2”,如图所示:
在这里插入图片描述
测试代码:

#include "SH79F9476.h"
#include "cpu.h"
#include "intrins.h"
#include "api_ext.h"void main()
{// 时钟设置高速模式CLKCON = 0x08;Delay();CLKCON |= 0x04;// P0.0,P0.1设置为输出P0CR = 0x03;P0 = 0x00;// TIMER2 16位捕获模式// 允许所有中断IEN0 |= 0x80;// 打开定时器2中断IEN1 |= 0x04;// 检测到T2EX 引脚上一个下降沿,产生一个捕获或重载T2CON = 0x08;// 设置定时器2工作在捕获模式T2CON |= 0x01;// 设置系统时钟12分频作为定时器时钟源T2MOD = 0x00;TL2 = 0x00;TH2 = 0x00;// BIT2 启动定时器T2CON |= 0x04; while(1);
}
// TIMER2的中断
void INT_TIMER2(void) interrupt 9{_push_(INSCON);Select_Bank0();// 定时器溢出if(T2CON & 0x80){// 溢出标志位清0T2CON &= 0x7F;// 翻转P0_0P0_0 = ~P0_0;}	// 检测到外部事件下降沿if(T2CON & 0x40){// 1011 1111, T2EX引脚外部事件被检测到的标志位清0T2CON &= 0xBF;// 翻转P0_1P0_1 = ~P0_1;}_pop_(INSCON);
}

测试代码中启动 T2EX(P1_1) 下降沿捕捉功能;全速运行后,T2EX(P1_1)口灌 1kHz 座号,观察:

  • P1_1 的下降沿 P0_1 状态会发生改变,频率为 500Hz。
  • P0_0 频率1000/0xFFFF(即65535),约为15.259Hz。

输入信号:
在这里插入图片描述

P0_1输出信号:
在这里插入图片描述
P0_0输出信号:
在这里插入图片描述

4. 工作方式1

(1)16位自动重载定时器说明

在16位自动重载方式下,定时器2可以被选为递增计数或递减计数。这个功能通过T2MOD中的DCEN位(递减计数允许)选择。

系统复位后,DCEN位复位值为0,定时器2默认递增计数。当设置DCEN时,定时器2递增计数或递减计数取决于T2EX引脚上的电平。

当DCEN = 0,通过在T2CON中的EXEN2位选择两个选项。
  • 如果EXEN2 = 0,定时器2递增到0FFFFH,在溢出后置起TF2位,同时定时器自动将用户软件写好的寄存器RCAP2H和
    RCAP2L的16位值装入TH2和TL2寄存器。
  • 如果EXEN2 = 1,溢出或在外部输入T2EX上的下降沿都能触发一个16位重载,置起EXF2位。如果ET2被使能,TF2和EXF2
    位都能产生一个中断。
    在这里插入图片描述
设置DCEN位允许定时器2递增计数或递减计数。当DCEN = 1时,T2EX引脚控制计数的方向,而EXEN2控制无效。
  • T2EX置1可使定时器2递增计数。定时器向0FFFFH溢出,然后设置TF2位。溢出也能分别引起RCAP2H和RCAP2L上的16
    位值重载入定时器寄存器。
  • T2EX清0可使定时器2递减计数。当TH2和TL2的值等于RCAP2H和RCAP2L的值时,定时器溢出。置起TF2位,同时0FFFFH
    重载入定时器寄存器。

无论定时器2溢出,EXF2位都被用作结果的第17位。在此工作方式下,EXF2不作为中断标志。

(2)代码实现

下面代码示例中,系统时钟 Option 选择“内部 128kHz RC 振荡器作为振荡器 1,24MHz 内部 RC 作为振荡器 2”,启动自动重载功能;
程序启动后,在P0_0引脚输出1k频率方波。
P0 端口翻转一次的时间为:
t = (0xFFFF-TH2TL2)1/24 us。
计算频率为: 1/(t
2) Hz

#include "SH79F9476.h"
#include "cpu.h"
#include "intrins.h"
#include "api_ext.h"void main()
{// 时钟设置高速模式CLKCON = 0x08;Delay();CLKCON |= 0x04;// P0.0,P0.1设置为输出P0CR = 0x03;P0 = 0x00;// 允许所有中断IEN0 |= 0x80;// 打开定时器2中断 IEN1 |= 0x04;// 设置定时器工作在重载模式,忽略T2EX引脚检测T2CON = 0;    // 选择定时器为递增定时器,时钟源为系统时钟(未使用1/12分频)T2MOD = 0x80; // 这里 0xD11F递增到0xFFFF溢出,差值12000,下面公式里24是频率24M// 定时12000*1/24=500usTL2 = 0x1F;   TH2 = 0xD1;// 重载计数器 ValueRCAP2L = 0x1F; RCAP2H = 0xD1;// 启动定时器T2CON |= 0x04; while (1);
}
// TIMER2的中断
void INT_TIMER2(void) interrupt 9
{_push_(INSCON);Select_Bank0();// 定时器溢出if (T2CON & 0x80){// 溢出标志位清0T2CON &= 0x7F;// 翻转P0_0P0_0 = ~P0_0;}// 检测到外部事件下降沿if (T2CON & 0x40){// 1011 1111, T2EX引脚外部事件被检测到的标志位清0T2CON &= 0xBF;// 翻转P0_1P0_1 = ~P0_1;}_pop_(INSCON);
}

在这里插入图片描述

5. 工作方式2 可编程时钟输出

(1)功能介绍

T2端口可以编程输出50%的占空比时钟周期。清C/T2位和置T2OE位,使定时器2作为时钟发生器。TR2位启动和中止定时器。

时钟频率为:
F = 1 2 ∗ 2 ∗ f S Y S 65536 − [ R C A P 2 H , R C A P 2 L ] F = \frac{1}{2*2} * \frac{f_{SYS}}{65536-[RCAP2H,RCAP2L]} F=22165536[RCAP2H,RCAP2L]fSYS

定时器2溢出不产生中断,所以定时器2可以作时钟输出。

功能框图:
在这里插入图片描述

(2)软件实现

下面示例中,系统时钟 Option 选择“内部 128kHz RC 振荡器作为振荡器 1,24MHz 内部 RC 作为振荡器 2”。

#include "SH79F9476.h"
#include "cpu.h"
#include "intrins.h"
#include "api_ext.h"void main()
{// 时钟设置高速模式CLKCON = 0x08;Delay();CLKCON |= 0x04;// P0.0,P0.1设置为输出P0CR = 0x03;P0 = 0x00;// 关闭定时器2中断IEN1 &= 0xFB; T2CON = 0;// P13作为T2输出T2MOD = 0x82;  // 系统时钟为24M,可产生100Hz的时钟      f=(1/4)*(Fsys/(65536-[RCAP2H,RCAP2L]))RCAP2L = 0xA0; RCAP2H = 0x15;TL2 = 0xA0;TH2 = 0x15;// 启动定时器T2CON |= 0x04; while (1);
}
// TIMER2的中断
void INT_TIMER2(void) interrupt 9
{_push_(INSCON);Select_Bank0();// 定时器溢出if (T2CON & 0x80){// 溢出标志位清0T2CON &= 0x7F;// 翻转P0_0P0_0 = ~P0_0;}// 检测到外部事件下降沿if (T2CON & 0x40){// 1011 1111, T2EX引脚外部事件被检测到的标志位清0T2CON &= 0xBF;// 翻转P0_1P0_1 = ~P0_1;}_pop_(INSCON);
}

程序运行后,T2 输出口(P1_3)输出 100Hz 频率时钟。
输出波形如下图所示:
在这里插入图片描述

三、其它定时器介绍

1. 定时器3

定时器3是16位自动重载定时器,通过两个数据寄存器TH3和TL3访问,由T3CON寄存器控制。IEN0寄存器的ET3位置1允许定时器3中断。

定时器3只有一种工作方式: 16位自动重载计数器/定时器。

在这里插入图片描述
代码示例:

  IEN0 |= 0xA0;     //打开定时器3中断_push_(INSCON);Select_Bank1();T3CON = 0x02;	  //外部32.768kHz/128kHz为时钟源,1分频//配置定时器的初值为0xfffe,溢出时间为2个128kHz时钟TL3 = 0xfe;		 TH3 = 0xff;T3CON |=0x04;  //启动定时器3_pop_(INSCON);void INT_TIMER3(void) interrupt 5
{ _push_(INSCON);Select_Bank0();P0_0 = ~P0_0;_pop_(INSCON);   
}

系统时钟 Option 选择“内部 128kHz RC 振荡器作为振荡器 1,24MHz内部 RC 作为振荡器 2”,全速运行后,T3 时钟为低频 128k 时钟,P0_0 引脚输出 32k 频率方波。

2. 定时器4

定时器4是16位自动重载定时器。通过两个数据寄存器TH4和TL4访问,由T4CON寄存器控制。IEN1寄存器的ET4位置1允许定时器4中断。

定时器4有2种工作方式: 16位自动重载定时器和有T4边沿触发的16位自动重载定时器。

官方代码示例:

void init_timer4()
{IEN0 |= 0x84;     //EA,ET4,中断使能_push_(INSCON);Select_Bank1();#ifdef TIMER4_OUTT4CON = 0x40;	  //T4引脚输出//配置定时器的初值为0x8000,T4引脚输出周期为2*0x8000个系统时钟的方波TL4 = 0x00;		 TH4 = 0x80;#endif#ifdef TIMER4_EDGETRIGT4CON = 0x48;	//T4上升沿触发,且可以多次触发TL4 = 0x00;TH4 = 0x00;#endifT4CON |=0x02;  //启动定时器4Select_Bank0();_pop_(INSCON);
}void INT_TIMER4(void) interrupt 2
{ _push_(INSCON);Select_Bank0();P0_0 = ~P0_0;_pop_(INSCON);       
}

启用 TIMER4_OUT

系统时钟 Option 选择“内部 128kHz RC振荡器作为振荡器1,24MHz内部RC作为振荡器2”,全速运行后,时钟为系统时钟,T4引脚(P1_1)输出周期为 2.7302ms 方波。

启用 TIMER4_EDGETRIG

系统时钟 Option 选择“内部 128kHzRC 振荡器作为振荡器 1,24MHz 内部 RC 作为振荡器 2”,全速运行后:
向 T4(P1_1)输入一个上升沿,P0.0状态翻转一次;向T4 (P1_1)输入周期性的上升沿,若周期小于T4定时时间(2.7302ms),
T4 将一直处于重新计时状态,P0.0 将无波形输出;若周期大于 T4 定时时间(2.7302ms),P0.0输出方波。

3. 定时器5

定时器5是16位自动重载定时器。通过两个数据寄存器TH5和TL5访问,由T5CON寄存器控制。IEN0寄存器的ET5位置1允许定时器5中断。

定时器5有一种工作方式:16位自动重载定时器。

官方代码示例:

void init_timer5()
{IEN0 |= 0x88;     //EA, ET5_push_(INSCON);Select_Bank1();//配置定时器的初值为0xD120,溢出时间为0x2EE0个系统时钟TL5 = 0x20;		 TH5 = 0xD1;T5CON |=0x02;  //启动定时器5_pop_(INSCON);
}void INT_TIMER5(void) interrupt 3
{ _push_(INSCON);Select_Bank0();P0_0 = ~P0_0;_pop_(INSCON);       
}

系统时钟 Option 选择“内部 128kHz RC 振荡器作为振荡器 1,24MHz
内部 RC 作为振荡器 2”,运行后时钟为系统时钟,P0_0 引脚输出 1kHz 频率方波。

本文学习资源来自中颖官网芯片文档
本文代码开源地址: https://gitee.com/xundh/learn-sinowealth-51

这篇关于中颖51芯片学习3. 定时器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/887814

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

day-51 合并零之间的节点

思路 直接遍历链表即可,遇到val=0跳过,val非零则加在一起,最后返回即可 解题过程 返回链表可以有头结点,方便插入,返回head.next Code /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode() {}*

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

线性代数|机器学习-P36在图中找聚类

文章目录 1. 常见图结构2. 谱聚类 感觉后面几节课的内容跨越太大,需要补充太多的知识点,教授讲得内容跨越较大,一般一节课的内容是书本上的一章节内容,所以看视频比较吃力,需要先预习课本内容后才能够很好的理解教授讲解的知识点。 1. 常见图结构 假设我们有如下图结构: Adjacency Matrix:行和列表示的是节点的位置,A[i,j]表示的第 i 个节点和第 j 个