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

【源码】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,直接就无法识别了。。。' U, X4 Q, [% O' z0 h3 Z' W
我的程序是官方最新的0254版本,不知道楼主的V2.0.0是什么版本
电路.png
官方源码.png
radio2radio 回答时间:2019-9-30 12:53:38
刚好我最近也在为STLINK-V3MINI,移植DAPLink的事情伤脑筋,看了一下DAPLink的源码,许多事情还不是很了解。6 T3 Q8 [9 w. ^3 a! E; s" c8 N

! s- c4 Y( P3 V. b% y1 w3 ^7 A要改高速USB,首先你的硬件要没有问题,比如说我的STLINK-V3原来就是内置高速USB接口的。 我在CubeMX开个高速的VCP项目,很容易就验证了硬件。 建议您也试一试。
" X* l$ n/ r/ I+ S* ]4 l1 s* y; \& Y" |8 R# @
不知你用什么MCU,DAPLink里面有没有人用过。$ L, X% M5 T  |( n, t' {

2 Y! ~& k0 e, r" N" x软件方面,先改usbd_hw.h里面的底层驱动的函数,用你的高速USB库实现,如果有现成的,就省事了。
7 P! T! K8 s7 Y8 F" G开通高速,要到usb_config.c文件里面修改配置,可以参考已经搞好的高速项目,比如k26f 和sam3u2c。
' R* |# u) W" L" @; X/ {( A6 `5 c! I( b
radio2radio 回答时间:2019-9-30 13:14:36
mcu_i 发表于 2019-9-30 11:57* G3 K& J5 O/ }0 z% @2 u1 ^3 H! d
楼主好,我做了一个daplink,遇到这样一个问题,就是目前是全速设备,想改成高速设备,电路仿照别人的,在D ...

: T6 P: \8 g  f2 i% a接上面的回复。 版本号的问题,! w( a3 N6 e, z/ Y

% D/ c( w$ `8 w' F( b' eCMSIS-DAP 有2个版本在用:v1.1.0(DAPLink用的),v2.0.0(增加了SWO_STREAM模式等)
- Y6 A$ e9 D" D9 W+ r  U$ S9 t
; p% k, q* W8 jDAPLink的版本号,0254是最新版的。
1 V& f9 [7 `  a* s! I
/ B7 L  @1 z5 e# F还有一个经常提到的CMSIS-DAP v1,这个是指HID模式的。 CMSIS-DAP v2是指WinUSB模式的。
飞跃-344154 回答时间:2019-10-2 21:58:57
不错,值得一试
radio2radio 回答时间:2019-10-10 00:07:31
关于DAPLink的思考,4 @5 G: G" ?- R. e7 P
由于很想将现在的DAPLink移植到STLINK-V3MINI硬件上面,仔细研究了一下DAPLink的源代码。 说实话,我没有使用过DAPLink,随着对DAPLink理念的深入理解,我发现移植DAPLink到独立的硬件上面,比如这个STLINK-V3MINI,意义不大。 现决定放弃。
/ ^0 v8 D  X; K6 p& j6 T. w* ?2 H$ m- G( v8 V
DAPLink是CMSIS-DAP的延申,主要是用于IC厂家在推广一款MCU时提供的开发板/演示板上面使用。功能类似于STLINK在STM32各种开发板上面所提供的辅助开发接口。- O  O- r, e* p* \
* J$ k% H5 ^5 z
1- DAPLink的控制IC,内部称为HIC,常见的是K20DX, LPC11U35, STM32F103等等。 HIC主要功能是运行CMSIS-DAP,具有USB-MSC自我更新能力,和拖拽下载目标板程序的功能,新版本具有WebUSB下载目标程序的功能。  J+ F: t* s, [7 x& [7 ~

/ _. y1 y9 I0 H2- DAPLink可以提供一种标准的上位机可控的下载接口,开发板供应商,第三方上位机软件开发商,可以包装成各种傻瓜式的开发环境。 目的是令整个系统容易使用,特别是给儿童使用。这与我们经常使用的IDE不是一码事儿。! b2 j" [' l5 C- s
7 E6 Q& m* C! T9 ]! ~2 N
3- DAPLink控制板,通常要与目标板一起提供给终端使用者,一般没有单独的设备出售。 因为不同的目标板MCU不同,MCU程序的下载算法也不同,这就使得DAPLink的控制软件也不同,虽然有USB-MSC自我更新能力, 也不能很方便地像JLINK/STLINK/CMSIS-DAP那样在不同的IC之间转换。
/ q- Z3 n; n' A" }' p" b# |8 `2 N+ y! T! [5 W4 @
4- DAPLink所用的HIC要便宜,固件要成熟。 这一点对开发板厂商很重要。 是不是USB2.0高速(高速的价格贵好几倍),不重要。, W4 i) F8 w6 e' p0 x: Q, w. z) M3 Z1 C
2 P0 G4 U/ [* j2 _& r0 n% C
3 M( C# R4 n9 w. c7 F: X) ]
所以我..........放弃移植DAPLink,不搞了。 有时间继续优化CMSIS-DAP。. S+ n4 v' P' h0 p7 k
顺便说一下, 使用独立的CMSIS-DAP, 特别是这个高速版的,很好用。2 }1 H  E. t& A- Q0 M& h# q
8 N6 M- p: l, C+ E$ a
mcu_i 回答时间:2019-10-17 23:25:56
radio2radio 发表于 2019-9-30 12:53. T- f  {1 w' y9 ?8 x- J" A' D1 }
刚好我最近也在为STLINK-V3MINI,移植DAPLink的事情伤脑筋,看了一下DAPLink的源码,许多事情还不是很了解 ...
! Z2 c9 K# Q) w
感谢楼主,找了一些资料后我现在搞明白了,我那个电路应该是不能实现高速USB,必须加高速USB的芯片才可以。& L3 v9 O* C6 F9 j+ F
最近我在研究关闭daplink一键拖拽下载的功能,也就是使其连接电脑后不显示U盘,改了源码里面带着dsiable、msd之类字眼的变量,都不管用,楼主有没有这方面的经验?谢谢
radio2radio 回答时间:2019-10-18 00:17:09
mcu_i 发表于 2019-10-17 23:25
) h+ Z' l: O) Z感谢楼主,找了一些资料后我现在搞明白了,我那个电路应该是不能实现高速USB,必须加高速USB的芯片才可以 ...

" s  u* I) e+ B% B我没有这方面经验,不过不知道您为什么要去掉这个拖拽下载功能,不用摆在那里不行吗。 拖拽下载功能,是有很严格的要求的,不是自己的代码,不能刷的呀。
Nikola 回答时间:2019-10-29 13:09:48
STM32F723IEK6 太贵了。。。
radio2radio 回答时间:2019-10-29 13:39:01
秦秦秦 发表于 2019-10-29 13:09
8 e" [' C1 C) i# A8 }' |# VSTM32F723IEK6 太贵了。。。
7 z4 C9 H  j/ R% x* v3 w( }
买IC如果数量不大,当然贵啦。) _6 |8 c3 ^3 N

4 R/ j& e0 Y6 B4 L, P自己用,建议您买2个STLINK-V3MINI,一个不动,一个改装。
Nikola 回答时间:2019-11-6 11:12:39
radio2radio 发表于 2019-10-29 13:394 _2 e% m& Q, [! n; A
买IC如果数量不大,当然贵啦。; ~3 B) q4 ~+ I% |# A( {" F9 R* b2 n7 L6 t
2 l% K+ L; H# s% e
自己用,建议您买2个STLINK-V3MINI,一个不动,一个改装。 ...

; `0 Y# v8 s2 F, J谢谢您的建议
radio2radio 回答时间:2019-11-9 20:25:57
今天搞定了AC6的优化问题,原来是CMSIS-DAP源码的一个已知的小Bug,底层定时部分会随着选择不同的优化等级而有变化。 在大多数的情况下,不影响使用。 所以ARM方面也不急于改正。  X' L9 m# P$ Q& ^  {% F  j8 J6 S
(1楼源码已更新)
radio2radio 回答时间:2019-11-30 12:35:39
今天又做了重要更新,速度更加快了,在Keil里面设定SW速度为10MHz,实际SWCLK可以达到8MHz。
( F% F9 _  c/ w$ d- b: b) n
: ^4 R) B! `% u3 h其实,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
" T1 l! V" U3 y9 I; @& {: e边缘那些GPIO可能可以通过bridge(STLINK-V3-BRIDGE)控制?不过就算这样,也要上位机才行 ...
7 h5 |2 B: K* K* x9 v1 e6 m9 H* |
这个功能是需要上位机软件支持,ST已经有软件,但是只支持原装的STLINK-V3MINI。
& [1 v7 g/ Q0 t- t5 f9 Z! V+ _% ?( J改装后的CMSIS-DAP,这些GPIOs可以利用做好多事情。
5 r7 `* I7 Z5 U: ]1 {7 `
' S; E4 t$ p# T" z" q7 r复制出(STLINK-V3-BRIDGE)的控制功能,就要搞清楚ST软件的协议,还是很麻烦的。自己写一个出来,又要连上位机软件都要写。 主要还是觉得用处不大。( _" U" O" H- ]8 n* {3 }" A
也想过用GPIO搞一个逻辑分析仪,后来发现自己做的性能不如20多元TB买的那种。; |! @: |+ W/ H  @( X; x4 F- V
4 i" G$ o5 y1 T, T: B# Q- Z4 c
始终没有想好如何利用起来那些个GPIO/I2C/SPI/CAN/ADC。。。。
关于意法半导体
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
招聘信息
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
关注我们
st-img 微信公众号
st-img 手机版