硬汉嵌入式论坛

 找回密码
 立即注册
查看: 3053|回复: 9
收起左侧

[USB] 普及下RL-USB的裸机版和RTOS版相关问题

[复制链接]

1万

主题

6万

回帖

10万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
107034
QQ
发表于 2020-10-19 11:17:28 | 显示全部楼层 |阅读模式
【小知识】

这个CMSIS-RTOS不仅可以作为各种OS的封装层,还可以是裸机封装层,像DAPLINK里面就提供了一个裸机方式的CMSIS-RTOS层。

现在为什么新作的RL-USB教程里面没有再推出裸机,FreeRTOS,uCOS-III等组合方式了,请往下看:

QQ截图20201019104453.png



MDK4时代:

最早2010年年底到2011年年初,MDK在自己的安装目录里面添加了Host和Device的源码,早期的源码比较简陋,后面就逐渐形成RL-USB库。

这个库是可以裸机使用,也可以OS使用,切换方法比较简单,就是底层接口的一个宏定义__RTX。

QQ截图20201019102808.png

这个时代,不仅是RL-USB,像RL-TCPnet,RL-FlashFS,我都做了一大批裸机和配套uCOS-III,FreeRTOS等大杂烩方式的例子。

部分截图如下:
QQ截图20201019103446.png

下面这个V6早期的综合Demo创建方式,基本已经是RTX4所有组件全家桶合影:

6666.png

MDK5时代:

进入MDK5,已经开启了RTX5全家桶一条龙服务时代,使用MDK RTE环境一键创建,不再需要MDK4时代繁琐的手动添加方式。

但是对于想要裸机添加各种组件的用户,新的版本已经不再推荐这个方式,你选择了裸机添加,就意味着你放弃了使用MDK RTE,因为RTE不支持用户直接选择中间件。

比如你选择了RL-USB,会提示你必须选择一个RTOS支持:

5555.png

这个时候你要选择裸机使用吗,工作量是何其大,如果你是按照DAPLINK那套方式(其实是更接近于MDK4时代的源码)还方便些,但是你想直接将MDK5里面的RL-USB拉出来

难度非常大,因为里面一大堆描述符的宏定义配置,并且每个应用类都是一个独立的任务,比如你创建一个复合设备,使用了5个USB任务,你自己来创建维护太麻烦了,特别是各种宏定义管理

代码都是这种样子的,不使用RTE自己添加的时候各种错误。

5.png

而且要你自己为维护一个类似MDK RTE的这个文件:
7777.png

那么问题来了,自己添加既然这么麻烦,那么问题就转到了使用CMSIS-RTOS封装层,借助这个封装层:

(1)我们可以继续使用裸机方式(DAPLINK已经提供了一个简单接口实现)

他这个方式,如果应用到DAPLINK原有的代码上比较简单,如果应用到MDK5上,对于一般用户来说,难度系统略高,因为你要维护我前面说各种方式,特别是独立任务的实现。自己做个RTE组件还是比较繁琐的。

自己添加MDK5里面的RL-USB相关代码,相当麻烦。

特别注意,这个还仅仅是你做了个RL-USB,除非你不用别的中间件,如果要用,这种方式绝对让你用的生不如死。因为我早期研究是打算继续采用MDK4方式的,降低对MDK RTE依赖。后来我直接放弃了,非常不友好。

(2)再说说CMSIS-RTOS使用其它RTOS,像FreeRTOS

这个最有说服力,因为MDK已经尽最大努力来完善FreeRTOS在MDK RTE上的各种兼容。实际效果怎么样了?实际效果差强人意,从去年开始发布的RL-TCPnet V7.X教程配套了RTX5和FreeRTOS两个版本。

使用FreeRTOS版本,各种问题频出,特别是长时间批量数据传输。我们自己来做一款OS的兼容这些中间件就更加困难了,完全没必要。


总结:

最后说一下DAPLINK这个东西,他为了便于用户实现,做了各种骚操作,特别是还整了一个类似裸机版CMSIS-RTOS层,这个方法直接替换MDK RTE中RTX5在各种中间件里面的位置,还远远达不到。

所以我们现在的RL-USB教程仅推出RTX5版,使用MDK RTE一键创建,其它方式都不再使用。

评分

参与人数 2金币 +40 收起 理由
role_2099 + 20 很给力!
hqgboy + 20 很给力!

查看全部评分

回复

使用道具 举报

6

主题

122

回帖

140

积分

初级会员

积分
140
发表于 2020-10-19 12:50:54 | 显示全部楼层
如此看来,还真的有必要革新。
回复

使用道具 举报

1万

主题

6万

回帖

10万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
107034
QQ
 楼主| 发表于 2020-10-19 13:28:09 | 显示全部楼层
更新完毕。
回复

使用道具 举报

5

主题

192

回帖

212

积分

高级会员

积分
212
发表于 2020-10-19 13:44:43 | 显示全部楼层
嗯,听明白了
回复

使用道具 举报

1万

主题

6万

回帖

10万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
107034
QQ
 楼主| 发表于 2020-10-19 13:46:58 | 显示全部楼层
dy84082666 发表于 2020-10-19 12:50
如此看来,还真的有必要革新。

经过这段时间测试。

H7-TOOL的RTX5全家桶版工程也准备改成所有HAL库,DSP库,以及各种中间件全部用RTE添加

http://www.armbbs.cn/forum.php?mod=viewthread&tid=100195




回复

使用道具 举报

4

主题

74

回帖

86

积分

初级会员

积分
86
发表于 2020-10-19 15:04:29 | 显示全部楼层
新人,没有用过相关的RTOS,最近在学习RXT5的RL-USB,以前跑过ST给的自己的库文件,感觉数据传输稳定性方面不太好,选RTX5的原因是方便好用稳定,但是RTX5的资料不多,除了KEIL官网的,学这个操作系统有时候不知道这个内核的工作机制,等着硬汉RTX5的内核进度,认真学习RTX5。请问RTX5的内核学习看RTX4参考性大不大?因为现在RTX5的内核教程更新中。
回复

使用道具 举报

1万

主题

6万

回帖

10万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
107034
QQ
 楼主| 发表于 2020-10-20 01:11:51 | 显示全部楼层
滴滴滴 发表于 2020-10-19 15:04
新人,没有用过相关的RTOS,最近在学习RXT5的RL-USB,以前跑过ST给的自己的库文件,感觉数据传输稳定性方面 ...

可以看RTX5的官方文档。
回复

使用道具 举报

4

主题

74

回帖

86

积分

初级会员

积分
86
发表于 2020-10-20 09:34:12 | 显示全部楼层
eric2013 发表于 2020-10-20 01:11
可以看RTX5的官方文档。

收到,谢谢!
回复

使用道具 举报

23

主题

1406

回帖

1475

积分

至尊会员

积分
1475
发表于 2020-10-20 14:36:52 | 显示全部楼层
表示已经不会裸机写程序了
代码不规范,亲人两行泪!
回复

使用道具 举报

41

主题

112

回帖

235

积分

高级会员

积分
235
发表于 2020-11-17 09:52:11 | 显示全部楼层
“各种骚操作” ,哈哈
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|小黑屋|Archiver|手机版|硬汉嵌入式论坛

GMT+8, 2024-5-15 07:30 , Processed in 0.301399 second(s), 32 queries .

Powered by Discuz! X3.4 Licensed

Copyright © 2001-2023, Tencent Cloud.

快速回复 返回顶部 返回列表