网站建设的服务器/it培训班大概需要多少钱

网站建设的服务器,it培训班大概需要多少钱,网站风格什么意思,望京网站建设公司RTC实时时钟 RTC实时时钟 想记录或读取日期和事件,就可以通过操作RTC实现 RTC与BKP和PWR经常同时出现 一般情况下,VBTA是电池供电口,需要接备用电池 在BKP备份寄存器写入两个数据,然后再读出之后显示,BKP的数据&a…

RTC实时时钟

RTC实时时钟

想记录或读取日期和事件,就可以通过操作RTC实现

RTC与BKP和PWR经常同时出现

一般情况下,VBTA是电池供电口,需要接备用电池

在BKP备份寄存器写入两个数据,然后再读出之后显示,BKP的数据,需要VBAT的引脚接上备用电池来维持,才能保证断电不丢失。如果接了备用电池,BKP可以完成一些主电源掉电时,保存少量数据的任务

Unix时间戳

BKP和RTC外设结构

Unix 时间戳(Unix Timestamp)定义为从UTC/GMT的1970年1月1日0时0分0秒开始所经过的秒数,不考虑闰秒

时间戳存储在一个秒计数器中,秒计数器为32位/64位的整型变量

世界上所有时区的秒计数器相同,不同时区通过添加偏移来得到当地时间

优点:

1:简化硬件电路,在设计硬件电路的时候,直接用一个很大的秒寄存器来实现,不需要考虑进位

2:来进行一些时间间隔的计算时,非常方便

STM32中的RTC,核心的计时部分是一个32位可编程计数器

UTC/GMT

GMT(Greenwich Mean Time)格林尼治标准时间是一种以地球自转为基础的时间计量系统。它将地球自转一周的时间间隔等分为24小时,以此确定计时标准

UTC(Universal Time Coordinated)协调世界时是一种以原子钟为基础的时间计量系统。它规定铯133原子基态的两个超精细能级间在零磁场下跃迁辐射9,192,631,770周所持续的时间为1秒。当原子钟计时一天的时间与地球自转一周的时间相差超过0.9秒时,UTC会执行闰秒来保证其计时与地球自转的协调一致

时间戳函数

C语言的time.h模块提供了时间获取和时间戳转换的相关函数,可以方便地进行秒计数器、日期时间和字符串之间的转换

秒计数器数据类型:数据类型名为time_t

日期时间数据类型:类型名为struct tm

字符串数据类型:类型名为char*,就是char型数据的指针,用来指向一个表示时间的字符串

函数作用
time_t time(time_t*);获取系统时钟
struct tm* gmtime(const time_t*);秒计数器转换为日期时间(格林尼治时间)
struct tm* localtime(const time_t*);秒计数器转换为日期时间(当地时间)
time_t mktime(struct tm*);日期时间转换为秒计数器(当地时间)
char* ctime(const time_t*);秒计数器转换为字符串(默认格式)
char* asctime(const struct tm*);日期时间转换为字符串(默认格式)
size_t strftime(char*, size_t, const char*, const struct tm*);日期时间转换为字符串(自定义格式)

在这里插入图片描述

BKP与RTC外设

BKP简介

BKP(Backup Registers)备份寄存器

BKP可用于存储用户应用程序数据。当VDD(2.0-3.6V)电源被切断,他们仍然由VBAT(1.8-3.6V)维持供电。当系统在待机模式下被唤醒,或系统复位或电源复位时,他们也不会被复位

TAMPER引脚产生的侵入事件将所有备份寄存器内容清除

RTC引脚输出RTC校准时钟、RTC闹钟脉冲或者秒脉冲

存储RTC时钟校准寄存器

用户数据存储容量:

20字节(中容量和小容量)/ 84字节(大容量和互联型)

BKP基本结构

在这里插入图片描述

橙色部分可以被称为后备区域,当VDD主电源掉电时,后备区域仍然可以由VBAT的备用电池供电,当VDD主电源上电时,后备区域供电会由VBAT切换到VDD

RTC简介

RTC(Real Time Clock)实时时钟

RTC是一个独立的定时器,可为系统提供时钟和日历的功能

RTC和时钟配置系统处于后备区域,系统复位时数据不清零,VDD(2.0-3.6V)断电后可借助VBAT(1.8-3.6V)供电继续走时

32位的可编程计数器,可对应Unix时间戳的秒计数器

20位的可编程预分频器,可适配不同频率的输入时钟

可选择三种RTC时钟源:

HSE时钟除以128(通常为8MHz/128)

LSE振荡器时钟(通常为32.768KHz)

LSI振荡器时钟(40KHz)

RTC框图

在这里插入图片描述
在这里插入图片描述

RTC基本结构

在这里插入图片描述

在程序中,配置数据选择器,可以选择始终来源;配置重装寄存器,可以选择分频系数;配置32位计数器,可以进行日期时间的读写,需要闹钟的话,配置32位闹钟值即可,需要中断的话,先允许中断,再配置NVIC,最后写对应的中断函数即可

配合RTC的外部硬件电路

主要需要电池和外部低速晶振

在这里插入图片描述
在这里插入图片描述

RTC操作注意事项

执行以下操作将使能对BKP和RTC的访问:

  1. 设置RCC_APB1ENR的PWREN和BKPEN,使能PWR和BKP时钟
  2. 设置PWR_CR的DBP,使能对BKP和RTC的访问

若在读取RTC寄存器时,RTC的APB1接口曾经处于禁止状态,则软件首先必须等待RTC_CRL寄存器中的RSF位(寄存器同步标志)被硬件置1

必须设置RTC_CRL寄存器中的CNF位,使RTC进入配置模式后,才能写入RTC_PRL、RTC_CNT、RTC_ALR寄存器

对RTC任何寄存器的写操作,都必须在前一次写操作结束后进行。可以通过查询RTC_CR寄存器中的RTOFF状态位,判断RTC寄存器是否处于更新中。仅当RTOFF状态位是1时,才可以写入RTC寄存器

读写BKP与RTC

BKP代码配置步骤

第一步:开启PWR和BKP的时钟

第二步:使用PWR的一个函数,使能对BKP和RTC的访问

BKP相关库函数

void BKP_DeInit(void);

可以让BKP的数据都变成0

void BKP_TamperPinLevelConfig(uint16_t BKP_TamperPinLevel);

void BKP_TamperPinCmd(FunctionalState NewState);

用于配置TAMPER的侵入检测功能

void BKP_ITConfig(FunctionalState NewState);

中断配置,是否开启中断

void BKP_RTCOutputConfig(uint16_t BKP_RTCOutputSource);

时钟输出功能的配置,可以选择在RTC引脚上输出时钟信号,输出RTC校准时钟、RTC闹钟脉冲或者秒脉冲

void BKP_SetRTCCalibrationValue(uint8_t CalibrationValue);

设置RTC校准值,写入RTC校准寄存器

void BKP_WriteBackupRegister(uint16_t BKP_DR, uint16_t Data);

写备份寄存器,第一个参数指定要写在哪个DR里,第二个参数指定要写入的数据,是16位的整型数据

uint16_t BKP_ReadBackupRegister(uint16_t BKP_DR);

读备份寄存器,参数指定要读哪个DR,返回值就是DR里存的值

void PWR_BackupAccessCmd(FunctionalState NewState);

备份寄存器访问使能,设置PWR_CR寄存器里的DBP位

RTC初始化流程

第一步:在使用RTC外设之前,执行注意事项第一点,开启PWR和BKP的时钟,使能BKP和RTC的访问

第二步:启动RTC的时钟,使用LSE作为系统时钟,要使用RCC模块里的函数,开启LSE的时钟

第三步:配置RTCCLK这个数据选择器,指定LSE为RTCCLK,这一步函数也在RTC模块里面

第四步:调用两个等待的函数,等待同步,等待上一次操作完成

第五步:配置预分频器,给PRL重装寄存器一个合适的分频值,以确保输出给计数器的频率是1Hz

第六步:配置CNT的值,给RTC一个初始时间,需要闹钟的话可以配置闹钟值,需要中断可以配置中断

RCC相关库函数

void RCC_LSEConfig(uint8_t RCC_LSE);

配置LSE外设低速时钟

void RCC_LSICmd(FunctionalState NewState);

配置LSI内部低速时钟

void RCC_RTCCLKConfig(uint32_t RCC_RTCCLKSource);

RTCCLK配置,用来选择RTCCLK的时钟源,实际上就是配置数据选择器

void RCC_RTCCLKCmd(FunctionalState NewState);

启动RTCCLK

FlagStatus RCC_GetFlagStatus(uint8_t RCC_FLAG);

获取标志位,等待RCC有个标志位LSERDY置1之后,时钟才算启动完成,工作稳定

void RTC_ITConfig(uint16_t RTC_IT, FunctionalState NewState);

配置中断输出

void RTC_EnterConfigMode(void);

进入配置模式

void RTC_ExitConfigMode(void);

退出配置模式

uint32_t RTC_GetCounter(void);

获取CNT计数器的值

void RTC_SetCounter(uint32_t CounterValue);

写入CNT计数器的值

void RTC_SetPrescaler(uint32_t PrescalerValue);

写入预分频器,会写入到预分频器的PRL重装寄存器中,用来配置预分频器的分频系数

void RTC_SetAlarm(uint32_t AlarmValue);

写入闹钟值

uint32_t RTC_GetDivider(void);

读取预分频器中的DIV余数寄存器

void RTC_WaitForLastTask(void);

等待上次操作完成

void RTC_WaitForSynchro(void);

等待同步

代码示例

读写BKP

代码文件:main.c

#include "stm32f10x.h"                  // Device header
#include "OLED.h"
#include "Key.h"uint8_t KeyNum;//定义两个数组,一个写入,一个读出
uint16_t ArrayWrite[]={0x1234,0x5678};
uint16_t ArrayRead[2];int main(void)
{OLED_Init();Key_Init();OLED_ShowString(1,1,"W:");OLED_ShowString(2,1,"R:");//BKP的初始化//第一步:开启PWR和BKP的时钟RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR,ENABLE);RCC_APB1PeriphClockCmd(RCC_APB1Periph_BKP,ENABLE);//第二步:使能对BKP和RTC的访问PWR_BackupAccessCmd(ENABLE);while(1){//按下按键,变更一下数据,再写入到BKP中KeyNum=Key_GetNum();if(KeyNum==1){ArrayWrite[0]++;ArrayWrite[1]++;BKP_WriteBackupRegister(BKP_DR1,ArrayWrite[0]);BKP_WriteBackupRegister(BKP_DR2,ArrayWrite[1]);OLED_ShowHexNum(1,3,ArrayWrite[0],4);OLED_ShowHexNum(1,8,ArrayWrite[1],4);}//读取数据ArrayRead[0]=BKP_ReadBackupRegister(BKP_DR1);ArrayRead[1]=BKP_ReadBackupRegister(BKP_DR2);OLED_ShowHexNum(2,3,ArrayRead[0],4);OLED_ShowHexNum(2,8,ArrayRead[1],4);}
}

实时时钟

代码文件:MyRTC.c

#include "stm32f10x.h"                  // Device header
#include <time.h>//在写C语言程序中,十进制前面不要补0,比如01,09
uint16_t MyRTC_Time[]={2023,1,1,23,59,55};void MyRTC_SetTime(void);void MyRTC_Init(void)
{//第一步:开启PWR和BKP的时钟,使能BKP和RTC的访问RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR,ENABLE);RCC_APB1PeriphClockCmd(RCC_APB1Periph_BKP,ENABLE);PWR_BackupAccessCmd(ENABLE);if(BKP_ReadBackupRegister(BKP_DR1)!=0xA5A5){//第二步:开启LSE时钟,并等待LSE时钟启动完成RCC_LSEConfig(RCC_LSE_ON);//等待LSE启动完成while(RCC_GetFlagStatus(RCC_FLAG_LSERDY)!=SET);//第三步:选择RTCCLK时钟源RCC_RTCCLKConfig(RCC_RTCCLKSource_LSE);RCC_RTCCLKCmd(ENABLE);//调用等待的函数,一个是等待同步,一个是等待上一次写入操作完成RTC_WaitForSynchro();RTC_WaitForLastTask();//配置预分频器RTC_SetPrescaler(32768-1);RTC_WaitForLastTask();//设置初始时间,给32位的秒计数器RTC_SetCounter(1672588795);RTC_WaitForLastTask();MyRTC_SetTime();BKP_WriteBackupRegister(BKP_DR1,0xA5A5);}else{RTC_WaitForSynchro();RTC_WaitForLastTask();}}//写两个函数,一个是设置时间,一个是读取时间
void MyRTC_SetTime(void)
{//第一步:把数组指定的时间,填充到struct tm结构体里//第二步:使用mktime函数,得到秒数//第三步:将秒数写道RTC的CNT中//将数组的时间转换为秒数,写入到CNT中time_t time_cnt;struct tm time_date;time_date.tm_year=MyRTC_Time[0]-1900;time_date.tm_mon=MyRTC_Time[1]-1;time_date.tm_mday=MyRTC_Time[2];time_date.tm_hour=MyRTC_Time[3];time_date.tm_min=MyRTC_Time[4];time_date.tm_sec=MyRTC_Time[5];//日期时间到秒数的转换time_cnt=mktime(&time_date)-8*60*60;RTC_SetCounter(time_cnt);//写入寄存器后,需要等待操作完成RTC_WaitForLastTask();
}void MyRTC_ReadTime(void)
{//第一步:读取CNT的秒数time_t time_cnt;struct tm time_date;time_cnt=RTC_GetCounter()+8*60*60;time_date=*localtime(&time_cnt);//第三步:把time_date的时间,转移到数组里面MyRTC_Time[0]=time_date.tm_year+1900;MyRTC_Time[1]=time_date.tm_mon+1;MyRTC_Time[2]=time_date.tm_mday;MyRTC_Time[3]=time_date.tm_hour;MyRTC_Time[4]=time_date.tm_min;MyRTC_Time[5]=time_date.tm_sec;
}

main.c

#include "stm32f10x.h"                  // Device header
#include "OLED.h"
#include "MyRTC.h"int main(void)
{OLED_Init();MyRTC_Init();OLED_ShowString(1,1,"Date:XXXX-XX-XX");OLED_ShowString(2,1,"Time:XX:XX:XX");OLED_ShowString(3,1,"CNT:");OLED_ShowString(4,1,"DIV:");while(1){MyRTC_ReadTime();OLED_ShowNum(1,6,MyRTC_Time[0],4);OLED_ShowNum(1,11,MyRTC_Time[1],2);OLED_ShowNum(1,14,MyRTC_Time[2],2);OLED_ShowNum(2,6,MyRTC_Time[3],2);OLED_ShowNum(2,9,MyRTC_Time[4],2);OLED_ShowNum(2,12,MyRTC_Time[5],2);OLED_ShowNum(3,6,RTC_GetCounter(),10);OLED_ShowNum(4,6,RTC_GetDivider(),10);}
}

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

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

相关文章

C# Unity 唐老狮 No.2 模拟面试题

本文章不作任何商业用途 仅作学习与交流 安利唐老狮与其他老师合作的网站,内有大量免费资源和优质付费资源,我入门就是看唐老师的课程 打好坚实的基础非常非常重要: Unity课程 - 游习堂 - 唐老狮创立的游戏开发在线学习平台 - Powered By EduSoho 如果你发现了文章内特殊的字体…

Denoising Diffusion Implicit Models (DDIM)

因为扩散模型的正向过程可以实现跳步&#xff0c;其马尔科夫性并不重要&#xff0c;因此DDIM尝试在反向过程中也舍弃马尔科夫性的约束。在引入一个可控参数 σ t \sigma_t σt​后&#xff0c;反向过程的迭代被整理为预测 x 0 x_0 x0​后重新进行正向扩散的过程&#xff0c;扩散…

LearnOpenGL之Shader编程用算法绘画

———————————————————— 前序 ——————————————————— AndroidLearnOpenGL是本博主自己实现的LearnOpenGL练习集合&#xff1a; Github地址&#xff1a;GitHub - wangyongyao1989/AndroidLearnOpenGL: OpenGL基础及运用 系列文章&#xff…

第5章_管理策略

管理策略 如前所述&#xff0c;策略定义了在授予对对象的访问权限之前必须满足的条件。 单击 Policy &#xff08;策略&#xff09; 选项卡可查看与资源服务器关联的所有策略。 在此选项卡上&#xff0c;您可以查看以前创建的策略列表&#xff0c;以及创建和编辑策略。 要创…

Chromium_src源码

Chromium_src源码 码云上有一个OpenHarmony-TPC/chromium_src项目&#xff0c;目前已经停止维护了&#xff0c;迁移到GitCode上了&#xff0c;源代码项目地址为&#xff1a;openharmony-tpc/chromium_chrome 特此记录一下老的项目的相关软件架构 Chromium 简介 软件架构 软…

Android ObjectBox数据库使用与集成指南

ObjectBox其核心特点ObjectBox与 SQLite 和 Realm 的对比Android集成ObjectBox创建ObjectBox实体对象创建ObjectBox操作管理类OBManager在Application初始化ObjectBox插入或更新数据查询数据统计数据分页数据查询删除数据总结今天分享一套Android另一个数据库ObjectBox。Object…

013作用域

一、基本概念 C语言中&#xff0c;标识符都有一定的可见范围&#xff0c;这些可见范围保证了标识符只能在一个有限的区域内使用&#xff0c;这个可见范围&#xff0c;被称为作用域&#xff08;scope&#xff09;。 软件开发中&#xff0c;尽量缩小标识符的作用域是一项基本原…

AH表情捕捉设备:虚拟人动态表情捕捉

在虚拟人应用里&#xff0c;除了关注虚拟人能否展现流畅的肢体动作&#xff0c;其表情是否自然流畅同样关键。虚拟人作为新兴技术产物&#xff0c;广泛应用于娱乐直播、影视动画等领域。自然的表情能让虚拟人更具亲和力与真实感&#xff0c;大幅提升用户体验。 而广州虚拟动力…

pikachu

暴力破解 基于表单的暴力破解 【2024版】最新BurpSuit的使用教程&#xff08;非常详细&#xff09;零基础入门到精通&#xff0c;看一篇就够了&#xff01;让你挖洞事半功倍&#xff01;_burpsuite使用教程-CSDN博客 登录页面&#xff0c;随意输入抓包&#xff0c;发送到攻击…

C++预编译、编译、汇编、链接详解

一、准备阶段 g编译环境&#xff0c;配置好环境变量 新建一个helloworld.cpp #include <iostream> using namespace std; int main() {cout << "Hello, world!" << endl;return 0; }命令查看 g --help 二、预编译 预处理阶段对自定义和预定义…

docker使用代理的简单配置

1准备代理服务器 准备代理服务器&#xff0c;例如192.168.120.168:52209 配置docker.service文件 查看service文件的位置 systemctl status docker 编辑service文件 vim /usr/lib/systemd/system/docker.service 添加代理配置 ... [Service] Environment"HTTP_PROXY…

【FL0090】基于SSM和微信小程序的球馆预约系统

&#x1f9d1;‍&#x1f4bb;博主介绍&#x1f9d1;‍&#x1f4bb; 全网粉丝10W,CSDN全栈领域优质创作者&#xff0c;博客之星、掘金/知乎/b站/华为云/阿里云等平台优质作者、专注于Java、小程序/APP、python、大数据等技术领域和毕业项目实战&#xff0c;以及程序定制化开发…

使用esp32接入大模型(http请求)

本示例适用于所有乐鑫的esp32模组及开发板。使用串口通信和http协议。实现简单的和大模型对话要求。 话不多说直接上代码 #include <WiFi.h> #include <HTTPClient.h> #include <ArduinoJson.h>#define DEBUG 1// 替换为你的Wi-Fi网络凭据 #define WLAN_SSI…

GitHub高效搜索工具

[GitHub项目搜索工具] 一款开发者专属的星矿探测仪&#xff01; 你是否还在用stars:>1000手动筛选GitHub项目&#xff1f; 你是否经常为了找一个合适的开源库翻遍搜索结果&#xff1f; 这个工具或许能改变你的代码资源发掘方式… &#x1f31f; 痛点洞察 在GitHub的3.28亿个…

【uniapp原生】实时记录接口请求延迟,并生成写入文件到安卓设备

在开发实时数据监控应用时&#xff0c;记录接口请求的延迟对于性能分析和用户体验优化至关重要。本文将基于 UniApp 框架&#xff0c;介绍如何实现一个实时记录接口请求延迟的功能&#xff0c;并深入解析相关代码的实现细节。 前期准备&必要的理解 1. 功能概述 该功能的…

支付宝 IoT 设备入门宝典(下)设备经营篇

上篇介绍了支付宝 IoT 设备管理&#xff0c;但除了这些基础功能外&#xff0c;商户还可以利用设备进行一些运营动作&#xff0c;让设备更好的帮助自己&#xff0c;本篇就会以设备经营为中心&#xff0c;介绍常见的设备相关能力和问题解决方案。如果对上篇感兴趣&#xff0c;可以…

船舶广播系统:航行中的信息枢纽和安全保障

船舶广播系统是船舶重要的通信设备之一&#xff0c;承担着船舶内部通信、对外联络、应急广播等重要功能&#xff0c;船舶广播系统是船舶上的一种重要设备&#xff0c;它可以用于传递重要信息和指示&#xff0c;是保障船舶安全航行和乘客安全的重要设施。 船舶广播系统通常由以…

Unity插件-Mirror使用方法(一)Mirror介绍

目录 一、使用介绍 二、插件介绍 1、简述 2、核心功能与特点 基于组件的高层抽象 服务器-客户端架构 序列化与同步 可扩展性与灵活性 跨平台支持 社区与生态 3、典型应用场景 4、基本使用示例 安装 设置 NetworkManager 同步变量与 RPC 5、优缺点对比 6、为什…

企业如何挖掘数据资产价值?

本期推荐&#xff1a;挖掘数据资产价值&#xff0c;赋能企业发展&#xff0c;共28页ppt。 关注WeChat Subscription Account【智慧城市指北】&#xff0c;回复关键字“20250228数据资产”&#xff0c;获取获得本文电子版材料的方式(非无偿&#xff09;~ 篇幅限制&#xff0c;…

使用tkinter有UI方式来拷贝Excel文件

有需求使用tkinter 有用户交互界面来拷贝Excel文件&#xff0c;最后进行打包完成 代码如下&#xff0c;实现思路是先使用tkinter库选择Excel路径&#xff0c;然后保存到txt文档&#xff0c; import time import tkinter from pathlib import Path from typing import Optiona…