Error: unable to find a matching CMSIS-DAP device

1.问题定位

ubuntu下开发GD32,通过vscode的插件cortex-debug+openocd+GD-Link调试GD32遇到问题。问题如下:

openocd -s "/opt/openocd-0.12.0-4/openocd/scripts/" -f "./openocd/gd32f470_cmsis_dap.cfg" 
xPack Open On-Chip Debugger 0.12.0+dev-01685-gb9224c0c0-dirty (2024-08-02-19:50)
Licensed under GNU GPL v2
For bug reports, read
        http://openocd.org/doc/doxygen/bugs.html
Info : DEPRECATED target event trace-config; use TPIU events {pre,post}-{enable,disable}
Info : Listening on port 6666 for tcl connections
Info : Listening on port 4444 for telnet connections
Error: unable to open CMSIS-DAP device 0x28e9:0x58f
Error: unable to find a matching CMSIS-DAP device

使用sudo命令是没找到openocd命令,将openocd加入sudo的环境变量中。

sudo visudo

找到 secure_path 配置行,在其后增加/opt/openocd-0.12.0-4/bin

Defaults        secure_path="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/snap/bin:/opt/openocd-0.12.0-4/bin"

执行openocd命令连接GD_Link调试器,用sudo权限:

sudo openocd -s "/opt/openocd-0.12.0-4/openocd/scripts/" -f "./openocd/gd32f470_cmsis_dap.cfg" 
xPack Open On-Chip Debugger 0.12.0+dev-01685-gb9224c0c0-dirty (2024-08-02-19:50)
Licensed under GNU GPL v2
For bug reports, read
        http://openocd.org/doc/doxygen/bugs.html
Info : DEPRECATED target event trace-config; use TPIU events {pre,post}-{enable,disable}
Info : Listening on port 6666 for tcl connections
Info : Listening on port 4444 for telnet connections
Info : CMSIS-DAP: SWD supported
Info : CMSIS-DAP: JTAG supported
Info : CMSIS-DAP: Atomic commands supported
Info : CMSIS-DAP: Test domain timer supported
Info : CMSIS-DAP: FW Version = 2.0.0
Info : CMSIS-DAP: Interface Initialised (SWD)
Info : SWCLK/TCK = 1 SWDIO/TMS = 1 TDI = 1 TDO = 1 nTRST = 0 nRESET = 1
Info : CMSIS-DAP: Interface ready
Info : clock speed 2000 kHz
Info : SWD DPIDR 0x2ba01477
Info : [gd32f4xx.cpu] Cortex-M4 r0p1 processor detected
Info : [gd32f4xx.cpu] target has 6 breakpoints, 4 watchpoints
Info : [gd32f4xx.cpu] Examination succeed
Info : [gd32f4xx.cpu] starting gdb server on 3333
Info : Listening on port 3333 for gdb connections

不用sudo权限时

openocd -s "/opt/openocd-0.12.0-4/openocd/scripts/" -f "./openocd/gd32f470_cmsis_dap.cfg" 
xPack Open On-Chip Debugger 0.12.0+dev-01685-gb9224c0c0-dirty (2024-08-02-19:50)
Licensed under GNU GPL v2
For bug reports, read
        http://openocd.org/doc/doxygen/bugs.html
Info : DEPRECATED target event trace-config; use TPIU events {pre,post}-{enable,disable}
Info : Listening on port 6666 for tcl connections
Info : Listening on port 4444 for telnet connections
Error: unable to open CMSIS-DAP device 0x28e9:0x58f
Error: unable to find a matching CMSIS-DAP device

查看cmsis-dap设备的权限,cmsis-dap是hid设备,在/dev下表现为hidraw*

ls -l /dev/hidraw*
crw------- 1 root root 241, 0 11月 15 18:46 /dev/hidraw0
crw------- 1 root root 241, 1 11月 15 19:33 /dev/hidraw1

确实只有root权限。

2.修改设备权限

2.1创建 udev 规则

在 /etc/udev/rules.d/ 目录下创建一个新的 udev 规则文件,如 99-cmsis-dap.rules,并将以下内容添加到该文件中。

sudo vim /etc/udev/rules.d/99-cmsis-dap.rules 
SUBSYSTEM=="hidraw", ATTRS{idVendor}=="28e9", ATTRS{idProduct}=="058f", MODE="0666"
xendless@ubuntu22:~/ohos/openharmony-4.1-release$ lsusb
Bus 002 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub
Bus 001 Device 008: ID 28e9:058f GDMicroelectronics CMSIS-DAP
Bus 001 Device 002: ID 80ee:0021 VirtualBox USB Tablet
Bus 001 Device 001: ID 1d6b:0001 Linux Foundation 1.1 root hub

28e9:058f中28e9为idVendor,258f为idProduct。

2.2重载 udev 规则: 创建完规则后,重新加载 udev 规则:

sudo udevadm control --reload-rules

重新插拔cmsis-dap调试器。

ls -l /dev/hidraw*
crw------- 1 root root 241, 0 11月 15 18:46 /dev/hidraw0
crw-rw-rw- 1 root root 241, 1 11月 15 19:50 /dev/hidraw1

权限发生变化。
再次执行openocd命令

openocd -c "gdb_port 50000" -c "tcl_port 50001" -c "telnet_port 50002" -s /opt/openocd-0.12.0-4/openocd/scripts -f /home/xendless/.vscode-server/extensions/marus25.cortex-debug-1.12.1/support/openocd-helpers.tcl -f /home/xendless/ohos/openharmony-4.1-release/openocd/gd32f470_cmsis_dap.cfg
xPack Open On-Chip Debugger 0.12.0+dev-01685-gb9224c0c0-dirty (2024-08-02-19:50)
Licensed under GNU GPL v2
For bug reports, read
        http://openocd.org/doc/doxygen/bugs.html
DEPRECATED! use 'gdb port', not 'gdb_port'
DEPRECATED! use 'tcl port' not 'tcl_port'
CDLiveWatchSetup
Info : DEPRECATED target event trace-config; use TPIU events {pre,post}-{enable,disable}
Info : Listening on port 50001 for tcl connections
Info : Listening on port 50002 for telnet connections
Info : CMSIS-DAP: SWD supported
Info : CMSIS-DAP: JTAG supported
Info : CMSIS-DAP: Atomic commands supported
Info : CMSIS-DAP: Test domain timer supported
Info : CMSIS-DAP: FW Version = 2.0.0
Info : CMSIS-DAP: Interface Initialised (SWD)
Info : SWCLK/TCK = 1 SWDIO/TMS = 1 TDI = 1 TDO = 1 nTRST = 0 nRESET = 1
Info : CMSIS-DAP: Interface ready
Info : clock speed 2000 kHz
Info : SWD DPIDR 0x2ba01477
Info : [gd32f4xx.cpu] Cortex-M4 r0p1 processor detected
Info : [gd32f4xx.cpu] target has 6 breakpoints, 4 watchpoints
Info : [gd32f4xx.cpu] Examination succeed
Info : [gd32f4xx.cpu] starting gdb server on 50000
Info : Listening on port 50000 for gdb connections

问题解决。

3.总结

问题出在cmsis-dap设备只有root权限,没有用户权限。

4.测试

之后按F5进入调试状态。


cmsis-dap.png

相关的.cfg文件见git仓库

虽然写的有点随意,如果觉得有用,帮忙点个赞,感谢!

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,635评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,628评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,971评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,986评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,006评论 6 394
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,784评论 1 307
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,475评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,364评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,860评论 1 317
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,008评论 3 338
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,152评论 1 351
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,829评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,490评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,035评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,156评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,428评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,127评论 2 356

推荐阅读更多精彩内容

  • 熟悉RT-Thread的朋友都知道,RT-Thread提供了许多BSP,但不是所有的板子都能找到相应的BSP,这时...
    BruceOu阅读 374评论 0 1
  • 一、新建本地工程文件夹 为了工程目录更加清晰,我们在本地电脑上新建一个“工程模板”文件夹,在它之下再新建 6 个文...
    Leung_ManWah阅读 1,645评论 0 2
  • STLINK虽然是个闭源的JTAG/SWD工具,但是用途却被工程师们扩展了很多,甚至比开源的CMSIS-DAP/D...
    小鱼儿他老汉阅读 3,144评论 0 8
  • 目录 作为一名PHP开发者,我们一定要懂得如何搭建PHP开发环境,目前主流的PHP开发环境组合是LAMP和LNMP...
    23世纪阅读 1,102评论 0 0
  • 一、目录结构 目录说明/binBinary的缩写,这个目录存放最经常使用的命令;/sbins就是Super Use...
    CJ21阅读 1,627评论 0 15