阿里云怎么做静态网站/湖南好搜公司seo

阿里云怎么做静态网站,湖南好搜公司seo,做类似淘宝的网站需多少资金,网站建设中企动力上海概念 GPT,全称General Purpose Timer,就是个通用定时器,取的名字奇怪了点。定时器是一定要的,要么提供给BSW去使用,要么提供给OS去使用。 配置 General GptDeinitApi控制接口Gpt_DeInit是否启用 GptEnableDisable…

概念

GPT,全称General Purpose Timer,就是个通用定时器,取的名字奇怪了点。定时器是一定要的,要么提供给BSW去使用,要么提供给OS去使用。

配置

General

GptDeinitApi控制接口Gpt_DeInit是否启用

GptEnableDisableNotificationApi控制接口Gpt_EnableNotification和Gpt_DisableNotification是否启用。

GptTimeElapsedApi控制接口Gpt_GetTimeElapsed是否启用

GptTimeRemainingApi控制接口Gpt_GetTimeRemaining是否启用

GptTimeElapsedApi控制接口Gpt_GetTimeElapsed是否启用

GptTimeRemainingApi控制接口Gpt_GetTimeRemaining是否启用

GptVersionInfoApi控制接口Gpt_GetVersionInfo是否启用

GptWakeupFunctionalityApi控制唤醒相关功能接口接口Gpt_SetMode, Gpt_EnableWakeup,Gpt_DisableWakeup和Gpt_Cbk_CheckWakeup()是否启用。

这里介绍一下定时器唤醒机制:如果硬件支持并启用,内部硬件计时器可以作为唤醒源,如果一个通道作为唤醒源,就不能用来做其他的用途。

GptDevErrorDetect开发者错误检测是PORT_DEV_ERROR_DETECT宏定义的开关,新人可以勾选,它能帮你检查出一些开发阶段的错误。老手一般不打开,因为会影响到代码的执行效率。

GptReportWakeupSource控制唤醒源报告是否启用

GptEnableDualClockMode在模式转换时启用预分频器设置,一般用不上。

GptEnablePit64启用pit 64位功能,PIT就是Periodic Interrupt Timer周期中断定时器,PIT64就是一个大点的PIT计时器,能容纳更大的tick数据,因为芯片只有32位,所以分开高32位和低32位传回来。

 

GptClockReferencePoint

这里就是在GPT模块里面创建个时钟引用,本身不创建任何东西,只是把MCU模块里面配置的时钟引用过来,作为一个基准时钟,给到GptChannelConfigSet里面的定时器去用。

GptChannelConfigSet

GptChannelConfiguration里面的才是主要的配置,每个容器就是一个通用定时器。

 

GptChannelId自己排序的号

GptHwChannel物理通用定时器通道,可以选STM(System Timer Module系统时钟模块)/GTM(Generic Timer Module通用定时器模块)/PIT(Periodic Interrupt Timer周期中断定时器)之类的。

 

  • STM(系统时钟模块):适用于系统级任务,如系统心跳或任务调度,通常与系统时钟直接相关。
  • GTM(通用定时器模块):适合需要多种功能的场景,如PWM生成、输入捕捉和比较输出,灵活性高。
  • PIT(周期中断定时器):专为生成周期性中断设计,适合需要定期执行任务的情况。

GptChannelMode定时器超时之后的行为,也就是连续计时还是一次性计时。

GptChannelTickFrequency指定定时器的频率,单位为Hz。最大不能大于下面引用的GptClockReferencePoint引用的MCU时钟,下面称为“引用的MCU时钟”。

对于STM,引用的MCU时钟除以定时器频率小于等于256。

对于RTC,引用的MCU时钟除以定时器频率只能是32或512或16384。

其他通道改这个配置值是不起作用的。

GptFreezeEnable勾选之后不能在代码运行的时候修改硬件通道。

GptEnableWakeup使能通道唤醒功能

GptNotification通用定时器的回调函数,这个函数要自己实现,动态代码只会生成个定义,不会实现出来。

GptChannelClkSrcRef选择GptClockReferencePoint里面的引用,这个引用后面会再引用到MCU的时钟源。具体GPT的时钟基础就是引用的MCU频率,在Gpt_StartTimer接口里面设置超时时间,到达超时时间就会调用回调函数。

GptWakeupSourceRef唤醒源,从ECU状态管理器里面获取。

GptDisableEcumWakeupSourceNotification通过调用EcuM_CheckWakeup接口启用/禁用EcuM通知

静态代码

Gpt_CheckWakeup检查支持唤醒的GPT通道是否是唤醒事件的源,并调用ECU状态管理器服务EcuM_SetWakeupEvent,用于有效的GPT通道唤醒事件。在调用Gpt_Cbk_CheckWakeup之前,需要初始化驱动程序。

Gpt_DeInit逆初始化接口,根据硬件通道是STM/PIT/GTM/PIT1类型来操作对应的寄存器。譬如硬件通道是STM类型的,就操作STM_CR寄存器失能定时器、分频数设置为0,操作STM_CCR寄存器失能STM通道里面跟定时器相关的配置,操作STM_CMP寄存器将比较器里面的值清零,操作STM_CIR寄存器清除中断标志位。最后,无论是什么类型的硬件通道,都会把通道状态进行重置,模式设置为普通,回调函数指针清空。

Gpt_DisableWakeup禁用单个GPT通道的唤醒中断调用。实际上就是调用Gpt_LLD_DisableWakeup接口,根据硬件通道类型去失能对应通道的中断,入参是物理通道ID,需要在动态代码里面复制。

Gpt_EnableNotification开启单个GPT通道的唤醒中断调用,操作Gpt_DisableWakeup相反。

Gpt_GetTimeElapsed获取从开始计时或重新开始计时到现在的tick,实际上是调用Gpt_LLD_GetTimeElapsed接口获取当前tick返回。

Gpt_GetTimeRemaining获取现在到超时之间的tick,实际上是调用Gpt_LLD_GetTimeRemaining接口获取当前tick和超时tick进行相减后返回。

Gpt_GetVersionInfo获取版本信息,需要传入一个Std_VersionInfoType类型的结构体指针,接口会把版本信息赋值到传入的结构体里面。

Gpt_Init初始化的时候需要调用,入参是Gpt_ConfigType类型的结构体指针,接口会把入参的结构体或者Gpt_InitConfigPC结构体里面的内容赋值给全局结构体Gpt_Cfg_Ptr,这个结构体会在Gpt_LLD_SetSleepMode等GPT相关的操作函数里面使用到。

Gpt_SetMode设置GPT的模式,只有GPT_MODE_NORMAL和GPT_MODE_SLEEP可以选。如果是GPT_MODE_NORMAL,调用Gpt_LLD_SetNormalMode接口,有回调函数就使能回调函数,使能定时器。如果是GPT_MODE_SLEEP,调用Gpt_LLD_SetSleepMode,停止定时器并失能,有回调函数失能回调函数。并且在执行过程中调用Gpt_Schm_ProtectResource和Gpt_Schm_UnprotectResource保护GPT的执行。

Gpt_StartTimer启动定时器,入参为GPT通道和超时值,单位为tick。先调用Gpt_LLD_CheckStartTimeoutValue检查超时值是否合理,再调用Gpt_LLD_StartTimer开始计时。并且在执行过程中调用Gpt_Schm_ProtectResource和Gpt_Schm_UnprotectResource保护GPT的执行。

Gpt_StopTimer停止定时器,调用Gpt_LLD_StopTimer暂停计时。并且在执行过程中调用Gpt_Schm_ProtectResource和Gpt_Schm_UnprotectResource保护GPT的执行。

Gpt_DisableNotification失能定时器函数回调机制。

Gpt_DisableNotification_Pit64失能Pit64的回调机制,其实就是清除PIT1_TCTRL寄存器。并且在执行过程中调用Gpt_Schm_ProtectResource和Gpt_Schm_UnprotectResource保护GPT的执行。

介绍到这里,需要注意一件事情,就是启动定时器之前,如果有回调函数,就要先使能回调机制。暂停定时器的时候,如果有回调函数,就要失能回调机制,放在暂停定时器的前还是后都可以。

Gpt_EnableNotification_Pit64使能Pit64的回调机制

Gpt_EnableWakeup_Pit64使能PIT64的唤醒功能

Gpt_GetTimeElapsed_Pit64获取PIT64从开始计时或重新开始计时到现在的tick

Gpt_GetTimeRemaining_Pit64获取PIT64计时器离超时还有多久的tick

Gpt_StartTimer_Pit64启动PIT64计时器

Gpt_StopTimer_Pit64暂停PIT64计时器

动态代码

GPT_GTM_TOMx_CH_y_ISR_USED,其中x和y都是可变的数字,当你选择的GPT通道为GTM的,就会出现这类定义,这类定义会将动态代码里面的ISR(Gpt_TOM_x_CHy_CHz_ISR);接口编译进来,其中xyz都是可变数字。其实就是开启一个TOM的中断,并且把该接口实现,该接口本质上就是调用Gpt_Gtm_LLD_ProcessInterrupt接口执行产生中断时候的动作,譬如重载、调用回调函数之类的。

其他的GTM和STM、PIT也类似。

Gpt_InitChannelPC_1数组里面有每一个GPT的初始配置信息,用来给Gpt_Init初始化的。

 

 

 

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

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

相关文章

IDE集成开发环境MyEclipse中安装SVN

打开Myeclipse的help菜单----install from site 点击add弹出对话框 在输入框中输入对应内容 http://subclipse.tigris.org/update_1.10.x 点击OK之后,会刷新出两个选项,需要选中的 点击next,出现许可的时候选中同意,一直结束等…

服务器CPU微架构

1、微架构图 前端:预解码、解码、分支预测、L1指令缓存、指令TLB缓存 后端:顺序重排缓存器ROB处理依赖,调度器送到执行引擎 执行引擎:8路超标量,每一路可以进行独立的微操作处理 Port0、1、5、6支持整数、浮点数的加…

SpringBoot调用DeepSeek

引入依赖 <dependency><groupId>io.github.pig-mesh.ai</groupId><artifactId>deepseek-spring-boot-starter</artifactId><version>1.4.5</version> </dependency>配置 deepseek:api-key: sk-******base-url: https://api.…

【前端基础】Day 9 PC端品优购项目

目录 1. 品优购项目规划 1.1 网站制作流程 1.2 品优购项目整体介绍 1.3 学习目的 1.4 开发工具以及技术栈 1.5 项目搭建工作 1.6 网站favicon图标 1.7 网站TDK三大标签SEO优化 2. 品优购首页制作 2.1 常见模块类命名 2.2 快捷导航shortcut制作 2.3 header制作 2.4…

OpenMCU(一):STM32F407 FreeRTOS移植

概述 本文主要描述了STM32F407移植FreeRTOS的简要步骤。移植描述过程中&#xff0c;忽略了Keil软件的部分使用技巧。默认读者熟练使用Keil软件。本文的描述是基于OpenMCU_FreeRTOS这个工程&#xff0c;该工程已经下载放好了移植stm32f407 FreeRTOS的所有文件 OpenMCU_FreeRTOS工…

NetBeans 8.2 开发 CIFLog3.5 - 创建WelcomeDemo

NetBeans 8.2 开发 CIFLog3.5 - 创建WelcomeDemo NetBeans 8.2 开发 CIFLog3.5 - 创建WelcomeDemo创建一个基于CIFLog平台的应用系统1. 下载安装CIFLog2. 授权使用3. 解决本地机器码验证错误问题4. 创建一个基于CIFLog平台的应用系统&#xff08;1&#xff09;新建项目&#xf…

MARL零样本协调之Fictitious Co-Play学习笔记

下列引用来自知乎作者Algernon 知乎link FCP作为ZSC领域两阶段训练方法的开创者 论文《Collaborating with Humans without Human Data》来自 NeurIPS 2021。这篇论文提出 Fictitious Co-Play (FCP) 来解决 ZSC 问题。论文认为&#xff0c;ZSC 的第一个重要问题是对称性&#x…

SpringBoot-模拟SSE对话交互

SpringBoot-模拟SSE对话交互 后端使用SSE进行会话&#xff0c;前端使用Html模拟大模型的问答交互->【前端】【后端】 1-学习目的 本项目代码仓库&#xff1a;https://gitee.com/enzoism/springboot_sse 1-核心知识点 1&#xff09;什么是SSE协议->客户端发起一次请求&am…

Avalonia 中文乱码

代码字体文件设置成支持中文的&#xff0c;但是编译的代码还是显示的乱码&#xff0c;原因是代码文件的文件编码格式不支持中文导致的。 如下面的2个页面一部分中文显示正常&#xff0c;一部分显示正常&#xff0c;一部分显示乱码。

国产编辑器EverEdit - 工具栏自定义及认识工具栏上的按钮

1 设置-高级-工具条 1.1 设置说明 1.1.1 工具条自定义 选择主菜单工具 -> 设置 -> 常规&#xff0c;在弹出的选项窗口中选择工具条分类&#xff0c;如下图所示&#xff1a; 左侧窗口是当前支持所有功能按钮列表(上图中居中栏)&#xff0c;右侧的窗口是当前显示在工具栏…

TMS320F28P550SJ9学习笔记2:Sysconfig 配置与点亮LED

今日学习使用Sysconfig 对引脚进行配置&#xff0c;并点亮开发板上的LED4 与LED5 我的单片机开发板平台是 LAUNCHXL_F28P55x 我是在上文描述的驱动库C2000ware官方例程example的工程基础之上进行添加功能的 该例程路径如下&#xff1a;D:\C2000Ware_5_04_00_00\driverlib\f28p…

人机交互革命:从触屏到脑波的13维战争

人机交互革命&#xff1a;从触屏到脑波的13维战争 一、交互维度大爆炸&#xff1a;重新定义人机沟通边界 当ChatGPT开始解析你的微表情&#xff0c;当Neuralink芯片能读取皮层信号&#xff0c;人机交互已突破【键鼠】的次元壁。我们正经历人类史上最大规模的感官革命&#xff…

使用Qt调用HslCommunication(C++调用C#库)

使用C/CLI 来调用C#的dll 任务分解&#xff1a; 1、实现C#封装一个调用hsl的dll&#xff1b; 2、实现C控制台调用C#的dll库&#xff1b; 3、把调用C#的dll用C再封装为一个dll&#xff1b; 4、最后再用Qt调用c的dll&#xff1b; 填坑&#xff1a; 1、开发时VS需要安装CLI项目库…

maven高级-03.继承与聚合-版本锁定

一.版本锁定 在maven中&#xff0c;父工程的pom文件中通过<dependencyManagement>来统一管理依赖的版本。 注意&#xff1a; <dependencyManagement>仅仅管理依赖的版本号&#xff0c;并不进行依赖的注入。如果要进行依赖注入还是要使用<dependencies>注解。…

postman请求后端接受List集合对象

后端集合 post请求&#xff0c;即前端请求方式

软件测试人员在工作中如何运用Linux?

软件测试的小伙们就会明白会使用Linux是多么重要的一件事&#xff0c;工作时需要用到&#xff0c;面试时会被问到&#xff0c;简历中需要写到。 对于软件测试人员来说&#xff0c;不需要你多么熟练使用Linux所有命令&#xff0c;也不需要你对Linux系统完全了解&#xff0c;你只…

数据结构秘籍(二)图(含图的概念、存储以及图的两大搜索)

1 引言 线性数据结构的元素满足唯一的线性关系&#xff0c;每个元素&#xff08;初第一个和最后一个外&#xff09;只有一个直接前趋和一个直接后继。树形数据结构的元素之间有着明显的层次关系。但是图形结构的元素之间的关系是任意的。 什么是图&#xff1f; 简单来说&…

printf 与前置++、后置++、前置--、后置-- 的关系

# 前置和前置-- 先看一段代码 大家是不是认为printf输出的是 2 3 3 2 1 1 但是实际输出的是 3 3 3 1 1 1 在这两行printf函数代码里&#xff0c;编译器会先计算 a 和 --a 的值&#xff0c;然后再 从右向左 开始输出。 printf函数中&#xff0c;如果有多个…

永磁同步电机无速度算法--反电动势观测器

一、原理介绍 在众多无位置传感器控制方法中&#xff0c;低通滤波反电势观测器结构简单&#xff0c;参数整定容易&#xff0c;易于编程实现。但是该方法估计出的反电势会产生相位滞后&#xff0c;需要在估计永磁同步电机转子位置时进行了相位补偿。 二、仿真模型 在MATLAB/si…

大语言模型揭秘:从诞生到智能

引言 在人工智能飞速发展的今天&#xff0c;大语言模型&#xff08;Large Language Models, LLMs&#xff09;无疑是技术领域最耀眼的明星之一。它们不仅能够理解人类的自然语言&#xff0c;还能生成流畅的文本&#xff0c;甚至在对话、翻译、创作等任务中表现出接近人类的智能…