0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

什么是DAP協(xié)議?DAP如何工作?詳解deepin-IDE中的調(diào)試功能

OSC開源社區(qū) ? 來源:OSCHINA 社區(qū) ? 2023-11-10 16:46 ? 次閱讀

作者:deepin-mozart、toberyan


前不久深度科技旗下 deepin 社區(qū)發(fā)布了自己的 IDE:deepin-IDE,得到了全網(wǎng)用戶尤其是開源社區(qū)用戶的廣泛關(guān)注,目前在 GitHub倉庫的 star 數(shù)量已經(jīng)達到 600 多個,說明大家的熱情還是很高漲的。

為了從技術(shù)層面給大家的熱情做一個反饋,本文試著將 deepin-IDE 內(nèi)部的一些實現(xiàn)方法進行分享,希望能夠解答友友們的疑惑并得到積極的反饋。

本篇挑了大家關(guān)心的 “調(diào)試” 部分進行分享。需要說明的是,deepin-IDE 的調(diào)試功能是選用 DAP(Debug Adapter Protocol )調(diào)試適配協(xié)議實現(xiàn)的,所以整體架構(gòu)是圍繞該協(xié)議搭建的,至于DAP具體是什么,讓我們帶著問號往下看。

什么是DAP協(xié)議

DAP即調(diào)試適配協(xié)議 (Debug Adapter Protocol),顧名思義,它是用來對多種調(diào)試器進行抽象統(tǒng)一的適配層,將原有IDE和調(diào)試工具直接交互的模式更改為和DAP進行交互。該模式可以讓IDE集成多種調(diào)試器變得更簡單,且靈活性更好。

在IDE中的調(diào)試功能有許多小功能組成,包括單步執(zhí)行、斷點、查看變量值等,常規(guī)的實現(xiàn)方式是在每個IDE中去實現(xiàn)這些邏輯,且因為調(diào)試工具的接口不同,還需要為每個調(diào)試工具做一些適配工作,這將導(dǎo)致大量且重復(fù)的工作,如下圖所示:

6ee9c6c8-7eef-11ee-939d-92fbcf53809c.png




調(diào)試適配器協(xié)議背后的想法是標(biāo)準(zhǔn)化一個抽象協(xié)議,用于開發(fā)工具如何與具體調(diào)試器通信。這個思想和LSP(Language Server Protocol) 和BSP(Build Server Protocol) 類似,都是通過協(xié)議去統(tǒng)一相同功能在不同工具之間的差異性。其所處位置如下圖所示,其中左邊為不同的開發(fā)工具,右邊為不能同的調(diào)試器,不同于開發(fā)工具和調(diào)試器直接交互的方式,DAP將這些交互統(tǒng)一了起來,讓開發(fā)工具和調(diào)試工具都面向DAP編程。

上圖中的交互是通過協(xié)議進行,所以不會像通過API的方式存在語言限制,可以更好的適應(yīng)調(diào)試器的集成。

DAP 如何工作

以下部分解釋了開發(fā)工具(例如IDE或編輯器)和調(diào)試適配器之間的交互,包括具體的協(xié)議格式說明、交互流程等。

調(diào)試會話

開發(fā)工具有兩種基礎(chǔ)的方式和調(diào)試器進行交互,分別是:

【單會話模式】 在這種模式下,開發(fā)工具啟動一個調(diào)試適配器作為一個單獨的進程并且通過標(biāo)準(zhǔn)的 std 接口進行通信。在調(diào)試會話的結(jié)束時調(diào)試適配器就終止,對于當(dāng)前的調(diào)試會話,開發(fā)工具往往需要實現(xiàn)多個調(diào)試適配。

【多會話模式】

在這種模式下,開發(fā)工具不會啟動調(diào)試適配器,而是假定它已經(jīng)在運行并且會在特定端口上偵聽連接嘗試,對于每個調(diào)試會話,開發(fā)工具在特定端口上啟動一個新的通信會話并在會話結(jié)束時斷開連接。

在與調(diào)試適配器建立連接后,開發(fā)工具和調(diào)試適配器之間通過基礎(chǔ)協(xié)議進行通信。

基礎(chǔ)協(xié)議

基礎(chǔ)協(xié)議由兩部分組成,包括頭和內(nèi)容 (類似于 HTTP),頭部和內(nèi)容部分通過 “ ” 進行分割:
【協(xié)議頭】


協(xié)議頭部分由字段組成, 每個頭字段由一個鍵和一個值組成,用‘:’(一個冒號和一個空格)分隔, 每個頭字段都以 “ “結(jié)尾。由于最后一個協(xié)議頭字段和整個協(xié)議頭本身都以 終止,并且由于協(xié)議頭是強制性的,所以消息的內(nèi)容部分總是在(并唯一標(biāo)識)兩個 序列之前。當(dāng)前只支持一個協(xié)議頭字段:

Content-Length 數(shù)字 這個字段是必須的,用來記錄內(nèi)容字段的長度,單位是字節(jié)。
頭字段名 值類型 描述


協(xié)議頭部分使用的是 “ASCII” 編碼。

【內(nèi)容部分】

內(nèi)容部分包含了實際要傳輸?shù)臄?shù)據(jù),這些數(shù)據(jù)用JSON格式來描述請求、響應(yīng)和事件。內(nèi)容部分用的是utf-8編碼

為了有個具體的認(rèn)識,這里舉個簡單的例子。在調(diào)試過程中,開發(fā)人員經(jīng)常會使用到下一步操作,在DAP中其協(xié)議為:

Content-Length: 119



{
  "seq": 153,
  "type": "request",
  "command": "next",
  "arguments": {
    "threadId": 3
   }
}
類型是 “請求”,命令是下一步,參數(shù)部分可以攜帶多個,這里是用的線程 Id。這個協(xié)議看著挺簡單的,是吧?接下來就講講如何使用它。


使用方法


詳細(xì)的使用方法這里就不涉及,因為用一個時序圖就可以說明:

6f01278c-7eef-11ee-939d-92fbcf53809c.png


可以看到,初始化、請求、響應(yīng)等必要的步驟都在圖中。其中調(diào)試適配器可以理解為調(diào)試器的抽象,調(diào)試功能的最終執(zhí)行者是由對應(yīng)語言的調(diào)試工具實現(xiàn)的。



在 deepin-IDE 中的實現(xiàn)


在 deepin-IDE 中,調(diào)試功能的實現(xiàn)是結(jié)合cppdap+debugmanager實現(xiàn)的。

cppdap是一款基于 C++ 開發(fā)的SDK,基本實現(xiàn)了DAP的全量協(xié)議。deepin-IDE 的客戶端和服務(wù)端都是應(yīng)用的該SDK進行開發(fā),據(jù)此可以實現(xiàn)以下功能:

1. 通信功能,包括服務(wù)端的 TCP 監(jiān)聽,客戶端的 TCP 連接等;

2.DAP協(xié)議的封裝,并實現(xiàn)協(xié)議的串行化和解串行化;

3. 提供注冊回調(diào)功能,從而可以在回調(diào)內(nèi)處理各種事件、請求等;

它的層級結(jié)構(gòu)如下:

6f1393c2-7eef-11ee-939d-92fbcf53809c.png


用cppdap可以減少客戶端和服務(wù)端不少工作量,也統(tǒng)一了兩邊的協(xié)議數(shù)據(jù)。而 debugmanager 可以理解為調(diào)試器的抽象,包含所有必要的調(diào)試要素。整體結(jié)構(gòu)如下:

6f266f4c-7eef-11ee-939d-92fbcf53809c.png


左邊是客戶端,右邊是服務(wù)端,內(nèi)部實現(xiàn)如下:


客戶端實現(xiàn)


客戶端包含了兩個個主要功能,一個是和DAP服務(wù)端進行交互,發(fā)送調(diào)試命令或處理返回的數(shù)據(jù);另一個是將DAP數(shù)據(jù)轉(zhuǎn)換后顯示到用戶界面,并響應(yīng)界面發(fā)送的事件。概括起來就包含業(yè)務(wù)模塊、事件模塊、DAP模塊和界面 4 個部分。
業(yè)務(wù)模塊


業(yè)務(wù)模塊包含了插件類、調(diào)試參數(shù)、調(diào)試管理類等,其中插件類負(fù)責(zé)插件加載、初始化、獲取上下文等,調(diào)試管理類用來組合事件、DAP、界面幾個模塊。事件模塊

事件模塊包含兩個子模塊,分別是事件發(fā)送和事件接收,比如頁面跳轉(zhuǎn)事件、添加 移除斷點事件等。DAP模塊


DAP模塊基于cppdap開發(fā),采用層級結(jié)構(gòu),底層是原始DAP協(xié)議封裝,中間層是針對業(yè)務(wù)做的進一步封裝,簡化了向外提供的接口,最上層是對整個調(diào)試功能的整合,包括數(shù)據(jù)緩存、界面元素、命令收發(fā)。

6f469d76-7eef-11ee-939d-92fbcf53809c.png


界面部分 界面模塊包含堆棧界面、變量界面、斷點列表、異步對話框等,用于DAP的數(shù)據(jù)展示。

6f546514-7eef-11ee-939d-92fbcf53809c.png


如上圖所示,灰色部分為DAP客戶端的界面呈現(xiàn)。


服務(wù)端實現(xiàn)



服務(wù)端的功能分為兩個部分,一個是基于cppdap實現(xiàn)命令的收發(fā),另一個是與gdb交互,實現(xiàn)調(diào)試程序的啟動、暫停、退出等一系列動作。
DAP


和客戶端一樣,服務(wù)端也是基于cppdap實現(xiàn)的通信和協(xié)議封裝和解析。調(diào)試工具


和調(diào)試工具的交互是通過進程調(diào)用的方式實現(xiàn),接收進程輸出得到返回信息。如果調(diào)試工具本身支持DAP協(xié)議,則可以直接交互。


至此,本次的分享就到這兒啦!不知道你對deepin-IDE中的調(diào)試功能有所了解了嗎?

溫馨提示,deepin-IDE 還包含很多有意思的功能,如果大家感興趣可以積極反饋,后續(xù)有機會再進行分享。

審核編輯:湯梓紅

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 適配器
    +關(guān)注

    關(guān)注

    8

    文章

    1914

    瀏覽量

    67850
  • IDE
    IDE
    +關(guān)注

    關(guān)注

    0

    文章

    334

    瀏覽量

    46614
  • 調(diào)試技術(shù)
    +關(guān)注

    關(guān)注

    0

    文章

    7

    瀏覽量

    6614
  • GitHub
    +關(guān)注

    關(guān)注

    3

    文章

    465

    瀏覽量

    16359

原文標(biāo)題:解密deepin-IDE:如何實現(xiàn)簡單靈活的調(diào)試技術(shù)?

文章出處:【微信號:OSC開源社區(qū),微信公眾號:OSC開源社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    如何通過DAP協(xié)議訪問內(nèi)部存儲器?

    我想使用 DAP 協(xié)議對 TC38x 系列 MCU 的 pFlash/DFlash 進行編程。 是否有任何記錄了 DAP 協(xié)議詳細(xì)信息的相關(guān)文檔? 如何通過
    發(fā)表于 01-23 07:51

    使用帶有DAP miniwiggler硬件的memtool進行閃存,如何使用memtool進行調(diào)試?

    我正在嘗試使用帶有 DAP miniwiggler 硬件的 memtool 進行閃存。 但是我不知道如何調(diào)試它。 另外,如果它們有任何設(shè)置可以將程序計數(shù)器設(shè)置為我們的應(yīng)用程序內(nèi)存地址,那將非常有幫助。 如何使用memtool進行調(diào)試
    發(fā)表于 01-23 06:37

    【仿真器,不只有J—Link】CMSIS-DAP調(diào)試標(biāo)準(zhǔn)解讀

    得到了openOCD和pyOCD的支持,同樣可以實現(xiàn)jlink上位機的功能。使用u*** hid協(xié)議,向下對于調(diào)試器的實現(xiàn)來說降低了復(fù)雜度,向上對于IDE的集成帶來的好處則是免驅(qū)動,方
    發(fā)表于 04-05 10:35

    怎樣去使用CMSIS_DAP調(diào)試器呢

    關(guān)于STM32調(diào)試器CMSIS_DAP的使用及注意事項說明最近在做了一個DAP調(diào)試器,完全開源的方案,大部分代碼都是由STM32CUBEMX生成的,使用的STM32CubeIDE作為開
    發(fā)表于 03-01 06:15

    RTT Studio什么時候可以實現(xiàn)DAP下載調(diào)試呢?

    RTT Studio什么時候可以實現(xiàn)DAP下載調(diào)試呢?手上只有一個DAP的仿真器,大概什么時候能用上呀?多謝。。。。。
    發(fā)表于 05-11 09:47

    為什么無法在MCUXpresso IDE為導(dǎo)入的cmake項目設(shè)置LinkServer (CMSIS-DAP)調(diào)試

    你好!我無法在 MCUXpresso IDE 為導(dǎo)入的 cmake 項目設(shè)置 LinkServer (CMSIS-DAP) 調(diào)試。是否可以?我找不到任何解決方案。 細(xì)節(jié): 我創(chuàng)建了簡
    發(fā)表于 05-29 08:01

    CoreSight DAP相關(guān)資料

    本指南的目的是讓您更好地了解: ·什么是CoreSight調(diào)試訪問端口(DAP)及其工作原理。 ·什么是接入端口(AP)及其工作原理。 ·什么是ROM表,以及它是如何實現(xiàn)的。 ·使用A
    發(fā)表于 08-25 07:54

    GD32_CMSIS_DAP

    GD32_CMSIS_DAP,有需要的下來看看
    發(fā)表于 07-29 17:08 ?99次下載

    基于OpenOCD和DAP的嵌入式遠(yuǎn)程調(diào)試系統(tǒng)研究與設(shè)計

    統(tǒng)通過OpenOCD向目標(biāo)芯片發(fā)送調(diào)試命令,經(jīng)過JTAG仿真器傳給目標(biāo)芯片的JTACJ接口,并通過DAP生成總線事務(wù)完成調(diào)試操作。經(jīng)實際應(yīng)用表明,該系統(tǒng)支持插入斷點、單步執(zhí)行、讀寫寄存器和存儲空間等
    發(fā)表于 11-23 16:15 ?2次下載
    基于OpenOCD和<b class='flag-5'>DAP</b>的嵌入式遠(yuǎn)程<b class='flag-5'>調(diào)試</b>系統(tǒng)研究與設(shè)計

    DAP022芯片手冊

    DAP022是一個高度集成的PWM控制器。它內(nèi)置了幾個功能來增強sot - 26脫機電源的性能包。在輕載狀態(tài)下,DAP022自動折疊操作
    發(fā)表于 01-02 15:27 ?42次下載
    <b class='flag-5'>DAP</b>022芯片手冊

    介紹DAP Miniwiggler的安裝使用

    DAP Miniwiggler在DAVE3和Memtool的使用
    的頭像 發(fā)表于 07-11 01:21 ?1.2w次閱讀

    ES DAP Viewer用戶手冊

    電子發(fā)燒友網(wǎng)站提供《ES DAP Viewer用戶手冊.pdf》資料免費下載
    發(fā)表于 09-22 14:36 ?0次下載
    ES <b class='flag-5'>DAP</b> Viewer用戶手冊

    完全兼容CMSIS DAP調(diào)試適配器的IBDAP

    電子發(fā)燒友網(wǎng)站提供《完全兼容CMSIS DAP調(diào)試適配器的IBDAP.zip》資料免費下載
    發(fā)表于 11-21 11:01 ?2次下載
    完全兼容CMSIS <b class='flag-5'>DAP</b>的<b class='flag-5'>調(diào)試</b>適配器的IBDAP

    好多人問,必須正式介紹一下:deepin-IDE

    deepin-IDE 并不是突然冒出來的,在內(nèi)部已經(jīng)開發(fā)了多年時間,為什么一直都默默無聞呢?因為這期間都在不斷完善特色功能,并攻克一些技術(shù)難題,還沒有達到非常完善的地步。同時因為設(shè)計人員沒有參與
    的頭像 發(fā)表于 09-04 16:34 ?681次閱讀
    好多人問,必須正式介紹一下:<b class='flag-5'>deepin-IDE</b>

    deepin-IDE舊貌換新顏:從Qt到DTK

    deepin-IDEDeepin Union Code)新版本現(xiàn)已推出,具體更新內(nèi)容如下
    的頭像 發(fā)表于 12-28 09:45 ?900次閱讀
    <b class='flag-5'>deepin-IDE</b>舊貌換新顏:從Qt到DTK