痞子衡嵌入式:飛思卡爾i.MX RTyyyy系列MCU硬體那些事(2.1)- 玩轉板載OpenSDA,Freelink調試器

来源:https://www.cnblogs.com/henjay724/archive/2019/10/14/11671536.html
-Advertisement-
Play Games

本文是i.MXRT硬體那些事系列第二篇,第一篇痞子衡給大家整體介紹了i.MXRT官方EVK,從本文開始痞子衡將細聊EVK上的組件,今天要講的是一個非常經典而且常用的組件 - 板載調試器。如今各大半導體廠商推出的EVK基本都會配置自己家設計的板載調試器,方便客戶開箱即用,不需要自己額外準備模擬器。眾所... ...



  大家好,我是痞子衡,是正經搞技術的痞子。今天痞子衡給大家介紹的是飛思卡爾i.MX RTyyyy系列EVK上板載調試器的用法

  本文是i.MXRT硬體那些事系列第二篇,第一篇痞子衡給大家整體介紹了i.MXRT官方EVK,從本文開始痞子衡將細聊EVK上的組件,今天要講的是一個非常經典而且常用的組件 - 板載調試器。如今各大半導體廠商推出的EVK基本都會配置自己家設計的板載調試器,方便客戶開箱即用,不需要自己額外準備模擬器。眾所周知,在嵌入式開發里調試器的作用是非常巨大的,用好調試器可以事半功倍。那麼恩智浦出品的板載調試器有哪些特點呢?痞子衡將會為你揭秘:

一、背景簡介

  說到i.MXRT系列EVK板載調試器的背景,那真是一段長長的歷史。恩智浦在2015年收購了飛思卡爾,這兩家知名半導體公司在這之前都設計了自己的板載調試器,飛思卡爾是OpenSDA調試器,主要用於Kinetis系列Tower/FRDM開發板;恩智浦是LPC-Link調試器,主要用於LPC系列LPCXpresso開發板。i.MXRT系列是在兩家合併之後新推出的MCU產品,那麼到底要採用哪一種板載調試器呢?設計i.MXRT EVK的工程師也曾糾結過,這個糾結最終也反映到了i.MXRT EVK上。
  i.MXRT系列最先發佈的兩款晶元是RT1050、RT1020,其後是RT1060、RT1015、RT1010、RT1170...,讓我們分別打開它們EVK原理圖找到其中板載調試器介面部分,如下所示:

  早期i.MXRT晶元(RT1050/RT1020)EVK上配置的是OpenSDA調試器,從RT1060以及之後的晶元開始,EVK上板載調試器全部換成了Freelink(其實Freelink就是LPC-Link,在i.MXRT EVK上叫LPC-Link聽起來怪怪的,所以改了個名字),為什麼會從OpenSDA調試器換到Freelink調試器?因為i.MXRT晶元主要是由原飛思卡爾團隊設計的,所以板載調試器第一選擇當然是輕車熟路的OpenSDA,但是Freelink主控晶元LPC4322(雙核CM4+CM0, 204MHz)相比OpenSDA主控MK20DX128(單核CM4, 50MHz)要強大得多,使用LPC4322作為調試器主控不僅性能更佳,未來功能拓展性也更好(君不見SEGGER J-Link從V10開始主控也選擇了LPC4300系列LPC4337),因此高性能的Freelink調試器顯然更適合i.MXRT EVK。
  看起來當前i.MXRT EVK存在兩種不同的調試器介面,不過僅從功能上來說,OpenSDA和Freelink有區別嗎?其實沒有區別,恩智浦出廠為這兩種不同的調試器主控燒錄了相同的固件DAPLink,DAPLink是ARM官方開源的Cortex-M調試器項目,在DAPLink項目主頁上,MK20和LPC4322均在器件支持列表裡,並且ARM官方還為OpenSDA和LPC-Link電路做了I/O級別的相容:

二、核心功能

  上一節講了無論是OpenSDA介面還是Freelink介面的調試器,其實從調試使用角度來說,它們本質上都是DAPLink調試器,其功能特點都取決於DAPLink固件,繼續回到DAPLink項目主頁,可以看到如下功能介紹:

  總體來說DAPLink固件主要有三大功能,第一是CMSIS-DAP協議的線上調試,知名IDE(Keil MDK、IAR EWARM)里都有CMSIS-DAP協議選項;第二是虛擬串口,嵌入式開發里,串口是常用的交互方式,DAPLink使用USB CDC虛擬了串口,為你省去了一個USB轉串口的模塊(如CH340T模塊);第三是拖拽進U盤下載,DAPLink還額外做了一個U盤拖拽下載的功能,方便用戶將應用程式下載到片內/片外Flash里。需要註意的是,虛擬串口與U盤下載功能都是板級相關的,跟I/O連接以及Flash型號綁定了。

三、使用示例

  講完了DAPLink三大核心功能,下麵痞子衡將結合恩智浦官方SDK里的示例工程為大傢具體演示這三大功能。

3.1 準備工作

  • 準備一塊IMXRT1050-EVKB(Rev.A)或者MIMXRT1060-EVK(Rev.A1),假設板載調試器里的DAPLink固件是完好的。
  • 準備一臺PC,最好是Win10系統,如果是Win10以下系統需要手動安裝好 serial port driver,註意要連接EVK上安裝驅動,詳見 安裝註意事項
  • 準備一根Micro USB連接線,一端接上EVK的J14口,另一端連PC,EVK供電方式選擇DAPLink(將J1的Pin5和Pin6連接)。
  • 在PC上安裝至少一個IDE(MCUXpresso/MDK/IAR),痞子衡安裝的是IAR EWARM v8.32.2。
  • 進入 MCUXpresso SDK Builder主頁 下載最新的RT1050或RT1060 SDK開發包,Toolchain全部勾選上。

  一切準備工作就緒,你應該可以看到EVK上電源燈D3顯示黃色,這表明DAPLink供電正常,再打開設備管理器,可以看到如下三處設備,表明DAPLink驅動也在正常工作。

3.2 演示一:線上調試

  首先演示的是線上調試,其實更準確的說是在內部SRAM中調試,即利用板載DAPLink調試器直接將應用程式下載進i.MXRT內部SRAM中,並跳轉到應用程式中單步執行。當然有朋友會疑問,除了在內部SRAM調試,還有在外部SDRAM調試和在外部SPI NOR Flash調試,後兩種不是本小節討論的內容,痞子衡會在後續的文章中再細聊。
  以RT1050-EVKB為例,使用IAR打開SDK里的 \boards\evkbimxrt1050\demo_apps\hello_world\iar 工程,hello_world是SDK里最典型的常式,該常式一共包含6個Project build(不算xx_debug/xx_release區別),其中debug或ram_0x1400_debug是鏈接到SRAM中的工程(.text段在ITCM里,.data段在DTCM里),這兩個build即可用作在SRAM調試,選中debug工程,確認工程Options里的Debugger選的是CMSIS-DAP,然後點擊IAR菜單欄上的“Download and Debug (Ctrl+D)”按鈕,便能進入單步調試。

3.3 演示二:虛擬串口

  繼續演示虛擬串口,RT1050/RT1060 SDK里hello_world常式使能的是UART1(GPIO_AD_B0_12/13),OpenSDA/Freelink主控晶元與i.MXRT晶元的UART連接正是這個,因此DAPLink虛擬出來的串口可直接用於hello_world常式。
  進入hello_world工程單步調試以後,隨便打開一個串口調試助手,COM口設為39(與3.1節里設備管理器里設備號一致),然後直接按F5運行,可以在串口調試助手接收區里看到"hello world."列印出來。如果沒有看到列印信息,請檢查J30/J31(RT1050-EVKB)或J45/J46(RT1060-EVK)是否已連接。

3.4 演示三:U盤拖拽下載

  最後演示U盤拖拽下載,前面講的線上調試是把應用程式直接下載到i.MXRT內部SRAM中,斷電重啟後應用程式就丟失了,而U盤拖拽下載是將應用程式下載到外部SPI NOR Flash中,斷電重啟後ROM會負責啟動SPI NOR Flash中的程式,因此可以實現離線運行。如果你看過痞子衡 《i.MXRT啟動那些事》 系列文章,你應該知道所有類型的應用程式都可以存儲在SPI NOR Flash中,無論是在Flash中XIP執行,還是在SRAM/SDRAM中執行,但是這些需要離線運行的應用程式必須要加上必要的i.MXRT啟動頭(FDCB,IVT, BootData)形成Bootable image才可以存儲在SPI NOR Flash中,而U盤拖拽下載僅適用Bootable image。
  仍以RT1050-EVKB為例,前面說過hello_world一共包含6個Project build,其中flexspi_nor_debug和flexspi_nor_sdram_debug工程可以直接生成Bootable image,因為這兩個Build使能了XIP_BOOT_HEADER_ENABLE,這個巨集決定了evkbimxrt1050_flexspi_nor_config.c中的hyperflash_config結構體常量和fsl_flexspi_nor_boot.c中的image_vector_table、boot_data結構體常量是否會被鏈接進最終的可執行文件。

  痞子衡講過,U盤拖拽下載是跟Flash類型相關的,咱們再打開RT1050-EVKB原理圖,找到其中NOR Flash部分,從原理圖上來看,RT1050-EVKB有兩種類型NOR Flash可選,分別是八線HyperFlash(S26KS512SDPBHI02)和四線QSPI Flash(IS25WP064AJBLE),而預設連接的是八線HyperFlash,SDK常式里的flexspi_nor_xx build使能的啟動頭(FDCB)也正是對應HyperFlash(即evkbimxrt1050_flexspi_nor_config.c文件里的hyperflash_config)。

  在進行U盤拖拽之前,首先需要設置RT1050-EVKB的撥碼開關SW7,從原理圖上看,SW7的3、4位對應Boot Mode,我們需要將Boot Mode設為2'b01,即設置i.MXRT晶元進入Serial Downloader模式,然後重新上電,再進行U盤拖拽下載。為什麼需要這麼做?這是因為如果i.MXRT晶元處於非Serial Downloader模式(比如Internal Boot),板子上電,ROM會嘗試初始化FlexSPI模塊去訪問外部Flash,如果FlexSPI模塊被初始化過一次,這可能會導致DAPLink中的FlexSPI驅動不能正常工作。
  現在讓我們選中flexspi_nor_debug工程,確認工程Options里Output Converter中Output format選擇的是"Raw binary",編譯工程生成可執行文件hello_world.bin,然後將這個bin文件拖拽進名為 "RT1050-EVK" 的虛擬U盤裡:

  U盤拖拽下載已成功,現在讓我們檢驗一下應用程式是否能夠離線運行,首先需要將Boot Mode設為2'b10,即設置i.MXRT晶元進入Internal Boot模式,然後還需要設置i.MXRT從外部SPI NOR Flash啟動,從原理圖上看,SW7的1、2位對應BOOT_CFG[9]、BOOT_CFG[6],我們需要將BOOT_CFG[6]設成1'b0,即從FlexSPI1 NOR啟動,然後再將BOOT_CFG[9]設成1'b1,即FLASH_TYPE選擇010 - HyperFlash 1V8,與EVK上連接的Flash類型保持一致。此時斷電重啟,你應該可以看到hello world離線運行了。

  至於RT1060-EVK的U盤拖拽下載,其實與RT1050-EVKB差不多,只是需要註意的是RT1060-EVK上預設連接的Flash是四線QSPI Flash,SDK常式里的flexspi_nor_xx build使能的啟動頭(FDCB)也對應的是QSPI Flash(即evkimxrt1060_flexspi_nor_config.c文件里的qspiflash_config)。U盤下載成後BOOT_CFG[9]需設成1'b0,即FLASH_TYPE選擇000 - Device supports 3B read by default。

四、更新固件

  講完了DAPLink調試器的功能與使用,最後再介紹一下更新DAPLink固件的方法。那麼我們為什麼需要更新DAPLink固件?我們知道ARM官方一直在維護DAPLink項目,代碼也在不斷地更新,或修複bug或新增功能,使用最新的DAPLink固件總不是壞事。有人可能會說,只要舊的DAPLink固件功能足夠我使用,我就沒有必要更新,確實有一定道理,但出現如下兩種情況,你就不得不更新DAPLink固件:

  • 你為i.MXRT-EVK更換了Flash連接(比如從HyperFlash換到了QSPI Flash),而且你還想繼續使用DAPLink的U盤拖拽下載
  • i.MXRT官方SDK的重大升級,並且DAPLink固件與SDK存在某種聯繫。據痞子衡所知,SDK 2.3.x的時候,DAPLink是可以自動為拖拽進U盤的裸image加啟動頭的,而到了SDK 2.6.x的時候,DAPLink就是直接下載Bootable image。

  現在讓我們試一下更換DAPLink固件,其實操作很簡單,你還記得DAPLink調試器的U盤拖拽下載嗎?其實DAPLink固件的更新也是用U盤拖拽下載的方式,因為DAPLink項目本身包含DAPLink Bootloader和DAPLink固件,下載用戶應用程式我們藉助的是DAPLink固件,而更新DAPLink固件,我們則需要藉助DAPLink Bootloader。
  首先讓我們準備一個DAPLink固件,我們不需要去DAPLink項目主頁自己去編固件,直接進到恩智浦 OpenSDA主頁 ,還是以RT1050-EVKB為例吧,預設DAPLink固件是支持onboard hyper-flash的,我們現在將其換為支持onboard spi-flash的固件,點擊DAPLink v0244 - Supports onboard spi-flash下麵的Download Binary即可下載到k20dx_mimxrt1050_evk_qspi_if_crc_20180419.zip包,將包解壓後裡面即是我們要的固件(.bin格式)。

  有了新固件,這時候需要讓DAPLink進入Bootloader模式,確認J27(RT1050-EVKB)/J43(RT1060-EVK)連接的是Pin1-2,然後按住SW4(RT1050-EVKB)/SW9(RT1060-EVK)按鈕,斷電重啟,如果出現名為 "MAINTENANCE" 的虛擬U盤,即表明進入DAPLink Bootloader模式成功,這時候將新固件拖拽進去即大功告成。

  至此,飛思卡爾i.MX RTyyyy系列EVK上板載調試器的用法痞子衡便介紹完畢了,掌聲在哪裡~~~


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在寫C#代碼的時候,你可能經常會遇到這個錯誤: 在寫C#代碼的時候,你可能經常會遇到這個錯誤: 但如果想避免NullReferenceException的發生,確實需要做很多麻煩的工作。 但如果想避免NullReferenceException的發生,確實需要做很多麻煩的工作。 可空引用類型 Nul ...
  • 本文是MVP Ediwang寫的回憶一個80後的拖控制項的感悟,與君共勉:每一代人都有記憶里的味道。煤球爐、黑白電視機是屬於父母的記憶。而“拖控制項”式編程,啟蒙了無數像我這樣的80後(嗯,89也算80後)。 ...
  • Ubuntu16.04安裝Docker、nvidia docker Docker安裝 1.更換國內軟體源,推薦中國科技大學的源,穩定速度快(可選) sudo cp /etc/apt/sources.list /etc/apt/sources.list.bak sudo sed i 's/archiv ...
  • 本文首發於:微信公眾號「運維之美」,公眾號 ID:Hi Linux。 「運維之美」是一個有情懷、有態度,專註於 Linux 運維相關技術文章分享的公眾號。公眾號致力於為廣大運維工作者分享各類技術文章和發佈最前沿的科技信息。公眾號的核心理念是:分享,我們認為只有分享才能使我們的團體更強大。如果你想第一 ...
  • 最近使用git 管理項目的時候,編譯過程中出現了很多中間文件,今天發現使用 git clean 命令可以很方便進行清除: 保持更新,轉載請註明出處;更多內容請訪問 cnblogs.com/xuyaowen ...
  • linux掛載iso鏡像可以分為兩種,直接掛載鏡像和上傳鏡像文件至伺服器進行掛載 一、虛擬機鏡像掛載 測試時使用虛擬機,此時可以直接在虛擬機的設置中將鏡像文件直接選擇併進行掛載,無需上傳至虛擬機伺服器內。 1、點擊cd/dvd,選擇使用ISO映像文件,瀏覽所需iso文件,並勾選已連接。此時虛擬機桌面 ...
  • Ubuntu 網路配置 安裝 操作系統之後,為了通過 連接主機,或者連接其他主機。需要進行如下網路配置和ssh服務配置。 1 網路配置 1.1 修改網路配置信息 ,在其中找到對應網卡進行修改 輸入以下內容 接下來配置 打開配置文件進行修改 ,輸入以下內容: 1.2 重啟機器 這是因為 之後,發現網路 ...
  • 假如當前存在的問題是: /bin/bazel 存在命令的版本為 0.18.0 /home/yaoxu/bin/bazel 存在的命令的版本為 0.10.0 我們應該如何配置環境變數,來確定執行哪個版本呢? 通過我的實驗,環境變數是逐層覆蓋的,越在後面的環境變數優先順序越高;如果系統中預設是 0.18. ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...