STM32笔记:使用SysTick测量程序的运行时间

原创 2015年11月18日 22:35:43

本实验用来测量延时函数(如下)的运行时间

void Delay(__IO u32 nCount)  

{
for(; nCount != 0; nCount--);

//SysTick.c


#include "SysTick.h"
 
__IO u32 TimingDelay = 0;

void SysTick_Init(void)
{
	/* SystemFrequency / 1000       1ms中断一次
	 * SystemFrequency / 100000  	10us中断一次 
	 * SystemFrequency / 1000000    1us中断一次
	 */
//	if (SysTick_Config(SystemFrequency / 100000))	// ST3.0.0库版本
	if (SysTick_Config(SystemCoreClock / 1000000))	// ST3.5.0库版本
	{ 
		/* Capture error */ 
		while (1);
	}
		// 关闭滴答定时器 
	SysTick->CTRL &= ~ SysTick_CTRL_ENABLE_Msk;
}



 void Delay(__IO u32 nCount)	 
{
	for(; nCount != 0; nCount--);
} 
/*
 * 函数名:TimingDelay_Count
 * 描述  :获取节拍程序
 * 输入  :无
 * 输出  :无
 * 调用  :在SysTick中断函数SysTick_Handler()调用
 */  
void TimingDelay_Count(void)
{

	TimingDelay++;
}

//stm32f10x_it.c 

/**
  ******************************************************************************
  * @file    Project/STM32F10x_StdPeriph_Template/stm32f10x_it.c 
  * @author  MCD Application Team
  * @version V3.5.0
  * @date    08-April-2011
  * @brief   Main Interrupt Service Routines.
  *          This file provides template for all exceptions handler and 
  *          peripherals interrupt service routine.
  ******************************************************************************
  * @attention
  *
  * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
  * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
  * TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
  * DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
  * FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
  * CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
  *
  * <h2><center>&copy; COPYRIGHT 2011 STMicroelectronics</center></h2>
  ******************************************************************************
  */

/* Includes ------------------------------------------------------------------*/
#include "stm32f10x_it.h"

/** @addtogroup STM32F10x_StdPeriph_Template
  * @{
  */

/* Private typedef -----------------------------------------------------------*/
/* Private define ------------------------------------------------------------*/
/* Private macro -------------------------------------------------------------*/

/* Private variables ---------------------------------------------------------*/


/* Private function prototypes -----------------------------------------------*/

extern void TimingDelay_Count(void);   //外部函数

/* Private functions ---------------------------------------------------------*/

/******************************************************************************/
/*            Cortex-M3 Processor Exceptions Handlers                         */
/******************************************************************************/

/**
  * @brief  This function handles NMI exception.
  * @param  None
  * @retval None
  */
void NMI_Handler(void)
{
}

/**
  * @brief  This function handles Hard Fault exception.
  * @param  None
  * @retval None
  */
void HardFault_Handler(void)
{
  /* Go to infinite loop when Hard Fault exception occurs */
  while (1)
  {
  }
}

/**
  * @brief  This function handles Memory Manage exception.
  * @param  None
  * @retval None
  */
void MemManage_Handler(void)
{
  /* Go to infinite loop when Memory Manage exception occurs */
  while (1)
  {
  }
}

/**
  * @brief  This function handles Bus Fault exception.
  * @param  None
  * @retval None
  */
void BusFault_Handler(void)
{
  /* Go to infinite loop when Bus Fault exception occurs */
  while (1)
  {
  }
}

/**
  * @brief  This function handles Usage Fault exception.
  * @param  None
  * @retval None
  */
void UsageFault_Handler(void)
{
  /* Go to infinite loop when Usage Fault exception occurs */
  while (1)
  {
  }
}

/**
  * @brief  This function handles SVCall exception.
  * @param  None
  * @retval None
  */
void SVC_Handler(void)
{
}

/**
  * @brief  This function handles Debug Monitor exception.
  * @param  None
  * @retval None
  */
void DebugMon_Handler(void)
{
}

/**
  * @brief  This function handles PendSVC exception.
  * @param  None
  * @retval None
  */
void PendSV_Handler(void)
{
}

/**
  * @brief  This function handles SysTick Handler.
  * @param  None
  * @retval : None
  */
void SysTick_Handler(void)
{
	TimingDelay_Count();	    //在S<span style="font-family: Arial, Helvetica, sans-serif;">ysTick.c文件里</span>

}

/******************************************************************************/
/*                 STM32F10x Peripherals Interrupt Handlers                   */
/*  Add here the Interrupt Handler for the used peripheral(s) (PPP), for the  */
/*  available peripheral interrupt handler's name please refer to the startup */
/*  file (startup_stm32f10x_xx.s).                                            */
/******************************************************************************/

/**
  * @brief  This function handles PPP interrupt request.
  * @param  None
  * @retval None
  */
/*void PPP_IRQHandler(void)
{
}*/

/**
  * @}
  */ 


/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/

//main.c

#include "stm32f10x.h"
#include "SysTick.h"

extern __IO u32 TimingDelay;


int main(void)
{	
	
	SysTick_Init();

	SysTick->CTRL |=  SysTick_CTRL_ENABLE_Msk;  //使能滴答定时器
	Delay(10000);   
        SysTick->CTRL &= ~SysTick_CTRL_ENABLE_Msk;
	

}


0.00355199 - 0.00005228 = 0.00349971(s) 约等于DAB,与TimingDelay几乎一致。


STM32学习笔记之测量某个函数运行时间

1. 设置Trace时的工作频率(就是当前的系统时钟,如stm32f103,f107为72MHz,f407为168M,f429为180M): 2. 进入调试状态,在一条语...
  • sinat_23338865
  • sinat_23338865
  • 2016年07月26日 21:03
  • 4253

x86、STM32(Keil MDK)环境测量一条(段)语句的执行时间小结

1. 设置Trace时的工作频率: 2. 进入调试状态,在一条语句前设置断点执行到此,再执行到另外的语句处,下面的Sec就是执行时间...
  • dijkstar
  • dijkstar
  • 2015年04月10日 20:47
  • 5191

STM32学习之:keil测量函数运行时间

1. 设置Trace时的工作频率(就是当前的系统时钟,如stm32f103,f107为72MHz,f407为168M,f429为180M): 2. 进入调试状态,在一条语...
  • Cheatscat
  • Cheatscat
  • 2018年01月12日 09:45
  • 26

stm32移植millis()记录系统开机运行时间

首先初始化RTC和millis MILLIS_Init(); //初始化RTC为1Hz,同时初始化millis MILLIS_Init() 函数的实现 void MILLIS_...
  • Aguangg_6655_la
  • Aguangg_6655_la
  • 2017年02月22日 17:32
  • 926

STM32F103R8T6_计算代码运行时间

  • 2015年06月27日 11:25
  • 221KB
  • 下载

stm32 timer 测程序的时间

最近在写用TIMER测程序的时间,suo
  • u011317784
  • u011317784
  • 2014年10月29日 17:59
  • 847

STM32的AFIO时钟什么时候需要开启

相比于普通单片机,STM32 拥有复杂的时钟系统,相应的控制器称为 RCC(Reset Clock Controller,复位与时钟控制器)。每个外设都配备了外设时钟的开关,当我们不使用某个外设时,可...
  • luckydarcy
  • luckydarcy
  • 2016年06月01日 01:23
  • 5474

STM32使用C标准库time.h里面的时间时钟函数

标准C里面已经定义好时间日期库time.h,在嵌入式里面并没有被限制使用。下面我们看一下怎样在IAR中使用time.h库。 有四个与时间相关的类型:clock_t、time_t、size_t 和 t...
  • MakeWorks
  • MakeWorks
  • 2017年10月15日 21:58
  • 392

Keil精确测量代码运行时间

在工程设置中“Debug”下,选右边硬件仿真,点下拉框选“J-LINK/J-TRACE”,再点“Setting” 在弹出窗口中“Debug”下,选“JTAG”或“SW”,在后面选好下载速率。...
  • qlexcel
  • qlexcel
  • 2017年02月21日 14:45
  • 2605

STM32F4(用SysTick实现Delay函数)

STM32F4(用SysTick实现Delay函数) 1,开发环境       1,适用芯片:STM32F4全部芯片       2,固件库:STM32F4xx_DSP_StdPeriph_Lib_...
  • u012325601
  • u012325601
  • 2017年03月05日 15:10
  • 383
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:STM32笔记:使用SysTick测量程序的运行时间
举报原因:
原因补充:

(最多只允许输入30个字)