完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
1. CPU利用率统计的方法 当前CPU利用率的统计,就是在相同时间内,统计CPU在不调度的情况下和CPU在调度情况下的占用时间比例,得出CPU的空闲比例;那CPU占用率就等于(1 - 空闲率)。 2. CPU利用率统计的实现 2.1 打开rtconfig.h文件,切换到Configuration Wizard窗口,将Basic Configuration中的OS tick per second值修改为100、勾选Hook Configuration中的子选项using idle hook配置,如下图所示: 图1:rtconfig.h配置 2.2 添加CPU占用率统计的实现代码: /* Private define -----------------------------------------------------------*/ #define MM32_CPU_USAGE_TICK 10 #define MM32_CPU_USAGE_LOOP 100 /* Private variables --------------------------------------------------------*/ rt_uint8_t mm32_cpu_usage_integer = 0; rt_uint8_t mm32_cpu_usage_decimal = 0; rt_uint32_t mm32_cpu_usage_count = 0; /****************************************************************************** * @Brief * @param * @retval * @attention ******************************************************************************/ void mm32_cpu_usage_hook(void) { volatile rt_tick_t tick = 0; volatile rt_uint32_t count = 0; volatile rt_uint32_t loop = 0; if(mm32_cpu_usage_count == 0) { rt_enter_critical(); tick = rt_tick_get(); while((rt_tick_get() - tick) < MM32_CPU_USAGE_TICK) { mm32_cpu_usage_count++; loop = 0; while(loop < MM32_CPU_USAGE_LOOP) { loop++; } } rt_exit_critical(); } count = 0; tick = rt_tick_get(); while((rt_tick_get() - tick) < MM32_CPU_USAGE_TICK) { count++; loop = 0; while(loop < MM32_CPU_USAGE_LOOP) { loop++; } } /* Calculate MM32 CPU Usage */ if(count < mm32_cpu_usage_count) { count = mm32_cpu_usage_count - count; mm32_cpu_usage_integer = (count * 100) / mm32_cpu_usage_count; mm32_cpu_usage_decimal = ((count * 100) % mm32_cpu_usage_count) * 100 / mm32_cpu_usage_count; } else { mm32_cpu_usage_count = count; mm32_cpu_usage_integer = 0; mm32_cpu_usage_decimal = 0; } } /****************************************************************************** * @brief * @param * @retval * @attention ******************************************************************************/ void mm32_cpu_usage_get(rt_uint8_t *integer, rt_uint8_t *decimal) { RT_ASSERT(integer != RT_NULL); RT_ASSERT(decimal != RT_NULL); *integer = mm32_cpu_usage_integer; *decimal = mm32_cpu_usage_decimal; } 2.3 添加测试线程代码,并将CPU利用率的钩子函数设置为IDLE钩子函数,在其中一个线程中读取并打印当前的CPU利用率: /* Private define -----------------------------------------------------------*/ #define MM32_THREAD_STACK_SIZE 512 #define MM32_THREAD_PRIORITY 5 #define MM32_THREAD_TIMESLICE 10 /* Private variables --------------------------------------------------------*/ static rt_thread_t mm32_thread1 = RT_NULL; static char mm32_thread2_stack[1024]; static struct rt_thread mm32_thread2; /****************************************************************************** * @brief * @param * @retval * @attention ******************************************************************************/ void mm32_thread1_entry(void *parameter) { rt_uint8_t integer = 0; rt_uint8_t decimal = 0; /* Init LEDs GPIO */ BSP_LED_Init(); while(1) { /* Toggle LED1~LED2 status */ BSP_LED1_TOGGLE(); BSP_LED2_TOGGLE(); mm32_cpu_usage_get(&integer, &decimal); rt_kprintf("MM32 CPU Usage : %d.%d%rn", integer, decimal); /* Delay 500ms */ rt_thread_mdelay(1000); } } /****************************************************************************** * @brief * @param * @retval * @attention ******************************************************************************/ void mm32_thread2_entry(void *parameter) { while(1) { /* Toggle LED3~LED4 status */ BSP_LED3_TOGGLE(); BSP_LED4_TOGGLE(); /* Delay 250ms */ rt_thread_mdelay(250); } } /****************************************************************************** * @brief * @param * @retval * @attention ******************************************************************************/ int main(void) { mm32_thread1 = rt_thread_create("thread1", mm32_thread1_entry, RT_NULL, MM32_THREAD_STACK_SIZE, MM32_THREAD_PRIORITY, MM32_THREAD_TIMESLICE); if(mm32_thread1 != RT_NULL) { rt_thread_startup(mm32_thread1); } rt_thread_init(&mm32_thread2, "thread2", mm32_thread2_entry, RT_NULL, &mm32_thread2_stack[0], sizeof(mm32_thread2_stack), MM32_THREAD_PRIORITY - 1, MM32_THREAD_TIMESLICE); rt_thread_startup(&mm32_thread2); /* Set Idle Thread Hook */ rt_thread_idle_sethook(mm32_cpu_usage_hook); return 0; } 3. 结果验证 编译软件工程无误后,下载代码到芯片;在串口终端工具中我们可以看到当前两个LED灯闪烁线程对于CPU的利用率情况: |
|
相关推荐
|
|
只有小组成员才能发言,加入小组>>
2256个成员聚集在这个小组
加入小组灵动微电子MM32全系列MCU产品应用手册,库函数和例程和选型表
11920 浏览 3 评论
【MM32 eMiniBoard试用连载】+基于OLED12864的GUI---U8G2
6015 浏览 1 评论
【MM32 eMiniBoard试用连载】移植RT-Thread至MM32L373PS
11149 浏览 0 评论
【MM32 eMiniBoard测评报告】+ 开箱 + 初探
4615 浏览 1 评论
灵动微课堂(第106讲) | MM32 USB功能学习笔记 —— WinUSB设备
4351 浏览 1 评论
[MM32软件] MM32F002使用内部flash存储数据怎么操作?
1576浏览 1评论
889浏览 0评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-1-13 03:41 , Processed in 0.839907 second(s), Total 69, Slave 52 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号