1.简化自动初始化宏。

2.修改callback为call。
This commit is contained in:
MacRsh
2023-11-25 00:34:07 +08:00
parent f5da3b7567
commit a637ce0a31
3 changed files with 28 additions and 219 deletions

190
README.md
View File

@@ -1,190 +0,0 @@
# 简介
**mr-library** 是一个专为嵌入式系统设计的轻量级框架,模块化的软件架构充分考虑了嵌入式系统的资源和性能要求。
通过提供标准化的设备管理等,极大地简化了嵌入式应用的开发难度,帮助开发者快速构建嵌入式应用程序。
**设备框架** 为开发者提供标准化的接口open、close、ioctl、read、write解耦应用程序与底层硬件驱动使应用开发无需硬件驱动的实现细节。
当硬件变动时,只需要适配底层驱动,上层应用可以无缝地迁移到新硬件上,大大提高了软硬件的可重用性和可扩展性。
### 应用场景
- MCU开发中硬件gpio、uart_dev、spi、i2c、pwm等标准化管理。
- RTOS实时操作系统的外挂设备框架。
- 各类Iot和智能硬件产品的快速开发。
### 项目结构
![项目结构图](https://gitee.com/MacRsh/mr-library/raw/master/document/resource/framework.png)
----------
# 设备框架
通过标准化的接口,开发者能以面向对象的方式访问硬件设备,简化开发流程。框架实现了各种常用设备的通用设备模型,开发者可快速移植到不同的硬件平台。
使用组件化和分层设备思想,可对模型自由添加裁剪,帮助开发者快速开发出高可靠、可维护的程序。
### 标准化设备接口
设备框架提供标准化的操作接口,设备的所有操作都可通过以下接口实现:
| 接口 | 描述 |
|:----------------|:--------|
| mr_device_add | 添加设备 |
| mr_device_find | 查找设备 |
| mr_device_open | 打开设备 |
| mr_device_close | 关闭设备 |
| mr_device_ioctl | 控制设备 |
| mr_device_read | 从设备读取数据 |
| mr_device_write | 向设备写入数据 |
### SPI设备使用示例
SPI设备模型实现了总线和设备的分层。在使用时开发者只需实例化对应的设备对象将其挂载至对应总线即可通过简单的读写接口访问设备无需关心底层的SPI通信细节。
模型会根据设备的参数自动配置SPI通信参数如时钟频率、SPI模式等简化配置过程。同时模型也会自动控制设备的片选信号开发者不再需要显式地控制CS管脚。
```c
/* 定义SPI设备 */
#define SPI_DEVICE0_CS_NUMBER 10
#define SPI_DEVICE1_CS_NUMBER 20
struct mr_spi_device spi_device0, spi_device1;
/* 添加SPI设备 */
mr_spi_device_add(&spi_device0, "spi10", SPI_DEVICE0_CS_NUMBER);
mr_spi_device_add(&spi_device1, "spi11", SPI_DEVICE1_CS_NUMBER);
/* 查找SPI设备 */
mr_device_t spi0_device = mr_device_find("spi10");
mr_device_t spi1_device = mr_device_find("spi11");
/* 挂载总线 */
mr_device_ioctl(spi0_device, MR_DEVICE_CTRL_CONNECT, "spi1");
mr_device_ioctl(spi1_device, MR_DEVICE_CTRL_CONNECT, "spi1");
/* 以可读可写的方式打开SPI设备 */
mr_device_open(spi0_device, MR_DEVICE_OFLAG_RDWR);
mr_device_open(spi1_device, MR_DEVICE_OFLAG_RDWR);
/* 写入数据 */
char buffer0[] = "hello";
char buffer1[] = "world";
mr_device_write(spi0_device, -1, buffer0, sizeof(buffer0) - 1);
mr_device_write(spi1_device, -1, buffer1, sizeof(buffer1) - 1);
/* 读取数据 */
mr_device_read(spi0_device, -1, buffer0, sizeof(buffer0) - 1);
mr_device_read(spi1_device, -1, buffer1, sizeof(buffer1) - 1);
/* 关闭设备 */
mr_device_close(spi0_device);
mr_device_close(spi1_device);
```
----------
# 组件
组件是一种模块化的软件构建单元,专为嵌入式系统设计。组件设计充分考虑了嵌入式系统的资源限制,通过按需选择、自由组合的概念,极大提升了资源的利用率。
每个组件都承担特定的功能或任务例如任务管理组件专注于对程序任务的管理使得裸机与RTOS程序可高效移植。开发者可自主选择需要的组件添加到项目中。
### etask组件
事件任务框架是一种用于处理异步事件和任务的编程模型。它提供了结构化的方式来管理和调度事件和任务,在并发环境中实现高效处理。
使用事件任务框架可以抽象和管理复杂的并发处理逻辑,提高代码的可维护性和可扩展性。使开发人员能够专注于事件处理逻辑,而无需关注底层的并发细节。
事件任务框架支持动态添加和移除事件任务,通过添加或替换事件任务来实现新增功能或修改业务逻辑,而无需修改其他代码。这种可插拔性使系统更灵活、能快速响应需求变化。
使用示例:
```c
/* 定义事件 */
#define EVENT_1 1234
#define EVENT_2 "event_3"
#define EVENT_3 3456
/* 定义事件回调 */
mr_err_t event1_cb(mr_etask_t etask, void *args)
{
printf("event1_cb\r\n");
return MR_ERR_OK;
}
mr_err_t event2_cb(mr_etask_t etask, void *args)
{
printf("event2_cb\r\n");
return MR_ERR_OK;
}
mr_err_t event3_cb(mr_etask_t etask, void *args)
{
printf("event3_cb\r\n");
return MR_ERR_OK;
}
/* 定义事件任务 */
struct mr_etask etask;
int main(void)
{
/* 添加事件任务 */
mr_etask_add(&etask, "etask", 3);
/* 启动普通事件 */
mr_etask_start(&etask, EVENT_1, MR_ETASK_SFLAG_EVENT, 0, event1_cb, NULL);
mr_etask_start(&etask, mr_etask_str2id(EVENT_2), MR_ETASK_SFLAG_EVENT, 0, event2_cb, NULL);
/* 启动定时事件 */
mr_etask_start(&etask, EVENT_3, MR_ETASK_SFLAG_TIMER | MR_ETASK_SFLAG_HARD, 5, event3_cb, NULL);
/* 延迟唤醒事件1 */
mr_etask_wakeup(&etask, EVENT_1, MR_ETASK_WFLAG_DELAY);
/* 立即唤醒事件2 */
mr_etask_wakeup(&etask, mr_etask_str2id(EVENT_2), MR_ETASK_WFLAG_NOW);
/* 状态唤醒事件2 */
mr_etask_wakeup(&etask, mr_etask_str2id(EVENT_2), MR_ETASK_WFLAG_STATE);
while (1)
{
/* 更新事件任务时钟 */
mr_etask_tick_update(&etask);
/* 事件任务处理 */
mr_etask_handle(&etask);
}
}
```
### 更多组件请查看 `module` 目录
----------
# 代码目录
**mr-library** 的代码目录结构如下表所示:
| 名称 | 描述 |
|:---------|:------|
| bsp | 板级支持包 |
| device | 设备文件 |
| document | 文档 |
| driver | 驱动文件 |
| include | 库头文件 |
| module | 组件 |
| package | 软件包 |
| src | 库源文件 |
----------
# 更多使用教程与开发者文档请查看 `document` 目录
----------
# 许可协议
遵循 **Apache License 2.0** 开源许可协议,可免费应用于商业产品,无需公开私有代码。
----------
# 贡献代码
如果您对 **mr-library** 项目感兴趣,欢迎参与开发并成为代码贡献者。欢迎加入讨论群 **199915649(QQ)**

View File

@@ -73,27 +73,22 @@ typedef int (*mr_init_fn_t)(void);
/**
* @brief Exports a board auto initialization function.
*/
#define MR_INIT_BOARD_EXPORT(fn) MR_INIT_EXPORT(fn, "1")
/**
* @brief Exports a console auto initialization function.
*/
#define MR_INIT_CONSOLE_EXPORT(fn) MR_INIT_EXPORT(fn, "2")
#define MR_BOARD_EXPORT(fn) MR_INIT_EXPORT(fn, "1")
/**
* @brief Exports a driver auto initialization function.
*/
#define MR_INIT_DRV_EXPORT(fn) MR_INIT_EXPORT(fn, "3")
#define MR_DRV_EXPORT(fn) MR_INIT_EXPORT(fn, "2")
/**
* @brief Exports a device auto initialization function.
*/
#define MR_INIT_DEV_EXPORT(fn) MR_INIT_EXPORT(fn, "4")
#define MR_DEV_EXPORT(fn) MR_INIT_EXPORT(fn, "3")
/**
* @brief Exports a app auto initialization function.
*/
#define MR_INIT_APP_EXPORT(fn) MR_INIT_EXPORT(fn, "5")
#define MR_APP_EXPORT(fn) MR_INIT_EXPORT(fn, "4")
/**
* @brief Error code.
@@ -163,10 +158,11 @@ struct mr_avl
*/
enum mr_drv_type
{
Mr_Drv_Type_Gpio = 0, /**< GPIO */
Mr_Drv_Type_Pin = 0, /**< GPIO */
Mr_Drv_Type_Spi, /**< SPI */
Mr_Drv_Type_I2c, /**< I2C */
Mr_Drv_Type_Uart, /**< UART */
Mr_Drv_Type_Serial, /**< SERIAL */
Mr_Drv_Type_Can, /**< CAN */
Mr_Drv_Type_Adc, /**< ADC */
Mr_Drv_Type_Dac, /**< DAC */
Mr_Drv_Type_Timer, /**< Timer */
@@ -177,7 +173,7 @@ enum mr_drv_type
*/
struct mr_drv
{
uint32_t type; /**< Device type */
uint32_t type; /**< Driver type */
void *ops; /**< Driver operations */
void *data; /**< Driver data */
};
@@ -187,10 +183,11 @@ struct mr_drv
*/
enum mr_dev_type
{
Mr_Dev_Type_Gpio = Mr_Drv_Type_Gpio, /**< GPIO */
Mr_Dev_Type_Pin = Mr_Drv_Type_Pin, /**< GPIO */
Mr_Dev_Type_Spi = Mr_Drv_Type_Spi, /**< SPI */
Mr_Dev_Type_I2c = Mr_Drv_Type_I2c, /**< I2C */
Mr_Dev_Type_Uart = Mr_Drv_Type_Uart, /**< UART */
Mr_Dev_Type_Serial = Mr_Drv_Type_Serial, /**< SERIAL */
Mr_Dev_Type_Can = Mr_Drv_Type_Can, /**< CAN */
Mr_Dev_Type_Adc = Mr_Drv_Type_Adc, /**< ADC */
Mr_Dev_Type_Dac = Mr_Drv_Type_Dac, /**< DAC */
Mr_Dev_Type_Timer = Mr_Drv_Type_Timer, /**< Timer */
@@ -214,12 +211,12 @@ struct mr_dev;
/**
* @brief Device control general command.
*/
#define MR_CTRL_SET_RD_CB ((0x01|0x80) << 24) /**< Set read callback */
#define MR_CTRL_SET_WR_CB ((0x02|0x80) << 24) /**< Set write callback */
#define MR_CTRL_SET_RD_CALL ((0x01|0x80) << 24) /**< Set read callback */
#define MR_CTRL_SET_WR_CALL ((0x02|0x80) << 24) /**< Set write callback */
#define MR_CTRL_SET_SLEEP ((0x03|0x80) << 24) /**< Set sleep */
#define MR_CTRL_SET_WAKEUP ((0x04|0x80) << 24) /**< Set wakeup */
#define MR_CTRL_GET_RD_CB ((0x01|0x00) << 24) /**< Get read callback */
#define MR_CTRL_GET_WR_CB ((0x02|0x00) << 24) /**< Get write callback */
#define MR_CTRL_GET_RD_CALL ((0x01|0x00) << 24) /**< Get read callback */
#define MR_CTRL_GET_WR_CALL ((0x02|0x00) << 24) /**< Get write callback */
/**
* @brief Device control command.
@@ -311,8 +308,8 @@ struct mr_dev
struct
{
int desc; /**< Device descriptor */
int (*cb)(int desc, void *args); /**< Callback function */
} rd_cb, wr_cb; /**< Read/write callback */
int (*call)(int desc, void *args); /**< Callback function */
} rd_call, wr_call; /**< Read/write callback */
const struct mr_dev_ops *ops; /**< Device operations */
const struct mr_drv *drv; /**< Driver */

View File

@@ -13,23 +13,25 @@
extern "C" {
#endif /* __cplusplus */
#define MR_CFG_NAME_MAX 10
#define MR_CFG_DESC_MAX 32
#define MR_CFG_NAME_MAX (10)
#define MR_CFG_DESC_MAX (32)
#define MR_USING_RDWR_CTRL
#define MR_USING_ADC
#define MR_USING_DAC
#define MR_USING_GPIO
#define MR_USING_PIN
#define MR_USING_I2C
#define MR_USING_SPI
#define MR_USING_UART
#define MR_USING_PWM
#define MR_USING_SERIAL
#define MR_USING_TIMER
#define MR_USING_CAN
#define MR_CFG_HEAP_SIZE (4 * 1024)
#define MR_CFG_CONSOLE_NAME "uart1"
#define MR_CFG_UART_RD_BUFSZ_INIT 32
#define MR_CFG_UART_WR_BUFSZ_INIT 0
#define MR_CFG_SPI_RD_BUFSZ_INIT 32
#define MR_CFG_I2C_RD_BUFSZ_INIT 32
#define MR_CFG_SERIAL_RD_BUFSZ (32)
#define MR_CFG_SERIAL_WR_BUFSZ (0)
#define MR_CFG_SPI_RD_BUFSZ (32)
#define MR_CFG_I2C_RD_BUFSZ (32)
#ifdef __cplusplus
}