Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
PWM
设备驱动框架
LPC55S69对接RT-Thread PWM设备框架
发布于 2023-03-10 21:40:23 浏览:395
订阅该版
[tocm] # LPC55S69对接RT-Thread PWM设备框架 在使用 RT-Thread 的 bsp pwm 的时候,注意到 lpc55sxx 系列只对接了通用定时器2中的通道1作为 PWM 输出。但其实 LPC55S69 具备非常多的 PWM 资源。于是根据 RT-Thread 设备驱动框架了,对接了其他通用定时器的 PWM 输出。 ## 开始对接 ### 创建PWM设备 之前该 BSP 中的 drv_pwm 已经对接了基本的接口,但只考虑了一个通道作为 PWM 输出,在实际的使用中具有较大的局限性,不能充分发挥作用。我们首先基于PWM设备基类结构派生出新的 PWM 设备结构体: ``` struct lpc_pwm { struct rt_device_pwm pwm_device; CTIMER_Type * tim; uint32_t channel; char *name; }; ``` 因为 PWM 设备不止一个 ,所以我们定义一个全局的 PWM 设备表来同时创建多个 PWM 设备: ``` static struct lpc_pwm lpc_pwm_obj[] = { #if defined(BSP_USING_CTIMER1_MAT0) || defined(BSP_USING_CTIMER1_MAT1) || \ defined(BSP_USING_CTIMER1_MAT2) { .tim = CTIMER1, .name = "pwm1", .channel = RT_NULL }, #endif #if defined(BSP_USING_CTIMER2_MAT0) || defined(BSP_USING_CTIMER2_MAT1) || \ defined(BSP_USING_CTIMER2_MAT2) { .tim = CTIMER2, .name = "pwm2", .channel = RT_NULL }, #endif }; /* 可以根据实际需求自行扩展 */ ``` 选择指定定时器的具体通道作为 PWM 输出: ``` static void pwm_get_channel(void) { #ifdef BSP_USING_CTIMER1_MAT0 lpc_pwm_obj[PWM1_INDEX].channel |= 1 << 0; #endif #ifdef BSP_USING_CTIMER1_MAT1 lpc_pwm_obj[PWM1_INDEX].channel |= 1 << 1; #endif #ifdef BSP_USING_CTIMER1_MAT2 lpc_pwm_obj[PWM1_INDEX].channel |= 1 << 2; #endif #ifdef BSP_USING_CTIMER2_MAT0 lpc_pwm_obj[PWM2_INDEX].channel |= 1 << 0; #endif #ifdef BSP_USING_CTIMER2_MAT1 lpc_pwm_obj[PWM2_INDEX].channel |= 1 << 1; #endif #ifdef BSP_USING_CTIMER2_MAT2 lpc_pwm_obj[PWM2_INDEX].channel |= 1 << 2; #endif } /* 可以根据实际需求自行扩展 */ ``` ### 实现PWM设备的操作方法 PWM 设备只有一个 control 方法, control 方法使用设备控制字 cmd 来区分操作,分别有ENABLE、DISABLE、SET、GET。这部分原先已经基本实现过了,只需添加新的定时器判断分支即可。 ## 注册PWM设备 原先是使用 rt_hw_pwm_init() 即可注册定时器2通道1这一个定时器设备,但现在需要注册的是多个 PWM 设备,于是编写 lpc_pwm_init() 将 PWM 设备表中的多个 PWM 设备逐个进行注册。 ``` static int lpc_pwm_init(void) { int i = 0; int result = RT_EOK; pwm_get_channel(); for (i = 0; i < sizeof(lpc_pwm_obj) / sizeof(lpc_pwm_obj[0]); i++) { /* pwm init */ if (rt_hw_pwm_init(&lpc_pwm_obj[i]) != RT_EOK) { LOG_E("%s init failed", lpc_pwm_obj[i].name); result = -RT_ERROR; goto __exit; } else { LOG_D("%s init success", lpc_pwm_obj[i].name); /* register pwm device */ if (rt_device_pwm_register(&lpc_pwm_obj[i].pwm_device, lpc_pwm_obj[i].name, &lpc_drv_ops, lpc_pwm_obj[i].tim) == RT_EOK) { LOG_D("%s register success", lpc_pwm_obj[i].name); } else { LOG_E("%s register failed", lpc_pwm_obj[i].name); result = -RT_ERROR; } } } __exit: return result; } INIT_DEVICE_EXPORT(lpc_pwm_init); ``` 至此,对于该 BSP 的 drv_pwm 的重构基本完成,主要目的是更全面的对接 RT-Thread 设备框架,能够同时使用多路 PWM 输出,提高其适用性和灵活性。 ## 后续优化 之后希望通过进一步研究功能强大的 SCTime/PWM ,并将其也添加到设备驱动框架中来。 欢迎大家交流~
0
条评论
默认排序
按发布时间排序
登录
注册新账号
关于作者
螺丝松掉的人
这家伙很懒,什么也没写!
文章
42
回答
0
被采纳
0
关注TA
发私信
相关文章
1
玩iot camera笔记之3测试试用3路pwm
2
[已解决]PWM输出异常分析
3
给RT-Thread添加PWM驱动框架
4
关于rt-thread-3.1.0 pwm
5
关于rt-thread的PWM框架在stm32f103vf应用的疑问
6
rt-thread stm32 bsp adc pwm 外设适配好了吗
7
stm32f103ze 添加pwm 设备失败
8
【正点原子】潘多拉IoT-STM32L475开发板 用menuconfig 看不到PWM....
9
关于rtthread 4.0.0版本中pwm的初始化定时器寄存器读写问题
10
RT-Thread正点原子战舰V3使用PWM设备驱动没有输出
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
I2C_IIC
ESP8266
UART
WIZnet_W5500
ota在线升级
PWM
cubemx
flash
freemodbus
BSP
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
SFUD
msh
keil_MDK
ulog
C++_cpp
MicroPython
本月问答贡献
xusiwei1236
5
个答案
2
次被采纳
踩姑娘的小蘑菇
1
个答案
2
次被采纳
用户名由3_15位
7
个答案
1
次被采纳
bernard
4
个答案
1
次被采纳
张世争
1
个答案
1
次被采纳
本月文章贡献
聚散无由
2
篇文章
15
次点赞
catcatbing
2
篇文章
5
次点赞
Wade
2
篇文章
2
次点赞
Ghost_Girls
1
篇文章
6
次点赞
YZRD
1
篇文章
2
次点赞
回到
顶部
发布
问题
投诉
建议
回到
底部