单片机时钟周期(可通过keil仿真了解到每条语句的运行时间)

本文是用于个人学习记录,如有出错请多多指教!

一、keil仿真语句运行时间运算

1.在keil下仿真,我们打开工程设置对话框,在target 的标签下,Xtal(MHZ),改为11.0592;(已51单片机为例)

 2.打开仿真

先看一下此刻sec所对应的的数字记录下

 然后点击要你要运行的语句(在词条语句的数字行点击,点击完成红色)

点击运行按钮

运行后的观看sec变化

即运行一条语句所花费的时间等于 423.18-422.09=1.09us

而这个时间正好是51单片机在11.0592Mhz晶振频率下,一个机器周期(重要)所花费的时间。

二、单片机周期

(1)时钟周期。也称震荡周期,定义为时钟频率的倒数(时钟周期就是单片机外接晶振的倒数,如12MHZ的晶振,它的时钟周期就是1/12us),它是单片机中最基本的、最小的时间单位。在一个时钟周期内,CPU仅完成一个最基本的动作。显然,对同一种单片机来说,时钟频率越高,单片机的工作速度越快。但是,不同单片机的内部硬件结构电路不想听,所需要的时钟频率范围也不一定相同。

(2)STM32F1举例

1. 时钟周期

看配置的系统时钟是N,时钟周期就是1/N,例如103配置sysclk为72M,时钟周期就是1/72M = 0.01389us。

2. 机器周期
在计算机中,常把一条指令的执行过程划分为若干个阶段,每一个阶段完成一项工作。每一项工作称为一个基本操作,完成一个基本操作所需要的时间称为机器周期,是最小衡量单位。

对于51单片机,一个机器周期等于12个时钟周期。

3. 指令周期
1. 用C语言写的程序,会被转换成一条一条的指令,不同的指令执行的时间不同。

2. 简单指令需要一个机器周期,复杂指令可能需要两个或两个以上的机器周期。

3. stm32中1.25 DMIPS/MHz,就是1Mhz的频率,每秒钟可以执行1.25M指令。72M,那么就是72*1.25。所以执行一条指令的时间:1/90us=0.011us=11ns

4. 指令分为单指令和多指令。

举例:

比如C语言编写的一条代码,这条代码对应3条指令,这里比如是单指令,每条指令又对应几个机器周期,一个机器周期又对应几个时钟周期。

备注:单位从小到大:时钟周期<机器周期<指令周期
 

在STM32F103微控制器中,一个机器周期(Machine Cycle)通常指一个指令的执行需要经过的最小时间单位。大多数指令的机器周期为1个或者多个时钟周期。具体而言,STM32F103微控制器内置的ARM Cortex-M3处理器中,许多指令的机器周期为1到3个时钟周期

总结:一条代码语句会被划分为几个指令,每个指令执行时间不固定,每个指令指令过程有划分为若干个阶段,每个阶段完成一个基本操作,这个基本操作位一个机器周期,所以指令周期不固定。

那么机器周期等于多少个时钟周期呢,stm32不固定可能1-3个时钟周期。

51单片机则一个机器周期固定位12个时钟周期。

Keil5是一款常用的嵌入式开发工具,对于LED灯闪烁程序,我们通常会使用它编写C语言或汇编语言的代码。下面是一个简单的示例,演示如何在Keil5中创建一个LED灯周期性闪烁的项目: 1. **新建工程**:打开Keil uVision IDE,选择"New -> Project",选择适合的硬件平台,如STM32或AVR。 2. **添加源文件**:在项目管理器中添加一个新的C或汇编源文件,比如`main.c`。 3. **配置LED设置**:在`main.c`中,首先需要包含头文件并定义LED的GPIO口。例如,假设我们的LED连接到PA0引脚,可以这样初始化: ```c #include "stm32f10x.h" GPIO_InitTypeDef GPIO_InitStructure; GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; //推挽输出 GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_Init(GPIOA, &GPIO_InitStructure); ``` 4. **闪烁函数**:编写一个定时器中断服务程序,让LED每隔一定时间改变状态(点亮或熄灭),例如使用Delay_ms函数加上中断延迟: ```c void delay_ms(uint32_t time) { uint32_t start_time = HAL_GetTick(); while ((HAL_GetTick() - start_time) < time); } void TIM_IRQHandler(void) { static uint8_t led_state = 0; // 状态变量 if (led_state == 0) { // LED熄灭 GPIO_SetBits(GPIOA, GPIO_Pin_0); // 高电平关闭LED led_state = 1; } else { // LED点亮 GPIO_ResetBits(GPIOA, GPIO_Pin_0); // 低电平点亮LED led_state = 0; } // 更新定时器间隔,这里仅做演示,实际应用需考虑定时器配置 HAL_Delay(500); // LED闪烁频率(毫秒) } ``` 5. **启用中断和定时器**:在主函数`int main()`中,注册TIM中断、开启中断,并启动定时器。 6. **编译和下载**:设置好目标板的连接方式,点击"Build"生成HEX文件,然后通过"Programmers"选项将程序烧录到板子上。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值