博客
关于我
基于 STM32CubeMX 添加 RT-Thread 操作系统组件(十七)- CPU 利用率统计
阅读量:635 次
发布时间:2019-03-12

本文共 1175 字,大约阅读时间需要 3 分钟。

如何在STM32CubeMx中使用RT-Thread操作系统(单线程内存管理)

一、STM32CubeMx配置

在开始使用STM32CubeMx之前,您需要对其进行基本配置。如下操作完成硬件配置:

  • 打开CubeMx工具

    启动STM32CubeMx并选择相应的开发板,完成_initialization_过程。

  • 选择正确的板子和芯片

    在设备管理中,确保你选择了正确的开发板和对应的芯片型号。

  • 完成系统初始化

    按照引导ados中 completesystem initialization_的详细步骤,完成系统硬件配置。

  • 二、KEIL IDE配置

    在完成硬件配置后,进入KEIL IDE进行软件配置:

  • 创建一个空工程

    在KEIL中创建一个新项目,选择对应的板子和芯片型号。

  • 添加RT-Thread包含文件

    在APPLICATION/USER文件夹中添加ROOT/rtthread.h和ROOT/rthw.h文件。

  • 导入示例代码

    将rtthread\examples\kernel\cpuusage.c添加到工程,开始编译确认无误。

  • 编写或添加自定义代码

    在CPUUSAGE.H中定义API接口,实现CPU利用率的获取和初始化功能。

  • 创建线程控制块

    在rt-thread.c中实现线程创建和控制逻辑。通过MX_RT_Thread_Init函数启动多个线程。

  • 三、实现CPU利用率的监控

  • 获取CPU利用率函数

    CPU_USAGE_GET函数用于获取系统的CPU利用率,传入回.major和 minor两个整数参数。

  • 初始化CPU利用率监控

    需要实现CPU_USAGE_INITIALIZER函数,确保系统在启动时能正确初始化监控功能。

  • 使用中断或任务管理器

    在os_tasks中添加中断或任务管理器,定期调用CPUUSAGE_GET函数获取CPU状态。

  • 四、关键文件的实现分析

  • CPUUSAGE.C实现

    包含了CPU利用率的具体测量逻辑,设计了本地变量和调度机制。

  • CPUUSAGE.H头文件

    声明了CPU使用率获取的接口和相关的全局函数。

  • RT-Thread配置文件

    在RT-Thread中配置系统时,将CPU利用率监控作为独立任务或中断处理。

  • 五、验证与测试

  • 配置串口调试

    在kservice.c中配置自定义Console输出,确保能通过串口监控程序输出结果。

  • 编译与测试

    在KEIL中完成代码编译,烧录到目标硬件,进行实际测试。

  • 观察结果

    使用终端或串口监控工具,观察CPU利用率的变化情况,确保监控系统正常工作。

  • 通过以上步骤,您可以在STM32CubeMx开发环境中成功添加和使用RT-Thread操作系统组件,实现对单线程内存管理和现代操作系统功能的轻量级支持。每一步骤的详细操作和源代码都在对应的文档和示例中提供,帮助您快速上手并完成开发任务。

    转载地址:http://mpexz.baihongyu.com/

    你可能感兴趣的文章
    nginx配置全解
    查看>>
    Nginx配置参数中文说明
    查看>>
    nginx配置域名和ip同时访问、开放多端口
    查看>>
    Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
    查看>>
    Nginx配置如何一键生成
    查看>>
    Nginx配置实例-负载均衡实例:平均访问多台服务器
    查看>>
    Nginx配置文件nginx.conf中文详解(总结)
    查看>>
    Nginx配置负载均衡到后台网关集群
    查看>>
    ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名
    查看>>
    NHibernate学习[1]
    查看>>
    NHibernate异常:No persister for的解决办法
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
    查看>>
    NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>