Error: unable to find a matching CMSIS-DAP device

1.問題定位

ubuntu下開發(fā)GD32杏慰,通過vscode的插件cortex-debug+openocd+GD-Link調(diào)試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的環(huán)境變量中阱冶。

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"

執(zhí)行openocd命令連接GD_Link調(diào)試器,用sudo權(quán)限:

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權(quán)限時

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設(shè)備的權(quán)限岩喷,cmsis-dap是hid設(shè)備,在/dev下表現(xiàn)為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權(quán)限监憎。

2.修改設(shè)備權(quán)限

2.1創(chuàng)建 udev 規(guī)則

在 /etc/udev/rules.d/ 目錄下創(chuàng)建一個新的 udev 規(guī)則文件纱意,如 99-cmsis-dap.rules,并將以下內(nèi)容添加到該文件中鲸阔。

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 規(guī)則: 創(chuàng)建完規(guī)則后褐筛,重新加載 udev 規(guī)則:

sudo udevadm control --reload-rules

重新插拔cmsis-dap調(diào)試器类少。

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

權(quán)限發(fā)生變化。
再次執(zhí)行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.總結(jié)

問題出在cmsis-dap設(shè)備只有root權(quán)限硫狞,沒有用戶權(quán)限。

4.測試

之后按F5進入調(diào)試狀態(tài)晃痴。


cmsis-dap.png

相關(guān)的.cfg文件見git倉庫

雖然寫的有點隨意残吩,如果覺得有用,幫忙點個贊倘核,感謝泣侮!

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市紧唱,隨后出現(xiàn)的幾起案子活尊,更是在濱河造成了極大的恐慌,老刑警劉巖漏益,帶你破解...
    沈念sama閱讀 212,718評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蛹锰,死亡現(xiàn)場離奇詭異,居然都是意外死亡遭庶,警方通過查閱死者的電腦和手機宁仔,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,683評論 3 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來峦睡,“玉大人翎苫,你說我怎么就攤上這事权埠。” “怎么了煎谍?”我有些...
    開封第一講書人閱讀 158,207評論 0 348
  • 文/不壞的土叔 我叫張陵攘蔽,是天一觀的道長。 經(jīng)常有香客問我呐粘,道長满俗,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,755評論 1 284
  • 正文 為了忘掉前任作岖,我火速辦了婚禮唆垃,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘痘儡。我一直安慰自己辕万,他們只是感情好,可當我...
    茶點故事閱讀 65,862評論 6 386
  • 文/花漫 我一把揭開白布沉删。 她就那樣靜靜地躺著渐尿,像睡著了一般。 火紅的嫁衣襯著肌膚如雪矾瑰。 梳的紋絲不亂的頭發(fā)上砖茸,一...
    開封第一講書人閱讀 50,050評論 1 291
  • 那天,我揣著相機與錄音殴穴,去河邊找鬼凉夯。 笑死,一個胖子當著我的面吹牛推正,可吹牛的內(nèi)容都是我干的恍涂。 我是一名探鬼主播宝惰,決...
    沈念sama閱讀 39,136評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼植榕,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了尼夺?” 一聲冷哼從身側(cè)響起尊残,我...
    開封第一講書人閱讀 37,882評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎淤堵,沒想到半個月后寝衫,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,330評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡拐邪,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,651評論 2 327
  • 正文 我和宋清朗相戀三年慰毅,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片扎阶。...
    茶點故事閱讀 38,789評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡汹胃,死狀恐怖婶芭,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情着饥,我是刑警寧澤犀农,帶...
    沈念sama閱讀 34,477評論 4 333
  • 正文 年R本政府宣布,位于F島的核電站宰掉,受9級特大地震影響呵哨,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜轨奄,卻給世界環(huán)境...
    茶點故事閱讀 40,135評論 3 317
  • 文/蒙蒙 一孟害、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧挪拟,春花似錦纹坐、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,864評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至球切,卻和暖如春谷誓,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背吨凑。 一陣腳步聲響...
    開封第一講書人閱讀 32,099評論 1 267
  • 我被黑心中介騙來泰國打工捍歪, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人鸵钝。 一個月前我還...
    沈念sama閱讀 46,598評論 2 362
  • 正文 我出身青樓糙臼,卻偏偏與公主長得像,于是被迫代替她去往敵國和親恩商。 傳聞我的和親對象是個殘疾皇子变逃,可洞房花燭夜當晚...
    茶點故事閱讀 43,697評論 2 351

推薦閱讀更多精彩內(nèi)容

  • 熟悉RT-Thread的朋友都知道,RT-Thread提供了許多BSP怠堪,但不是所有的板子都能找到相應的BSP揽乱,這時...
    BruceOu閱讀 368評論 0 1
  • 一、新建本地工程文件夾 為了工程目錄更加清晰粟矿,我們在本地電腦上新建一個“工程模板”文件夾凰棉,在它之下再新建 6 個文...
    Leung_ManWah閱讀 1,596評論 0 2
  • STLINK雖然是個閉源的JTAG/SWD工具,但是用途卻被工程師們擴展了很多陌粹,甚至比開源的CMSIS-DAP/D...
    小魚兒他老漢閱讀 3,135評論 0 8
  • 目錄 作為一名PHP開發(fā)者撒犀,我們一定要懂得如何搭建PHP開發(fā)環(huán)境,目前主流的PHP開發(fā)環(huán)境組合是LAMP和LNMP...
    23世紀閱讀 1,086評論 0 0
  • 一、目錄結(jié)構(gòu) 目錄說明/binBinary的縮寫或舞,這個目錄存放最經(jīng)常使用的命令隧膏;/sbins就是Super Use...
    CJ21閱讀 1,608評論 0 15