常见泽1 发表于 2024-7-5 22:41

《嵌入式软件的时间分析》第五章软件时间分析方法-运行时间测量学习

<p>&nbsp;</p>

<p >&nbsp;</p>

<p ><span style="font-family:宋体;"><span style="font-size:16px;">软件时间分析方法这一章主要学习了运行时间的测量</span></span></p>

<p ><span style="font-family:宋体;"><span style="font-size:16px;">最古老的时间分析方法就是利用端口引脚进行运行时测量。</span></span></p>

<p ><span style="font-family:宋体;"><span style="font-size:16px;">利用示波器或者逻辑分析仪对端口引脚上的信号进行可视化和测量,来测试总执行时间。</span></span></p>

<p ><span style="font-family:宋体;"><span style="font-size:16px;">这个其实是非常常用,如果你想测量这段代码等占用的时间,最常用的就是通过这种古老的端口测量方法。</span></span></p>

<p >&nbsp;</p>

<p ><span style="font-family:宋体;"><span style="font-size:16px;">在STM32的应用中,还特地引入了SEV,这个SEV比书中举例的ATMEGA8的PORTB的配置简单很多,直接调用sev()就可以实现端口的拉高拉低,sev函数只占用一个时钟周期,假设时钟是100MHz</span></span></p>

<p >&nbsp;</p>

<p ><span style="font-family:宋体;"><span style="font-size:16px;"> &nbsp;</span></span></p>

<p >&nbsp;</p>

<p ><span style="font-family:宋体;"><span style="font-size:16px;">一个时钟周期也就是10ns,如果是STM32F4,主频接近180M,那占用的时间就更加短。参考例程</span></span></p>

<pre>
<code>GPIO_InitStruct.Pin = GPIO_PIN_10;

GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;

GPIO_InitStruct.Pull = GPIO_PULLDOWN;

GPIO_InitStruct.Speed = GPIO_SPEED_HIGH;

GPIO_InitStruct.Alternate = GPIO_AF15_EVENTOUT;

HAL_GPIO_Init(GPIOB, &amp;GPIO_InitStruct);</code></pre>

<p >&nbsp;</p>

<p ><span style="font-family:宋体;"><span style="font-size:16px;">第二种方法:</span></span></p>

<p ><span style="font-family:宋体;"><span style="font-size:16px;">不使用端口和仪器的时间测量方法</span></span></p>

<p ><span style="font-family:宋体;"><span style="font-size:16px;">端口引脚或外部测量方法并不是一直可以使用,外部测量设备有时候可能手上正好没有,就需要使用其它方便的操作方法,比如硬件定时器作为测量的基础。</span></span></p>

<p ><span style="font-family:宋体;"><span style="font-size:16px;">配置好定时器周期后,定时器值存储在测量元素的开头,在测量元素的结尾时读出这个值,这俩个值的差值就是总运行时间。</span></span></p>

<p >&nbsp;</p>

<p ><span style="font-family:宋体;"><span style="font-size:16px;">用STM32来举例</span></span></p>

<pre>
<code>start_cnt=__HAL_TIM_GET_COUNTER(&amp;TIM1_Handler); //获取定时器的值,开始计时

HAL_GPIO_WritePin(GPIOA,GPIO_PIN_1,GPIO_PIN_SET);

delay_ms(20);

HAL_GPIO_WritePin(GPIOA,GPIO_PIN_1,GPIO_PIN_RESET);      /

delay_ms(20);

end_cnt=__HAL_TIM_GET_COUNTER(&amp;TIM1_Handler);  //获取结束时的定时器的计数值</code></pre>

<p><span style="font-family:宋体;"><span style="font-size:16px;">end_cnt和start_cnt的差值就是运行的时间</span></span></p>

<p>&nbsp;</p>

combat 发表于 2024-7-6 10:23

实时系统中运行时间长度是必须要关注的

常见泽1 发表于 2024-7-6 11:16

combat 发表于 2024-7-6 10:23
实时系统中运行时间长度是必须要关注的

<p>是的,这个时间需要重点关注 很重要</p>
页: [1]
查看完整版本: 《嵌入式软件的时间分析》第五章软件时间分析方法-运行时间测量学习