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

【源码】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,直接就无法识别了。。。( x) \( B( X; [, Z
我的程序是官方最新的0254版本,不知道楼主的V2.0.0是什么版本
电路.png
官方源码.png
radio2radio 回答时间:2019-9-30 12:53:38
刚好我最近也在为STLINK-V3MINI,移植DAPLink的事情伤脑筋,看了一下DAPLink的源码,许多事情还不是很了解。
" q  I% f. x4 L7 e- I! u$ G8 N9 J
要改高速USB,首先你的硬件要没有问题,比如说我的STLINK-V3原来就是内置高速USB接口的。 我在CubeMX开个高速的VCP项目,很容易就验证了硬件。 建议您也试一试。
- p2 B- M* G9 v' d
6 e. L6 _7 o3 e. v( M) Y. k% h不知你用什么MCU,DAPLink里面有没有人用过。7 r$ N, W2 J4 o

) G3 e1 I4 Y' [6 h7 Y软件方面,先改usbd_hw.h里面的底层驱动的函数,用你的高速USB库实现,如果有现成的,就省事了。
  C, b( Z/ u- |6 H7 W开通高速,要到usb_config.c文件里面修改配置,可以参考已经搞好的高速项目,比如k26f 和sam3u2c。
, i8 j9 O# C8 ], R6 u# ~; F6 R  v
radio2radio 回答时间:2019-9-30 13:14:36
mcu_i 发表于 2019-9-30 11:57
. G8 S1 E" N) R: s0 |' E1 M) x( Y楼主好,我做了一个daplink,遇到这样一个问题,就是目前是全速设备,想改成高速设备,电路仿照别人的,在D ...

) |) O- K/ @0 g6 g' A" U" l接上面的回复。 版本号的问题,( R, j( g( r, j, b0 T
; E: Y7 j, _3 m
CMSIS-DAP 有2个版本在用:v1.1.0(DAPLink用的),v2.0.0(增加了SWO_STREAM模式等)
9 f% f/ [7 q3 a+ U
* [; b7 }8 I1 J. lDAPLink的版本号,0254是最新版的。
& \0 v- f$ u# [. P% S- I0 C* p5 C
4 c! z# y( a% m9 m! F: \, [) h还有一个经常提到的CMSIS-DAP v1,这个是指HID模式的。 CMSIS-DAP v2是指WinUSB模式的。
飞跃-344154 回答时间:2019-10-2 21:58:57
不错,值得一试
radio2radio 回答时间:2019-10-10 00:07:31
关于DAPLink的思考,& P, W7 h) e. r5 C) q, r3 F
由于很想将现在的DAPLink移植到STLINK-V3MINI硬件上面,仔细研究了一下DAPLink的源代码。 说实话,我没有使用过DAPLink,随着对DAPLink理念的深入理解,我发现移植DAPLink到独立的硬件上面,比如这个STLINK-V3MINI,意义不大。 现决定放弃。
/ J4 x( H, v5 M. c' W. w& X( ^6 ~, r. D
DAPLink是CMSIS-DAP的延申,主要是用于IC厂家在推广一款MCU时提供的开发板/演示板上面使用。功能类似于STLINK在STM32各种开发板上面所提供的辅助开发接口。- D2 U% e* y8 w1 Q, h

% J( n- n3 j! d& v% u2 U- L1- DAPLink的控制IC,内部称为HIC,常见的是K20DX, LPC11U35, STM32F103等等。 HIC主要功能是运行CMSIS-DAP,具有USB-MSC自我更新能力,和拖拽下载目标板程序的功能,新版本具有WebUSB下载目标程序的功能。
# o7 n+ O$ o, @4 z8 c
: B) T8 @4 [9 R: S% }. _8 ^( ?2- DAPLink可以提供一种标准的上位机可控的下载接口,开发板供应商,第三方上位机软件开发商,可以包装成各种傻瓜式的开发环境。 目的是令整个系统容易使用,特别是给儿童使用。这与我们经常使用的IDE不是一码事儿。
, @- G1 f: H* w% h, w  q& i. d- L  j" O
3- DAPLink控制板,通常要与目标板一起提供给终端使用者,一般没有单独的设备出售。 因为不同的目标板MCU不同,MCU程序的下载算法也不同,这就使得DAPLink的控制软件也不同,虽然有USB-MSC自我更新能力, 也不能很方便地像JLINK/STLINK/CMSIS-DAP那样在不同的IC之间转换。
: i# l9 r3 q, U# L8 o0 I
6 G/ g& F6 n( Z1 _3 k1 |5 B% F3 ~4- DAPLink所用的HIC要便宜,固件要成熟。 这一点对开发板厂商很重要。 是不是USB2.0高速(高速的价格贵好几倍),不重要。
5 f; X& |, K$ h* ^2 a4 K* r; i; d8 l% J$ Z' m0 e4 X# o+ R

7 D! C6 \0 `  e" O1 `1 R所以我..........放弃移植DAPLink,不搞了。 有时间继续优化CMSIS-DAP。6 N, P, }4 g9 ^' q4 O2 }
顺便说一下, 使用独立的CMSIS-DAP, 特别是这个高速版的,很好用。
" q; [; j3 d" E5 @; n7 |! ~- g. q  y' a) o+ N2 e4 G
mcu_i 回答时间:2019-10-17 23:25:56
radio2radio 发表于 2019-9-30 12:535 H; p' p, N" U2 S! @3 S% f
刚好我最近也在为STLINK-V3MINI,移植DAPLink的事情伤脑筋,看了一下DAPLink的源码,许多事情还不是很了解 ...

- s+ Y9 d1 g0 l4 q) O  @感谢楼主,找了一些资料后我现在搞明白了,我那个电路应该是不能实现高速USB,必须加高速USB的芯片才可以。
/ B9 z& |, d$ Q) V  A# A% w9 \最近我在研究关闭daplink一键拖拽下载的功能,也就是使其连接电脑后不显示U盘,改了源码里面带着dsiable、msd之类字眼的变量,都不管用,楼主有没有这方面的经验?谢谢
radio2radio 回答时间:2019-10-18 00:17:09
mcu_i 发表于 2019-10-17 23:25; G4 V" R1 s2 h6 R0 A5 X+ j
感谢楼主,找了一些资料后我现在搞明白了,我那个电路应该是不能实现高速USB,必须加高速USB的芯片才可以 ...
+ n( e, x; {" U4 n
我没有这方面经验,不过不知道您为什么要去掉这个拖拽下载功能,不用摆在那里不行吗。 拖拽下载功能,是有很严格的要求的,不是自己的代码,不能刷的呀。
Nikola 回答时间:2019-10-29 13:09:48
STM32F723IEK6 太贵了。。。
radio2radio 回答时间:2019-10-29 13:39:01
秦秦秦 发表于 2019-10-29 13:090 h( b2 Y  _8 x
STM32F723IEK6 太贵了。。。
3 F8 m8 w+ i* f& l# Y  h
买IC如果数量不大,当然贵啦。
; i/ }2 E; ]' y& k" Y: J
7 T! t. Q' L+ A/ A1 j4 _自己用,建议您买2个STLINK-V3MINI,一个不动,一个改装。
Nikola 回答时间:2019-11-6 11:12:39
radio2radio 发表于 2019-10-29 13:397 d' u; S; v2 `, ]' Y8 K& ~
买IC如果数量不大,当然贵啦。
! }  q6 C7 B, P1 E& W: a. T( V) T* e1 W1 L; r% i7 Q
自己用,建议您买2个STLINK-V3MINI,一个不动,一个改装。 ...

" B; ^& k% F& H+ `, d, X9 T谢谢您的建议
radio2radio 回答时间:2019-11-9 20:25:57
今天搞定了AC6的优化问题,原来是CMSIS-DAP源码的一个已知的小Bug,底层定时部分会随着选择不同的优化等级而有变化。 在大多数的情况下,不影响使用。 所以ARM方面也不急于改正。
: \) ^1 B6 S- _9 Z9 c7 Q(1楼源码已更新)
radio2radio 回答时间:2019-11-30 12:35:39
今天又做了重要更新,速度更加快了,在Keil里面设定SW速度为10MHz,实际SWCLK可以达到8MHz。
# |1 w& h/ q) B5 F+ E4 Q9 z7 p/ y5 q3 ^
其实,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:019 v5 `' N+ `  T( _- [- B1 T
边缘那些GPIO可能可以通过bridge(STLINK-V3-BRIDGE)控制?不过就算这样,也要上位机才行 ...

9 w% X* J$ f$ b+ _3 E5 l这个功能是需要上位机软件支持,ST已经有软件,但是只支持原装的STLINK-V3MINI。; q9 f7 v# ^  K( \" c
改装后的CMSIS-DAP,这些GPIOs可以利用做好多事情。
) p' J% c6 a1 N; Q2 q, r) d* t( C6 c& H
复制出(STLINK-V3-BRIDGE)的控制功能,就要搞清楚ST软件的协议,还是很麻烦的。自己写一个出来,又要连上位机软件都要写。 主要还是觉得用处不大。
: U9 x3 j3 a$ q6 v9 y4 O0 r8 x也想过用GPIO搞一个逻辑分析仪,后来发现自己做的性能不如20多元TB买的那种。
4 c5 |3 t7 ^' A' C7 Z2 s) c2 Q7 ^/ ~- h  M; X5 r
始终没有想好如何利用起来那些个GPIO/I2C/SPI/CAN/ADC。。。。
关于意法半导体
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
招聘信息
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
关注我们
st-img 微信公众号
st-img 手机版