专为嵌入式系统设计的轻量级框架
专今天分享一个开源的、专为嵌入式系统设计的轻量级框架。开源地址:https://gitee.com/MacRsh/mr-librarymr-library简介MR 框架是专为嵌入式系统设计的轻量级框架。充分考虑了嵌入式系统在资源和性能方面的需求。通过提供标准化的设备管理接口,极大简化了嵌入式应用开发的难度,帮助开发者快速构建嵌入式应用程序。框架为开发者提供了标准化的开启(open)、关闭(clos
专今天分享一个开源的、专为嵌入式系统设计的轻量级框架。
开源地址:
https://gitee.com/MacRsh/mr-library
mr-library简介
MR 框架是专为嵌入式系统设计的轻量级框架。充分考虑了嵌入式系统在资源和性能方面的需求。通过提供标准化的设备管理接口,极大简化了嵌入式应用开发的难度,帮助开发者快速构建嵌入式应用程序。
框架为开发者提供了标准化的开启(open)、关闭(close)、控制(ioctl)、读(read)、写(write) 等接口。它将应用程序与底层硬件驱动进行解耦。应用程序无需了解驱动的实现细节。
当硬件发生改变时,只需要适配底层驱动,应用程序就可以无缝迁移到新硬件上。这大大提高了软件的可重用性和应对新硬件的可扩展性。
关键特性
-
标准化的设备访问接口
-
应用程序和驱动开发解耦
-
简化底层驱动和应用程序开发
-
轻量易上手,资源占用低
-
模块化设计,各部分解耦合并独立开发,极低的硬件迁移成本
-
支持在裸机环境和操作系统环境下使用
主要组成
-
设备框架:提供设备访问标准接口
-
内存管理:动态内存管理
-
工具:链表、队列、平衡树等常用数据结构
-
各类功能组件
标准化设备接口
设备的所有操作都可通过以下接口实现:
| 接口 | 描述 |
|---|---|
| mr_dev_register | 注册设备 |
| mr_dev_open | 打开设备 |
| mr_dev_close | 关闭设备 |
| mr_dev_ioctl | 控制设备 |
| mr_dev_read | 从设备读取数据 |
| mr_dev_write | 向设备写入数据 |
示例:
struct mr_spi_dev spi_dev;
int main(void)
{
/* 注册SPI10设备(CS低电平有效)到SPI1总线上 */
mr_spi_dev_register(&spi_dev, "spi1/spi10", 0, MR_SPI_CS_ACTIVE_LOW);
/* 打开SPI1总线下的SPI10设备 */
int ds = mr_dev_open("spi1/spi10", MR_OFLAG_RDWR);
/* 发送数据 */
uint8_t wr_buf[] = {0x01, 0x02, 0x03, 0x04};
mr_dev_write(ds, wr_buf, sizeof(wr_buf));
/* 接收数据 */
uint8_t rd_buf[4] = {0};
mr_dev_read(ds, rd_buf, sizeof(rd_buf));
/* 关闭设备 */
mr_dev_close(ds);
}
配置工具
MR 提供 Kconfig 可视化配置工具,开发者无需深入了解源代码即可进行配置。
Kconfig 会根据配置文件自动生成配置选项界面。开发者可以通过简单的操作来选择需要启用的功能组件和设置相关参数。
通过修改参数,快速裁剪所需功能。配置完成后通过 Python 脚本自动生成配置文件。
目录结构
| 名称 | 描述 |
|---|---|
| bsp | 板级支持包 |
| components | 组件 |
| device | 设备文件 |
| document | 文档 |
| driver | 驱动文件 |
| include | 库头文件 |
| source | 库源文件 |
| Kconfig | 配置文件 |
| kconfig.py | 自动配置脚本 |
| LICENSE | 许可证 |
开始使用
配置 Kconfig 环境
注:Kconfig 并非必须的,但是推荐使用(安装和配置非常快捷,后续教程也是以应用 Kconfig 为例)。
-
验证系统是否安装Python环境。在命令行中运行
python --version检查Python版本(Kconfig依赖于python,若无python环境请自行安装)。 -
在命令行中使用所示命令安装
Kconfig:python -m pip install windows-curses python -m pip install kconfiglib -
在命令行中运行
menuconfig -h验证安装是否成功。
将框架导入工程
-
从
Gitee或Github仓库下载最新版本源码到本地。 -
将源码导入到您工程所在的目录。以STM32工程为例:
工程目录 -
如使用的芯片已经做了
BSP适配请参考芯片对应BSP中的配置教程,完成BSP配置。 -
移除不需要的文件
bsp、document、module目录(如不需要GIT也可以移除.git文件删除)。完成后,目录结构如下所示:
工程目录1 -
将文件加入到IDE中(大部分IDE都能自动识别工程路径下的文件,无需进行此步骤)。以
keil为例:
工程目录Keil 添加
source、device、driver目录下的所有文件。
配置菜单选项
-
在
mr-library目录下打开命令行工具,运行menuconfig进行菜单配置。
工程目录2 注:当添加对应芯片驱动的后,将显示
Device configure和Driver configure。对应Driver configure请参考BSP下教程。 -
选中
Device configure回车进入菜单,按照需要配置功能。
工程目录3 -
配置完成后,按
Q退出菜单配置界面,按Y保存配置。
生成配置文件
-
在
mr-library目录下打开命令行工具,运行python kconfig.py,自动生成配置文件mr_config.h。
添加包含路径
-
在编译器中添加
mr-library的包含路径,以keil为例:
工程目录4 -
配置自动初始化(GCC环境),查找您工程下以
.ld为后缀的连接脚本文件(通常为link.ld),在脚本文件中添加代码:注:如果您的是在keil等,能够自动生成链接脚本的环境下,请跳过此步骤。/* mr-library auto init */ . = ALIGN(4); _mr_auto_init_start = .; KEEP(*(SORT(.auto_init*))) _mr_auto_init_end = .;示例:
工程目录5 -
配置GNU语法。如果您使用的是非
GCC编译器,请使能GNU语法。以keil为例:AC5:
工程目录6 AC6:
工程目录7 -
在您的工程中引入
#include "include/mr_lib.h"。 -
在
main函数中添加mr_auto_init();自动初始化函数。
先来点个灯吧
#include "include/mr_lib.h"
/* 定义LED引脚(PC13)*/
#define LED_PIN_NUMBER 45
int main(void)
{
/* 自动初始化 */
mr_auto_init();
/* 打开PIN设备 */
int ds = mr_dev_open("pin", MR_OFLAG_RDWR);
/* 设置到LED引脚 */
mr_dev_ioctl(ds, MR_CTL_PIN_SET_NUMBER, mr_make_local(int, LED_PIN_NUMBER));
/* 设置LED引脚为推挽输出模式 */
mr_dev_ioctl(ds, MR_CTL_PIN_SET_MODE, mr_make_local(int, MR_PIN_MODE_OUTPUT));
while(1)
{
/* 点亮LED */
mr_dev_write(ds, mr_make_local(uint8_t, MR_PIN_HIGH_LEVEL), sizeof(uint8_t));
mr_delay_ms(500);
mr_dev_write(ds, mr_make_local(uint8_t, MR_PIN_LOW_LEVEL), sizeof(uint8_t));
mr_delay_ms(500);
}
}
Hello World
#include "include/mr_lib.h"
int main(void)
{
/* 自动初始化 */
mr_auto_init();
/* 打开Serial-1设备 */
int ds = mr_dev_open("serial1", MR_OFLAG_RDWR);
/* 输出Hello World */
mr_dev_write(ds, "Hello World\r\n", sizeof("Hello World\r\n"));
while(1);
}
本文来源网络,免费传达知识,版权归原作者所有。如涉及作品版权问题,请联系我进行删除。
------------ END ------------

点击“阅读原文”查看更多分享。
更多推荐
所有评论(0)