RTT设备驱动框架学习(UART)

2024-04-21 22:28

本文主要是介绍RTT设备驱动框架学习(UART),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在serial.h中

struct rt_serial_device
{struct rt_device parent;const struct rt_uart_ops *ops;struct serial_configure config;void *serial_rx;void *serial_tx;struct rt_spinlock spinlock;struct rt_device_notify rx_notify;
}
typedef struct rt_serial_device rt_serial_t;
struct rt_uart_ops
{rt_err_t (*configure)(struct rt_serial_device *serial, struct serial_configure *cfg);rt_err_t (*control)(struct rt_serial_device *serial, int cmd, void *arg);int (*putc)(struct rt_serial_device *serial, char c);int (*getc)(struct rt_serial_device *serial);rt_ssize_t (*dma_transmit)(struct rt_serial_device *serial, rt_uint8_t *buf, rt_size_t size, int direction);
};
struct serial_configure
{rt_uint32_t baud_rate;rt_uint32_t data_bits               :4;rt_uint32_t stop_bits               :2;rt_uint32_t parity                  :2;rt_uint32_t bit_order               :1;rt_uint32_t invert                  :1;rt_uint32_t bufsz                   :16;rt_uint32_t flowcontrol             :1;rt_uint32_t reserved                :5;
};

在drv_usart.h中

struct stm32_uart
{UART_HandleTypeDef handle;struct stm32_uart_config *config;rt_uint32_t DR_mask;rt_uint16_t uart_dma_flag;struct rt_serial_device serial;
};
struct stm32_uart_config
{const char *name;USART_TypeDef *Instance;IRQn_Type irq_type;struct dma_config *dma_rx;struct dma_config *dma_tx;
}

在drv_usart.c中要实现串口驱动框架层定义的接口

static const struct rt_uart_ops stm32_uart_ops =
{.configure = stm32_configure,.control = stm32_control,.putc = stm32_putc,.getc = stm32_getc,.dma_transmit = stm32_dma_transmit
};

然后在初始化函数里去注册设备驱动程序

int rt_hw_usart_init(void)
{struct serial_configure config = RT_SERIAL_CONFIG_DEFAULT;rt_err_t result = 0;stm32_uart_get_dma_config();for(rt_size_t i=0; i<sizeof(uart_obj)/sizeof(struct stm32_uart); i++){/* init UART object */uart_obj[i].config = &uart_config[i];uart_obj[i].serial.ops    = &stm32_uart_ops;uart_obj[i].serial.config = config;/* register UART device */result = rt_hw_serial_register(&uart_obj[i].serialm uart_obj[i].config->name,  RT_DEVICE_FLAG_RDWR| RT_DEVICE_FLAG_INT_RX| RT_DEVICE_FLAG_INT_TX| uart_obj[i].uart_dma_flag, NULL);RT_ASSERT(result == RT_EOK);}return result;
}
static struct stm32_uart uart_objt[sizeof(uart_config)/sizeof(uart_config[0])] = {0};
static struct stm32_uart_config uart_config[] =
{
#ifdef BSP_USING_UART1UART1_CONFIG,
#endif
#ifdef BSP_USING_UART2UART2_CONFIG,
#endif
#ifdef BSP_USING_UART3UART3_CONFIG,
#endif
#ifdef BSP_USING_UART4UART4_CONFIG,
#endif
#ifdef BSP_USING_UART5UART5_CONFIG,
#endif
#ifdef BSP_USING_UART6UART6_CONFIG,
#endif
#ifdef BSP_USING_UART7UART7_CONFIG,
#endif
#ifdef BSP_USING_UART8UART8_CONFIG,
#endif
#ifdef BSP_USING_LPUART1LPUART1_CONFIG,
#endif
};
#ifndef LPUART1_CONFIG
#define LPUART1_CONFIG                                              \{                                                               \.name = "lpuart1",                                          \.Instance = LPUART1,                                        \.irq_type = LPUART1_IRQn,                                   \}
#endif /* LPUART1_CONFIG */

在serial.c中

rt_err_t rt_hw_serial_register(struct rt_serial_device *serial,const char              *name,rt_uint32_t              flag,void                    *data)
{rt_err_t ret;struct rt_device *device;RT_ASSERT(serial != RT_NULL);rt_spin_lock_init(&(serial->spinlock));device = &(serial->parent);device->type        = RT_Device_Class_Char;device->rx_indicate = RT_NULL;device->tx_complete = RT_NULL;#ifdef RT_USING_DEVICE_OPSdevice->ops         = &serial_ops;
#elsedevice->init        = rt_serial_init;device->open        = rt_serial_open;device->close       = rt_serial_close;device->read        = rt_serial_read;device->write       = rt_serial_write;device->control     = rt_serial_control;
#endifdevice->user_data   = data;/* register a character device */ret = rt_device_register(device, name, flag);#ifdef RT_USING_POSIX_STDIO/* set fops */device->fops        = &_serial_fops;
#endifreturn ret;
}

这篇关于RTT设备驱动框架学习(UART)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/924182

相关文章

C++ HTTP框架推荐(特点及优势)

《C++HTTP框架推荐(特点及优势)》:本文主要介绍C++HTTP框架推荐的相关资料,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. Crow2. Drogon3. Pistache4. cpp-httplib5. Beast (Boos

SpringBoot基础框架详解

《SpringBoot基础框架详解》SpringBoot开发目的是为了简化Spring应用的创建、运行、调试和部署等,使用SpringBoot可以不用或者只需要很少的Spring配置就可以让企业项目快... 目录SpringBoot基础 – 框架介绍1.SpringBoot介绍1.1 概述1.2 核心功能2

重新对Java的类加载器的学习方式

《重新对Java的类加载器的学习方式》:本文主要介绍重新对Java的类加载器的学习方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、介绍1.1、简介1.2、符号引用和直接引用1、符号引用2、直接引用3、符号转直接的过程2、加载流程3、类加载的分类3.1、显示

如何在Ubuntu上安装NVIDIA显卡驱动? Ubuntu安装英伟达显卡驱动教程

《如何在Ubuntu上安装NVIDIA显卡驱动?Ubuntu安装英伟达显卡驱动教程》Windows系统不同,Linux系统通常不会自动安装专有显卡驱动,今天我们就来看看Ubuntu系统安装英伟达显卡... 对于使用NVIDIA显卡的Ubuntu用户来说,正确安装显卡驱动是获得最佳图形性能的关键。与Windo

Android与iOS设备MAC地址生成原理及Java实现详解

《Android与iOS设备MAC地址生成原理及Java实现详解》在无线网络通信中,MAC(MediaAccessControl)地址是设备的唯一网络标识符,本文主要介绍了Android与iOS设备M... 目录引言1. MAC地址基础1.1 MAC地址的组成1.2 MAC地址的分类2. android与I

Spring框架中@Lazy延迟加载原理和使用详解

《Spring框架中@Lazy延迟加载原理和使用详解》:本文主要介绍Spring框架中@Lazy延迟加载原理和使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、@Lazy延迟加载原理1.延迟加载原理1.1 @Lazy三种配置方法1.2 @Component

嵌入式Linux之使用设备树驱动GPIO的实现方式

《嵌入式Linux之使用设备树驱动GPIO的实现方式》:本文主要介绍嵌入式Linux之使用设备树驱动GPIO的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、设备树配置1.1 添加 pinctrl 节点1.2 添加 LED 设备节点二、编写驱动程序2.1

嵌入式Linux驱动中的异步通知机制详解

《嵌入式Linux驱动中的异步通知机制详解》:本文主要介绍嵌入式Linux驱动中的异步通知机制,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、异步通知的核心概念1. 什么是异步通知2. 异步通知的关键组件二、异步通知的实现原理三、代码示例分析1. 设备结构

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

usb接口驱动异常问题常用解决方案

《usb接口驱动异常问题常用解决方案》当遇到USB接口驱动异常时,可以通过多种方法来解决,其中主要就包括重装USB控制器、禁用USB选择性暂停设置、更新或安装新的主板驱动等... usb接口驱动异常怎么办,USB接口驱动异常是常见问题,通常由驱动损坏、系统更新冲突、硬件故障或电源管理设置导致。以下是常用解决