共计 2302 个字符,预计需要花费 6 分钟才能阅读完成。
设施框架
mr-library 将硬件设施形象成设施对象,并提供了对立的设施操作接口,不便应用程序与硬件设施进行交互。通过将驱动层与设施层解耦,进步了代码的可靠性和可维护性。
设施模型
设施对象定义如下:
struct mr_device
{
struct mr_object object; /* 设施对象基类 */
enum mr_device_type type; /* 设施类型 */
mr_uint16_t support_flag; /* 设施反对的打开方式 */
mr_uint16_t open_flag; /* 设施打开方式 */
mr_size_t ref_count; /* 设施被援用次数 */
void *data; /* 设施数据 */
mr_err_t (*rx_cb)(mr_device_t device, void *args); /* 设施接管回调函数 */
mr_err_t (*tx_cb)(mr_device_t device, void *args); /* 设施发送回调函数 */
const struct mr_device_ops *ops; /* 设施操作方法 */
};
设施类型
设施框架反对多种类型的设施,每种设施都由一个枚举值来示意。设施类型定义如下:
enum mr_device_type
{
MR_DEVICE_TYPE_NONE, /* 无类型设施 */
MR_DEVICE_TYPE_PIN, /* GPIO 设施 */
MR_DEVICE_TYPE_SPI_BUS, /* SPI 总线设施 */
MR_DEVICE_TYPE_SPI, /* SPI 设施 */
MR_DEVICE_TYPE_I2C_BUS, /* I2C 总线设施 */
MR_DEVICE_TYPE_I2C, /* I2C 设施 */
MR_DEVICE_TYPE_SERIAL, /* UART 设施 */
MR_DEVICE_TYPE_ADC, /* ADC 设施 */
MR_DEVICE_TYPE_DAC, /* DAC 设施 */
MR_DEVICE_TYPE_PWM, /* PWM 设施 */
MR_DEVICE_TYPE_TIMER, /* TIMER 设施 */
MR_DEVICE_TYPE_FLASH, /* FLASH 设施 */
/* ... */
};
设施打开方式
设施只能以反对的打开方式关上,定义如下:
#define MR_OPEN_RDONLY 0x1000 /* 只读关上 */
#define MR_OPEN_WRONLY 0x2000 /* 只写关上 */
#define MR_OPEN_RDWR 0x3000 /* 可读可写 */
设施操作方法
每种设施类型都有对应的设施操作方法,包含关上设施、敞开设施、管制设施、读取设施和写入设施等操作。设施操作方法定义如下:
struct mr_device_ops
{mr_err_t (*open)(mr_device_t device);
mr_err_t (*close)(mr_device_t device);
mr_err_t (*ioctl)(mr_device_t device, int cmd, void *args);
mr_ssize_t (*read)(mr_device_t device, mr_off_t pos, void *buffer, mr_size_t size);
mr_ssize_t (*write)(mr_device_t device, mr_off_t pos, const void *buffer, mr_size_t size);
};
接口 | 形容 |
---|---|
open | 关上设施,同时实现设施配置。只有当设施首次被关上时,才会调用此办法来关上设施。 |
close | 敞开设施。只有当设施被所有用户敞开时(设施援用次数为 0),才会调用此办法来敞开设施。 |
ioctl | 管制设施。依据 cmd 命令管制设施 |
read | 从设施读取数据。pos 是设施读取地位(不同设施所示意的意义不同,请查看设施具体手册),size 是设施读取字节大小。 |
write | 向设施写入数据。pos 是设施写入地位(不同设施所示意的意义不同,请查看设施具体手册),size 是设施写入字节大小。 |
拜访设施
应用程序通过设施操作接口来拜访硬件设施,具体如下:
接口 | 形容 |
---|---|
mr_device_add | 将设施增加到内核容器中 |
mr_device_find | 在内核容器中查找设施 |
mr_device_open | 关上设施 |
mr_device_close | 敞开设施 |
mr_device_ioctl | 管制设施 |
mr_device_read | 从设施读取数据 |
mr_device_write | 向设施写入数据 |
设施操作示例
上面是一个以 PIN 设施为例的设施操作示例:
/* 寻找 PIN 设施 */
mr_device_t pin_device = mr_device_find("pin");
/* 以可读可写的形式关上 PIN 设施 */
mr_device_open(pin_device, MR_OPEN_RDWR);
/* 配置 B13 引脚为推挽输入模式 */
struct mr_pin_config pin_config = {29, MR_PIN_MODE_OUTPUT};
mr_device_ioctl(pin_device, MR_CTRL_CONFIG, &pin_config);
/* 设置 B13 为高电平 */
mr_uint8_t pin_level = 1;
mr_device_write(pin_device, 29, &pin_level, sizeof(pin_level));
/* 获取 B13 电平 */
mr_device_read(pin_device, 29, &pin_level, sizeof(pin_level));
———-
仓库链接
———-
许可协定
遵循 Apache License 2.0 开源许可协定,可收费利用于商业产品,无需公开公有代码。
正文完