小柴冲刺软考中级嵌入式系统设计师系列二、嵌入式系统硬件基础知识(5)定时器和计数器

越努力,越幸运!

兄弟们,要搬家到上海滴水湖了

职业生涯又迎来一次比较重要的变动

郑州->上海->上海临港

哈哈哈


flechazo

小柴冲刺软考中级嵌入式系统设计师系列总目录


一、硬件定时器

从硬件角度来看,定时器(Timer)和计数器(Counter)的概念可以互换,但它们在特定应用中的使用情况有所不同。定时器的基本结构及各组件的作用与可编程间隔计时器类似。系统时间由定时器/计数器产生的输出脉冲触发中断而产生,输出脉冲的周期称为“滴答”,表示发生了一次时钟中断。实时操作系统内核提供的硬件定时器管理功能包括:

初始化定时器:

  • 负责设置定时器相关寄存器、滴答间隔时间,以及挂接系统时钟中断处理程序。

维持相对时间和日历时间:

  • 相对时间是系统启动以来的时间,每发生一个滴答,系统的相对时间增加1。内核可以从实时时钟获取启动时刻的日历时间。

任务有限等待的计时:

  • 使用时间等待链组织需要延迟处理的对象(或任务)。例如,使用差分时间链,每产生一个滴答,链首对象的时间值减1;当减至0时,链首对象被激活,并从链中移除。

时间片轮换调度的计时:

  • 在时钟中断服务程序中更新当前运行任务的已执行时间。如果已执行时间等于任务的时间片,表示任务用完了分配的时间配额,需结束运行并转入就绪队列。

二、软件定时器

虽然硬件定时器管理已包括多种功能,实时内核仍需支持软件定时器管理功能,以便应用程序根据需要创建和使用软件定时器。

  • 软件定时器在创建时由用户提供定时值;当定时值减至0时,触发时间服务例程。用户可在此例程中完成所需操作。

  • 在中断服务处理程序中,需要对软件定时器的定时值进行减1操作。

  • 在无硬件看门狗的情况下,软件定时器可用于实现看门狗。在系统正常运行时,确保定时器不会到期;若进入定时器服务例程,则表示系统出现错误。

三、可编程间隔定时器

可编程间隔定时器:(Programmable Interval Timer,PIT)又称计数器,主要功能是事件计数和生成时间中断,以解决系统时间的控制问题。PIT 种类很多,但是它们的基本结构类似。可编程定时、计数器总体上由两部分组成:计数硬件和通信寄存器。

通信寄存器包含:

  • 控制寄存器

  • 状态寄存器

  • 计数初始值寄存器

  • 计数输出寄存器

典型的 PIT 原理如图 2-16 所示。

图片

操作系统通过这些寄存器控制计数硬件的工作方式,并读取当前状态和计数值等信息。

在操作系统内核初始化时,内核向定时计数器写入控制字和计数初值,计数硬件会按照设定方式对输入脉冲进行计数。计数器从初始值开始,每收到一次脉冲信号,计数器减1。当计数器减至0时,输出高电平或低电平(输出脉冲),然后重复计数,产生输出脉冲。

定时器产生的输出脉冲是操作系统时钟的硬件基础,接入中断控制器,定期产生时钟中断信号。操作系统利用时钟中断维护正常工作,每次时钟中断,时间计数变量增加1。

定时器中断速率:每秒产生的中断个数,每个中断称为一个滴答(Tick),表示一个时间单位。例如,定时器速率为1000个滴答/秒,则每个滴答表示1ms。定时器中断速率在控制寄存器中设定,取值范围与输入时钟频率有关。

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

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

相关文章

学习--图像信噪比

目录 图像信噪比 图像信噪比 图像信噪比的计算公式: 其中, M M M和 N N N分别表示图像长度和宽度上的像素数。 f ( i , j ) f(i,j) f(i,j) 和 g ( i , j ) g(i,j) g(i,j)分别是原始图像和去噪后的图像在点 ( i , j ) (i,j) (i,j)处的像素值。 信噪…

Redis_写时复制(cow)

Redis会根据配置,每隔一段时间中对Redis服务中当下的数据集进行快照。配置自动生成rdb文件,后台使用的是bgsave方式。 save 60 1000 //关闭RDB只需要将所有的save保存策略注释掉即可Redis借助操作系统提供的写时复制技术(Copy-On-Write, COW…

SYN590RL 300MHz至450MHz ASK接收机芯片IC

一般描述 SYN590RL是赛诺克全新开发设计的一款宽电压范围,低功耗,高性能,无需外置AGC电容,灵敏度达到典型-110dBm,300MHz”450MHz 频率范围应用的单芯片ASK或OOK射频接收器。 SYN59ORL是一款典型的即插即用型单片高集成度无线接收器&…

vue elementui el-table实现增加行,行内编辑修改

需求&#xff1a; 前端进行新增表单时&#xff0c;同时增加表单的明细数据。明细数据部分&#xff0c;可进行行编辑。 效果图&#xff1a; <el-card><div slot"header"><span style"font-weight: bold">外来人员名单2</span><…

代码随想录算法训练营第46期Day43

leetcode.322零钱兑换 class Solution { public: //无限个硬币->完全背包int coinChange(vector<int>& coins, int amount) {vector<int> dp(10010,INT_MAX);//dp代表的在某个数值下最小的硬币数&#xff0c;要求是最小的硬币数&#xff0c;所以初始值要尽可…

FreeSWITCH JSON API

仅举几例&#xff1a; fs_cli -x json {"command" : "status", "data" : ""} fs_cli -x json {"command" : "sofia.status", "data" : ""} fs_cli -x json {"command" : "…

面试域——技术面试准备

摘要 来到技术面试这环节有两种情况&#xff0c;其一&#xff1a;这场技术面试可能就是一个面试官KPI面试&#xff08;就是面试工作量&#xff0c;这个面试你是不可能过。&#xff09;如今的就业环境下&#xff0c;人力资源部门也是有考核指标。如果遇到这样的面试你就放平心态…

NLP实践项目1——判断推文的负面情绪

数据来源&#xff1a;https://datahack.analyticsvidhya.com/contest/linguipedia-codefest-natural-language-processing-1/?utm_sourceword-embeddings-count-word2veec&utm_mediumbloghttps://datahack.analyticsvidhya.com/contest/linguipedia-codefest-natural-lang…

FPGA开发时,什么情况下使用BRAM,什么情况下使用DRAM

DRAM&#xff1a;Distributed RAM&#xff0c;DRAM是用逻辑单元拼出来的。 BRAM&#xff1a;Block RAM&#xff0c;BRAM是fpga中定制的ram资源。 较大的存储应用&#xff0c;建议用block ram ; 零星的小ram&#xff0c;一般就用distributed ram。但这只是个一般原则&#xff0…

Linux中exec命令和xargs命令的使用

文章目录 exec基本用法选项实用示例 xargs基本用法选项实用示例 exec 在Linux系统中&#xff0c;xargs是一个非常有用的命令行工具&#xff0c;它能够将标准输入数据转化为命令行参数。xargs可以读取来自标准输入的数据&#xff0c;并将其作为参数传递给其他命令。以下是一些x…

别名联想路径,前端项目输入@/自动出提示目录和文件

如果在引入文件时&#xff0c;想要输入/后自动提示目录该如何做呢&#xff1f; 1.在项目的根目录下新增jsconfig.json文件 注意&#xff1a;一定得是根目录下&#xff0c;这个文件是个固定的名字&#xff0c;vscode在启动的时候会自动读取这个配置文件。 2.添加json格式的配置项…

反射、动态代理、SPI机制在RPC框架中应用

Java反射的理解 Java 反射机制是在运行状态中&#xff0c;对于任意一个类&#xff0c;都能够知道这个类中的所有属性和方法&#xff0c;对于任意一个对象&#xff0c;都能够调用它的任意一个方法和属性&#xff1b;这种动态获取的信息以及动态调用对象的方法的功能称为 Java 语…

【解惑】如何用python输出“1024“

要在Python中输出字符串“1024”&#xff0c;可以使用简单的 print() 函数。以下是实现这个功能的基本代码示例&#xff1a; # 输出字符串"1024" print("1024")代码解释&#xff1a; print() 函数用于将指定内容输出到控制台。在 print() 中使用双引号或…

Cesium基础-(Viewer)

1. Viewer 构造参数介绍 Cesium中的Viewer是用于显示和控制3D场景的核心组件。它提供了创建和管理3D地球模型、加载图像覆盖物、设置相机位置和方向以及处理用户输入等功能。Viewer可以看作是一个带有多种功能的可交互的三维数字地球容器&#xff0c;是任何Cesium应用程序的基…

利用Arcgis进行沟道形态分析

在做项目的时候需要学习到水文分析和沟道形态分析的学习&#xff0c;所以自己摸索着做了下面的工作和内容。如有不对请多指正&#xff01;&#xff01; 一、沟道形态分析概述 沟道形态分析是水文分析的一个重要方面&#xff0c;用于研究河流的形态和特征。沟道形态分析可以帮助…

Java 用正则表达式解析日期通配符

定时作业的执行时间配置在数据库里&#xff0c;比如“****-**-05 05:00:00”表示每个月的五日凌晨五点&#xff0c;"****-**** 03:00:00" 表示为每日的凌晨3点执行。 即根据系统的时间&#xff0c;解析两种格式 &#xff1a;1.每个月特定的一天 2.每天特定的时间 im…

python编程-模块与包

目录 一、模块 1. 模块的概念和作用 代码复用的深入理解 命名空间隔离的更多示例 2. 模块的创建和结构 变量定义的细节 函数定义的拓展 类定义的深化 3. 模块的导入和使用 import语句 from...import语句 import语句的更多注意事项 from...import语句的深入探讨 二…

C# 企业微信机器人推送消息 windows服务应用程序的使用

C# 企业微信机器人推送消息 先添加一个机器人! 然后查看机器人就可以得到一个 webhook 特别特别要注意&#xff1a;一定要保护好机器人的webhook地址&#xff0c;避免泄漏&#xff01; 然后开始写代码 &#xff0c;只需要httpPost 调用一下这个地址就可以发送消息了。 首先我…

JavaSE:16、Java IO

学习 资源1 学习资源 2 1、文件字节流 import java.io.*;import java.util.*;public class Main {public static void main(String[] args) {//try-with-resource语法,自动closetry(FileInputStream file new FileInputStream("E:/text.txt")) {System.out.prin…

Z-BlogPHP显示错误Undefined array key 0 (set_error_handler)的解决办法

今天打开博客的时候&#xff0c;意外发现页面&#xff0c;打开均显示错误&#xff1a;Undefined array key 0 (set_error_handler)。 博客程序采用的是Z-BlogPHP。百度了一圈没有找到解决办法&#xff0c;在官方论坛里也没找到解决办法。 于是开始自己排查原因。我服务器采用…