你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

【源码】STLINK-V3MINI 高速USB仿真器,成功改刷【高速CMSIS-DAP】  

[复制链接]
radio2radio 发布时间:2019-9-1 14:04
阅读主题, 点击返回1楼
收藏 25 评论91 发布时间:2019-9-1 14:04
91个回答
mcu_i 回答时间:2019-9-30 11:57:04
楼主好,我做了一个daplink,遇到这样一个问题,就是目前是全速设备,想改成高速设备,电路仿照别人的,在D+线上加了个pmos用来控制1.5k上拉电阻的连接,那么问题来了,怎么对官方的源码进行改动才能实现高速USB设备?我看到程序里有个    USBD_HighSpeed = __FALSE ;我给改成了__TRUE,直接就无法识别了。。。
6 z7 n+ M+ o# t我的程序是官方最新的0254版本,不知道楼主的V2.0.0是什么版本
电路.png
官方源码.png
radio2radio 回答时间:2019-9-30 12:53:38
刚好我最近也在为STLINK-V3MINI,移植DAPLink的事情伤脑筋,看了一下DAPLink的源码,许多事情还不是很了解。
) [. i/ B& y5 B" m
) g( Y: X( l9 Y/ V- @要改高速USB,首先你的硬件要没有问题,比如说我的STLINK-V3原来就是内置高速USB接口的。 我在CubeMX开个高速的VCP项目,很容易就验证了硬件。 建议您也试一试。
. j5 {! r) |0 L( t  }2 B! m: k
2 L  A9 P  n+ r& L8 M& _2 C5 @不知你用什么MCU,DAPLink里面有没有人用过。
: a' \8 g6 E& o6 d  |) V# F) s8 a% B! Q* H5 ^
软件方面,先改usbd_hw.h里面的底层驱动的函数,用你的高速USB库实现,如果有现成的,就省事了。
, H% A1 _2 I, S开通高速,要到usb_config.c文件里面修改配置,可以参考已经搞好的高速项目,比如k26f 和sam3u2c。' j: o3 k9 Q' `$ V2 p
radio2radio 回答时间:2019-9-30 13:14:36
mcu_i 发表于 2019-9-30 11:57
- ]; T# c. f& h7 s4 k楼主好,我做了一个daplink,遇到这样一个问题,就是目前是全速设备,想改成高速设备,电路仿照别人的,在D ...
3 m% Y0 T3 g5 X% M8 Z0 h1 i) ]# c
接上面的回复。 版本号的问题,5 Q' R- g% j9 D; E: ~

6 s4 z/ i' b- J) W/ z! CCMSIS-DAP 有2个版本在用:v1.1.0(DAPLink用的),v2.0.0(增加了SWO_STREAM模式等)
3 |1 y3 Z1 r6 A
# X" [) D% H" W+ lDAPLink的版本号,0254是最新版的。4 h' z, |! d! R- M
# {" G1 s. l. s1 C: G8 j6 {
还有一个经常提到的CMSIS-DAP v1,这个是指HID模式的。 CMSIS-DAP v2是指WinUSB模式的。
飞跃-344154 回答时间:2019-10-2 21:58:57
不错,值得一试
radio2radio 回答时间:2019-10-10 00:07:31
关于DAPLink的思考,
$ v+ m! X9 H3 ^7 a% p由于很想将现在的DAPLink移植到STLINK-V3MINI硬件上面,仔细研究了一下DAPLink的源代码。 说实话,我没有使用过DAPLink,随着对DAPLink理念的深入理解,我发现移植DAPLink到独立的硬件上面,比如这个STLINK-V3MINI,意义不大。 现决定放弃。$ n6 e# R+ G% ?0 W6 }3 V& s
5 _$ e: V: t$ o" S! a3 D
DAPLink是CMSIS-DAP的延申,主要是用于IC厂家在推广一款MCU时提供的开发板/演示板上面使用。功能类似于STLINK在STM32各种开发板上面所提供的辅助开发接口。
0 \* F+ J/ M8 X0 _* _
: d. R; ]7 D$ P. z4 b, N1- DAPLink的控制IC,内部称为HIC,常见的是K20DX, LPC11U35, STM32F103等等。 HIC主要功能是运行CMSIS-DAP,具有USB-MSC自我更新能力,和拖拽下载目标板程序的功能,新版本具有WebUSB下载目标程序的功能。
7 X5 [/ U7 ~# z) F6 U; g& r/ M9 K' \( ^- V8 J( b8 X& [
2- DAPLink可以提供一种标准的上位机可控的下载接口,开发板供应商,第三方上位机软件开发商,可以包装成各种傻瓜式的开发环境。 目的是令整个系统容易使用,特别是给儿童使用。这与我们经常使用的IDE不是一码事儿。
* c# f' q% T  w; Y9 s  h2 b/ x0 [! X6 E/ {1 l" f/ U
3- DAPLink控制板,通常要与目标板一起提供给终端使用者,一般没有单独的设备出售。 因为不同的目标板MCU不同,MCU程序的下载算法也不同,这就使得DAPLink的控制软件也不同,虽然有USB-MSC自我更新能力, 也不能很方便地像JLINK/STLINK/CMSIS-DAP那样在不同的IC之间转换。
2 {9 R/ V* m% k: M7 P- _5 C* f  {3 J# Z" s5 V6 T
4- DAPLink所用的HIC要便宜,固件要成熟。 这一点对开发板厂商很重要。 是不是USB2.0高速(高速的价格贵好几倍),不重要。
  o4 \) B# E# F, y3 o# R) y' |3 B# J8 I9 Z6 i
1 M, c6 @' X3 v4 s, n% F
所以我..........放弃移植DAPLink,不搞了。 有时间继续优化CMSIS-DAP。
+ i& @/ f9 ], i: z: B) E顺便说一下, 使用独立的CMSIS-DAP, 特别是这个高速版的,很好用。
% V5 D0 u0 q  t6 Q% _4 C% E7 @
5 @) V  A2 w, }! K
mcu_i 回答时间:2019-10-17 23:25:56
radio2radio 发表于 2019-9-30 12:53
6 b  T% ?, i/ Q( @8 A$ n刚好我最近也在为STLINK-V3MINI,移植DAPLink的事情伤脑筋,看了一下DAPLink的源码,许多事情还不是很了解 ...

/ p3 B9 s& r, @/ m$ ~% q& i感谢楼主,找了一些资料后我现在搞明白了,我那个电路应该是不能实现高速USB,必须加高速USB的芯片才可以。
3 n# Z* h) i$ [% s7 L* l7 J最近我在研究关闭daplink一键拖拽下载的功能,也就是使其连接电脑后不显示U盘,改了源码里面带着dsiable、msd之类字眼的变量,都不管用,楼主有没有这方面的经验?谢谢
radio2radio 回答时间:2019-10-18 00:17:09
mcu_i 发表于 2019-10-17 23:255 M6 m$ K! F8 A' @" k
感谢楼主,找了一些资料后我现在搞明白了,我那个电路应该是不能实现高速USB,必须加高速USB的芯片才可以 ...
$ p% |7 Q* W2 H1 l7 ]: p
我没有这方面经验,不过不知道您为什么要去掉这个拖拽下载功能,不用摆在那里不行吗。 拖拽下载功能,是有很严格的要求的,不是自己的代码,不能刷的呀。
Nikola 回答时间:2019-10-29 13:09:48
STM32F723IEK6 太贵了。。。
radio2radio 回答时间:2019-10-29 13:39:01
秦秦秦 发表于 2019-10-29 13:09* ~1 N! j. {) x' W
STM32F723IEK6 太贵了。。。

/ K6 [9 X7 W/ M; A买IC如果数量不大,当然贵啦。/ U5 ~; C7 N9 E+ e$ _8 d) {6 F: y

- S# ~- T  d5 x% m自己用,建议您买2个STLINK-V3MINI,一个不动,一个改装。
Nikola 回答时间:2019-11-6 11:12:39
radio2radio 发表于 2019-10-29 13:39
% }) t3 T9 r$ O* k& S买IC如果数量不大,当然贵啦。$ O/ ]7 {/ n, S# x7 E" G4 P

/ z/ k! k7 M3 t% I- }: L- @自己用,建议您买2个STLINK-V3MINI,一个不动,一个改装。 ...

) d+ {' X( W* A2 ?谢谢您的建议
radio2radio 回答时间:2019-11-9 20:25:57
今天搞定了AC6的优化问题,原来是CMSIS-DAP源码的一个已知的小Bug,底层定时部分会随着选择不同的优化等级而有变化。 在大多数的情况下,不影响使用。 所以ARM方面也不急于改正。7 W: b. Y* Q* c5 G, y
(1楼源码已更新)
radio2radio 回答时间:2019-11-30 12:35:39
今天又做了重要更新,速度更加快了,在Keil里面设定SW速度为10MHz,实际SWCLK可以达到8MHz。
2 F) C7 J4 H$ o4 x7 C( z, b9 v. i) b1 l  ~) g
其实,SWCLK的速度还可以进一步提高,翻倍也不难,有源码在那里,想改就可以改。
radio2radio 回答时间:2019-12-23 08:49:27
昨天又重要更新,速度快多了,SWD模式18MHz最高时。
zjq985062714 回答时间:2020-3-27 16:01:44
边缘那些GPIO可能可以通过bridge(STLINK-V3-BRIDGE)控制?不过就算这样,也要上位机才行
radio2radio 回答时间:2020-3-27 16:43:46
zjq985062714 发表于 2020-3-27 16:01. J% f: ~3 N1 n& V1 R8 Q7 S/ c0 p2 ?
边缘那些GPIO可能可以通过bridge(STLINK-V3-BRIDGE)控制?不过就算这样,也要上位机才行 ...

/ o' G! E( s7 ?2 _2 d/ B! n这个功能是需要上位机软件支持,ST已经有软件,但是只支持原装的STLINK-V3MINI。" m& \( |+ p* y% a# ^( C
改装后的CMSIS-DAP,这些GPIOs可以利用做好多事情。
: V* |7 v6 s. X/ t  i& i, w- v7 `( [) a! L' @
复制出(STLINK-V3-BRIDGE)的控制功能,就要搞清楚ST软件的协议,还是很麻烦的。自己写一个出来,又要连上位机软件都要写。 主要还是觉得用处不大。
. F# v( v) a8 g3 W9 Q4 d也想过用GPIO搞一个逻辑分析仪,后来发现自己做的性能不如20多元TB买的那种。
+ b; n& k) ~4 e6 j3 \3 L2 v: a% L" N2 E& j$ |$ p3 _- L; [
始终没有想好如何利用起来那些个GPIO/I2C/SPI/CAN/ADC。。。。
关于意法半导体
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
招聘信息
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
关注我们
st-img 微信公众号
st-img 手机版